X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Flogin%2Finhibit.c;h=9b6613340f2324ba53fbbb547733016b1f606682;hb=1e447e0a3cb3e98827938a182593056ddbb13b29;hp=029c9549d2ecafb73f7036402afe3610e8c5b384;hpb=b9c26b413497a0014ac2058a0ec04849a83df1ea;p=elogind.git diff --git a/src/login/inhibit.c b/src/login/inhibit.c index 029c9549d..9b6613340 100644 --- a/src/login/inhibit.c +++ b/src/login/inhibit.c @@ -43,9 +43,9 @@ static enum { static int inhibit(DBusConnection *bus, DBusError *error) { DBusMessage *reply = NULL; - int fd; + int r; - fd = bus_method_call_with_reply ( + r = bus_method_call_with_reply( bus, "org.freedesktop.login1", "/org/freedesktop/login1", @@ -58,26 +58,26 @@ static int inhibit(DBusConnection *bus, DBusError *error) { DBUS_TYPE_STRING, &arg_why, DBUS_TYPE_STRING, &arg_mode, DBUS_TYPE_INVALID); - if (fd) - return fd; + if (r < 0) + return r; if (!dbus_message_get_args(reply, error, - DBUS_TYPE_UNIX_FD, &fd, + DBUS_TYPE_UNIX_FD, &r, DBUS_TYPE_INVALID)) - fd = -EIO; + r = -EIO; dbus_message_unref(reply); - return fd; + return r; } static int print_inhibitors(DBusConnection *bus, DBusError *error) { - DBusMessage *reply; + DBusMessage *reply = NULL; unsigned n = 0; DBusMessageIter iter, sub, sub2; int r; - r = bus_method_call_with_reply ( + r = bus_method_call_with_reply( bus, "org.freedesktop.login1", "/org/freedesktop/login1", @@ -86,8 +86,7 @@ static int print_inhibitors(DBusConnection *bus, DBusError *error) { &reply, NULL, DBUS_TYPE_INVALID); - if (r) - return -ENOMEM; + if (r < 0) goto finish; if (!dbus_message_iter_init(reply, &iter)) { @@ -99,7 +98,6 @@ static int print_inhibitors(DBusConnection *bus, DBusError *error) { r = -EIO; goto finish; } - dbus_message_iter_recurse(&iter, &sub); printf("%-21s %-20s %-20s %-5s %6s %6s\n", "WHAT", @@ -109,7 +107,7 @@ static int print_inhibitors(DBusConnection *bus, DBusError *error) { "UID", "PID"); - + dbus_message_iter_recurse(&iter, &sub); while (dbus_message_iter_get_arg_type(&sub) != DBUS_TYPE_INVALID) { const char *what, *who, *why, *mode; char *ewho, *ewhy; @@ -162,8 +160,10 @@ static int help(void) { "Execute a process while inhibiting shutdown/sleep/idle.\n\n" " -h --help Show this help\n" " --version Show package version\n" - " --what=WHAT Operations to inhibit, colon separated list of idle,\n" - " sleep, shutdown\n" + " --what=WHAT Operations to inhibit, colon separated list of:\n" + " shutdown, sleep, idle, handle-power-key,\n" + " handle-suspend-key, handle-hibernate-key,\n" + " handle-lid-switch\n" " --who=STRING A descriptive string who is inhibiting\n" " --why=STRING A descriptive string why is being inhibited\n" " --mode=MODE One of block or delay\n" @@ -210,7 +210,6 @@ static int parse_argv(int argc, char *argv[]) { case ARG_VERSION: puts(PACKAGE_STRING); - puts(DISTRIBUTION); puts(SYSTEMD_FEATURES); return 0; @@ -305,6 +304,8 @@ int main(int argc, char *argv[]) { /* Child */ close_nointr_nofail(fd); + close_all_fds(NULL, 0); + execvp(argv[optind], argv + optind); log_error("Failed to execute %s: %m", argv[optind]); _exit(EXIT_FAILURE);