ncurses 6.0 - patch 20150912
[ncurses.git] / ncurses / tinfo / lib_raw.c
index 61b422c1fb885a1c366e184a9e62f7ba3e89afa4..928692b0cb272ad52433dbb98ad2502dd5866303 100644 (file)
@@ -1,5 +1,5 @@
 /****************************************************************************
- * Copyright (c) 1998 Free Software Foundation, Inc.                        *
+ * Copyright (c) 1998-2011,2012 Free Software Foundation, Inc.              *
  *                                                                          *
  * Permission is hereby granted, free of charge, to any person obtaining a  *
  * copy of this software and associated documentation files (the            *
 /****************************************************************************
  *  Author: Zeyd M. Ben-Halim <zmbenhal@netcom.com> 1992,1995               *
  *     and: Eric S. Raymond <esr@snark.thyrsus.com>                         *
+ *     and: Thomas E. Dickey                        1998-on                 *
+ *     and: Juergen Pfeifer                         2009                    *
  ****************************************************************************/
 
-
 /*
  *     raw.c
  *
  */
 
 #include <curses.priv.h>
-#include <term.h>      /* cur_term */
-
-MODULE_ID("$Id: lib_raw.c,v 1.3 1999/03/06 22:28:24 tom Exp $")
 
-#if defined(SVR4_TERMIO) && !defined(_POSIX_SOURCE)
-#define _POSIX_SOURCE
-#endif
+MODULE_ID("$Id: lib_raw.c,v 1.21 2012/01/21 19:21:29 KO.Myung-Hun Exp $")
 
 #if HAVE_SYS_TERMIO_H
-#include <sys/termio.h>        /* needed for ISC */
+#include <sys/termio.h>                /* needed for ISC */
 #endif
 
 #ifdef __EMX__
 #include <io.h>
-#include <fcntl.h>
+#define _nc_setmode(mode) setmode(SP_PARM->_ifd, mode)
+#else
+#define _nc_setmode(mode)      /* nothing */
+#endif
+
+#if USE_KLIBC_KBD
+#define INCL_KBD
+#include <os2.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())
+#define BEFORE(N)      if (USE_TRACEF(TRACE_BITS)) _nc_locked_tracef("%s before bits: %s", N, _nc_tracebits())
+#define AFTER(N)       if (USE_TRACEF(TRACE_BITS)) _nc_locked_tracef("%s after bits: %s", N, _nc_tracebits())
 #else
 #define BEFORE(s)
 #define AFTER(s)
 #endif /* TRACE */
 
