blob: e2dbb37c37c2e62c0275047efc6b8c183b7d3eb2 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
#include "irix3-3.h"
#define USG5_3
#define IRIX4
#define HAVE_ALLOCA
#ifndef NOT_C_CODE
#include <alloca.h>
#endif
#undef IRIS_UTIME
#undef NEED_SIOCTL
/* Make process_send_signal work by "typing" a signal character on the pty. */
#define SIGNALS_VIA_CHARACTERS
/* use K&R C */
#ifndef __GNUC__
#define C_SWITCH_MACHINE -cckr
#endif
/* SGI has all the fancy wait stuff, but we can't include sys/wait.h
because it defines BIG_ENDIAN and LITTLE_ENDIAN (ugh!.) Instead
we'll just define WNOHANG right here.
(An implicit decl is good enough for wait3.) */
#define WNOHANG 0x1
/* No need to use sprintf to get the tty name--we get that from _getpty. */
#undef PTY_TTY_NAME_SPRINTF
#define PTY_TTY_NAME_SPRINTF
/* No need to get the pty name at all. */
#define PTY_NAME_SPRINTF
/* We need only try once to open a pty. */
#define PTY_ITERATION
/* Here is how to do it. */
/* It is necessary to prevent SIGCHLD signals within _getpty.
So we block them. */
#define PTY_OPEN \
{ \
int mask = sigblock (sigmask (SIGCHLD)); \
char *name = _getpty (&fd, O_RDWR | O_NDELAY, 0600, 0); \
sigsetmask(mask); \
if (name == 0) \
return -1; \
if (fd < 0) \
return -1; \
if (fstat (fd, &stb) < 0) \
return -1; \
strcpy (pty_name, name); \
}
/* Use the BSD versions of the getpgrp and setpgrp functions. */
#define setpgrp(pid, pgrp) BSDsetpgrp((pid), (pgrp))
#define getpgrp(pid) BSDgetpgrp(pid)
/* jpff@maths.bath.ac.uk reports `struct exception' is not defined
on this system, so inhibit use of matherr. */
#define NO_MATHERR
|