X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Flogind.h;h=d91cae38fe19006630c353c3a4e7f2134f09edb7;hb=6f7f51f793e5f2a5d42e05e3f1e3101f49d37299;hp=8702d1aed27247244ddd054e69377d53063dcc8b;hpb=47a2669062882d1b4ed6ae3c7b8926e09f2a978e;p=elogind.git diff --git a/src/logind.h b/src/logind.h index 8702d1aed..d91cae38f 100644 --- a/src/logind.h +++ b/src/logind.h @@ -36,9 +36,16 @@ * * spawn user systemd * direct client API - * add configuration file - * D-Bus method: AttachDevices(seat, devices[]); - * use named pipes to detect when a session dies + * add display symlinks also per-session + * + * udev: + * drop redundant udev_device_get_is_initialized() use as soon as libudev is fixed + * properly escape/remove : and . from seat names in udev rules + * use device_has_tag() as soon as it is available + * trigger based on libudev if available + * enumerate recursively with libudev when triggering + * use sysfs in device hash table, not sysname, when fb driver is fixed + * fix ACL enumeration as soon as libudev can properly handle two match tags when enumerating * * non-local X11 server * reboot/shutdown halt management @@ -78,7 +85,7 @@ struct Manager { Seat *vtconsole; char *cgroup_path; - char **controllers; + char **controllers, **reset_controllers; char **kill_only_users, **kill_exclude_users; @@ -87,7 +94,7 @@ struct Manager { unsigned long session_counter; Hashmap *cgroups; - Hashmap *pipe_fds; + Hashmap *fifo_fds; }; enum { @@ -95,7 +102,7 @@ enum { FD_VCSA_UDEV, FD_CONSOLE, FD_BUS, - FD_PIPE_BASE + FD_FIFO_BASE }; Manager *manager_new(void); @@ -124,7 +131,7 @@ int manager_spawn_autovt(Manager *m, int vtnr); void manager_cgroup_notify_empty(Manager *m, const char *cgroup); -void manager_gc(Manager *m); +void manager_gc(Manager *m, bool drop_not_started); int manager_get_idle_hint(Manager *m, dual_timestamp *t);