hyprland-wiki/pages/Useful Utilities/Hyprland-desktop-portal.md

119 lines
3.1 KiB
Markdown
Raw Permalink Normal View History

2022-12-03 23:52:10 +01:00
An XDG Desktop Portal (later called XDP) is a program that lets other
applications communicate swiftly with the compositor through D-Bus.
It's used for stuff like e.g. opening file pickers, screen sharing.
On Wayland, it also requires an implementation. For Hyprland,
you'd usually use `xdg-desktop-portal-wlr` (later called XDPW)
Unfortunately, due to various reasons the -wlr portal is inferior
to the KDE or Gnome ones.
In order to bridge the gap, Hyprland has its own fork of XDPW that
has more features, called [xdg-desktop-portal-hyprland](https://github.com/hyprwm/xdg-desktop-portal-hyprland).
(later called XDPH)
{{< hint type=important >}}
You don't **need** XDPH. Hyprland will work with XDPW, but XDPH has more features, like e.g.
2022-12-05 02:02:43 +01:00
window sharing.
2022-12-05 02:07:34 +01:00
XDPH will work on other wlroots-based compositors, although limited to the XDPW features (other
will be disabled)
2022-12-03 23:52:10 +01:00
{{< /hint >}}
## Installing
{{< tabs "uniqueid" >}}
2022-12-03 23:52:10 +01:00
{{< tab "Arch Linux" >}}
```plain
2023-04-11 00:03:21 +02:00
pacman -S xdg-desktop-portal-hyprland
```
or, for -git:
```plain
2022-12-05 02:01:55 +01:00
yay -S xdg-desktop-portal-hyprland-git
```
2023-01-20 16:56:34 +01:00
{{< /tab >}}
{{< tab "Gentoo" >}}
## Unmask dependencies
### /etc/portage/profile/package.unmask
```plain
dev-qt/qtbase
dev-qt/qtwayland
dev-qt/qtdeclarative
dev-qt/qtshadertools
```
## Apply necessary useflags
### /etc/portage/package.use
```plain
dev-qt/qtbase opengl egl eglfs gles2-only
dev-qt/qtdeclarative opengl
sys-apps/xdg-desktop-portal screencast
```
## Unmask dependencies and xdph
### /etc/portage/package.accept_keywords
```plain
gui-libs/xdg-desktop-portal-hyprland
dev-qt/qtbase
dev-qt/qtwayland
dev-qt/qtdeclarative
dev-qt/qtshadertools
```
btw those are the useflags that I have tested, you could also test others.
## Installation
```sh
eselect repository enable guru
emaint sync -r guru
emerge --ask --verbose gui-libs/xdg-desktop-portal-hyprland
```
{{< /tab >}}
{{< tab "Manual" >}}
2022-12-03 23:52:10 +01:00
See [The Github repo's readme](https://github.com/hyprwm/xdg-desktop-portal-hyprland).
{{</ tab >}}
{{< /tabs >}}
2023-08-26 17:13:54 +02:00
{{< hint type=tip >}}
XDPH doesn't implement a file picker. For that, I recommend installing `xdg-desktop-portal-gtk` alongside XDPH.
2022-12-10 18:06:29 +01:00
{{< /hint >}}
2022-12-05 02:01:55 +01:00
## Usage
Should start automatically.
The most basic way of telling everything is OK is by trying to screenshare anything, or
open OBS and select pipewire source. If XDPH is running, a qt menu will pop up asking you
what to share.
If it doesn't, and you get e.g. slurp, then XDPW is launching. In that case, try removing XDPW.
XDPH will work on other wlroots compositors, but features available only on Hyprland will not work
(e.g. window sharing)
2022-12-03 23:52:10 +01:00
For a nuclear option, you can use this script and `exec-once` it:
```sh
#!/bin/bash
sleep 1
killall -e xdg-desktop-portal-hyprland
killall -e xdg-desktop-portal-wlr
2022-12-03 23:52:10 +01:00
killall xdg-desktop-portal
2023-02-08 11:18:09 +01:00
/usr/lib/xdg-desktop-portal-hyprland &
2022-12-03 23:52:10 +01:00
sleep 2
/usr/lib/xdg-desktop-portal &
```
2022-12-05 02:01:55 +01:00
adjust the paths if incorrect.
2023-02-17 00:56:49 +01:00
## Debugging
If you get long app launch times, or screensharing does not work, consult the logs.
`systemctl --user status xdg-desktop-portal-hyprland`
if you see a crash, it's most likely you are missing `qt6-wayland` and/or `qt5-wayland`.