From 71e5820df128c671793cdaec7847f30504b5d563 Mon Sep 17 00:00:00 2001 From: Moritz Grimm Date: Fri, 7 Jul 2017 16:34:47 +0200 Subject: [PATCH] Make cmdline_parse() restartable --- src/cmdline.c | 1 + tests/check_cmdline.c | 5 ----- 2 files changed, 1 insertion(+), 5 deletions(-) diff --git a/src/cmdline.c b/src/cmdline.c index 6479a7e..0187603 100644 --- a/src/cmdline.c +++ b/src/cmdline.c @@ -101,6 +101,7 @@ cmdline_parse(int argc, char *argv[], int *ret_p) _set_program_name(argv[0]); + optind = 1; for (;;) { ch = getopt(argc, argv, OPTSTRING); if (0 > ch) diff --git a/tests/check_cmdline.c b/tests/check_cmdline.c index fd50fa0..48865d2 100644 --- a/tests/check_cmdline.c +++ b/tests/check_cmdline.c @@ -7,8 +7,6 @@ Suite * cmdline_suite(void); void setup_checked(void); void teardown_checked(void); -extern int optind; - START_TEST(test_configfile) { char *argv[] = @@ -102,11 +100,9 @@ START_TEST(test_verbose) ck_assert_int_ne(cmdline_parse(argc, argv, &ret), 0); ck_assert_uint_eq(cfg_get_program_verbosity(), 1); - optind = 1; ck_assert_int_ne(cmdline_parse(argc2, argv2, &ret), 0); ck_assert_uint_eq(cfg_get_program_verbosity(), 2); - optind = 1; ck_assert_int_ne(cmdline_parse(argc3, argv3, &ret), 0); ck_assert_uint_eq(cfg_get_program_verbosity(), 3); @@ -153,7 +149,6 @@ setup_checked(void) { if (0 < cfg_init()) ck_abort_msg("setup_checked failed"); - optind = 1; } void