diff options
| author | Denys Vlasenko <vda.linux@googlemail.com> | 2018-04-16 10:24:48 +0200 |
|---|---|---|
| committer | Denys Vlasenko <vda.linux@googlemail.com> | 2018-04-16 10:24:48 +0200 |
| commit | 058a153b6970660f3c284ac259986ae87507df9a (patch) | |
| tree | a43cce5c5cdfd826aa15955bb53b8dbcceec0a6b /libbb | |
| parent | c72499584abbf32b3757024bb0cd53f23d5d0d72 (diff) | |
| download | busybox-w32-058a153b6970660f3c284ac259986ae87507df9a.tar.gz busybox-w32-058a153b6970660f3c284ac259986ae87507df9a.tar.bz2 busybox-w32-058a153b6970660f3c284ac259986ae87507df9a.zip | |
less: fix fallout from "use common routine to set raw termios"
Testcase: (sleep 10; ls) | busybox less
[...]
~ LICENSE
~ Makefile
~ Makefile.custom
~ Makefile.flags
[...]
less did not want this part:
+ /* dont convert NL to CR+NL on output */
+ newterm->c_oflag &= ~(ONLCR);
function old new delta
get_termios_and_make_raw 108 115 +7
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'libbb')
| -rw-r--r-- | libbb/xfuncs.c | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/libbb/xfuncs.c b/libbb/xfuncs.c index e8c027f17..b4d512bd6 100644 --- a/libbb/xfuncs.c +++ b/libbb/xfuncs.c | |||
| @@ -330,7 +330,6 @@ int FAST_FUNC get_termios_and_make_raw(int fd, struct termios *newterm, struct t | |||
| 330 | newterm->c_cc[VMIN] = 1; | 330 | newterm->c_cc[VMIN] = 1; |
| 331 | /* no timeout (reads block forever) */ | 331 | /* no timeout (reads block forever) */ |
| 332 | newterm->c_cc[VTIME] = 0; | 332 | newterm->c_cc[VTIME] = 0; |
| 333 | if (flags & TERMIOS_RAW_CRNL) { | ||
| 334 | /* IXON, IXOFF, and IXANY: | 333 | /* IXON, IXOFF, and IXANY: |
| 335 | * IXOFF=1: sw flow control is enabled on input queue: | 334 | * IXOFF=1: sw flow control is enabled on input queue: |
| 336 | * tty transmits a STOP char when input queue is close to full | 335 | * tty transmits a STOP char when input queue is close to full |
| @@ -340,9 +339,12 @@ int FAST_FUNC get_termios_and_make_raw(int fd, struct termios *newterm, struct t | |||
| 340 | * and resume sending if START is received, or if any char | 339 | * and resume sending if START is received, or if any char |
| 341 | * is received and IXANY=1. | 340 | * is received and IXANY=1. |
| 342 | */ | 341 | */ |
| 342 | if (flags & TERMIOS_RAW_CRNL_INPUT) { | ||
| 343 | /* IXON=0: XON/XOFF chars are treated as normal chars (why we do this?) */ | 343 | /* IXON=0: XON/XOFF chars are treated as normal chars (why we do this?) */ |
| 344 | /* dont convert CR to NL on input */ | 344 | /* dont convert CR to NL on input */ |
| 345 | newterm->c_iflag &= ~(IXON | ICRNL); | 345 | newterm->c_iflag &= ~(IXON | ICRNL); |
| 346 | } | ||
| 347 | if (flags & TERMIOS_RAW_CRNL_OUTPUT) { | ||
| 346 | /* dont convert NL to CR+NL on output */ | 348 | /* dont convert NL to CR+NL on output */ |
| 347 | newterm->c_oflag &= ~(ONLCR); | 349 | newterm->c_oflag &= ~(ONLCR); |
| 348 | /* Maybe clear more c_oflag bits? Usually, only OPOST and ONLCR are set. | 350 | /* Maybe clear more c_oflag bits? Usually, only OPOST and ONLCR are set. |
| @@ -363,9 +365,12 @@ int FAST_FUNC get_termios_and_make_raw(int fd, struct termios *newterm, struct t | |||
| 363 | #ifndef IXANY | 365 | #ifndef IXANY |
| 364 | # define IXANY 0 | 366 | # define IXANY 0 |
| 365 | #endif | 367 | #endif |
| 366 | /* IXOFF=0: disable sending XON/XOFF if input buf is full */ | 368 | /* IXOFF=0: disable sending XON/XOFF if input buf is full |
| 367 | /* IXON=0: input XON/XOFF chars are not special */ | 369 | * IXON=0: input XON/XOFF chars are not special |
| 368 | /* dont convert anything on input */ | 370 | * BRKINT=0: dont send SIGINT on break |
| 371 | * IMAXBEL=0: dont echo BEL on input line too long | ||
| 372 | * INLCR,ICRNL,IUCLC: dont convert anything on input | ||
| 373 | */ | ||
| 369 | newterm->c_iflag &= ~(IXOFF|IXON|IXANY|BRKINT|INLCR|ICRNL|IUCLC|IMAXBEL); | 374 | newterm->c_iflag &= ~(IXOFF|IXON|IXANY|BRKINT|INLCR|ICRNL|IUCLC|IMAXBEL); |
| 370 | } | 375 | } |
| 371 | return r; | 376 | return r; |
