<?xml version="1.0" encoding="UTF-8"?>
<!-- generator="FeedCreator 1.7.6(BH)" -->
<rss version="2.0">
    <channel xmlns:g="http://base.google.com/ns/1.0">
        <title>Planet Maemo: category &quot;feed:fb2e01f2b05f173de4f8ef523cd2a4d2&quot;</title>
        <description>Blog entries from Maemo community</description>
        <link>http://maemo.org/news/planet-maemo/</link>
        <lastBuildDate>Sun, 24 May 2026 02:17:48 +0000</lastBuildDate>
        <generator>FeedCreator 1.7.6(BH)</generator>
        <language>en</language>
        <managingEditor>planet@maemo.org</managingEditor>
        <item>
            <title>Restructure MeeGo : By Installments</title>
            <link>http://mer-l-in.blogspot.com/2011/08/restructure-meego-by-installments.html</link>
            <description><![CDATA[
I've just published a series of articles that reflect my thoughts on<br />
improving MeeGo and setting some directon. This outline should help navigate.<br />
<br />
<ul><dt> <a href="http://mer-l-in.blogspot.com/2011/08/restructuring-meego-executive-summary.html ">Restructuring MeeGo : Executive Summary</a><br />
<dd> Where should MeeGo be targeted?<br />
<br />
<dt> <a href="http://mer-l-in.blogspot.com/2011/08/meego-core-focus.html ">MeeGo Core : focus</a><br />
<dd> What should MeeGo Core be delivering?<br />
<br />
<dt> <a href="http://mer-l-in.blogspot.com/2011/08/meego-systems-and-processes.html ">MeeGo: Systems and Processes</a><br />
<dd> What else should MeeGo be delivering?<br />
<br />
<dt> <a href="http://mer-l-in.blogspot.com/2011/08/meego-evaluating-meego.html ">MeeGo : Evaluating MeeGo</a><br />
<dd> How do we support MeeGo evangelists?<br />
<br />
<dt> <a href="http://mer-l-in.blogspot.com/2011/08/meego-lead-by-example.html ">MeeGo : Lead by example</a><br />
<dd> How we should walk in our customers shoes.<br />
<br />
<dt> <a href="http://mer-l-in.blogspot.com/2011/08/meego-and-hacker-community.html ">MeeGo and the hacker community</a><br />
<dd> How do we embrace the hacker community?<br />
<br />
<dt> <a href="http://mer-l-in.blogspot.com/2011/08/meego-infrastructure.html ">MeeGo : Infrastructure</a><br />
<dd> Pragmatics... what services should we run?<br />
<br />
<dt> <a href="http://mer-l-in.blogspot.com/2011/08/meego-restructured.html ">MeeGo :Restructured</a><br />
<dd> How could we approach this?<br />
</ul><span class="net_nemein_favourites">4 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=c680a66cc06c11e087959fb6a0d8391c391c&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/c680a66cc06c11e087959fb6a0d8391c391c/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=c680a66cc06c11e087959fb6a0d8391c391c&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/c680a66cc06c11e087959fb6a0d8391c391c/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Sun, 07 Aug 2011 00:10:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-c680a66cc06c11e087959fb6a0d8391c391c</guid>
        </item>
        <item>
            <title>MeeGo DE - *THAT* is how you do it ....</title>
            <link>http://mer-l-in.blogspot.com/2011/04/meego-de-that-is-how-you-do-it.html</link>
            <description><![CDATA[
Over the past several weeks I've been hitting one concept over and over again: "reference".<br />
<br />
I'm talking here about the idea of a reference implementation; and I don't mean something so comprehensive that it's almost useless... rather a manageable set of information aimed at easing entry into a project.<br />
<br />
I've been accused of being a bit long-winded :) So let me offer a short proposal:<br />
<br />
<blockquote>Justify the DE project by extending the "DE Project Vision" to include "Be a reference vendor". Extend the deliverables to include documentation about processes, organisational layout and tool usage. Test, challenge and improve the MeeGo <-> Vendor interface.<br />
</blockquote><br />
I put this to Carsten and Jukka a while ago and they were very positive about it - so if it sounds intriguing then here's my thinking:<br />
<br />
MeeGo is (or should be) aimed at vendors. So what is a vendor? Or perhaps, in this context, what aspects of a vendor are we interested in?  I think the following three areas are relevant:<br />
<ul><li> The Veneer ("Value Add Layer" if you're marketing a device)<br />
<li> Hardware Adaptation<br />
<li> Contributing Back (A phb may prefer to hear: "Influencing MeeGo's direction")<br />
</ul>
As a vendor newly arriving at MeeGo I am going to need to work in one or more of these areas - so what do I do? What systems do I need? How do I setup teams, OBS projects? How do they interact with MeeGo? What testing processes should I use? What tools and systems are already available? How do I avoid re-inventing the wheel? How do I link to the core OBS? How do I get a feature included in the core?
<p>
Answering these questions correctly is vital if a vendor is to effectively assess the cost of operating in the MeeGo ecosystem; and that assesment should influence their decision to work with MeeGo. Quite simply: the lower we can make barriers to entry, the more vendors will join MeeGo. Not only that; if we can identify and resolve problems with them then that will improve satisfaction. It is also worth remembering that many vendors will be new to working in the open - using the reference project may help to overcome 'shyness' be it cultural or confidentiality based.
<p>

This is not just about vendors either. MeeGo as a project has to support the vendor ecosystem - and whilst we do want a diverse community out there, we don't want to support needless variations in process or even terminology. Providing a "suggested way of working" and ensuring that all our tools and processes work with it means that we can minimise the cost of these interactions from MeeGo's point-of-view.
<p>

MeeGo also provides interfaces to these vendors - but has no real mechanism for reviewing or testing them (although I'd like to address that in my <a href="http://sf2011.meego.com/program/sessions/bof-fixing-meego-setting-open-vendor-ecosystem">BoF session at MeeGo 2011</a>). For example
<ul><li> the handling and communication of significant API changes during development;<br />
<li> simple operational communication;<br />
<li> how are vendor products supported *after* a MeeGo release? <br />
<li> how should vendors operate near releases (forks);<br />
<li> I need a change to a MeeGo component : it's not going to be accepted this release; what do I do?<br />
</ul>

DE operates in all of the layers I mentioned but it's not clear what activity is related to what layers. I'd like to see:

<ul><li> DE provide some clarity around the three roles: particularly a review of the OBS project structure and role-specific processes.<br />
<li> Clear product-oriented and release-managed deliverables in the veneer layer with testing and automation<br />
<li> Documentation of a requirements driven approach to MeeGo core contributions<br />
<li> Documentation of a requirements driven approach to hardware adaptation<br />
</ul><br />
Of course the objective of these deliverables is to support new vendors and contributors to DE/MeeGo; not to overburden the contibutors. bearing in mind that<br />
<br />
I think the success criteria in this ares would be if any organisation can quickly and easily setup a new initiative to thoroughly evaluate MeeGo for a new product.<br />
<br />
There are other areas where we can support vendors by pursuing this model; the use of the MeeGo community OBS mimics the separation between the MeeGo OBS and the vendor's internal OBS. This allow issues dealing with the relationship to MeeGo to be examined openly: what is the recommended link to the core OBS; how are vendors impacted by downtime; what's the best approach to provide a reasonably stable MeeGo base to build the 'veneer layer' on during a sprint whilst still allowing the vendor to be aware of emerging issues in Trunk.<br />
<br />
MeeGo also has other system tools: BOSS, REVS, IMG and OTS are freely available and were designed at Nokia using their product building  expertise - how can we offer these to the MeeGo vendor ecosystem to once again reduce cost and probably more importantly: time to market. These tools are used in MeeGo core - but they are not documented or discussed (and are probably not relevant to vendors anyway since their business goals are different). Using them in DE allows increased public scrutiny.<br />
<br />
So here's another success criteria (for both DE and MeeGo tools): is DE using MeeGo tools to deliver their product? Do the managment reports from REVS provide useful data? Is BOSS automation effective and sufficiently low-overhead? Does OTS work in resource-limited environments?<br />
<br />
Finally - you have to ask what the point of the DE project is? I think if it can be held up as an example of "How to work with MeeGo" and has real deliverables beyond supporting an aging device then it provides a tangible benefit to everyone in MeeGo.<br />
<br />
A little post-script too : whilst I've focused on DE here this concept applies to a lot of what's done around MeeGo. Opensource succeeds because we stand on the shoulders of midgets - a *lot* of midgets. We should each aim to ensure that when we 'deliver' something to the opensource community we ask "how easy have I made it to let someone else improve on this?"<span class="net_nemein_favourites">6 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=b4073cd070cb11e096a1d9e7433b4f704f70&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/b4073cd070cb11e096a1d9e7433b4f704f70/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=b4073cd070cb11e096a1d9e7433b4f704f70&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/b4073cd070cb11e096a1d9e7433b4f704f70/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Wed, 27 Apr 2011 12:48:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-b4073cd070cb11e096a1d9e7433b4f704f70</guid>
        </item>
        <item>
            <title>What now for MeeGo?</title>
            <link>http://mer-l-in.blogspot.com/2011/02/what-now-for-meego.html</link>
            <description><![CDATA[
So Nokia has  dramatically reduced commitment to MeeGo  and has cited,
amongst other thinks, MeeGo's inability to deliver a focussed baseline
with sufficient speed. I happen  to agree with this failure (and given
Nokia  was a  significant part  of  MeeGo's management  I don't  think
there's a blame issue - more a how do we fix it issue)

<h2>Assumptions and observations:</h2>

<ul>
<li> MeeGo is intended to provide a viable but focussed baseline upon
    which vendors can build compliant products; not to be an expansive
    and 'complete' linux distribution.

<li> MeeGo has limited dedicated resourcs and focusing them on a
    reduced MeeGo core will improve quality.

<li> MeeGo's main customers are not end-users - they are device
    vendors : they should be the focus of our core engineering team's
    design, delivery and QA effort.

<li> MeeGo core does not appreciate the difficulties a vendor has in
    tracking MeeGo;

<li> A visibly secure development model is important to the perceived
    integrity of MeeGo - so visibly restricting write access to the
    core is important.

</ul>

<h2>Proposal:</h2>

<ul>
<li> MeeGo Core is confirmed as not being a linux distribution

<li> An open MeeGo project (openMeeGo?) is created on the community
    infrastructure to provide a reference MeeGo distribution

<li> Packages not *essential* to the delivery of a compliant MeeGo
    Core are moved into the community OBS (emacs, vi etc - maybe even
    the reference UXes) where they are available for use by
    development teams and end users.

<li> "openMeeGo" acts as a reference vendor and provides a forum for
    reviewing and improving the processes MeeGo uses to communicate
    releases

<li> MeeGo community (which includes core developers) has a
    significantly lower barrier to entry.

</ul><span class="net_nemein_favourites">10 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=700c491c36b511e09c9a61df60a2e888e888&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/700c491c36b511e09c9a61df60a2e888e888/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=700c491c36b511e09c9a61df60a2e888e888&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/700c491c36b511e09c9a61df60a2e888e888/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Sat, 12 Feb 2011 09:59:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-700c491c36b511e09c9a61df60a2e888e888</guid>
        </item>
        <item>
            <title>MeeGo Community Development: Apps, Surrounds and the Community OBS</title>
            <link>http://mer-l-in.blogspot.com/2011/01/meego-community-development-apps.html</link>
            <description><![CDATA[
So... lets say we have some device that run MeeGo; what else can
it do? Where are the apps?
<br/><br/>

<h3>Apps - the area formerly known as "Extras"</h3>

Borrowing <a href="http://lists.meego.com/pipermail/meego-community/2010-December/003021.html">Andrew Flegg (Jaffa)'s mission statement</a> for MeeGo Community
Apps: we need to ensure a vibrant and quality area for community open
source software.  <br/><br/>

So MeeGo Apps is the community app store and follows on from the
succesful <a href="http://maemo.org/downloads/Maemo5">Maemo Extras.</a> <br/><br/>

It allows app developers to build MeeGo compliant (and other) apps and
distribute them to users.  <br/><br/>

What makes Apps different from a 'random repository' is the community
QA process that is applied; the objective of this QA process is to
permit users to trust the apps and to deliver a collection of apps
that a commercial vendor could enable on a shipping device (as Nokia
did with 'Maemo Extras' on the N900).  <br/><br/>

Clearly then, there needs to be some processes (and automation) to
define how QA checks are carried out and what to do when certain
events occur. We already have a process automation sytem (called BOSS
- it's is being developed by Nokia and is essentially an integration
of various OSS libraries) - now we need to decide what processes and
criteria we use to manage and promote apps. Initially I suggest we
start with <a href="http://wiki.maemo.org/Extras_repository_process_definition">the Maemo Extras process</a> and refine that.  <br/><br/>

When we talk about process we are also talking about policy. I've
discussed this below and quite a few of the points apply to Apps.<br/><br/>

Now, it's not yet clear what OBS targets Apps should build
against. Currently <a href="https://build.pub.meego.com/project/list_public">we have</a>:
<ul>
<li> MeeGo:1.1:Core
<li> MeeGo:1.1:Core:Handset
<li> MeeGo:1.1:Core:IVI
<li> MeeGo:1.1:Core:Netbook
</ul>

These correspond to the MeeGo Core and then a number of UXes. However
there are plans to consolidate them in the main MeeGo OBS - but how
should the Apps area look?  Should a handset user be presented with apps
which were only intended to run on a netbook? OTOH is this anything to
do with the repo and build target - should it be determined by
metadata and selectively presented by the download application?
<br/><br/>

Well, until this is resolved, an app developer simply needs to enable
each target that the app supports to make it available in that
repository.<br/><br/>

I think the discussion up to this point is fairly simple and
uncontentious; we can start to address the issues mentioned and 
<a href="http://wiki.meego.com/Community_Application_Support">just get on with it</a> and start to deliver MeeGo Apps :)<br/><br/>

However, as mentioned, the Apps area allows both MeeGo-compliant and
MeeGo-extra applications. <i>MeeGo-compliant</i> apps are those which only
use libraries in MeeGo core/UX; <i>MeeGo-extra</i> apps have a little extra
open-source goodness sprinkled in... Surrounds.

<h2>MeeGo: The Linux Distro</h2>

Before I tackle 'Surrounds' lets step back a little:<br/><br/>

Since MeeGo was announced around a year ago I've been interested in
how development happens around MeeGo as well as in the centre. The
following is intended to be a discussion document; there are clearly
some large gaps and I expect some of my proposals to be shot down -
but I really hope that only happens when better ones are proposed!
<br/><br/>

In order to address this I think it's important to ask... what is the
point of MeeGo? Well, IMHO, MeeGo is primarily a modern linux baseline
upon which commercial mobile computer products can be delivered.
MeeGo's main customers are not end-users - they are device vendors;
*they* should be the focus of our core engineering team's design,
delivery and QA effort.  <br/><br/>

So MeeGo clearly has a focused development area with the main OBS
supporting the development and delivery of the MeeGo core system
software and reference UXes.  <br/><br/>

Of course MeeGo is also capable of being a wonderful and open linux
distro in its own right. However I personally think that to be a
success, the MeeGo core needs to focus on the primary goal and allow
more of the "linux distro" side to be managed as a surrounding
project.  <br/><br/>

Incidentally, in my day job I care a lot about how MeeGo presents
itself to us as a vendor. I think it would be a good thing for MeeGo
to have it's own "reference product" built around the core that it
offers to vendors. This would expose issues like:
<ul>
<li> How does MeeGo communicate significant upcoming changes to it's
customers?
<li> How do we deal with package naming clashes?
<li> How much of MeeGo is needed for compliance vs the parts that are
needed to make a reference implementation?
<li> With more than one community product: how connected are devices?
</ul>

So, 'Surrounds' is a proposal that aims to provide a collection of
open source libraries, tools and applications that support the
building of collaborative bazaar-style applications and yes, maybe
even MeeGo distributions. <br/><br/>

Whilst I don't think this is an immediate change, I do think it's an
interesting direction for MeeGo to take that may allow more focus on
the core deliverables.
<br/><br/>

In the meantime lets look at this "extra open-source goodness" I
promised:

<h2>Surrounds</h2>

As we know, the open source world is a world of sharing; we regularly
stand on the shoulders of our peers and it's considered very bad taste
to just 'bundle' a library into a monolithic application. (Notice how
I didn't mention any kind of compliance programme by name - aren't I
good!) <br/><br/>

Surrounds provides a collection of libraries and tools that encourages
this <b>best practice</b> way of working in MeeGo and delivers <i>MeeGo-extra</i>
apps. The most obvious area would be for languages like perl, python
and ruby. These languages have large numbers of useful libs that
clearly are not going to be present in core MeeGo. Of course there
will be many other tools and applications that would also be at home
in Surrounds. <br/><br/>

Over time, packages may migrate into core MeeGo and equally, some are
going to be deprecated. Hopefully Surrounds makes both of those
actions a little easier but we do need to decide how we handle
deprecation/promotion of applications/libs between core and Surrounds.
<br/><br/>

There are many complexities when dealing with a collection of packages
like this:
<br/><br/>

<h3>QA and Releases</h3>

The fundamental question is "How is Surrounds QA'ed and released?".
<br/><br/>

This is a significant undertaking and needs a lot of resource and
users. This alone means that Surrounds should probably start off
slowly and ramp up as MeeGo users and developers arrive in larger
numbers. The important thing is to prepare for the main issues we're
likely to face.
<br/><br/>

I propose that Surrounds is actually only populated on an "as needed"
basis; tools can be submitted directly but libraries have to be needed
by a tool or by an application submitted to the Apps area.
<br/><br/>


<h3>Upgrades and concurrent installations</h3>

For example: let's look at a device that has MeeGo 1.2 installed on it
and an application "Wowee" built against an imaginary libvisual-1.0
which is in the Surrounds-1.2-A stable release of Surrounds.
<br/><br/>

9 months later many libraries have been updated and developers
want to use the latest versions... it's time to release a new
version of Surrounds-1.2. Sadly libvisual is up to version 1.0a
with a minor tweak which would break Wowee; not only that but
the Wowee developer has gone awol (so there's no-one to test
it) and no-one's stepped up to update it. Even worse there are
50,000 users using Wowee which is working like a dream.
<br/><br/>

Looking at the large number of apps in Maemo Extras I think
problems like this will arise and are beyond the resources of
the community to handle at this point.
<br/><br/>

A technical solution may be that when Surrounds-1.2-A is installed it
goes into /opt/surrounds/1.2-A/... and any apps use the appropriate
path to find their dependencies.  <br/><br/>

This allows apps that use libraries from Surrounds-1.2-A and
Surrounds-1.2-B to be installed concurrently even if they use
different versions.
<br/><br/>

I'm not sure how Surrounds-1.2 handles upgrades from MeeGo 1.2 to 1.3.
<br/><br/>

The message however is that there are many issues like this that it
would be good to identify in advance. Just ask a maemo developer about
the <a href="http://wiki.maemo.org/Opt_Problem">"optification"</a> hack :)

<br/><br/>
<h3>Porting vs Maintaining : A MeeGo partner</h3>

When it comes to populating Surrounds we need to look to the larger
linux ecosystem.<br/><br/>

Some tools and libraries will have comitted maintainers who have time
to monitor their packages and fix bugs and security issues in a timely
manner.  <br/><br/> This is the classic distribution 'maintainer'
role.  <br/><br/>

Some libraries won't. Developers will simply need a particular library
and 'grab' a source rpm that looks like it's good-enough. They throw
it at the OBS and a few minutes later have an installable package for
their application. This is what happens in Maemo Extras.  <br/><br/>

I call this activity 'porting'.  <br/><br/>

The problem arises when another developer does the same thing a
few weeks later with a slightly different version of the
package. This may cause the original app to fail.
<br/><br/>

Equally, none of those developers want to commit to maintaining
the library. So when a security issue arises, no-one is ready
to update the package.
<br/><br/>

I'm actually a little concerned about prolific porting - and sadly
this is the bit that gets the fame and glory : "look how many packages
he's ported". The truth is that this doesn't bode well for MeeGo in
the long run.  <br/><br/>

My suggestion for this group of packages is to nominate an upstream or
partner distro with a good security record and a wide base of
packages. Surrounds releases would closely track this distro (and will
likely differ from core MeeGo). Packages taken from this distro would
be fast tracked as 'ported' rather than 'maintained' and only minimal
packaging changes would be allowed. This would allow Surrounds to
leverage the partner-distro's security efforts (and hopefully offer
benefits to the partner in return).  <br/><br/>

For obvious reasons I propose openSuse as the partner distro. (For the
record I'm a Debian guy - but lets be sensible here!) <br/><br/>

For equally obvious reasons this is a political minefield :)

<br/><br/>
<h3>Some random policy questions:</h3>

There are a lot of policy considerations for the community; some I
wrote in a bit of rant (forgive me Shane). Some apply to Surrounds and
Apps, some to the OBS in general <br/><br/>
<ul>
<li> Licenses: OSI only licenses? GPL3 (considering the "promotion
to core" target).

<li> People: What's the process for absent devs?  If someone says
"hey, lbt, let me upload a new version of that library Shane
uploaded" ... do I just let her?  What if there's a security
issue in it?  What if you've not been seen in 3 months? Do
maintainers need to demonstrate reliability to handle timely
updates?

<li> Legal : Do we accept mp3 players? libdecss? What about porn?
What about apps with a rather rude splash screen?  Any patent
issues? (Don't forget the system physically lives in the
"land of the free" so is subject to state seizure by the
RIAA).

<li> Commercial: I've had commercial organisations enquire about using
the community OBS. I've had them ask to sponsor it. How do we deal
with this? My first reaction is "no commercial work"... but why not?

<li> Quality: Do we insist on a valid bugtracker being identified
for all Surrounds packages?  Must it proxy via a bmc#?

<li> Packages scope: Where's the ITP?

<li> Can we rebuild MeeGo with some different compiler flags (think
non-ssse3 ... yay ... I can run MeeGo on my AMD desktop at last!)

<li> Do we sign any of the community repos? What does that mean?

<li> Acceptable Use Policy : at what point do we ask users to stop
doing what they're doing?

<li> Non-MeeGo targets? When Smeegol becomes Sogmeel will we allow it
to be a target?
</ul>

Again the message is "there's a lot to think about".

<h2>The Community OBS</h2>

We have a <a href="http://build.pub.meego.com">MeeGo Community OBS</a> already; and it builds apps for MeeGo.
<br/><br/>

It is currently managed by Niels Breet (X-fade) and I (lbt) - but we
need more help. In part this whole post is a way to structure what
we'd like to achieve and to make it easier to identify tasks.

<br/><br/>
<h3>Structure</h3>

So what project structure do we need? We've not assumed MeeGo at the
top level namespace to allow us to support additional distros such as
Fremantle and hopefully others.
<br/><br/>

One common use for structure is to provide a QA route. Packages go
from some sub-project in a developer's home: area to a 'Team' area and
then into a Testing area. Each transition is subject to policy and
quality checks. Defining these workflows and structures correctly will
make life easier.

<br/><br/>
<h3>Team Areas</h3>

It makes sense for teams to have collaboration for things like KDE,
Gnome, Python, LibreOffice, Emacs etc. This would allow more thorough
testing to take place before releasing either to Surrounds or Apps
<br/><br/>

However, what's needed to form a team? Can anyone just step up and
claim Team:KDE or should we ask for some relationship with upstream?
Do we just want to assess a proposal? Who does the assesment? Do we
announce this and give time for the community to raise objections or
considerations?<br/><br/>

<br/><br/>
<h3>PPAs</h3>

The general policy for *home* projects is "OSI, nothing illegal and
don't take the piss". We may (or may not) need a more formal one :)
<br/><br/>

Certainly these PPAs offer developers a huge amount of freedom. They
can start by uploading and building a package in a "home" directory
(which can have a structure underneath it for multiple projects). This
will allow them to build against any of the main targets; any
group/community projects or even any other community member home
projects. Oh, and they can use each others code as a baseline
too. Once built the packages are automatically published to a repo on
the community downloads server.
<br/><br/>

AFAIUI this is a lot like the Ubuntu PPA solution (hence the heading).
<br/><br/>

At that point developers can stop if they want. They have a complete
set of repositories (1 per subproject). No painful QA processes for
them and no 'fragmentation' for the MeeGo community. But equally these
repo(s) will needed to be manually added to a device in order for it
to appear in any apt-get/zypper/yum etc. Oh, and the Apps downloader
team really should pay attention here.
<br/><br/>

A huge benefit here is that to for a user to get at a development
version of an application they use a specific repository, not a
mishmash of randomly unstable packages (like the Maemo Extras-devel
area).

<br/><br/>
<h3>MeeGo Targets</h3>
What MeeGo targets do we support?
<br/><br/>

MeeGo 1.0? Really? Does anyone use that?
<br/><br/>

MeeGo 1.1 and above make sense. But what architectures? As released is
fine - but what if there are community rebuilds of non-ssse3?

<br/><br/>
Also, when MeeGo releases distro updates, do we just rebuild all apps?
What happens to QA at this point?

<br/><br/>
<h3>MeeGo Snapshots</h3>

One area to look at is how often we import MeeGo snapshots - and incur
the rebuild cost for any projects targetting them.
<br/><br/>

<br/><br/>
<h3>MeeGo Rebuilds</h3>

Frankly I'm a bit fed up that after a year I can't run MeeGo on my
desktop. It has an AMD phenom chip and an ATI card - both well
supported in the opensource world. It's time to build a community
MeeGo :)
<br/><br/>

Do we need a community version targetting the DublinBook? What about
the O2 Joggler? Are there any policy issues here? Can anyone ask for
this - there's potentially a lot of resource tied up doing this kind
of rebuild.

<br/><br/>
<h3>Surrounds</h3>

What projects are needed in the Surrounds area?  Certainly some
unstable->testing->stable cycle makes sense; but this is not likely to
be finalised until the workflow is understood.

<br/><br/>
<h3>Fremantle</h3>
The Fremantle migration. Mmmm. Well it might happen at some point :)


<h1>Actions and Ideas</h1>

<ul>
<li> Establish a task-force/group to coordinate and deliver activity and
to act as a communications hub.
<li> Design and implement OBS project structures and targets for Surrounds,
Apps, Teams and (suggestions for) home areas
<li> Design and communicate process/policy for putting packages into
these projects and migrating them
<li> How do packages move from Community OBS into MeeGo core
<li> Implement and automate stuff
<li> Structure and enrich the outstanding issues outlined above
<li> Design project structures
<li> Work up a proposal which sees MeeGo split into Core and Distro
<li> Copy this list into a Wiki so it's actually useful
</ul><span class="net_nemein_favourites">10 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=c39c796a29b511e0acec71d7aaed34af34af&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/c39c796a29b511e0acec71d7aaed34af34af/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=c39c796a29b511e0acec71d7aaed34af34af&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/c39c796a29b511e0acec71d7aaed34af34af/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Thu, 27 Jan 2011 01:19:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-c39c796a29b511e0acec71d7aaed34af34af</guid>
        </item>
        <item>
            <title>Open Letter / Proposal to allow Maemo on the MeeGo Community OBS</title>
            <link>http://mer-l-in.blogspot.com/2010/06/open-letter-proposal-to-allow-maemo-on.html</link>
            <description><![CDATA[
This is an open letter to the whole MeeGo community and on behalf of the Maemo development community. The purpose of this letter is to ask the MeeGo community for their permission to bring Maemo build targets (currently Fremantle eventually Harmattan, Diablo, Chinook?) to the MeeGo Community OBS and to ask the Maemo development community for their support in this project.<br />
<br />
*<a href="http://lists.meego.com/pipermail/meego-community/2010-June/001041.html">Please discuss on meego-community mailing list</a>*<br />
<br />
I would like to emphasise that this is a Maemo Community initiative and is not being pushed by Nokia.<br />
<br />
At this point we are not aware of any similar initiatives related to the Moblin community but we would fully support any that arise.<br />
<br />
The Maemo community has built up around Nokia devices which, in many ways, are amongst the most open devices available in their class. There is a passion for openness in the Maemo community and we know that the future for this family of devices lies with MeeGo.<br />
<br />
Many of us are looking forward to MeeGo and are keen to transition as smoothly as possible.<br />
<br />
However our devices are not fully open and developing for them has dependencies on vendor proprietary binaries which would need to be available on the build service. This would mean putting closed binaries on the MeeGo OBS and having a part of the MeeGo Community OBS functionality being 'restricted' to Maemo developers.<br />
<br />
Naturally we recognise and respect that MeeGo is an open source project and there may be ideological issues in allowing closed binaries into the ecosystem (even though they're just for build/linking). We also recognise the risk of "opening the door" to closed binaries and suggest that this arrangement could be agreed as a one-time "grandfathering in" (http://en.wikipedia.org/wiki/Grandfather_clause) situation for the Maemo community.<br />
<br />
However we also feel that the benefits of supporting a smooth transition for the vibrant Maemo development community would be worthwhile both for MeeGo and Maemo:<br />
<br />
<ul><li>developers would be able to use the OBS' natural ability to target Fremantle, Harmattan and MeeGo from a single location. This would bring more developers and their applications to MeeGo sooner. </li>
<li>many of the same people in the Maemo and MeeGo community teams look after the Maemo Autobuilder and the MeeGo application OBS. Our limited volunteer time would be used more effectively on a single platform instance.</li>
<li>resources earmarked for Maemo could be added to the MeeGo estate and would naturally be used at peak efficiency as Maemo demand decreases and MeeGo demand rises.</li>
<li>new Maemo community Quality Assurance processes would evolve around the shared OBS and could assist the development of MeeGo QA processes.</li>
</ul><br />
and perhaps most important of all:<br />
<br />
<ul><li>users of existing devices could expect a significantly longer maintainable life from products built on a consolidated build service and could look forward to their applications being available on MeeGo as soon as devices become available.</li>
</ul><br />
The maemo.org buildservice already has a 'proof of concept' instance of the OBS which allows the Fremantle target to co-exist with a MeeGo target and we already intend to use this as a basis for the MeeGo community OBS.<br />
<br />
The proposed solution *must* allow MeeGo community users to use the MeeGo Community OBS without any reference to Nokia closed binaries; this facet of the service should be entirely optional.<br />
<br />
Equally the legal issues around the closed binaries require an EULA related to demonstrated possession of a relevant device. This can be handled in a similar manner to the Maemo Autobuilder service; ie registration of a serial# to a developer account.<br />
<br />
The proposal therefore is:<br />
<br />
<ul><li>To provide the closed binaries as a build-target repository (probably DoD for those who know and care) on the community OBS.</li>
<li>To grant ACL based access to this repository based on acceptance of an EULA</li>
<li>To *not* require any such EULA for 'MeeGo-only' accounts on the service</li>
</ul><br />
I've run this by Tero Kejo in Nokia and he's very supportive of the idea.<br />
<br />
From:<br />
<br />
David Greaves / lbt<br />
&nbsp;&nbsp; Community Member and build systems guy.<br />
Niels Breet / X-Fade<br />
&nbsp;&nbsp; maemo.org webmaster and autobuild owner   <br />
Carsten Munk / Stskeeps<br />
&nbsp;&nbsp; maemo.org distmaster<br />
Andrew Flegg / Jaffa<br />
&nbsp;&nbsp; on behalf of the Maemo Community Council<span class="net_nemein_favourites">39 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=dcc592fc794b11dfb52d2b1479143b9f3b9f&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/dcc592fc794b11dfb52d2b1479143b9f3b9f/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=dcc592fc794b11dfb52d2b1479143b9f3b9f&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/dcc592fc794b11dfb52d2b1479143b9f3b9f/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Wed, 16 Jun 2010 14:18:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-dcc592fc794b11dfb52d2b1479143b9f3b9f</guid>
        </item>
        <item>
            <title>OBS and Fremantle ... huge success :)    and HELP!!!!</title>
            <link>http://mer-l-in.blogspot.com/2010/05/obs-and-fremantle-huge-success-and-help.html</link>
            <description><![CDATA[
As you may know I recently volunteered to setup a community OBS in my "spare time" (hah, right!). This is a progress report because I've reached a significant milestone... the following 193 applications have been built from 'Extras' most on both ARM and X86:<br />
<br />
<span style="font-size: small;"><blockquote>accdisplay, acl, actman, adblock-plus-1.0, adflashblock-css, alienblaster, anarchism, attitude, attr, audiofile, avahi, battery-eye, belltower, blubbels, bluetooth-dun, bluezwitch, brainparty-data, burgerspace, catorise, clutter, clutter-gtk, copernicium, crimson, currencyconverter, datetoday-home-widget, dbus-python, de-lite, dialcentral, doom-wad-shareware, easy-deb-chroot, easypark, ejpi, fapn, feedingit, feedparser, flac, flatzebra, fm-boost, fmradio, freecell4maemo, fschedule, fuse, gboggle, glibmm2.4, glogarchive, gnome-python, gonvert, goocanvas, gpe-icons, gpodder-icon-theme, greekiradio, gst-plugins-good0.10-flv, gst-plugins-good0.10-mkv, gst-plugins-good0.10-ogg, gst0.10-python, gstreamer0.10-ffmpeg, gtk+extra2, gweled, headphoned, healthcheck, hex-a-hop, host, irssi, jamaendo, json-glib, kernel-power-settings, libart-lgpl, libcap, libdaemon, libevent, libffi, libgnomecanvas, libgnomeprint, libgtkhtml2, libliqbase, libmad, libmicrofeed, libmodplug, libraw-lite, librsvg, libsidplay, libsigc++-2.0, libsoup2.26-1, libxinerama, liqflow, lirc, lybniz, lzma, lzo2, madbomber, maemo-optify, mafw-lastfm, mancala, mastory, masudoku, mauku, mclock, meanwhile, mediabox, microfeed, microfeed-providers-unstable, microfeed-utils, milkyway-wallpaper, mirror, mplayer, mspede, mutagen, mygpoclient, n900-fmrx-enabler, n900fly, nako, ncalc, nmap, notify-python, omweather, openvpn, openvpn-applet, panucci, pedometerhomewidget, pexpect, polipo, poppler, proximityd, pycairo, pycurl, pygame, pygobject, pygtk, pygtkeditor, pyinotify, pymaemo-optify, pypianobar, pyrecipe, python-central, python-dbus, python-evolution, python-facebook, python-gdata, python-gtkhtml2, python-imaging, python-location, python-numeric, python-support, python-twitter, python-xml, python-ystockquote, qtsixa, quickbrownfox, quicknote, recaller, reflect, rfk, rmz-helsinki-wallpaper, rmz-senaatintori-wallpaper, rootsh, rsync, sdl-net1.2, sdl-ttf2.0, sdlgfx, sdlpango, sense, sgt-puzzles, shortcutd, sip4, sleeper, solarwolf, sopwith, sqlite, ssh-status, stockthis, storageusage, supertux-stable, systeminfowidget, tar, tennix, thai-ttf, tickstill, tor, touchsearch, tsocks, uqm-3do-data, uqm-data, uremote, ussd-common, ussd-widget, vim, vor, vultures, wget, witter, worldtv99, xkblayouts-rx51-ru, zoutube</blockquote></span><br />
There are a lot that don't build but I think we're at the point where I need help from some experts and it's time to open the beta service up to early adopters. You can see what I've done <a href="http://wiki.maemo.org/OpenSuse_Build_Service/Fremantle_Setup">to setup Fremantle on the OBS</a>.<br />
<br />
<span style="font-size: large;">As I said </span><span style="font-size: x-large;">HELP</span><br />
I now need to fix build issues like:<br />
<pre>installing hildon-update-category-database
/usr/bin/hildon-update-category-database: I don't have write permission on /usr/share/mime.
Try rerunning me as root.
dpkg: error processing hildon-update-category-database (--install):
 subprocess post-installation script returned error exit status 1
Errors were encountered while processing:
 hildon-update-category-database
exit ...
</pre>which blocks a large number of applications<br />
<br />
and package specific ones like this in libogg:<br />
<pre>automake: configure.in: installing `./mkinstalldirs'
Makefile.am:3: require version 1.6, but have 1.4-p6
include/ogg/Makefile.am:6: invalid variable `nodist_ogginclude_HEADERS'
autoreconf: automake failed with exit status: 1
make: *** [configure-stamp] Error 1
dpkg-buildpackage: failure: debian/rules build gave error exit status 2
</pre><br />
I can fix almost all of them myself but that's not the point - we need a team to make this work. Please get in touch and help.<span class="net_nemein_favourites">20 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=09288c8a60df11dfb2efe9be122acc1dcc1d&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/09288c8a60df11dfb2efe9be122acc1dcc1d/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=09288c8a60df11dfb2efe9be122acc1dcc1d&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/09288c8a60df11dfb2efe9be122acc1dcc1d/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Sun, 16 May 2010 11:38:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-09288c8a60df11dfb2efe9be122acc1dcc1d</guid>
        </item>
        <item>
            <title>Community Building for Maemo and MeeGo - What does the OBS *Do*?</title>
            <link>http://mer-l-in.blogspot.com/2010/05/community-building-for-maemo-and-meego.html</link>
            <description><![CDATA[
In a closed environment you use what's in the SDK and you get your own little space; talking to others is discouraged and sharing and re-use outside the blessed area is frowned upon. This dictatorial style has the advantage of making life easier for the vendor. In an open world we have more interactions... and as students of networks know: increased connectivity brings increased complexity as well as increased benefits.&nbsp; So this is an initial proposal for the organisation of OBS build projects and packages to support a QA process into an app-store / Extras or garage-like environment.   I'll introduce some basic OBS concepts and then describe how this might work. I would like this to raise awareness of some potential complexities that we may face and get some thoughts on how to deal with them. ...... Oh, and this is about both Maemo and MeeGo.<br />
<br />
<span style="font-size: large;">First an OBS Intro</span><br />
<ol><li>  It's a build system (fully local) and a build service (like the autobuilder).<br />
</li>
<li>  You put source into it and say "use this repository"  and it spits binary packages out.<br />
</li>
<li> It builds a minimal and "clean" SDK using the repository you told it to use<br />
</li>
<li>  It has packages - a package corresponds to a tarball and a spec/dsc<br />
</li>
<li>  It has projects - a project is like a directory with packages<br />
</li>
<li>  Packages are 'published' into a corresponding repository (which can be shared with others)<br />
</li>
<li> The published repositories can also be used by devices to download binary packages.<br />
</li>
</ol><br />
There is a lot more to it; scheduling, dependency based building, multiple architecture support, home projects, package signing...<br />
<br />
The 'trick' then, is to set up a structure of projects that we can use to support the publishing and sharing activities that we need.<br />
<br />
<span style="font-size: large;">So What are our Goals?</span><br />
We want:<br />
<ul><li>  to allow freedom for developers to develop;<br />
</li>
<li>  to provide a great build service and SDK<br />
</li>
<li>  to work with the core distro as much as possible<br />
</li>
<li>  to provide excellent quality assured applications for our "app store";<br />
</li>
<li>  and for MeeGo, to extend the core distro with a community supported area for libraries and packages that are depended upon by more than one application. <br />
</li>
</ul><br />
<span style="font-size: large;">First thing we get: Individual Homes and PPAs</span><br />
You'll start by uploading and building a package in your "home" directory (which can have a structure underneath it for multiple projects). This will allow you to build against any of the main distros; any group/community projects or even any other community member home projects. Oh, and they can use your code as a baseline too. Once built your code is automatically published to a repo on the<br />
community downloads server.<br />
<br />
This is a lot like the Ubuntu PPA solution.<br />
<br />
At that point you can stop if you want. You have a complete set of repositories (1/subproject). No painful QA processes. No 'fragmentation'. But equally your repo(s) will needed to be manually added to a device in order for it to appear in any apt-get/zypper/yum etc.<br />
<br />
A huge benefit here is that to get at a development version of an application you use a specific repository, not a mishmash of randomly unstable packages like Extras-devel.<br />
<br />
<span style="font-size: large;">For the pros: Community QA'ed Repository - Extras</span><br />
If you'd like your application to appear in the Extras repo which is pre-installed on devices then you can submit to the QA process.<br />
<br />
First you register for the package name, then submit your code to the distro promoter; there it is QA checked, copied to Extras:Testing, built, QA'ed again and becomes available in the Testing repository.<br />
<br />
&lt;here be dragons&gt; The community testers then approve your code. &lt;/dragons&gt;<br />
<br />
(I know that's a contentious point - and I don't have an answer. I do however have confidence that we can solve the problem through collaboration and co-operation.)<br />
<br />
Once approved the code is copied to the Extras:Stable repository for publication.<br />
<br />
<span style="font-size: large;">Conclusion</span><br />
<br />
Much of this text is online at: <br />
  <a href="http://wiki.maemo.org/OpenSuse_Build_Service">http://wiki.maemo.org/OpenSuse_Build_Service</a><br />
(I really hate it when things get locked up in blog posts and forums)<br />
<br />
How can you help?<br />
<br />
Some tasks needed to get the OBS running:<br />
<ul><li>  OBS Installation - a detailed guide on how the system was setup.<br />
</li>
<li>  Application QA Process on the OBS - a proposal<br />
</li>
<li>  Setting up Fremantle - WIP - post to follow<br />
</li>
<li>  Fixing the Fremantle SDK - mmmm<br />
</li>
<li>  Setting up cross-building - started, not imported yet<br />
</li>
<li>  An OBS Autobuilder queue - not started<br />
</li>
<li>  Reporting - not started <br />
</li>
</ul><br />
Also see:<br />
<ul><li>  <a href="http://wiki.meego.com/Proposal_for_Community_Application_Support">http://wiki.meego.com/Proposal_for_Community_Application_Support</a><br />
</li>
<li>  <a href="http://wiki.meego.com/Proposal_for_a_Repository_working_group">http://wiki.meego.com/Proposal_for_a_Repository_working_group</a><br />
</li>
</ul><span class="net_nemein_favourites">21 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=e626228e60ce11df926d6d53f925604f604f&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/e626228e60ce11df926d6d53f925604f604f/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=e626228e60ce11df926d6d53f925604f604f&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/e626228e60ce11df926d6d53f925604f604f/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Sun, 16 May 2010 10:28:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-e626228e60ce11df926d6d53f925604f604f</guid>
        </item>
        <item>
            <title>It was the Dawn of the 3rd Age...</title>
            <link>http://mer-l-in.blogspot.com/2010/05/it-was-dawn-of-3rd-age.html</link>
            <description><![CDATA[
...and not only is the Shadow War over but it looks like we <span style="font-size: small;"><b>will</b></span> have a community OBS thanks to the team formerly known as maemo.org infrastructure :)<br />
<br />
I'm really excited as I see this as a way for the Maemo and Moblin development communities to transition smoothly into a MeeGo future; we should eventually be able to offer an easy way to build applications for Fremantle, Harmattan, MeeGo and future device OSes too.<br />
<span style="font-size: large;"><br />
</span><br />
<span style="font-size: large;">So what's happened?</span><br />
<br />
A while ago the <a href="http://wiki.meego.com/Proposal_for_a_Repository_working_group">RWG proposal</a> was begun and we've been pushing it ever since. Tero, Mike, Neils and others have been working on the <a href="http://wiki.meego.com/Proposal_for_Community_Application_Support">CAT proposal</a> as well as the RWG. We got together on irc and had a chat about the scope and how to proceed.<br />
<br />
Last week <a href="http://trac.tspre.org/meetbot/meego-meeting/2010/meego-meeting.2010-05-05-18.58.html">the TSG agreed</a> we need something (kinda!) - so we decided that we'd go ahead and do it.<br />
<br />
We now (thanks to Tero &amp; Nokia?) have a test machine behind a firewall and I've setup an OBS (<a href="http://wiki.maemo.org/OpenSuse_Build_Service/Installation">more than you ever wanted to know... but you said to work in the open, right?</a>) to prototype how we'd deploy it for community use. This has a link to the MeeGo OBS and successfully builds MeeGo packages.<br />
<br />
<span style="font-size: large;">Where are we going?</span><br />
<br />
I don't know yet; but here's what I'm proposing (my ideas tempered with some input from others):<br />
<br />
Initially we should offer a MeeGo OBS and a Maemo OBS. There are corporate issues around this and whilst my personal aim is a single build system able to build debs and rpms against any M[aemG]*o distro, that isn't the first step.<br />
<br />
The MeeGo OBS will probably offer home directories and a way to build against the MeeGo weekly snapshots. We may be able to offer a 'live' feed if some OBS bugs are resolved and we have the build resources.<br />
<br />
The Maemo OBS will provide an alternative to the autobuilder for Fremantle and, eventually, for Harmattan. This makes sense as our longer term future with MeeGo is clearly the OBS.<br />
<br />
One thing I dread is having to go to each device vendor's build system to make build my app for their community app store; so maybe off into the future we'll even provide a neutral place where we can support multiple vendors: a single build system that can build community   MeeGo apps for devices from any vendor that participate.<br />
<br />
Another area of interest to me is something I call "Surrounds" (yes, Quim, I know... it needs work). This isn't my idea... lots of software products and distros have it. It's that chaotic area around a product where 'outsiders' or community people contribute their "unsupported" bits and pieces. Actually this deserves a post on its own. Anyhow, I think the OBS will make managing this a lot easier for the community.<br />
<br />
<span style="font-size: large;">There is still a lot to do...</span><br />
<br />
We've asked a few community devs to join (and please come and talk to us if you feel you can help - bear in mind that we need documentation and build system process experience more than development skills).<br />
<br />
A big task is the setup of an OBS build system for Fremantle. I managed to get this 80% done a while ago so that work needs digging up and finishing off. Once that's done we will need a lot of help validating all the Extras apps.<br />
<br />
Yet more work is required on my cross-compilation system used by the OBS. That was deployed for Mer and we need to redeploy it for Fremantle too.<br />
<br />
There is work on reporting systems and QA automation systems going on that we can re-use which will help in transforming the autobuilder promotion type processes and figuring out what is and isn't needed in the OBS world.<br />
<br />
Speaking of which ... do we take this opportunity to tweak the Extras promotion policy?<br />
I think we need something like the Devel-&gt;Testing-&gt;Stable process for Maemo apps - but maybe we should be working with the CAT guys to figure this one out?<br />
<br />
Finally please don't ask me when you'll get to use it, we don't have a schedule yet :(<br />
<br />
However, do feel free to ask me what we're working on or what we've done or what you can help with.<span class="net_nemein_favourites">22 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=02f4269e59ff11df93189d2d1cb6b9c5b9c5&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/02f4269e59ff11df93189d2d1cb6b9c5b9c5/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=02f4269e59ff11df93189d2d1cb6b9c5b9c5&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/02f4269e59ff11df93189d2d1cb6b9c5b9c5/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Fri, 07 May 2010 18:20:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-02f4269e59ff11df93189d2d1cb6b9c5b9c5</guid>
        </item>
        <item>
            <title>N900 and Mozilla on the BBC</title>
            <link>http://mer-l-in.blogspot.com/2009/12/n900-and-mozilla-on-bbc.html</link>
            <description><![CDATA[
Here's the <a href="http://news.bbc.co.uk/1/hi/technology/8425906.stm">BBC Technology story</a> it's good that the N900 is being seen as an open system at this level.<br />
<br />
snippets:<br />
<blockquote>The browser, codenamed Fennec, will initially be available for Nokia's N900 phone, followed by other handsets. <br />
</blockquote>&nbsp;and<br />
<blockquote>&nbsp;Apple is very restrictive. It doesn't allow other browsers.<br />
</blockquote>which is all promoting the core values the community loves about Maemo...<span class="net_nemein_favourites">19 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=dab0bc4ceef611deb781c73e76c9a8fca8fc&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/dab0bc4ceef611deb781c73e76c9a8fca8fc/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>1 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=dab0bc4ceef611deb781c73e76c9a8fca8fc&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/dab0bc4ceef611deb781c73e76c9a8fca8fc/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Tue, 22 Dec 2009 12:30:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-dab0bc4ceef611deb781c73e76c9a8fca8fc</guid>
        </item>
        <item>
            <title>Android... is it Linux ?</title>
            <link>http://mer-l-in.blogspot.com/2009/11/android-is-it-linux.html</link>
            <description><![CDATA[
This i just something that I saw on LWN (from Harald Welte) and felt needed a little more visibility here at maemo.<br />
<blockquote>The presentation shows how Google has simply thrown 5-10 years of Linux userspace evolution into the trashcan and re-implemented it partially for no reason.  Things like hard-coded device lists/permissions in object code rather than config files, the lack of support for hot-plugging devices (udev), the lack of kernel headers.  A libc that throws away System V IPC that every unix/Linux software developer takes for granted. The lack of complete POSIX threads.  I could continue this list, but hey, you should read those slides. now! <br />
</blockquote>&nbsp;<a href="http://tree.celinuxforum.org/CelfPubWiki/ELCEurope2009Presentations?action=AttachFile&amp;do=get&amp;target=Mythbusters_Android.pdf">The slides</a><br />
<br />
As usual the <a href="http://lwn.net/Articles/360343/">commentary</a> at LWN raises some interesting counters.<span class="net_nemein_favourites">30 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=3ac6eb12cb3711de907a1b979f91d0cad0ca&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/3ac6eb12cb3711de907a1b979f91d0cad0ca/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>1 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=3ac6eb12cb3711de907a1b979f91d0cad0ca&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/3ac6eb12cb3711de907a1b979f91d0cad0ca/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Fri, 06 Nov 2009 23:51:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-3ac6eb12cb3711de907a1b979f91d0cad0ca</guid>
        </item>
        <item>
            <title>Ovi Maps... Really? Is this the best we can do?</title>
            <link>http://mer-l-in.blogspot.com/2009/10/ovi-maps-really-is-this-best-we-can-do.html</link>
            <description><![CDATA[
I got caught in a nasty traffic jam tonight just a few miles from home.<br />
<br />
There was a road that I've never been down - windy country lanes, right general direction...<br />
<br />
I grin and whip out my N900 and give it to my wife to navigate us - just the ticket?<br />
<br />
No.<br />
<br />
An hour later we've been lost several times, argued and are generally very annoyed and unhappy. My wife thinks that *I* think she's stupid 'cos she can't use a map application. She hates that. I hate that.<br />
<br />
The maps UI sucks. It is unusable to a novice. The GPS seems to update randomly every 10 mins or so. It blocks the screen with messages. It tries to connect to GPRS when there's no signal (and clearly no need). Mostly it just completely fails to meet its purpose.<br />
<br />
As we hit a road we recognised I realised that I was so pissed off with this experience that if I were a consumer who'd paid retail for this device <span style="font-size: large;">I would want my money back </span>- and as someone who has breathed Maemo for almost a year now, that makes me very, very sad.<br />
<br />
<a href="http://www.flickr.com/photos/96141280@N00/4048158716/" title="Ovi Maps is Crap by davidmg, on Flickr"><img alt="Ovi Maps is Crap" height="376" src="http://farm3.static.flickr.com/2464/4048158716_49c82da6be.jpg" width="500" /></a><span class="net_nemein_favourites">33 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=a680203cc2f711deb26efd5ce40f164e164e&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/a680203cc2f711deb26efd5ce40f164e164e/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=a680203cc2f711deb26efd5ce40f164e164e&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/a680203cc2f711deb26efd5ce40f164e164e/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Tue, 27 Oct 2009 12:51:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-a680203cc2f711deb26efd5ce40f164e164e</guid>
        </item>
        <item>
            <title>Maemo Security - Lockdown or Liberation?</title>
            <link>http://mer-l-in.blogspot.com/2009/10/maemo-security-lockdown-or-liberation.html</link>
            <description><![CDATA[
At the Maemo2009 Summit Nokia shared a great deal of information about the security mechanisms that would be available and/or mandated in upcoming platforms.<p>The concepts outlined include well established favourites in the OSS world (like privilege management) as well as some that are rather less well regarded - such as relatives of the Trusted Computing Platform and DRM.<p>Inevitably there will be a significant amount of interest and concern about how this affects the open nature of the Maemo platform.<br />
<br />
I'd like to highlight that there is a specific boot-path <b>designed in</b> to allow a community kernel to be booted with, as far as I could tell, no loss of functionality other than access to DRM content. That's amazingly positive.<br />
<br />
For what it's worth I will say that I was massively sceptical as soon as I saw "Trusted Computing" and "DRM"; however after listening and thinking about it I came to the conclusion that this solution could be a huge benefit to the OSS community. Certainly Nokia can abuse it - but that's not the point. The point is do we - and should we - trust them.<br />
<br />
We certainly <b>need</b> more security. Right now when I download an application from Extras-Devel it can do <b>anything</b> to my device; on an N800 that's not so bad - on an N900 that can incur significant cost and could conceivably (and almost trivially) be used to  <style type="text/css">
p, li { white-space: pre-
</style>perpetrate fraud. I'd <b>like</b> to be able to say "no, scrabble game, you can't access my contacts data or make phonecalls - what on earth do you need to do that for?" An open security infrastructure would make me feel a whole lot more comfortable.<br />
<br />
As a starting point to a rational response I think a sensible thing to do is to brainstorm the key questions we need to ask Nokia in order to gather the data needed to come to a conclusion.<br />
<br />
The presentation was a great start - as was Elena's offer to continue the discussion on the mailing lists and respond to our queries and concerns (Thanks Elena).<br />
<br />
So,I have started a <a href="http://wiki.maemo.org/MaemoSecurity">Maemo Security</a> page on the wiki which I hope can capture community questions (and, eventually I hope, Nokia's answers) about these issues.<br />
<br />
The first questions are draft (I just landed and I'm tired!) to get people thinking. Certainly I want to re-watch Elena's presentation video several times before going much further.<br />
<br />
I suggest we initially add questions to the&nbsp; <a class="new" href="http://wiki.maemo.org/Talk:MaemoSecurity" title="Talk:MaemoSecurity discussion">Maemo Security discussion</a> page and&nbsp; and once they've been refined and consolidated, we'll add them onto the main page.Obviously discussion needs to happen on talk, email and irc too.<br />
<br />
I'll wrap up with a plea - <span style="font-size: large;">please don't over-react</span>&nbsp; - jumping to conclusions and misleading the rest of the OSS community before we know the facts can only hurt what has so far been the most amazingly open phone device I could have dreamt of!<br />
<br />
PS The Summit was brilliant!<span class="net_nemein_favourites">22 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=05b593beb69d11de865edf633a3e1e621e62&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/05b593beb69d11de865edf633a3e1e621e62/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=05b593beb69d11de865edf633a3e1e621e62&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/05b593beb69d11de865edf633a3e1e621e62/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Mon, 12 Oct 2009 18:54:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-05b593beb69d11de865edf633a3e1e621e62</guid>
        </item>
        <item>
            <title>Important Summit Announcement</title>
            <link>http://mer-l-in.blogspot.com/2009/10/important-summit-announcement.html</link>
            <description><![CDATA[
Well, it's important if you arrive for the Summit on Thursday and want to meet up for a beer (or, if Copenhagen was anything to go by... an ice-cream) in the evening.<br />
<br />
More details here: <br />
&nbsp; http://wiki.maemo.org/Maemo_Summit_2009/Schedule<br />
<br />
Meet up at 19:00 (so after early registration closes).<br />
<br />
There will be free beer available<br />
<br />
<br />
<br />
<br />
<br />
<br />
<br />
<br />
<br />
<br />
<br />
<br />
<br />
if someone offers to buy it ;)<span class="net_nemein_favourites">8 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=558d191cb2c811deacc4b97296bf22d822d8&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/558d191cb2c811deacc4b97296bf22d822d8/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=558d191cb2c811deacc4b97296bf22d822d8&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/558d191cb2c811deacc4b97296bf22d822d8/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Tue, 06 Oct 2009 23:22:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-558d191cb2c811deacc4b97296bf22d822d8</guid>
        </item>
        <item>
            <title>Want to PUSH... need a kickstart?</title>
            <link>http://mer-l-in.blogspot.com/2009/09/want-to-push-need-kickstart.html</link>
            <description><![CDATA[
So one problem with the <a href="http://blogs.nokia.com/pushn900/">PUSH</a> is that it's a bit tough for us software nerds to get into the real world. What would be cool is a nice easy "apt-get install HARDWARE" ... interested? read on...<br />
<br />
<div class="separator" style="clear: both; text-align: center;"><a href="http://www.velleman.eu/images/products/0/k8055.jpg" imageanchor="1" style="clear: right; float: right; margin-bottom: 1em; margin-left: 1em;"><img border="0" height="150" src="http://www.velleman.eu/images/products/0/k8055.jpg" width="200" /></a><br />
</div>A few years ago I bought a couple of these boards for about £25.<br />
<br />
They provide: <br />
<ul><li><span id="Description">5 digital input channels</span></li>
<li><span id="Description">8 digital output channels</span></li>
<li><span id="Description">2 analogue inputs</span></li>
<li><span id="Description">2</span><span id="Description"> analogue outputs (8 bit resolution)</span><span id="Description"> <br />
</span></li>
</ul><span id="Description"> You can also have up to 4 of these plugged in via a usb hub</span><span id="Description">.</span><br />
<br />
<span id="Description">So, I thought... how hard can it be... and actually it is quite easy. The source is on sourceforge and I'm packaging it so you can pull</span><span id="Description"> libvelleman from garage, plug in a board and PUSH :) </span><br />
<span id="Description"><br />
</span><br />
<span id="Description">As you can see the test program implements K.I.T.T. for you...<br />
</span><br />
<br />
<object height="344" width="425"><param name="movie" value="http://www.youtube.com/v/xPXyES0-9-Q&amp;hl=en&amp;fs=1&amp;"></param><param name="allowFullScreen" value="true"></param><param name="allowscriptaccess" value="always"></param><embed src="http://www.youtube.com/v/xPXyES0-9-Q&amp;hl=en&amp;fs=1&amp;" type="application/x-shockwave-flash" allowscriptaccess="always" allowfullscreen="true" width="425" height="344"></embed></object><br />
<br />
So now all we need is someone with an N900 to help me test it...<br />
<br />
(Warning: Don't get your hopes up - it appears that the N900 can't (yet?) act as a normal USB host; so no plugging in printers....)<span class="net_nemein_favourites">15 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=2c73aa28a62511deae9b89f67129e38de38d&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/2c73aa28a62511deae9b89f67129e38de38d/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=2c73aa28a62511deae9b89f67129e38de38d&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/2c73aa28a62511deae9b89f67129e38de38d/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Mon, 21 Sep 2009 09:54:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-2c73aa28a62511deae9b89f67129e38de38d</guid>
        </item>
        <item>
            <title>The Summit: Git/Gitorious - Untracked talks: consider adding them...</title>
            <link>http://mer-l-in.blogspot.com/2009/09/summit-gitgitorious-untracked-talks.html</link>
            <description><![CDATA[
I proposed a talk at the summit on DVCS and git and it has not been accepted (or rejected) by the talk selection group. This isn't a complaint&nbsp; :)&nbsp;&nbsp;&nbsp;&nbsp; . . . . . &nbsp; however I do worry that it <b>might</b> worth pushing ... what do you think? (Breaking news... sounds like there has been an acceptance - also it may make sense to do a BOF session after any presentations). I still would appreciate feedback - what' important to you?<br />
<br />
This message is just to solicit opinions and hopefully will validate their decision. If it causes a rethink then that's fine too. <br />
<br />
Heh - I could do without the extra work involved!! <br />
<br />
I personally thing think that as a development community with git on garage and gitorious.org we should be making efforts to understand how best to use DVCS processes to collaborate.<br />
<br />
Maybe it's just me but I see a lot of devs who are new to DVCS and very few community guidelines on how to use DVCS. Qt uses it but, as we've recently been discussing, it could be going better.<br />
<br />
Frankly I don't care which 'good practice' I use - I can go out and find lots of them. But it strikes me that as a community we should at least say "hey, quite a few of us are using this approach - if you don't have any strong preferences then you can use it too"<br />
<br />
So why now?<br />
<br />
Well, real soon now (I hope) we're going to have 3 different versions to support.<br />
<ul><li>Fremantle</li>
<li>Diablo</li>
<li>Mer</li>
</ul>They'll each have different capabilities and some apps just won't care - they'll support Fremantle or Diablo and ignore the others. That's fine. <br />
(Although being open-source you might find patches being sent in to add support for another flavour - how will you cope? Wouldn't you like some help in doing the boring stuff?)<br />
<br />
Other apps will decide to embrace that diversity from the start.<br />
<br />
So how do we (you) manage the build-variations (ie debian/* may well vary for each of them. Maybe ./configure too)? Do we use branches? How?<br />
<br />
Now how do we manage adding features and back-porting simple bug fixes to the stable release whilst you work on that big new feature set.<br />
<br />
How are contributions and teams handled?<br />
<br />
It sounds horrendous - and it can be!<br />
<br />
<br />
But actually this is all fairly simple stuff with DVCS once you have it explained and once you grok it - but it's bloody hard to figure out from scratch and it's also very unlikely that you'll arrive at the same solution as another team.<br />
<br />
Which means if you're a member of multiple teams you might find they each have different approaches - "whoo hoo!" - not! <br />
<br />
So anyway... I thought a talk would be a good idea.<br />
<br />
Now at the time no-one had volunteered so I did - some of you may have noticed my name at the bottom of:<br />
&nbsp; <a href="http://www.kernel.org/pub/software/scm/git/docs/git.html">http://www.kernel.org/pub/software/scm/git/docs/git.html</a><br />
(yes, I'm proud of that contribution)<br />
<br />
Now you may think that qualifies me to offer this talk - you'd be wrong ;)<br />
<br />
I was hanging around the kernel lists at the time, got interested and acted as an 'editor' pulling together words of wisdom. Since then I've used git a little but it wasn't until we started to need it in Mer that I reviewed the state-of-play and tried to pull in other people's good ideas - so that's what I'd use as a base.<br />
<br />
However we also have Johan Sørensen who wrote <a href="http://gitorious.org/">Gitorious.org</a> - I think having him speak on using git and gitorious would be an opportunity that we shouldn't miss.<br />
<br />
Equally there must be developers in Nokia/Trolltech who could say "we know this stuff and this is how we think you might want to do it."<br />
<br />
So... speak now...<br />
<br />
PS If anyone fancies collaborating and doing a multi-person presentation then I'm up for it.<span class="net_nemein_favourites">12 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=1595b266994f11deb8f311b4abce946b946b&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/1595b266994f11deb8f311b4abce946b946b/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=1595b266994f11deb8f311b4abce946b946b&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/1595b266994f11deb8f311b4abce946b946b/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Fri, 04 Sep 2009 16:56:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-1595b266994f11deb8f311b4abce946b946b</guid>
        </item>
        <item>
            <title>GrandCentral for Mer... connecting the components</title>
            <link>http://mer-l-in.blogspot.com/2009/09/grandcentral-for-mer-connecting.html</link>
            <description><![CDATA[
First, I'm sorry but this isn't an N900 post :) instead I've been looking at one of the areas that's holding back Mer. It's fairly simple conceptually: just handling interaction between various parts of the system; and by this I mean things like screen dimming; what happens when you press the power key; shutting down when the battery is low; waking up for an alarm... Things that should just work.&nbsp; Well, I think I have a potential solution. (Oh, and some of you may be interested... I also found out how far eclipse has come in the UML modelling space too!)<br />
<br />
Currently this is handled by <code>powerlaunch</code>; it is really not a bad bit of code and does most of its job well.<br />
<br />
Sadly it <b>really sucks</b> at being configurable!<br />
<br />
Here's a snippet:<br />
<code> global_key_press_power = timer_set _key_power_long $powerkey_longdelay; timer_set _key_power_medium $powerkey_mediumdelay; set powerkey_short 1; call _key_press_power_short<br />
global_key_release_power = timer_cancel _key_power_long; timer_cancel _key_power_medium; if $powerkey_short _key_release_power_short key_release_power_long<br />
</code><br />
<br />
I don't know what it does and the only way I'd be happy changing it would be after extensive research. Frankly it scares me!<br />
<br />
Here's what I was thinking we'd do for a 'configuration' syntax in Mer:<br />
<br />
<code> # describe some action<br />
def on_wifi_up():<br />
&nbsp;&nbsp;notify "The wifi is up"<br />
&nbsp;&nbsp;os.system("mail me@gmail.com -S 'wifi is up'")<br />
<br />
connect(wifi, "Connection.up", on_wifi_up)<br />
<br />
connect(camera, "Camera.active", takePhotoAfter10Secs)<br />
connect(camera, "Camera.turn",&nbsp;&nbsp; media.play, "/home/lbt/sounds/camera_click.wav")<br />
connect(powerButton, "Button.longPress", powermenu.show_menu)<br />
</code><br />
<br />
This uses a python signal library (like Qt or libsigc++) and provides a set of component objects that emit nice signals like "Connection.up".<br />
<br />
The benefits of this approach: <br />
<ul><li>simple syntax is nice and readable</li>
<li>interpreted so can easily be edited</li>
<li> python understood by many so can be easily extended</li>
<li>re-uses some powerlaunch code (eg powered)</li>
</ul>Of course there are drawbacks: <br />
<ul><li>it's not a config file - it's code (but considering we want to configure functional behaviour then any config syntax needs to be a language... so use a decent one)</li>
<li>python is quite large (but it's now in memory and .so are available)</li>
<li>it's another re-write :(&nbsp; (it only took a few days and I'm using powerlaunch as a prototype for config rules - if I can understand them!!)</li>
</ul>So anyway, as I said, I found eclipse Modelling edition...<br />
<div class="separator" style="clear: both; text-align: center;"><br />
<a href="http://www.flickr.com/photos/96141280@N00/3881800833/" title="GrandCentral UML diagram by lbt"><img alt="GrandCentral" src="http://farm4.static.flickr.com/3456/3881800833_aa24c71895_o.png" width="300" /></a></div><br />
<br />
<br />
This says (well, I hope it says):<br />
<ul><li>There is a system and a user dispatcher</li>
<li>They're based on a common Dispatcher</li>
<li>Which contains components (such as Headphone, Menu etc) that can</li>

<ul><li>send signals (eg when the camera on the N800 is turned)</li>
<li>take requests (dim the screen)</li>
<li>provide state information (a headphone is connected)</li>
<li>be accesed on D-Bus</li>
</ul>
<li>The Dispatcher creates Connections which</li>

<ul><li> listen() for Components to emit signals (also listening on D-Bus)</li>
<li>run Scriptlets which <b>might</b></li>

<ul><li>run arbitary code</li>
<li>make requests to components</li>
<li>emit signals that (other) Connections can listen() for</li>
</ul>
<li>Scriptlets are part of the Dispatcher</li>
</ul></ul><br />
Oh, and the good news is that it's up and running... I'll put the code on gitorious RSN.<span class="net_nemein_favourites">10 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=2391f520996111de888ffb52b15c28812881&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/2391f520996111de888ffb52b15c28812881/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=2391f520996111de888ffb52b15c28812881&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/2391f520996111de888ffb52b15c28812881/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Fri, 04 Sep 2009 15:00:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-2391f520996111de888ffb52b15c28812881</guid>
        </item>
        <item>
            <title>Do you take contributions?  or is it &quot;Beware of the Leopard&quot;</title>
            <link>http://mer-l-in.blogspot.com/2009/09/do-you-take-contributions-or-is-it.html</link>
            <description><![CDATA[
Open source is about opening things up... right?<br />
Well, yes.<br />
But I think there's more to it than that.<br />
<br />
Think about the kernel and how that works. A wide open mailing list (and source repository) with people getting on with it. Fedora? Ubuntu? The same. SGI's XFS filesystem; in fact any number of projects out there.<br />
<br />
But what does that even mean? "Getting on with it?"<br />
<br />
To me it means discussions, proposals, code, designs, bugs. If you care you can watch; you can even attempt to join in. You can certainly learn about what's happening and why.<br />
<br />
So here's the question...<br />
<br />
<b>Where's the 'Contribute to Maemo' on maemo.org?</b><br />
<br />
Fremantle is coming out - but it just appears on the download servers. There's no opportunity for the community to contribute. Where are the mailing list archives or the commit logs so I can find who committed that change, when and why?<br />
<br />
Opensource means you can't be shy; open doesn't mean "behind closed doors"; it doesn't mean "you get it when we're done".<br />
<br />
Open means "this is what we're doing". And "we" includes the community.<br />
<br />
I hope we're doing it <a href="http://wiki.maemo.org/Mer/Awareness">the right way in Mer</a>.<br />
<br />
irc is our main collaboration area and that's open and logged. Not terribly useful as an archive though. We have the chatter mailing list which gives a pretty good summary of key events.<br />
<br />
What we do to activate incoming developers to make it easy for them to contribute? Well, we've adopted gitorious as our DVCS and I think the process and UI there makes that a good call. I've also put <a href="http://wiki.maemo.org/Mer/Build">some effort into describing our 'internal' build processes</a> and what we (ultimately) expect DVCS contributions to look like.<br />
&nbsp;Carsten has setup a <a href="http://trac.tspre.org:9010/">neat little tracker</a> of outstanding tasks so potential contributors can pick up things to work on.<br />
<br />
We have some design statements on the wiki and we know that 'track Fremantle and predict Harmattan' are our tenets.<br />
<br />
I wondered what Android does?<br />
Hmm : <a href="http://source.android.com/roadmap">http://source.android.com/roadmap</a><br />
<blockquote>
The Android Open Source Project will publish roadmaps for
upcoming releases. The roadmaps will be developed with input from this
community, Project Leads, and the Open Handset Alliance</blockquote>
Sounds good.. and the code is up there.<br />
<br />
What about contributions?<br />
Well... <a href="https://review.source.android.com/#change,11544">say no more!</a> A random click got me that gem.<br />
<br />
Nokia and Maemo5 .... well, to be frank it looks a lot more like Microsoft.<br />
<br />
And that's not that harsh :)<br />
<br />
Microsoft provide (I'm told) excellent documentation for developing OSS on their platform.<br />
<br />
For Maemo there is some <a href="http://wiki.maemo.org/Documentation/Maemo_5_Developer_Guide/Development_Environment/Maemo_SDK">really</a> good developer documentation (seriously - I think this is not shouted about enough); there's superb support for creating OSS <b>on</b> Maemo platforms; and that's absolutely crucial.<br />
<br />
Contributing <b>to</b> Maemo... not so much.<br />
<br />
Yes, the source is there for the released maemo packages; and there are random directories like <a href="https://stage.maemo.org/svn/maemo/projects/email/osso-email-interface/trunk/ChangeLog">this</a> or <a href="https://stage.maemo.org/svn/maemo/projects/haf/tags/gail/gail-1.18.0-osso14/">this</a> &nbsp; (first one is circa 2005, 2nd April 2008)... browse around, we found some useful stuff in there!<br />
As Carsten said "god knows how i found that first time". There are garage projects too (impossible to
find the right ones though), recently we noticed some appearing on <a href="http://gitorious.org/maemo-af">gitorious</a> or&nbsp; git.maemo.org or svn....<br />
<br />
However I'm not really aware of anything other than bugzilla for communicating with the development teams; and I don't think that's something the community generally finds to be a 'shining example' :)<br />
<br />
We recently added a note <a href="http://wiki.maemo.org/Mer/Build#Mer_Source">by way of an apology</a> for Mer's lack of "apt-get source" but I think Maemo deserves it too:<br />
<blockquote>
`...You hadn't exactly gone out of your way to call attention to them
had you? I mean like actually telling anyone or anything.'<br />
`But the plans were on display...'<br />
`On display? I eventually had to go down to the cellar to find them.'<br />
`That's the display department.'<br />
`With a torch.'<br />
`Ah, well the lights had probably gone.'<br />
`So had the stairs.'<br />
`But look you found the notice didn't you?'<br />
`Yes,' said Arthur, `yes I did. It was on display in the bottom of a
locked filing cabinet stuck in a disused lavatory with a sign on the
door saying "Beware of The Leopard".'</blockquote>
<br />
I really don't think it's doom and gloom though - Qt has opened up a lot since Nokia took over. The development has moved out into the open and there's a process to contribute. Gitorious is&nbsp; being sponsored by Nokia/Qt and I hope the maemo-af team are leading the way.<br />
<br />
I really hope that when Harmattan arrives the basement is light and airy; very, very noisy and the leopard has relocated to the lobby!<span class="net_nemein_favourites">16 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=426f7138986d11de8b7297496e4131753175&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/426f7138986d11de8b7297496e4131753175/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=426f7138986d11de8b7297496e4131753175&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/426f7138986d11de8b7297496e4131753175/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Thu, 03 Sep 2009 10:00:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-426f7138986d11de8b7297496e4131753175</guid>
        </item>
        <item>
            <title>Accelerating OBS ....  !scratchbox</title>
            <link>http://mer-l-in.blogspot.com/2009/09/accelerating-obs-scratchbox.html</link>
            <description><![CDATA[
So I've been working on accelerating the <a href="https://build.opensuse.org/">Open Build Service</a> recently.<br><br />
It's a great build environment for Mer and we love it. It uses qemu to emulate arm architectures and provides a pristine chroot build environment using native packages. This approach of using distribution tools rather than a toolchain provides a more consistent build system.<br><br />
The problem is that this approach is slow. <br />
<br />
Following the 80/20 rule, the OBS engineers (thanks Martin, Jan Simon) identified the applications that represented the greatest load on the build system: <br />
<ul><li> bash </li>
<li> bzip2 </li>
<li> dpkg </li>
<li> gzip </li>
<li> m4 </li>
<li> make </li>
<li> perl </li>
</ul>And of course: <br />
<ul><li> gcc </li>
</ul>So the intention was to accelerate these binaries in the emulator by using host machine code, not emulated code.<br />
<br />
The emulator uses <a href="http://en.wikipedia.org/wiki/Binfmt_misc">binfmt_misc</a> to call qemu for foriegn binaries when it hits them so simply replacing the binaries with host binaries should work. <br />
<br />
Well; almost. <br />
<br />
The host binaries need their shared libraries; and they live in the same place as the emulated shared libraries... which may be used by non-replaced code. Hmmm.<br />
<br />
(Before going any further, lets establish a naming convention: target is the architecture of the chroot and eventual target; host is the architecture of the underlying CPU. Typically for us target is armel, host is x86.)<br />
<br />
The approach to solving this problem is to minimise changes from a pure arm build environment. This is achieved by installing both arm and x86 packages; to avoid collisions the x86 packages are installed into /lib-x86 (in the chroot) and of course, shared libraries will fall into /lib-x86/[usr/]lib and not overwrite the target .so files.<br />
The final step is to move selected binaries in /bin and /usr/bin out of the way and replace them with symlinks to the i586 binaries in /lib-x86/[usr/]bin<br />
<br />
Most x86 packages are unmodified; any paths they use will relate to the main / directory and the config/data files installed by the target package will be used. (This works in general although the eagle-eyed will spot issues with things like XS modules for perl - not a major problem for a simple build environment though).<br />
<br />
Some packages are modified to minimise build times - eg to avoid 64 bit builds; others are modified (eg dpkg) to set the target architecture as a default.<br />
<br />
Obviously the host binaries need to link to shared libraries which are not in the normal LDPATH. We don't want to have to rely on environment variables etc so 2 steps are used: <br />
<ul><li> modify ldlinux.so to look in /lib-x86/lib etc </li>
<li> modify the rpath value in the ELF header of each replaced binary </li>
</ul><br />
This is done by creating a static build of <a class="external text" href="http://nixos.org/patchelf.html" rel="nofollow" title="http://nixos.org/patchelf.html">patchelf</a> and modifying the binaries as they are installed.<br />
<br />
Finally a modified package has all postinst scripts removed and replaced with something like: <br />
<br />
<blockquote><pre><span style="font-family: courier new;">prefix=/lib-x86</span>
<span style="font-family: courier new;">$prefix/usr/bin/patchelf --set-rpath $prefix/lib $prefix/usr/bin/make</span>
<span style="font-family: courier new;">mv /usr/bin/make /usr/bin/make-orig-x86lib</span>
<span style="font-family: courier new;">ln -s $prefix/usr/bin/make /usr/bin/make</span>
</pre></blockquote><br />
Note that some libraries have an rpath and need to be treated with patchelf too.<br />
<br />
One final problem arises with fakeroot: it modifies the LD_LIBRARY_PATH to look for libfakeroot-XXX.so This is handled by editing the fakeroot script to append the /lib-x86/ paths in the same way the multi-arch paths are added.<br />
<br />
All in all this is actually a very clean solution:<br />
<ul><li>the modified binary uses the exact same source as the one it replace</li>
<li>the installation principles mimic biarch (and will, we hope use biarch when it's ready) <br />
</li>
<li> only the specific binary executable is replaced - data and scripts come from the target package</li>
<li>it can easily be switched on or off for a specific binary</li>
<li>enabling it on the OBS is done in the enclosing project, not the package</li>
</ul><br />
Next steps, making it work on the OBS and then ...  building a cross-gcc.<span class="net_nemein_favourites">10 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=0366f93496d311deabca8f0fd0e588ec88ec&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/0366f93496d311deabca8f0fd0e588ec88ec/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=0366f93496d311deabca8f0fd0e588ec88ec&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/0366f93496d311deabca8f0fd0e588ec88ec/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Tue, 01 Sep 2009 09:29:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-0366f93496d311deabca8f0fd0e588ec88ec</guid>
        </item>
        <item>
            <title>$ make distro</title>
            <link>http://mer-l-in.blogspot.com/2009/08/make-distro.html</link>
            <description><![CDATA[
That's what the OBS does for us.<br />
<br />
The <a href="https://build.opensuse.org/">openSuse builder</a>&nbsp; provides Mer with an incredibly powerful tool for building packages.<br />
<br />
It gives us:<br />
<ul><li>over 150 build cores !!<br />
</li>
<li>powerful monitoring and control tools - web and cli</li>
<li>total access - it's all GPL</li>
<li>proven capability - openSUSE and SLE are built using it</li>
<li>distribution neutrality<br />
</li>
</ul>OBS is a GPL, distro-neutral build system; it works by creating a totally empty virtual machine (or chroot), bootstrapping a minimal version of a distribution and then driving the distro's own build tools to pull in the build dependencies from the official distribution repository. Finally it calls the native tools (eg dpkg-buildpackage) to build the package<br />
<br />
Think of it as a wrapper around the distribution's standard build tools which provides queue management and a good web interface.<br />
<br />
What's good about that then?<br />
<ul><li>No wheels being re-invented - it uses the 'standard' tools</li>
<li>Quality control - packages must specify exactly what they depend on to build; and a build installs clean packages and builds from clean source</li>
<li>Management wrappers - more about this later<br />
</li>
</ul><br />
And it does this around multiple base distributions inclding Debian/Ubuntu/Redhat/Centos/Moblin and of course SUSE and openSUSE.<br />
Just try building a Redhat package on the Debian build system - or vice versa.<br />
<br />
What makes it particularly interesting for Mer is that it also does this with multiple architectures including ARM.<br />
<br />
So what Mer essentially does is to feed it a large number (~200) standard debian format source packages and wait for it to spit out .deb files in an sources.list compatible repository.<br />
<br />
Doing this correctly means it needs to analyse build dependencies and, make-like, consider the freshness of those dependencies to determine if a rebuild is required. So if a change is needed in&nbsp; libhildonfm2 then all the packages that depend on it will be rebuilt - nice.<br />
<br />
If you'd like to read a bit more about how Mer uses it then start on the <a href="http://wiki.maemo.org/Mer/Build">Mer Build</a> pages.<span class="net_nemein_favourites">2 <a href="http://maemo.org/news/?net_nemein_favourites_execute=fav&net_nemein_favourites_execute_for=c0ef059a960c11de9fd43390e24830e530e5&net_nemein_favourites_url=https://maemo.org/news/favorites//json/fav/midgard_article/c0ef059a960c11de9fd43390e24830e530e5/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-favorite.png" style="border: none;" alt="Add to favourites" title="Add to favourites" /></a>0 <a href="http://maemo.org/news/?net_nemein_favourites_execute=bury&net_nemein_favourites_execute_for=c0ef059a960c11de9fd43390e24830e530e5&net_nemein_favourites_url=https://maemo.org/news/favorites//json/bury/midgard_article/c0ef059a960c11de9fd43390e24830e530e5/" class="net_nemein_favourites_create"><img src="http://static.maemo.org:81/net.nemein.favourites/not-buried.png" style="border: none;" alt="Bury" title="Bury" /></a></span>]]></description>
            <author>David Greaves &lt;david@dgreaves.com&gt;</author>
            <category>feed:fb2e01f2b05f173de4f8ef523cd2a4d2</category>
            <pubDate>Sat, 29 Aug 2009 11:19:00 +0000</pubDate>
            <guid>http://maemo.org/midcom-permalink-c0ef059a960c11de9fd43390e24830e530e5</guid>
        </item>
    </channel>
</rss>
