[Telepathy] GSoC - Project Idea (refined)
Guillaume Desmottes
guillaume.desmottes at collabora.co.uk
Wed Mar 24 01:17:12 PDT 2010
Le mardi 23 mars 2010 à 11:16 +0100, Salomon Sickert a écrit :
> (I'm a potential GSoC-applicant looking for feedback on a project idea.)
Hi Salomon,
> Thanks for all the feedback. After reading through all this and
> reviewing the source code of the Mathusalem Projekt¹, it becomes clear
> to me, that my idea description was not precise enough.
>
> (As this is a cross-post, the original post is attached)
>
> Some notes about the project idea for SoC:
>
> 1. Creation of a set of simple D-Bus Interfaces, which allows the
> application developer to expose progress information about a
> running (background) task, which the user could be caring about.
> (e.g. Downloads, Burning, Backups, File Transfers, Printing
> Jobs, Cloning GIT, Syncing, ...) Things the user don't care
> about are not exposed. (e.g. updating locales-cache, rotating
> logs, ...)
How your project will be related to Mathusalem? Will you re-use code? Or
at least some part of the D-Bus API? I think it would be worth to
discuss with Steve to not lose experience from the past.
>
> 2. This is NOT about moving all file/io functionality in a common
> structure (which was in my understanding the central idea of the
> Mathusalem Project). In many cases this is not possible and also
> requires a lot of hard work. There are simply to many different
> protocols with specialised code. Also the approach is
> cross-desktop and I doubt the KDE-People would like to switch to
> an patched GIO/gvfs from their KIO. Another point is that in
> many cases it becomes very hairy to do all the error handling.
> In my opinion it is much easier to add a D-Bus Interface instead
> of moving whole portions of the code. I think these are the main
> reason, why Mathusalem didn't got integrated.
> 3. Integrating of my Interface should be fairly easy. A support
> library should allow the application developer to get done under
> one hour. The changes to the codebase should be minimal and
> trivial.
> 4. As the project aims to be ready for GNOME 3.0 (or 3.2 if the
> deadline is not met.), I will keep the thing simple and easy to
> migrate. In the case the project is accepted, I'm able to work
> much of my time on the project. I hope this enables me to have
> working base at the time for midterm evaluation and allows me
> then to concentrate on writing integration patches for other
> GNOME applications.
I guess you plan to write an UI displaying running tasks as well. It
would be interested to check with gnome-shell guys if that's something
they'd be interested in.
> What are the benefits?
> 1. It It is possible to create an central UI, where users can check
> the progress of his tasks. No more ten different dialogues,
> which clutter the workspace.
> 2. A more unified look'n'feel.
> 3. It's cross-desktop! It doesn't matter if its GNOME, KDE or
> whatever. It even doesn't have to draw an UI, it only hast to
> export the Interface, the rest is done from my project. (e.g.
> wget with D-Bus interface)
> 4. Integration with power management:
> * When the user hits the suspend button and there are non
> pause-able tasks, he gets notified. All pause-able task are
> automatically paused and resumed.
> * Running on battery will cause all pause-able jobs will
> automatically paused. Running von AC will cause that are
> resumed.
> * ...
>
> I hope this clarify my ideas. In the very near future a more technical
> detailed introduction can be found on my website, including a
> Proof-of-Concept.²
>
> As always feedback is appreciated, especially from Nautilus, Epiphany
> and Empathy developers. (What are your needs, what information should be
> exposed, how much logic should stay in the application, ...)
If other GNOME projects are interested in this feature I'd be happy to
integrate in Empathy/Telepathy as well.
We'll probably use it to display file transfers. From a Telepathy pov
that could be done without modifying Empathy by implementing an Observer
[1] watching FileTransfer channel [2].
Good luck with your project,
G.
[1]
http://telepathy.freedesktop.org/spec/org.freedesktop.Telepathy.Client.Observer.html
[2]
http://telepathy.freedesktop.org/spec/org.freedesktop.Telepathy.Channel.Type.FileTransfer.html
More information about the telepathy
mailing list