Merge branch 'jn/clone-add-empty-config-from-command-line'
"git clone --config var=val" is a way to populate the per-repository configuration file of the new repository, but it did not work well when val is an empty string. This has been fixed. * jn/clone-add-empty-config-from-command-line: clone: handle empty config values in -c
This commit is contained in:
commit
883247c2fc
@ -776,7 +776,9 @@ static int checkout(int submodule_progress)
|
||||
|
||||
static int write_one_config(const char *key, const char *value, void *data)
|
||||
{
|
||||
return git_config_set_multivar_gently(key, value ? value : "true", "^$", 0);
|
||||
return git_config_set_multivar_gently(key,
|
||||
value ? value : "true",
|
||||
CONFIG_REGEX_NONE, 0);
|
||||
}
|
||||
|
||||
static void write_config(struct string_list *config)
|
||||
|
@ -19,6 +19,14 @@ test_expect_success 'clone -c can set multi-keys' '
|
||||
test_cmp expect actual
|
||||
'
|
||||
|
||||
test_expect_success 'clone -c can set multi-keys, including some empty' '
|
||||
rm -rf child &&
|
||||
git clone -c credential.helper= -c credential.helper=hi . child &&
|
||||
printf "%s\n" "" hi >expect &&
|
||||
git --git-dir=child/.git config --get-all credential.helper >actual &&
|
||||
test_cmp expect actual
|
||||
'
|
||||
|
||||
test_expect_success 'clone -c without a value is boolean true' '
|
||||
rm -rf child &&
|
||||
git clone -c core.foo . child &&
|
||||
|
Loading…
Reference in New Issue
Block a user