pmap - removing the column width constraints in the -X/-XX modes

This commit changes the width measurement principle in the -X/-XX
modes so that a width of totals is measured instead of the width
of summands. The value of totals is always higher than the value
of summands. That additionally prevents the totals from having
a wrong indentation.

This commit also removes the minimum column width constraints
hardcoded to 7 characters.
This commit is contained in:
Jaromir Capik 2013-02-07 17:56:55 +01:00
parent 20ce346ebd
commit d454bfe902

31
pmap.c
View File

@ -39,6 +39,21 @@
#include "proc/readproc.h" #include "proc/readproc.h"
#include "proc/version.h" #include "proc/version.h"
static int integer_width(unsigned KLONG number)
{
int result;
result = !(number > 0);
while (number) {
result++;
number /= 10;
}
return result;
}
static void __attribute__ ((__noreturn__)) static void __attribute__ ((__noreturn__))
usage(FILE * out) usage(FILE * out)
{ {
@ -208,7 +223,7 @@ static void print_extended_maps (FILE *f)
dev[64], fmt_str[64], dev[64], fmt_str[64],
vmflags[VMFLAGS_LENGTH]; vmflags[VMFLAGS_LENGTH];
int maxw1=0, maxw2=0, maxw3=0, maxw4=0, maxw5=0, maxwv=0; int maxw1=0, maxw2=0, maxw3=0, maxw4=0, maxw5=0, maxwv=0;
int nfields, firstmapping, footer_gap, i; int nfields, firstmapping, footer_gap, i, width_of_total;
unsigned KLONG value; unsigned KLONG value;
char *ret; char *ret;
char c; char c;
@ -240,8 +255,6 @@ static void print_extended_maps (FILE *f)
if (strlen(dev) > maxw4) maxw4 = strlen(dev); if (strlen(dev) > maxw4) maxw4 = strlen(dev);
if (strlen(inode) > maxw5) maxw5 = strlen(inode); if (strlen(inode) > maxw5) maxw5 = strlen(inode);
if (7 > maxw5) maxw5 = 7;
ret = fgets(mapbuf, sizeof mapbuf, f); ret = fgets(mapbuf, sizeof mapbuf, f);
nfields = sscanf(mapbuf, "%"DETL"[^:]: %"NUML"[0-9] kB %c", nfields = sscanf(mapbuf, "%"DETL"[^:]: %"NUML"[0-9] kB %c",
detail_desc, value_str, &c); detail_desc, value_str, &c);
@ -264,10 +277,7 @@ static void print_extended_maps (FILE *f)
listtail = listnode; listtail = listnode;
/* listnode was calloc()ed so all fields are already NULL! */ /* listnode was calloc()ed so all fields are already NULL! */
strcpy(listnode->description, detail_desc); strcpy(listnode->description, detail_desc);
if (strlen(detail_desc) > 7)
listnode->max_width = strlen(detail_desc); listnode->max_width = strlen(detail_desc);
else
listnode->max_width = 7;
} else { } else {
/* === LIST EXISTS === */ /* === LIST EXISTS === */
if (strcmp(listnode->description, detail_desc) != 0) if (strcmp(listnode->description, detail_desc) != 0)
@ -277,9 +287,12 @@ static void print_extended_maps (FILE *f)
} }
strcpy(listnode->value_str, value_str); strcpy(listnode->value_str, value_str);
sscanf(value_str, "%"KLF"u", &listnode->value); sscanf(value_str, "%"KLF"u", &listnode->value);
if (firstmapping == 2) listnode->total += listnode->value; if (firstmapping == 2) {
if (strlen(value_str) > listnode->max_width) listnode->total += listnode->value;
listnode->max_width = strlen(value_str); width_of_total = integer_width(listnode->total);
if (width_of_total > listnode->max_width)
listnode->max_width = width_of_total;
}
listnode = listnode->next; listnode = listnode->next;
loop_end: loop_end:
ret = fgets(mapbuf, sizeof mapbuf, f); ret = fgets(mapbuf, sizeof mapbuf, f);