X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;ds=sidebyside;f=src%2Fmain.c;h=d6f5c56c2a79372f7ff8daae42639c29cdd0aee7;hb=00dc5d769ac4a4019d6b6fe22e8383ec8b030a96;hp=6c65e64a2eaa4dfc90febf37adc5891078e51699;hpb=3c14d26c4746768f1dc63d4b7ac0278a7abe5da1;p=elogind.git diff --git a/src/main.c b/src/main.c index 6c65e64a2..d6f5c56c2 100644 --- a/src/main.c +++ b/src/main.c @@ -1060,8 +1060,10 @@ int main(int argc, char *argv[]) { if ((r = manager_load_unit(m, arg_default_unit, NULL, &error, &target)) < 0) { log_error("Failed to load default target: %s", bus_error(&error, r)); dbus_error_free(&error); - } else if (target->meta.load_state != UNIT_LOADED) + } else if (target->meta.load_state == UNIT_ERROR) log_error("Failed to load default target: %s", strerror(-target->meta.load_error)); + else if (target->meta.load_state == UNIT_BANNED) + log_error("Default target banned."); if (!target || target->meta.load_state != UNIT_LOADED) { log_info("Trying to load rescue target..."); @@ -1070,12 +1072,17 @@ int main(int argc, char *argv[]) { log_error("Failed to load rescue target: %s", bus_error(&error, r)); dbus_error_free(&error); goto finish; - } else if (target->meta.load_state != UNIT_LOADED) { + } else if (target->meta.load_state == UNIT_ERROR) { log_error("Failed to load rescue target: %s", strerror(-target->meta.load_error)); goto finish; + } else if (target->meta.load_state == UNIT_BANNED) { + log_error("Rescue target banned."); + goto finish; } } + assert(target->meta.load_state == UNIT_LOADED); + if (arg_action == ACTION_TEST) { printf("-> By units:\n"); manager_dump_units(m, stdout, "\t");