Running queries via dbus
Alex Merry
kde at randomguy3.me.uk
Tue Mar 23 22:55:08 CET 2010
CC'ing plasma-devel, since this is an important point regarding runners that
use D-Bus. Please keep any discussion on this issue at plasma-devel.
On Tuesday 23 March 2010 17:26:54 Alex Merry wrote:
> On Monday 22 March 2010 22:05:26 Jacopo De Simoi wrote:
> > > In particular, Meta::Track has float as the return type of bpm().
> > > Perhaps it would be sensible to make this a qreal? Also, score()
> > > should probably also return qreal (rather than double) for
> > > consistency.
> >
> > Probably qreal would be the better choice; would it be possible to change
> > it only when using dbus, to minimize interference with other parts of the
> > code? As far as I can tell this issue makes the dbus query interface
> > basically useless in most cases.
>
> Well, yes, but it would be cleaner to just use qreal everywhere.
Right, committed this - it will be in the next release of Amarok.
BUT the main issue over the freezing interface is that the audioplayercontrol
runner is using synchronous D-Bus calls (QDBusConnection::call). This not
only blocks the calling thread, but the main thread as well (since that's
where the D-Bus call actually happens).
Instead, you should use QDBusConnection::asyncCall. This can be used in
exactly the same way (implicit casting FTW), and casting to a QDBusReply will
cause the calling thread to block as you would expect. But, importantly, it
WON'T cause the main thread to block.
Alternatively, you can pass QDBus::BlockWithGui as an argument to
QDBusConnection::call.
I'll commit this change to audioplayercontrol to trunk. Should I also
backport it?
Alex
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 198 bytes
Desc: This is a digitally signed message part.
Url : http://mail.kde.org/pipermail/amarok-devel/attachments/20100323/25c6fa18/attachment-0001.sig
More information about the Amarok-devel
mailing list