diff options
author | jsing <> | 2014-08-27 15:51:41 +0000 |
---|---|---|
committer | jsing <> | 2014-08-27 15:51:41 +0000 |
commit | c5509750f2f6ceb6b0744ad9ddcfbc989e815932 (patch) | |
tree | 2fd398d5e81b862d9213840a8f6740351978f860 /src | |
parent | 1fbc8b7e3211e362b5507749d1c5b692dcb8c64f (diff) | |
download | openbsd-c5509750f2f6ceb6b0744ad9ddcfbc989e815932.tar.gz openbsd-c5509750f2f6ceb6b0744ad9ddcfbc989e815932.tar.bz2 openbsd-c5509750f2f6ceb6b0744ad9ddcfbc989e815932.zip |
Add an option type that handles argument to integer conversion.
Diffstat (limited to 'src')
-rw-r--r-- | src/usr.bin/openssl/apps.c | 23 | ||||
-rw-r--r-- | src/usr.bin/openssl/apps.h | 3 |
2 files changed, 22 insertions, 4 deletions
diff --git a/src/usr.bin/openssl/apps.c b/src/usr.bin/openssl/apps.c index e5eda3f53b..fc5e2d073a 100644 --- a/src/usr.bin/openssl/apps.c +++ b/src/usr.bin/openssl/apps.c | |||
@@ -1,4 +1,4 @@ | |||
1 | /* $OpenBSD: apps.c,v 1.2 2014/08/27 14:59:44 jsing Exp $ */ | 1 | /* $OpenBSD: apps.c,v 1.3 2014/08/27 15:51:41 jsing Exp $ */ |
2 | /* | 2 | /* |
3 | * Copyright (c) 2014 Joel Sing <jsing@openbsd.org> | 3 | * Copyright (c) 2014 Joel Sing <jsing@openbsd.org> |
4 | * | 4 | * |
@@ -2253,7 +2253,9 @@ options_usage(struct option *opts) | |||
2253 | int | 2253 | int |
2254 | options_parse(int argc, char **argv, struct option *opts, char **unnamed) | 2254 | options_parse(int argc, char **argv, struct option *opts, char **unnamed) |
2255 | { | 2255 | { |
2256 | const char *errstr; | ||
2256 | struct option *opt; | 2257 | struct option *opt; |
2258 | long long val; | ||
2257 | char *arg, *p; | 2259 | char *arg, *p; |
2258 | int i, j; | 2260 | int i, j; |
2259 | 2261 | ||
@@ -2274,17 +2276,32 @@ options_parse(int argc, char **argv, struct option *opts, char **unnamed) | |||
2274 | if (strcmp(p, opt->name) != 0) | 2276 | if (strcmp(p, opt->name) != 0) |
2275 | continue; | 2277 | continue; |
2276 | 2278 | ||
2277 | switch (opt->type) { | 2279 | if (opt->type == OPTION_ARG || |
2278 | case OPTION_ARG: | 2280 | opt->type == OPTION_ARG_INT) { |
2279 | if (++i >= argc) { | 2281 | if (++i >= argc) { |
2280 | fprintf(stderr, | 2282 | fprintf(stderr, |
2281 | "missing %s argument for -%s\n", | 2283 | "missing %s argument for -%s\n", |
2282 | opt->argname, opt->name); | 2284 | opt->argname, opt->name); |
2283 | return (1); | 2285 | return (1); |
2284 | } | 2286 | } |
2287 | } | ||
2288 | |||
2289 | switch (opt->type) { | ||
2290 | case OPTION_ARG: | ||
2285 | *opt->opt.arg = argv[i]; | 2291 | *opt->opt.arg = argv[i]; |
2286 | break; | 2292 | break; |
2287 | 2293 | ||
2294 | case OPTION_ARG_INT: | ||
2295 | val = strtonum(argv[i], 0, INT_MAX, &errstr); | ||
2296 | if (errstr != NULL) { | ||
2297 | fprintf(stderr, | ||
2298 | "%s %s argument for -%s\n", | ||
2299 | errstr, opt->argname, opt->name); | ||
2300 | return (1); | ||
2301 | } | ||
2302 | *opt->opt.value = (int)val; | ||
2303 | break; | ||
2304 | |||
2288 | case OPTION_FLAG: | 2305 | case OPTION_FLAG: |
2289 | *opt->opt.flag = 1; | 2306 | *opt->opt.flag = 1; |
2290 | break; | 2307 | break; |
diff --git a/src/usr.bin/openssl/apps.h b/src/usr.bin/openssl/apps.h index 64e581b969..43d119500f 100644 --- a/src/usr.bin/openssl/apps.h +++ b/src/usr.bin/openssl/apps.h | |||
@@ -1,4 +1,4 @@ | |||
1 | /* $OpenBSD: apps.h,v 1.2 2014/08/27 14:59:44 jsing Exp $ */ | 1 | /* $OpenBSD: apps.h,v 1.3 2014/08/27 15:51:41 jsing Exp $ */ |
2 | /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) | 2 | /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) |
3 | * All rights reserved. | 3 | * All rights reserved. |
4 | * | 4 | * |
@@ -288,6 +288,7 @@ struct option { | |||
288 | const char *desc; | 288 | const char *desc; |
289 | enum { | 289 | enum { |
290 | OPTION_ARG, | 290 | OPTION_ARG, |
291 | OPTION_ARG_INT, | ||
291 | OPTION_FLAG, | 292 | OPTION_FLAG, |
292 | OPTION_VALUE, | 293 | OPTION_VALUE, |
293 | } type; | 294 | } type; |