diff options
author | Junio C Hamano <junkio@cox.net> | 2007-01-19 08:25:54 +0100 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2007-01-19 08:25:54 +0100 |
commit | 2266bf27b354a08522406eff916898b6300ddfa0 (patch) | |
tree | 630d0b33ac812c37883f32e2a4781372aae51c9e /refs.c | |
parent | Documentation: Generate command lists. (diff) | |
download | git-2266bf27b354a08522406eff916898b6300ddfa0.tar.xz git-2266bf27b354a08522406eff916898b6300ddfa0.zip |
for_each_reflog_ent: do not leak FILE *
The callback function can signal an early return by returning non-zero,
but the function leaked the FILE * opened on the reflog when doing so.
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'refs.c')
-rw-r--r-- | refs.c | 7 |
1 files changed, 4 insertions, 3 deletions
@@ -1110,6 +1110,7 @@ int for_each_reflog_ent(const char *ref, each_reflog_ent_fn fn, void *cb_data) const char *logfile; FILE *logfp; char buf[1024]; + int ret = 0; logfile = git_path("logs/%s", ref); logfp = fopen(logfile, "r"); @@ -1119,7 +1120,7 @@ int for_each_reflog_ent(const char *ref, each_reflog_ent_fn fn, void *cb_data) unsigned char osha1[20], nsha1[20]; char *email_end, *message; unsigned long timestamp; - int len, ret, tz; + int len, tz; /* old SP new SP name <email> SP time TAB msg LF */ len = strlen(buf); @@ -1140,9 +1141,9 @@ int for_each_reflog_ent(const char *ref, each_reflog_ent_fn fn, void *cb_data) message += 7; ret = fn(osha1, nsha1, buf+82, timestamp, tz, message, cb_data); if (ret) - return ret; + break; } fclose(logfp); - return 0; + return ret; } |