summaryrefslogtreecommitdiff
path: root/src/busctl
diff options
context:
space:
mode:
authorZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>2021-02-15 19:32:42 +0100
committerZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>2021-02-17 21:06:31 +0100
commit599c7c545f689f7d19a73238eecc69bf94fa6a74 (patch)
tree3d7cc8218ea1771ada8c36d094cda46a51c81291 /src/busctl
parent79dbbb261d245b619a4d82c1cdf96f6a4310ee0d (diff)
downloadsystemd-599c7c545f689f7d19a73238eecc69bf94fa6a74.tar.gz
tree-wide: add a helper to parse boolean optarg
This nicely covers the case when optarg is optional. The same parser can be used when the option string passed to getopt_long() requires a parameter and when it doesn't. The error messages are made consistent. Also fixes a log error c&p in --crash-reboot message.
Diffstat (limited to 'src/busctl')
-rw-r--r--src/busctl/busctl.c31
1 files changed, 11 insertions, 20 deletions
diff --git a/src/busctl/busctl.c b/src/busctl/busctl.c
index 6a492ebd02..99ff5bf561 100644
--- a/src/busctl/busctl.c
+++ b/src/busctl/busctl.c
@@ -2473,27 +2473,22 @@ static int parse_argv(int argc, char *argv[]) {
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:
@@ -2504,19 +2499,15 @@ static int parse_argv(int argc, char *argv[]) {
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':