-int raw(void)
+NCURSES_EXPORT(int)
+NCURSES_SP_NAME(raw) (NCURSES_SP_DCL0)
 {
-       T((T_CALLED("raw()")));
-       if (SP != 0 && cur_term != 0) {
+    int result = ERR;
+    TERMINAL *termp;
 
-               SP->_raw = TRUE;
-               SP->_cbreak = 1;
+    T((T_CALLED("raw(%p)"), (void *) SP_PARM));
+    if ((termp = TerminalOf(SP_PARM)) != 0) {
+       TTY buf;
 
-#ifdef __EMX__
-               setmode(SP->_ifd, O_BINARY);
-#endif
+       BEFORE("raw");
+       _nc_setmode(O_BINARY);
 
+       buf = termp->Nttyb;
 #ifdef TERMIOS
-               BEFORE("raw");
-               cur_term->Nttyb.c_lflag &= ~(ICANON|ISIG);
-               cur_term->Nttyb.c_iflag &= ~(COOKED_INPUT);
-               cur_term->Nttyb.c_cc[VMIN] = 1;
-               cur_term->Nttyb.c_cc[VTIME] = 0;
-               AFTER("raw");
+       buf.c_lflag &= (unsigned) ~(ICANON | ISIG | IEXTEN);
+       buf.c_iflag &= (unsigned) ~(COOKED_INPUT);
+       buf.c_cc[VMIN] = 1;
+       buf.c_cc[VTIME] = 0;
 #else
-               cur_term->Nttyb.sg_flags |= RAW;
+       buf.sg_flags |= RAW;
 #endif
-               returnCode(_nc_set_tty_mode(&cur_term->Nttyb));
+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
+       if (result == OK) {
+#if USE_KLIBC_KBD
+           KBDINFO kbdinfo;
+
+           kbdinfo.cb = sizeof(kbdinfo);
+           KbdGetStatus(&kbdinfo, 0);
+
+           kbdinfo.cb = sizeof(kbdinfo);
+           kbdinfo.fsMask &= ~KEYBOARD_ASCII_MODE;
+           kbdinfo.fsMask |= KEYBOARD_BINARY_MODE;
+           KbdSetStatus(&kbdinfo, 0);
+#endif
+           SP_PARM->_raw = TRUE;
+           SP_PARM->_cbreak = 1;
+           termp->Nttyb = buf;
        }
-       returnCode(ERR);
+       AFTER("raw");
+    }
+    returnCode(result);
 }
 
-int cbreak(void)
+#if NCURSES_SP_FUNCS
+NCURSES_EXPORT(int)
+raw(void)
 {
-       T((T_CALLED("cbreak()")));
+    return NCURSES_SP_NAME(raw) (CURRENT_SCREEN);
+}
+#endif
 
-       SP->_cbreak = 1;
+NCURSES_EXPORT(int)
+NCURSES_SP_NAME(cbreak) (NCURSES_SP_DCL0)
+{
+    int result = ERR;
+    TERMINAL *termp;
 
-#ifdef __EMX__
-       setmode(SP->_ifd, O_BINARY);
-#endif
+    T((T_CALLED("cbreak(%p)"), (void *) SP_PARM));
+    if ((termp = TerminalOf(SP_PARM)) != 0) {
+       TTY buf;
 
-#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");
+       _nc_setmode(O_BINARY);
+
+       buf = termp->Nttyb;
+#ifdef TERMIOS
+       buf.c_lflag &= (unsigned) ~ICANON;
+       buf.c_iflag &= (unsigned) ~ICRNL;
+       buf.c_lflag |= ISIG;
+       buf.c_cc[VMIN] = 1;
+       buf.c_cc[VTIME] = 0;
 #else
-       cur_term->Nttyb.sg_flags |= CBREAK;
+       buf.sg_flags |= CBREAK;
 #endif
-       returnCode(_nc_set_tty_mode( &cur_term->Nttyb));
+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
+       if (result == OK) {
+           SP_PARM->_cbreak = 1;
+           termp->Nttyb = buf;
+       }
+       AFTER("cbreak");
+    }
+    returnCode(result);
 }
 
-void qiflush(void)
+#if NCURSES_SP_FUNCS
+NCURSES_EXPORT(int)
+cbreak(void)
+{
+    return NCURSES_SP_NAME(cbreak) (CURRENT_SCREEN);
+}
+#endif
+
+/*
+ * Note:
+ * this implementation may be wrong.  See the comment under intrflush().
+ */
+NCURSES_EXPORT(void)
+NCURSES_SP_NAME(qiflush) (NCURSES_SP_DCL0)
 {
-       T((T_CALLED("qiflush()")));
+    int result = ERR;
+    TERMINAL *termp;
 
-       /*
-        * Note: this implementation may be wrong.  See the comment under
-        * intrflush().
-        */
+    T((T_CALLED("qiflush(%p)"), (void *) SP_PARM));
+    if ((termp = TerminalOf(SP_PARM)) != 0) {
+       TTY buf;
 
-#ifdef TERMIOS
        BEFORE("qiflush");
-       cur_term->Nttyb.c_lflag &= ~(NOFLSH);
-       AFTER("qiflush");
-       (void)_nc_set_tty_mode( &cur_term->Nttyb);
-       returnVoid;
+       buf = termp->Nttyb;
+#ifdef TERMIOS
+       buf.c_lflag &= (unsigned) ~(NOFLSH);
+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
+#else
+       /* FIXME */
 #endif
+       if (result == OK)
+           termp->Nttyb = buf;
+       AFTER("qiflush");
+    }
+    returnVoid;
 }
 
+#if NCURSES_SP_FUNCS
+NCURSES_EXPORT(void)
+qiflush(void)
+{
+    NCURSES_SP_NAME(qiflush) (CURRENT_SCREEN);
+}
+#endif
 
-int noraw(void)
+NCURSES_EXPORT(int)
+NCURSES_SP_NAME(noraw) (NCURSES_SP_DCL0)
 {
-       T((T_CALLED("noraw()")));
+    int result = ERR;
+    TERMINAL *termp;
 
-       SP->_raw = FALSE;
-       SP->_cbreak = 0;
+    T((T_CALLED("noraw(%p)"), (void *) SP_PARM));
+    if ((termp = TerminalOf(SP_PARM)) != 0) {
+       TTY buf;
 
-#ifdef __EMX__
-       setmode(SP->_ifd, O_TEXT);
-#endif
+       BEFORE("noraw");
+       _nc_setmode(O_TEXT);
 
+       buf = termp->Nttyb;
 #ifdef TERMIOS
-       BEFORE("noraw");
-       cur_term->Nttyb.c_lflag |= ISIG|ICANON;
-       cur_term->Nttyb.c_iflag |= COOKED_INPUT;
-       AFTER("noraw");
+       buf.c_lflag |= ISIG | ICANON |
+           (termp->Ottyb.c_lflag & IEXTEN);
+       buf.c_iflag |= COOKED_INPUT;
 #else
-       cur_term->Nttyb.sg_flags &= ~(RAW|CBREAK);
+       buf.sg_flags &= ~(RAW | CBREAK);
 #endif
-       returnCode(_nc_set_tty_mode( &cur_term->Nttyb));
+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
+       if (result == OK) {
+#if USE_KLIBC_KBD
+           KBDINFO kbdinfo;
+
+           kbdinfo.cb = sizeof(kbdinfo);
+           KbdGetStatus(&kbdinfo, 0);
+
+           kbdinfo.cb = sizeof(kbdinfo);
+           kbdinfo.fsMask &= ~KEYBOARD_BINARY_MODE;
+           kbdinfo.fsMask |= KEYBOARD_ASCII_MODE;
+           KbdSetStatus(&kbdinfo, 0);
+#endif
+           SP_PARM->_raw = FALSE;
+           SP_PARM->_cbreak = 0;
+           termp->Nttyb = buf;
+       }
+       AFTER("noraw");
+    }
+    returnCode(result);
 }
 
+#if NCURSES_SP_FUNCS
+NCURSES_EXPORT(int)
+noraw(void)
+{
+    return NCURSES_SP_NAME(noraw) (CURRENT_SCREEN);
+}
+#endif
 
-int nocbreak(void)
+NCURSES_EXPORT(int)
+NCURSES_SP_NAME(nocbreak) (NCURSES_SP_DCL0)
 {
-       T((T_CALLED("nocbreak()")));
+    int result = ERR;
+    TERMINAL *termp;
 
-       SP->_cbreak = 0;
+    T((T_CALLED("nocbreak(%p)"), (void *) SP_PARM));
+    if ((termp = TerminalOf(SP_PARM)) != 0) {
+       TTY buf;
 
-#ifdef __EMX__
-       setmode(SP->_ifd, O_TEXT);
-#endif
+       BEFORE("nocbreak");
+       _nc_setmode(O_TEXT);
 
+       buf = termp->Nttyb;
 #ifdef TERMIOS
-       BEFORE("nocbreak");
-       cur_term->Nttyb.c_lflag |= ICANON;
-       cur_term->Nttyb.c_iflag |= ICRNL;
-       AFTER("nocbreak");
+       buf.c_lflag |= ICANON;
+       buf.c_iflag |= ICRNL;
 #else
-       cur_term->Nttyb.sg_flags &= ~CBREAK;
+       buf.sg_flags &= ~CBREAK;
 #endif
-       returnCode(_nc_set_tty_mode( &cur_term->Nttyb));
+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
+       if (result == OK) {
+           SP_PARM->_cbreak = 0;
+           termp->Nttyb = buf;
+       }
+       AFTER("nocbreak");
+    }
+    returnCode(result);
+}
+
+#if NCURSES_SP_FUNCS
+NCURSES_EXPORT(int)
+nocbreak(void)
+{
+    return NCURSES_SP_NAME(nocbreak) (CURRENT_SCREEN);
 }
+#endif
 
-void noqiflush(void)
+NCURSES_EXPORT(void)
+NCURSES_SP_NAME(noqiflush) (NCURSES_SP_DCL0)
 {
-       T((T_CALLED("noqiflush()")));
+    int result = ERR;
+    TERMINAL *termp;
 
-       /*
-        * Note: this implementation may be wrong.  See the comment under
-        * intrflush().
-        */
+    T((T_CALLED("noqiflush(%p)"), (void *) SP_PARM));
+    if ((termp = TerminalOf(SP_PARM)) != 0) {
+       TTY buf;
 
-#ifdef TERMIOS
        BEFORE("noqiflush");
-       cur_term->Nttyb.c_lflag |= NOFLSH;
-       AFTER("noqiflush");
-       (void)_nc_set_tty_mode( &cur_term->Nttyb);
-       returnVoid;
+       buf = termp->Nttyb;
+#ifdef TERMIOS
+       buf.c_lflag |= NOFLSH;
+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
+#else
+       /* FIXME */
 #endif
+       if (result == OK)
+           termp->Nttyb = buf;
+       AFTER("noqiflush");
+    }
+    returnVoid;
+}
+
+#if NCURSES_SP_FUNCS
+NCURSES_EXPORT(void)
+noqiflush(void)
+{
+    NCURSES_SP_NAME(noqiflush) (CURRENT_SCREEN);
 }
+#endif
 
-int intrflush(WINDOW *win GCC_UNUSED, bool flag)
+/*
+ * This call does the same thing as the qiflush()/noqiflush() pair.  We know
+ * for certain that SVr3 intrflush() tweaks the NOFLSH bit; on the other hand,
+ * the match (in the SVr4 man pages) between the language describing NOFLSH in
+ * termio(7) and the language describing qiflush()/noqiflush() in
+ * curs_inopts(3x) is too exact to be coincidence.
+ */
+NCURSES_EXPORT(int)
+NCURSES_SP_NAME(intrflush) (NCURSES_SP_DCLx WINDOW *win GCC_UNUSED, bool flag)
 {
-       T((T_CALLED("intrflush(%d)"), flag));
+    int result = ERR;
+    TERMINAL *termp;
 
-       /*
-        * This call does the same thing as the qiflush()/noqiflush()
-        * pair.  We know for certain that SVr3 intrflush() tweaks the
-        * NOFLSH bit; on the other hand, the match (in the SVr4 man
-        * pages) between the language describing NOFLSH in termio(7)
-        * and the language describing qiflush()/noqiflush() in
-        * curs_inopts(3x) is too exact to be coincidence.
-        */
+    T((T_CALLED("intrflush(%p,%d)"), (void *) SP_PARM, flag));
+    if (SP_PARM == 0)
+       returnCode(ERR);
+
+    if ((termp = TerminalOf(SP_PARM)) != 0) {
+       TTY buf;
 
-#ifdef TERMIOS
        BEFORE("intrflush");
+       buf = termp->Nttyb;
+#ifdef TERMIOS
        if (flag)
-               cur_term->Nttyb.c_lflag &= ~(NOFLSH);
+           buf.c_lflag &= (unsigned) ~(NOFLSH);
        else
-               cur_term->Nttyb.c_lflag |= (NOFLSH);
-       AFTER("intrflush");
-       returnCode(_nc_set_tty_mode( &cur_term->Nttyb));
+           buf.c_lflag |= (NOFLSH);
+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
 #else
-       returnCode(ERR);
+       /* FIXME */
 #endif
+       if (result == OK) {
+           termp->Nttyb = buf;
+       }
+       AFTER("intrflush");
+    }
+    returnCode(result);
 }
+
+#if NCURSES_SP_FUNCS
+NCURSES_EXPORT(int)
+intrflush(WINDOW *win GCC_UNUSED, bool flag)
+{
+    return NCURSES_SP_NAME(intrflush) (CURRENT_SCREEN, win, flag);
+}
+#endif