diff options
author | Rob Landley <rob@landley.net> | 2015-05-14 13:43:01 -0500 |
---|---|---|
committer | Rob Landley <rob@landley.net> | 2015-05-14 13:43:01 -0500 |
commit | 5b2644cafc8a619b617ba0fbb5473667dbd634ba (patch) | |
tree | eeec75be235b699d55875560df8595545d14fd9c /lib | |
parent | 5ea14bd1c246f7571d466d18385db22f59ac3262 (diff) | |
download | toybox-5b2644cafc8a619b617ba0fbb5473667dbd634ba.tar.gz |
Promote reset (actually write a new one using the simple man 4 console_codes
terminal reset escape sequence) and add gettty() function to lib so terminal
gets reset even when we redirect stdout/stderr. (This is apparently the
expected behavior.)
Diffstat (limited to 'lib')
-rw-r--r-- | lib/interestingtimes.c | 9 | ||||
-rw-r--r-- | lib/lib.h | 1 |
2 files changed, 10 insertions, 0 deletions
diff --git a/lib/interestingtimes.c b/lib/interestingtimes.c index cea5039f..85b8eb4c 100644 --- a/lib/interestingtimes.c +++ b/lib/interestingtimes.c @@ -5,6 +5,15 @@ #include "toys.h" +int xgettty(void) +{ + int i, j; + + for (i = 0; i<3; i++) if (isatty(j = (i+1)%3)) return j; + + return xopen("/dev/tty", O_RDWR); +} + // Quick and dirty query size of terminal, doesn't do ANSI probe fallback. // set x=80 y=25 before calling to provide defaults. Returns 0 if couldn't // determine size. @@ -181,6 +181,7 @@ int qstrcmp(const void *a, const void *b); int xpoll(struct pollfd *fds, int nfds, int timeout); // interestingtimes.c +int xgettty(void); int terminal_size(unsigned *xx, unsigned *yy); int set_terminal(int fd, int raw, struct termios *old); int scan_key(char *scratch, char **seqs, int block); |