top: add a search capability
This commit is contained in:
parent
367b8bb616
commit
d6e6a9aa38
62
top.c
62
top.c
@ -2666,6 +2666,37 @@ static void file_writerc (void) {
|
|||||||
} // end: file_writerc
|
} // end: file_writerc
|
||||||
|
|
||||||
|
|
||||||
|
static void find_string (int ch) {
|
||||||
|
#define reDUX (found) ? "another " : ""
|
||||||
|
static char str[SCREENMAX];
|
||||||
|
static int found;
|
||||||
|
char buf[ROWMINSIZ];
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if ('&' == ch && !str[0]) {
|
||||||
|
show_msg("Locate next inactive, use \"L\"");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if ('L' == ch) {
|
||||||
|
strcpy(str, linein("Locate string"));
|
||||||
|
found = 0;
|
||||||
|
}
|
||||||
|
if (str[0]) {
|
||||||
|
for (i = Curwin->begtask; i < Frame_maxtask; i++) {
|
||||||
|
task_show(Curwin, Curwin->ppt[i], buf);
|
||||||
|
if (strstr(buf, str)) {
|
||||||
|
found = 1;
|
||||||
|
if (i == Curwin->begtask) continue;
|
||||||
|
Curwin->begtask = i;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
show_msg(fmtmk("%s\"%s\" not found", reDUX, str));
|
||||||
|
}
|
||||||
|
#undef reDUX
|
||||||
|
} // end: find_string
|
||||||
|
|
||||||
|
|
||||||
static void help_view (void) {
|
static void help_view (void) {
|
||||||
WIN_t *w = Curwin; // avoid gcc bloat with a local copy
|
WIN_t *w = Curwin; // avoid gcc bloat with a local copy
|
||||||
char ch;
|
char ch;
|
||||||
@ -2962,6 +2993,14 @@ static void keys_window (int ch) {
|
|||||||
case '_':
|
case '_':
|
||||||
if (ALTCHKw) wins_reflag(Flags_TOG, Show_TASKON);
|
if (ALTCHKw) wins_reflag(Flags_TOG, Show_TASKON);
|
||||||
break;
|
break;
|
||||||
|
case '&':
|
||||||
|
case 'L':
|
||||||
|
if (VIZCHKw(w)) { // ( next 2 are strictly for the UI )
|
||||||
|
SETw(w, Show_IDLEPS); // make sure we're showing idle tasks
|
||||||
|
w->usrseltyp = 0; // make sure we're not user filtering
|
||||||
|
find_string(ch); // ( we'll search entire ppt anyway )
|
||||||
|
}
|
||||||
|
break;
|
||||||
case 'A':
|
case 'A':
|
||||||
Rc.mode_altscr = !Rc.mode_altscr;
|
Rc.mode_altscr = !Rc.mode_altscr;
|
||||||
break;
|
break;
|
||||||
@ -3157,7 +3196,7 @@ static void do_key (int ch) {
|
|||||||
{ '#', '<', '>', 'b', 'c', 'i', 'n', 'R', 'S'
|
{ '#', '<', '>', 'b', 'c', 'i', 'n', 'R', 'S'
|
||||||
, 'U', 'u', 'V', 'x', 'y', 'z' } },
|
, 'U', 'u', 'V', 'x', 'y', 'z' } },
|
||||||
{ keys_window,
|
{ keys_window,
|
||||||
{ '+', '-', '=', '_', 'A', 'a', 'G', 'w'
|
{ '+', '-', '=', '_', '&', 'A', 'a', 'G', 'L', 'w'
|
||||||
, kbd_UP, kbd_DOWN, kbd_LEFT, kbd_RIGHT, kbd_PGUP, kbd_PGDN
|
, kbd_UP, kbd_DOWN, kbd_LEFT, kbd_RIGHT, kbd_PGUP, kbd_PGDN
|
||||||
, kbd_HOME, kbd_END } },
|
, kbd_HOME, kbd_END } },
|
||||||
{ keys_xtra,
|
{ keys_xtra,
|
||||||
@ -3340,8 +3379,9 @@ static void summary_show (void) {
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Display information for a single task row. */
|
* Build the information for a single task row and
|
||||||
static void task_show (const WIN_t *q, const proc_t *p) {
|
* display the results or return them to the caller. */
|
||||||
|
static void task_show (const WIN_t *q, const proc_t *p, char *ptr) {
|
||||||
#define makeCOL(va...) snprintf(cbuf, sizeof(cbuf), f, ## va)
|
#define makeCOL(va...) snprintf(cbuf, sizeof(cbuf), f, ## va)
|
||||||
#define makeVAR(v) { f = VARCOL_fmts; makeCOL(q->varcolsz, q->varcolsz, v); }
|
#define makeVAR(v) { f = VARCOL_fmts; makeCOL(q->varcolsz, q->varcolsz, v); }
|
||||||
#define pages2K(n) (unsigned long)( (n) << Pg2K_shft )
|
#define pages2K(n) (unsigned long)( (n) << Pg2K_shft )
|
||||||
@ -3364,6 +3404,7 @@ static void task_show (const WIN_t *q, const proc_t *p) {
|
|||||||
// these 2 aren't real procflgs, they're used in column highlighting!
|
// these 2 aren't real procflgs, they're used in column highlighting!
|
||||||
case X_XON:
|
case X_XON:
|
||||||
case X_XOF:
|
case X_XOF:
|
||||||
|
if (ptr) continue;
|
||||||
/* treat running tasks specially - entire row may get highlighted
|
/* treat running tasks specially - entire row may get highlighted
|
||||||
so we needn't turn it on and we MUST NOT turn it off */
|
so we needn't turn it on and we MUST NOT turn it off */
|
||||||
if (!('R' == p->state && CHKw(q, Show_HIROWS)))
|
if (!('R' == p->state && CHKw(q, Show_HIROWS)))
|
||||||
@ -3527,10 +3568,13 @@ static void task_show (const WIN_t *q, const proc_t *p) {
|
|||||||
rp = scat(rp, cbuf);
|
rp = scat(rp, cbuf);
|
||||||
} // end: for 'maxpflgs'
|
} // end: for 'maxpflgs'
|
||||||
|
|
||||||
PUFF("\n%s%s%s", (CHKw(q, Show_HIROWS) && 'R' == p->state)
|
if (ptr)
|
||||||
? q->capclr_rowhigh : q->capclr_rownorm
|
strcpy(ptr, rbuf);
|
||||||
, rbuf
|
else
|
||||||
, q->eolcap);
|
PUFF("\n%s%s%s", (CHKw(q, Show_HIROWS) && 'R' == p->state)
|
||||||
|
? q->capclr_rowhigh : q->capclr_rownorm
|
||||||
|
, rbuf
|
||||||
|
, q->eolcap);
|
||||||
#undef makeCOL
|
#undef makeCOL
|
||||||
#undef makeVAR
|
#undef makeVAR
|
||||||
#undef pages2K
|
#undef pages2K
|
||||||
@ -3570,14 +3614,14 @@ static int window_show (WIN_t *q, int wmax) {
|
|||||||
checking some stuff with each iteration and check it just once... */
|
checking some stuff with each iteration and check it just once... */
|
||||||
if (CHKw(q, Show_IDLEPS) && !q->usrseltyp)
|
if (CHKw(q, Show_IDLEPS) && !q->usrseltyp)
|
||||||
while (i < Frame_maxtask && lwin < wmax) {
|
while (i < Frame_maxtask && lwin < wmax) {
|
||||||
task_show(q, q->ppt[i++]);
|
task_show(q, q->ppt[i++], NULL);
|
||||||
++lwin;
|
++lwin;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
while (i < Frame_maxtask && lwin < wmax) {
|
while (i < Frame_maxtask && lwin < wmax) {
|
||||||
if ((CHKw(q, Show_IDLEPS) || isBUSY(q->ppt[i]))
|
if ((CHKw(q, Show_IDLEPS) || isBUSY(q->ppt[i]))
|
||||||
&& user_matched(q, q->ppt[i])) {
|
&& user_matched(q, q->ppt[i])) {
|
||||||
task_show(q, q->ppt[i]);
|
task_show(q, q->ppt[i], NULL);
|
||||||
++lwin;
|
++lwin;
|
||||||
}
|
}
|
||||||
++i;
|
++i;
|
||||||
|
8
top.h
8
top.h
@ -511,7 +511,7 @@ typedef struct WIN_t {
|
|||||||
" 1,I Toggle SMP view: '~11~2' single/separate states; '~1I~2' Irix/Solaris mode\n" \
|
" 1,I Toggle SMP view: '~11~2' single/separate states; '~1I~2' Irix/Solaris mode\n" \
|
||||||
" f,F Manage Fields: add/remove; change order; select sort field\n" \
|
" f,F Manage Fields: add/remove; change order; select sort field\n" \
|
||||||
"\n" \
|
"\n" \
|
||||||
" <,> . Move sort field: '~1<~2' next col left; '~1>~2' next col right\n" \
|
" L,&,<,> . Locate: '~1L~2'/'~1&~2' find/again; Move sort column: '~1<~2'/'~1>~2' left/right\n" \
|
||||||
" R,H,V . Toggle: '~1R~2' norm/rev sort; '~1H~2' show threads; '~1V~2' forest view\n" \
|
" R,H,V . Toggle: '~1R~2' norm/rev sort; '~1H~2' show threads; '~1V~2' forest view\n" \
|
||||||
" c,i,S . Toggle: '~1c~2' cmd name/line; '~1i~2' idle tasks; '~1S~2' cumulative time\n" \
|
" c,i,S . Toggle: '~1c~2' cmd name/line; '~1i~2' idle tasks; '~1S~2' cumulative time\n" \
|
||||||
" x~5,~1y~5 . Toggle highlights: '~1x~2' sort field; '~1y~2' running tasks\n" \
|
" x~5,~1y~5 . Toggle highlights: '~1x~2' sort field; '~1y~2' running tasks\n" \
|
||||||
@ -614,7 +614,8 @@ typedef struct WIN_t {
|
|||||||
|
|
||||||
/*###### Some Prototypes (ha!) #########################################*/
|
/*###### Some Prototypes (ha!) #########################################*/
|
||||||
|
|
||||||
/* These 'prototypes' are here solely for documentation purposes */
|
/* These 'prototypes' are here mostly for documentation purposes -- */
|
||||||
|
/* for now, the only essential one is task_show needed by find_string */
|
||||||
/*------ Sort callbacks ------------------------------------------------*/
|
/*------ Sort callbacks ------------------------------------------------*/
|
||||||
/* for each possible field, in the form of: */
|
/* for each possible field, in the form of: */
|
||||||
/*atic int sort_P_XXX (const proc_t **P, const proc_t **Q); */
|
/*atic int sort_P_XXX (const proc_t **P, const proc_t **Q); */
|
||||||
@ -685,6 +686,7 @@ typedef struct WIN_t {
|
|||||||
//atic void wins_stage_2 (void);
|
//atic void wins_stage_2 (void);
|
||||||
/*------ Interactive Input support (do_key helpers) --------------------*/
|
/*------ Interactive Input support (do_key helpers) --------------------*/
|
||||||
//atic void file_writerc (void);
|
//atic void file_writerc (void);
|
||||||
|
//atic void find_string (int ch);
|
||||||
//atic void help_view (void);
|
//atic void help_view (void);
|
||||||
//atic void keys_global (int ch);
|
//atic void keys_global (int ch);
|
||||||
//atic void keys_summary (int ch);
|
//atic void keys_summary (int ch);
|
||||||
@ -699,7 +701,7 @@ typedef struct WIN_t {
|
|||||||
//atic void do_key (int ch);
|
//atic void do_key (int ch);
|
||||||
//atic void summaryhlp (CPU_t *cpu, const char *pfx);
|
//atic void summaryhlp (CPU_t *cpu, const char *pfx);
|
||||||
//atic void summary_show (void);
|
//atic void summary_show (void);
|
||||||
//atic void task_show (const WIN_t *q, const proc_t *p);
|
static void task_show (const WIN_t *q, const proc_t *p, char *ptr);
|
||||||
//atic int window_show (WIN_t *q, int wmax);
|
//atic int window_show (WIN_t *q, int wmax);
|
||||||
/*------ Entry point plus two ------------------------------------------*/
|
/*------ Entry point plus two ------------------------------------------*/
|
||||||
//atic void framehlp (int wix, int max);
|
//atic void framehlp (int wix, int max);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user