diff options
author | Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> | 2013-12-24 23:55:43 -0500 |
---|---|---|
committer | Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> | 2013-12-26 11:24:42 -0500 |
commit | b65205466248531d52f9d6dba16195864b023d4a (patch) | |
tree | 9cd1c07512a5e12c0cf133dacf16fb0a670b3a29 | |
parent | 91f0ac7d40e4b89ccb8430b34dbf907f305763fa (diff) |
systemctl: simplify start_unit
-rw-r--r-- | src/fsck/fsck.c | 4 | ||||
-rw-r--r-- | src/systemctl/systemctl.c | 44 |
2 files changed, 21 insertions, 27 deletions
diff --git a/src/fsck/fsck.c b/src/fsck/fsck.c index 4f1aa22f9d..9170768cec 100644 --- a/src/fsck/fsck.c +++ b/src/fsck/fsck.c @@ -73,7 +73,8 @@ static void start_target(const char *target) { } static int parse_proc_cmdline(void) { - char *line, *w, *state; + _cleanup_free_ char *line = NULL; + char *w, *state; size_t l; int r; @@ -104,7 +105,6 @@ static int parse_proc_cmdline(void) { #endif } - free(line); return 0; } diff --git a/src/systemctl/systemctl.c b/src/systemctl/systemctl.c index c20a82b8b4..15d46bdfde 100644 --- a/src/systemctl/systemctl.c +++ b/src/systemctl/systemctl.c @@ -2146,9 +2146,10 @@ static enum action verb_to_action(const char *verb) { static int start_unit(sd_bus *bus, char **args) { _cleanup_bus_error_free_ sd_bus_error error = SD_BUS_ERROR_NULL; _cleanup_set_free_free_ Set *s = NULL; - const char *method, *mode, *one_name; + const char *method, *mode; char **name; - int r; + int r = 0; + char **names, *strv[] = {NULL, NULL}; /* at most one name */ assert(bus); @@ -2176,7 +2177,7 @@ static int start_unit(sd_bus *bus, char **args) { mode = streq(args[0], "isolate") ? "isolate" : action_table[action].mode ?: arg_job_mode; - one_name = action_table[action].target; + strv[0] = (char*) action_table[action].target; } else { assert(arg_action < ELEMENTSOF(action_table)); assert(action_table[arg_action].target); @@ -2184,9 +2185,14 @@ static int start_unit(sd_bus *bus, char **args) { method = "StartUnit"; mode = action_table[arg_action].mode; - one_name = action_table[arg_action].target; + strv[0] = (char*) action_table[arg_action].target; } + if (strv[0]) + names = strv; + else + names = args + 1; + if (!arg_no_block) { r = enable_wait_for_jobs(bus); if (r < 0) { @@ -2199,21 +2205,13 @@ static int start_unit(sd_bus *bus, char **args) { return log_oom(); } - if (one_name) { - r = start_unit_one(bus, method, one_name, mode, &error, s); - if (r < 0) - r = translate_bus_error_to_exit_status(r, &error); - } else { - r = 0; - - STRV_FOREACH(name, args+1) { - int q; + STRV_FOREACH(name, names) { + int q; - q = start_unit_one(bus, method, *name, mode, &error, s); - if (q < 0) { - r = translate_bus_error_to_exit_status(q, &error); - sd_bus_error_free(&error); - } + q = start_unit_one(bus, method, *name, mode, &error, s); + if (r == 0 && q < 0) { + r = translate_bus_error_to_exit_status(q, &error); + sd_bus_error_free(&error); } } @@ -2226,13 +2224,9 @@ static int start_unit(sd_bus *bus, char **args) { /* When stopping units, warn if they can still be triggered by * another active unit (socket, path, timer) */ - if (!arg_quiet && streq(method, "StopUnit")) { - if (one_name) - check_triggering_units(bus, one_name); - else - STRV_FOREACH(name, args+1) - check_triggering_units(bus, *name); - } + if (!arg_quiet && streq(method, "StopUnit")) + STRV_FOREACH(name, names) + check_triggering_units(bus, *name); } return r; |