1st 3.0.5 patch: wide top display
This commit is contained in:
parent
2de91e85be
commit
e7017ab912
21
top.1
21
top.1
@ -265,7 +265,12 @@ acknowledge \*(Us's default settings ...
|
||||
.Rje
|
||||
|
||||
.PP
|
||||
Within the following categories, \*(Us's startup defaults are documented
|
||||
\*(NT the width of \*(Me's display will be limited to 512 positions.
|
||||
Displaying all fields requires a minimum of 160 characters.
|
||||
The remaining width could be used for the 'Command' column.
|
||||
|
||||
.PP
|
||||
Within the following categories, \*(Me's startup defaults are documented
|
||||
assuming no \*(CF, thus no user customizations.
|
||||
However, items shown with an \*(AS could be overridden through the\fB
|
||||
command line\fR \*(EM a subject soon to be dealt with.
|
||||
@ -595,8 +600,9 @@ screen width.
|
||||
.in +4
|
||||
\*(NT The 'Command' field/column is\fB unique\fR, in that \fRit is not
|
||||
fixed-width, like all other fields.
|
||||
When displayed, this column will be allocated \fBall remaining screen width\fR
|
||||
to provide for the potential growth of program names into command lines!
|
||||
When displayed, this column will be allocated \fBall remaining screen width\fR,
|
||||
up to the maximum 512 characters, so as to provide for the potential growth of
|
||||
program names into command lines!
|
||||
.in
|
||||
|
||||
.TP 3
|
||||
@ -942,8 +948,13 @@ affect the window's size, as all prior \*(TDs will have already been painted.
|
||||
You will be prompted to enter the number of tasks to display.
|
||||
The lessor of your number and available screen rows will be used.
|
||||
|
||||
This is the command that, when used in \*(AM, gives you precise control
|
||||
over the size of each currently visible \*(TD.
|
||||
When used in \*(AM, this is the command that gives you precise control over
|
||||
the size of each currently visible \*(TD, except for the very last.
|
||||
It will not affect the last window's size, as all prior \*(TDs will have
|
||||
already been painted.
|
||||
|
||||
\*(NT If you wish to increase the size of the last visible \*(TD when in \*(AM,
|
||||
simply decrease the size of the \*(TD(s) above it.
|
||||
|
||||
.PP
|
||||
.\" .........................
|
||||
|
38
top.c
38
top.c
@ -80,7 +80,6 @@ static char *Myname;
|
||||
|
||||
/* The Name of the local config file, dynamically constructed */
|
||||
static char RCfile [OURPATHSZ];
|
||||
|
||||
/* The run-time acquired page size */
|
||||
static int Page_size;
|
||||
#ifdef UGH_ITS_4_RH
|
||||
@ -871,9 +870,6 @@ static proc_t **refreshprocs (proc_t **table, int flags)
|
||||
{
|
||||
#define PTRsz sizeof(proc_t *) /* eyeball candy */
|
||||
#define ENTsz sizeof(proc_t)
|
||||
/* quick & dirty response to 2.5.xx RT */
|
||||
#define RTx(p) { if (-99 > p->priority) p->priority = -99; \
|
||||
if (+99 < p->priority) p->priority = +99; }
|
||||
static unsigned savmax = 0; /* first time, Bypass: (i) */
|
||||
proc_t *ptsk = (proc_t *)-1; /* first time, Force: (ii) */
|
||||
unsigned curmax = 0; /* every time (jeeze) */
|
||||
@ -893,7 +889,6 @@ static proc_t **refreshprocs (proc_t **table, int flags)
|
||||
table[curmax]->cmdline = NULL;
|
||||
}
|
||||
if (!(ptsk = readproc(PT, table[curmax]))) break;
|
||||
RTx(ptsk)
|
||||
++curmax;
|
||||
}
|
||||
|
||||
@ -902,11 +897,9 @@ static proc_t **refreshprocs (proc_t **table, int flags)
|
||||
/* realloc as we go, keeping 'table' ahead of 'currmax++' */
|
||||
table = alloc_r(table, (curmax + 1) * PTRsz);
|
||||
/* here, readproc will allocate the underlying proc_t stg */
|
||||
if ((ptsk = readproc(PT, NULL))) {
|
||||
RTx(ptsk)
|
||||
if ((ptsk = readproc(PT, NULL)))
|
||||
table[curmax++] = ptsk;
|
||||
}
|
||||
}
|
||||
closeproc(PT);
|
||||
|
||||
/* iii) Chunkless: make 'eot' entry, after possible extension */
|
||||
@ -922,7 +915,6 @@ static proc_t **refreshprocs (proc_t **table, int flags)
|
||||
|
||||
#undef PTRsz
|
||||
#undef ENTsz
|
||||
#undef RTx
|
||||
}
|
||||
|
||||
|
||||
@ -977,15 +969,15 @@ static void before (char *me)
|
||||
static void configs_read (void)
|
||||
{
|
||||
static const char err_rc[] = "bad rcfile, you should delete '%s'";
|
||||
char fbuf[RCFBUFSIZ];
|
||||
char fbuf[SMLBUFSIZ];
|
||||
FILE *fp;
|
||||
float delay = DEF_DELAY;
|
||||
char id;
|
||||
int i;
|
||||
|
||||
snprintf(RCfile, sizeof(RCfile), ".%src", Myname);
|
||||
if (getenv("HOME"))
|
||||
strcpy(RCfile, fmtmk("%s%c", getenv("HOME"), '/'));
|
||||
strcat(RCfile, fmtmk(".%src", Myname));
|
||||
snprintf(RCfile, sizeof(RCfile), "%s/.%src", getenv("HOME"), Myname);
|
||||
|
||||
fp = fopen(SYS_RCFILE, "r");
|
||||
if (fp) {
|
||||
@ -1277,7 +1269,7 @@ static void fields_reorder (void)
|
||||
putp(Cap_clr_scr);
|
||||
putp(Cap_curs_huge);
|
||||
display_fields(Curwin->fieldscur, FIELDS_xtra);
|
||||
do {
|
||||
for (;;) {
|
||||
show_special(fmtmk(FIELDS_current
|
||||
, Cap_home, Curwin->fieldscur, Curwin->grpname, prompt));
|
||||
chin(0, &c, 1);
|
||||
@ -1292,7 +1284,7 @@ static void fields_reorder (void)
|
||||
p[1] = c;
|
||||
}
|
||||
}
|
||||
} while (1);
|
||||
}
|
||||
putp(Cap_curs_norm);
|
||||
}
|
||||
|
||||
@ -1310,7 +1302,7 @@ static void fields_sort (void)
|
||||
x = i = Curwin->sortindx;
|
||||
putp(Cap_clr_scr);
|
||||
putp(Cap_curs_huge);
|
||||
do {
|
||||
for (;;) {
|
||||
p = phoney + i;
|
||||
*p = toupper(*p);
|
||||
display_fields(phoney, SORT_xtra);
|
||||
@ -1321,7 +1313,7 @@ static void fields_sort (void)
|
||||
if (i < 0 || i >= MAXTBL(Fieldstab)) break;
|
||||
*p = tolower(*p);
|
||||
x = i;
|
||||
} while (1);
|
||||
}
|
||||
if ((p = strchr(Curwin->fieldscur, x + 'a')))
|
||||
*p = x + 'A';
|
||||
Curwin->sortindx = x;
|
||||
@ -1340,7 +1332,7 @@ static void fields_toggle (void)
|
||||
|
||||
putp(Cap_clr_scr);
|
||||
putp(Cap_curs_huge);
|
||||
do {
|
||||
for (;;) {
|
||||
display_fields(Curwin->fieldscur, FIELDS_xtra);
|
||||
show_special(fmtmk(FIELDS_current
|
||||
, Cap_home, Curwin->fieldscur, Curwin->grpname, prompt));
|
||||
@ -1351,7 +1343,7 @@ static void fields_toggle (void)
|
||||
*p = i + 'a';
|
||||
else if ((p = strchr(Curwin->fieldscur, i + 'a')))
|
||||
*p = i + 'A';
|
||||
} while (1);
|
||||
}
|
||||
putp(Cap_curs_norm);
|
||||
}
|
||||
|
||||
@ -1623,6 +1615,9 @@ static void wins_resize (int dont_care_sig)
|
||||
Screen_cols = wz.ws_col;
|
||||
Screen_rows = wz.ws_row;
|
||||
}
|
||||
/* we might disappoint some folks (but they'll deserve it) */
|
||||
if (SCREENMAX < Screen_cols) Screen_cols = SCREENMAX;
|
||||
|
||||
w = Curwin;
|
||||
do {
|
||||
win_colsheads(w);
|
||||
@ -2049,6 +2044,9 @@ static void show_a_task (WIN_t *q, proc_t *task)
|
||||
MKCOL(q, i, a, &pad, cbuf, task->ppid);
|
||||
break;
|
||||
case P_PRI:
|
||||
/* quick & dirty response to 2.5.xx RT priority */
|
||||
if (-99 > task->priority) task->priority = -99;
|
||||
else if (+99 < task->priority) task->priority = +99;
|
||||
MKCOL(q, i, a, &pad, cbuf, (long)task->priority);
|
||||
break;
|
||||
case P_RES:
|
||||
@ -2739,7 +2737,7 @@ int main (int dont_care_argc, char **argv)
|
||||
signal(SIGCONT, wins_resize);
|
||||
signal(SIGWINCH, wins_resize);
|
||||
|
||||
do {
|
||||
for (;;) {
|
||||
struct timeval tv;
|
||||
fd_set fs;
|
||||
char c;
|
||||
@ -2761,7 +2759,7 @@ int main (int dont_care_argc, char **argv)
|
||||
&& 0 < chin(0, &c, 1))
|
||||
do_key((unsigned)c);
|
||||
}
|
||||
} while (1);
|
||||
}
|
||||
|
||||
/*
|
||||
(listen before we return, aren't you sort of sad for 'so_lets_see-em'?)
|
||||
|
26
top.h
26
top.h
@ -59,20 +59,22 @@
|
||||
|
||||
/* Miscellaneous buffer sizes with liberal values
|
||||
-- mostly just to pinpoint source code usage/dependancies */
|
||||
#define SCREENMAX 512
|
||||
/* the above might seem pretty stingy, until you consider that with every
|
||||
one of top's fields are displayed we're talking a 160 byte column header
|
||||
-- so this will provide for all fields plus a 350+ byte command line */
|
||||
#define PFLAGSSIZ 32
|
||||
#define CAPBUFSIZ 32
|
||||
#define CLRBUFSIZ 64
|
||||
#define GETBUFSIZ 32
|
||||
#define TNYBUFSIZ 32
|
||||
#define SMLBUFSIZ 256
|
||||
#define MEDBUFSIZ 512
|
||||
#define OURPATHSZ 1024
|
||||
#define STATBUFSZ 1024
|
||||
#define BIGBUFSIZ 2048
|
||||
#define RCFBUFSIZ SMLBUFSIZ
|
||||
#define USRNAMSIZ GETBUFSIZ
|
||||
/* colbufsz does NOT apply to command lines - that field uses rowbufsz */
|
||||
#define COLBUFSIZ SMLBUFSIZ + CLRBUFSIZ
|
||||
#define ROWBUFSIZ MEDBUFSIZ + CLRBUFSIZ
|
||||
#define ROWBUFSIZ SCREENMAX + CLRBUFSIZ
|
||||
|
||||
|
||||
/*###### Some Miscellaneous Macro definitions ##########################*/
|
||||
@ -169,16 +171,10 @@ typedef struct {
|
||||
calculations. It exists primarily for SMP support but serves
|
||||
all environments. */
|
||||
typedef struct {
|
||||
TICS_t u, /* ticks count as represented in /proc/stat */
|
||||
n, /* (not in the order of our display) */
|
||||
s,
|
||||
i,
|
||||
w;
|
||||
TICS_t u_sav, /* tics count in the order of our display */
|
||||
s_sav,
|
||||
n_sav,
|
||||
i_sav,
|
||||
w_sav;
|
||||
/* ticks count as represented in /proc/stat */
|
||||
TICS_t u, n, s, i, w;
|
||||
/* tics count in the order of our display */
|
||||
TICS_t u_sav, s_sav, n_sav, i_sav, w_sav;
|
||||
} CPUS_t;
|
||||
|
||||
/* The scaling 'type' used with scale_num() -- this is how
|
||||
@ -286,7 +282,7 @@ typedef struct win {
|
||||
char grpname [GRPNAMSIZ], /* window number:name, printable */
|
||||
winname [WINNAMSIZ], /* window name, user changeable */
|
||||
fieldscur [PFLAGSSIZ], /* fields displayed and ordered */
|
||||
columnhdr [SMLBUFSIZ], /* column headings for procflags */
|
||||
columnhdr [SCREENMAX], /* column headings for procflags */
|
||||
colusrnam [USRNAMSIZ]; /* if selected by the 'u' command */
|
||||
} WIN_t;
|
||||
/* ////////////////////////////////////////////////////////////// */
|
||||
|
Loading…
x
Reference in New Issue
Block a user