Now that we know we have something useful, no need to make an answer up.
status = exit_status_from_string(argv[i]);
if (status < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL), "Invalid exit status \"%s\".", argv[i]);
+ return log_error_errno(status, "Invalid exit status \"%s\".", argv[i]);
assert(status >= 0 && (size_t) status < ELEMENTSOF(exit_status_mappings));
r = table_add_many(table,
t = log_target_from_string(e);
if (t < 0)
- return -EINVAL;
+ return t;
log_set_target(t);
return 0;
t = log_level_from_string(e);
if (t < 0)
- return -EINVAL;
+ return t;
log_set_max_level(t);
return 0;
type = unit_type_from_string(suffix + 1);
if (type < 0)
- return -EINVAL;
+ return type;
return unit_name_build_from_type(prefix, instance, type, ret);
}
p = cgroup_device_policy_from_string(policy);
if (p < 0)
- return -EINVAL;
+ return p;
if (!UNIT_WRITE_FLAGS_NOOP(flags)) {
c->device_policy = p;
case STATE_EXEC_COMMAND_TYPE:
id = service_exec_command_from_string(arg);
if (id < 0)
- return -EINVAL;
+ return id;
state = STATE_EXEC_COMMAND_INDEX;
break;
case STATE_EXEC_COMMAND_INDEX:
r = safe_atou(arg, &idx);
if (r < 0)
- return -EINVAL;
+ return r;
state = STATE_EXEC_COMMAND_PATH;
break;
case ARG_VERSION:
return version();
- case ARG_SUFFIX:
-
- if (unit_type_from_string(optarg) < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Invalid unit suffix type %s.", optarg);
+ case ARG_SUFFIX: {
+ UnitType t = unit_type_from_string(optarg);
+ if (t < 0)
+ return log_error_errno(t, "Invalid unit suffix type \"%s\".", optarg);
arg_suffix = optarg;
break;
+ }
case ARG_TEMPLATE:
-
if (!unit_name_is_valid(optarg, UNIT_NAME_TEMPLATE))
return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
"Template name %s is not valid.", optarg);
if (value) {
m = volatile_mode_from_string(value);
if (m < 0)
- log_warning("Failed to parse systemd.volatile= argument: %s", value);
+ log_warning_errno(m, "Failed to parse systemd.volatile= argument: %s", value);
else
arg_volatile_mode = m;
} else
l = rlimit_from_string_harder(field);
if (l < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL), "Unknown resource limit type: %s", field);
+ return log_error_errno(l, "Unknown resource limit type: %s", field);
if (isempty(eq + 1)) {
/* Remove only the specific rlimit */
case ARG_SPLIT_MODE:
arg_split_mode = journal_write_split_mode_from_string(optarg);
if (arg_split_mode == _JOURNAL_WRITE_SPLIT_INVALID)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Invalid split mode: %s", optarg);
+ return log_error_errno(arg_split_mode, "Invalid split mode: %s", optarg);
break;
case ARG_COMPRESS:
if (optarg) {
r = parse_boolean(optarg);
if (r < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Failed to parse --compress= parameter.");
+ return log_error_errno(r, "Failed to parse --compress= parameter.");
arg_compress = !!r;
} else
arg_output = output_mode_from_string(optarg);
if (arg_output < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL), "Unknown output format '%s'.", optarg);
+ return log_error_errno(arg_output, "Unknown output format '%s'.", optarg);
if (IN_SET(arg_output, OUTPUT_EXPORT, OUTPUT_JSON, OUTPUT_JSON_PRETTY, OUTPUT_JSON_SSE, OUTPUT_JSON_SEQ, OUTPUT_CAT))
arg_quiet = true;
to = log_level_from_string(dots + 2);
if (from < 0 || to < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
+ return log_error_errno(from < 0 ? from : to,
"Failed to parse log level range %s", optarg);
arg_priorities = 0;
p = log_level_from_string(optarg);
if (p < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Unknown log level %s", optarg);
+ return log_error_errno(p, "Unknown log level %s", optarg);
arg_priorities = 0;
num = log_facility_unshifted_from_string(fac);
if (num < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Bad --facility= argument \"%s\".", fac);
+ return log_error_errno(num, "Bad --facility= argument \"%s\".", fac);
if (set_ensure_put(&arg_facilities, NULL, INT_TO_PTR(num)) < 0)
return log_oom();
ll = log_level_from_string(value);
if (ll < 0)
- return -EINVAL;
+ return ll;
c->log_level_max = ll;
return 0;
a = device_action_from_string(action);
if (a < 0)
- return -EINVAL;
+ return a;
r = device_add_property_internal(device, "ACTION", action);
if (r < 0)
arg_output = output_mode_from_string(optarg);
if (arg_output < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Unknown output '%s'.", optarg);
+ return log_error_errno(arg_output, "Unknown output '%s'.", optarg);
if (OUTPUT_MODE_IS_JSON(arg_output))
arg_legend = false;
arg_signal = signal_from_string(optarg);
if (arg_signal < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Failed to parse signal string %s.", optarg);
+ return log_error_errno(arg_signal, "Failed to parse signal string %s.", optarg);
break;
case 'H':
t = dracut_dhcp_type_from_string(dhcp_type);
if (t < 0)
- return -EINVAL;
+ return t;
network = network_get(context, ifname);
if (!network) {
Network *network = userdata;
_cleanup_(address_free_or_set_invalidp) Address *n = NULL;
- AddressFamily a;
int r;
assert(filename);
return 0;
}
- a = duplicate_address_detection_address_family_from_string(rvalue);
+ AddressFamily a = duplicate_address_detection_address_family_from_string(rvalue);
if (a < 0) {
- log_syntax(unit, LOG_WARNING, filename, line, SYNTHETIC_ERRNO(EINVAL),
+ log_syntax(unit, LOG_WARNING, filename, line, a,
"Failed to parse %s=, ignoring: %s", lvalue, rvalue);
return 0;
}
-
n->duplicate_address_detection = a;
+
TAKE_PTR(n);
return 0;
}
_cleanup_(fdb_entry_free_or_set_invalidp) FdbEntry *fdb_entry = NULL;
Network *network = userdata;
- NeighborCacheEntryFlags f;
int r;
assert(filename);
if (r < 0)
return log_oom();
- f = fdb_ntf_flags_from_string(rvalue);
+ NeighborCacheEntryFlags f = fdb_ntf_flags_from_string(rvalue);
if (f < 0) {
- log_syntax(unit, LOG_WARNING, filename, line, SYNTHETIC_ERRNO(EINVAL),
+ log_syntax(unit, LOG_WARNING, filename, line, f,
"FDB failed to parse AssociatedWith=, ignoring assignment: %s",
rvalue);
return 0;
s = link_operstate_from_string(operstate);
if (s < 0)
- ret = log_link_debug_errno(l, SYNTHETIC_ERRNO(EINVAL),
- "Failed to parse operational state, ignoring: %m");
+ ret = log_link_debug_errno(l, s, "Failed to parse operational state, ignoring: %m");
else
l->operational_state = s;
}
t = rlimit_from_string(z);
if (t < 0)
- return json_log(v, flags, SYNTHETIC_ERRNO(EINVAL),
+ return json_log(v, flags, t,
"rlimit name unknown: %s", json_variant_string(v));
*type = t;
arg_kill_signal = signal_from_string(optarg);
if (arg_kill_signal < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Cannot parse signal: %s", optarg);
+ return log_error_errno(arg_kill_signal, "Cannot parse signal: %s", optarg);
arg_settings_mask |= SETTING_KILL_SIGNAL;
break;
rl = rlimit_from_string_harder(name);
if (rl < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Unknown resource limit: %s", name);
+ return log_error_errno(rl, "Unknown resource limit: %s", name);
if (!arg_rlimit[rl]) {
arg_rlimit[rl] = new0(struct rlimit, 1);
arg_resolv_conf = resolv_conf_mode_from_string(optarg);
if (arg_resolv_conf < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
+ return log_error_errno(arg_resolv_conf,
"Failed to parse /etc/resolv.conf mode: %s", optarg);
arg_settings_mask |= SETTING_RESOLV_CONF;
arg_timezone = timezone_mode_from_string(optarg);
if (arg_timezone < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
+ return log_error_errno(arg_timezone,
"Failed to parse /etc/localtime mode: %s", optarg);
arg_settings_mask |= SETTING_TIMEZONE;
m = managed_oom_mode_from_string(s);
if (m < 0)
- return json_log(v, flags, SYNTHETIC_ERRNO(EINVAL), "%s is not a valid ManagedOOMMode", s);
+ return json_log(v, flags, m, "%s is not a valid ManagedOOMMode", s);
*mode = m;
return 0;
r = dns_class_from_string(t);
if (r < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Unknown DNS class %s.", t);
+ return log_error_errno(r, "Unknown DNS class %s.", t);
class = r;
r = dns_type_from_string(t);
if (r < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Unknown DNS type %s.", t);
+ return log_error_errno(r, "Unknown DNS type %s: %m", t);
type = r;
}
r = dns_type_from_string(optarg);
- if (r < 0) {
- log_error("Failed to parse RR record type %s", optarg);
- return r;
- }
+ if (r < 0)
+ return log_error_errno(r, "Failed to parse RR record type %s: %m", optarg);
+
arg_type = (uint16_t) r;
assert((int) arg_type == r);
}
r = dns_class_from_string(optarg);
- if (r < 0) {
- log_error("Failed to parse RR record class %s", optarg);
- return r;
- }
+ if (r < 0)
+ return log_error_errno(r, "Failed to parse RR record class %s: %m", optarg);
+
arg_class = (uint16_t) r;
assert((int) arg_class == r);
}
r = dns_type_from_string(optarg);
- if (r < 0) {
- log_error("Failed to parse RR record type %s", optarg);
- return r;
- }
+ if (r < 0)
+ return log_error_errno(r, "Failed to parse RR record type %s: %m", optarg);
+
arg_type = (uint16_t) r;
assert((int) arg_type == r);
}
r = dns_class_from_string(optarg);
- if (r < 0) {
- log_error("Failed to parse RR record class %s", optarg);
- return r;
- }
+ if (r < 0)
+ return log_error_errno(r, "Failed to parse RR record class %s: %m", optarg);
+
arg_class = (uint16_t) r;
assert((int) arg_class == r);
p = startswith(key, "RLIMIT_");
if (!p)
- l = -1;
+ l = -SYNTHETIC_ERRNO(EINVAL);
else
l = rlimit_from_string(p);
if (l < 0)
- return json_log(variant, flags, SYNTHETIC_ERRNO(EINVAL), "Resource limit '%s' not known.", key);
+ return json_log(variant, flags, l, "Resource limit '%s' not known.", key);
if (!json_variant_is_object(value))
return json_log(value, flags, SYNTHETIC_ERRNO(EINVAL), "Resource limit '%s' has invalid value.", key);
k = user_disposition_from_string(json_variant_string(variant));
if (k < 0)
- return json_log(variant, flags, SYNTHETIC_ERRNO(EINVAL), "Disposition type '%s' not known.", json_variant_string(variant));
+ return json_log(variant, flags, k, "Disposition type '%s' not known.", json_variant_string(variant));
*disposition = k;
return 0;
k = user_storage_from_string(json_variant_string(variant));
if (k < 0)
- return json_log(variant, flags, SYNTHETIC_ERRNO(EINVAL), "Storage type '%s' not known.", json_variant_string(variant));
+ return json_log(variant, flags, k, "Storage type '%s' not known.", json_variant_string(variant));
*storage = k;
return 0;
m = volatile_mode_from_string(mode);
if (m < 0)
- return -EINVAL;
+ return m;
*ret = m;
} else
if (value) {
if (level) {
- if (log_level_from_string(value) < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "\"%s\" is not a valid log level.", value);
+ r = log_level_from_string(value);
+ if (r < 0)
+ return log_error_errno(r, "\"%s\" is not a valid log level.", value);
}
r = bus_set_property(bus, bloc,
show_mode = systemctl_show_mode_from_string(argv[0]);
if (show_mode < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Invalid argument.");
+ return log_error_errno(show_mode, "Invalid argument.");
if (show_mode == SYSTEMCTL_SHOW_HELP && argc <= 1)
return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
state = unit_active_state_from_string(buf);
if (state < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL), "Invalid unit state '%s' for: %s", buf, unit);
+ return log_error_errno(state, "Invalid unit state '%s' for: %s", buf, unit);
*ret_active_state = state;
return 0;
/* The kernel command line always wins. However if nothing was set there, the argument passed here wins instead. */
m = volatile_mode_from_string(argv[1]);
if (m < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL), "Couldn't parse volatile mode: %s", argv[1]);
+ return log_error_errno(m, "Couldn't parse volatile mode: %s", argv[1]);
}
if (argc < 3)