1 /****************************************************************************
2 * Copyright (c) 1998-2016,2017 Free Software Foundation, Inc. *
4 * Permission is hereby granted, free of charge, to any person obtaining a *
5 * copy of this software and associated documentation files (the *
6 * "Software"), to deal in the Software without restriction, including *
7 * without limitation the rights to use, copy, modify, merge, publish, *
8 * distribute, distribute with modifications, sublicense, and/or sell *
9 * copies of the Software, and to permit persons to whom the Software is *
10 * furnished to do so, subject to the following conditions: *
12 * The above copyright notice and this permission notice shall be included *
13 * in all copies or substantial portions of the Software. *
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS *
16 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF *
17 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. *
18 * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, *
19 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR *
20 * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR *
21 * THE USE OR OTHER DEALINGS IN THE SOFTWARE. *
23 * Except as contained in this notice, the name(s) of the above copyright *
24 * holders shall not be used in advertising or otherwise to promote the *
25 * sale, use or other dealings in this Software without prior written *
27 ****************************************************************************/
29 /****************************************************************************
30 * Author: Zeyd M. Ben-Halim <zmbenhal@netcom.com> 1992,1995 *
31 * and: Eric S. Raymond <esr@snark.thyrsus.com> *
32 * and: Thomas E. Dickey 1998-on *
33 * and: Juergen Pfeifer 2009 *
34 ****************************************************************************/
50 #include <curses.priv.h>
52 MODULE_ID("$Id: lib_raw.c,v 1.23 2017/04/15 22:24:45 tom Exp $")
55 #include <sys/termio.h> /* needed for ISC */
60 #define _nc_setmode(mode) setmode(SP_PARM->_ifd, mode)
62 #define _nc_setmode(mode) /* nothing */
70 #define COOKED_INPUT (IXON|BRKINT|PARMRK)
73 #define BEFORE(N) if (USE_TRACEF(TRACE_BITS)) _nc_locked_tracef("%s before bits: %s", N, _nc_tracebits())
74 #define AFTER(N) if (USE_TRACEF(TRACE_BITS)) _nc_locked_tracef("%s after bits: %s", N, _nc_tracebits())
81 NCURSES_SP_NAME(raw) (NCURSES_SP_DCL0)
86 T((T_CALLED("raw(%p)"), (void *) SP_PARM));
87 if ((termp = TerminalOf(SP_PARM)) != 0) {
91 _nc_setmode(O_BINARY);
95 buf.c_lflag &= (unsigned) ~(ICANON | ISIG | IEXTEN);
96 buf.c_iflag &= (unsigned) ~(COOKED_INPUT);
102 result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
107 kbdinfo.cb = sizeof(kbdinfo);
108 KbdGetStatus(&kbdinfo, 0);
110 kbdinfo.cb = sizeof(kbdinfo);
111 kbdinfo.fsMask &= ~KEYBOARD_ASCII_MODE;
112 kbdinfo.fsMask |= KEYBOARD_BINARY_MODE;
113 KbdSetStatus(&kbdinfo, 0);
116 SP_PARM->_raw = TRUE;
117 SP_PARM->_cbreak = 1;
130 return NCURSES_SP_NAME(raw) (CURRENT_SCREEN);
135 NCURSES_SP_NAME(cbreak) (NCURSES_SP_DCL0)
140 T((T_CALLED("cbreak(%p)"), (void *) SP_PARM));
141 if ((termp = TerminalOf(SP_PARM)) != 0) {
145 _nc_setmode(O_BINARY);
149 buf.c_lflag &= (unsigned) ~ICANON;
150 buf.c_iflag &= (unsigned) ~ICRNL;
155 buf.sg_flags |= CBREAK;
157 result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
160 SP_PARM->_cbreak = 1;
173 return NCURSES_SP_NAME(cbreak) (CURRENT_SCREEN);
179 * this implementation may be wrong. See the comment under intrflush().
182 NCURSES_SP_NAME(qiflush) (NCURSES_SP_DCL0)
186 T((T_CALLED("qiflush(%p)"), (void *) SP_PARM));
187 if ((termp = TerminalOf(SP_PARM)) != 0) {
194 buf.c_lflag &= (unsigned) ~(NOFLSH);
195 result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
211 NCURSES_SP_NAME(qiflush) (CURRENT_SCREEN);
216 NCURSES_SP_NAME(noraw) (NCURSES_SP_DCL0)
221 T((T_CALLED("noraw(%p)"), (void *) SP_PARM));
222 if ((termp = TerminalOf(SP_PARM)) != 0) {
230 buf.c_lflag |= ISIG | ICANON |
231 (termp->Ottyb.c_lflag & IEXTEN);
232 buf.c_iflag |= COOKED_INPUT;
234 buf.sg_flags &= ~(RAW | CBREAK);
236 result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
241 kbdinfo.cb = sizeof(kbdinfo);
242 KbdGetStatus(&kbdinfo, 0);
244 kbdinfo.cb = sizeof(kbdinfo);
245 kbdinfo.fsMask &= ~KEYBOARD_BINARY_MODE;
246 kbdinfo.fsMask |= KEYBOARD_ASCII_MODE;
247 KbdSetStatus(&kbdinfo, 0);
250 SP_PARM->_raw = FALSE;
251 SP_PARM->_cbreak = 0;
264 return NCURSES_SP_NAME(noraw) (CURRENT_SCREEN);
269 NCURSES_SP_NAME(nocbreak) (NCURSES_SP_DCL0)
274 T((T_CALLED("nocbreak(%p)"), (void *) SP_PARM));
275 if ((termp = TerminalOf(SP_PARM)) != 0) {
283 buf.c_lflag |= ICANON;
284 buf.c_iflag |= ICRNL;
286 buf.sg_flags &= ~CBREAK;
288 result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
291 SP_PARM->_cbreak = 0;
304 return NCURSES_SP_NAME(nocbreak) (CURRENT_SCREEN);
309 NCURSES_SP_NAME(noqiflush) (NCURSES_SP_DCL0)
313 T((T_CALLED("noqiflush(%p)"), (void *) SP_PARM));
314 if ((termp = TerminalOf(SP_PARM)) != 0) {
321 buf.c_lflag |= NOFLSH;
322 result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
338 NCURSES_SP_NAME(noqiflush) (CURRENT_SCREEN);
343 * This call does the same thing as the qiflush()/noqiflush() pair. We know
344 * for certain that SVr3 intrflush() tweaks the NOFLSH bit; on the other hand,
345 * the match (in the SVr4 man pages) between the language describing NOFLSH in
346 * termio(7) and the language describing qiflush()/noqiflush() in
347 * curs_inopts(3x) is too exact to be coincidence.
350 NCURSES_SP_NAME(intrflush) (NCURSES_SP_DCLx WINDOW *win GCC_UNUSED, bool flag)
355 T((T_CALLED("intrflush(%p,%d)"), (void *) SP_PARM, flag));
359 if ((termp = TerminalOf(SP_PARM)) != 0) {
366 buf.c_lflag &= (unsigned) ~(NOFLSH);
368 buf.c_lflag |= (NOFLSH);
369 result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
383 intrflush(WINDOW *win GCC_UNUSED, bool flag)
385 return NCURSES_SP_NAME(intrflush) (CURRENT_SCREEN, win, flag);