xdg-utils
xdg-utils 提供了用于管理 XDG MIME 应用程序 的官方工具。
- xdg-desktop-menu(1) - 安装桌面菜单项
- xdg-desktop-icon(1) - 将 桌面条目 复制到用户的桌面
- xdg-email(1) - 在用户首选的电子邮件客户端中撰写新邮件,并可预填主题和其他信息
- xdg-icon-resource(1) - 安装图标资源
- xdg-mime(1) - 查询并安装 MIME 类型及其关联
- xdg-open(1) - 使用用户首选的应用程序打开文件或 URI
- xdg-screensaver(1) - 启用、禁用或暂停屏幕保护程序
- xdg-settings(1) - 获取或设置默认 Web 浏览器和 URL 处理程序
安装
用法
环境变量
xdg-utils 尝试通过在适用时调用其提供的专门程序来与您的 桌面环境 集成。当前环境的评估流程如下 [1]
- 如果标准化的 XDG_CURRENT_DESKTOP 环境变量被设置为已识别的桌面环境,则使用相应的值。
- 如果存在任何经典回退变量或环境特定变量(例如 KDE 的
KDE_FULL_SESSION),则使用相应的值。 - 如果遗留的 DESKTOP_SESSION 环境变量被设置为已识别的桌面环境,则使用相应的值。
在此过程中,如果找到任何匹配项,DE 变量将在内部被覆盖为检测到的桌面环境的标准化值。因此,DE 既是一个遗留环境变量,也是 xdg-utils 的内部状态变量。例如,如果 XDG_CURRENT_DESKTOP 是 KDE,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 | Cinnamon, X-Cinnamon |
cinnamon |
– |
| Deepin | Deepin, DEEPIN, deepin1 |
deepin |
– |
| Enlightenment | ENLIGHTENMENT1 |
enlightenment |
– |
| GNOME | GNOME2 |
gnome |
gnome
|
| GNOME Flashback | GNOME-Flashback, GNOME-Flashback:GNOME2 |
gnome |
gnome
|
| KDE Plasma | KDE |
kde |
– |
| LXDE | LXDE |
lxde |
LXDE
|
| LXQt | LXQt |
lxqt |
– |
| MATE | MATE |
mate |
mate
|
| Xfce | XFCE |
xfce |
xfce, xfce4, Xfce Session |
- 这不是一个 在 freedesktop.org 注册的 环境。
- GNOME 的变体(包括 GNOME Classic 模式)在 xdg-utils 中都被视为相同。
请注意,这仅仅是 xdg-utils 提供的脚本能够 检测 到的列表。在以下条件下,脚本仍将执行通用的、与环境无关的操作:
- 通过
XDG_CURRENT_DESKTOP=X-Generic或DE=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 尝试为该桌面环境使用正确的程序
| 桌面环境 | 程序 | 软件包 (Package) |
|---|---|---|
| Cinnamon | gio
|
glib2 |
| GNOME | ||
| GNOME Flashback | ||
| LXDE | ||
| MATE | ||
| Xfce | ||
| Deepin | – | – |
| Enlightenment | ||
| LXQt | ||
| KDE Plasma | kmimetypefinder |
kde-cli-tools |
在通用情况下,xdg-mime 将
- 如果存在,则委派给 mimetype。需要 安装 perl-file-mimeinfo 软件包。
- 如果存在,则委派给 file。
xdg-open
xdg-open(1) 是一个被许多应用程序使用的 资源打开程序,它在实现 XDG MIME 应用程序标准的同时,尽可能与系统的桌面环境集成。
如果检测到桌面环境,将调用其提供的处理程序 [2]
| 桌面环境 | 程序 | 软件包 (Package) |
|---|---|---|
| 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 |
- 如果
KDE_SESSION_VERSION未设置,则将使用 konqueror 中的kfmclient。不过,KDE Plasma 在任何条件下都应该设置此变量。 - 也将尝试使用 glib2 中的
gio。
在通用情况下,xdg-open 将
- 查询 #xdg-mime 以获取与资源关联的默认桌面条目,解析该桌面条目并执行其命令。
- 如果存在,则委派给 run-mailcap。需要 安装 run-mailcapAUR 软件包。
- 如果存在,则委派给 mimeopen。需要 安装 perl-file-mimeinfo 软件包。
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 scheme 默认应用程序的快捷方式
$ xdg-settings set default-url-scheme-handler irc xchat.desktop
技巧与提示
URL scheme 处理程序
要设置 URL scheme 的默认应用程序,您可能还需要更改 x-scheme-handler/* MIME 类型的默认应用程序
$ xdg-mime default firefox.desktop x-scheme-handler/https x-scheme-handler/http