Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

PDF viewer MIME/DE/xdg-open defaults are ignored #3313

Closed
danielzgtg opened this issue Nov 13, 2023 · 3 comments · Fixed by #3746
Closed

PDF viewer MIME/DE/xdg-open defaults are ignored #3313

danielzgtg opened this issue Nov 13, 2023 · 3 comments · Fixed by #3746
Labels
enhancement New feature or (non bug related) change to the program.
Milestone

Comments

@danielzgtg
Copy link

Type of JetBrains IDE (IntelliJ, PyCharm, etc.) and version

IntelliJ IDEA 2023.2.2 (Ultimate Edition)
Build #IU-232.9921.47, built on September 12, 2023

Operating System

Ubuntu 23.10

TeXiFy IDEA version

0.9.1

What I did (steps to reproduce)

  1. Install
  2. Run any new document

Minimal example to reproduce the problem

\documentclass{article}
\begin{document}
    
\end{document}

Expected behavior

It should open Okular without me having to reconfigure it in the Run Configuration because it should autodetect my settings. If you want to parse the desktop environment, there is the XDG_CURRENT_DESKTOP=KDE environment variable. More generally, I have Okular at the top of my file associations, which is respected by xdg-open and part (the removed association of Evince) of it is stored at $XDG_CONFIG_DIRECTORY/mimeapps.list. Please detect the config in either place so people on both DEs will be happy.

Actual behavior

Evince is set to the default. Unlike Firefox, where removing the MIME association for zips causes it to use the KDE version, not even that works for TeXiFy. The only way to fix this is to change the Run Configuration. Uninstalling Evince could also work but I do not want to.

(if applicable) The full stacktrace of the exception thrown

No exception was thrown.

@danielzgtg danielzgtg added bug Deficiencies in TeXiFy behaviour. untriaged Issue type still needs to be triaged or verified. labels Nov 13, 2023
@PHPirates
Copy link
Collaborator

Thanks for the suggestion, I think you are right in that the current default is Evince if it is installed. We could have an entry like 'system default' which is selected by default if it is a supported PDF viewer. However, I don't know of a good way to check if xdg-open will open a supported PDF viewer? I would prefer opening a known supported PDF viewer rather than a system default one which is not.
I'm not sure about using XDG_CURRENT_DESKTOP, because which desktop you are running does not directly imply which pdf viewer you have as default, even if there are likely options, but if you have multiple PDF viewers installed you are already not really a 'defaults only' user I would say.
I don't have XDG_CONFIG_DIRECTORY, is that common to set manually, or a KDE thing?

Also I just want to check if you aware of run configuration templates: https://hannah-sten.github.io/TeXiFy-IDEA/running-a-latex-file.html#template-run-configurations

@PHPirates PHPirates added more-info-needed More information is needed from the person filing the issue. and removed untriaged Issue type still needs to be triaged or verified. labels Nov 13, 2023
@danielzgtg
Copy link
Author

Thank you for teaching me about run configuration templates. I just found out that there are both per-project and global versions. XDG_CONFIG_DIRECTORY is not set for me either, but it is specified that applications shall default to ~/.config. But nevermind those environment variables.

I remembered the command to find what xdg-open would open:

$ xdg-mime query default application/pdf
okularApplication_pdf.desktop
$ # After changing the file association:
$ xdg-mime query default application/pdf
org.gnome.Evince.desktop

This is part of the xdg-utils deb and is a preinstalled dependency of most desktop environments. If finding the .desktop file and parsing the Exec= would add too much complexity, TeXiFy could just match a substring in the xdg-mime output.

@PHPirates
Copy link
Collaborator

Thanks a lot! That command works for me as well, that should be easy enough to implement, indeed simple string matching should be sufficient. If it gives output then we can take the system default as default pdf viewer in the run configuration template.

I just remembered why it is not a good idea to use xdg-open by default: for forward search we need custom things, e.g. for Evince you need to communicate via the dbus.

@PHPirates PHPirates added enhancement New feature or (non bug related) change to the program. and removed bug Deficiencies in TeXiFy behaviour. more-info-needed More information is needed from the person filing the issue. labels Nov 14, 2023
@PHPirates PHPirates added this to the Next milestone Nov 10, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or (non bug related) change to the program.
Projects
None yet
2 participants