mirror of
https://git.zx2c4.com/cgit
synced 2024-11-26 02:18:42 +00:00
cache: fix resource leak: close file handle before return
Coverity-id: 13910 Signed-off-by: Christian Hesse <mail@eworm.de>
This commit is contained in:
parent
ed5dccbeaa
commit
76dc7a3371
12
cache.c
12
cache.c
@ -215,19 +215,25 @@ static int fill_slot(struct cache_slot *slot)
|
|||||||
return errno;
|
return errno;
|
||||||
|
|
||||||
/* Redirect stdout to lockfile */
|
/* Redirect stdout to lockfile */
|
||||||
if (dup2(slot->lock_fd, STDOUT_FILENO) == -1)
|
if (dup2(slot->lock_fd, STDOUT_FILENO) == -1) {
|
||||||
|
close(tmp);
|
||||||
return errno;
|
return errno;
|
||||||
|
}
|
||||||
|
|
||||||
/* Generate cache content */
|
/* Generate cache content */
|
||||||
slot->fn();
|
slot->fn();
|
||||||
|
|
||||||
/* update stat info */
|
/* update stat info */
|
||||||
if (fstat(slot->lock_fd, &slot->cache_st))
|
if (fstat(slot->lock_fd, &slot->cache_st)) {
|
||||||
|
close(tmp);
|
||||||
return errno;
|
return errno;
|
||||||
|
}
|
||||||
|
|
||||||
/* Restore stdout */
|
/* Restore stdout */
|
||||||
if (dup2(tmp, STDOUT_FILENO) == -1)
|
if (dup2(tmp, STDOUT_FILENO) == -1) {
|
||||||
|
close(tmp);
|
||||||
return errno;
|
return errno;
|
||||||
|
}
|
||||||
|
|
||||||
/* Close the temporary filedescriptor */
|
/* Close the temporary filedescriptor */
|
||||||
if (close(tmp))
|
if (close(tmp))
|
||||||
|
Loading…
Reference in New Issue
Block a user