Merge branch 'jk/maint-config-alias-fix' into maint

* jk/maint-config-alias-fix:
  handle_options(): do not miscount how many arguments were used
  config: always parse GIT_CONFIG_PARAMETERS during git_config
  git_config: don't peek at global config_parameters
  config: make environment parsing routines static
This commit is contained in:
Junio C Hamano 2011-06-01 14:05:22 -07:00
commit 1c6e3514d0
4 changed files with 30 additions and 48 deletions

View File

@ -1007,8 +1007,6 @@ typedef int (*config_fn_t)(const char *, const char *, void *);
extern int git_default_config(const char *, const char *, void *); extern int git_default_config(const char *, const char *, void *);
extern int git_config_from_file(config_fn_t fn, const char *, void *); extern int git_config_from_file(config_fn_t fn, const char *, void *);
extern void git_config_push_parameter(const char *text); extern void git_config_push_parameter(const char *text);
extern int git_config_parse_parameter(const char *text);
extern int git_config_parse_environment(void);
extern int git_config_from_parameters(config_fn_t fn, void *data); extern int git_config_from_parameters(config_fn_t fn, void *data);
extern int git_config(config_fn_t fn, void *); extern int git_config(config_fn_t fn, void *);
extern int git_config_early(config_fn_t fn, void *, const char *repo_config); extern int git_config_early(config_fn_t fn, void *, const char *repo_config);

View File

@ -20,14 +20,6 @@ static int zlib_compression_seen;
const char *config_exclusive_filename = NULL; const char *config_exclusive_filename = NULL;
struct config_item {
struct config_item *next;
char *name;
char *value;
};
static struct config_item *config_parameters;
static struct config_item **config_parameters_tail = &config_parameters;
static void lowercase(char *p) static void lowercase(char *p)
{ {
for (; *p; p++) for (; *p; p++)
@ -47,9 +39,9 @@ void git_config_push_parameter(const char *text)
strbuf_release(&env); strbuf_release(&env);
} }
int git_config_parse_parameter(const char *text) static int git_config_parse_parameter(const char *text,
config_fn_t fn, void *data)
{ {
struct config_item *ct;
struct strbuf tmp = STRBUF_INIT; struct strbuf tmp = STRBUF_INIT;
struct strbuf **pair; struct strbuf **pair;
strbuf_addstr(&tmp, text); strbuf_addstr(&tmp, text);
@ -58,23 +50,20 @@ int git_config_parse_parameter(const char *text)
strbuf_setlen(pair[0], pair[0]->len - 1); strbuf_setlen(pair[0], pair[0]->len - 1);
strbuf_trim(pair[0]); strbuf_trim(pair[0]);
if (!pair[0]->len) { if (!pair[0]->len) {
strbuf_list_free(pair);
return error("bogus config parameter: %s", text);
}
lowercase(pair[0]->buf);
if (fn(pair[0]->buf, pair[1] ? pair[1]->buf : NULL, data) < 0) {
strbuf_list_free(pair); strbuf_list_free(pair);
return -1; return -1;
} }
ct = xcalloc(1, sizeof(struct config_item));
ct->name = strbuf_detach(pair[0], NULL);
if (pair[1]) {
strbuf_trim(pair[1]);
ct->value = strbuf_detach(pair[1], NULL);
}
strbuf_list_free(pair); strbuf_list_free(pair);
lowercase(ct->name);
*config_parameters_tail = ct;
config_parameters_tail = &ct->next;
return 0; return 0;
} }
int git_config_parse_environment(void) { int git_config_from_parameters(config_fn_t fn, void *data)
{
const char *env = getenv(CONFIG_DATA_ENVIRONMENT); const char *env = getenv(CONFIG_DATA_ENVIRONMENT);
char *envw; char *envw;
const char **argv = NULL; const char **argv = NULL;
@ -92,8 +81,7 @@ int git_config_parse_environment(void) {
} }
for (i = 0; i < nr; i++) { for (i = 0; i < nr; i++) {
if (git_config_parse_parameter(argv[i]) < 0) { if (git_config_parse_parameter(argv[i], fn, data) < 0) {
error("bogus config parameter: %s", argv[i]);
free(argv); free(argv);
free(envw); free(envw);
return -1; return -1;
@ -102,7 +90,7 @@ int git_config_parse_environment(void) {
free(argv); free(argv);
free(envw); free(envw);
return 0; return nr > 0;
} }
static int get_next_char(void) static int get_next_char(void)
@ -839,22 +827,6 @@ int git_config_system(void)
return !git_env_bool("GIT_CONFIG_NOSYSTEM", 0); return !git_env_bool("GIT_CONFIG_NOSYSTEM", 0);
} }
int git_config_from_parameters(config_fn_t fn, void *data)
{
static int loaded_environment;
const struct config_item *ct;
if (!loaded_environment) {
if (git_config_parse_environment() < 0)
return -1;
loaded_environment = 1;
}
for (ct = config_parameters; ct; ct = ct->next)
if (fn(ct->name, ct->value, data) < 0)
return -1;
return 0;
}
int git_config_early(config_fn_t fn, void *data, const char *repo_config) int git_config_early(config_fn_t fn, void *data, const char *repo_config)
{ {
int ret = 0, found = 0; int ret = 0, found = 0;
@ -884,9 +856,16 @@ int git_config_early(config_fn_t fn, void *data, const char *repo_config)
found += 1; found += 1;
} }
ret += git_config_from_parameters(fn, data); switch (git_config_from_parameters(fn, data)) {
if (config_parameters) case -1: /* error */
found += 1; ret--;
break;
case 0: /* found nothing */
break;
default: /* found at least one item */
found++;
break;
}
return ret == 0 ? found : ret; return ret == 0 ? found : ret;
} }

6
git.c
View File

@ -66,7 +66,7 @@ static void commit_pager_choice(void) {
static int handle_options(const char ***argv, int *argc, int *envchanged) static int handle_options(const char ***argv, int *argc, int *envchanged)
{ {
int handled = 0; const char **orig_argv = *argv;
while (*argc > 0) { while (*argc > 0) {
const char *cmd = (*argv)[0]; const char *cmd = (*argv)[0];
@ -116,7 +116,6 @@ static int handle_options(const char ***argv, int *argc, int *envchanged)
*envchanged = 1; *envchanged = 1;
(*argv)++; (*argv)++;
(*argc)--; (*argc)--;
handled++;
} else if (!prefixcmp(cmd, "--git-dir=")) { } else if (!prefixcmp(cmd, "--git-dir=")) {
setenv(GIT_DIR_ENVIRONMENT, cmd + 10, 1); setenv(GIT_DIR_ENVIRONMENT, cmd + 10, 1);
if (envchanged) if (envchanged)
@ -156,9 +155,8 @@ static int handle_options(const char ***argv, int *argc, int *envchanged)
(*argv)++; (*argv)++;
(*argc)--; (*argc)--;
handled++;
} }
return handled; return (*argv) - orig_argv;
} }
static int handle_alias(int *argcp, const char ***argv) static int handle_alias(int *argcp, const char ***argv)

View File

@ -897,4 +897,11 @@ test_expect_success 'key sanity-checking' '
git config foo."ba =z".bar false git config foo."ba =z".bar false
' '
test_expect_success 'git -c works with aliases of builtins' '
git config alias.checkconfig "-c foo.check=bar config foo.check" &&
echo bar >expect &&
git checkconfig >actual &&
test_cmp expect actual
'
test_done test_done