diff options
author | Marek Polacek <mmpolacek@gmail.com> | 2010-10-28 21:34:56 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2010-10-28 21:34:56 +0200 |
commit | 7b18107384d950358e146d42bf02b391fab5ffd6 (patch) | |
tree | 9994e2bcaa038c3128ed8b3bca99486e22f660fb /console-tools/reset.c | |
parent | 02788ac7e2a44eee889aa1005e89076f928e964a (diff) | |
download | busybox-w32-7b18107384d950358e146d42bf02b391fab5ffd6.tar.gz busybox-w32-7b18107384d950358e146d42bf02b391fab5ffd6.tar.bz2 busybox-w32-7b18107384d950358e146d42bf02b391fab5ffd6.zip |
*: use _exit() in sighandlers; showkey: do not use exit-thru-sighandler
While at it, make ESC sequences more readable; and removed check for
isatty(stdin) in reset. Code shrink:
text data bss dec hex filename
884771 936 17216 902923 dc70b busybox_old
884723 936 17216 902875 dc6db busybox_unstripped
Signed-off-by: Marek Polacek <mmpolacek@gmail.com>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'console-tools/reset.c')
-rw-r--r-- | console-tools/reset.c | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/console-tools/reset.c b/console-tools/reset.c index 7dffdea18..1806ce742 100644 --- a/console-tools/reset.c +++ b/console-tools/reset.c | |||
@@ -8,11 +8,13 @@ | |||
8 | * Licensed under GPLv2 or later, see file LICENSE in this source tree. | 8 | * Licensed under GPLv2 or later, see file LICENSE in this source tree. |
9 | */ | 9 | */ |
10 | 10 | ||
11 | #include "libbb.h" | ||
12 | |||
13 | /* BTW, which "standard" package has this utility? It doesn't seem | 11 | /* BTW, which "standard" package has this utility? It doesn't seem |
14 | * to be ncurses, coreutils, console-tools... then what? */ | 12 | * to be ncurses, coreutils, console-tools... then what? */ |
15 | 13 | ||
14 | #include "libbb.h" | ||
15 | |||
16 | #define ESC "\033" | ||
17 | |||
16 | #if ENABLE_STTY | 18 | #if ENABLE_STTY |
17 | int stty_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; | 19 | int stty_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; |
18 | #endif | 20 | #endif |
@@ -26,15 +28,15 @@ int reset_main(int argc UNUSED_PARAM, char **argv UNUSED_PARAM) | |||
26 | 28 | ||
27 | /* no options, no getopt */ | 29 | /* no options, no getopt */ |
28 | 30 | ||
29 | if (isatty(STDIN_FILENO) && isatty(STDOUT_FILENO)) { | 31 | if (/*isatty(STDIN_FILENO) &&*/ isatty(STDOUT_FILENO)) { |
30 | /* See 'man 4 console_codes' for details: | 32 | /* See 'man 4 console_codes' for details: |
31 | * "ESC c" -- Reset | 33 | * "ESC c" -- Reset |
32 | * "ESC ( K" -- Select user mapping | 34 | * "ESC ( K" -- Select user mapping |
33 | * "ESC [ J" -- Erase to the end of screen | ||
34 | * "ESC [ 0 m" -- Reset all display attributes | 35 | * "ESC [ 0 m" -- Reset all display attributes |
36 | * "ESC [ J" -- Erase to the end of screen | ||
35 | * "ESC [ ? 25 h" -- Make cursor visible | 37 | * "ESC [ ? 25 h" -- Make cursor visible |
36 | */ | 38 | */ |
37 | printf("\033c\033(K\033[J\033[0m\033[?25h"); | 39 | printf(ESC"c" ESC"(K" ESC"[0m" ESC"[J" ESC"[?25h"); |
38 | /* http://bugs.busybox.net/view.php?id=1414: | 40 | /* http://bugs.busybox.net/view.php?id=1414: |
39 | * people want it to reset echo etc: */ | 41 | * people want it to reset echo etc: */ |
40 | #if ENABLE_STTY | 42 | #if ENABLE_STTY |