diff options
| author | Lennart Poettering <lennart@poettering.net> | 2016-02-16 13:21:14 +0100 | 
|---|---|---|
| committer | Lennart Poettering <lennart@poettering.net> | 2016-02-16 13:21:14 +0100 | 
| commit | d477bc35b0bf92514fcbdb315b9ffefe993d0395 (patch) | |
| tree | d686f03c2f7d854c161d24a33631a0e398d26840 /src/shared/bus-util.c | |
| parent | 6043679c6ec485a96926f07c26d77f2c0c246fe2 (diff) | |
| parent | c11bda1e3ca774ec09adab868e716dd8a84d5614 (diff) | |
Merge pull request #2630 from keszybz/systemctl-m-h
systemctl: fix style to avoid modification of array passed by caller
Diffstat (limited to 'src/shared/bus-util.c')
| -rw-r--r-- | src/shared/bus-util.c | 31 | 
1 files changed, 15 insertions, 16 deletions
| diff --git a/src/shared/bus-util.c b/src/shared/bus-util.c index 1fcf3f6a7f..c87eaf63d8 100644 --- a/src/shared/bus-util.c +++ b/src/shared/bus-util.c @@ -2028,8 +2028,8 @@ static const struct {          { "start-limit", "start of the service was attempted too often" }  }; -static void log_job_error_with_service_result(const char* service, const char *result, const char** extra_args) { -        _cleanup_free_ char *service_shell_quoted = NULL, *_systemctl, *_journalctl; +static void log_job_error_with_service_result(const char* service, const char *result, const char* const* extra_args) { +        _cleanup_free_ char *service_shell_quoted = NULL;          const char *systemctl = "systemctl", *journalctl = "journalct";          assert(service); @@ -2037,13 +2037,11 @@ static void log_job_error_with_service_result(const char* service, const char *r          service_shell_quoted = shell_maybe_quote(service);          if (extra_args && extra_args[1]) { -                assert(extra_args[0] == NULL); +                _cleanup_free_ char *t; -                extra_args[0] = "systemctl"; -                systemctl = _systemctl = strv_join((char**) extra_args, " "); - -                extra_args[0] = "journalctl"; -                journalctl = _journalctl = strv_join((char**) extra_args, " "); +                t = strv_join((char**) extra_args, " "); +                systemctl = strjoina("systemctl ", t ?: "<args>", NULL); +                journalctl = strjoina("journalctl ", t ?: "<args>", NULL);          }          if (!isempty(result)) { @@ -2058,29 +2056,30 @@ static void log_job_error_with_service_result(const char* service, const char *r                                    "See \"%s status %s\" and \"%s -xe\" for details.\n",                                    service,                                    explanations[i].explanation, -                                  systemctl ?: "systemctl <args>", +                                  systemctl,                                    service_shell_quoted ?: "<service>", -                                  journalctl ?: "journalctl <args>"); +                                  journalctl);                          goto finish;                  }          } -        log_error("Job for %s failed. See \"%s status %s\" and \"%s -xe\" for details.\n", +        log_error("Job for %s failed.\n" +                  "See \"%s status %s\" and \"%s -xe\" for details.\n",                    service, -                  systemctl ?: "systemctl <args>", +                  systemctl,                    service_shell_quoted ?: "<service>", -                  journalctl ?: "journalctl <args>"); +                  journalctl);  finish:          /* For some results maybe additional explanation is required */          if (streq_ptr(result, "start-limit"))                  log_info("To force a start use \"%1$s reset-failed %2$s\"\n"                           "followed by \"%1$s start %2$s\" again.", -                         systemctl ?: "systemctl <args>", +                         systemctl,                           service_shell_quoted ?: "<service>");  } -static int check_wait_response(BusWaitForJobs *d, bool quiet, const char** extra_args) { +static int check_wait_response(BusWaitForJobs *d, bool quiet, const char* const* extra_args) {          int r = 0;          assert(d->result); @@ -2131,7 +2130,7 @@ static int check_wait_response(BusWaitForJobs *d, bool quiet, const char** extra          return r;  } -int bus_wait_for_jobs(BusWaitForJobs *d, bool quiet, const char** extra_args) { +int bus_wait_for_jobs(BusWaitForJobs *d, bool quiet, const char* const* extra_args) {          int r = 0;          assert(d); | 
