config_rename_section: fix FILE* leak

Noticed by SungHyun Nam.

Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
Junio C Hamano 2006-12-19 21:55:27 -08:00
parent c17f9f12a4
commit fc1905bb93

View File

@ -749,7 +749,7 @@ out_free:
int git_config_rename_section(const char *old_name, const char *new_name) int git_config_rename_section(const char *old_name, const char *new_name)
{ {
int ret = 0; int ret = 0;
const char *config_filename; char *config_filename;
struct lock_file *lock = xcalloc(sizeof(struct lock_file), 1); struct lock_file *lock = xcalloc(sizeof(struct lock_file), 1);
int out_fd; int out_fd;
char buf[1024]; 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); config_filename = xstrdup(config_filename);
out_fd = hold_lock_file_for_update(lock, config_filename, 0); out_fd = hold_lock_file_for_update(lock, config_filename, 0);
if (out_fd < 0) if (out_fd < 0) {
return error("Could not lock config file!"); ret = error("Could not lock config file!");
goto out;
}
if (!(config_file = fopen(config_filename, "rb"))) if (!(config_file = fopen(config_filename, "rb"))) {
return error("Could not open config file!"); ret = error("Could not open config file!");
goto out;
}
while (fgets(buf, sizeof(buf), config_file)) { while (fgets(buf, sizeof(buf), config_file)) {
int i; 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)); write(out_fd, buf, strlen(buf));
} }
fclose(config_file);
if (close(out_fd) || commit_lock_file(lock) < 0) 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; return ret;
} }