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:
Jim Warner 2012-09-25 02:02:02 -05:00 committed by Craig Small
parent bbf8e44fb4
commit 7557f3f754
2 changed files with 6 additions and 11 deletions

View File

@ -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

View File

@ -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