From 879abf012ee720fe198d498add6b470a097b10b0 Mon Sep 17 00:00:00 2001 From: djm Date: Tue, 16 Aug 2005 11:32:09 +0000 Subject: [PATCH] - (djm) [ttymodes.c] bugzilla #1054: Fix encoding of _POSIX_VDISABLE, from Jacob Nevins; ok dtucker@ --- ChangeLog | 4 ++++ ttymodes.c | 30 ++++++++++++++++++++++++++++-- 2 files changed, 32 insertions(+), 2 deletions(-) diff --git a/ChangeLog b/ChangeLog index 114e885e..fc67023c 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +20050816 + - (djm) [ttymodes.c] bugzilla #1054: Fix encoding of _POSIX_VDISABLE, + from Jacob Nevins; ok dtucker@ + 20050815 - (tim) [sftp.c] wrap el_end() in #ifdef USE_LIBEDIT - (tim) [configure.ac] corrections to libedit tests. Report and patches diff --git a/ttymodes.c b/ttymodes.c index c32e213a..cf4c7d5c 100644 --- a/ttymodes.c +++ b/ttymodes.c @@ -240,6 +240,32 @@ baud_to_speed(int baud) } } +/* + * Encode a special character into SSH line format. + */ +static u_int +special_char_encode(cc_t c) +{ +#ifdef _POSIX_VDISABLE + if (c == _POSIX_VDISABLE) + return 255; +#endif /* _POSIX_VDISABLE */ + return c; +} + +/* + * Decode a special character from SSH line format. + */ +static cc_t +special_char_decode(u_int c) +{ +#ifdef _POSIX_VDISABLE + if (c == 255) + return _POSIX_VDISABLE; +#endif /* _POSIX_VDISABLE */ + return c; +} + /* * Encodes terminal modes for the terminal referenced by fd * or tiop in a portable manner, and appends the modes to a packet @@ -287,7 +313,7 @@ tty_make_modes(int fd, struct termios *tiop) #define TTYCHAR(NAME, OP) \ debug3("tty_make_modes: %d %d", OP, tio.c_cc[NAME]); \ buffer_put_char(&buf, OP); \ - put_arg(&buf, tio.c_cc[NAME]); + put_arg(&buf, special_char_encode(tio.c_cc[NAME])); #define TTYMODE(NAME, FIELD, OP) \ debug3("tty_make_modes: %d %d", OP, ((tio.FIELD & NAME) != 0)); \ @@ -375,7 +401,7 @@ tty_parse_modes(int fd, int *n_bytes_ptr) #define TTYCHAR(NAME, OP) \ case OP: \ n_bytes += arg_size; \ - tio.c_cc[NAME] = get_arg(); \ + tio.c_cc[NAME] = special_char_decode(get_arg()); \ debug3("tty_parse_modes: %d %d", OP, tio.c_cc[NAME]); \ break; #define TTYMODE(NAME, FIELD, OP) \ -- 2.45.2