summaryrefslogtreecommitdiff
path: root/src/system.hh.in
diff options
context:
space:
mode:
authorStefano Zacchiroli <zack@upsilon.cc>2014-10-13 23:15:23 +0200
committerMartin Michlmayr <tbm@cyrius.com>2014-10-13 17:15:56 -0400
commit56976a127c081a6a008c81966360003a8711a319 (patch)
treeb27188861374e243746aaf561a0a9cf480989fbb /src/system.hh.in
parent6b2520cc49edf4d167bec10850b832c308ebf9a3 (diff)
downloadfork-ledger-56976a127c081a6a008c81966360003a8711a319.tar.gz
fork-ledger-56976a127c081a6a008c81966360003a8711a319.tar.bz2
fork-ledger-56976a127c081a6a008c81966360003a8711a319.zip
make --columns default to terminal width, as returned by ioctl()
If set, the COLUMNS environment variable will take precedence over terminal width. However, please note that COLUMNS is usually *not* exported by shells to child processes, so in most cases COLUMNS will be undefined for ledger---hence the motivation for this change. Terminal width is queried using ioctl() on stdin. For the sake of portability the querying is done only on platform where ioctl() is detected as supported at compile-time.
Diffstat (limited to 'src/system.hh.in')
-rw-r--r--src/system.hh.in5
1 files changed, 5 insertions, 0 deletions
diff --git a/src/system.hh.in b/src/system.hh.in
index eaee14dc..67a218da 100644
--- a/src/system.hh.in
+++ b/src/system.hh.in
@@ -63,6 +63,7 @@
#define HAVE_REALPATH @HAVE_REALPATH@
#define HAVE_GETPWUID @HAVE_GETPWUID@
#define HAVE_GETPWNAM @HAVE_GETPWNAM@
+#define HAVE_IOCTL @HAVE_IOCTL@
#define HAVE_ISATTY @HAVE_ISATTY@
#define HAVE_UNIX_PIPES @HAVE_UNIX_PIPES@
@@ -151,6 +152,10 @@ typedef std::ostream::pos_type ostream_pos_type;
#include <pwd.h>
#endif
+#if HAVE_IOCTL
+#include <sys/ioctl.h>
+#endif
+
#if HAVE_UNIX_PIPES
#include <sys/types.h>
#include <sys/wait.h>