#include "main-func.h"
#include "nulstr-util.h"
#include "pager.h"
+#include "parse-argument.h"
#include "parse-util.h"
#include "path-util.h"
#include "pretty-print.h"
break;
case ARG_MAN:
- if (optarg) {
- r = parse_boolean(optarg);
- if (r < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Failed to parse --man= argument.");
-
- arg_man = r;
- } else
- arg_man = true;
-
+ r = parse_boolean_argument("--man", optarg, &arg_man);
+ if (r < 0)
+ return r;
break;
case ARG_GENERATORS:
- if (optarg) {
- r = parse_boolean(optarg);
- if (r < 0)
- return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
- "Failed to parse --generators= argument.");
-
- arg_generators = r;
- } else
- arg_generators = true;
-
+ r = parse_boolean_argument("--generators", optarg, &arg_generators);
+ if (r < 0)
+ return r;
break;
case ARG_ITERATIONS:
break;
case ARG_EXPECT_REPLY:
- r = parse_boolean(optarg);
+ r = parse_boolean_argument("--expect-reply=", optarg, &arg_expect_reply);
if (r < 0)
- return log_error_errno(r, "Failed to parse --expect-reply= parameter '%s': %m", optarg);
-
- arg_expect_reply = r;
+ return r;
break;
case ARG_AUTO_START:
- r = parse_boolean(optarg);
+ r = parse_boolean_argument("--auto-start=", optarg, &arg_auto_start);
if (r < 0)
- return log_error_errno(r, "Failed to parse --auto-start= parameter '%s': %m", optarg);
-
- arg_auto_start = r;
+ return r;
break;
case ARG_ALLOW_INTERACTIVE_AUTHORIZATION:
- r = parse_boolean(optarg);
+ r = parse_boolean_argument("--allow-interactive-authorization=", optarg,
+ &arg_allow_interactive_authorization);
if (r < 0)
- return log_error_errno(r, "Failed to parse --allow-interactive-authorization= parameter '%s': %m", optarg);
-
- arg_allow_interactive_authorization = r;
+ return r;
break;
case ARG_TIMEOUT:
break;
case ARG_AUGMENT_CREDS:
- r = parse_boolean(optarg);
+ r = parse_boolean_argument("--augment-creds=", optarg, &arg_augment_creds);
if (r < 0)
- return log_error_errno(r, "Failed to parse --augment-creds= parameter '%s': %m", optarg);
-
- arg_augment_creds = r;
+ return r;
break;
case ARG_WATCH_BIND:
- r = parse_boolean(optarg);
+ r = parse_boolean_argument("--watch-bind=", optarg, &arg_watch_bind);
if (r < 0)
- return log_error_errno(r, "Failed to parse --watch-bind= parameter '%s': %m", optarg);
-
- arg_watch_bind = r;
+ return r;
break;
case 'j':
#include "hashmap.h"
#include "main-func.h"
#include "missing_sched.h"
+#include "parse-argument.h"
#include "parse-util.h"
#include "path-util.h"
#include "pretty-print.h"
break;
case ARG_RECURSIVE:
- r = parse_boolean(optarg);
+ r = parse_boolean_argument("--recursive=", optarg, &arg_recursive);
if (r < 0)
- return log_error_errno(r, "Failed to parse --recursive= argument '%s': %m", optarg);
+ return r;
- arg_recursive = r;
- arg_recursive_unset = r == 0;
+ arg_recursive_unset = !r;
break;
case 'M':
break;
case ARG_DUMP_CORE:
- if (!optarg)
- arg_dump_core = true;
- else {
- r = parse_boolean(optarg);
- if (r < 0)
- return log_error_errno(r, "Failed to parse dump core boolean: \"%s\": %m",
- optarg);
- arg_dump_core = r;
- }
+ r = parse_boolean_argument("--dump-core", optarg, &arg_dump_core);
+ if (r < 0)
+ return r;
break;
case ARG_CRASH_CHVT:
break;
case ARG_CRASH_SHELL:
- if (!optarg)
- arg_crash_shell = true;
- else {
- r = parse_boolean(optarg);
- if (r < 0)
- return log_error_errno(r, "Failed to parse crash shell boolean: \"%s\": %m",
- optarg);
- arg_crash_shell = r;
- }
+ r = parse_boolean_argument("--crash-shell", optarg, &arg_crash_shell);
+ if (r < 0)
+ return r;
break;
case ARG_CRASH_REBOOT:
- if (!optarg)
- arg_crash_reboot = true;
- else {
- r = parse_boolean(optarg);
- if (r < 0)
- return log_error_errno(r, "Failed to parse crash shell boolean: \"%s\": %m",
- optarg);
- arg_crash_reboot = r;
- }
+ r = parse_boolean_argument("--crash-reboot", optarg, &arg_crash_reboot);
+ if (r < 0)
+ return r;
break;
case ARG_CONFIRM_SPAWN:
break;
case ARG_SERVICE_WATCHDOGS:
- r = parse_boolean(optarg);
+ r = parse_boolean_argument("--service-watchdogs=", optarg, &arg_service_watchdogs);
if (r < 0)
- return log_error_errno(r, "Failed to parse service watchdogs boolean: \"%s\": %m",
- optarg);
- arg_service_watchdogs = r;
+ return r;
break;
case ARG_SHOW_STATUS:
#include "alloc-util.h"
#include "fd-util.h"
#include "main-func.h"
+#include "parse-argument.h"
#include "parse-util.h"
#include "pretty-print.h"
#include "string-util.h"
{}
};
- int c;
+ int c, r;
assert(argc >= 0);
assert(argv);
"Failed to parse stderr priority value.");
break;
- case ARG_LEVEL_PREFIX: {
- int k;
-
- k = parse_boolean(optarg);
- if (k < 0)
- return log_error_errno(k, "Failed to parse level prefix value.");
-
- arg_level_prefix = k;
+ case ARG_LEVEL_PREFIX:
+ r = parse_boolean_argument("--level-prefix=", optarg, &arg_level_prefix);
+ if (r < 0)
+ return r;
break;
- }
case '?':
return -EINVAL;
#include "mount-util.h"
#include "mountpoint-util.h"
#include "pager.h"
+#include "parse-argument.h"
#include "parse-util.h"
#include "path-util.h"
#include "pretty-print.h"
}
case ARG_FSCK:
- r = parse_boolean(optarg);
+ r = parse_boolean_argument("--fsck=", optarg, &arg_fsck);
if (r < 0)
- return log_error_errno(r, "Failed to parse --fsck= argument: %s", optarg);
-
- arg_fsck = r;
+ return r;
break;
case ARG_DESCRIPTION:
#include "mkdir.h"
#include "mkfs-util.h"
#include "mount-util.h"
-#include "parse-util.h"
#include "parse-argument.h"
+#include "parse-util.h"
#include "path-util.h"
#include "pretty-print.h"
#include "proc-cmdline.h"
break;
case ARG_DRY_RUN:
- r = parse_boolean(optarg);
+ r = parse_boolean_argument("--dry-run=", optarg, &arg_dry_run);
if (r < 0)
- return log_error_errno(r, "Failed to parse --dry-run= parameter: %s", optarg);
-
- dry_run = r;
+ return r;
break;
case ARG_EMPTY:
break;
case ARG_DISCARD:
- r = parse_boolean(optarg);
+ r = parse_boolean_argument("--discard=", optarg, &arg_discard);
if (r < 0)
- return log_error_errno(r, "Failed to parse --discard= parameter: %s", optarg);
-
- arg_discard = r;
+ return r;
break;
case ARG_FACTORY_RESET:
#include "missing_network.h"
#include "netlink-util.h"
#include "pager.h"
+#include "parse-argument.h"
#include "parse-util.h"
#include "pretty-print.h"
#include "resolvconf-compat.h"
break;
case ARG_LEGEND:
- r = parse_boolean(optarg);
+ r = parse_boolean_argument("--legend=", optarg, &arg_legend);
if (r < 0)
- return log_error_errno(r, "Failed to parse --legend= argument");
-
- arg_legend = r;
+ return r;
break;
case 'p':
break;
case ARG_LEGEND:
- r = parse_boolean(optarg);
+ r = parse_boolean_argument("--legend=", optarg, &arg_legend);
if (r < 0)
- return log_error_errno(r, "Failed to parse --legend= argument");
-
- arg_legend = r;
+ return r;
break;
case 'p':
/* All functions in this file emit warnigs. */
+int parse_boolean_argument(const char *optname, const char *s, bool *ret) {
+ int r;
+
+ /* Returns the result through *ret and the return value. */
+
+ if (s) {
+ r = parse_boolean(s);
+ if (r < 0)
+ return log_error_errno(r, "Failed to parse boolean argument to %s: %s.", optname, s);
+
+ *ret = r;
+ return r;
+ } else {
+ /* s may be NULL. This is controlled by getopt_long() parameters. */
+ *ret = true;
+ return true;
+ }
+}
+
int parse_json_argument(const char *s, JsonFormatFlags *ret) {
assert(s);
assert(ret);
#include "json.h"
+int parse_boolean_argument(const char *optname, const char *s, bool *ret);
int parse_json_argument(const char *s, JsonFormatFlags *ret);
int parse_path_argument(const char *path, bool suppress_root, char **arg);
int parse_signal_argument(const char *s, int *ret);