cache: fix resource leak: close file handle before return
Coverity-id: 13910 Signed-off-by: Christian Hesse <mail@eworm.de>
Tá an tiomantas seo le fáil i:
tuismitheoir
ed5dccbeaa
tiomantas
76dc7a3371
12
cache.c
12
cache.c
@ -215,19 +215,25 @@ static int fill_slot(struct cache_slot *slot)
|
||||
return errno;
|
||||
|
||||
/* Redirect stdout to lockfile */
|
||||
if (dup2(slot->lock_fd, STDOUT_FILENO) == -1)
|
||||
if (dup2(slot->lock_fd, STDOUT_FILENO) == -1) {
|
||||
close(tmp);
|
||||
return errno;
|
||||
}
|
||||
|
||||
/* Generate cache content */
|
||||
slot->fn();
|
||||
|
||||
/* update stat info */
|
||||
if (fstat(slot->lock_fd, &slot->cache_st))
|
||||
if (fstat(slot->lock_fd, &slot->cache_st)) {
|
||||
close(tmp);
|
||||
return errno;
|
||||
}
|
||||
|
||||
/* Restore stdout */
|
||||
if (dup2(tmp, STDOUT_FILENO) == -1)
|
||||
if (dup2(tmp, STDOUT_FILENO) == -1) {
|
||||
close(tmp);
|
||||
return errno;
|
||||
}
|
||||
|
||||
/* Close the temporary filedescriptor */
|
||||
if (close(tmp))
|
||||
|
Á lódáil...
x
Tagairt in Eagrán Nua
Cuir bac ar úsáideoir