Commit c57f6682 by Nikolai Vladimirov

config: allow empty string as value

`git_config_set_string(config, "config.section", "")` fails when
escaping the value.

The buffer in `escape_value` is allocated without NULL-termination. And
in case of empty string 0 is passed for buffer size in `git_buf_grow`.

`git_buf_detach` returns NULL when the allocated size is 0 and that
leads to an error return in `GITERR_CHECK_ALLOC` called after
`escape_value`

The change in `config_file.c` was suggested by Russell Belfer <rb@github.com>
parent c5780abb
...@@ -1293,6 +1293,9 @@ static char *escape_value(const char *ptr) ...@@ -1293,6 +1293,9 @@ static char *escape_value(const char *ptr)
assert(ptr); assert(ptr);
len = strlen(ptr); len = strlen(ptr);
if (!len)
return git__calloc(1, sizeof(char));
git_buf_grow(&buf, len); git_buf_grow(&buf, len);
while (*ptr != '\0') { while (*ptr != '\0') {
......
...@@ -242,3 +242,20 @@ void test_config_write__can_set_a_value_to_NULL(void) ...@@ -242,3 +242,20 @@ void test_config_write__can_set_a_value_to_NULL(void)
cl_git_sandbox_cleanup(); cl_git_sandbox_cleanup();
} }
void test_config_write__can_set_an_empty_value(void)
{
git_repository *repository;
git_config *config;
const char * str;
repository = cl_git_sandbox_init("testrepo.git");
cl_git_pass(git_repository_config(&config, repository));
cl_git_pass(git_config_set_string(config, "core.somevar", ""));
cl_git_pass(git_config_get_string(&str, config, "core.somevar"));
cl_assert_equal_s(str, "");
git_config_free(config);
cl_git_sandbox_cleanup();
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment