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:
parent
20ce346ebd
commit
d454bfe902
31
pmap.c
31
pmap.c
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user