Add elogind support

Resolves SirCmpwn/wlroots#146
This commit is contained in:
dudemanguy 2017-09-22 12:02:55 -05:00
parent e5e6dab7fd
commit 175f89f4ff
6 changed files with 22 additions and 3 deletions

View file

@ -28,9 +28,13 @@ if systemd.found()
backend_files += files('session/logind.c')
endif
if elogind.found()
backend_files += files('session/logind.c')
endif
lib_wlr_backend = static_library(
'wlr_backend',
backend_files,
include_directories: wlr_inc,
dependencies: [wayland_server, egl, gbm, libinput, systemd, wlr_protos],
dependencies: [wayland_server, egl, gbm, libinput, systemd, elogind, wlr_protos],
)

View file

@ -5,8 +5,6 @@
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <systemd/sd-bus.h>
#include <systemd/sd-login.h>
#include <unistd.h>
#include <sys/sysmacros.h>
#include <sys/stat.h>
@ -15,6 +13,14 @@
#include <wlr/backend/session/interface.h>
#include <wlr/util/log.h>
#ifdef HAS_SYSTEMD
#include <systemd/sd-bus.h>
#include <systemd/sd-login.h>
#elif HAS_ELOGIND
#include <elogind/sd-bus.h>
#include <elogind/sd-login.h>
#endif
enum { DRM_MAJOR = 226 };
const struct session_impl session_logind;

View file

@ -18,6 +18,8 @@ extern const struct session_impl session_direct;
static const struct session_impl *impls[] = {
#ifdef HAS_SYSTEMD
&session_logind,
#elif HAS_ELOGIND
&session_logind,
#endif
&session_direct,
NULL,