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:
commit
1c6e3514d0
2
cache.h
2
cache.h
@ -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);
|
||||||
|
63
config.c
63
config.c
@ -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
6
git.c
@ -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)
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user