aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/read.c
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@openbsd.org>2014-10-18 15:57:34 +0000
committerIngo Schwarze <schwarze@openbsd.org>2014-10-18 15:57:34 +0000
commit867ec9d5be8ed8f6d221a1f9689d54aaaf811f22 (patch)
treefd4ede39a3121482ee7e1acbc3025652c8699cd8 /read.c
parent3b2a0945b5ed108c60a317a21b84e4da6b52b312 (diff)
downloadmandoc-867ec9d5be8ed8f6d221a1f9689d54aaaf811f22.tar.gz
mandoc-867ec9d5be8ed8f6d221a1f9689d54aaaf811f22.tar.zst
mandoc-867ec9d5be8ed8f6d221a1f9689d54aaaf811f22.zip
plug file descriptor leaks on read or write failure;
hinted at by Steffen Nurpmeso <sdaoden at yandex dot com>.
Diffstat (limited to 'read.c')
-rw-r--r--read.c22
1 files changed, 10 insertions, 12 deletions
diff --git a/read.c b/read.c
index 4a0ee101..1bcc8cac 100644
--- a/read.c
+++ b/read.c
@@ -1,4 +1,4 @@
-/* $Id: read.c,v 1.90 2014/10/12 19:31:41 schwarze Exp $ */
+/* $Id: read.c,v 1.91 2014/10/18 15:57:34 schwarze Exp $ */
/*
* Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
* Copyright (c) 2010-2014 Ingo Schwarze <schwarze@openbsd.org>
@@ -768,7 +768,7 @@ mparse_readfd(struct mparse *curp, int fd, const char *file)
(*curp->mmsg)(MANDOCERR_SYSOPEN,
curp->file_status,
file, 0, 0, strerror(errno));
- goto out;
+ return(curp->file_status);
}
/*
@@ -778,21 +778,19 @@ mparse_readfd(struct mparse *curp, int fd, const char *file)
* the parse phase for the file.
*/
- if ( ! read_whole_file(curp, file, fd, &blk, &with_mmap))
- goto out;
-
- mparse_parse_buffer(curp, blk, file);
-
+ if (read_whole_file(curp, file, fd, &blk, &with_mmap)) {
+ mparse_parse_buffer(curp, blk, file);
#if HAVE_MMAP
- if (with_mmap)
- munmap(blk.buf, blk.sz);
- else
+ if (with_mmap)
+ munmap(blk.buf, blk.sz);
+ else
#endif
- free(blk.buf);
+ free(blk.buf);
+ }
if (STDIN_FILENO != fd && -1 == close(fd))
perror(file);
-out:
+
return(curp->file_status);
}