Changes in 22.21
================
* Missing comma in fuser(1) added Debian #702391
+ * pstree uses COLUMN env variable Debian #717017
Changes in 22.20
================
.\"
.\" Copyright 1993-2002 Werner Almesberger
-.\" 2002-2012 Craig Small
+.\" 2002-2013 Craig Small
.\" This program is free software; you can redistribute it and/or modify
.\" it under the terms of the GNU General Public License as published by
.\" the Free Software Foundation; either version 2 of the License, or
.\" (at your option) any later version.
.\"
-.TH PSTREE 1 "2012-07-28" "psmisc" "User Commands"
+.TH PSTREE 1 "2013-07-16" "psmisc" "User Commands"
.SH NAME
pstree \- display a tree of processes
.SH SYNOPSIS
implicitly disables compaction. If both PIDs and PGIDs are displayed
then PIDs are shown first.
.IP \fB\-l\fP
-Display long lines. By default, lines are truncated to the display
-width or 132 if output is sent to a non-tty or if the display width is
-unknown.
+Display long lines. By default, lines are truncated to either the COLUMNS
+environment variable or the display width. If neither of these methods work,
+the default of 132 columns is used.
.IP \fB\-n\fP
Sort processes with the same ancestor by PID instead of by name.
(Numeric sort.)
static int charlen = 0; /* length of character */
static void fix_orphans(security_context_t scontext);
+
+/*
+ * Determine the correct output width, what we use is:
+ */
+static int get_output_width(void)
+{
+ char *ep, *env_columns;
+ struct winsize winsz;
+
+ env_columns = getenv("COLUMNS");
+ if (env_columns && *env_columns) {
+ long t;
+ t = strtol(env_columns, &ep, 0);
+ if (!*ep && (t > 0) && (t < 0x7fffffffL))
+ return (int)t;
+ }
+ if (ioctl(1, TIOCGWINSZ, &winsz) >= 0)
+ if (winsz.ws_col)
+ return winsz.ws_col;
+ return 132;
+
+}
+
/*
* Allocates additional buffer space for width and more as needed.
* The first call will allocate the first buffer.
int main(int argc, char **argv)
{
PROC *current;
- struct winsize winsz;
const struct passwd *pw;
pid_t pid, highlight;
char termcap_area[1024];
{ 0, 0, 0, 0 }
};
- if (ioctl(1, TIOCGWINSZ, &winsz) >= 0)
- if (winsz.ws_col)
- output_width = winsz.ws_col;
+ output_width = get_output_width();
pid = ROOT_PID;
highlight = 0;
pw = NULL;