From: Lennart Poettering Date: Thu, 3 May 2012 14:29:15 +0000 (+0200) Subject: systemctl: allow 'systemctl reboot -ff' to succeed even without D-Bus X-Git-Tag: v183~167 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=3beddc7861783347eb0aaf5fa492e8b2aef9e691;ds=sidebyside systemctl: allow 'systemctl reboot -ff' to succeed even without D-Bus --- diff --git a/src/systemctl/systemctl.c b/src/systemctl/systemctl.c index cbe6848d0..681ad8c21 100644 --- a/src/systemctl/systemctl.c +++ b/src/systemctl/systemctl.c @@ -1783,7 +1783,6 @@ static int start_special(DBusConnection *bus, char **args) { enum action a; int r; - assert(bus); assert(args); a = verb_to_action(args[0]); @@ -5204,7 +5203,9 @@ static int systemctl_main(DBusConnection *bus, int argc, char *argv[], DBusError return 0; } - if (!bus) { + if (((!streq(verbs[i].verb, "reboot") && + !streq(verbs[i].verb, "halt") && + !streq(verbs[i].verb, "reboot")) || arg_force <= 0) && !bus) { log_error("Failed to get D-Bus connection: %s", dbus_error_is_set(error) ? error->message : "No connection to service manager."); return -EIO;