From eef0c8c5903576a37de14fe1d11340fffc1badfd Mon Sep 17 00:00:00 2001 From: Jim Warner Date: Wed, 15 Jun 2022 00:00:00 -0500 Subject: [PATCH] top: modify 'focus' strv function to display 'n/a' too <=== port of newlib fc3ba30a ______________________________ original newlib message This commit just brings that 'bot_focus_strv' function up to the same standard as the vanilla 'bot_focus_str' guy. Namely, if there is no cmdline or environ for any process, that bottom window will now display an 'n/a'. [ with the nature of those string vectors, it wasn't ] [ the same simple process found for regular strings. ] Signed-off-by: Jim Warner --- top/top.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/top/top.c b/top/top.c index 5a145707..1d6ea6c0 100644 --- a/top/top.c +++ b/top/top.c @@ -5165,9 +5165,11 @@ static int bot_focus_strv (const char *hdr, const char **strv) { if (strv) { // we're a little careless with overhead here (it's a one time cost) memset(Bot_buf, '\0', sizeof(Bot_buf)); - n = (void*)&strv[0] - (void*)strv[0]; + n = (char*)&strv[0] - strv[0]; if (n >= sizeof(Bot_buf)) n = sizeof(Bot_buf) - 1; memcpy(Bot_buf, strv[0], n); + if (!Bot_buf[0] || (!strcmp(Bot_buf, "-") && n <= sizeof(char*))) + strcpy(Bot_buf, "n/a"); for (nsav= 0, p = Bot_buf; strv[nsav] != NULL; nsav++) { p += strlen(strv[nsav]) + 1; if ((p - Bot_buf) >= sizeof(Bot_buf))