top: treat all of those vertical scroll keys uniformly
When not displaying all tasks (the 'i' toggle is off), the concept of vertical scrolling has no real meaning. However, only 2 keys (up/down) impacting that vertical position were currently being disabled with this mode. This patch will extend such treatment to the following additional vertical impact keys: pgup,pgdn,home & end. Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
parent
19ec80bd41
commit
5705866fb6
20
top/top.c
20
top/top.c
@ -4694,7 +4694,7 @@ static void keys_window (int ch) {
|
|||||||
if (VIZCHKw(w)) if (CHKw(w, Show_IDLEPS) && 0 < w->begtask) w->begtask -= 1;
|
if (VIZCHKw(w)) if (CHKw(w, Show_IDLEPS) && 0 < w->begtask) w->begtask -= 1;
|
||||||
break;
|
break;
|
||||||
case kbd_DOWN:
|
case kbd_DOWN:
|
||||||
if (VIZCHKw(w)) if (CHKw(w, Show_IDLEPS) && (w->begtask < PIDSmaxt -1)) w->begtask += 1;
|
if (VIZCHKw(w)) if (CHKw(w, Show_IDLEPS) && (w->begtask < PIDSmaxt - 1)) w->begtask += 1;
|
||||||
break;
|
break;
|
||||||
#ifdef USE_X_COLHDR // ------------------------------------
|
#ifdef USE_X_COLHDR // ------------------------------------
|
||||||
case kbd_LEFT:
|
case kbd_LEFT:
|
||||||
@ -4762,34 +4762,40 @@ static void keys_window (int ch) {
|
|||||||
break;
|
break;
|
||||||
#endif // USE_X_COLHDR ------------------------------------
|
#endif // USE_X_COLHDR ------------------------------------
|
||||||
case kbd_PGUP:
|
case kbd_PGUP:
|
||||||
if (VIZCHKw(w)) if (0 < w->begtask) {
|
if (VIZCHKw(w)) {
|
||||||
|
if (CHKw(w, Show_IDLEPS) && 0 < w->begtask) {
|
||||||
w->begtask -= (w->winlines - 1);
|
w->begtask -= (w->winlines - 1);
|
||||||
if (0 > w->begtask) w->begtask = 0;
|
if (0 > w->begtask) w->begtask = 0;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case kbd_PGDN:
|
case kbd_PGDN:
|
||||||
if (VIZCHKw(w)) if (w->begtask < PIDSmaxt -1) {
|
if (VIZCHKw(w)) {
|
||||||
|
if (CHKw(w, Show_IDLEPS) && w->begtask < PIDSmaxt - 1) {
|
||||||
w->begtask += (w->winlines - 1);
|
w->begtask += (w->winlines - 1);
|
||||||
if (w->begtask > PIDSmaxt -1) w->begtask = PIDSmaxt -1;
|
if (w->begtask > PIDSmaxt - 1) w->begtask = PIDSmaxt - 1;
|
||||||
if (0 > w->begtask) w->begtask = 0;
|
if (0 > w->begtask) w->begtask = 0;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case kbd_HOME:
|
case kbd_HOME:
|
||||||
#ifndef SCROLLVAR_NO
|
#ifndef SCROLLVAR_NO
|
||||||
if (VIZCHKw(w)) w->begtask = w->begpflg = w->varcolbeg = 0;
|
if (VIZCHKw(w)) if (CHKw(w, Show_IDLEPS)) w->begtask = w->begpflg = w->varcolbeg = 0;
|
||||||
#else
|
#else
|
||||||
if (VIZCHKw(w)) w->begtask = w->begpflg = 0;
|
if (VIZCHKw(w)) if (CHKw(w, Show_IDLEPS)) w->begtask = w->begpflg = 0;
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
case kbd_END:
|
case kbd_END:
|
||||||
if (VIZCHKw(w)) {
|
if (VIZCHKw(w)) {
|
||||||
w->begtask = (PIDSmaxt - w->winlines) +1;
|
if (CHKw(w, Show_IDLEPS)) {
|
||||||
|
w->begtask = (PIDSmaxt - w->winlines) + 1;
|
||||||
if (0 > w->begtask) w->begtask = 0;
|
if (0 > w->begtask) w->begtask = 0;
|
||||||
w->begpflg = w->endpflg;
|
w->begpflg = w->endpflg;
|
||||||
#ifndef SCROLLVAR_NO
|
#ifndef SCROLLVAR_NO
|
||||||
w->varcolbeg = 0;
|
w->varcolbeg = 0;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
default: // keep gcc happy
|
default: // keep gcc happy
|
||||||
break;
|
break;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user