top: avoid unrecognized 'Inspect' entries memory leaks

Upon startup there exists the potential for some minor
memory leakage should some rcfile 'Inspect' entries be
invalid. By delaying any malloc/strdup until after the
entries are completely validated we will prevent that.

Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
Jim Warner 2018-07-21 00:00:00 -05:00 committed by Craig Small
parent 11b87c73ed
commit 40dbd50056

View File

@ -3336,7 +3336,7 @@ static int config_insp (FILE *fp, char *buf, size_t size) {
#define nxtLINE { buf[0] = '\0'; continue; } #define nxtLINE { buf[0] = '\0'; continue; }
size_t lraw = strlen(Inspect.raw) +1; size_t lraw = strlen(Inspect.raw) +1;
int n, x; int n, x;
char *s; char *s1, *s2, *s3;
if (i < 0 || (size_t)i >= INT_MAX / sizeof(struct I_ent)) break; if (i < 0 || (size_t)i >= INT_MAX / sizeof(struct I_ent)) break;
if (lraw >= INT_MAX - size) break; if (lraw >= INT_MAX - size) break;
@ -3357,12 +3357,9 @@ static int config_insp (FILE *fp, char *buf, size_t size) {
Rc_questions = 1; Rc_questions = 1;
} }
} }
if (!(s = strtok(buf, "\t\n"))) { Rc_questions = 1; nxtLINE; } if (!(s1 = strtok(buf, "\t\n"))) { Rc_questions = 1; nxtLINE; }
iT(type) = alloc_s(s); if (!(s2 = strtok(NULL, "\t\n"))) { Rc_questions = 1; nxtLINE; }
if (!(s = strtok(NULL, "\t\n"))) { Rc_questions = 1; nxtLINE; } if (!(s3 = strtok(NULL, "\t\n"))) { Rc_questions = 1; nxtLINE; }
iT(name) = alloc_s(s);
if (!(s = strtok(NULL, "\t\n"))) { Rc_questions = 1; nxtLINE; }
iT(fmts) = alloc_s(s);
switch (toupper(buf[0])) { switch (toupper(buf[0])) {
case 'F': case 'F':
@ -3375,6 +3372,9 @@ static int config_insp (FILE *fp, char *buf, size_t size) {
Rc_questions = 1; Rc_questions = 1;
nxtLINE; nxtLINE;
} }
iT(type) = alloc_s(s1);
iT(name) = alloc_s(s2);
iT(fmts) = alloc_s(s3);
iT(farg) = (strstr(iT(fmts), "%d")) ? 1 : 0; iT(farg) = (strstr(iT(fmts), "%d")) ? 1 : 0;
iT(fstr) = alloc_c(FNDBUFSIZ); iT(fstr) = alloc_c(FNDBUFSIZ);
iT(flen) = 0; iT(flen) = 0;