Discussion:
How to deal with .desktop renames (recommended for dbus activation) and users configs (launchers, mimetype handlers, ...)
Sebastien Bacher
2014-11-26 10:00:42 UTC
Permalink
Hey there,

To be dbus activable applications need to rename their .desktop [1], we
started seeing some applications doing that (e.g gedit renamed from
gedit.desktop to org.gnome.Gedit.desktop)

That's creating an issue for users/distributions, since the old .desktop
name is written in launchers' configuration and mimetype handlers
configurations.

Is there a recommended way to deal with the upgrade issue?

Should applications keep shipping a .desktop with the old name and
NoDisplay or something around those line? Should a new "alias" kind of
key be added that would allow the new .desktop to declare claiming other
names as well (would require updating parsers and it might make handling
of conflicts non trivial)

Thoughts?

Thanks,
Sebastien Bacher

[1]
http://standards.freedesktop.org/desktop-entry-spec/desktop-entry-spec-1.1.html#dbus
Ryan Lortie
2014-11-26 15:40:38 UTC
Permalink
hi,
Post by Sebastien Bacher
Should applications keep shipping a .desktop with the old name and
NoDisplay or something around those line? Should a new "alias" kind of
key be added that would allow the new .desktop to declare claiming other
names as well (would require updating parsers and it might make handling
of conflicts non trivial)
I agree that this is a problem and I'm sorry that we didn't address it
before now.

It's my opinion that we want to at least add an Aliases= key to desktop
files.

My reason for thinking this is because it's the least-effort thing for
application authors to do (nobody would object to adding a single line
to a file). It also puts the metadata about these renames where it
belongs: upstream.

Meanwhile, any other thing that we want to do can be based on this.

There are a few possibilities:

One is that we could attempt to 'migrate' the old data that we find in
the user's session. There are hook mechanisms in place for this sort of
stuff already (Ubuntu features 'session-migration'). This would involve
at least updating the user's mime associations to the new names, but
applications (mostly launchers) would probably also want to provide
hooks for updating their databases as well.

Another possibility is to create a copy of the original desktop file
marked NoDisplay=true, with an additional key like
X-FreeDesktop-IsAlias=true or such. update-desktop-database would use
this extra key to garbage-collect the file once the original app is
uninstalled (or once it stops advertising the Alias=). We might also
consider adding a new public key like CanonicalName= that points back to
the file that this is an alias for. That would give applications a
mechanism by which they could update their settings.

Another possibility is to collect all of the aliases into a cache
(similar to the mimeapps one) and teach the various desktop file parser
implementations about this.

A final possibility is to implement the idea with the NoDisplay=true
copy of the desktop file at package build time -- there could be a dpkg
(etc.) hook for creating a second copy of the desktop file that gets
installed under the old name as part of the package.


I don't have a strong opinion on which is the best way forward here and
I welcome the thoughts of others. One thing I'm quite sure of, though,
is that any solution is going to begin with an "Aliases=" line in the
desktop file installed by applications.

Cheers

Loading...