top: end reliance on strdup not failing & roll our own

Lately, top has begun to rely more and more on dynamic
memory allocations rather than the static buffers that
were found in many of its structures. This was perhaps
most evident in the increasing use of the strdup call.

This commit trades that function call for the internal
equivalent which will protect us from malloc failures.

(everything is perfectly justified plus right margins)
(are completely filled, but of course it must be luck)

Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
Jim Warner 2013-02-11 00:00:00 -06:00 committed by Craig Small
parent 44e61f0f6d
commit c856a80ad5
2 changed files with 14 additions and 7 deletions

View File

@ -890,6 +890,12 @@ static void *alloc_r (void *ptr, size_t num) {
} // end: alloc_r } // end: alloc_r
static char *alloc_s (const char *str) MALLOC;
static char *alloc_s (const char *str) {
return strcpy(alloc_c(strlen(str) +1), str);
} // end: alloc_s
/* /*
* This function is used in connection with raw single byte * This function is used in connection with raw single byte
* unsolicited keyboard input that's susceptible to SIGWINCH * unsolicited keyboard input that's susceptible to SIGWINCH
@ -3207,7 +3213,7 @@ static void configs_read (void) {
try_inspect_entries: try_inspect_entries:
// we'll start off Inspect stuff with 1 'potential' blank line // we'll start off Inspect stuff with 1 'potential' blank line
// ( only realized if we end up with Inspect.total > 0 ) // ( only realized if we end up with Inspect.total > 0 )
for (i = 0, Inspect.raw = strdup("\n");;) { for (i = 0, Inspect.raw = alloc_s("\n");;) {
#define iT(element) Inspect.tab[i].element #define iT(element) Inspect.tab[i].element
size_t lraw = strlen(Inspect.raw) +1; size_t lraw = strlen(Inspect.raw) +1;
char *s; char *s;
@ -3222,11 +3228,11 @@ try_inspect_entries:
p = fmtmk(N_fmt(YINSP_rcfile_fmt), i +1); p = fmtmk(N_fmt(YINSP_rcfile_fmt), i +1);
if (!(s = strtok(fbuf, "\t\n"))) { Rc_questions = 1; continue; } if (!(s = strtok(fbuf, "\t\n"))) { Rc_questions = 1; continue; }
iT(type) = strdup(s); iT(type) = alloc_s(s);
if (!(s = strtok(NULL, "\t\n"))) { Rc_questions = 1; continue; } if (!(s = strtok(NULL, "\t\n"))) { Rc_questions = 1; continue; }
iT(name) = strdup(s); iT(name) = alloc_s(s);
if (!(s = strtok(NULL, "\t\n"))) { Rc_questions = 1; continue; } if (!(s = strtok(NULL, "\t\n"))) { Rc_questions = 1; continue; }
iT(fmts) = strdup(s); iT(fmts) = alloc_s(s);
switch (toupper(fbuf[0])) { switch (toupper(fbuf[0])) {
case 'F': case 'F':
@ -3257,10 +3263,10 @@ try_inspect_entries:
Inspect.total = Inspect.demo = MAXTBL(sels); Inspect.total = Inspect.demo = MAXTBL(sels);
Inspect.tab = alloc_c(sizeof(struct I_ent) * Inspect.total); Inspect.tab = alloc_c(sizeof(struct I_ent) * Inspect.total);
for (i = 0; i < Inspect.total; i++) { for (i = 0; i < Inspect.total; i++) {
Inspect.tab[i].type = strdup(N_txt(YINSP_deqtyp_txt)); Inspect.tab[i].type = alloc_s(N_txt(YINSP_deqtyp_txt));
Inspect.tab[i].name = strdup(sels[i]); Inspect.tab[i].name = alloc_s(sels[i]);
Inspect.tab[i].func = insp_do_demo; Inspect.tab[i].func = insp_do_demo;
Inspect.tab[i].fmts = strdup(N_txt(YINSP_deqfmt_txt)); Inspect.tab[i].fmts = alloc_s(N_txt(YINSP_deqfmt_txt));
Inspect.tab[i].fstr = alloc_c(FNDBUFSIZ); Inspect.tab[i].fstr = alloc_c(FNDBUFSIZ);
} }
#undef mkS #undef mkS

View File

@ -631,6 +631,7 @@ typedef struct WIN_t {
/*------ Low Level Memory/Keyboard/File I/O support --------------------*/ /*------ Low Level Memory/Keyboard/File I/O support --------------------*/
//atic void *alloc_c (size_t num); //atic void *alloc_c (size_t num);
//atic void *alloc_r (void *ptr, size_t num); //atic void *alloc_r (void *ptr, size_t num);
//atic char *alloc_s (const char *str);
//atic inline int ioa (struct timespec *ts); //atic inline int ioa (struct timespec *ts);
//atic int ioch (int ech, char *buf, unsigned cnt); //atic int ioch (int ech, char *buf, unsigned cnt);
//atic int iokey (int init); //atic int iokey (int init);