aboutsummaryrefslogtreecommitdiff
path: root/toys/posix
diff options
context:
space:
mode:
authorRob Landley <rob@landley.net>2020-09-04 01:42:36 -0500
committerRob Landley <rob@landley.net>2020-09-04 01:42:36 -0500
commit1ff35e6c508fc605fd4268d479e5473f50debb67 (patch)
treed5c4cd024b8716e5da416cf408a26c288af6eeb3 /toys/posix
parentec5e6e12ee6d7047ab013f3a2826abdb52666ea0 (diff)
downloadtoybox-1ff35e6c508fc605fd4268d479e5473f50debb67.tar.gz
Autodetect pid length.
Diffstat (limited to 'toys/posix')
-rw-r--r--toys/posix/ps.c31
1 files changed, 21 insertions, 10 deletions
diff --git a/toys/posix/ps.c b/toys/posix/ps.c
index 8707ae5a..cadc060b 100644
--- a/toys/posix/ps.c
+++ b/toys/posix/ps.c
@@ -213,7 +213,7 @@ GLOBALS(
dev_t tty;
void *fields, *kfields;
long long ticks, bits, time;
- int kcount, forcek, sortpos;
+ int kcount, forcek, sortpos, pidlen;
int (*match_process)(long long *slot);
void (*show_process)(void *tb);
)
@@ -311,7 +311,6 @@ struct procpid {
#define XX 64 // force string representation for sorting, etc
// TODO: Android uses -30 for LABEL, but ideally it would auto-size.
-// TODO: ideally, PID and PPID would auto-size too.
struct typography {
char *name, *help;
signed char width, slot;
@@ -1112,8 +1111,9 @@ static char *parse_ko(void *data, char *type, int length)
}
if (i==ARRAY_LEN(typos)) return type;
if (!field->title) field->title = typos[field->which].name;
- if (!field->len) field->len = typos[field->which].width;
- else if (typos[field->which].width<0) field->len *= -1;
+ k = i<2 ? TT.pidlen : typos[field->which].width;
+ if (!field->len) field->len = k;
+ else if (k<0) field->len *= -1;
dlist_add_nomalloc(data, (void *)field);
return 0;
@@ -1280,11 +1280,9 @@ static void default_ko(char *s, void *fields, char *err, struct arg_list *arg)
if (x) help_help();
}
-void ps_main(void)
+void common_setup(void)
{
- char **arg;
- struct dirtree *dt;
- char *not_o;
+ char buf[128];
int i;
TT.ticks = sysconf(_SC_CLK_TCK); // units for starttime/uptime
@@ -1295,6 +1293,20 @@ void ps_main(void)
if (!fstat(i, &st)) TT.tty = st.st_rdev;
}
+ if (readfile("/proc/sys/kernel/pid_max", buf, 128))
+ while (isdigit(buf[TT.pidlen])) TT.pidlen++;
+ else TT.pidlen = 6;
+}
+
+void ps_main(void)
+{
+ char **arg;
+ struct dirtree *dt;
+ char *not_o;
+ int i;
+
+ common_setup();
+
// If we can't query terminal size pad to 80 but do -w
TT.width = 80;
if (!isatty(1) || !terminal_size(&TT.width, 0)) toys.optflags |= FLAG_w;
@@ -1733,8 +1745,7 @@ static void top_common(
static void top_setup(char *defo, char *defk)
{
- TT.ticks = sysconf(_SC_CLK_TCK); // units for starttime/uptime
- TT.tty = tty_fd() != -1;
+ common_setup();
// Are we doing "batch" output or interactive?
if (FLAG(b)) TT.width = TT.height = 99999;