diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/core/dbus-execute.c | 12 | ||||
| -rw-r--r-- | src/core/load-fragment.c | 19 | ||||
| -rw-r--r-- | src/shared/bus-unit-util.c | 4 | 
3 files changed, 25 insertions, 10 deletions
| diff --git a/src/core/dbus-execute.c b/src/core/dbus-execute.c index 60b0288bb0..c57af5aaaf 100644 --- a/src/core/dbus-execute.c +++ b/src/core/dbus-execute.c @@ -1498,12 +1498,15 @@ int bus_exec_context_set_transient_property(                          return r;                  STRV_FOREACH(p, l) { -                        int offset; -                        if (!utf8_is_valid(*p)) +                        const char *i = *p; +                        size_t offset; + +                        if (!utf8_is_valid(i))                                  return sd_bus_error_setf(error, SD_BUS_ERROR_INVALID_ARGS, "Invalid %s", name); -                        offset = **p == '-'; -                        if (!path_is_absolute(*p + offset)) +                        offset = i[0] == '-'; +                        offset += i[offset] == '+'; +                        if (!path_is_absolute(i + offset))                                  return sd_bus_error_setf(error, SD_BUS_ERROR_INVALID_ARGS, "Invalid %s", name);                  } @@ -1522,7 +1525,6 @@ int bus_exec_context_set_transient_property(                                  unit_write_drop_in_private_format(u, mode, name, "%s=", name);                          } else {                                  r = strv_extend_strv(dirs, l, true); -                                  if (r < 0)                                          return -ENOMEM; diff --git a/src/core/load-fragment.c b/src/core/load-fragment.c index 243c288885..5b7471c0d0 100644 --- a/src/core/load-fragment.c +++ b/src/core/load-fragment.c @@ -3839,7 +3839,8 @@ int config_parse_namespace_path_strv(          cur = rvalue;          for (;;) {                  _cleanup_free_ char *word = NULL, *resolved = NULL, *joined = NULL; -                bool ignore_enoent; +                const char *w; +                bool ignore_enoent = false, shall_prefix = false;                  r = extract_first_word(&cur, &word, NULL, EXTRACT_QUOTES);                  if (r == 0) @@ -3856,9 +3857,17 @@ int config_parse_namespace_path_strv(                          continue;                  } -                ignore_enoent = word[0] == '-'; +                w = word; +                if (startswith(w, "-")) { +                        ignore_enoent = true; +                        w++; +                } +                if (startswith(w, "+")) { +                        shall_prefix = true; +                        w++; +                } -                r = unit_full_printf(u, word + ignore_enoent, &resolved); +                r = unit_full_printf(u, w, &resolved);                  if (r < 0) {                          log_syntax(unit, LOG_ERR, filename, line, r, "Failed to resolve specifiers in %s: %m", word);                          continue; @@ -3871,7 +3880,9 @@ int config_parse_namespace_path_strv(                  path_kill_slashes(resolved); -                joined = strjoin(ignore_enoent ? "-" : "", resolved); +                joined = strjoin(ignore_enoent ? "-" : "", +                                 shall_prefix ? "+" : "", +                                 resolved);                  r = strv_push(sv, joined);                  if (r < 0) diff --git a/src/shared/bus-unit-util.c b/src/shared/bus-unit-util.c index b6da20a04a..a4677bef27 100644 --- a/src/shared/bus-unit-util.c +++ b/src/shared/bus-unit-util.c @@ -484,7 +484,7 @@ int bus_append_unit_property_assignment(sd_bus_message *m, const char *assignmen                  for (p = eq;;) {                          _cleanup_free_ char *word = NULL; -                        int offset; +                        size_t offset;                          r = extract_first_word(&p, &word, NULL, EXTRACT_QUOTES);                          if (r < 0) { @@ -500,6 +500,8 @@ int bus_append_unit_property_assignment(sd_bus_message *m, const char *assignmen                          }                          offset = word[0] == '-'; +                        offset += word[offset] == '+'; +                          if (!path_is_absolute(word + offset)) {                                  log_error("Failed to parse %s value %s", field, eq);                                  return -EINVAL; | 
