From: Jim Warner Date: Fri, 23 Jul 2021 05:00:00 +0000 (-0500) Subject: top: make eu_TREE_LVL a signed int not an unsigned int X-Git-Tag: v4.0.0~164 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=8c2622aea814d13d3667a255fca48fe3c1db9503;p=procps-ng top: make eu_TREE_LVL a signed int not an unsigned int Since the internally kept nesting 'level' under forest view is limited to a maximum of 101, we will now treat it as signed to avoid any potential conversion issues. Signed-off-by: Jim Warner --- diff --git a/top/top.c b/top/top.c index 68fb23af..78b869cc 100644 --- a/top/top.c +++ b/top/top.c @@ -1702,7 +1702,7 @@ static struct { , { -1, -1, -1, PIDS_TIME_START } // ull_int ( if Show_FOREST, eu_TIME_START ) , { -1, -1, -1, PIDS_ID_FUID } // u_int ( if a usrseltyp, eu_ID_FUID ) , { -1, -1, -1, PIDS_extra } // s_ch ( if Show_FOREST, eu_TREE_HID ) - , { -1, -1, -1, PIDS_extra } // u_int ( if Show_FOREST, eu_TREE_LVL ) + , { -1, -1, -1, PIDS_extra } // s_int ( if Show_FOREST, eu_TREE_LVL ) , { -1, -1, -1, PIDS_extra } // u_int ( if Show_FOREST, eu_TREE_ADD ) #undef A_left #undef A_right @@ -4364,11 +4364,11 @@ static int Hide_tot; // total used in above array | * This little recursive guy was the real forest view workhorse. | * He fills in the Tree_ppt array and also sets the child indent | * level which is stored in an 'extra' result struct as a u_int. | */ -static void forest_adds (const int self, unsigned level) { +static void forest_adds (const int self, int level) { // tailored 'results stack value' extractor macros #define rSv(E,X) PID_VAL(E, s_int, Seed_ppt[X]) // if xtra-procps-debug.h active, can't use PID_VAL with assignment - #define rSv_Lvl Tree_ppt[Tree_idx]->head[eu_TREE_LVL].result.u_int + #define rSv_Lvl Tree_ppt[Tree_idx]->head[eu_TREE_LVL].result.s_int int i; if (Tree_idx < PIDSmaxt) { // immunize against insanity | @@ -4414,20 +4414,20 @@ static void forest_begin (WIN_t *q) { error_exit(fmtmk(N_fmt(LIB_errorpid_fmt),__LINE__, strerror(errno))); #endif for (i = 0; i < PIDSmaxt; i++) { // avoid hidepid distorts | - if (!PID_VAL(eu_TREE_LVL, u_int, Seed_ppt[i])) // parents lvl 0 | + if (!PID_VAL(eu_TREE_LVL, s_int, Seed_ppt[i])) // parents lvl 0 | forest_adds(i, 0); // add parents + children | } /* we use up to three additional 'PIDS_extra' results in our stack | eu_TREE_HID (s_ch) : where 'x' == collapsed & 'z' == unseen | - eu_TREE_LVL (u_int): where level number is stored (0 - 100) | + eu_TREE_LVL (s_int): where level number is stored (0 - 100) | eu_TREE_ADD (u_int): where a children's tics stored (maybe) | */ for (i = 0; i < Hide_tot; i++) { // if have xtra-procps-debug.h, cannpt use PID_VAL w/ assignment | #define rSv(E,T,X) Tree_ppt[X]->head[E].result.T #define rSv_Pid(X) rSv(EU_PID, s_int, X) - #define rSv_Lvl(X) rSv(eu_TREE_LVL, u_int, X) + #define rSv_Lvl(X) rSv(eu_TREE_LVL, s_int, X) #define rSv_Hid(X) rSv(eu_TREE_HID, s_ch, X) /* next 2 aren't needed if TREE_VCPUOFF but they cost us nothing | & the EU_CPU slot will now always be present (even if it's 0) | */ @@ -4439,7 +4439,7 @@ static void forest_begin (WIN_t *q) { if (rSv_Pid(j) == Hide_pid[i]) { int parent = j; int children = 0; - unsigned level = rSv_Lvl(parent); + int level = rSv_Lvl(parent); while (j+1 < PIDSmaxt && rSv_Lvl(j+1) > level) { ++j; rSv_Hid(j) = 'z'; @@ -4478,7 +4478,7 @@ static void forest_begin (WIN_t *q) { static inline const char *forest_colour (const WIN_t *q, struct pids_stack *p) { // tailored 'results stack value' extractor macros #define rSv(E) PID_VAL(E, str, p) - #define rSv_Lvl PID_VAL(eu_TREE_LVL, u_int, p) + #define rSv_Lvl PID_VAL(eu_TREE_LVL, s_int, p) #define rSv_Hid PID_VAL(eu_TREE_HID, s_ch, p) #ifndef SCROLLVAR_NO static char buf[1024*64*2]; // the same as libray's max buffer size @@ -5778,7 +5778,7 @@ static const char *task_show (const WIN_t *q, struct pids_stack *p) { /* we use up to three additional 'PIDS_extra' results in our stacks eu_TREE_HID (s_ch) : where 'x' == collapsed and 'z' == unseen - eu_TREE_LVL (u_int): where a level number is stored (0 - 100) + eu_TREE_LVL (s_int): where a level number is stored (0 - 100) eu_TREE_ADD (u_int): where children's tics are stored (maybe) */ #ifndef TREE_VWINALL if (q == Curwin) // note: the following is NOT indented