| Age | Commit message (Collapse) | Author | 
|---|
|  | Setting auto_features=disabled is supposed to disable all optional
dependencies. Since we aren't using a feature option here, we need
to manually add logic to disable logind in this case. | 
|  | These features don't have any dependencies, so "auto" doesn't make
sense. | 
|  | This removes the "Program sh found" line in the build logs, and
should not change anything else. | 
|  | If -Dlogind=auto but systemd/elogind isn't available,
logind_provider would get set to the last item of the foreach loop.
This would incorrectly report "systemd: YES". | 
|  | Allow package maintainers to explicitly select a logind provider
by passing -Dlogind=systemd or -Dlogind=elogind. In case both are
available (e.g. for distributions which support both), this makes
it possible to gte deterministic behavior.
By default, auto-detect the logind provider. That way, users which
have systemd or elogind installed get the backend built by default. | 
|  |  | 
|  |  | 
|  | clang-format wants to put the terminating NULLs on the same line as the
noop backend when it doens't have any immediate non-NULL neighbors.
Add a newline to stop it. | 
|  | This can be used by parent projects when seatd is a subproject:
    libseat = dependency('libseat', fallback: ['seatd', 'libseat']) | 
|  | This is useful for headless testing, for instance with VKMS:
    modprobe vkms
    export WLR_DRM_DEVICES=/dev/dri/card1
    export WLR_BACKENDS=drm
    export LIBSEAT_BACKEND=noop
    sway
We don't need any of the VT handling in this case. | 
|  | https://cgit.freebsd.org/src/commit/?id=925f44f33862908f9a2e72520a17af148c7d0db5
https://cgit.freebsd.org/src/commit/?id=2b61bda2c75f30f6eadd18fb891fd885e4c8d19d | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | Needed for the clang-format target. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | This fd would only still be set after closing clients if no clients were
active on the current VT. | 
|  | Removing the link before before means that we can return without a link,
resulting in a double-remove. | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | `seatd.1` is the only man page, so it's not necessary to install it or
require scdoc when the server is not built. | 
|  | If a client closed while it was disabled, the VT would not be torn down.
If the user navigated back to the VT it belonged to, they would be
stuck.
When a client is disabled, open the fd for the VT it belonged to and
perform regular teardown on it. | 
|  | This simplifies logic in seat handling. | 
|  |  | 
|  | This is not strictly speaking necessary as detaching from the bus should
trigger this automatically, but elogind apparently has issues with this.
Doing this explicitly does no harm, so let's just do that. | 
|  |  | 
|  |  | 
|  | This is only available on FreeBSD 13, so test for that version. | 
|  | This is wrong, and leads to LOCAL_PEERCRED being interpreted as
SO_DEBUG. 0 should be used instead.
See: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=246189. | 
|  | Upstream says compositors should wait for DRM nodes using udev instead. | 
|  | It currently returned -1 on failure and 1 on success. The API is
intended to return -1 on failure and 0 on success, so fix that. | 
|  |  | 
|  |  | 
|  | There is nothing for us to dispatch unless we wake on an fd, so just
retry poll if it fails with EINTR instead of doing a full dispatch loop. | 
|  | The most common pain point I've seen with people trying out seat is
forgetting to add themselves to whatever group the distro has chosen
to own the socket.
Logging this error and path of the socket should make it easier to tell
why things aren't working. |