xdg-utils

出自 ArchWiki
(重定向自 Xdg-open

xdg-utils 提供了用于管理 XDG MIME 应用程序的官方实用程序。

安装

安装 xdg-utils 软件包。

用法

环境变量

注意: 正常运行的桌面环境应自动设置这些变量。本节仅用于理解 xdg-utils 的工作原理,例如用于故障排除。

xdg-utils 尝试通过调用其提供的专用程序(如果适用)与您的 桌面环境 集成。当前环境的评估如下 [1]

  • 如果标准化的 XDG_CURRENT_DESKTOP 环境变量设置为已识别的桌面环境,则使用相应的值。
  • 如果存在任何经典回退或特定于环境的变量(例如 KDE 的 KDE_FULL_SESSION),则使用相应的值。
  • 如果旧版 DESKTOP_SESSION 环境变量设置为已识别的桌面环境,则使用相应的值。

在此过程中,如果找到任何匹配项,则 DE 变量将在内部被检测到的桌面环境的规范化值覆盖。因此,DE 既是旧版环境变量,也是 xdg-utils 的内部状态变量。例如,如果 XDG_CURRENT_DESKTOPKDE,则 xdg-utils 将在内部将 DE 设置为 kde。如果未找到匹配项,则将使用任何预先存在的 DE 值,这样 XDG_CURRENT_DESKTOP=KDE 等同于 XDG_CURRENT_DESKTOP 未设置,并且具有 DE=kde。值得注意的是这个实现细节,因为它导致了以下结果:如果以其他方式检测到桌面环境,则预设的 DE 将被忽略

xdg-utils 识别的变量的值为

桌面环境 XDG_CURRENT_DESKTOP DE DESKTOP_SESSION
X-Generic1 generic
Cinnamon CinnamonX-Cinnamon cinnamon
Deepin DeepinDEEPINdeepin1 deepin
Enlightenment ENLIGHTENMENT1 enlightenment
GNOME GNOME2 gnome gnome
GNOME Flashback GNOME-FlashbackGNOME-Flashback:GNOME2 gnome gnome
KDE Plasma KDE kde
LXDE LXDE lxde LXDE
LXQt LXQt lxqt
MATE MATE mate mate
Xfce XFCE xfce xfcexfce4Xfce Session
  1. 这不是一个 在 freedesktop.org 上注册 的环境。
  2. GNOME 变体,包括 GNOME Classic 模式,都被 xdg-utils 视为相同。

请注意,这只是 xdg-utils 提供的脚本能够检测的内容列表。在以下情况下,脚本仍将执行通用的、与环境无关的操作

  • 通过 XDG_CURRENT_DESKTOP=X-GenericDE=generic 请求了通用例程。
  • 环境检测失败。所有相关的环境变量都无法识别或未设置,并且经典回退没有显示任何内容。
  • 执行了特定于环境的操作,但失败了,例如,由于缺少程序。

xdg-mime

xdg-mime(1) 是一个用于直接查询和修改默认 MIME 应用程序的脚本。它在其他脚本(如 xdg-open)中使用,也是一个有用的故障排除工具。

确定文件的 MIME 类型

$ xdg-mime query filetype photo.jpeg
image/jpeg

确定 MIME 类型的默认应用程序

$ xdg-mime query default image/jpeg
gimp.desktop

更改 MIME 类型的默认应用程序

$ xdg-mime default feh.desktop image/jpeg

要将文件管理器设置为默认文件管理器(例如 -Thunar),请输入

$ xdg-mime default thunar.desktop inode/directory

调试 MIME 类型的默认应用程序

$ env XDG_UTILS_DEBUG_LEVEL=10  xdg-mime query default text/html
Checking /home/user/.config/mimeapps.list
Checking /home/user/.local/share/applications/defaults.list and /home/user/.local/share/applications/mimeinfo.cache
Checking /usr/local/share/applications/defaults.list and /usr/local/share/applications/mimeinfo.cache
Checking /usr/share/applications/defaults.list and /usr/share/applications/mimeinfo.cache
qutebrowser.desktop

当需要确定文件的 MIME 类型时,xdg-mime 尝试使用适合桌面环境的程序

桌面环境 程序 软件包
Cinnamon gio glib2
GNOME
GNOME Flashback
LXDE
MATE
Xfce
Deepin
Enlightenment
LXQt
KDE Plasma kmimetypefinder kde-cli-tools

在通用情况下,xdg-mime

xdg-open

xdg-open(1) 是一个 资源打开器,被许多应用程序使用,实现了 XDG MIME 应用程序标准,同时尽可能与系统的桌面环境集成。

如果检测到桌面环境,将调用其提供的处理程序 [2]

桌面环境 程序 软件包
Cinnamon gio glib2
GNOME
GNOME Flashback
MATE
Deepin dde-open deepin-api
Enlightenment enlightenment_open enlightenment
KDE Plasma kde-open1 kde-cli-tools
LXDE pcmanfm pcmanfm
LXQt
Xfce exo-open2 exo
  1. 如果 KDE_SESSION_VERSION 未设置,则将使用 konqueror 中的 kfmclient 代替。但是,KDE Plasma 应该在任何情况下都设置此变量。
  2. 还将尝试使用 glib2 中的 gio

在通用情况下,xdg-open

提示: 要查看 xdg-open 将使用哪个后端,请设置 XDG_UTILS_DEBUG_LEVEL=3

由于 xdg-mime 依赖于 perl-file-mimeinfo 软件包来实现 XDG MIME 应用程序标准,如果您不使用桌面环境,则应安装 perl-file-mimeinfo,或考虑使用不同的 资源打开器

xdg-settings

请参阅 xdg-settings(1)

使用单个应用程序打开所有 Web MIME 类型的快捷方式

$ xdg-settings set default-web-browser firefox.desktop

用于设置 URL 方案的默认应用程序的快捷方式

$ xdg-settings set default-url-scheme-handler irc xchat.desktop

技巧与提示

URL 方案处理程序

要为 URL 方案设置默认应用程序,您可能还需要更改 x-scheme-handler/* MIME 类型的默认应用程序

$ xdg-mime default firefox.desktop x-scheme-handler/https x-scheme-handler/http