Replace `iff' in comments.
[bpt/emacs.git] / src / systty.h
CommitLineData
a04c9535 1/* systty.h - System-dependent definitions for terminals.
429ab54e
GM
2 Copyright (C) 1993, 1994, 2001, 2002, 2003, 2004,
3 2005, 2006, 2007 Free Software Foundation, Inc.
d0d6b7c5
JB
4
5This file is part of GNU Emacs.
6
7GNU Emacs is free software; you can redistribute it and/or modify
8it under the terms of the GNU General Public License as published by
684d6f5b 9the Free Software Foundation; either version 3, or (at your option)
d0d6b7c5
JB
10any later version.
11
12GNU Emacs is distributed in the hope that it will be useful,
13but WITHOUT ANY WARRANTY; without even the implied warranty of
14MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15GNU General Public License for more details.
16
17You should have received a copy of the GNU General Public License
18along with GNU Emacs; see the file COPYING. If not, write to
4fc5845f
LK
19the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
20Boston, MA 02110-1301, USA. */
d0d6b7c5 21
2182d459
RS
22#ifdef HAVE_TERMIOS
23#define HAVE_TCATTR
24#endif
7f6d476f 25
d0d6b7c5
JB
26\f
27/* Include the proper files. */
28#ifdef HAVE_TERMIO
0674a1f9
JB
29#ifdef __DGUX
30#include <sys/ioctl.h>
31#endif
d2d846a3 32#ifndef NO_TERMIO
d0d6b7c5 33#include <termio.h>
d2d846a3 34#endif /* not NO_TERMIO */
92ea836d 35#ifndef INCLUDED_FCNTL
b65e3dd7 36#define INCLUDED_FCNTL
d0d6b7c5 37#include <fcntl.h>
92ea836d
RS
38#endif
39#else /* not HAVE_TERMIO */
d0d6b7c5 40#ifdef HAVE_TERMIOS
3580badc
RS
41#if defined(_AIX) && defined(_I386)
42#include <termios.h> /* termios.h needs to be before termio.h */
43#include <termio.h>
ab9ba9ea 44#else /* not (_AIX && _I386) */
c62e9958 45#ifndef NO_TERMIO
d0d6b7c5 46#include <termio.h>
c62e9958 47#endif
d0d6b7c5 48#include <termios.h>
ab9ba9ea 49#endif /* not (_AIX && _I386) */
b65e3dd7 50#define INCLUDED_FCNTL
1aaaff21 51#include <fcntl.h>
d0d6b7c5
JB
52#else /* neither HAVE_TERMIO nor HAVE_TERMIOS */
53#ifndef VMS
101adcb5 54#ifndef DOS_NT
d0d6b7c5 55#include <sgtty.h>
101adcb5 56#endif /* not DOS_NT */
a04c9535
JB
57#else /* VMS */
58#include <descrip.h>
59static struct iosb
60{
61 short status;
62 short offset;
63 short termlen;
64 short term;
65} input_iosb;
66
67extern int waiting_for_ast;
68extern int stop_input;
210b2b4f
JB
69extern int input_ef;
70extern int timer_ef;
71extern int process_ef;
a04c9535
JB
72extern int input_eflist;
73extern int timer_eflist;
74
75static $DESCRIPTOR (input_dsc, "TT");
76static int terminator_mask[2] = { 0, 0 };
77
78static struct sensemode {
79 short status;
80 unsigned char xmit_baud;
81 unsigned char rcv_baud;
82 unsigned char crfill;
83 unsigned char lffill;
84 unsigned char parity;
85 unsigned char unused;
86 char class;
87 char type;
88 short scr_wid;
89 unsigned long tt_char : 24, scr_len : 8;
90 unsigned long tt2_char;
91} sensemode_iosb;
92#endif /* VMS */
d0d6b7c5
JB
93#endif /* not HAVE_TERMIOS */
94#endif /* not HAVE_TERMIO */
95
c9b67b7b 96#ifdef __GNU_LIBRARY__
c3ff76c4 97#include <sys/ioctl.h>
c9b67b7b
RM
98#include <termios.h>
99#endif
100
8e0ecd77 101#ifdef AIXHFT
4746118a
JB
102/* Get files for keyboard remapping */
103#define HFNKEYS 2
104#include <sys/hft.h>
105#include <sys/devinfo.h>
106#endif
107
108/* Get rid of LLITOUT in 4.1, since it is said to stimulate kernel bugs. */
109#ifdef BSD4_1
110#undef LLITOUT
111#define LLITOUT 0
112#endif /* 4.1 */
113
114#ifdef NEED_BSDTTY
115#include <sys/bsdtty.h>
177c0ea7 116#endif
4746118a
JB
117
118#if defined (HPUX) && defined (HAVE_PTYS)
119#include <sys/ptyio.h>
120#endif
378ac314 121
4746118a
JB
122#ifdef AIX
123#include <sys/pty.h>
4746118a
JB
124#endif /* AIX */
125
378ac314 126#if (defined (POSIX) || defined (NEED_UNISTD_H)) && defined (HAVE_UNISTD_H)
9825c716 127#include <unistd.h>
5ab57b9f
RS
128#endif
129
4746118a 130#ifdef SYSV_PTYS
8243aa4e 131#include <sys/types.h>
4746118a 132#include <sys/tty.h>
ffd56f97
JB
133#ifdef titan
134#include <sys/ttyhw.h>
135#include <sys/stream.h>
136#endif
372d3c2e 137#ifndef NO_PTY_H
4746118a
JB
138#include <sys/pty.h>
139#endif
372d3c2e 140#endif
4746118a
JB
141
142/* saka@pfu.fujitsu.co.JP writes:
143 FASYNC defined in this file. But, FASYNC don't working.
144 so no problem, because unrequest_sigio only need. */
145#if defined (pfa)
146#include <sys/file.h>
147#endif
148
d0d6b7c5
JB
149\f
150/* Special cases - inhibiting the use of certain features. */
151
152#ifdef APOLLO
153#undef TIOCSTART
154#endif
155
ffd56f97
JB
156#ifdef XENIX
157#undef TIOCGETC /* Avoid confusing some conditionals that test this. */
158#endif
159
d0d6b7c5
JB
160#ifdef BROKEN_TIOCGETC
161#undef TIOCGETC /* Avoid confusing some conditionals that test this. */
162#endif
163
164/* UNIPLUS systems may have FIONREAD. */
165#ifdef UNIPLUS
166#include <sys.ioctl.h>
167#endif
168
169/* Allow m- file to inhibit use of FIONREAD. */
170#ifdef BROKEN_FIONREAD
171#undef FIONREAD
172#undef ASYNC
173#endif
174
eb8c3be9 175/* Interrupt input is not used if there is no FIONREAD. */
d0d6b7c5
JB
176#ifndef FIONREAD
177#undef SIGIO
178#endif
179
50b8cf60
JB
180/* On TERMIOS systems, the tcmumbleattr calls take care of these
181 parameters, and it's a bad idea to use them (on AIX, it makes the
c39d651c 182 tty hang for a long time). */
50b8cf60
JB
183#if defined (TIOCGLTC) && !defined (HAVE_TERMIOS)
184#define HAVE_LTCHARS
185#endif
186
187#if defined (TIOCGETC) && !defined (HAVE_TERMIOS)
188#define HAVE_TCHARS
189#endif
190
d0d6b7c5 191\f
2102829e
RS
192/* Try to establish the correct character to disable terminal functions
193 in a system-independent manner. Note that USG (at least) define
194 _POSIX_VDISABLE as 0! */
195
196#ifdef _POSIX_VDISABLE
197#define CDISABLE _POSIX_VDISABLE
198#else /* not _POSIX_VDISABLE */
199#ifdef CDEL
d04e8e46 200#undef CDISABLE
2102829e
RS
201#define CDISABLE CDEL
202#else /* not CDEL */
203#define CDISABLE 255
204#endif /* not CDEL */
205#endif /* not _POSIX_VDISABLE */
206\f
d0d6b7c5
JB
207/* Get the number of characters queued for output. */
208
209/* EMACS_OUTQSIZE(FD, int *SIZE) stores the number of characters
210 queued for output to the terminal FD in *SIZE, if FD is a tty.
211 Returns -1 if there was an error (i.e. FD is not a tty), 0
212 otherwise. */
213#ifdef TIOCOUTQ
214#define EMACS_OUTQSIZE(fd, size) (ioctl ((fd), TIOCOUTQ, (size)))
215#endif
216
217#ifdef HAVE_TERMIO
218#ifdef TCOUTQ
219#undef EMACS_OUTQSIZE
220#define EMACS_OUTQSIZE(fd, size) (ioctl ((fd), TCOUTQ, (size)))
221#endif
222#endif
223
224\f
225/* Manipulate a terminal's current process group. */
226
227/* EMACS_HAVE_TTY_PGRP is true if we can get and set the tty's current
228 controlling process group.
229
230 EMACS_GET_TTY_PGRP(int FD, int *PGID) sets *PGID the terminal FD's
231 current process group. Return -1 if there is an error.
232
233 EMACS_SET_TTY_PGRP(int FD, int *PGID) sets the terminal FD's
234 current process group to *PGID. Return -1 if there is an error. */
235
ffd56f97
JB
236#ifdef HPUX
237/* HPUX tty process group stuff doesn't work, says the anonymous voice
238 from the past. */
239#else
d0d6b7c5
JB
240#ifdef TIOCGPGRP
241#define EMACS_HAVE_TTY_PGRP
242#else
243#ifdef HAVE_TERMIOS
244#define EMACS_HAVE_TTY_PGRP
245#endif
246#endif
ffd56f97 247#endif
d0d6b7c5
JB
248
249#ifdef EMACS_HAVE_TTY_PGRP
250
75bb6750 251#if defined (HAVE_TERMIOS) && ! defined (BSD_TERMIOS)
d0d6b7c5
JB
252
253#define EMACS_GET_TTY_PGRP(fd, pgid) (*(pgid) = tcgetpgrp ((fd)))
161aa2f8 254#define EMACS_SET_TTY_PGRP(fd, pgid) (tcsetpgrp ((fd), *(pgid)))
d0d6b7c5
JB
255
256#else
257#ifdef TIOCSPGRP
258
259#define EMACS_GET_TTY_PGRP(fd, pgid) (ioctl ((fd), TIOCGPGRP, (pgid)))
260#define EMACS_SET_TTY_PGRP(fd, pgid) (ioctl ((fd), TIOCSPGRP, (pgid)))
261
262#endif
263#endif
264
265#else
266
267/* Just ignore this for now and hope for the best */
268#define EMACS_GET_TTY_PGRP(fd, pgid) 0
ef15f270 269#define EMACS_SET_TTY_PGRP(fd, pgif) 0
d0d6b7c5
JB
270
271#endif
272
281bbdfb 273/* EMACS_GETPGRP (arg) returns the process group of the process. */
727b007c 274
f7ff70e8 275#if defined (GETPGRP_VOID)
727b007c
RS
276# define EMACS_GETPGRP(x) getpgrp()
277#else
278# define EMACS_GETPGRP(x) getpgrp(x)
f7ff70e8 279#endif /* !GETPGRP_VOID */
d0d6b7c5
JB
280\f
281/* Manipulate a TTY's input/output processing parameters. */
282
283/* struct emacs_tty is a structure used to hold the current tty
284 parameters. If the terminal has several structures describing its
285 state, for example a struct tchars, a struct sgttyb, a struct
286 tchars, a struct ltchars, and a struct pagechars, struct
287 emacs_tty should contain an element for each parameter struct
288 that Emacs may change.
289
1334b321
JB
290 EMACS_GET_TTY (int FD, struct emacs_tty *P) stores the parameters
291 of the tty on FD in *P. Return zero if all's well, or -1 if we ran
292 into an error we couldn't deal with.
d0d6b7c5 293
1bf61ff9 294 EMACS_SET_TTY (int FD, struct emacs_tty *P, int flushp)
d0d6b7c5 295 sets the parameters of the tty on FD according to the contents of
1bf61ff9
RS
296 *P. If flushp is non-zero, we discard queued input to be
297 written before making the change.
1334b321 298 Return 0 if all went well, and -1 if anything failed.
d0d6b7c5 299
e0f24100 300 EMACS_TTY_TABS_OK (struct emacs_tty *P) is false if the kernel
d0d6b7c5
JB
301 expands tabs to spaces upon output; in that case, there is no
302 advantage to using tabs over spaces. */
303
304
d0d6b7c5 305/* For each tty parameter structure that Emacs might want to save and restore,
1334b321
JB
306 - include an element for it in this structure, and
307 - extend the emacs_{get,set}_tty functions in sysdep.c to deal with the
308 new members. */
d0d6b7c5
JB
309
310struct emacs_tty {
311
312/* There is always one of the following elements, so there is no need
313 for dummy get and set definitions. */
2182d459 314#ifdef HAVE_TCATTR
d0d6b7c5
JB
315 struct termios main;
316#else
317#ifdef HAVE_TERMIO
318 struct termio main;
319#else
320#ifdef VMS
321 struct sensemode main;
8e99c732 322#else
101adcb5 323#ifdef DOS_NT
8e99c732 324 int main;
101adcb5 325#else /* not DOS_NT */
d0d6b7c5 326 struct sgttyb main;
101adcb5 327#endif /* not DOS_NT */
d0d6b7c5
JB
328#endif
329#endif
8e99c732 330#endif
50b8cf60
JB
331
332/* If we have TERMIOS, we don't need to do this - they're taken care of
333 by the tc*attr calls. */
334#ifndef HAVE_TERMIOS
335#ifdef HAVE_LTCHARS
2182d459
RS
336 struct ltchars ltchars;
337#endif
50b8cf60
JB
338
339#ifdef HAVE_TCHARS
2182d459
RS
340 struct tchars tchars;
341 int lmode;
d0d6b7c5 342#endif
50b8cf60 343#endif
2182d459
RS
344};
345\f
346/* Define EMACS_GET_TTY and EMACS_SET_TTY,
c2e4f49a 347 the macros for reading and setting parts of `struct emacs_tty'.
d0d6b7c5 348
c2e4f49a
JB
349 These got pretty unmanageable (huge macros are hard to debug), and
350 finally needed some code which couldn't be done as part of an
351 expression, so we moved them out to their own functions in sysdep.c. */
352#define EMACS_GET_TTY(fd, p) (emacs_get_tty ((fd), (p)))
353#define EMACS_SET_TTY(fd, p, waitp) (emacs_set_tty ((fd), (p), (waitp)))
4c571d09
AS
354#ifdef P_ /* Unfortunately this file is sometimes included before lisp.h */
355extern int emacs_get_tty P_ ((int, struct emacs_tty *));
356extern int emacs_set_tty P_ ((int, struct emacs_tty *, int));
357#endif
d0d6b7c5 358
2182d459
RS
359\f
360/* Define EMACS_TTY_TABS_OK. */
d0d6b7c5
JB
361
362#ifdef HAVE_TERMIOS
363
c7040669 364#ifdef TABDLY
d0d6b7c5 365#define EMACS_TTY_TABS_OK(p) (((p)->main.c_oflag & TABDLY) != TAB3)
c7040669
RS
366#else
367#define EMACS_TTY_TABS_OK(p) 1
368#endif
d0d6b7c5
JB
369
370#else /* not def HAVE_TERMIOS */
371#ifdef HAVE_TERMIO
372
373#define EMACS_TTY_TABS_OK(p) (((p)->main.c_oflag & TABDLY) != TAB3)
374
375#else /* neither HAVE_TERMIO nor HAVE_TERMIOS */
376#ifdef VMS
377
378#define EMACS_TTY_TABS_OK(p) (((p)->main.tt_char & TT$M_MECHTAB) != 0)
379
380#else
381
101adcb5 382#ifdef DOS_NT
8e99c732 383#define EMACS_TTY_TABS_OK(p) 0
101adcb5 384#else /* not DOS_NT */
d0d6b7c5 385#define EMACS_TTY_TABS_OK(p) (((p)->main.sg_flags & XTABS) != XTABS)
101adcb5 386#endif /* not DOS_NT */
d0d6b7c5
JB
387
388#endif /* not def VMS */
389#endif /* not def HAVE_TERMIO */
390#endif /* not def HAVE_TERMIOS */
ab5796a9
MB
391
392/* arch-tag: cf4b90bc-be41-401c-be98-40619178a712
393 (do not change this comment) */