top: minor refactor in preparation for other filtering
While it's only documented (so far) in commit text and
an occasional email I've tried to maintain some coding
standards primarily for reference/navigation purposes.
They also served, I felt, as useful mental challenges.
Someday I will get around to formerly documenting them
but in the meantime here are the ones for this commit:
. functions are grouped into logical (i hope) sections
. functions & sections are ordered to avoid prototypes
. function names are alphabetical within every section
Thus, given those constraints/objectives, and in order
to prepare for an upcoming Other_Filter feature, a few
things had to be renamed and rearranged. Plus a couple
of other (unrelated) tweaks were made for consistency.
(everything is perfectly justified plus right margins)
(are completely filled, but of course it must be luck)
Reference(s):
commit 270e8e7eeb
http://www.freelists.org/post/procps/PATCH-12-top-restore-terminal-state-on-exit,4
Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
parent
b9976f7056
commit
5e4bade595
116
top/top.c
116
top/top.c
@ -1335,7 +1335,7 @@ static const char *user_certify (WIN_t *q, const char *str, char typ) {
|
|||||||
* Determine if this proc_t matches the 'u/U' selection criteria
|
* Determine if this proc_t matches the 'u/U' selection criteria
|
||||||
* for a given window -- it's called from only one place, and
|
* for a given window -- it's called from only one place, and
|
||||||
* likely inlined even without the directive */
|
* likely inlined even without the directive */
|
||||||
static inline int user_matched (WIN_t *q, const proc_t *p) {
|
static inline int user_matched (const WIN_t *q, const proc_t *p) {
|
||||||
switch(q->usrseltyp) {
|
switch(q->usrseltyp) {
|
||||||
case 0: // uid selection inactive
|
case 0: // uid selection inactive
|
||||||
return 1;
|
return 1;
|
||||||
@ -3299,7 +3299,7 @@ static void configs_read (void) {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#ifndef USE_X_COLHDR
|
#ifndef USE_X_COLHDR
|
||||||
OFFw(w, NOHICOL_xxx);
|
OFFw(w, NOHIFND_xxx);
|
||||||
#endif
|
#endif
|
||||||
} // end: for (GROUPSMAX)
|
} // end: for (GROUPSMAX)
|
||||||
|
|
||||||
@ -3886,56 +3886,12 @@ static void wins_stage_2 (void) {
|
|||||||
#endif
|
#endif
|
||||||
} // end: wins_stage_2
|
} // end: wins_stage_2
|
||||||
|
|
||||||
/*###### Interactive Input support (do_key helpers) ####################*/
|
/*###### Interactive Input Tertiary support ############################*/
|
||||||
|
|
||||||
/*
|
|
||||||
* These routines exist just to keep the do_key() function
|
|
||||||
* a reasonably modest size. */
|
|
||||||
|
|
||||||
static void file_writerc (void) {
|
|
||||||
FILE *fp;
|
|
||||||
int i;
|
|
||||||
|
|
||||||
if (Rc_questions) {
|
|
||||||
show_pmt(N_txt(XTRA_warncfg_txt));
|
|
||||||
if ('y' != tolower(iokey(1)))
|
|
||||||
return;
|
|
||||||
Rc_questions = 0;
|
|
||||||
}
|
|
||||||
if (!(fp = fopen(Rc_name, "w"))) {
|
|
||||||
show_msg(fmtmk(N_fmt(FAIL_rc_open_fmt), Rc_name, strerror(errno)));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
fprintf(fp, "%s's " RCF_EYECATCHER, Myname);
|
|
||||||
fprintf(fp, "Id:%c, Mode_altscr=%d, Mode_irixps=%d, Delay_time=%d.%d, Curwin=%d\n"
|
|
||||||
, RCF_VERSION_ID
|
|
||||||
, Rc.mode_altscr, Rc.mode_irixps
|
|
||||||
// this may be ugly, but it keeps us locale independent...
|
|
||||||
, (int)Rc.delay_time, (int)((Rc.delay_time - (int)Rc.delay_time) * 1000)
|
|
||||||
, (int)(Curwin - Winstk));
|
|
||||||
|
|
||||||
for (i = 0 ; i < GROUPSMAX; i++) {
|
|
||||||
fprintf(fp, "%s\tfieldscur=%s\n"
|
|
||||||
, Winstk[i].rc.winname, Winstk[i].rc.fieldscur);
|
|
||||||
fprintf(fp, "\twinflags=%d, sortindx=%d, maxtasks=%d\n"
|
|
||||||
, Winstk[i].rc.winflags, Winstk[i].rc.sortindx
|
|
||||||
, Winstk[i].rc.maxtasks);
|
|
||||||
fprintf(fp, "\tsummclr=%d, msgsclr=%d, headclr=%d, taskclr=%d\n"
|
|
||||||
, Winstk[i].rc.summclr, Winstk[i].rc.msgsclr
|
|
||||||
, Winstk[i].rc.headclr, Winstk[i].rc.taskclr);
|
|
||||||
}
|
|
||||||
|
|
||||||
// any new addition(s) last, for older rcfiles compatibility...
|
|
||||||
fprintf(fp, "Fixed_widest=%d, Summ_mscale=%d, Task_mscale=%d, Zero_suppress=%d\n"
|
|
||||||
, Rc.fixed_widest, Rc.summ_mscale, Rc.task_mscale, Rc.zero_suppress);
|
|
||||||
|
|
||||||
if (Inspect.raw)
|
|
||||||
fputs(Inspect.raw, fp);
|
|
||||||
|
|
||||||
fclose(fp);
|
|
||||||
show_msg(fmtmk(N_fmt(WRITE_rcfile_fmt), Rc_name));
|
|
||||||
} // end: file_writerc
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This section exists so as to offer some function naming freedom
|
||||||
|
* while also maintaining the strict alphabetical order protocol
|
||||||
|
* within each section. */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This guy is a *Helper* function serving the following two masters:
|
* This guy is a *Helper* function serving the following two masters:
|
||||||
@ -3972,8 +3928,8 @@ static void find_string (int ch) {
|
|||||||
Curwin->findlen = strlen(Curwin->findstr);
|
Curwin->findlen = strlen(Curwin->findstr);
|
||||||
found = 0;
|
found = 0;
|
||||||
#ifndef USE_X_COLHDR
|
#ifndef USE_X_COLHDR
|
||||||
if (Curwin->findstr[0]) SETw(Curwin, NOHICOL_xxx);
|
if (Curwin->findstr[0]) SETw(Curwin, NOHIFND_xxx);
|
||||||
else OFFw(Curwin, NOHICOL_xxx);
|
else OFFw(Curwin, NOHIFND_xxx);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
if (Curwin->findstr[0]) {
|
if (Curwin->findstr[0]) {
|
||||||
@ -4039,6 +3995,56 @@ signify_that:
|
|||||||
} // end: help_view
|
} // end: help_view
|
||||||
|
|
||||||
|
|
||||||
|
static void write_rcfile (void) {
|
||||||
|
FILE *fp;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (Rc_questions) {
|
||||||
|
show_pmt(N_txt(XTRA_warncfg_txt));
|
||||||
|
if ('y' != tolower(iokey(1)))
|
||||||
|
return;
|
||||||
|
Rc_questions = 0;
|
||||||
|
}
|
||||||
|
if (!(fp = fopen(Rc_name, "w"))) {
|
||||||
|
show_msg(fmtmk(N_fmt(FAIL_rc_open_fmt), Rc_name, strerror(errno)));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
fprintf(fp, "%s's " RCF_EYECATCHER, Myname);
|
||||||
|
fprintf(fp, "Id:%c, Mode_altscr=%d, Mode_irixps=%d, Delay_time=%d.%d, Curwin=%d\n"
|
||||||
|
, RCF_VERSION_ID
|
||||||
|
, Rc.mode_altscr, Rc.mode_irixps
|
||||||
|
// this may be ugly, but it keeps us locale independent...
|
||||||
|
, (int)Rc.delay_time, (int)((Rc.delay_time - (int)Rc.delay_time) * 1000)
|
||||||
|
, (int)(Curwin - Winstk));
|
||||||
|
|
||||||
|
for (i = 0 ; i < GROUPSMAX; i++) {
|
||||||
|
fprintf(fp, "%s\tfieldscur=%s\n"
|
||||||
|
, Winstk[i].rc.winname, Winstk[i].rc.fieldscur);
|
||||||
|
fprintf(fp, "\twinflags=%d, sortindx=%d, maxtasks=%d\n"
|
||||||
|
, Winstk[i].rc.winflags, Winstk[i].rc.sortindx
|
||||||
|
, Winstk[i].rc.maxtasks);
|
||||||
|
fprintf(fp, "\tsummclr=%d, msgsclr=%d, headclr=%d, taskclr=%d\n"
|
||||||
|
, Winstk[i].rc.summclr, Winstk[i].rc.msgsclr
|
||||||
|
, Winstk[i].rc.headclr, Winstk[i].rc.taskclr);
|
||||||
|
}
|
||||||
|
|
||||||
|
// any new addition(s) last, for older rcfiles compatibility...
|
||||||
|
fprintf(fp, "Fixed_widest=%d, Summ_mscale=%d, Task_mscale=%d, Zero_suppress=%d\n"
|
||||||
|
, Rc.fixed_widest, Rc.summ_mscale, Rc.task_mscale, Rc.zero_suppress);
|
||||||
|
|
||||||
|
if (Inspect.raw)
|
||||||
|
fputs(Inspect.raw, fp);
|
||||||
|
|
||||||
|
fclose(fp);
|
||||||
|
show_msg(fmtmk(N_fmt(WRITE_rcfile_fmt), Rc_name));
|
||||||
|
} // end: write_rcfile
|
||||||
|
|
||||||
|
/*###### Interactive Input Secondary support (do_key helpers) ##########*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* These routines exist just to keep the do_key() function
|
||||||
|
* a reasonably modest size. */
|
||||||
|
|
||||||
static void keys_global (int ch) {
|
static void keys_global (int ch) {
|
||||||
WIN_t *w = Curwin; // avoid gcc bloat with a local copy
|
WIN_t *w = Curwin; // avoid gcc bloat with a local copy
|
||||||
|
|
||||||
@ -4628,7 +4634,7 @@ static void do_key (int ch) {
|
|||||||
case 'q': // no return from this guy
|
case 'q': // no return from this guy
|
||||||
bye_bye(NULL);
|
bye_bye(NULL);
|
||||||
case 'W': // no need for rebuilds
|
case 'W': // no need for rebuilds
|
||||||
file_writerc();
|
write_rcfile();
|
||||||
return;
|
return;
|
||||||
default: // and now, the real work...
|
default: // and now, the real work...
|
||||||
for (i = 0; i < MAXTBL(key_tab); ++i)
|
for (i = 0; i < MAXTBL(key_tab); ++i)
|
||||||
@ -4846,7 +4852,7 @@ static const char *task_show (const WIN_t *q, const proc_t *p) {
|
|||||||
case X_XON:
|
case X_XON:
|
||||||
case X_XOF:
|
case X_XOF:
|
||||||
cp = NULL;
|
cp = NULL;
|
||||||
if (!CHKw(q, INFINDS_xxx | NOHICOL_xxx)) {
|
if (!CHKw(q, INFINDS_xxx | NOHIFND_xxx)) {
|
||||||
/* 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)))
|
||||||
|
@ -307,7 +307,7 @@ typedef struct CPU_t {
|
|||||||
#define INFINDS_xxx 0x010000 // build rows for find_string, not display
|
#define INFINDS_xxx 0x010000 // build rows for find_string, not display
|
||||||
#define EQUWINS_xxx 0x000001 // rebalance all wins & tasks (off i,n,u/U)
|
#define EQUWINS_xxx 0x000001 // rebalance all wins & tasks (off i,n,u/U)
|
||||||
#ifndef USE_X_COLHDR
|
#ifndef USE_X_COLHDR
|
||||||
#define NOHICOL_xxx 0x100000 // must restrict Show_HICOLS temporarily
|
#define NOHIFND_xxx 0x100000 // must restrict Show_HICOLS temporarily
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Default flags if there's no rcfile to provide user customizations
|
// Default flags if there's no rcfile to provide user customizations
|
||||||
@ -656,7 +656,7 @@ typedef struct WIN_t {
|
|||||||
//atic int get_int (const char *prompt);
|
//atic int get_int (const char *prompt);
|
||||||
//atic inline const char *hex_make (KLONG num, int noz);
|
//atic inline const char *hex_make (KLONG num, int noz);
|
||||||
//atic const char *user_certify (WIN_t *q, const char *str, char typ);
|
//atic const char *user_certify (WIN_t *q, const char *str, char typ);
|
||||||
//atic inline int user_matched (WIN_t *q, const proc_t *p);
|
//atic inline int user_matched (const WIN_t *q, const proc_t *p);
|
||||||
/*------ Basic Formatting support --------------------------------------*/
|
/*------ Basic Formatting support --------------------------------------*/
|
||||||
//atic inline const char *justify_pad (const char *str, int width, int justr);
|
//atic inline const char *justify_pad (const char *str, int width, int justr);
|
||||||
//atic inline const char *make_chr (const char ch, int width, int justr);
|
//atic inline const char *make_chr (const char ch, int width, int justr);
|
||||||
@ -715,11 +715,12 @@ typedef struct WIN_t {
|
|||||||
//atic void wins_reflag (int what, int flg);
|
//atic void wins_reflag (int what, int flg);
|
||||||
//atic void wins_stage_1 (void);
|
//atic void wins_stage_1 (void);
|
||||||
//atic void wins_stage_2 (void);
|
//atic void wins_stage_2 (void);
|
||||||
/*------ Interactive Input support (do_key helpers) --------------------*/
|
/*------ Interactive Input Tertiary support ----------------------------*/
|
||||||
//atic void file_writerc (void);
|
|
||||||
//atic inline int find_ofs (const WIN_t *q, const char *buf);
|
//atic inline int find_ofs (const WIN_t *q, const char *buf);
|
||||||
//atic void find_string (int ch);
|
//atic void find_string (int ch);
|
||||||
//atic void help_view (void);
|
//atic void help_view (void);
|
||||||
|
//atic void write_rcfile (void);
|
||||||
|
/*------ Interactive Input Secondary support (do_key helpers) ----------*/
|
||||||
//atic void keys_global (int ch);
|
//atic void keys_global (int ch);
|
||||||
//atic void keys_summary (int ch);
|
//atic void keys_summary (int ch);
|
||||||
//atic void keys_task (int ch);
|
//atic void keys_task (int ch);
|
||||||
|
@ -19,9 +19,6 @@
|
|||||||
|
|
||||||
#include <locale.h>
|
#include <locale.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#ifdef VALIDATE_NLS
|
|
||||||
#include <stdlib.h>
|
|
||||||
#endif
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "../include/nls.h"
|
#include "../include/nls.h"
|
||||||
@ -29,6 +26,10 @@
|
|||||||
#include "top.h"
|
#include "top.h"
|
||||||
#include "top_nls.h"
|
#include "top_nls.h"
|
||||||
|
|
||||||
|
#ifdef VALIDATE_NLS
|
||||||
|
#include <stdlib.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
// Programmer Note(s):
|
// Programmer Note(s):
|
||||||
// Preparation ---------------------------------------------
|
// Preparation ---------------------------------------------
|
||||||
// Unless you have *something* following the gettext macro,
|
// Unless you have *something* following the gettext macro,
|
||||||
|
Loading…
Reference in New Issue
Block a user