KDE Telepathy Sprint
On a sunny September weekend in Cambridge, England, ten KDE and Telepathy developers met in the Collabora office to plan the future of Instant Messaging in KDE software. Once everyone had arrived, our host George Goldberg gave us an overview of the current state of the codebase, which parts are usable, which parts still need writing, and which parts were written years ago and need revision. This turned into a project management session to determine the order for getting things done, and a discussion about a release schedule that will make the project visible without tying it prematurely into compatibility guarantees that slow down development.
The Team
The sprint attendees are shown below. Many have also written personal blog entries about the sprint - click on their names to read those.
Back Row:. Olli Salli (oggis), Dominik Schmidt (domme), David Edmundson (david_edmundson), Sebastian Trueg (trueg), Will Stephenson (wstephenson) Front Row: George Goldberg (grundleborg), George Kiagiadakis (gkiagia), Dario Freddi (drf), Daniele Domenichelli (drdanz), Andre Magalhes (andrunko)
Creativity
We paid a visit to a local hostelry to get the creative juices flowing with some real ale and typical English pub food like bubble & squeak, faggots in gravy and sausages & mash. One of our contributors, who will remain nameless, protested initially that he did not really like beer, but by the end of the evening was returning frequently to the bar for more flat, warm, malted barley juice.Back in the office, the Telepathy-Qt4 authors Olli Salli and Andre Magalhaes were there to advise. Olli gave a detailed talk on the concepts of the Telepathy-Qt4 library, new features that make it easier to code with, and the basic Telepathy components that are most important to client authors. They then sat with the KDE UI hackers to identify useful features in their code that can be be pushed down into the library.
Hard Work
Instant Messaging UI designs are like opinions - everybody has one. The modular nature of KDE Telepathy will allow any component to be replaced, for example with wildly skinnable contact lists or infinitely configurable chat windows, yet everyone agreed that it is important to have a functional yet elegant default user interface. Andre, Will Stephenson, and Daniele Domenchielli formed a UI Love breakout group and commandeered the whiteboard in Collabora's kitchen. They set about sketching some concepts for a contact list, chat window, voice/video call widget and configuration UI that combine the best of current technology with the experience of Kopete and other clients. These are being mocked up using Qt Quick.
Library Hacking
Meanwhile, our host George Goldberg worked on the KTelepathy library that is the immediate foundation for all the other components. This is responsible for uniting the individual contacts that Telepathy deals with into Persons, equivalent to Kopete's metacontacts. It makes heavy use of Nepomuk, KDE's central store of metadata and interrelationships between objects. Master of Semantics, Sebastian Trueg attended the meeting to provide on-the-spot advice in writing optimal Nepomuk queries, updates to the semantic ontologies that describe how Instant Messaging data fits together. And he provided instant fixes when we ran into problems.
George Kiagiadakis, coming to KDE Telepathy from KCall, worked on the call UI while David Edmundson took on the chat window, assisted by Dominik Schmidt in the Webkit-based implementation of Adium theme support. Dario Freddi, meanwhile, hacked on adapting the contact list to the current Telepathy APIs, while Daniele Domenchielli planned API designs and helped with the UIs.
Future Plans
The project team plans to make an initial release outside the KDE release cycle in January and to explore including Telepathy in KDE Platform 4.7 in July 2011. Additional contributors are welcome in #kde-telepathy on Freenode or on the kde-telepathy @ kde.org mailing list. There are plenty interesting tasks left to be picked up!