forked from enlightenment/enlightenment
save inhibit fd from systemd or fd is closed/lost and inhibit is lost!
This commit is contained in:
parent
9d2b22553a
commit
5f4027dbca
|
@ -50,6 +50,7 @@ static void _e_sys_systemd_hibernate(void);
|
|||
static void _e_sys_systemd_exists_cb(void *data, const Eldbus_Message *m, Eldbus_Pending *p);
|
||||
|
||||
static Eina_Bool systemd_works = EINA_FALSE;
|
||||
static int _e_sys_systemd_inhibit_fd = -1;
|
||||
|
||||
static const int E_LOGOUT_AUTO_TIME = 60;
|
||||
static const int E_LOGOUT_WAIT_TIME = 15;
|
||||
|
@ -108,6 +109,11 @@ e_sys_shutdown(void)
|
|||
eldbus_connection_unref(conn);
|
||||
login1_manger_proxy = NULL;
|
||||
}
|
||||
if (_e_sys_systemd_inhibit_fd >= 0)
|
||||
{
|
||||
close(_e_sys_systemd_inhibit_fd);
|
||||
_e_sys_systemd_inhibit_fd = -1;
|
||||
}
|
||||
eldbus_shutdown();
|
||||
return 1;
|
||||
}
|
||||
|
@ -288,6 +294,15 @@ e_sys_handlers_set(void (*suspend_func)(void),
|
|||
_e_sys_resume_func = resume_func;
|
||||
}
|
||||
|
||||
static void
|
||||
_e_sys_systemd_inhibit_cb(void *data __UNUSED__, const Eldbus_Message *m, Eldbus_Pending *p __UNUSED__)
|
||||
{
|
||||
int fd = -1;
|
||||
if (eldbus_message_error_get(m, NULL, NULL)) return;
|
||||
if (!eldbus_message_arguments_get(m, "h", &fd))
|
||||
_e_sys_systemd_inhibit_fd = fd;
|
||||
}
|
||||
|
||||
static void
|
||||
_e_sys_systemd_handle_inhibit(void)
|
||||
{
|
||||
|
@ -305,7 +320,7 @@ _e_sys_systemd_handle_inhibit(void)
|
|||
"Enlightenment", // who (string)
|
||||
"Normal Execution", // why (string)
|
||||
"block");
|
||||
eldbus_proxy_send(login1_manger_proxy, m, NULL, NULL, -1);
|
||||
eldbus_proxy_send(login1_manger_proxy, m, _e_sys_systemd_inhibit_cb, NULL, -1);
|
||||
}
|
||||
|
||||
static void
|
||||
|
|
Loading…
Reference in New Issue