aboutsummaryrefslogtreecommitdiff
path: root/coreutils/stty.c
diff options
context:
space:
mode:
Diffstat (limited to 'coreutils/stty.c')
-rw-r--r--coreutils/stty.c39
1 files changed, 7 insertions, 32 deletions
diff --git a/coreutils/stty.c b/coreutils/stty.c
index d1e74f437..378a848e7 100644
--- a/coreutils/stty.c
+++ b/coreutils/stty.c
@@ -781,36 +781,6 @@ struct globals {
781 G.max_col = 80; \ 781 G.max_col = 80; \
782} while (0) 782} while (0)
783 783
784
785/* Return a string that is the printable representation of character CH */
786/* Adapted from 'cat' by Torbjorn Granlund */
787static const char *visible(unsigned ch)
788{
789 char *bpout = G.buf;
790
791 if (ch == _POSIX_VDISABLE)
792 return "<undef>";
793
794 if (ch >= 128) {
795 ch -= 128;
796 *bpout++ = 'M';
797 *bpout++ = '-';
798 }
799
800 if (ch < 32) {
801 *bpout++ = '^';
802 *bpout++ = ch + 64;
803 } else if (ch < 127) {
804 *bpout++ = ch;
805 } else {
806 *bpout++ = '^';
807 *bpout++ = '?';
808 }
809
810 *bpout = '\0';
811 return G.buf;
812}
813
814static void set_speed_or_die(enum speed_setting type, const char *arg, 784static void set_speed_or_die(enum speed_setting type, const char *arg,
815 struct termios *mode) 785 struct termios *mode)
816{ 786{
@@ -1038,6 +1008,7 @@ static void do_display(const struct termios *mode, int all)
1038#endif 1008#endif
1039 1009
1040 for (i = 0; i != CIDX_min; ++i) { 1010 for (i = 0; i != CIDX_min; ++i) {
1011 char ch;
1041 /* If swtch is the same as susp, don't print both */ 1012 /* If swtch is the same as susp, don't print both */
1042#if VSWTCH == VSUSP 1013#if VSWTCH == VSUSP
1043 if (i == CIDX_swtch) 1014 if (i == CIDX_swtch)
@@ -1051,8 +1022,12 @@ static void do_display(const struct termios *mode, int all)
1051 continue; 1022 continue;
1052 } 1023 }
1053#endif 1024#endif
1054 wrapf("%s = %s;", nth_string(control_name, i), 1025 ch = mode->c_cc[control_info[i].offset];
1055 visible(mode->c_cc[control_info[i].offset])); 1026 if (ch == _POSIX_VDISABLE)
1027 strcpy(G.buf, "<undef>");
1028 else
1029 visible(ch, G.buf, 0);
1030 wrapf("%s = %s;", nth_string(control_name, i), G.buf);
1056 } 1031 }
1057#if VEOF == VMIN 1032#if VEOF == VMIN
1058 if ((mode->c_lflag & ICANON) == 0) 1033 if ((mode->c_lflag & ICANON) == 0)