]> git.ipfire.org Git - thirdparty/git.git/commitdiff
env--helper: write to opt->value in parseopt helper
authorJeff King <peff@peff.net>
Wed, 30 Sep 2020 12:28:32 +0000 (08:28 -0400)
committerJunio C Hamano <gitster@pobox.com>
Wed, 30 Sep 2020 19:53:47 +0000 (12:53 -0700)
We use OPT_CALLBACK_F() to call the option_parse_type() callback,
passing it the address of "cmdmode" as the value to write to. But the
callback doesn't look at opt->value at all, and instead writes to a
global variable.

This works out because that's the same global variable we happen to pass
in, but it's rather confusing.  Let's use the passed-in value instead.
We'll also make "cmdmode" a local variable of the main function,
ensuring we can't make the same mistake again.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/env--helper.c

index 23c214fff6d69101c29d49bad033b602cd1b3173..3aa4282114933316d6dae588321ae1816de42bb5 100644 (file)
@@ -7,18 +7,20 @@ static char const * const env__helper_usage[] = {
        NULL
 };
 
-static enum {
+enum cmdmode {
        ENV_HELPER_TYPE_BOOL = 1,
        ENV_HELPER_TYPE_ULONG
-} cmdmode = 0;
+};
 
 static int option_parse_type(const struct option *opt, const char *arg,
                             int unset)
 {
+       enum cmdmode *cmdmode = opt->value;
+
        if (!strcmp(arg, "bool"))
-               cmdmode = ENV_HELPER_TYPE_BOOL;
+               *cmdmode = ENV_HELPER_TYPE_BOOL;
        else if (!strcmp(arg, "ulong"))
-               cmdmode = ENV_HELPER_TYPE_ULONG;
+               *cmdmode = ENV_HELPER_TYPE_ULONG;
        else
                die(_("unrecognized --type argument, %s"), arg);
 
@@ -33,6 +35,7 @@ int cmd_env__helper(int argc, const char **argv, const char *prefix)
        int ret;
        int ret_int, default_int;
        unsigned long ret_ulong, default_ulong;
+       enum cmdmode cmdmode = 0;
        struct option opts[] = {
                OPT_CALLBACK_F(0, "type", &cmdmode, N_("type"),
                               N_("value is given this type"), PARSE_OPT_NONEG,