diff options
author | mav <mav@FreeBSD.org> | 2010-07-19 02:26:59 +0000 |
---|---|---|
committer | mav <mav@FreeBSD.org> | 2010-07-19 02:26:59 +0000 |
commit | f0bb2087cfa819034fd0bd3586acc599fe3d4672 (patch) | |
tree | 6daa1d2ca33b3b058150048305e61e1ad69c6c4c /usr.bin/systat | |
parent | 2408918606e89f8cab79b07feaa6da0cef14fd1a (diff) | |
download | FreeBSD-src-f0bb2087cfa819034fd0bd3586acc599fe3d4672.zip FreeBSD-src-f0bb2087cfa819034fd0bd3586acc599fe3d4672.tar.gz |
Partially revert r209312, restoring ability to fit "stray irqX" names into
into available 10 characters by dropping "irq" in the middle of string.
Diffstat (limited to 'usr.bin/systat')
-rw-r--r-- | usr.bin/systat/vmstat.c | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/usr.bin/systat/vmstat.c b/usr.bin/systat/vmstat.c index 2985403..f5e8324 100644 --- a/usr.bin/systat/vmstat.c +++ b/usr.bin/systat/vmstat.c @@ -259,18 +259,22 @@ initkre(void) cp1 = cp1 + 2; cp2 = strdup(cp); bcopy(cp1, cp, sz - (cp1 - cp) + 1); - /* If line is long - drop "irq", - if too long - drop "irqN". */ - if (sz <= 10 + 1) { - strcat(cp, " "); - strcat(cp, cp2); - } else if (sz <= 10 + 4) { + if (sz <= 10 + 4) { strcat(cp, " "); strcat(cp, cp2 + 3); } free(cp2); } } + + /* + * Convert "name irqN" to "name N" if the former is + * longer than the field width. + */ + if ((cp1 = strstr(cp, "irq")) != NULL && + strlen(cp) > 10) + bcopy(cp1 + 3, cp1, strlen(cp1 + 3) + 1); + intrname[i] = cp; cp = nextcp; } |