<html><head></head><body><div class="gmail_quote">On 3 May 2021 7:06:05 pm GMT+05:30, "Jehan Pagès" <jehan.marmottard@gmail.com> wrote:<blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;">
<div dir="ltr"><div dir="ltr">Hi!<br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Mon, May 3, 2021 at 2:40 PM David Faure <<a href="mailto:faure@kde.org">faure@kde.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">On lundi 3 mai 2021 13:47:17 CEST Eli Schwartz wrote:<br>
> On 5/3/21 5:58 AM, David Faure wrote:<br>
> > On jeudi 18 février 2021 03:17:45 CEST Eli Schwartz wrote:<br>
> >> On 2/17/21 5:52 PM, Bastien Nocera wrote:<br>
> >>> The order for mime-types with no defaults has nothing to do with a<br>
> >>> "shared database", it's implementation specific, as it's not codified<br>
> >>> in the mime specs. GLib probably behaves differently than Qt does,<br>
> >>> which means that the file managers using either of those are likely to<br>
> >>> behave differently.<br>
> >> <br>
> >> Qt's native support for opening files in accordance with XDG is to<br>
> >> invoke /usr/bin/xdg-open.<br>
> > <br>
> > The actual code for choosing preferred applications for a mimetype, in the<br>
> > Qt/ KDE world, isn't in Qt, but in KDE Frameworks (KService).<br>
> <br>
> That seems highly unlikely.<br>
<br>
Wanna bet? It's my code, I know very well where it is :)<br>
<br>
(But we in fact agree, see below. I should have prefixed my sentence with a <br>
"Yes,")<br>
<br>
> The Qt world can't possibly depend on the<br>
> KDE world, because KDE builds on Qt rather than Qt building on KDE. So<br>
> applications using Qt for cross-platform application programming, which<br>
> aren't KDE applications, will not suddenly go link in KService.<br>
<br>
Link, no, indeed, but there are other ways to call code than linking: <br>
executing processes, for instance.<br>
<br>
> In fact, like I said immediately above, Qt's native facility here is<br>
> QDesktopServices::openUrl() which invokes xdg-open. xdg-open then checks<br>
> various things to probe for your currently running DE, and...<br>
> <br>
> If that DE is some version of kde it will run kde-open or kfmclient.<br>
<br>
Exactly. And kde-open calls into KService. So for a Qt app in a KDE <br>
environment (Plasma workspace), my assessment is correct, the actual <br>
implementation that ends up being triggered is the one in KService.<br>
<br>
> If that DE is gnome, then "the Qt world" will be running a program that<br>
> then runs "gio open", and hence the actual code for choosing preferred<br>
> applications in the Qt world isn't in Qt, but in GLib.<br>
<br>
Right.<br>
<br>
> I chose my words very carefully in response to "GLib probably behaves<br>
> differently than Qt does" by pointing out that Qt in fact does nothing,<br>
> but I assumed people know that xdg-open defers to GLib if you're logged<br>
> into gnome, and defers to KDE frameworks if you're logged into KDE.<br>
<br>
OK. Then we're both right. I also chose my words very carefully by saying<br>
"in the Qt/KDE world", i.e. when KDE is there into the equation.<br>
<br>
> Yes, I'm on the packaging team for a Linux distro that declines to be<br>
> put in the position of being an arbiter of good taste. Don't look to us<br>
> to choose preferred mimeapps.lst applications, we refuse.<br>
<br>
I understand. But then, if<br>
* the distro doesn't want to choose<br>
* the user hasn't made any specific choice<br>
* the application developers are not the best candidate for choosing<br>
then who remains? :)<br>
<br>
Actually in KDE we've had a historical solution which allowed application <br>
developers to set an "InitialPreference" number in the desktop file,<br>
but this still requires a desktop-environment-wide agreement.<br>
For instance it allowed us to say that for images, viewers should have<br>
a higher default preference than image editors.<br>
But looking at krita today I see a very high InitialPreference so I guess this <br>
didn't fully work out either...<br>
Let's just say it worked as a a 4th level like:<br>
* the desktop environment as a whole decides on ordering<br>
But of course with apps coming from multiple DEs this can only lead to a fight <br>
between gimp and krita as to who should have the highest preference.<br>
<br>
In the end I think <br>
1) desktop environments can provide a mimeapps-$desktop.lst for distros to use<br>
2) users will still have to do some adjustments, especially when using distros <br>
who didn't want to decide for them.<br>
<br>
The old debate of View vs Edit doesn't really solve this, as someone mentioned <br>
here, different apps have different features, which goes far beyond View or <br>
Edit.<br></blockquote><div><br></div><div>Which is why my original proposal is not about View vs Edit (please read it, as apparently you have not). It is about the intent of the app. If I take GIMP's intent, it is really about editing XCF files.</div><div><br></div><div>Now if we comes into PSD or ORA files, these are not GIMP's native files, but they have clearly similar intent and since we support it, yes GIMP is a very sane choice too (but if Photoshop were on Linux for instance, I would say it should advertize to be about editing PSD, hence take precedence when installed).</div><div><br></div><div>Finally we can open various end-formats (PNG, JPEG, WebM, and a few dozens more…) so GIMP advertizes it in its desktop file. It's important because it allows GIMP to be in the proposed secondary software (commonly right-click menu item "open with") which makes life easier to people; and also because in worst case when no other software can view some image format, even if you don't want to edit it, at least you can view it in GIMP as a fallback (I cited a few cases where we were the only free software able to display some formats for years AFAIK and even now there are some formats where it is still the case, it would seem).<br></div><div><br></div><div>This is not a GIMP-only situation. I remember cases in my experience where LibreOffice would open .txt files (like what?!) and other similar weird events. Right now, we are in this situation where the default is regularly just weird and there have been various reports of this for years.</div><div><br></div><div>So my proposition is not about View vs Edit, please read it. It is an intent concept, the intent is not too accurate on purpose, because at some point, over-precision doesn't make sense. Yes at some point the user will have to choose. For instance the format `.odt` is a valid native format for LibreOffice, OpenOffice and Calligra AFAIK, so if you have all 3 installed, the default could be any of these (until an explicit user decision). No need to add more accuracy IMO. But this much accuracy (as I proposed in 3 intents: native/intended, similar and supports) at least would be extremely useful to avoid obvious ridiculous defaults.</div><div><br></div><div>Jehan<br></div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
-- <br>
David Faure, <a href="mailto:faure@kde.org" target="_blank">faure@kde.org</a>, <a href="http://www.davidfaure.fr" rel="noreferrer" target="_blank">http://www.davidfaure.fr</a><br>
Working on KDE Frameworks 5<br>
<br>
<br>
<br>
_______________________________________________<br>
xdg mailing list<br>
<a href="mailto:xdg@lists.freedesktop.org" target="_blank">xdg@lists.freedesktop.org</a><br>
<a href="https://lists.freedesktop.org/mailman/listinfo/xdg" rel="noreferrer" target="_blank">https://lists.freedesktop.org/mailman/listinfo/xdg</a><br>
</blockquote></div><br clear="all"></div></blockquote></div><br clear="all">I think the best option will be a FallbackMIMETYPE which just makes the app lower priority that other option. So gimp, Krita (just had a SVG open in it), some ide can just set it and use It. Another important thing will be to extend the mimetype definitions so mimetypes can inherit mimetype of another mimetype so it reduce the need to set so many mimetype(Especially important for text editor where almost any editor that can handle text/plain can handle other mimetypes in text/ making automatic fallback will help too)</body></html>