From 867ec9d5be8ed8f6d221a1f9689d54aaaf811f22 Mon Sep 17 00:00:00 2001 From: Ingo Schwarze Date: Sat, 18 Oct 2014 15:57:34 +0000 Subject: plug file descriptor leaks on read or write failure; hinted at by Steffen Nurpmeso . --- main.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) (limited to 'main.c') diff --git a/main.c b/main.c index 620cd6c1..f6597b84 100644 --- a/main.c +++ b/main.c @@ -1,4 +1,4 @@ -/* $Id: main.c,v 1.192 2014/09/03 23:21:47 schwarze Exp $ */ +/* $Id: main.c,v 1.193 2014/10/18 15:57:34 schwarze Exp $ */ /* * Copyright (c) 2008-2012 Kristaps Dzonsons * Copyright (c) 2010, 2011, 2012, 2014 Ingo Schwarze @@ -581,14 +581,15 @@ passthrough(const char *file, int fd) for (off = 0; off < nr; off += nw) if ((nw = write(STDOUT_FILENO, buf + off, (size_t)(nr - off))) == -1 || nw == 0) { + close(fd); syscall = "write"; goto fail; } - if (nr == 0) { - close(fd); + close(fd); + + if (nr == 0) return(MANDOCLEVEL_OK); - } syscall = "read"; fail: -- cgit v1.2.3-56-ge451