top: enhanced 'scale_tics' function for Ctrl-E scaling

When scale_tics was refactored and then Ctrl-E support
added to top, the complete range of scaling values was
not visible. Namely, a single 'd' (days) & 'w' (weeks)
was never seen with ^E. With this commit they will be.

Reference(s):
. Mar, 2022 - introduced ^E tics scaling
commit 402bf1903b25ac78b0c4cbf63d457feee78a391c
. Mar, 2022 - refactored scale_tics
commit 71eb90c1b27ef039ccc90f6060406099df45eade

Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
Jim Warner 2022-03-06 00:00:00 -06:00 committed by Craig Small
parent 81df85a1b5
commit e4e7991a26

View File

@ -1633,8 +1633,10 @@ end_justifies:
#define TICS_AS_SECS 0 #define TICS_AS_SECS 0
#define TICS_AS_MINS 1 #define TICS_AS_MINS 1
#define TICS_AS_HOUR 2 #define TICS_AS_HOUR 2
#define TICS_AS_DAYS 3 #define TICS_AS_DAY1 3
#define TICS_AS_WEEK 4 #define TICS_AS_DAY2 4
#define TICS_AS_WEEK 5
#define TICS_AS_LAST 6
/* /*
* Do some scaling stuff. * Do some scaling stuff.
@ -1719,7 +1721,7 @@ static const char *scale_tics (TIC_t tics, int width, int justr, int target) {
if (width >= snprintf(buf, sizeof(buf), "%lu,%02lu", hour, mins % 60)) if (width >= snprintf(buf, sizeof(buf), "%lu,%02lu", hour, mins % 60))
goto end_justifies; goto end_justifies;
} }
case TICS_AS_DAYS: // fall through case TICS_AS_DAY1: // fall through
if (days < ddLIMIT + 1) { if (days < ddLIMIT + 1) {
if (width >= snprintf(buf, sizeof(buf), DD "+" HH, days, hour % 24)) if (width >= snprintf(buf, sizeof(buf), DD "+" HH, days, hour % 24))
goto end_justifies; goto end_justifies;
@ -1727,6 +1729,7 @@ static const char *scale_tics (TIC_t tics, int width, int justr, int target) {
if (width >= snprintf(buf, sizeof(buf), DD "+%lu", days, hour % 24)) if (width >= snprintf(buf, sizeof(buf), DD "+%lu", days, hour % 24))
goto end_justifies; goto end_justifies;
#endif #endif
case TICS_AS_DAY2: // fall through
if (width >= snprintf(buf, sizeof(buf), DD, days)) if (width >= snprintf(buf, sizeof(buf), DD, days))
goto end_justifies; goto end_justifies;
} }
@ -1737,6 +1740,7 @@ static const char *scale_tics (TIC_t tics, int width, int justr, int target) {
if (width >= snprintf(buf, sizeof(buf), WW "+%lu", week, days % 7)) if (width >= snprintf(buf, sizeof(buf), WW "+%lu", week, days % 7))
goto end_justifies; goto end_justifies;
#endif #endif
case TICS_AS_LAST: // fall through
if (width >= snprintf(buf, sizeof(buf), WW, week)) if (width >= snprintf(buf, sizeof(buf), WW, week))
goto end_justifies; goto end_justifies;
default: // fall through default: // fall through
@ -3884,7 +3888,7 @@ static const char *configs_file (FILE *fp, const char *name, float *delay) {
Rc.task_mscale = 0; Rc.task_mscale = 0;
if (Rc.zero_suppress < 0 || Rc.zero_suppress > 1) if (Rc.zero_suppress < 0 || Rc.zero_suppress > 1)
Rc.zero_suppress = 0; Rc.zero_suppress = 0;
if (Rc.tics_scaled < 0 || Rc.tics_scaled > TICS_AS_WEEK) if (Rc.tics_scaled < 0 || Rc.tics_scaled > TICS_AS_LAST)
Rc.tics_scaled = 0; Rc.tics_scaled = 0;
// prepare to warn that older top can no longer read rcfile ... // prepare to warn that older top can no longer read rcfile ...
@ -5156,7 +5160,7 @@ static void keys_global (int ch) {
case kbd_CtrlE: case kbd_CtrlE:
#ifndef SCALE_FORMER #ifndef SCALE_FORMER
Rc.tics_scaled++; Rc.tics_scaled++;
if (Rc.tics_scaled > TICS_AS_WEEK) if (Rc.tics_scaled > TICS_AS_LAST)
Rc.tics_scaled = 0; Rc.tics_scaled = 0;
#endif #endif
break; break;