diff options
author | Sergey Vlasov <vsu@altlinux.ru> | 2005-09-23 14:28:28 +0200 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2005-09-23 23:30:45 +0200 |
commit | 1a951815ddaa4e4b570cc67e204f45e9a12841e0 (patch) | |
tree | 8a44a8e894c6239dd063dcaf841f63e6c35fc9cb /local-fetch.c | |
parent | [PATCH] git-local-fetch: Fix error checking and leak in setup_indices() (diff) | |
download | git-1a951815ddaa4e4b570cc67e204f45e9a12841e0.tar.xz git-1a951815ddaa4e4b570cc67e204f45e9a12841e0.zip |
[PATCH] git-local-fetch: Avoid calling close(-1)
After open() failure, copy_file() called close(ifd) with ifd == -1
(harmless, but causes Valgrind noise). The same thing was possible
for the destination file descriptor.
Signed-off-by: Sergey Vlasov <vsu@altlinux.ru>
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'local-fetch.c')
-rw-r--r-- | local-fetch.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/local-fetch.c b/local-fetch.c index b3947a9657..a3e35f9c81 100644 --- a/local-fetch.c +++ b/local-fetch.c @@ -75,7 +75,8 @@ static int copy_file(const char *source, const char *dest, const char *hex) void *map; ifd = open(source, O_RDONLY); if (ifd < 0 || fstat(ifd, &st) < 0) { - close(ifd); + if (ifd >= 0) + close(ifd); fprintf(stderr, "cannot open %s\n", source); return -1; } @@ -89,7 +90,8 @@ static int copy_file(const char *source, const char *dest, const char *hex) status = ((ofd < 0) || (write(ofd, map, st.st_size) != st.st_size)); munmap(map, st.st_size); - close(ofd); + if (ofd >= 0) + close(ofd); if (status) fprintf(stderr, "cannot write %s\n", dest); else |