summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJunio C Hamano <junkio@cox.net>2006-12-19 21:55:27 -0800
committerJunio C Hamano <junkio@cox.net>2006-12-19 22:30:59 -0800
commitfc1905bb9340304fb5980841fca24638028c1c5e (patch)
tree593c15e05706a0f1e607b55dc7385b64a1ff908e
parentc17f9f12a4a8d224e5cff6bcfa6191450f90fa0b (diff)
downloadgit-fc1905bb9340304fb5980841fca24638028c1c5e.tar.gz
config_rename_section: fix FILE* leak
Noticed by SungHyun Nam. Signed-off-by: Junio C Hamano <junkio@cox.net>
-rw-r--r--config.c19
1 files changed, 13 insertions, 6 deletions
diff --git a/config.c b/config.c
index 663993fefa..8cbdd178bd 100644
--- a/config.c
+++ b/config.c
@@ -749,7 +749,7 @@ out_free:
int git_config_rename_section(const char *old_name, const char *new_name)
{
int ret = 0;
- const char *config_filename;
+ char *config_filename;
struct lock_file *lock = xcalloc(sizeof(struct lock_file), 1);
int out_fd;
char buf[1024];
@@ -762,11 +762,15 @@ int git_config_rename_section(const char *old_name, const char *new_name)
}
config_filename = xstrdup(config_filename);
out_fd = hold_lock_file_for_update(lock, config_filename, 0);
- if (out_fd < 0)
- return error("Could not lock config file!");
+ if (out_fd < 0) {
+ ret = error("Could not lock config file!");
+ goto out;
+ }
- if (!(config_file = fopen(config_filename, "rb")))
- return error("Could not open config file!");
+ if (!(config_file = fopen(config_filename, "rb"))) {
+ ret = error("Could not open config file!");
+ goto out;
+ }
while (fgets(buf, sizeof(buf), config_file)) {
int i;
@@ -806,8 +810,11 @@ int git_config_rename_section(const char *old_name, const char *new_name)
}
write(out_fd, buf, strlen(buf));
}
+ fclose(config_file);
if (close(out_fd) || commit_lock_file(lock) < 0)
- return error("Cannot commit config file!");
+ ret = error("Cannot commit config file!");
+ out:
+ free(config_filename);
return ret;
}