jcs's openbsd hax
openbsd
1/* $OpenBSD: lib_kernel.c,v 1.4 2023/10/17 09:52:09 nicm Exp $ */
2
3/****************************************************************************
4 * Copyright 2020-2022,2023 Thomas E. Dickey *
5 * Copyright 1998-2009,2010 Free Software Foundation, Inc. *
6 * *
7 * Permission is hereby granted, free of charge, to any person obtaining a *
8 * copy of this software and associated documentation files (the *
9 * "Software"), to deal in the Software without restriction, including *
10 * without limitation the rights to use, copy, modify, merge, publish, *
11 * distribute, distribute with modifications, sublicense, and/or sell *
12 * copies of the Software, and to permit persons to whom the Software is *
13 * furnished to do so, subject to the following conditions: *
14 * *
15 * The above copyright notice and this permission notice shall be included *
16 * in all copies or substantial portions of the Software. *
17 * *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS *
19 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF *
20 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. *
21 * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, *
22 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR *
23 * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR *
24 * THE USE OR OTHER DEALINGS IN THE SOFTWARE. *
25 * *
26 * Except as contained in this notice, the name(s) of the above copyright *
27 * holders shall not be used in advertising or otherwise to promote the *
28 * sale, use or other dealings in this Software without prior written *
29 * authorization. *
30 ****************************************************************************/
31
32/****************************************************************************
33 * Author: Zeyd M. Ben-Halim <zmbenhal@netcom.com> 1992,1995 *
34 * and: Eric S. Raymond <esr@snark.thyrsus.com> *
35 * and: Thomas E. Dickey 2002 *
36 * and: Juergen Pfeifer 2009 *
37 ****************************************************************************/
38
39/*
40 * lib_kernel.c
41 *
42 * Misc. low-level routines:
43 * erasechar()
44 * killchar()
45 * flushinp()
46 *
47 * The baudrate() and delay_output() functions could logically live here,
48 * but are in other modules to reduce the static-link size of programs
49 * that use only these facilities.
50 */
51
52#include <curses.priv.h>
53
54MODULE_ID("$Id: lib_kernel.c,v 1.4 2023/10/17 09:52:09 nicm Exp $")
55
56#ifdef TERMIOS
57static int
58_nc_vdisable(void)
59{
60 int value = -1;
61#if defined(_POSIX_VDISABLE) && HAVE_UNISTD_H
62 value = _POSIX_VDISABLE;
63#endif
64#if defined(_PC_VDISABLE) && HAVE_FPATHCONF
65 if (value == -1) {
66 value = (int) fpathconf(0, _PC_VDISABLE);
67 if (value == -1) {
68 value = 0377;
69 }
70 }
71#elif defined(VDISABLE)
72 if (value == -1)
73 value = VDISABLE;
74#endif
75 return value;
76}
77#endif /* TERMIOS */
78
79/*
80 * erasechar()
81 *
82 * Return erase character as given in cur_term->Ottyb.
83 *
84 */
85
86NCURSES_EXPORT(char)
87NCURSES_SP_NAME(erasechar) (NCURSES_SP_DCL0)
88{
89 int result = ERR;
90 TERMINAL *termp = TerminalOf(SP_PARM);
91
92 T((T_CALLED("erasechar(%p)"), (void *) SP_PARM));
93
94 if (termp != 0) {
95#ifdef TERMIOS
96 result = termp->Ottyb.c_cc[VERASE];
97 if (result == _nc_vdisable())
98 result = ERR;
99#elif defined(EXP_WIN32_DRIVER)
100 result = ERR;
101#else
102 result = termp->Ottyb.sg_erase;
103#endif
104 }
105 returnChar((char) result);
106}
107
108#if NCURSES_SP_FUNCS
109NCURSES_EXPORT(char)
110erasechar(void)
111{
112 return NCURSES_SP_NAME(erasechar) (CURRENT_SCREEN);
113}
114#endif
115
116/*
117 * killchar()
118 *
119 * Return kill character as given in cur_term->Ottyb.
120 *
121 */
122
123NCURSES_EXPORT(char)
124NCURSES_SP_NAME(killchar) (NCURSES_SP_DCL0)
125{
126 int result = ERR;
127 TERMINAL *termp = TerminalOf(SP_PARM);
128
129 T((T_CALLED("killchar(%p)"), (void *) SP_PARM));
130
131 if (termp != 0) {
132#ifdef TERMIOS
133 result = termp->Ottyb.c_cc[VKILL];
134 if (result == _nc_vdisable())
135 result = ERR;
136#elif defined(EXP_WIN32_DRIVER)
137 result = ERR;
138#else
139 result = termp->Ottyb.sg_kill;
140#endif
141 }
142 returnChar((char) result);
143}
144
145#if NCURSES_SP_FUNCS
146NCURSES_EXPORT(char)
147killchar(void)
148{
149 return NCURSES_SP_NAME(killchar) (CURRENT_SCREEN);
150}
151#endif
152
153static void
154flush_input(int fd)
155{
156#ifdef TERMIOS
157 tcflush(fd, TCIFLUSH);
158#else /* !TERMIOS */
159 errno = 0;
160 do {
161#if defined(EXP_WIN32_DRIVER)
162 _nc_console_flush(_nc_console_fd2handle(fd));
163#else
164 ioctl(fd, TIOCFLUSH, 0);
165#endif
166 } while
167 (errno == EINTR);
168#endif
169}
170
171/*
172 * flushinp()
173 *
174 * Flush any input on tty
175 */
176
177NCURSES_EXPORT(int)
178NCURSES_SP_NAME(flushinp) (NCURSES_SP_DCL0)
179{
180 T((T_CALLED("flushinp(%p)"), (void *) SP_PARM));
181
182 if (SP_PARM != 0) {
183 if (NC_ISATTY(SP_PARM->_ifd))
184 flush_input(SP_PARM->_ifd);
185 else if (NC_ISATTY(SP_PARM->_ofd))
186 flush_input(SP_PARM->_ofd);
187 if (SP_PARM) {
188 SP_PARM->_fifohead = -1;
189 SP_PARM->_fifotail = 0;
190 SP_PARM->_fifopeek = 0;
191 }
192 returnCode(OK);
193 }
194 returnCode(ERR);
195}
196
197#if NCURSES_SP_FUNCS
198NCURSES_EXPORT(int)
199flushinp(void)
200{
201 return NCURSES_SP_NAME(flushinp) (CURRENT_SCREEN);
202}
203#endif