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 | |
parent | 5ea14bd1c246f7571d466d18385db22f59ac3262 (diff) | |
download | toybox-5b2644cafc8a619b617ba0fbb5473667dbd634ba.tar.gz toybox-5b2644cafc8a619b617ba0fbb5473667dbd634ba.tar.bz2 toybox-5b2644cafc8a619b617ba0fbb5473667dbd634ba.zip |
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.)
-rw-r--r-- | lib/interestingtimes.c | 9 | ||||
-rw-r--r-- | lib/lib.h | 1 | ||||
-rw-r--r-- | toys/other/reset.c | 23 | ||||
-rw-r--r-- | toys/pending/reset.c | 34 |
4 files changed, 33 insertions, 34 deletions
diff --git a/lib/interestingtimes.c b/lib/interestingtimes.c index cea5039..85b8eb4 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); diff --git a/toys/other/reset.c b/toys/other/reset.c new file mode 100644 index 0000000..0c2089c --- /dev/null +++ b/toys/other/reset.c @@ -0,0 +1,23 @@ +/* reset.c - reset the terminal. + * + * Copyright 2015 Rob Landley <rob@landley.net> + * + * No standard. + +USE_RESET(NEWTOY(reset, 0, TOYFLAG_USR|TOYFLAG_BIN)) + +config RESET + bool "reset" + default y + help + usage: reset + + reset the terminal +*/ +#include "toys.h" + +void reset_main(void) +{ + // man 4 console codes: reset terminal is ESC (no left bracket) c + xwrite(xgettty(), "\033c", 2); +} diff --git a/toys/pending/reset.c b/toys/pending/reset.c deleted file mode 100644 index a12f0b6..0000000 --- a/toys/pending/reset.c +++ /dev/null @@ -1,34 +0,0 @@ -/* reset.c - A program to reset the terminal. - * - * Copyright 2014 Ashwini Kumar <ak.ashwini@gmail.com> - * Copyright 2014 Kyungwan Han <asura321@gmail.com> - * - * No Standard. - -USE_RESET(NEWTOY(reset, NULL, TOYFLAG_USR|TOYFLAG_BIN)) - -config RESET - bool "reset" - default n - help - usage: reset - - A program to reset the terminal. -*/ -#define FOR_reset -#include "toys.h" - -void reset_main(void) -{ - char *args[] = {"stty", "sane", NULL}; - - /* \033c - reset the terminal with default setting - * \033(B - set the G0 character set (B=US) - * \033[2J - clear the whole screen - * \033[0m - Reset all attributes - */ - if (isatty(1)) xprintf("\033c\033(B\033[0m\033[J\033[?25h"); - fflush(stdout); - // set the terminal to sane settings - xexec(args); -} |