[prev in list] [next in list] [prev in thread] [next in thread] 

List:       kde-core-devel
Subject:    Re: Review Request: Pluggable KFileDialog/KAbstractFileModule
From:       "David Faure" <faure () kde ! org>
Date:       2009-08-30 22:26:53
Message-ID: 20090830222653.14746.65208 () localhost
[Download RAW message or body]


-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
http://reviewboard.kde.org/r/1407/#review2202
-----------------------------------------------------------

Ship it!


Heh. This is funny side effect of the kde-4.0 change were we made kfile dlopened. The \
idea was not at all to allow other implementations of it (rather it was just to delay \
the loading of that code). But ok, why not :)

About using the trader: indeed, not much point when the library name is already known \
(from the config). Using the trader would make sense if you wanted the user to be \
able to configure the preferred "KIO/FileModule" without knowing the name of the \
library (but simply by selecting in the list of available ones), or if you wanted the \
mere installation of the alternate module to mean it should be used \
(InitialPreference field). But indeed we don't want that in the case of the file \
dialog.

The fallback to loadFileModule("kfilemodule") could be done only if moduleName != \
"kfilemodule", btw, to avoid trying the same thing twice.

Anyway. No real objections to the patch, but I wonder if the integration of nepomuk \
features in the filedialog shouldn't be done with an additional "mode" in the \
existing filedialog rather than a hard all-or-nothing config item. A user might want \
to sometimes "query nepomuk" and sometimes "use the old-fashioned way"...

- David


On 2009-08-28 13:16:59, Sebastian Trueg wrote:
> 
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> http://reviewboard.kde.org/r/1407/
> -----------------------------------------------------------
> 
> (Updated 2009-08-28 13:16:59)
> 
> 
> Review request for kdelibs.
> 
> 
> Summary
> -------
> 
> KIO already loads the widget used in the KFileDialog dynamically from \
> libkfilemodule. The base class is KAbstractFileModule. However, the loaded \
> lib/plugin is fixed. This small patch changes the situation making it really \
> pluggable by using the standard KService procedure of loading plugins. It allows to \
> easily change the file dialog implementation by creating a plugin of type \
> "KIO/FileModule" and adding its name to the "kfilemodulerc" config file. The reason \
> for this is that in the GSoC Alessandro Sivieri developed a replacement for the \
> file dialog based on Nepomuk. He tried to patch it into kdelibs but it was a mess \
> due to all the dependencies. With this approach implementations can easily be \
> switched. 
> Open issues:
> * the patch uses KService::serviceByDesktopName but also contains commented code \
>                 using KServiceTypeTrader. I am not sure which is preferable.
> * I left in the legacy code of loading the filemodule from libkfilemodule. I \
> suppose this should be removed. 
> 
> Diffs
> -----
> 
> trunk/KDE/kdelibs/kfile/CMakeLists.txt 1013393 
> trunk/KDE/kdelibs/kfile/kfilemodule.desktop PRE-CREATION 
> trunk/KDE/kdelibs/kfile/kfilemodule.h 1013393 
> trunk/KDE/kdelibs/kfile/kfilemodule.cpp 1013393 
> trunk/KDE/kdelibs/kio/CMakeLists.txt 1013393 
> trunk/KDE/kdelibs/kio/kfile/kfiledialog.cpp 1013393 
> trunk/KDE/kdelibs/kio/kfile/kiofilemodule.desktop PRE-CREATION 
> 
> Diff: http://reviewboard.kde.org/r/1407/diff
> 
> 
> Testing
> -------
> 
> 
> Thanks,
> 
> Sebastian
> 
> 


[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic