top: with new 'X' command, WCHAN becomes fixed-width
This 'Sleeping in function' field was made variable width because the length of current kernel symbols usually exceeded the former top's 9 character limit. As a variable width field it would steal valuable horizontal display positions from other, more likely, displayed fields such as COMMAND or CGROUPS. With the advent of the new 'X' toggle, no fixed-width non-scalable field need suffer permanent truncation. Thus, WCHAN is being made fixed width with a default size of 10 characters. Signed-off-by: Jim Warner <james.warner@comcast.net> top/top.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-)
This commit is contained in:
parent
bbf8e44fb4
commit
7557f3f754
11
top/top.1
11
top/top.1
@ -718,13 +718,6 @@ By displaying this field, \*(We's own working set could be increased by over
|
|||||||
Should that occur, your only means of reducing that overhead will be to stop
|
Should that occur, your only means of reducing that overhead will be to stop
|
||||||
and restart \*(We.
|
and restart \*(We.
|
||||||
|
|
||||||
\*(NT The 'WCHAN' field, unlike most columns, is not fixed-width.
|
|
||||||
When displayed, it plus any other variable width columns will be allocated
|
|
||||||
all remaining screen width (up to the maximum \*(WX characters).
|
|
||||||
Even so, such variable width fields could still suffer truncation.
|
|
||||||
\*(XT 5c. SCROLLING a Window for additional information on accessing
|
|
||||||
any truncated data.
|
|
||||||
|
|
||||||
.TP 4
|
.TP 4
|
||||||
37.\fB nDRT \*(Em Dirty Pages Count \fR
|
37.\fB nDRT \*(Em Dirty Pages Count \fR
|
||||||
The number of pages that have been modified since they were last
|
The number of pages that have been modified since they were last
|
||||||
@ -973,8 +966,8 @@ by a '+' in the last position.
|
|||||||
This \*(CI can be used to alter the widths for the following fields:
|
This \*(CI can be used to alter the widths for the following fields:
|
||||||
|
|
||||||
.Bd -literal
|
.Bd -literal
|
||||||
\fI field default field default \fR
|
\fI field default field default field default \fR
|
||||||
GID 5 GROUP 8
|
GID 5 GROUP 8 WCHAN 10
|
||||||
RUID 5 RUSER 8
|
RUID 5 RUSER 8
|
||||||
SUID 5 SUSER 8
|
SUID 5 SUSER 8
|
||||||
UID 5 USER 8
|
UID 5 USER 8
|
||||||
|
@ -1382,7 +1382,7 @@ static FLD_t Fieldstab[] = {
|
|||||||
{ 4, SK_no, A_right, SF(DRT), L_statm },
|
{ 4, SK_no, A_right, SF(DRT), L_statm },
|
||||||
{ 1, -1, A_right, SF(STA), L_EITHER },
|
{ 1, -1, A_right, SF(STA), L_EITHER },
|
||||||
{ -1, -1, A_left, SF(CMD), L_EITHER },
|
{ -1, -1, A_left, SF(CMD), L_EITHER },
|
||||||
{ -1, -1, A_left, SF(WCH), L_stat },
|
{ 10, -1, A_left, SF(WCH), L_stat },
|
||||||
{ 8, -1, A_left, SF(FLG), L_stat },
|
{ 8, -1, A_left, SF(FLG), L_stat },
|
||||||
{ -1, -1, A_left, SF(CGR), L_CGROUP },
|
{ -1, -1, A_left, SF(CGR), L_CGROUP },
|
||||||
{ -1, -1, A_left, SF(SGD), L_status },
|
{ -1, -1, A_left, SF(SGD), L_status },
|
||||||
@ -1901,6 +1901,8 @@ static void zap_fieldstab (void) {
|
|||||||
= Rc.fixed_widest ? 8 + Rc.fixed_widest : 8;
|
= Rc.fixed_widest ? 8 + Rc.fixed_widest : 8;
|
||||||
Fieldstab[P_TTY].width
|
Fieldstab[P_TTY].width
|
||||||
= Rc.fixed_widest ? 8 + Rc.fixed_widest : 8;
|
= Rc.fixed_widest ? 8 + Rc.fixed_widest : 8;
|
||||||
|
Fieldstab[P_WCH].width
|
||||||
|
= Rc.fixed_widest ? 10 + Rc.fixed_widest : 10;
|
||||||
|
|
||||||
// lastly, ensure we've got proper column headers...
|
// lastly, ensure we've got proper column headers...
|
||||||
calibrate_fields();
|
calibrate_fields();
|
||||||
@ -3955,7 +3957,7 @@ static const char *task_show (const WIN_t *q, const proc_t *p) {
|
|||||||
u = hex_make(p->wchan, 0);
|
u = hex_make(p->wchan, 0);
|
||||||
else
|
else
|
||||||
u = lookup_wchan(p->wchan, p->tid);
|
u = lookup_wchan(p->wchan, p->tid);
|
||||||
makeVAR(u);
|
cp = make_str(u, W, Js);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default: // keep gcc happy
|
default: // keep gcc happy
|
||||||
|
Loading…
Reference in New Issue
Block a user