<div class="gmail_quote">On Sun, Mar 24, 2013 at 5:11 PM, Kevin Krammer <span dir="ltr"><<a href="mailto:krammer@kde.org" target="_blank">krammer@kde.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="im">On Friday, 2013-03-22, Duncan wrote:<br>
<br>
> My problem isn't so much with that, it's with killing support for old<br>
> versions before the new versions are sufficiently stable replacements,<br>
> ESPECIALLY after promising support "as long as there are users!"  That<br>
> triggered a drop of a lot of my former kde software choices with the bump<br>
> to kde4, when kde was insisting that kde4 was stable and that they<br>
> weren't supporting kde3 any longer, at the very SAME time they were<br>
> saying on bugs "Oh, that's not ported to kde4 yet."<br>
<br>
</div>Well, the 3 series was actively released about one and a half year into the 4<br>
series and continues to be available up to today.<br>
To make certain older version become unavailable would be a lot of work,<br>
requiring to remove tags, branches and time information from the repositories.<br>
I consider it an inherent bonus of openly developed software that any version<br>
is available at any time.<br>
<br>
Whether certain products are update to newer APIs mostly depends on human<br>
resources associated with the product.<br>
Both as in availability (e.g. people switching to other areas, leaving the<br>
community, etc) and in decision making (e.g. joining efforts with a similar<br>
product's team, finding that newer technology has obsoleted a product, etc).<br>
<br>
While this does of course impact ongoing maintenance, e.g. shifting from<br>
product creators to product distributors or deployers, it does usually not<br>
impact ongoing availability.<br>
The latter usually not only in the form of markers in source code repositories<br>
but also in the form of archived release packages, etc.<br>
<div class="im"><br>
> The story repeated<br>
> with the akonadification of kdepim; I honestly DID try the akonadified<br>
> kmail, but somewhere about the time it lost my 10th mail or so and I was<br>
> trying to figure out whether it got caught in akonadi somewhere or was<br>
> simply gone (after having to do much of the conversion manually in the<br>
> first place because the automated process failed), I asked myself why I<br>
> put up with it, why I couldn't just expect, AND HAVE, email that "just<br>
> worked", that devs didn't needlessly change something that was working<br>
> perfectly fine as it was, breaking it in the process.  (Ironically, I<br>
> ended up on claws-mail, one of the "short list" of clients I had<br>
> evaluated but eventually dropped for kmail, back when I originally<br>
> switched from MS and OE.  It's still using the same mh-dir mail format it<br>
> was back in 2001... and it still works.  Only unlike kmail, they didn't<br>
> drop a well working solution in a chase for utopia.  Had I only chosen it<br>
> back then...)<br>
<br>
</div>One of the things that can easily be missed when not considering the<br>
surroundings of the "big picture" is that requirements for products of the<br>
same or similar category can be vastly different.<br>
<br>
Akonadi is certainly a bit overengineered, also due to it being the second<br>
generation solution (second generation problem), but it does address needs and<br>
issues gathered over years of wide spread use.<br>
<br>
For example, if we look at KMail, one can easily fall into the trap of<br>
thinking of it as just an program for writing and reading emails and thus<br>
compare it too closely with other products that do that but only that.<br>
<br>
However, if one considers the additional requirements, it becomes often<br>
quickly obvious that other product's features for those requirements are<br>
either quite crude or not existant at all.<br>
<br>
Lets for example take the basic requirement of enabling other programs to send<br>
email, e.g. need for sending out invitations to events in scheduling and<br>
calendaring applications.<br>
While working on xdg-email it became often quite frustrating that email<br>
programs would either not have stable external interfaces (commandline, D-Bus<br>
or otherwise) or not even have them at all!<br>
<br>
Another, often quite problematic use case, is providing access to the<br>
addressbook or being able to access an externally provided one.<br>
A lot of programs fail to have accessors for external addressbooks, are only<br>
able to deal with their native one or are rather fragile regarding concurrent<br>
access (e.g. not having (proper) file locking or assuming in-memory state is<br>
equal to on-disk state, etc).<br>
<br>
Even for KMail, which had those requirments covered for quite some time<br>
already, some choices on how to do them had massiv impact on the agility of<br>
the product, its maintainablity and so on.<br>
<br>
The solution the involved developers devised deals with those requirements in<br>
an architecturally clean way. Unfortunately implementation of even the<br>
cleanest architecture and design can be difficult and appear to be complete<br>
and stable under test conditions because, e.g. some cases of data or<br>
configuration have just been hit yet.<br>
<br>
Due to the availability of alternatives, including previous versions of the<br>
same product, these growing pains can often be mitigated for certain groups of<br>
users, e.g. those not needing any advanced features or those who can live with<br>
the quirks of previous versions.<br>
<div class="im"><br>
> Fortunately, kde5 aka kde frameworks is supposed to be a much less<br>
> disruptive upgrade, and it's going much more modular as well, so it's<br>
> much less likely.  But THIS time I'm prepared, should it happen.  I won't<br>
> be caught not viably being able to switch, again.<br>
<br>
</div>Indeed. Frameworks 5, aside from its modularization work, will also improve<br>
the visibility of the distinction between different products. Discussions like<br>
this are a good example how difficult it still is for many people to see the<br>
how wide the range of products is, how unrelated certain products and their<br>
respective teams are to others, etc.<br>
<div class="im"><br>
> Of course there's the possible upcoming xorg -> wayland switch to worry<br>
> about too.  That could really upset the Linux desktop environment status<br>
> quo in all sorts of interesting ways and I think most of the leading DEs<br>
> realize that.<br>
<br>
</div>My guess would be that only a small group of products will be affected, mostly<br>
those related to the workspace category, maybe some system tools.<br>
The vast majority of programs does not employ any X11 specific code and should<br>
thus be mostly unaffected by a move away from it.<br>
The main unforseeable issues would be hidden assumptions on system behavior.<br>
<div class="HOEnZb"><div class="h5"><br>
Cheers,<br>
Kevin<br></div></div></blockquote><div><br>See, we all agree with the fact that KDE SC is a complicated project and it's a good design; for starters Akonadi is the only piece of software proving the likes of MS exchange. But the project doesn't  have enough developers to satisfy the release needs, especially if it's @ 6 months.<br>
<br>The developers are less+they are contributers+KDE SC is HUGE and complicated, but still 6 months?<br><br>On the other hand, look at Xfce. They're hesitant to add basic features like Thunar search, tabbed browsing, cause they say the don't have enough developers. On top of that look at their super slow release cycles (-bugfixes).<br>
<br>As a result there exists nothing more stable than Xfce.<br><br>You can even look at Gnome. They test their major releases for full 6 months, and release a beta every month.<br></div></div>