|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
From 3c56cab44150ad47323970cfadfb0257c6305a74 Mon Sep 17 00:00:00 2001
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
From: Ben Wolsieffer <benwolsieffer@gmail.com>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Date: Tue, 26 Aug 2014 22:08:02 +0200
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Subject: [PATCH] logind: add HandleLidSwitchDocked= option to logind.conf +
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
documentation
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
https://bugs.freedesktop.org/show_bug.cgi?id=82485
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
---
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
man/logind.conf.xml | 16 +++++++++++-----
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/login/logind-action.c | 18 ------------------
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/login/logind-button.c | 18 ++++++++++++++++--
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/login/logind-core.c | 22 ++++++++++++++++++++++
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/login/logind-dbus.c | 1 +
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/login/logind-gperf.gperf | 1 +
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/login/logind.c | 7 +++++--
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/login/logind.conf | 1 +
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/login/logind.h | 2 ++
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
9 files changed, 59 insertions(+), 27 deletions(-)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/man/logind.conf.xml b/man/logind.conf.xml
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index f037da259b..8ba95230be 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/man/logind.conf.xml
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/man/logind.conf.xml
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -224,6 +224,7 @@
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
<term><varname>HandleSuspendKey=</varname></term>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
<term><varname>HandleHibernateKey=</varname></term>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
<term><varname>HandleLidSwitch=</varname></term>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ <term><varname>HandleLidSwitchDocked=</varname></term>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
<listitem><para>Controls whether
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
logind shall handle the system power
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -255,13 +256,18 @@
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
and
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
<varname>HandleLidSwitch=</varname>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
default to <literal>suspend</literal>.
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ <varname>HandleLidSwitchDocked=</varname>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ defaults to <literal>ignore</literal>.
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
<varname>HandleHibernateKey=</varname>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
defaults to
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- <literal>hibernate</literal>. Note
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- that the lid switch is ignored if the
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- system is inserted in a docking
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- station, or if more than one display
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- is connected.</para></listitem>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ <literal>hibernate</literal>. If the
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ system is inserted in a docking station,
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ or if more than one display is connected,
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ the action specified by
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ <varname>HandleLidSwitchDocked=</varname>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ occurs; otherwise the
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ <varname>HandleLidSwitch=</varname>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ action occurs.</para></listitem>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
</varlistentry>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
<varlistentry>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/src/login/logind-action.c b/src/login/logind-action.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index 36ee4418b8..0844df20a9 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/src/login/logind-action.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/src/login/logind-action.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -71,24 +71,6 @@ int manager_handle_action(
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
if (inhibit_key == INHIBIT_HANDLE_LID_SWITCH) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- int n;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
-
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- /* If we are docked don't react to lid closing */
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- if (manager_is_docked(m)) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- log_debug("Ignoring lid switch request, system is docked.");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- return 0;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- }
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
-
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- /* If we have more than one display connected,
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- * don't react to lid closing. */
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- n = manager_count_displays(m);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- if (n < 0)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- log_warning("Display counting failed: %s", strerror(-n));
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- else if (n > 1) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- log_debug("Ignoring lid switch request, %i displays connected.", n);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- return 0;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- }
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
-
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
/* If the last system suspend or startup is too close,
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
* let's not suspend for now, to give USB docking
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
* stations some time to settle so that we can
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/src/login/logind-button.c b/src/login/logind-button.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index 2561d13c67..57e619efe6 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/src/login/logind-button.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/src/login/logind-button.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -97,13 +97,27 @@ int button_set_seat(Button *b, const char *sn) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
return 0;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+static void button_lid_switch_handle_action(Manager *manager, bool is_edge) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ HandleAction handle_action;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ assert(manager);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ /* If we are docked, handle the lid switch differently */
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ if (manager_is_docked_or_multiple_displays(manager))
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ handle_action = manager->handle_lid_switch_docked;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ else
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ handle_action = manager->handle_lid_switch;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ manager_handle_action(manager, INHIBIT_HANDLE_LID_SWITCH, handle_action, manager->lid_switch_ignore_inhibited, is_edge);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+}
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
static int button_recheck(sd_event_source *e, void *userdata) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Button *b = userdata;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
assert(b);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
assert(b->lid_closed);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- manager_handle_action(b->manager, INHIBIT_HANDLE_LID_SWITCH, b->manager->handle_lid_switch, b->manager->lid_switch_ignore_inhibited, false);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ button_lid_switch_handle_action(b->manager, false);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
return 1;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -186,7 +200,7 @@ static int button_dispatch(sd_event_source *s, int fd, uint32_t revents, void *u
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
NULL);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
b->lid_closed = true;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- manager_handle_action(b->manager, INHIBIT_HANDLE_LID_SWITCH, b->manager->handle_lid_switch, b->manager->lid_switch_ignore_inhibited, true);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ button_lid_switch_handle_action(b->manager, true);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
button_install_check_event_source(b);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
} else if (ev.code == SW_DOCK) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/src/login/logind-core.c b/src/login/logind-core.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index 053d2ed63e..ed7ea5da31 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/src/login/logind-core.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/src/login/logind-core.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -537,3 +537,25 @@ int manager_count_displays(Manager *m) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
return n;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+bool manager_is_docked_or_multiple_displays(Manager *m) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ int n;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ /* If we are docked don't react to lid closing */
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ if (manager_is_docked(m)) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ log_debug("System is docked.");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ return true;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ }
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ /* If we have more than one display connected,
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ * assume that we are docked. */
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ n = manager_count_displays(m);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ if (n < 0)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ log_warning("Display counting failed: %s", strerror(-n));
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ else if (n > 1) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ log_debug("Multiple (%i) displays connected.", n);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ return true;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ }
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ return false;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+}
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/src/login/logind-dbus.c b/src/login/logind-dbus.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index acef5119b1..0b2b7b5afe 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/src/login/logind-dbus.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/src/login/logind-dbus.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -1919,6 +1919,7 @@ const sd_bus_vtable manager_vtable[] = {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
SD_BUS_PROPERTY("HandleSuspendKey", "s", property_get_handle_action, offsetof(Manager, handle_suspend_key), SD_BUS_VTABLE_PROPERTY_CONST),
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
SD_BUS_PROPERTY("HandleHibernateKey", "s", property_get_handle_action, offsetof(Manager, handle_hibernate_key), SD_BUS_VTABLE_PROPERTY_CONST),
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
SD_BUS_PROPERTY("HandleLidSwitch", "s", property_get_handle_action, offsetof(Manager, handle_lid_switch), SD_BUS_VTABLE_PROPERTY_CONST),
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ SD_BUS_PROPERTY("HandleLidSwitchDocked", "s", property_get_handle_action, offsetof(Manager, handle_lid_switch_docked), SD_BUS_VTABLE_PROPERTY_CONST),
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
SD_BUS_PROPERTY("IdleAction", "s", property_get_handle_action, offsetof(Manager, idle_action), SD_BUS_VTABLE_PROPERTY_CONST),
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
SD_BUS_PROPERTY("IdleActionUSec", "t", NULL, offsetof(Manager, idle_action_usec), SD_BUS_VTABLE_PROPERTY_CONST),
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
SD_BUS_PROPERTY("PreparingForShutdown", "b", property_get_preparing, 0, 0),
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/src/login/logind-gperf.gperf b/src/login/logind-gperf.gperf
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index 006f7286c5..62460673b9 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/src/login/logind-gperf.gperf
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/src/login/logind-gperf.gperf
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -24,6 +24,7 @@ Login.HandlePowerKey, config_parse_handle_action, 0, offsetof(Manag
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Login.HandleSuspendKey, config_parse_handle_action, 0, offsetof(Manager, handle_suspend_key)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Login.HandleHibernateKey, config_parse_handle_action, 0, offsetof(Manager, handle_hibernate_key)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Login.HandleLidSwitch, config_parse_handle_action, 0, offsetof(Manager, handle_lid_switch)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+Login.HandleLidSwitchDocked, config_parse_handle_action, 0, offsetof(Manager, handle_lid_switch_docked)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Login.PowerKeyIgnoreInhibited, config_parse_bool, 0, offsetof(Manager, power_key_ignore_inhibited)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Login.SuspendKeyIgnoreInhibited, config_parse_bool, 0, offsetof(Manager, suspend_key_ignore_inhibited)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Login.HibernateKeyIgnoreInhibited, config_parse_bool, 0, offsetof(Manager, hibernate_key_ignore_inhibited)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/src/login/logind.c b/src/login/logind.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index 52e1c43a47..1f94a97bd0 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/src/login/logind.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/src/login/logind.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -55,6 +55,7 @@ Manager *manager_new(void) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
m->handle_suspend_key = HANDLE_SUSPEND;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
m->handle_hibernate_key = HANDLE_HIBERNATE;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
m->handle_lid_switch = HANDLE_SUSPEND;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ m->handle_lid_switch_docked = HANDLE_IGNORE;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
m->lid_switch_ignore_inhibited = true;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
m->idle_action_usec = 30 * USEC_PER_MINUTE;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -232,7 +233,8 @@ static int manager_enumerate_buttons(Manager *m) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
if (m->handle_power_key == HANDLE_IGNORE &&
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
m->handle_suspend_key == HANDLE_IGNORE &&
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
m->handle_hibernate_key == HANDLE_IGNORE &&
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- m->handle_lid_switch == HANDLE_IGNORE)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ m->handle_lid_switch == HANDLE_IGNORE &&
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ m->handle_lid_switch_docked == HANDLE_IGNORE)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
return 0;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
e = udev_enumerate_new(m->udev);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -875,7 +877,8 @@ static int manager_connect_udev(Manager *m) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
if (m->handle_power_key != HANDLE_IGNORE ||
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
m->handle_suspend_key != HANDLE_IGNORE ||
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
m->handle_hibernate_key != HANDLE_IGNORE ||
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
- m->handle_lid_switch != HANDLE_IGNORE) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ m->handle_lid_switch != HANDLE_IGNORE ||
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ m->handle_lid_switch_docked != HANDLE_IGNORE) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
m->udev_button_monitor = udev_monitor_new_from_netlink(m->udev, "udev");
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
if (!m->udev_button_monitor)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/src/login/logind.conf b/src/login/logind.conf
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index 79f96ec05b..4608a2c0e2 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/src/login/logind.conf
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/src/login/logind.conf
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -18,6 +18,7 @@
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
#HandleSuspendKey=suspend
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
#HandleHibernateKey=hibernate
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
#HandleLidSwitch=suspend
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+#HandleLidSwitchDocked=ignore
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
#PowerKeyIgnoreInhibited=no
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
#SuspendKeyIgnoreInhibited=no
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
#HibernateKeyIgnoreInhibited=no
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/src/login/logind.h b/src/login/logind.h
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index 31353eff02..2f76572580 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/src/login/logind.h
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/src/login/logind.h
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -114,6 +114,7 @@ struct Manager {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
HandleAction handle_suspend_key;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
HandleAction handle_hibernate_key;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
HandleAction handle_lid_switch;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ HandleAction handle_lid_switch_docked;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
bool power_key_ignore_inhibited;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
bool suspend_key_ignore_inhibited;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -159,6 +160,7 @@ int manager_get_session_by_pid(Manager *m, pid_t pid, Session **session);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
bool manager_is_docked(Manager *m);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
int manager_count_displays(Manager *m);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+bool manager_is_docked_or_multiple_displays(Manager *m);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
extern const sd_bus_vtable manager_vtable[];
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|