mirror of
https://github.com/hyprwm/wlroots-hyprland.git
synced 2024-11-22 21:05:58 +01:00
session/logind: Clean up add_signal_matches
The original signal matching was using the old interface before sd_bus_match_signal was added, which the new code uses. Change them all to use it now.
This commit is contained in:
parent
3ebf079a9a
commit
626c98d754
1 changed files with 16 additions and 19 deletions
|
@ -558,48 +558,45 @@ error:
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool add_signal_matches(struct logind_session *session) {
|
static bool add_signal_matches(struct logind_session *session) {
|
||||||
|
static const char *logind = "org.freedesktop.login1";
|
||||||
|
static const char *logind_path = "/org/freedesktop/login1";
|
||||||
|
static const char *manager_interface = "org.freedesktop.login1.Manager";
|
||||||
|
static const char *session_interface = "org.freedesktop.login1.Session";
|
||||||
|
static const char *property_interface = "org.freedesktop.DBus.Properties";
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
char str[256];
|
ret = sd_bus_match_signal(session->bus, NULL, logind, logind_path,
|
||||||
const char fmt[] = "type='signal',"
|
manager_interface, "SessionRemoved", session_removed, session);
|
||||||
"sender='org.freedesktop.login1',"
|
|
||||||
"interface='org.freedesktop.login1.%s',"
|
|
||||||
"member='%s',"
|
|
||||||
"path='%s'";
|
|
||||||
|
|
||||||
snprintf(str, sizeof(str), fmt, "Manager", "SessionRemoved",
|
|
||||||
"/org/freedesktop/login1");
|
|
||||||
ret = sd_bus_add_match(session->bus, NULL, str, session_removed, session);
|
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
wlr_log(WLR_ERROR, "Failed to add D-Bus match: %s", strerror(-ret));
|
wlr_log(WLR_ERROR, "Failed to add D-Bus match: %s", strerror(-ret));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
snprintf(str, sizeof(str), fmt, "Session", "PauseDevice", session->path);
|
ret = sd_bus_match_signal(session->bus, NULL, logind, session->path,
|
||||||
ret = sd_bus_add_match(session->bus, NULL, str, pause_device, session);
|
session_interface, "PauseDevice", pause_device, session);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
wlr_log(WLR_ERROR, "Failed to add D-Bus match: %s", strerror(-ret));
|
wlr_log(WLR_ERROR, "Failed to add D-Bus match: %s", strerror(-ret));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
snprintf(str, sizeof(str), fmt, "Session", "ResumeDevice", session->path);
|
ret = sd_bus_match_signal(session->bus, NULL, logind, session->path,
|
||||||
ret = sd_bus_add_match(session->bus, NULL, str, resume_device, session);
|
session_interface, "ResumeDevice", resume_device, session);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
wlr_log(WLR_ERROR, "Failed to add D-Bus match: %s", strerror(-ret));
|
wlr_log(WLR_ERROR, "Failed to add D-Bus match: %s", strerror(-ret));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = sd_bus_match_signal(session->bus, NULL, "org.freedesktop.login1",
|
ret = sd_bus_match_signal(session->bus, NULL, logind, session->path,
|
||||||
session->path, "org.freedesktop.DBus.Properties", "PropertiesChanged",
|
property_interface, "PropertiesChanged",
|
||||||
session_properties_changed, session);
|
session_properties_changed, session);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
wlr_log(WLR_ERROR, "Failed to add D-Bus match: %s", strerror(-ret));
|
wlr_log(WLR_ERROR, "Failed to add D-Bus match: %s", strerror(-ret));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = sd_bus_match_signal(session->bus, NULL, "org.freedesktop.login1",
|
ret = sd_bus_match_signal(session->bus, NULL, logind, session->seat_path,
|
||||||
session->seat_path, "org.freedesktop.DBus.Properties",
|
property_interface, "PropertiesChanged",
|
||||||
"PropertiesChanged", seat_properties_changed, session);
|
seat_properties_changed, session);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
wlr_log(WLR_ERROR, "Failed to add D-Bus match: %s", strerror(-ret));
|
wlr_log(WLR_ERROR, "Failed to add D-Bus match: %s", strerror(-ret));
|
||||||
return false;
|
return false;
|
||||||
|
|
Loading…
Reference in a new issue