Skip to content

Commit 26b8abc

Browse files
vermiculusgitster
authored andcommitted
var: do not print usage() with a correct invocation
Before, git-var could print usage() even if the command was invoked correctly with a variable defined in git_vars -- provided that its read() function returned NULL. Now, we only print usage() only if it was called with a logical variable that wasn't defined -- regardless of read(). Since we now know the variable is valid when we call read_var(), we can avoid printing usage() here (and exiting with code 129) and instead exit quietly with code 1. While exiting with a different code can be a breaking change, it's far better than changing the exit status more generally from 'failure' to 'success'. Signed-off-by: Sean Allred <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent c000d91 commit 26b8abc

File tree

2 files changed

+15
-10
lines changed

2 files changed

+15
-10
lines changed

Documentation/git-var.txt

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,8 @@ SYNOPSIS
1313

1414
DESCRIPTION
1515
-----------
16-
Prints a Git logical variable.
16+
Prints a Git logical variable. Exits with code 1 if the variable has
17+
no value.
1718

1819
OPTIONS
1920
-------

builtin/var.c

Lines changed: 13 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -56,18 +56,15 @@ static void list_vars(void)
5656
printf("%s=%s\n", ptr->name, val);
5757
}
5858

59-
static const char *read_var(const char *var)
59+
static const struct git_var *get_git_var(const char *var)
6060
{
6161
struct git_var *ptr;
62-
const char *val;
63-
val = NULL;
6462
for (ptr = git_vars; ptr->read; ptr++) {
6563
if (strcmp(var, ptr->name) == 0) {
66-
val = ptr->read(IDENT_STRICT);
67-
break;
64+
return ptr;
6865
}
6966
}
70-
return val;
67+
return NULL;
7168
}
7269

7370
static int show_config(const char *var, const char *value, void *cb)
@@ -81,7 +78,9 @@ static int show_config(const char *var, const char *value, void *cb)
8178

8279
int cmd_var(int argc, const char **argv, const char *prefix)
8380
{
84-
const char *val = NULL;
81+
const struct git_var *git_var;
82+
const char *val;
83+
8584
if (argc != 2)
8685
usage(var_usage);
8786

@@ -91,10 +90,15 @@ int cmd_var(int argc, const char **argv, const char *prefix)
9190
return 0;
9291
}
9392
git_config(git_default_config, NULL);
94-
val = read_var(argv[1]);
95-
if (!val)
93+
94+
git_var = get_git_var(argv[1]);
95+
if (!git_var)
9696
usage(var_usage);
9797

98+
val = git_var->read(IDENT_STRICT);
99+
if (!val)
100+
return 1;
101+
98102
printf("%s\n", val);
99103

100104
return 0;

0 commit comments

Comments
 (0)