From f85d9a2b95548eca7b61c0643185fa418a75d8c1 Mon Sep 17 00:00:00 2001 From: Craig Small Date: Sat, 14 May 2016 22:43:19 +1000 Subject: [PATCH] library: Remove dead branch in file2strvec A while loop used n >=0 A branch inside the loop had a test for n<0 That's never going to happen! So the branch must go. There is similiar code outside the branch. Yes, I miss pythons while else here. Also cleaned up the ***-awful indentation this function had. No wonder that branch lived for so long there. References: Coverity #99119 Signed-off-by: Craig Small --- proc/readproc.c | 52 +++++++++++++++++++++++-------------------------- 1 file changed, 24 insertions(+), 28 deletions(-) diff --git a/proc/readproc.c b/proc/readproc.c index 2e6a3025..728c85b5 100644 --- a/proc/readproc.c +++ b/proc/readproc.c @@ -624,42 +624,38 @@ static char** file2strvec(const char* directory, const char* what) { sprintf(buf, "%s/%s", directory, what); fd = open(buf, O_RDONLY, 0); - if(fd==-1) return NULL; + if(fd==-1) + return NULL; /* read whole file into a memory buffer, allocating as we go */ while ((n = read(fd, buf, sizeof buf - 1)) >= 0) { - if (n < (int)(sizeof buf - 1)) - end_of_file = 1; - if (n == 0 && rbuf == 0) { - close(fd); - return NULL; /* process died between our open and read */ - } - if (n < 0) { - if (rbuf) - free(rbuf); - close(fd); - return NULL; /* read error */ - } - if (end_of_file && (n == 0 || buf[n-1]))/* last read char not null */ - buf[n++] = '\0'; /* so append null-terminator */ - rbuf = xrealloc(rbuf, tot + n); /* allocate more memory */ - memcpy(rbuf + tot, buf, n); /* copy buffer into it */ - tot += n; /* increment total byte ctr */ - if (end_of_file) - break; + if (n < (int)(sizeof buf - 1)) + end_of_file = 1; + if (n == 0 && rbuf == 0) { + close(fd); + return NULL; /* process died between our open and read */ + } + if (end_of_file && (n == 0 || buf[n-1]))/* last read char not null */ + buf[n++] = '\0'; /* so append null-terminator */ + rbuf = xrealloc(rbuf, tot + n); /* allocate more memory */ + memcpy(rbuf + tot, buf, n); /* copy buffer into it */ + tot += n; /* increment total byte ctr */ + if (end_of_file) + break; } close(fd); if (n <= 0 && !end_of_file) { - if (rbuf) free(rbuf); - return NULL; /* read error */ + if (rbuf) + free(rbuf); + return NULL; /* read error */ } endbuf = rbuf + tot; /* count space for pointers */ align = (sizeof(char*)-1) - ((tot + sizeof(char*)-1) & (sizeof(char*)-1)); for (c = 0, p = rbuf; p < endbuf; p++) { - if (!*p || *p == '\n') - c += sizeof(char*); - if (*p == '\n') - *p = 0; + if (!*p || *p == '\n') + c += sizeof(char*); + if (*p == '\n') + *p = 0; } c += sizeof(char*); /* one extra for NULL term */ @@ -669,8 +665,8 @@ static char** file2strvec(const char* directory, const char* what) { *q++ = p = rbuf; /* point ptrs to the strings */ endbuf--; /* do not traverse final NUL */ while (++p < endbuf) - if (!*p) /* NUL char implies that */ - *q++ = p+1; /* next string -> next char */ + if (!*p) /* NUL char implies that */ + *q++ = p+1; /* next string -> next char */ *q = 0; /* null ptr list terminator */ return ret; -- 2.40.0