How Can I change wallpaper from CLI?

Aaron J. Seigo aseigo at kde.org
Thu Sep 6 11:50:19 UTC 2012


On Thursday, September 6, 2012 12:47:16 Kevin Krammer wrote:
> The problem with that (as far as I can tell) is that this would not be
> available to non-KDE apps, which (again as far as I understand) is the case
> of the thread starter.

if the issue was non-KDE apps, this would be an interesting starting point for 
discussion.

but the discussion moved to the example of a KIPI plugin for digikam. that is 
a KDE application.

once we get our own house in order, then i'd love to discuss about how we 
interface with the rest of the world.

> D-Bus interfaces have the advantage of being accessible from almost any
> program technology stack, most times even from shell scripts.

qdbus org.kde.ActivityManager /ActivityManager | grep Resource

we're smart enough to implement things in ways that aren't completely stupid. 
;)


and really this is a design question ("is associating URIs and metadata with 
windows a good / better solution? if so, how?"), not an implementation problem 
("what is used for remote procedure calls?"). 

even if the implementation is bad (though i don't believe it is), we can 
usefully improve the implementation as long as we have a good design to start 
with; the reverse is not true however -> design flaws don't get fixed by 
improving the implementation of them.

currently when it comes to things like setting wallpapers, our design sucked.

so some of us worked on improving that, and if you look at its use in Plasma 
Active you can judge for yourself whether or not it is an improvement or not.

and now we're asking the rest of our community to use that improved design 
broadly including on the desktop.

> > show me a dbus api for wallpaper setting that can do that. :)
> 
> Just curious: what kind of non-D-Bus communication mechanism is used by
> that?

it uses DBus. the differentiation is that it isn't focused on "making something 
to set a wallpaper" but focused on "allowing content to be introspected so 
that things can be done for/with that content".

making an API for "setting wallpaper" is not only fragile (see the differences 
in KDesktop 1, 2, 3 and Plasma; see the differences for windows, mac, xfce, 
gnome, etc) it is also very limited in scope and needs to be upkept in every 
single application.

the design concept of "expose the URI of the content this application window 
is showing" suffers none of those limitations. and it lets us do the trivial 
things like "set that as a wallpaper" easily: it's writing one plugin for one 
app (SLC) instead of writing one plugin for every single application out 
there.

really, it's the same thinking that went into things like kparts.

-- 
Aaron J. Seigo
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 198 bytes
Desc: This is a digitally signed message part.
URL: <http://mail.kde.org/pipermail/plasma-devel/attachments/20120906/6cff9f5d/attachment-0001.sig>


More information about the Plasma-devel mailing list