#include <curses.priv.h>
#include <term.h>
MODULE_ID("$Id: lib_raw.c,v 1.1.1.1 2001/11/29 20:40:57 jevans Exp $")
#if SVR4_TERMIO && !defined(_POSIX_SOURCE)
#define _POSIX_SOURCE
#endif
#if HAVE_SYS_TERMIO_H
#include <sys/termio.h>
#endif
#ifdef __EMX__
#include <io.h>
#endif
#define COOKED_INPUT (IXON|BRKINT|PARMRK)
#ifdef TRACE
#define BEFORE(N) if (_nc_tracing&TRACE_BITS) _tracef("%s before bits: %s", N, _nc_tracebits())
#define AFTER(N) if (_nc_tracing&TRACE_BITS) _tracef("%s after bits: %s", N, _nc_tracebits())
#else
#define BEFORE(s)
#define AFTER(s)
#endif
NCURSES_EXPORT(int)
raw(void)
{
T((T_CALLED("raw()")));
if (SP != 0 && cur_term != 0) {
SP->_raw = TRUE;
SP->_cbreak = 1;
#ifdef __EMX__
setmode(SP->_ifd, O_BINARY);
#endif
#ifdef TERMIOS
BEFORE("raw");
cur_term->Nttyb.c_lflag &= ~(ICANON | ISIG | IEXTEN);
cur_term->Nttyb.c_iflag &= ~(COOKED_INPUT);
cur_term->Nttyb.c_cc[VMIN] = 1;
cur_term->Nttyb.c_cc[VTIME] = 0;
AFTER("raw");
#else
cur_term->Nttyb.sg_flags |= RAW;
#endif
returnCode(_nc_set_tty_mode(&cur_term->Nttyb));
}
returnCode(ERR);
}
NCURSES_EXPORT(int)
cbreak(void)
{
T((T_CALLED("cbreak()")));
SP->_cbreak = 1;
#ifdef __EMX__
setmode(SP->_ifd, O_BINARY);
#endif
#ifdef TERMIOS
BEFORE("cbreak");
cur_term->Nttyb.c_lflag &= ~ICANON;
cur_term->Nttyb.c_iflag &= ~ICRNL;
cur_term->Nttyb.c_lflag |= ISIG;
cur_term->Nttyb.c_cc[VMIN] = 1;
cur_term->Nttyb.c_cc[VTIME] = 0;
AFTER("cbreak");
#else
cur_term->Nttyb.sg_flags |= CBREAK;
#endif
returnCode(_nc_set_tty_mode(&cur_term->Nttyb));
}
NCURSES_EXPORT(void)
qiflush(void)
{
T((T_CALLED("qiflush()")));
#ifdef TERMIOS
BEFORE("qiflush");
cur_term->Nttyb.c_lflag &= ~(NOFLSH);
AFTER("qiflush");
(void) _nc_set_tty_mode(&cur_term->Nttyb);
#endif
returnVoid;
}
NCURSES_EXPORT(int)
noraw(void)
{
T((T_CALLED("noraw()")));
SP->_raw = FALSE;
SP->_cbreak = 0;
#ifdef __EMX__
setmode(SP->_ifd, O_TEXT);
#endif
#ifdef TERMIOS
BEFORE("noraw");
cur_term->Nttyb.c_lflag |= ISIG | ICANON |
(cur_term->Ottyb.c_lflag & IEXTEN);
cur_term->Nttyb.c_iflag |= COOKED_INPUT;
AFTER("noraw");
#else
cur_term->Nttyb.sg_flags &= ~(RAW | CBREAK);
#endif
returnCode(_nc_set_tty_mode(&cur_term->Nttyb));
}
NCURSES_EXPORT(int)
nocbreak(void)
{
T((T_CALLED("nocbreak()")));
SP->_cbreak = 0;
#ifdef __EMX__
setmode(SP->_ifd, O_TEXT);
#endif
#ifdef TERMIOS
BEFORE("nocbreak");
cur_term->Nttyb.c_lflag |= ICANON;
cur_term->Nttyb.c_iflag |= ICRNL;
AFTER("nocbreak");
#else
cur_term->Nttyb.sg_flags &= ~CBREAK;
#endif
returnCode(_nc_set_tty_mode(&cur_term->Nttyb));
}
NCURSES_EXPORT(void)
noqiflush(void)
{
T((T_CALLED("noqiflush()")));
#ifdef TERMIOS
BEFORE("noqiflush");
cur_term->Nttyb.c_lflag |= NOFLSH;
AFTER("noqiflush");
(void) _nc_set_tty_mode(&cur_term->Nttyb);
#endif
returnVoid;
}
NCURSES_EXPORT(int)
intrflush(WINDOW *win GCC_UNUSED, bool flag)
{
T((T_CALLED("intrflush(%d)"), flag));
#ifdef TERMIOS
BEFORE("intrflush");
if (flag)
cur_term->Nttyb.c_lflag &= ~(NOFLSH);
else
cur_term->Nttyb.c_lflag |= (NOFLSH);
AFTER("intrflush");
returnCode(_nc_set_tty_mode(&cur_term->Nttyb));
#else
returnCode(ERR);
#endif
}