summaryrefslogtreecommitdiff
path: root/src/config_file.c
diff options
context:
space:
mode:
authorVicent Martí <tanoku@gmail.com>2012-05-03 23:27:15 -0700
committerVicent Martí <tanoku@gmail.com>2012-05-03 23:27:15 -0700
commit5f8af1bcac3d982adf0bc37a0868e420161dc761 (patch)
treeda738a93013dcd6c92e9249385b72956b5b1a74b /src/config_file.c
parent3fd99be98a91416dae77d65fe593965a0723fa8c (diff)
parent8e210931ca5d57b6ca7bc16b41598faa9339bc09 (diff)
downloadlibgit2-new-error-handling.tar.gz
Merge pull request #662 from carlosmn/remotesnew-error-handling
Add git_remote_add()
Diffstat (limited to 'src/config_file.c')
-rw-r--r--src/config_file.c11
1 files changed, 6 insertions, 5 deletions
diff --git a/src/config_file.c b/src/config_file.c
index be0977475..3219cca5c 100644
--- a/src/config_file.c
+++ b/src/config_file.c
@@ -258,17 +258,17 @@ static int config_set(git_config_file *cfg, const char *name, const char *value)
GITERR_CHECK_ALLOC(var->value);
}
+ if (config_write(b, key, NULL, value) < 0) {
+ cvar_free(var);
+ return -1;
+ }
+
git_strmap_insert2(b->values, key, var, old_var, rval);
if (rval < 0)
return -1;
if (old_var != NULL)
cvar_free(old_var);
- if (config_write(b, key, NULL, value) < 0) {
- cvar_free(var);
- return -1;
- }
-
return 0;
}
@@ -1021,6 +1021,7 @@ static int config_write(diskfile_backend *cfg, const char *key, const regex_t *p
pre_end = post_start = cfg->reader.read_ptr;
git__free(current_section);
+ current_section = NULL;
if (parse_section_header(cfg, &current_section) < 0)
goto rewrite_fail;