return 1;
}
+static int bus_append_parse_io_device_weight(sd_bus_message *m, const char *field, const char *eq) {
+ int r;
+
+ if (isempty(eq))
+ r = sd_bus_message_append(m, "(sv)", field, "a(st)", 0);
+ else {
+ const char *e = strchr(eq, ' ');
+ if (!e)
+ return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
+ "Failed to parse %s value %s.",
+ field, eq);
+
+ const char *path = strndupa_safe(eq, e - eq);
+ const char *weight = e + 1;
+
+ uint64_t u;
+ r = safe_atou64(weight, &u);
+ if (r < 0)
+ return log_error_errno(r, "Failed to parse %s value %s: %m", field, weight);
+
+ r = sd_bus_message_append(m, "(sv)", field, "a(st)", 1, path, u);
+ }
+ if (r < 0)
+ return bus_log_create_error(r);
+
+ return 1;
+}
+
static int bus_append_exec_command(sd_bus_message *m, const char *field, const char *eq) {
bool explicit_path = false, done = false, ambient_hack = false;
_cleanup_strv_free_ char **l = NULL, **ex_opts = NULL;
if (cgroup_io_limit_type_from_string(field) >= 0)
return bus_append_parse_cgroup_io_limit(m, field, eq);
- if (streq(field, "IODeviceWeight")) {
- if (isempty(eq))
- r = sd_bus_message_append(m, "(sv)", field, "a(st)", 0);
- else {
- const char *path, *weight, *e;
- uint64_t u;
-
- e = strchr(eq, ' ');
- if (!e)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Failed to parse %s value %s.",
- field, eq);
-
- path = strndupa_safe(eq, e - eq);
- weight = e+1;
-
- r = safe_atou64(weight, &u);
- if (r < 0)
- return log_error_errno(r, "Failed to parse %s value %s: %m", field, weight);
-
- r = sd_bus_message_append(m, "(sv)", field, "a(st)", 1, path, u);
- }
-
- if (r < 0)
- return bus_log_create_error(r);
-
- return 1;
- }
+ if (streq(field, "IODeviceWeight"))
+ return bus_append_parse_io_device_weight(m, field, eq);
if (streq(field, "IODeviceLatencyTargetSec")) {
const char *field_usec = "IODeviceLatencyTargetUSec";