annotate src/process.c @ 44029:aa071cceb8e0

described the new "=" fiture.
author Michael Kifer <kifer@cs.stonybrook.edu>
date Wed, 20 Mar 2002 06:41:51 +0000
parents da239fc7bb6c
children e2339254ba48
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1 /* Asynchronous subprocess control for GNU Emacs.
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2 Copyright (C) 1985, 86, 87, 88, 93, 94, 95, 96, 98, 1999,
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3 2001, 2002 Free Software Foundation, Inc.
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5 This file is part of GNU Emacs.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
7 GNU Emacs is free software; you can redistribute it and/or modify
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
8 it under the terms of the GNU General Public License as published by
1780
d01c59bac5c1 * frame.h (FRAME_SAMPLE_VISIBILITY): Make sure frame is marked as
Jim Blandy <jimb@redhat.com>
parents: 1683
diff changeset
9 the Free Software Foundation; either version 2, or (at your option)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
10 any later version.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
11
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
12 GNU Emacs is distributed in the hope that it will be useful,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
15 GNU General Public License for more details.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
16
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
18 along with GNU Emacs; see the file COPYING. If not, write to
14186
ee40177f6c68 Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents: 14131
diff changeset
19 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
ee40177f6c68 Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents: 14131
diff changeset
20 Boston, MA 02111-1307, USA. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
21
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
22
26313
9275b6adbad2 Undo last change and define _GNU_SOURCE before config.h.
Dave Love <fx@gnu.org>
parents: 26311
diff changeset
23 #define _GNU_SOURCE /* to get strsignal declared with glibc 2 */
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
24 #include <config.h>
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
25 #include <signal.h>
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
26
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
27 /* This file is split into two parts by the following preprocessor
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
28 conditional. The 'then' clause contains all of the support for
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
29 asynchronous subprocesses. The 'else' clause contains stub
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
30 versions of some of the asynchronous subprocess routines that are
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
31 often called elsewhere in Emacs, so we don't have to #ifdef the
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
32 sections that call them. */
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
33
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
34
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
35 #ifdef subprocesses
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
36
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
37 #include <stdio.h>
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
38 #include <errno.h>
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
39 #include <setjmp.h>
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
40 #include <sys/types.h> /* some typedefs are used in sys/file.h */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
41 #include <sys/file.h>
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
42 #include <sys/stat.h>
6158
6b81b2575071 Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 5891
diff changeset
43 #ifdef HAVE_UNISTD_H
6b81b2575071 Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 5891
diff changeset
44 #include <unistd.h>
6b81b2575071 Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 5891
diff changeset
45 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
46
29035
95e767e77a88 (toplevel) [UNIX98_PTYS]: Include stdlib.h.
Gerd Moellmann <gerd@gnu.org>
parents: 29017
diff changeset
47 #if defined(WINDOWSNT) || defined(UNIX98_PTYS)
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
48 #include <stdlib.h>
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
49 #include <fcntl.h>
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
50 #endif /* not WINDOWSNT */
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
51
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
52 #ifdef HAVE_SOCKETS /* TCP connection support, if kernel can do it */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
53 #include <sys/socket.h>
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
54 #include <netdb.h>
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
55 #include <netinet/in.h>
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
56 #include <arpa/inet.h>
12749
ce48ec025b0a Maybe include net/errno.h.
Richard M. Stallman <rms@gnu.org>
parents: 12648
diff changeset
57 #ifdef NEED_NET_ERRNO_H
ce48ec025b0a Maybe include net/errno.h.
Richard M. Stallman <rms@gnu.org>
parents: 12648
diff changeset
58 #include <net/errno.h>
ce48ec025b0a Maybe include net/errno.h.
Richard M. Stallman <rms@gnu.org>
parents: 12648
diff changeset
59 #endif /* NEED_NET_ERRNO_H */
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
60
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
61 /* Are local (unix) sockets supported? */
43999
177616cff62b Define HAVE_LOCAL_SOCKETS based on HAVE_SYS_UN_H.
Kim F. Storm <storm@cua.dk>
parents: 43995
diff changeset
62 #if defined (HAVE_SYS_UN_H) && !defined (NO_SOCKETS_IN_FILE_SYSTEM)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
63 #if !defined (AF_LOCAL) && defined (AF_UNIX)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
64 #define AF_LOCAL AF_UNIX
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
65 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
66 #ifdef AF_LOCAL
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
67 #define HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
68 #include <sys/un.h>
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
69 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
70 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
71 #endif /* HAVE_SOCKETS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
72
26313
9275b6adbad2 Undo last change and define _GNU_SOURCE before config.h.
Dave Love <fx@gnu.org>
parents: 26311
diff changeset
73 /* TERM is a poor-man's SLIP, used on GNU/Linux. */
4914
56bc426b1eb4 [TERM]: Include client.h.
Richard M. Stallman <rms@gnu.org>
parents: 4883
diff changeset
74 #ifdef TERM
56bc426b1eb4 [TERM]: Include client.h.
Richard M. Stallman <rms@gnu.org>
parents: 4883
diff changeset
75 #include <client.h>
56bc426b1eb4 [TERM]: Include client.h.
Richard M. Stallman <rms@gnu.org>
parents: 4883
diff changeset
76 #endif
56bc426b1eb4 [TERM]: Include client.h.
Richard M. Stallman <rms@gnu.org>
parents: 4883
diff changeset
77
7238
c9598edda1a2 (IN_ADDR, NUMERIC_ADDR_ERROR): Made conditional on HAVE_BROKEN_INET_ADDR.
Paul Reilly <pmr@pajato.com>
parents: 7220
diff changeset
78 /* On some systems, e.g. DGUX, inet_addr returns a 'struct in_addr'. */
c9598edda1a2 (IN_ADDR, NUMERIC_ADDR_ERROR): Made conditional on HAVE_BROKEN_INET_ADDR.
Paul Reilly <pmr@pajato.com>
parents: 7220
diff changeset
79 #ifdef HAVE_BROKEN_INET_ADDR
4998
3cd3a39f98f4 (IN_ADDR, NUMERIC_ADDR_ERROR): New macros (two versions).
Richard M. Stallman <rms@gnu.org>
parents: 4994
diff changeset
80 #define IN_ADDR struct in_addr
3cd3a39f98f4 (IN_ADDR, NUMERIC_ADDR_ERROR): New macros (two versions).
Richard M. Stallman <rms@gnu.org>
parents: 4994
diff changeset
81 #define NUMERIC_ADDR_ERROR (numeric_addr.s_addr == -1)
3cd3a39f98f4 (IN_ADDR, NUMERIC_ADDR_ERROR): New macros (two versions).
Richard M. Stallman <rms@gnu.org>
parents: 4994
diff changeset
82 #else
3cd3a39f98f4 (IN_ADDR, NUMERIC_ADDR_ERROR): New macros (two versions).
Richard M. Stallman <rms@gnu.org>
parents: 4994
diff changeset
83 #define IN_ADDR unsigned long
3cd3a39f98f4 (IN_ADDR, NUMERIC_ADDR_ERROR): New macros (two versions).
Richard M. Stallman <rms@gnu.org>
parents: 4994
diff changeset
84 #define NUMERIC_ADDR_ERROR (numeric_addr == -1)
3cd3a39f98f4 (IN_ADDR, NUMERIC_ADDR_ERROR): New macros (two versions).
Richard M. Stallman <rms@gnu.org>
parents: 4994
diff changeset
85 #endif
3cd3a39f98f4 (IN_ADDR, NUMERIC_ADDR_ERROR): New macros (two versions).
Richard M. Stallman <rms@gnu.org>
parents: 4994
diff changeset
86
16220
02044b05d8e0 Replaced symbol BSD with BSD_SYSTEM.
Karl Heuer <kwzh@gnu.org>
parents: 16206
diff changeset
87 #if defined(BSD_SYSTEM) || defined(STRIDE)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
88 #include <sys/ioctl.h>
1012
a48ed1d416dd * process.c (process_send_signal): Don't send SIGTSTP if the
Jim Blandy <jimb@redhat.com>
parents: 849
diff changeset
89 #if !defined (O_NDELAY) && defined (HAVE_PTYS) && !defined(USG5)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
90 #include <fcntl.h>
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
91 #endif /* HAVE_PTYS and no O_NDELAY */
16220
02044b05d8e0 Replaced symbol BSD with BSD_SYSTEM.
Karl Heuer <kwzh@gnu.org>
parents: 16206
diff changeset
92 #endif /* BSD_SYSTEM || STRIDE */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
93
5240
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
94 #ifdef BROKEN_O_NONBLOCK
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
95 #undef O_NONBLOCK
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
96 #endif /* BROKEN_O_NONBLOCK */
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
97
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
98 #ifdef NEED_BSDTTY
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
99 #include <bsdtty.h>
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
100 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
101
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
102 #ifdef IRIS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
103 #include <sys/sysmacros.h> /* for "minor" */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
104 #endif /* not IRIS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
105
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
106 #include "systime.h"
1047
1ab1ed32e82a * process.c: Include "systty.h", not "systerm.h".
Jim Blandy <jimb@redhat.com>
parents: 1030
diff changeset
107 #include "systty.h"
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
108
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
109 #include "lisp.h"
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
110 #include "window.h"
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
111 #include "buffer.h"
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
112 #include "charset.h"
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
113 #include "coding.h"
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
114 #include "process.h"
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
115 #include "termhooks.h"
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
116 #include "termopts.h"
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
117 #include "commands.h"
31099
0fe5afca71e4 Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents: 30582
diff changeset
118 #include "keyboard.h"
1780
d01c59bac5c1 * frame.h (FRAME_SAMPLE_VISIBILITY): Make sure frame is marked as
Jim Blandy <jimb@redhat.com>
parents: 1683
diff changeset
119 #include "frame.h"
16780
e9dc2569cb12 Include blockinput.h.
Richard M. Stallman <rms@gnu.org>
parents: 16728
diff changeset
120 #include "blockinput.h"
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
121 #include "dispextern.h"
26868
edeeffd7d8c7 Include composite.h.
Kenichi Handa <handa@m17n.org>
parents: 26526
diff changeset
122 #include "composite.h"
27430
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
123 #include "atimer.h"
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
124
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
125 Lisp_Object Qprocessp;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
126 Lisp_Object Qrun, Qstop, Qsignal;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
127 Lisp_Object Qopen, Qclosed, Qconnect, Qfailed, Qlisten;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
128 Lisp_Object Qlocal;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
129 Lisp_Object QCname, QCbuffer, QChost, QCservice, QCfamily;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
130 Lisp_Object QClocal, QCremote, QCcoding;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
131 Lisp_Object QCserver, QCdatagram, QCnowait, QCnoquery, QCstop;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
132 Lisp_Object QCfilter, QCsentinel, QClog, QCoptions, QCfeature;
8231
5226ed89c1a6 (Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8063
diff changeset
133 Lisp_Object Qlast_nonmenu_event;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
134 /* Qexit is declared and initialized in eval.c. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
135
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
136 /* a process object is a network connection when its childp field is neither
16058
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
137 Qt nor Qnil but is instead a cons cell (HOSTNAME PORTNUM). */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
138
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
139 #ifdef HAVE_SOCKETS
16058
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
140 #define NETCONN_P(p) (GC_CONSP (XPROCESS (p)->childp))
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
141 #define NETCONN1_P(p) (GC_CONSP ((p)->childp))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
142 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
143 #define NETCONN_P(p) 0
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
144 #define NETCONN1_P(p) 0
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
145 #endif /* HAVE_SOCKETS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
146
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
147 /* Define first descriptor number available for subprocesses. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
148 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
149 #define FIRST_PROC_DESC 1
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
150 #else /* Not VMS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
151 #define FIRST_PROC_DESC 3
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
152 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
153
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
154 /* Define SIGCHLD as an alias for SIGCLD. There are many conditionals
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
155 testing SIGCHLD. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
156
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
157 #if !defined (SIGCHLD) && defined (SIGCLD)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
158 #define SIGCHLD SIGCLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
159 #endif /* SIGCLD */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
160
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
161 #include "syssignal.h"
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
162
4639
76f242eb1fa8 Include syswait.h.
Richard M. Stallman <rms@gnu.org>
parents: 4320
diff changeset
163 #include "syswait.h"
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
164
25770
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
165 extern void set_waiting_for_input P_ ((EMACS_TIME *));
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
166
31099
0fe5afca71e4 Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents: 30582
diff changeset
167 #ifndef USE_CRT_DLL
5543
dbc1d920ef5c Don't declare sys_nerr.
Roland McGrath <roland@gnu.org>
parents: 5534
diff changeset
168 extern int errno;
31099
0fe5afca71e4 Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents: 30582
diff changeset
169 #endif
5543
dbc1d920ef5c Don't declare sys_nerr.
Roland McGrath <roland@gnu.org>
parents: 5534
diff changeset
170 #ifdef VMS
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
171 extern char *sys_errlist[];
5543
dbc1d920ef5c Don't declare sys_nerr.
Roland McGrath <roland@gnu.org>
parents: 5534
diff changeset
172 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
173
8331
14ddb4c66461 [!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents: 8287
diff changeset
174 #ifndef HAVE_H_ERRNO
14ddb4c66461 [!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents: 8287
diff changeset
175 extern int h_errno;
14ddb4c66461 [!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents: 8287
diff changeset
176 #endif
14ddb4c66461 [!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents: 8287
diff changeset
177
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
178 /* t means use pty, nil means use a pipe,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
179 maybe other values to come. */
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
180 static Lisp_Object Vprocess_connection_type;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
181
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
182 #ifdef SKTPAIR
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
183 #ifndef HAVE_SOCKETS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
184 #include <sys/socket.h>
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
185 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
186 #endif /* SKTPAIR */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
187
10548
dcae4394587d (process_tick, update_tick): Make non-static.
Karl Heuer <kwzh@gnu.org>
parents: 10527
diff changeset
188 /* These next two vars are non-static since sysdep.c uses them in the
dcae4394587d (process_tick, update_tick): Make non-static.
Karl Heuer <kwzh@gnu.org>
parents: 10527
diff changeset
189 emulation of `select'. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
190 /* Number of events of change of status of a process. */
10548
dcae4394587d (process_tick, update_tick): Make non-static.
Karl Heuer <kwzh@gnu.org>
parents: 10527
diff changeset
191 int process_tick;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
192 /* Number of events for which the user or sentinel has been notified. */
10548
dcae4394587d (process_tick, update_tick): Make non-static.
Karl Heuer <kwzh@gnu.org>
parents: 10527
diff changeset
193 int update_tick;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
194
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
195 /* Define NON_BLOCKING_CONNECT if we can support non-blocking connects. */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
196
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
197 #ifdef BROKEN_NON_BLOCKING_CONNECT
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
198 #undef NON_BLOCKING_CONNECT
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
199 #else
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
200 #ifndef NON_BLOCKING_CONNECT
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
201 #ifdef HAVE_SOCKETS
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
202 #ifdef HAVE_SELECT
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
203 #if defined (HAVE_GETPEERNAME) || defined (GNU_LINUX)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
204 #if defined (O_NONBLOCK) || defined (O_NDELAY)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
205 #if defined (EWOULDBLOCK) || defined (EINPROGRESS)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
206 #define NON_BLOCKING_CONNECT
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
207 #endif /* EWOULDBLOCK || EINPROGRESS */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
208 #endif /* O_NONBLOCK || O_NDELAY */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
209 #endif /* HAVE_GETPEERNAME || GNU_LINUX */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
210 #endif /* HAVE_SELECT */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
211 #endif /* HAVE_SOCKETS */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
212 #endif /* NON_BLOCKING_CONNECT */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
213 #endif /* BROKEN_NON_BLOCKING_CONNECT */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
214
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
215 /* Define DATAGRAM_SOCKETS if datagrams can be used safely on
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
216 this system. We need to read full packets, so we need a
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
217 "non-destructive" select. So we require either native select,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
218 or emulation of select using FIONREAD. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
219
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
220 #ifdef BROKEN_DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
221 #undef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
222 #else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
223 #ifndef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
224 #ifdef HAVE_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
225 #if defined (HAVE_SELECT) || defined (FIONREAD)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
226 #if defined (HAVE_SENDTO) && defined (HAVE_RECVFROM) && defined (EMSGSIZE)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
227 #define DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
228 #endif /* HAVE_SENDTO && HAVE_RECVFROM && EMSGSIZE */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
229 #endif /* HAVE_SELECT || FIONREAD */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
230 #endif /* HAVE_SOCKETS */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
231 #endif /* DATAGRAM_SOCKETS */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
232 #endif /* BROKEN_DATAGRAM_SOCKETS */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
233
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
234 #ifdef TERM
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
235 #undef NON_BLOCKING_CONNECT
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
236 #undef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
237 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
238
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
239
10527
68b8191091a7 #include sysselect.h instead of defining things by hand.
Karl Heuer <kwzh@gnu.org>
parents: 10032
diff changeset
240 #include "sysselect.h"
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
241
25770
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
242 extern int keyboard_bit_set P_ ((SELECT_TYPE *));
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
243
13414
b035c6e41457 [HAVE_NTGUI] (POLL_FOR_INPUT): Define macro.
Geoff Voelker <voelker@cs.washington.edu>
parents: 13159
diff changeset
244 /* If we support a window system, turn on the code to poll periodically
7486
cfe4840ffde9 (Fopen_network_stream): Call bind_polling_period; later unbind the binding.
Richard M. Stallman <rms@gnu.org>
parents: 7454
diff changeset
245 to detect C-g. It isn't actually used when doing interrupt input. */
13414
b035c6e41457 [HAVE_NTGUI] (POLL_FOR_INPUT): Define macro.
Geoff Voelker <voelker@cs.washington.edu>
parents: 13159
diff changeset
246 #ifdef HAVE_WINDOW_SYSTEM
7486
cfe4840ffde9 (Fopen_network_stream): Call bind_polling_period; later unbind the binding.
Richard M. Stallman <rms@gnu.org>
parents: 7454
diff changeset
247 #define POLL_FOR_INPUT
cfe4840ffde9 (Fopen_network_stream): Call bind_polling_period; later unbind the binding.
Richard M. Stallman <rms@gnu.org>
parents: 7454
diff changeset
248 #endif
cfe4840ffde9 (Fopen_network_stream): Call bind_polling_period; later unbind the binding.
Richard M. Stallman <rms@gnu.org>
parents: 7454
diff changeset
249
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
250 /* Mask of bits indicating the descriptors that we wait for input on. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
251
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
252 static SELECT_TYPE input_wait_mask;
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
253
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
254 /* Mask that excludes keyboard input descriptor (s). */
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
255
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
256 static SELECT_TYPE non_keyboard_wait_mask;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
257
17224
dd2545e79add (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 17110
diff changeset
258 /* Mask that excludes process input descriptor (s). */
dd2545e79add (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 17110
diff changeset
259
dd2545e79add (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 17110
diff changeset
260 static SELECT_TYPE non_process_wait_mask;
dd2545e79add (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 17110
diff changeset
261
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
262 /* Mask of bits indicating the descriptors that we wait for connect to
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
263 complete on. Once they complete, they are removed from this mask
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
264 and added to the input_wait_mask and non_keyboard_wait_mask. */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
265
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
266 static SELECT_TYPE connect_wait_mask;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
267
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
268 /* Number of bits set in connect_wait_mask. */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
269 static int num_pending_connects;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
270
7044
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
271 /* The largest descriptor currently in use for a process object. */
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
272 static int max_process_desc;
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
273
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
274 /* The largest descriptor currently in use for keyboard input. */
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
275 static int max_keyboard_desc;
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
276
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
277 /* Nonzero means delete a process right away if it exits. */
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
278 static int delete_exited_processes;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
279
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
280 /* Indexed by descriptor, gives the process (if any) for that descriptor */
6164
d047d5a48e0e (chan_process, Vprocess_alist): No longer static.
Richard M. Stallman <rms@gnu.org>
parents: 6158
diff changeset
281 Lisp_Object chan_process[MAXDESC];
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
282
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
283 /* Alist of elements (NAME . PROCESS) */
6164
d047d5a48e0e (chan_process, Vprocess_alist): No longer static.
Richard M. Stallman <rms@gnu.org>
parents: 6158
diff changeset
284 Lisp_Object Vprocess_alist;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
285
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
286 /* Buffered-ahead input char from process, indexed by channel.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
287 -1 means empty (no char is buffered).
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
288 Used on sys V where the only way to tell if there is any
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
289 output from the process is to read at least one char.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
290 Always -1 on systems that support FIONREAD. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
291
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
292 /* Don't make static; need to access externally. */
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
293 int proc_buffered_char[MAXDESC];
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
294
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
295 /* Table of `struct coding-system' for each process. */
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
296 static struct coding_system *proc_decode_coding_system[MAXDESC];
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
297 static struct coding_system *proc_encode_coding_system[MAXDESC];
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
298
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
299 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
300 /* Table of `partner address' for datagram sockets. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
301 struct sockaddr_and_len {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
302 struct sockaddr *sa;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
303 int len;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
304 } datagram_address[MAXDESC];
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
305 #define DATAGRAM_CHAN_P(chan) (datagram_address[chan].sa != 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
306 #define DATAGRAM_CONN_P(proc) (datagram_address[XPROCESS (proc)->infd].sa != 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
307 #else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
308 #define DATAGRAM_CHAN_P(chan) (0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
309 #define DATAGRAM_CONN_P(proc) (0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
310 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
311
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
312 static Lisp_Object get_process ();
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
313 static void exec_sentinel ();
6158
6b81b2575071 Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 5891
diff changeset
314
14404
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
315 extern EMACS_TIME timer_check ();
14785
e4a9806c1e83 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14758
diff changeset
316 extern int timers_run;
14404
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
317
6158
6b81b2575071 Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 5891
diff changeset
318 /* Maximum number of bytes to send to a pty without an eof. */
6b81b2575071 Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 5891
diff changeset
319 static int pty_max_bytes;
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
320
21049
01e626b0a624 (Vdefault_file_name_coding_system): Extern it.
Kenichi Handa <handa@m17n.org>
parents: 20715
diff changeset
321 extern Lisp_Object Vfile_name_coding_system, Vdefault_file_name_coding_system;
19837
3bee81323f73 (create_process): Encode the new current dir.
Richard M. Stallman <rms@gnu.org>
parents: 19642
diff changeset
322
11609
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
323 #ifdef HAVE_PTYS
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
324 /* The file name of the pty opened by allocate_pty. */
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
325
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
326 static char pty_name[24];
11609
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
327 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
328
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
329 /* Compute the Lisp form of the process status, p->status, from
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
330 the numeric status that was returned by `wait'. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
331
1522
19ccf004b172 * process.c: (status_convert): Declare this to return a
Jim Blandy <jimb@redhat.com>
parents: 1323
diff changeset
332 Lisp_Object status_convert ();
19ccf004b172 * process.c: (status_convert): Declare this to return a
Jim Blandy <jimb@redhat.com>
parents: 1323
diff changeset
333
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
334 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
335 update_status (p)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
336 struct Lisp_Process *p;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
337 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
338 union { int i; WAITTYPE wt; } u;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
339 u.i = XFASTINT (p->raw_status_low) + (XFASTINT (p->raw_status_high) << 16);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
340 p->status = status_convert (u.wt);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
341 p->raw_status_low = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
342 p->raw_status_high = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
343 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
344
3608
Jim Blandy <jimb@redhat.com>
parents: 3593
diff changeset
345 /* Convert a process status word in Unix format to
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
346 the list that we use internally. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
347
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
348 Lisp_Object
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
349 status_convert (w)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
350 WAITTYPE w;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
351 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
352 if (WIFSTOPPED (w))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
353 return Fcons (Qstop, Fcons (make_number (WSTOPSIG (w)), Qnil));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
354 else if (WIFEXITED (w))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
355 return Fcons (Qexit, Fcons (make_number (WRETCODE (w)),
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
356 WCOREDUMP (w) ? Qt : Qnil));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
357 else if (WIFSIGNALED (w))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
358 return Fcons (Qsignal, Fcons (make_number (WTERMSIG (w)),
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
359 WCOREDUMP (w) ? Qt : Qnil));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
360 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
361 return Qrun;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
362 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
363
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
364 /* Given a status-list, extract the three pieces of information
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
365 and store them individually through the three pointers. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
366
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
367 void
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
368 decode_status (l, symbol, code, coredump)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
369 Lisp_Object l;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
370 Lisp_Object *symbol;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
371 int *code;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
372 int *coredump;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
373 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
374 Lisp_Object tem;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
375
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
376 if (SYMBOLP (l))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
377 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
378 *symbol = l;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
379 *code = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
380 *coredump = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
381 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
382 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
383 {
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
384 *symbol = XCAR (l);
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
385 tem = XCDR (l);
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
386 *code = XFASTINT (XCAR (tem));
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
387 tem = XCDR (tem);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
388 *coredump = !NILP (tem);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
389 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
390 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
391
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
392 /* Return a string describing a process status list. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
393
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
394 Lisp_Object
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
395 status_message (status)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
396 Lisp_Object status;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
397 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
398 Lisp_Object symbol;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
399 int code, coredump;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
400 Lisp_Object string, string2;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
401
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
402 decode_status (status, &symbol, &code, &coredump);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
403
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
404 if (EQ (symbol, Qsignal) || EQ (symbol, Qstop))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
405 {
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
406 char *signame;
26526
b7438760079b * callproc.c (strerror): Remove decl.
Paul Eggert <eggert@twinsun.com>
parents: 26313
diff changeset
407 synchronize_system_messages_locale ();
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
408 signame = strsignal (code);
5579
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
409 if (signame == 0)
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
410 signame = "unknown";
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
411 string = build_string (signame);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
412 string2 = build_string (coredump ? " (core dumped)\n" : "\n");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
413 XSTRING (string)->data[0] = DOWNCASE (XSTRING (string)->data[0]);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
414 return concat2 (string, string2);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
415 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
416 else if (EQ (symbol, Qexit))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
417 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
418 if (code == 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
419 return build_string ("finished\n");
2429
96b55f2f19cd Rename int-to-string to number-to-string, since it can handle
Jim Blandy <jimb@redhat.com>
parents: 2357
diff changeset
420 string = Fnumber_to_string (make_number (code));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
421 string2 = build_string (coredump ? " (core dumped)\n" : "\n");
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
422 return concat3 (build_string ("exited abnormally with code "),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
423 string, string2);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
424 }
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
425 else if (EQ (symbol, Qfailed))
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
426 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
427 string = Fnumber_to_string (make_number (code));
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
428 string2 = build_string ("\n");
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
429 return concat3 (build_string ("failed with code "),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
430 string, string2);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
431 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
432 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
433 return Fcopy_sequence (Fsymbol_name (symbol));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
434 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
435
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
436 #ifdef HAVE_PTYS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
437
11609
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
438 /* Open an available pty, returning a file descriptor.
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
439 Return -1 on failure.
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
440 The file name of the terminal corresponding to the pty
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
441 is left in the variable pty_name. */
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
442
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
443 int
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
444 allocate_pty ()
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
445 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
446 struct stat stb;
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
447 register int c, i;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
448 int fd;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
449
624
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
450 /* Some systems name their pseudoterminals so that there are gaps in
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
451 the usual sequence - for example, on HP9000/S700 systems, there
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
452 are no pseudoterminals with names ending in 'f'. So we wait for
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
453 three failures in a row before deciding that we've reached the
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
454 end of the ptys. */
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
455 int failed_count = 0;
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
456
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
457 #ifdef PTY_ITERATION
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
458 PTY_ITERATION
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
459 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
460 for (c = FIRST_PTY_LETTER; c <= 'z'; c++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
461 for (i = 0; i < 16; i++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
462 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
463 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
464 #ifdef PTY_NAME_SPRINTF
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
465 PTY_NAME_SPRINTF
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
466 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
467 sprintf (pty_name, "/dev/pty%c%x", c, i);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
468 #endif /* no PTY_NAME_SPRINTF */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
469
822
c6e94e13926c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 808
diff changeset
470 #ifdef PTY_OPEN
c6e94e13926c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 808
diff changeset
471 PTY_OPEN;
c6e94e13926c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 808
diff changeset
472 #else /* no PTY_OPEN */
624
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
473 #ifdef IRIS
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
474 /* Unusual IRIS code */
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
475 *ptyv = emacs_open ("/dev/ptc", O_RDWR | O_NDELAY, 0);
624
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
476 if (fd < 0)
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
477 return -1;
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
478 if (fstat (fd, &stb) < 0)
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
479 return -1;
822
c6e94e13926c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 808
diff changeset
480 #else /* not IRIS */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
481 if (stat (pty_name, &stb) < 0)
624
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
482 {
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
483 failed_count++;
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
484 if (failed_count >= 3)
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
485 return -1;
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
486 }
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
487 else
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
488 failed_count = 0;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
489 #ifdef O_NONBLOCK
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
490 fd = emacs_open (pty_name, O_RDWR | O_NONBLOCK, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
491 #else
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
492 fd = emacs_open (pty_name, O_RDWR | O_NDELAY, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
493 #endif
822
c6e94e13926c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 808
diff changeset
494 #endif /* not IRIS */
c6e94e13926c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 808
diff changeset
495 #endif /* no PTY_OPEN */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
496
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
497 if (fd >= 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
498 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
499 /* check to make certain that both sides are available
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
500 this avoids a nasty yet stupid bug in rlogins */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
501 #ifdef PTY_TTY_NAME_SPRINTF
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
502 PTY_TTY_NAME_SPRINTF
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
503 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
504 sprintf (pty_name, "/dev/tty%c%x", c, i);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
505 #endif /* no PTY_TTY_NAME_SPRINTF */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
506 #ifndef UNIPLUS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
507 if (access (pty_name, 6) != 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
508 {
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
509 emacs_close (fd);
2887
0554478bfa71 * process.c [__sgi] (allocate_pty): Give up immediately if pty is
Jim Blandy <jimb@redhat.com>
parents: 2830
diff changeset
510 #if !defined(IRIS) && !defined(__sgi)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
511 continue;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
512 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
513 return -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
514 #endif /* IRIS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
515 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
516 #endif /* not UNIPLUS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
517 setup_pty (fd);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
518 return fd;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
519 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
520 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
521 return -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
522 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
523 #endif /* HAVE_PTYS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
524
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
525 Lisp_Object
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
526 make_process (name)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
527 Lisp_Object name;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
528 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
529 register Lisp_Object val, tem, name1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
530 register struct Lisp_Process *p;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
531 char suffix[10];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
532 register int i;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
533
36434
40cfe4976f04 (make_process): Use allocate_process.
Gerd Moellmann <gerd@gnu.org>
parents: 35336
diff changeset
534 p = allocate_process ();
9969
007d93b04e1f (make_process): Use allocate_vectorlike and VECSIZE.
Karl Heuer <kwzh@gnu.org>
parents: 9952
diff changeset
535
9277
21f6120be5ba (make_process, create_process, Fopen_network_stream, deactivate_process,
Karl Heuer <kwzh@gnu.org>
parents: 9115
diff changeset
536 XSETINT (p->infd, -1);
21f6120be5ba (make_process, create_process, Fopen_network_stream, deactivate_process,
Karl Heuer <kwzh@gnu.org>
parents: 9115
diff changeset
537 XSETINT (p->outfd, -1);
9318
a14cc1712337 (make_process, list_processes_1, create_process, Faccept_process_output,
Karl Heuer <kwzh@gnu.org>
parents: 9277
diff changeset
538 XSETFASTINT (p->pid, 0);
a14cc1712337 (make_process, list_processes_1, create_process, Faccept_process_output,
Karl Heuer <kwzh@gnu.org>
parents: 9277
diff changeset
539 XSETFASTINT (p->tick, 0);
a14cc1712337 (make_process, list_processes_1, create_process, Faccept_process_output,
Karl Heuer <kwzh@gnu.org>
parents: 9277
diff changeset
540 XSETFASTINT (p->update_tick, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
541 p->raw_status_low = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
542 p->raw_status_high = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
543 p->status = Qrun;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
544 p->mark = Fmake_marker ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
545
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
546 /* If name is already in use, modify it until it is unused. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
547
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
548 name1 = name;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
549 for (i = 1; ; i++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
550 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
551 tem = Fget_process (name1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
552 if (NILP (tem)) break;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
553 sprintf (suffix, "<%d>", i);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
554 name1 = concat2 (name, build_string (suffix));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
555 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
556 name = name1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
557 p->name = name;
9969
007d93b04e1f (make_process): Use allocate_vectorlike and VECSIZE.
Karl Heuer <kwzh@gnu.org>
parents: 9952
diff changeset
558 XSETPROCESS (val, p);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
559 Vprocess_alist = Fcons (Fcons (name, val), Vprocess_alist);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
560 return val;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
561 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
562
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
563 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
564 remove_process (proc)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
565 register Lisp_Object proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
566 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
567 register Lisp_Object pair;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
568
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
569 pair = Frassq (proc, Vprocess_alist);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
570 Vprocess_alist = Fdelq (pair, Vprocess_alist);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
571
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
572 deactivate_process (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
573 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
574
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
575 DEFUN ("processp", Fprocessp, Sprocessp, 1, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
576 doc: /* Return t if OBJECT is a process. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
577 (object)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
578 Lisp_Object object;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
579 {
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
580 return PROCESSP (object) ? Qt : Qnil;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
581 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
582
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
583 DEFUN ("get-process", Fget_process, Sget_process, 1, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
584 doc: /* Return the process named NAME, or nil if there is none. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
585 (name)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
586 register Lisp_Object name;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
587 {
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
588 if (PROCESSP (name))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
589 return name;
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
590 CHECK_STRING (name);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
591 return Fcdr (Fassoc (name, Vprocess_alist));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
592 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
593
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
594 DEFUN ("get-buffer-process", Fget_buffer_process, Sget_buffer_process, 1, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
595 doc: /* Return the (or a) process associated with BUFFER.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
596 BUFFER may be a buffer or the name of one. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
597 (buffer)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
598 register Lisp_Object buffer;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
599 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
600 register Lisp_Object buf, tail, proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
601
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
602 if (NILP (buffer)) return Qnil;
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
603 buf = Fget_buffer (buffer);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
604 if (NILP (buf)) return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
605
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
606 for (tail = Vprocess_alist; !NILP (tail); tail = Fcdr (tail))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
607 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
608 proc = Fcdr (Fcar (tail));
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
609 if (PROCESSP (proc) && EQ (XPROCESS (proc)->buffer, buf))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
610 return proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
611 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
612 return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
613 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
614
808
707866b2a190 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 765
diff changeset
615 /* This is how commands for the user decode process arguments. It
707866b2a190 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 765
diff changeset
616 accepts a process, a process name, a buffer, a buffer name, or nil.
707866b2a190 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 765
diff changeset
617 Buffers denote the first process in the buffer, and nil denotes the
707866b2a190 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 765
diff changeset
618 current buffer. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
619
4994
4146a65b9f02 (get_process): Add `static' to definition.
Richard M. Stallman <rms@gnu.org>
parents: 4914
diff changeset
620 static Lisp_Object
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
621 get_process (name)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
622 register Lisp_Object name;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
623 {
6313
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
624 register Lisp_Object proc, obj;
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
625 if (STRINGP (name))
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
626 {
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
627 obj = Fget_process (name);
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
628 if (NILP (obj))
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
629 obj = Fget_buffer (name);
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
630 if (NILP (obj))
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
631 error ("Process %s does not exist", XSTRING (name)->data);
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
632 }
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
633 else if (NILP (name))
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
634 obj = Fcurrent_buffer ();
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
635 else
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
636 obj = name;
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
637
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
638 /* Now obj should be either a buffer object or a process object.
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
639 */
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
640 if (BUFFERP (obj))
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
641 {
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
642 proc = Fget_buffer_process (obj);
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
643 if (NILP (proc))
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
644 error ("Buffer %s has no process", XSTRING (XBUFFER (obj)->name)->data);
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
645 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
646 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
647 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
648 CHECK_PROCESS (obj);
6313
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
649 proc = obj;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
650 }
6313
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
651 return proc;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
652 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
653
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
654 DEFUN ("delete-process", Fdelete_process, Sdelete_process, 1, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
655 doc: /* Delete PROCESS: kill it and forget about it immediately.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
656 PROCESS may be a process, a buffer, the name of a process or buffer, or
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
657 nil, indicating the current buffer's process. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
658 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
659 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
660 {
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
661 process = get_process (process);
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
662 XPROCESS (process)->raw_status_low = Qnil;
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
663 XPROCESS (process)->raw_status_high = Qnil;
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
664 if (NETCONN_P (process))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
665 {
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
666 XPROCESS (process)->status = Fcons (Qexit, Fcons (make_number (0), Qnil));
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
667 XSETINT (XPROCESS (process)->tick, ++process_tick);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
668 }
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
669 else if (XINT (XPROCESS (process)->infd) >= 0)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
670 {
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
671 Fkill_process (process, Qnil);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
672 /* Do this now, since remove_process will make sigchld_handler do nothing. */
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
673 XPROCESS (process)->status
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
674 = Fcons (Qsignal, Fcons (make_number (SIGKILL), Qnil));
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
675 XSETINT (XPROCESS (process)->tick, ++process_tick);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
676 status_notify ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
677 }
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
678 remove_process (process);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
679 return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
680 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
681
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
682 DEFUN ("process-status", Fprocess_status, Sprocess_status, 1, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
683 doc: /* Return the status of PROCESS.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
684 The returned value is one of the following symbols:
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
685 run -- for a process that is running.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
686 stop -- for a process stopped but continuable.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
687 exit -- for a process that has exited.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
688 signal -- for a process that has got a fatal signal.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
689 open -- for a network stream connection that is open.
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
690 listen -- for a network stream server that is listening.
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
691 closed -- for a network stream connection that is closed.
43600
f21620032428 (Fprocess_status): Document connect and failed return values.
Kim F. Storm <storm@cua.dk>
parents: 43598
diff changeset
692 connect -- when waiting for a non-blocking connection to complete.
f21620032428 (Fprocess_status): Document connect and failed return values.
Kim F. Storm <storm@cua.dk>
parents: 43598
diff changeset
693 failed -- when a non-blocking connection has failed.
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
694 nil -- if arg is a process name and no such process exists.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
695 PROCESS may be a process, a buffer, the name of a process, or
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
696 nil, indicating the current buffer's process. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
697 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
698 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
699 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
700 register struct Lisp_Process *p;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
701 register Lisp_Object status;
7937
bf963799d8be (Fprocess_status): Return nil for process name that has no process.
Richard M. Stallman <rms@gnu.org>
parents: 7893
diff changeset
702
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
703 if (STRINGP (process))
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
704 process = Fget_process (process);
7937
bf963799d8be (Fprocess_status): Return nil for process name that has no process.
Richard M. Stallman <rms@gnu.org>
parents: 7893
diff changeset
705 else
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
706 process = get_process (process);
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
707
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
708 if (NILP (process))
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
709 return process;
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
710
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
711 p = XPROCESS (process);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
712 if (!NILP (p->raw_status_low))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
713 update_status (p);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
714 status = p->status;
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
715 if (CONSP (status))
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
716 status = XCAR (status);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
717 if (NETCONN1_P (p))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
718 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
719 if (EQ (status, Qexit))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
720 status = Qclosed;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
721 else if (EQ (p->command, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
722 status = Qstop;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
723 else if (EQ (status, Qrun))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
724 status = Qopen;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
725 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
726 return status;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
727 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
728
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
729 DEFUN ("process-exit-status", Fprocess_exit_status, Sprocess_exit_status,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
730 1, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
731 doc: /* Return the exit status of PROCESS or the signal number that killed it.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
732 If PROCESS has not yet exited or died, return 0. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
733 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
734 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
735 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
736 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
737 if (!NILP (XPROCESS (process)->raw_status_low))
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
738 update_status (XPROCESS (process));
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
739 if (CONSP (XPROCESS (process)->status))
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
740 return XCAR (XCDR (XPROCESS (process)->status));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
741 return make_number (0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
742 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
743
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
744 DEFUN ("process-id", Fprocess_id, Sprocess_id, 1, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
745 doc: /* Return the process id of PROCESS.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
746 This is the pid of the Unix process which PROCESS uses or talks to.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
747 For a network connection, this value is nil. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
748 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
749 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
750 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
751 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
752 return XPROCESS (process)->pid;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
753 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
754
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
755 DEFUN ("process-name", Fprocess_name, Sprocess_name, 1, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
756 doc: /* Return the name of PROCESS, as a string.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
757 This is the name of the program invoked in PROCESS,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
758 possibly modified to make it unique among process names. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
759 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
760 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
761 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
762 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
763 return XPROCESS (process)->name;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
764 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
765
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
766 DEFUN ("process-command", Fprocess_command, Sprocess_command, 1, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
767 doc: /* Return the command that was executed to start PROCESS.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
768 This is a list of strings, the first string being the program executed
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
769 and the rest of the strings being the arguments given to it.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
770 For a non-child channel, this is nil. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
771 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
772 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
773 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
774 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
775 return XPROCESS (process)->command;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
776 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
777
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
778 DEFUN ("process-tty-name", Fprocess_tty_name, Sprocess_tty_name, 1, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
779 doc: /* Return the name of the terminal PROCESS uses, or nil if none.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
780 This is the terminal that the process itself reads and writes on,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
781 not the name of the pty that Emacs uses to talk with that terminal. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
782 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
783 register Lisp_Object process;
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
784 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
785 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
786 return XPROCESS (process)->tty_name;
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
787 }
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
788
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
789 DEFUN ("set-process-buffer", Fset_process_buffer, Sset_process_buffer,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
790 2, 2, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
791 doc: /* Set buffer associated with PROCESS to BUFFER (a buffer, or nil). */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
792 (process, buffer)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
793 register Lisp_Object process, buffer;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
794 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
795 struct Lisp_Process *p;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
796
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
797 CHECK_PROCESS (process);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
798 if (!NILP (buffer))
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
799 CHECK_BUFFER (buffer);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
800 p = XPROCESS (process);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
801 p->buffer = buffer;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
802 if (NETCONN1_P (p))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
803 p->childp = Fplist_put (p->childp, QCbuffer, buffer);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
804 return buffer;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
805 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
806
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
807 DEFUN ("process-buffer", Fprocess_buffer, Sprocess_buffer,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
808 1, 1, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
809 doc: /* Return the buffer PROCESS is associated with.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
810 Output from PROCESS is inserted in this buffer unless PROCESS has a filter. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
811 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
812 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
813 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
814 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
815 return XPROCESS (process)->buffer;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
816 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
817
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
818 DEFUN ("process-mark", Fprocess_mark, Sprocess_mark,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
819 1, 1, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
820 doc: /* Return the marker for the end of the last output from PROCESS. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
821 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
822 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
823 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
824 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
825 return XPROCESS (process)->mark;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
826 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
827
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
828 DEFUN ("set-process-filter", Fset_process_filter, Sset_process_filter,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
829 2, 2, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
830 doc: /* Give PROCESS the filter function FILTER; nil means no filter.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
831 t means stop accepting output from the process.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
832 When a process has a filter, each time it does output
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
833 the entire string of output is passed to the filter.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
834 The filter gets two arguments: the process and the string of output.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
835 If the process has a filter, its buffer is not used for output. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
836 (process, filter)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
837 register Lisp_Object process, filter;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
838 {
36623
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
839 struct Lisp_Process *p;
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
840
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
841 CHECK_PROCESS (process);
36623
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
842 p = XPROCESS (process);
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
843
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
844 /* Don't signal an error if the process' input file descriptor
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
845 is closed. This could make debugging Lisp more difficult,
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
846 for example when doing something like
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
847
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
848 (setq process (start-process ...))
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
849 (debug)
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
850 (set-process-filter process ...) */
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
851
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
852 if (XINT (p->infd) >= 0)
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
853 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
854 if (EQ (filter, Qt) && !EQ (p->status, Qlisten))
36623
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
855 {
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
856 FD_CLR (XINT (p->infd), &input_wait_mask);
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
857 FD_CLR (XINT (p->infd), &non_keyboard_wait_mask);
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
858 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
859 else if (EQ (p->filter, Qt)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
860 && !EQ (p->command, Qt)) /* Network process not stopped. */
36623
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
861 {
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
862 FD_SET (XINT (p->infd), &input_wait_mask);
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
863 FD_SET (XINT (p->infd), &non_keyboard_wait_mask);
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
864 }
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
865 }
36623
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
866
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
867 p->filter = filter;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
868 if (NETCONN1_P (p))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
869 p->childp = Fplist_put (p->childp, QCfilter, filter);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
870 return filter;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
871 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
872
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
873 DEFUN ("process-filter", Fprocess_filter, Sprocess_filter,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
874 1, 1, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
875 doc: /* Returns the filter function of PROCESS; nil if none.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
876 See `set-process-filter' for more info on filter functions. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
877 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
878 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
879 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
880 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
881 return XPROCESS (process)->filter;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
882 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
883
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
884 DEFUN ("set-process-sentinel", Fset_process_sentinel, Sset_process_sentinel,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
885 2, 2, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
886 doc: /* Give PROCESS the sentinel SENTINEL; nil for none.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
887 The sentinel is called as a function when the process changes state.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
888 It gets two arguments: the process, and a string describing the change. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
889 (process, sentinel)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
890 register Lisp_Object process, sentinel;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
891 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
892 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
893 XPROCESS (process)->sentinel = sentinel;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
894 return sentinel;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
895 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
896
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
897 DEFUN ("process-sentinel", Fprocess_sentinel, Sprocess_sentinel,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
898 1, 1, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
899 doc: /* Return the sentinel of PROCESS; nil if none.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
900 See `set-process-sentinel' for more info on sentinels. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
901 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
902 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
903 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
904 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
905 return XPROCESS (process)->sentinel;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
906 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
907
6830
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
908 DEFUN ("set-process-window-size", Fset_process_window_size,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
909 Sset_process_window_size, 3, 3, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
910 doc: /* Tell PROCESS that it has logical window size HEIGHT and WIDTH. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
911 (process, height, width)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
912 register Lisp_Object process, height, width;
6830
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
913 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
914 CHECK_PROCESS (process);
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
915 CHECK_NATNUM (height);
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
916 CHECK_NATNUM (width);
36623
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
917
36659
c1c5ad73f700 (Fset_process_window_size): Fix a typo.
Gerd Moellmann <gerd@gnu.org>
parents: 36623
diff changeset
918 if (XINT (XPROCESS (process)->infd) < 0
36623
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
919 || set_window_size (XINT (XPROCESS (process)->infd),
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
920 XINT (height), XINT (width)) <= 0)
6830
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
921 return Qnil;
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
922 else
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
923 return Qt;
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
924 }
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
925
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
926 DEFUN ("set-process-inherit-coding-system-flag",
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
927 Fset_process_inherit_coding_system_flag,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
928 Sset_process_inherit_coding_system_flag, 2, 2, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
929 doc: /* Determine whether buffer of PROCESS will inherit coding-system.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
930 If the second argument FLAG is non-nil, then the variable
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
931 `buffer-file-coding-system' of the buffer associated with PROCESS
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
932 will be bound to the value of the coding system used to decode
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
933 the process output.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
934
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
935 This is useful when the coding system specified for the process buffer
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
936 leaves either the character code conversion or the end-of-line conversion
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
937 unspecified, or if the coding system used to decode the process output
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
938 is more appropriate for saving the process buffer.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
939
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
940 Binding the variable `inherit-process-coding-system' to non-nil before
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
941 starting the process is an alternative way of setting the inherit flag
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
942 for the process which will run. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
943 (process, flag)
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
944 register Lisp_Object process, flag;
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
945 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
946 CHECK_PROCESS (process);
21848
050ea21cec87 (Fset_process_inherit_coding_system_flag, Fstart_process):
Richard M. Stallman <rms@gnu.org>
parents: 21798
diff changeset
947 XPROCESS (process)->inherit_coding_system_flag = flag;
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
948 return flag;
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
949 }
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
950
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
951 DEFUN ("process-inherit-coding-system-flag",
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
952 Fprocess_inherit_coding_system_flag, Sprocess_inherit_coding_system_flag,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
953 1, 1, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
954 doc: /* Return the value of inherit-coding-system flag for PROCESS.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
955 If this flag is t, `buffer-file-coding-system' of the buffer
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
956 associated with PROCESS will inherit the coding system used to decode
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
957 the process output. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
958 (process)
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
959 register Lisp_Object process;
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
960 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
961 CHECK_PROCESS (process);
21848
050ea21cec87 (Fset_process_inherit_coding_system_flag, Fstart_process):
Richard M. Stallman <rms@gnu.org>
parents: 21798
diff changeset
962 return XPROCESS (process)->inherit_coding_system_flag;
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
963 }
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
964
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
965 DEFUN ("set-process-query-on-exit-flag",
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
966 Fset_process_query_on_exit_flag, Sset_process_query_on_exit_flag,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
967 2, 2, 0,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
968 doc: /* Specify if query is needed for PROCESS when Emacs is exited.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
969 If the second argument FLAG is non-nil, emacs will query the user before
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
970 exiting if PROCESS is running. */)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
971 (process, flag)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
972 register Lisp_Object process, flag;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
973 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
974 CHECK_PROCESS (process);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
975 XPROCESS (process)->kill_without_query = Fnull (flag);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
976 return flag;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
977 }
4231
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
978
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
979 DEFUN ("process-query-on-exit-flag",
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
980 Fprocess_query_on_exit_flag, Sprocess_query_on_exit_flag,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
981 1, 1, 0,
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
982 doc: /* Return the current value of query on exit flag for PROCESS. */)
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
983 (process)
16058
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
984 register Lisp_Object process;
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
985 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
986 CHECK_PROCESS (process);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
987 return Fnull (XPROCESS (process)->kill_without_query);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
988 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
989
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
990 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
991 Lisp_Object Fprocess_datagram_address ();
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
992 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
993
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
994 DEFUN ("process-contact", Fprocess_contact, Sprocess_contact,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
995 1, 2, 0,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
996 doc: /* Return the contact info of PROCESS; t for a real child.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
997 For a net connection, the value depends on the optional KEY arg.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
998 If KEY is nil, value is a cons cell of the form (HOST SERVICE),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
999 if KEY is t, the complete contact information for the connection is
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1000 returned, else the specific value for the keyword KEY is returned.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1001 See `make-network-process' for a list of keywords. */)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1002 (process, key)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1003 register Lisp_Object process, key;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1004 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1005 Lisp_Object contact;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1006
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1007 CHECK_PROCESS (process);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1008 contact = XPROCESS (process)->childp;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1009
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1010 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1011 if (DATAGRAM_CONN_P (process)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1012 && (EQ (key, Qt) || EQ (key, QCremote)))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1013 contact = Fplist_put (contact, QCremote,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1014 Fprocess_datagram_address (process));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1015 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1016
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1017 if (!NETCONN_P (process) || EQ (key, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1018 return contact;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1019 if (NILP (key))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1020 return Fcons (Fplist_get (contact, QChost),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1021 Fcons (Fplist_get (contact, QCservice), Qnil));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1022 return Fplist_get (contact, key);
16058
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
1023 }
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
1024
4231
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1025 #if 0 /* Turned off because we don't currently record this info
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1026 in the process. Perhaps add it. */
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1027 DEFUN ("process-connection", Fprocess_connection, Sprocess_connection, 1, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1028 doc: /* Return the connection type of PROCESS.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1029 The value is nil for a pipe, t or `pty' for a pty, or `stream' for
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1030 a socket connection. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1031 (process)
4231
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1032 Lisp_Object process;
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1033 {
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1034 return XPROCESS (process)->type;
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1035 }
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1036 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1037
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1038 Lisp_Object
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1039 list_processes_1 (query_only)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1040 Lisp_Object query_only;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1041 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1042 register Lisp_Object tail, tem;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1043 Lisp_Object proc, minspace, tem1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1044 register struct Lisp_Process *p;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1045 char tembuf[300];
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1046 int w_proc, w_buffer, w_tty;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1047 Lisp_Object i_status, i_buffer, i_tty, i_command;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1048
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1049 w_proc = 4; /* Proc */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1050 w_buffer = 6; /* Buffer */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1051 w_tty = 0; /* Omit if no ttys */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1052
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1053 for (tail = Vprocess_alist; !NILP (tail); tail = Fcdr (tail))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1054 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1055 int i;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1056
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1057 proc = Fcdr (Fcar (tail));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1058 p = XPROCESS (proc);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1059 if (NILP (p->childp))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1060 continue;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1061 if (!NILP (query_only) && !NILP (p->kill_without_query))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1062 continue;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1063 if (STRINGP (p->name)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1064 && ( i = XSTRING (p->name)->size, (i > w_proc)))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1065 w_proc = i;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1066 if (!NILP (p->buffer))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1067 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1068 if (NILP (XBUFFER (p->buffer)->name) && w_buffer < 8)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1069 w_buffer = 8; /* (Killed) */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1070 else if ((i = XSTRING (XBUFFER (p->buffer)->name)->size, (i > w_buffer)))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1071 w_buffer = i;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1072 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1073 if (STRINGP (p->tty_name)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1074 && (i = XSTRING (p->tty_name)->size, (i > w_tty)))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1075 w_tty = i;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1076 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1077
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1078 XSETFASTINT (i_status, w_proc + 1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1079 XSETFASTINT (i_buffer, XFASTINT (i_status) + 9);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1080 if (w_tty)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1081 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1082 XSETFASTINT (i_tty, XFASTINT (i_buffer) + w_buffer + 1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1083 XSETFASTINT (i_command, XFASTINT (i_buffer) + w_tty + 1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1084 } else {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1085 i_tty = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1086 XSETFASTINT (i_command, XFASTINT (i_buffer) + w_buffer + 1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1087 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1088
9318
a14cc1712337 (make_process, list_processes_1, create_process, Faccept_process_output,
Karl Heuer <kwzh@gnu.org>
parents: 9277
diff changeset
1089 XSETFASTINT (minspace, 1);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1090
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1091 set_buffer_internal (XBUFFER (Vstandard_output));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1092 Fbuffer_disable_undo (Vstandard_output);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1093
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1094 current_buffer->truncate_lines = Qt;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1095
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1096 write_string ("Proc", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1097 Findent_to (i_status, minspace); write_string ("Status", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1098 Findent_to (i_buffer, minspace); write_string ("Buffer", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1099 if (!NILP (i_tty))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1100 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1101 Findent_to (i_tty, minspace); write_string ("Tty", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1102 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1103 Findent_to (i_command, minspace); write_string ("Command", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1104 write_string ("\n", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1105
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1106 write_string ("----", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1107 Findent_to (i_status, minspace); write_string ("------", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1108 Findent_to (i_buffer, minspace); write_string ("------", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1109 if (!NILP (i_tty))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1110 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1111 Findent_to (i_tty, minspace); write_string ("---", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1112 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1113 Findent_to (i_command, minspace); write_string ("-------", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1114 write_string ("\n", -1);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1115
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1116 for (tail = Vprocess_alist; !NILP (tail); tail = Fcdr (tail))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1117 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1118 Lisp_Object symbol;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1119
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1120 proc = Fcdr (Fcar (tail));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1121 p = XPROCESS (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1122 if (NILP (p->childp))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1123 continue;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1124 if (!NILP (query_only) && !NILP (p->kill_without_query))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1125 continue;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1126
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1127 Finsert (1, &p->name);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1128 Findent_to (i_status, minspace);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1129
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1130 if (!NILP (p->raw_status_low))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1131 update_status (p);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1132 symbol = p->status;
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
1133 if (CONSP (p->status))
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
1134 symbol = XCAR (p->status);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1135
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1136
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1137 if (EQ (symbol, Qsignal))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1138 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1139 Lisp_Object tem;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1140 tem = Fcar (Fcdr (p->status));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1141 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1142 if (XINT (tem) < NSIG)
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1143 write_string (sys_errlist [XINT (tem)], -1);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1144 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1145 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1146 Fprinc (symbol, Qnil);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1147 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1148 else if (NETCONN1_P (p))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1149 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1150 if (EQ (symbol, Qexit))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1151 write_string ("closed", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1152 else if (EQ (p->command, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1153 write_string ("stopped", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1154 else if (EQ (symbol, Qrun))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1155 write_string ("open", -1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1156 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1157 Fprinc (symbol, Qnil);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1158 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1159 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1160 Fprinc (symbol, Qnil);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1161
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1162 if (EQ (symbol, Qexit))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1163 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1164 Lisp_Object tem;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1165 tem = Fcar (Fcdr (p->status));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1166 if (XFASTINT (tem))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1167 {
11695
0f9b9c375416 (list_processes_1): Cast XFASTINT for passing to sprintf.
Richard M. Stallman <rms@gnu.org>
parents: 11609
diff changeset
1168 sprintf (tembuf, " %d", (int) XFASTINT (tem));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1169 write_string (tembuf, -1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1170 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1171 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1172
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1173 if (EQ (symbol, Qsignal) || EQ (symbol, Qexit))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1174 remove_process (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1175
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1176 Findent_to (i_buffer, minspace);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1177 if (NILP (p->buffer))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1178 insert_string ("(none)");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1179 else if (NILP (XBUFFER (p->buffer)->name))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1180 insert_string ("(Killed)");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1181 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1182 Finsert (1, &XBUFFER (p->buffer)->name);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1183
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1184 if (!NILP (i_tty))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1185 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1186 Findent_to (i_tty, minspace);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1187 if (STRINGP (p->tty_name))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1188 Finsert (1, &p->tty_name);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1189 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1190
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1191 Findent_to (i_command, minspace);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1192
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1193 if (EQ (p->status, Qlisten))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1194 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1195 Lisp_Object port = Fplist_get (p->childp, QCservice);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1196 if (INTEGERP (port))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1197 port = Fnumber_to_string (port);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1198 sprintf (tembuf, "(network %s server on %s)\n",
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1199 (DATAGRAM_CHAN_P (p->infd) ? "datagram" : "stream"),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1200 XSTRING (port)->data);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1201 insert_string (tembuf);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1202 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1203 else if (NETCONN1_P (p))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1204 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1205 /* For a local socket, there is no host name,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1206 so display service instead. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1207 Lisp_Object host = Fplist_get (p->childp, QChost);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1208 if (!STRINGP (host))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1209 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1210 host = Fplist_get (p->childp, QCservice);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1211 if (INTEGERP (host))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1212 host = Fnumber_to_string (host);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1213 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1214 sprintf (tembuf, "(network %s connection to %s)\n",
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1215 (DATAGRAM_CHAN_P (p->infd) ? "datagram" : "stream"),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1216 XSTRING (host)->data);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1217 insert_string (tembuf);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1218 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1219 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1220 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1221 tem = p->command;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1222 while (1)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1223 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1224 tem1 = Fcar (tem);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1225 Finsert (1, &tem1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1226 tem = Fcdr (tem);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1227 if (NILP (tem))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1228 break;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1229 insert_string (" ");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1230 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1231 insert_string ("\n");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1232 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1233 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1234 return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1235 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1236
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1237 DEFUN ("list-processes", Flist_processes, Slist_processes, 0, 1, "P",
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1238 doc: /* Display a list of all processes.
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1239 If optional argument QUERY-ONLY is non-nil, only processes with
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1240 the query-on-exit flag set will be listed.
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1241 Any process listed as exited or signaled is actually eliminated
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1242 after the listing is made. */)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1243 (query_only)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1244 Lisp_Object query_only;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1245 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1246 internal_with_output_to_temp_buffer ("*Process List*",
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1247 list_processes_1, query_only);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1248 return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1249 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1250
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1251 DEFUN ("process-list", Fprocess_list, Sprocess_list, 0, 0, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1252 doc: /* Return a list of all processes. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1253 ()
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1254 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1255 return Fmapcar (Qcdr, Vprocess_alist);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1256 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1257
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1258 /* Starting asynchronous inferior processes. */
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1259
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1260 static Lisp_Object start_process_unwind ();
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1261
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1262 DEFUN ("start-process", Fstart_process, Sstart_process, 3, MANY, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1263 doc: /* Start a program in a subprocess. Return the process object for it.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1264 NAME is name for process. It is modified if necessary to make it unique.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1265 BUFFER is the buffer or (buffer-name) to associate with the process.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1266 Process output goes at end of that buffer, unless you specify
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1267 an output stream or filter function to handle the output.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1268 BUFFER may be also nil, meaning that this process is not associated
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1269 with any buffer.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1270 Third arg is program file name. It is searched for in PATH.
40641
d94fc1022312 (Fstart_process): Add usage to doc-string.
Pavel Janík <Pavel@Janik.cz>
parents: 40231
diff changeset
1271 Remaining arguments are strings to give program as arguments.
d94fc1022312 (Fstart_process): Add usage to doc-string.
Pavel Janík <Pavel@Janik.cz>
parents: 40231
diff changeset
1272 usage: (start-process NAME BUFFER PROGRAM &rest PROGRAM-ARGS) */)
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1273 (nargs, args)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1274 int nargs;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1275 register Lisp_Object *args;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1276 {
1683
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1277 Lisp_Object buffer, name, program, proc, current_dir, tem;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1278 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1279 register unsigned char *new_argv;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1280 int len;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1281 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1282 register unsigned char **new_argv;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1283 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1284 register int i;
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1285 int count = specpdl_ptr - specpdl;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1286
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1287 buffer = args[1];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1288 if (!NILP (buffer))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1289 buffer = Fget_buffer_create (buffer);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1290
1683
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1291 /* Make sure that the child will be able to chdir to the current
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1292 buffer's current directory, or its unhandled equivalent. We
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1293 can't just have the child check for an error when it does the
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1294 chdir, since it's in a vfork.
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1295
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1296 We have to GCPRO around this because Fexpand_file_name and
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1297 Funhandled_file_name_directory might call a file name handling
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1298 function. The argument list is protected by the caller, so all
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1299 we really have to worry about is buffer. */
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1300 {
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1301 struct gcpro gcpro1, gcpro2;
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1302
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1303 current_dir = current_buffer->directory;
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1304
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1305 GCPRO2 (buffer, current_dir);
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1306
10744
54a76e0b97ec (Fstart_process): Make process marker point into proc buf.
Richard M. Stallman <rms@gnu.org>
parents: 10548
diff changeset
1307 current_dir
54a76e0b97ec (Fstart_process): Make process marker point into proc buf.
Richard M. Stallman <rms@gnu.org>
parents: 10548
diff changeset
1308 = expand_and_dir_to_file (Funhandled_file_name_directory (current_dir),
54a76e0b97ec (Fstart_process): Make process marker point into proc buf.
Richard M. Stallman <rms@gnu.org>
parents: 10548
diff changeset
1309 Qnil);
1683
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1310 if (NILP (Ffile_accessible_directory_p (current_dir)))
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1311 report_file_error ("Setting current directory",
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1312 Fcons (current_buffer->directory, Qnil));
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1313
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1314 UNGCPRO;
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1315 }
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1316
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1317 name = args[0];
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
1318 CHECK_STRING (name);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1319
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1320 program = args[2];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1321
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
1322 CHECK_STRING (program);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1323
29017
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1324 proc = make_process (name);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1325 /* If an error occurs and we can't start the process, we want to
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1326 remove it from the process list. This means that each error
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1327 check in create_process doesn't need to call remove_process
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1328 itself; it's all taken care of here. */
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1329 record_unwind_protect (start_process_unwind, proc);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1330
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1331 XPROCESS (proc)->childp = Qt;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1332 XPROCESS (proc)->command_channel_p = Qnil;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1333 XPROCESS (proc)->buffer = buffer;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1334 XPROCESS (proc)->sentinel = Qnil;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1335 XPROCESS (proc)->filter = Qnil;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1336 XPROCESS (proc)->command = Flist (nargs - 2, args + 2);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1337
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1338 /* Make the process marker point into the process buffer (if any). */
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1339 if (!NILP (buffer))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1340 set_marker_both (XPROCESS (proc)->mark, buffer,
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1341 BUF_ZV (XBUFFER (buffer)),
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1342 BUF_ZV_BYTE (XBUFFER (buffer)));
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1343
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1344 {
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1345 /* Decide coding systems for communicating with the process. Here
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1346 we don't setup the structure coding_system nor pay attention to
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1347 unibyte mode. They are done in create_process. */
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1348
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1349 /* Qt denotes we have not yet called Ffind_operation_coding_system. */
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1350 Lisp_Object coding_systems = Qt;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1351 Lisp_Object val, *args2;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1352 struct gcpro gcpro1, gcpro2;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1353
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1354 val = Vcoding_system_for_read;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1355 if (NILP (val))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1356 {
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1357 args2 = (Lisp_Object *) alloca ((nargs + 1) * sizeof *args2);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1358 args2[0] = Qstart_process;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1359 for (i = 0; i < nargs; i++) args2[i + 1] = args[i];
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1360 GCPRO2 (proc, current_dir);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1361 coding_systems = Ffind_operation_coding_system (nargs + 1, args2);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1362 UNGCPRO;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1363 if (CONSP (coding_systems))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1364 val = XCAR (coding_systems);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1365 else if (CONSP (Vdefault_process_coding_system))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1366 val = XCAR (Vdefault_process_coding_system);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1367 }
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1368 XPROCESS (proc)->decode_coding_system = val;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1369
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1370 val = Vcoding_system_for_write;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1371 if (NILP (val))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1372 {
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1373 if (EQ (coding_systems, Qt))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1374 {
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1375 args2 = (Lisp_Object *) alloca ((nargs + 1) * sizeof args2);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1376 args2[0] = Qstart_process;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1377 for (i = 0; i < nargs; i++) args2[i + 1] = args[i];
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1378 GCPRO2 (proc, current_dir);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1379 coding_systems = Ffind_operation_coding_system (nargs + 1, args2);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1380 UNGCPRO;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1381 }
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1382 if (CONSP (coding_systems))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1383 val = XCDR (coding_systems);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1384 else if (CONSP (Vdefault_process_coding_system))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1385 val = XCDR (Vdefault_process_coding_system);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1386 }
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1387 XPROCESS (proc)->encode_coding_system = val;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1388 }
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1389
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1390 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1391 /* Make a one member argv with all args concatenated
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1392 together separated by a blank. */
21244
50929073a0ba Use STRING_BYTES and SET_STRING_BYTES.
Richard M. Stallman <rms@gnu.org>
parents: 21177
diff changeset
1393 len = STRING_BYTES (XSTRING (program)) + 2;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1394 for (i = 3; i < nargs; i++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1395 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1396 tem = args[i];
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
1397 CHECK_STRING (tem);
21244
50929073a0ba Use STRING_BYTES and SET_STRING_BYTES.
Richard M. Stallman <rms@gnu.org>
parents: 21177
diff changeset
1398 len += STRING_BYTES (XSTRING (tem)) + 1; /* count the blank */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1399 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1400 new_argv = (unsigned char *) alloca (len);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1401 strcpy (new_argv, XSTRING (program)->data);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1402 for (i = 3; i < nargs; i++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1403 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1404 tem = args[i];
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
1405 CHECK_STRING (tem);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1406 strcat (new_argv, " ");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1407 strcat (new_argv, XSTRING (tem)->data);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1408 }
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1409 /* Need to add code here to check for program existence on VMS */
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1410
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1411 #else /* not VMS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1412 new_argv = (unsigned char **) alloca ((nargs - 1) * sizeof (char *));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1413
6390
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1414 /* If program file name is not absolute, search our path for it */
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1415 if (!IS_DIRECTORY_SEP (XSTRING (program)->data[0])
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1416 && !(XSTRING (program)->size > 1
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1417 && IS_DEVICE_SEP (XSTRING (program)->data[1])))
6390
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1418 {
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1419 struct gcpro gcpro1, gcpro2, gcpro3, gcpro4;
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1420
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1421 tem = Qnil;
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1422 GCPRO4 (name, program, buffer, current_dir);
39812
66e0816837a8 Update calls to openp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39429
diff changeset
1423 openp (Vexec_path, program, Vexec_suffixes, &tem, 1);
6390
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1424 UNGCPRO;
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1425 if (NILP (tem))
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1426 report_file_error ("Searching for program", Fcons (program, Qnil));
12648
98aba238cf62 (Fstart_process): Don't expand the file name before trying openp.
Richard M. Stallman <rms@gnu.org>
parents: 12541
diff changeset
1427 tem = Fexpand_file_name (tem, Qnil);
29017
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1428 tem = ENCODE_FILE (tem);
6390
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1429 new_argv[0] = XSTRING (tem)->data;
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1430 }
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1431 else
12491
4ad7be34ece1 (Fstart_process): Expand PROGRAM.
Richard M. Stallman <rms@gnu.org>
parents: 12378
diff changeset
1432 {
4ad7be34ece1 (Fstart_process): Expand PROGRAM.
Richard M. Stallman <rms@gnu.org>
parents: 12378
diff changeset
1433 if (!NILP (Ffile_directory_p (program)))
4ad7be34ece1 (Fstart_process): Expand PROGRAM.
Richard M. Stallman <rms@gnu.org>
parents: 12378
diff changeset
1434 error ("Specified program for new process is a directory");
4ad7be34ece1 (Fstart_process): Expand PROGRAM.
Richard M. Stallman <rms@gnu.org>
parents: 12378
diff changeset
1435
29017
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1436 tem = ENCODE_FILE (program);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1437 new_argv[0] = XSTRING (tem)->data;
12491
4ad7be34ece1 (Fstart_process): Expand PROGRAM.
Richard M. Stallman <rms@gnu.org>
parents: 12378
diff changeset
1438 }
6390
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1439
29017
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1440 /* Here we encode arguments by the coding system used for sending
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1441 data to the process. We don't support using different coding
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1442 systems for encoding arguments and for encoding data sent to the
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1443 process. */
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1444
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1445 for (i = 3; i < nargs; i++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1446 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1447 tem = args[i];
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
1448 CHECK_STRING (tem);
29017
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1449 if (STRING_MULTIBYTE (tem))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1450 tem = (code_convert_string_norecord
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1451 (tem, XPROCESS (proc)->encode_coding_system, 1));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1452 new_argv[i - 2] = XSTRING (tem)->data;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1453 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1454 new_argv[i - 2] = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1455 #endif /* not VMS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1456
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
1457 XPROCESS (proc)->decoding_buf = make_uninit_string (0);
20715
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
1458 XPROCESS (proc)->decoding_carryover = make_number (0);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
1459 XPROCESS (proc)->encoding_buf = make_uninit_string (0);
20715
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
1460 XPROCESS (proc)->encoding_carryover = make_number (0);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
1461
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
1462 XPROCESS (proc)->inherit_coding_system_flag
21848
050ea21cec87 (Fset_process_inherit_coding_system_flag, Fstart_process):
Richard M. Stallman <rms@gnu.org>
parents: 21798
diff changeset
1463 = (NILP (buffer) || !inherit_process_coding_system
050ea21cec87 (Fset_process_inherit_coding_system_flag, Fstart_process):
Richard M. Stallman <rms@gnu.org>
parents: 21798
diff changeset
1464 ? Qnil : Qt);
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
1465
20382
dbad9367d232 (create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents: 20225
diff changeset
1466 create_process (proc, (char **) new_argv, current_dir);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1467
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1468 return unbind_to (count, proc);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1469 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1470
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1471 /* This function is the unwind_protect form for Fstart_process. If
14036
621a575db6f7 Comment fixes.
Karl Heuer <kwzh@gnu.org>
parents: 13777
diff changeset
1472 PROC doesn't have its pid set, then we know someone has signaled
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1473 an error and the process wasn't started successfully, so we should
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1474 remove it from the process list. */
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1475 static Lisp_Object
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1476 start_process_unwind (proc)
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1477 Lisp_Object proc;
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1478 {
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
1479 if (!PROCESSP (proc))
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1480 abort ();
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1481
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1482 /* Was PROC started successfully? */
3685
47d7fda8a609 (start_process_unwind): Use XINT.
Richard M. Stallman <rms@gnu.org>
parents: 3666
diff changeset
1483 if (XINT (XPROCESS (proc)->pid) <= 0)
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1484 remove_process (proc);
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1485
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1486 return Qnil;
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1487 }
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1488
27430
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1489 void
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1490 create_process_1 (timer)
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1491 struct atimer *timer;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1492 {
27430
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1493 /* Nothing to do. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1494 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1495
27430
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1496
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1497 #if 0 /* This doesn't work; see the note before sigchld_handler. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1498 #ifdef USG
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1499 #ifdef SIGCHLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1500 /* Mimic blocking of signals on system V, which doesn't really have it. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1501
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1502 /* Nonzero means we got a SIGCHLD when it was supposed to be blocked. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1503 int sigchld_deferred;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1504
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1505 SIGTYPE
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1506 create_process_sigchld ()
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1507 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1508 signal (SIGCHLD, create_process_sigchld);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1509
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1510 sigchld_deferred = 1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1511 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1512 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1513 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1514 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1515
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1516 #ifndef VMS /* VMS version of this function is in vmsproc.c. */
20382
dbad9367d232 (create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents: 20225
diff changeset
1517 void
1683
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1518 create_process (process, new_argv, current_dir)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1519 Lisp_Object process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1520 char **new_argv;
1683
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1521 Lisp_Object current_dir;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1522 {
11926
40d7e6f04ebe (create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents: 11845
diff changeset
1523 int pid, inchannel, outchannel;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1524 int sv[2];
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1525 #ifdef POSIX_SIGNALS
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1526 sigset_t procmask;
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1527 sigset_t blocked;
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1528 struct sigaction sigint_action;
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1529 struct sigaction sigquit_action;
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1530 #ifdef AIX
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1531 struct sigaction sighup_action;
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1532 #endif
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1533 #else /* !POSIX_SIGNALS */
25770
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
1534 #if 0
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1535 #ifdef SIGCHLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1536 SIGTYPE (*sigchld)();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1537 #endif
25770
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
1538 #endif /* 0 */
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1539 #endif /* !POSIX_SIGNALS */
11926
40d7e6f04ebe (create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents: 11845
diff changeset
1540 /* Use volatile to protect variables from being clobbered by longjmp. */
40d7e6f04ebe (create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents: 11845
diff changeset
1541 volatile int forkin, forkout;
40d7e6f04ebe (create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents: 11845
diff changeset
1542 volatile int pty_flag = 0;
31099
0fe5afca71e4 Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents: 30582
diff changeset
1543 #ifndef USE_CRT_DLL
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1544 extern char **environ;
31099
0fe5afca71e4 Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents: 30582
diff changeset
1545 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1546
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1547 inchannel = outchannel = -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1548
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1549 #ifdef HAVE_PTYS
7748
9a9c8372af80 (create_process): Get a pty for any non-nil Vprocess_connection_type value.
Richard M. Stallman <rms@gnu.org>
parents: 7605
diff changeset
1550 if (!NILP (Vprocess_connection_type))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1551 outchannel = inchannel = allocate_pty ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1552
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1553 if (inchannel >= 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1554 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1555 #ifndef USG
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1556 /* On USG systems it does not work to open the pty's tty here
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1557 and then close and reopen it in the child. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1558 #ifdef O_NOCTTY
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1559 /* Don't let this terminal become our controlling terminal
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1560 (in case we don't have one). */
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1561 forkout = forkin = emacs_open (pty_name, O_RDWR | O_NOCTTY, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1562 #else
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1563 forkout = forkin = emacs_open (pty_name, O_RDWR, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1564 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1565 if (forkin < 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1566 report_file_error ("Opening pty", Qnil);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1567 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1568 forkin = forkout = -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1569 #endif /* not USG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1570 pty_flag = 1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1571 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1572 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1573 #endif /* HAVE_PTYS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1574 #ifdef SKTPAIR
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1575 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1576 if (socketpair (AF_UNIX, SOCK_STREAM, 0, sv) < 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1577 report_file_error ("Opening socketpair", Qnil);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1578 outchannel = inchannel = sv[0];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1579 forkout = forkin = sv[1];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1580 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1581 #else /* not SKTPAIR */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1582 {
25129
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1583 int tem;
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1584 tem = pipe (sv);
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1585 if (tem < 0)
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1586 report_file_error ("Creating pipe", Qnil);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1587 inchannel = sv[0];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1588 forkout = sv[1];
25129
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1589 tem = pipe (sv);
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1590 if (tem < 0)
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1591 {
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1592 emacs_close (inchannel);
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1593 emacs_close (forkout);
25129
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1594 report_file_error ("Creating pipe", Qnil);
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1595 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1596 outchannel = sv[1];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1597 forkin = sv[0];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1598 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1599 #endif /* not SKTPAIR */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1600
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1601 #if 0
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1602 /* Replaced by close_process_descs */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1603 set_exclusive_use (inchannel);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1604 set_exclusive_use (outchannel);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1605 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1606
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1607 /* Stride people say it's a mystery why this is needed
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1608 as well as the O_NDELAY, but that it fails without this. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1609 #if defined (STRIDE) || (defined (pfa) && defined (HAVE_PTYS))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1610 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1611 int one = 1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1612 ioctl (inchannel, FIONBIO, &one);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1613 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1614 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1615
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1616 #ifdef O_NONBLOCK
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1617 fcntl (inchannel, F_SETFL, O_NONBLOCK);
14405
4aa693528ee3 (create_process): Set outchannel to be non-blocking.
Richard M. Stallman <rms@gnu.org>
parents: 14404
diff changeset
1618 fcntl (outchannel, F_SETFL, O_NONBLOCK);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1619 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1620 #ifdef O_NDELAY
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1621 fcntl (inchannel, F_SETFL, O_NDELAY);
14405
4aa693528ee3 (create_process): Set outchannel to be non-blocking.
Richard M. Stallman <rms@gnu.org>
parents: 14404
diff changeset
1622 fcntl (outchannel, F_SETFL, O_NDELAY);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1623 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1624 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1625
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1626 /* Record this as an active process, with its channels.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1627 As a result, child_setup will close Emacs's side of the pipes. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1628 chan_process[inchannel] = process;
9277
21f6120be5ba (make_process, create_process, Fopen_network_stream, deactivate_process,
Karl Heuer <kwzh@gnu.org>
parents: 9115
diff changeset
1629 XSETINT (XPROCESS (process)->infd, inchannel);
21f6120be5ba (make_process, create_process, Fopen_network_stream, deactivate_process,
Karl Heuer <kwzh@gnu.org>
parents: 9115
diff changeset
1630 XSETINT (XPROCESS (process)->outfd, outchannel);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1631 /* Record the tty descriptor used in the subprocess. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1632 if (forkin < 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1633 XPROCESS (process)->subtty = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1634 else
9318
a14cc1712337 (make_process, list_processes_1, create_process, Faccept_process_output,
Karl Heuer <kwzh@gnu.org>
parents: 9277
diff changeset
1635 XSETFASTINT (XPROCESS (process)->subtty, forkin);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1636 XPROCESS (process)->pty_flag = (pty_flag ? Qt : Qnil);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1637 XPROCESS (process)->status = Qrun;
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
1638 if (!proc_decode_coding_system[inchannel])
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
1639 proc_decode_coding_system[inchannel]
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
1640 = (struct coding_system *) xmalloc (sizeof (struct coding_system));
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
1641 setup_coding_system (XPROCESS (process)->decode_coding_system,
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
1642 proc_decode_coding_system[inchannel]);
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
1643 if (!proc_encode_coding_system[outchannel])
22848
f17131794fbc Whitespace change.
Richard M. Stallman <rms@gnu.org>
parents: 22763
diff changeset
1644 proc_encode_coding_system[outchannel]
f17131794fbc Whitespace change.
Richard M. Stallman <rms@gnu.org>
parents: 22763
diff changeset
1645 = (struct coding_system *) xmalloc (sizeof (struct coding_system));
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
1646 setup_coding_system (XPROCESS (process)->encode_coding_system,
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
1647 proc_encode_coding_system[outchannel]);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1648
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1649 /* Delay interrupts until we have a chance to store
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1650 the new fork's pid in its process structure */
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1651 #ifdef POSIX_SIGNALS
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1652 sigemptyset (&blocked);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1653 #ifdef SIGCHLD
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1654 sigaddset (&blocked, SIGCHLD);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1655 #endif
41856
0028402ed7d1 (create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents: 40656
diff changeset
1656 #ifdef HAVE_WORKING_VFORK
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1657 /* On many hosts (e.g. Solaris 2.4), if a vforked child calls `signal',
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1658 this sets the parent's signal handlers as well as the child's.
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1659 So delay all interrupts whose handlers the child might munge,
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1660 and record the current handlers so they can be restored later. */
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1661 sigaddset (&blocked, SIGINT ); sigaction (SIGINT , 0, &sigint_action );
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1662 sigaddset (&blocked, SIGQUIT); sigaction (SIGQUIT, 0, &sigquit_action);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1663 #ifdef AIX
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1664 sigaddset (&blocked, SIGHUP ); sigaction (SIGHUP , 0, &sighup_action );
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1665 #endif
41856
0028402ed7d1 (create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents: 40656
diff changeset
1666 #endif /* HAVE_WORKING_VFORK */
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1667 sigprocmask (SIG_BLOCK, &blocked, &procmask);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1668 #else /* !POSIX_SIGNALS */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1669 #ifdef SIGCHLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1670 #ifdef BSD4_1
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1671 sighold (SIGCHLD);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1672 #else /* not BSD4_1 */
16220
02044b05d8e0 Replaced symbol BSD with BSD_SYSTEM.
Karl Heuer <kwzh@gnu.org>
parents: 16206
diff changeset
1673 #if defined (BSD_SYSTEM) || defined (UNIPLUS) || defined (HPUX)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1674 sigsetmask (sigmask (SIGCHLD));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1675 #else /* ordinary USG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1676 #if 0
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1677 sigchld_deferred = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1678 sigchld = signal (SIGCHLD, create_process_sigchld);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1679 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1680 #endif /* ordinary USG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1681 #endif /* not BSD4_1 */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1682 #endif /* SIGCHLD */
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1683 #endif /* !POSIX_SIGNALS */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1684
7893
e54617027a47 (create_process): Set input_wait_mask before forking.
Karl Heuer <kwzh@gnu.org>
parents: 7884
diff changeset
1685 FD_SET (inchannel, &input_wait_mask);
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
1686 FD_SET (inchannel, &non_keyboard_wait_mask);
7893
e54617027a47 (create_process): Set input_wait_mask before forking.
Karl Heuer <kwzh@gnu.org>
parents: 7884
diff changeset
1687 if (inchannel > max_process_desc)
e54617027a47 (create_process): Set input_wait_mask before forking.
Karl Heuer <kwzh@gnu.org>
parents: 7884
diff changeset
1688 max_process_desc = inchannel;
e54617027a47 (create_process): Set input_wait_mask before forking.
Karl Heuer <kwzh@gnu.org>
parents: 7884
diff changeset
1689
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1690 /* Until we store the proper pid, enable sigchld_handler
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1691 to recognize an unknown pid as standing for this process.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1692 It is very important not to let this `marker' value stay
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1693 in the table after this function has returned; if it does
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1694 it might cause call-process to hang and subsequent asynchronous
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1695 processes to get their return values scrambled. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1696 XSETINT (XPROCESS (process)->pid, -1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1697
16780
e9dc2569cb12 Include blockinput.h.
Richard M. Stallman <rms@gnu.org>
parents: 16728
diff changeset
1698 BLOCK_INPUT;
e9dc2569cb12 Include blockinput.h.
Richard M. Stallman <rms@gnu.org>
parents: 16728
diff changeset
1699
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1700 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1701 /* child_setup must clobber environ on systems with true vfork.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1702 Protect it from permanent change. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1703 char **save_environ = environ;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1704
21049
01e626b0a624 (Vdefault_file_name_coding_system): Extern it.
Kenichi Handa <handa@m17n.org>
parents: 20715
diff changeset
1705 current_dir = ENCODE_FILE (current_dir);
19837
3bee81323f73 (create_process): Encode the new current dir.
Richard M. Stallman <rms@gnu.org>
parents: 19642
diff changeset
1706
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1707 #ifndef WINDOWSNT
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1708 pid = vfork ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1709 if (pid == 0)
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1710 #endif /* not WINDOWSNT */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1711 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1712 int xforkin = forkin;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1713 int xforkout = forkout;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1714
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1715 #if 0 /* This was probably a mistake--it duplicates code later on,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1716 but fails to handle all the cases. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1717 /* Make sure SIGCHLD is not blocked in the child. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1718 sigsetmask (SIGEMPTYMASK);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1719 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1720
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1721 /* Make the pty be the controlling terminal of the process. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1722 #ifdef HAVE_PTYS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1723 /* First, disconnect its current controlling terminal. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1724 #ifdef HAVE_SETSID
7266
f87808bd90e9 (create_process): Undo April 19 setsid change.
Richard M. Stallman <rms@gnu.org>
parents: 7238
diff changeset
1725 /* We tried doing setsid only if pty_flag, but it caused
f87808bd90e9 (create_process): Undo April 19 setsid change.
Richard M. Stallman <rms@gnu.org>
parents: 7238
diff changeset
1726 process_set_signal to fail on SGI when using a pipe. */
f87808bd90e9 (create_process): Undo April 19 setsid change.
Richard M. Stallman <rms@gnu.org>
parents: 7238
diff changeset
1727 setsid ();
1030
9934251d8219 (WCOREDUMP): Define only if not defined.
Richard M. Stallman <rms@gnu.org>
parents: 1012
diff changeset
1728 /* Make the pty's terminal the controlling terminal. */
3023
cfd999700613 (create_process): Ignore retval from TIOCSTTY.
Richard M. Stallman <rms@gnu.org>
parents: 2961
diff changeset
1729 if (pty_flag)
6975
b7411e378b65 (create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 6947
diff changeset
1730 {
b7411e378b65 (create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 6947
diff changeset
1731 #ifdef TIOCSCTTY
b7411e378b65 (create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 6947
diff changeset
1732 /* We ignore the return value
b7411e378b65 (create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 6947
diff changeset
1733 because faith@cs.unc.edu says that is necessary on Linux. */
b7411e378b65 (create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 6947
diff changeset
1734 ioctl (xforkin, TIOCSCTTY, 0);
1030
9934251d8219 (WCOREDUMP): Define only if not defined.
Richard M. Stallman <rms@gnu.org>
parents: 1012
diff changeset
1735 #endif
6975
b7411e378b65 (create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 6947
diff changeset
1736 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1737 #else /* not HAVE_SETSID */
5181
31874690939f (create_process): Do setpgrp for USG regardless of IRIX.
Richard M. Stallman <rms@gnu.org>
parents: 5161
diff changeset
1738 #ifdef USG
5347
21bffe027a7d (create_process) [NTTYDISC]: Set the tty line discipline.
Richard M. Stallman <rms@gnu.org>
parents: 5332
diff changeset
1739 /* It's very important to call setpgrp here and no time
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1740 afterwards. Otherwise, we lose our controlling tty which
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1741 is set when we open the pty. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1742 setpgrp ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1743 #endif /* USG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1744 #endif /* not HAVE_SETSID */
7116
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1745 #if defined (HAVE_TERMIOS) && defined (LDISC1)
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1746 if (pty_flag && xforkin >= 0)
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1747 {
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1748 struct termios t;
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1749 tcgetattr (xforkin, &t);
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1750 t.c_lflag = LDISC1;
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1751 if (tcsetattr (xforkin, TCSANOW, &t) < 0)
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1752 emacs_write (1, "create_process/tcsetattr LDISC1 failed\n", 39);
7116
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1753 }
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1754 #else
6947
c5f990fad6bb (create_process): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 6928
diff changeset
1755 #if defined (NTTYDISC) && defined (TIOCSETD)
6393
7de1d288460e (create_process): Skip the ioctl if fd is -1.
Karl Heuer <kwzh@gnu.org>
parents: 6390
diff changeset
1756 if (pty_flag && xforkin >= 0)
5548
36d2fd17f833 (create_process): Set line discipline only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 5543
diff changeset
1757 {
36d2fd17f833 (create_process): Set line discipline only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 5543
diff changeset
1758 /* Use new line discipline. */
36d2fd17f833 (create_process): Set line discipline only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 5543
diff changeset
1759 int ldisc = NTTYDISC;
7605
53186c2698e5 (create_process): Don't complain about error from TIOCSETD.
Richard M. Stallman <rms@gnu.org>
parents: 7486
diff changeset
1760 ioctl (xforkin, TIOCSETD, &ldisc);
5548
36d2fd17f833 (create_process): Set line discipline only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 5543
diff changeset
1761 }
5347
21bffe027a7d (create_process) [NTTYDISC]: Set the tty line discipline.
Richard M. Stallman <rms@gnu.org>
parents: 5332
diff changeset
1762 #endif
7116
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1763 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1764 #ifdef TIOCNOTTY
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1765 /* In 4.3BSD, the TIOCSPGRP bug has been fixed, and now you
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1766 can do TIOCSPGRP only to the process's controlling tty. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1767 if (pty_flag)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1768 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1769 /* I wonder: would just ioctl (0, TIOCNOTTY, 0) work here?
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1770 I can't test it since I don't have 4.3. */
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1771 int j = emacs_open ("/dev/tty", O_RDWR, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1772 ioctl (j, TIOCNOTTY, 0);
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1773 emacs_close (j);
3826
647bef18618f Changes for Irix 4.0, tested this time:
Jim Blandy <jimb@redhat.com>
parents: 3810
diff changeset
1774 #ifndef USG
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1775 /* In order to get a controlling terminal on some versions
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1776 of BSD, it is necessary to put the process in pgrp 0
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1777 before it opens the terminal. */
16127
8d6d35b486c0 (create_process): Test HAVE_SETPGID for using setpgid.
Richard M. Stallman <rms@gnu.org>
parents: 16116
diff changeset
1778 #ifdef HAVE_SETPGID
9882
ccc5562a7194 (create_process) [OSF1]: Use setpgid, not setpgrp.
Richard M. Stallman <rms@gnu.org>
parents: 9793
diff changeset
1779 setpgid (0, 0);
ccc5562a7194 (create_process) [OSF1]: Use setpgid, not setpgrp.
Richard M. Stallman <rms@gnu.org>
parents: 9793
diff changeset
1780 #else
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1781 setpgrp (0, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1782 #endif
9882
ccc5562a7194 (create_process) [OSF1]: Use setpgid, not setpgrp.
Richard M. Stallman <rms@gnu.org>
parents: 9793
diff changeset
1783 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1784 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1785 #endif /* TIOCNOTTY */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1786
16076
5d1e0290bbd0 (create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 16058
diff changeset
1787 #if !defined (RTU) && !defined (UNIPLUS) && !defined (DONT_REOPEN_PTY)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1788 /*** There is a suggestion that this ought to be a
16076
5d1e0290bbd0 (create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 16058
diff changeset
1789 conditional on TIOCSPGRP,
5d1e0290bbd0 (create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 16058
diff changeset
1790 or !(defined (HAVE_SETSID) && defined (TIOCSCTTY)).
5d1e0290bbd0 (create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 16058
diff changeset
1791 Trying the latter gave the wrong results on Debian GNU/Linux 1.1;
5d1e0290bbd0 (create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 16058
diff changeset
1792 that system does seem to need this code, even though
5d1e0290bbd0 (create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 16058
diff changeset
1793 both HAVE_SETSID and TIOCSCTTY are defined. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1794 /* Now close the pty (if we had it open) and reopen it.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1795 This makes the pty the controlling terminal of the subprocess. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1796 if (pty_flag)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1797 {
5240
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
1798 #ifdef SET_CHILD_PTY_PGRP
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
1799 int pgrp = getpid ();
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
1800 #endif
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
1801
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1802 /* I wonder if emacs_close (emacs_open (pty_name, ...))
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1803 would work? */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1804 if (xforkin >= 0)
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1805 emacs_close (xforkin);
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1806 xforkout = xforkin = emacs_open (pty_name, O_RDWR, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1807
11514
321726163a65 (create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents: 11376
diff changeset
1808 if (xforkin < 0)
321726163a65 (create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents: 11376
diff changeset
1809 {
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1810 emacs_write (1, "Couldn't open the pty terminal ", 31);
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1811 emacs_write (1, pty_name, strlen (pty_name));
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1812 emacs_write (1, "\n", 1);
11514
321726163a65 (create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents: 11376
diff changeset
1813 _exit (1);
321726163a65 (create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents: 11376
diff changeset
1814 }
321726163a65 (create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents: 11376
diff changeset
1815
5240
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
1816 #ifdef SET_CHILD_PTY_PGRP
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
1817 ioctl (xforkin, TIOCSPGRP, &pgrp);
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
1818 ioctl (xforkout, TIOCSPGRP, &pgrp);
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
1819 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1820 }
16076
5d1e0290bbd0 (create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 16058
diff changeset
1821 #endif /* not UNIPLUS and not RTU and not DONT_REOPEN_PTY */
15368
6229fb866493 (create_process): Add DONT_OPEN_PTY conditional.
Richard M. Stallman <rms@gnu.org>
parents: 15355
diff changeset
1822
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1823 #ifdef SETUP_SLAVE_PTY
7058
1855e568a9b8 (create_process): Use SETUP_SLAVE_PTY only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 7044
diff changeset
1824 if (pty_flag)
1855e568a9b8 (create_process): Use SETUP_SLAVE_PTY only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 7044
diff changeset
1825 {
1855e568a9b8 (create_process): Use SETUP_SLAVE_PTY only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 7044
diff changeset
1826 SETUP_SLAVE_PTY;
1855e568a9b8 (create_process): Use SETUP_SLAVE_PTY only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 7044
diff changeset
1827 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1828 #endif /* SETUP_SLAVE_PTY */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1829 #ifdef AIX
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1830 /* On AIX, we've disabled SIGHUP above once we start a child on a pty.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1831 Now reenable it in the child, so it will die when we want it to. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1832 if (pty_flag)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1833 signal (SIGHUP, SIG_DFL);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1834 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1835 #endif /* HAVE_PTYS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1836
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1837 signal (SIGINT, SIG_DFL);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1838 signal (SIGQUIT, SIG_DFL);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1839
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1840 /* Stop blocking signals in the child. */
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1841 #ifdef POSIX_SIGNALS
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1842 sigprocmask (SIG_SETMASK, &procmask, 0);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1843 #else /* !POSIX_SIGNALS */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1844 #ifdef SIGCHLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1845 #ifdef BSD4_1
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1846 sigrelse (SIGCHLD);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1847 #else /* not BSD4_1 */
16220
02044b05d8e0 Replaced symbol BSD with BSD_SYSTEM.
Karl Heuer <kwzh@gnu.org>
parents: 16206
diff changeset
1848 #if defined (BSD_SYSTEM) || defined (UNIPLUS) || defined (HPUX)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1849 sigsetmask (SIGEMPTYMASK);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1850 #else /* ordinary USG */
1207
af619d68a576 * process.c [SIGCHLD && !BSD && !UNIPLUS && !HPUX]
Jim Blandy <jimb@redhat.com>
parents: 1180
diff changeset
1851 #if 0
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1852 signal (SIGCHLD, sigchld);
1207
af619d68a576 * process.c [SIGCHLD && !BSD && !UNIPLUS && !HPUX]
Jim Blandy <jimb@redhat.com>
parents: 1180
diff changeset
1853 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1854 #endif /* ordinary USG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1855 #endif /* not BSD4_1 */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1856 #endif /* SIGCHLD */
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1857 #endif /* !POSIX_SIGNALS */
8390
ee13e8728666 (create_process): Set default handling for SIGINT, etc.
Richard M. Stallman <rms@gnu.org>
parents: 8354
diff changeset
1858
7059
6a55de48ade5 (create_process): Use child_setup_tty only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 7058
diff changeset
1859 if (pty_flag)
6a55de48ade5 (create_process): Use child_setup_tty only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 7058
diff changeset
1860 child_setup_tty (xforkout);
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1861 #ifdef WINDOWSNT
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1862 pid = child_setup (xforkin, xforkout, xforkout,
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1863 new_argv, 1, current_dir);
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1864 #else /* not WINDOWSNT */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1865 child_setup (xforkin, xforkout, xforkout,
638
40b255f55df3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 624
diff changeset
1866 new_argv, 1, current_dir);
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1867 #endif /* not WINDOWSNT */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1868 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1869 environ = save_environ;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1870 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1871
16780
e9dc2569cb12 Include blockinput.h.
Richard M. Stallman <rms@gnu.org>
parents: 16728
diff changeset
1872 UNBLOCK_INPUT;
e9dc2569cb12 Include blockinput.h.
Richard M. Stallman <rms@gnu.org>
parents: 16728
diff changeset
1873
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1874 /* This runs in the Emacs process. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1875 if (pid < 0)
7157
3f4fc9d682b4 (create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents: 7116
diff changeset
1876 {
3f4fc9d682b4 (create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents: 7116
diff changeset
1877 if (forkin >= 0)
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1878 emacs_close (forkin);
7157
3f4fc9d682b4 (create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents: 7116
diff changeset
1879 if (forkin != forkout && forkout >= 0)
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1880 emacs_close (forkout);
7157
3f4fc9d682b4 (create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents: 7116
diff changeset
1881 }
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1882 else
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1883 {
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1884 /* vfork succeeded. */
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1885 XSETFASTINT (XPROCESS (process)->pid, pid);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1886
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1887 #ifdef WINDOWSNT
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1888 register_child (pid, inchannel);
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1889 #endif /* WINDOWSNT */
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1890
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1891 /* If the subfork execv fails, and it exits,
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1892 this close hangs. I don't know why.
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1893 So have an interrupt jar it loose. */
27430
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1894 {
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1895 struct atimer *timer;
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1896 EMACS_TIME offset;
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1897
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1898 stop_polling ();
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1899 EMACS_SET_SECS_USECS (offset, 1, 0);
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1900 timer = start_atimer (ATIMER_RELATIVE, offset, create_process_1, 0);
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1901
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1902 XPROCESS (process)->subtty = Qnil;
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1903 if (forkin >= 0)
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1904 emacs_close (forkin);
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1905
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1906 cancel_atimer (timer);
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1907 start_polling ();
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1908 }
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1909
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1910 if (forkin != forkout && forkout >= 0)
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1911 emacs_close (forkout);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1912
11609
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
1913 #ifdef HAVE_PTYS
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1914 if (pty_flag)
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1915 XPROCESS (process)->tty_name = build_string (pty_name);
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1916 else
11609
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
1917 #endif
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1918 XPROCESS (process)->tty_name = Qnil;
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1919 }
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1920
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1921 /* Restore the signal state whether vfork succeeded or not.
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1922 (We will signal an error, below, if it failed.) */
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1923 #ifdef POSIX_SIGNALS
41856
0028402ed7d1 (create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents: 40656
diff changeset
1924 #ifdef HAVE_WORKING_VFORK
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1925 /* Restore the parent's signal handlers. */
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1926 sigaction (SIGINT, &sigint_action, 0);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1927 sigaction (SIGQUIT, &sigquit_action, 0);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1928 #ifdef AIX
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1929 sigaction (SIGHUP, &sighup_action, 0);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1930 #endif
41856
0028402ed7d1 (create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents: 40656
diff changeset
1931 #endif /* HAVE_WORKING_VFORK */
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1932 /* Stop blocking signals in the parent. */
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1933 sigprocmask (SIG_SETMASK, &procmask, 0);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1934 #else /* !POSIX_SIGNALS */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1935 #ifdef SIGCHLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1936 #ifdef BSD4_1
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1937 sigrelse (SIGCHLD);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1938 #else /* not BSD4_1 */
16220
02044b05d8e0 Replaced symbol BSD with BSD_SYSTEM.
Karl Heuer <kwzh@gnu.org>
parents: 16206
diff changeset
1939 #if defined (BSD_SYSTEM) || defined (UNIPLUS) || defined (HPUX)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1940 sigsetmask (SIGEMPTYMASK);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1941 #else /* ordinary USG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1942 #if 0
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1943 signal (SIGCHLD, sigchld);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1944 /* Now really handle any of these signals
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1945 that came in during this function. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1946 if (sigchld_deferred)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1947 kill (getpid (), SIGCHLD);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1948 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1949 #endif /* ordinary USG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1950 #endif /* not BSD4_1 */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1951 #endif /* SIGCHLD */
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1952 #endif /* !POSIX_SIGNALS */
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1953
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1954 /* Now generate the error if vfork failed. */
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1955 if (pid < 0)
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1956 report_file_error ("Doing vfork", Qnil);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1957 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1958 #endif /* not VMS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1959
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1960
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1961 #ifdef HAVE_SOCKETS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1962
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1963 /* Convert an internal struct sockaddr to a lisp object (vector or string).
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1964 The address family of sa is not included in the result. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1965
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1966 static Lisp_Object
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1967 conv_sockaddr_to_lisp (sa, len)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1968 struct sockaddr *sa;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1969 int len;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1970 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1971 Lisp_Object address;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1972 int i;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1973 unsigned char *cp;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1974 register struct Lisp_Vector *p;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1975
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1976 switch (sa->sa_family)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1977 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1978 case AF_INET:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1979 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1980 struct sockaddr_in *sin = (struct sockaddr_in *) sa;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1981 len = sizeof (sin->sin_addr) + 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1982 address = Fmake_vector (make_number (len), Qnil);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1983 p = XVECTOR (address);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1984 p->contents[--len] = make_number (ntohs (sin->sin_port));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1985 cp = (unsigned char *)&sin->sin_addr;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1986 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1987 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1988 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1989 case AF_LOCAL:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1990 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1991 struct sockaddr_un *sun = (struct sockaddr_un *) sa;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1992 for (i = 0; i < sizeof (sun->sun_path); i++)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1993 if (sun->sun_path[i] == 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1994 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1995 return make_unibyte_string (sun->sun_path, i);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1996 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1997 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1998 default:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1999 len -= sizeof (sa->sa_family);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2000 address = Fcons (make_number (sa->sa_family),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2001 Fmake_vector (make_number (len), Qnil));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2002 p = XVECTOR (XCDR (address));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2003 cp = (unsigned char *) sa + sizeof (sa->sa_family);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2004 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2005 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2006
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2007 i = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2008 while (i < len)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2009 p->contents[i++] = make_number (*cp++);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2010
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2011 return address;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2012 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2013
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2014
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2015 /* Get family and required size for sockaddr structure to hold ADDRESS. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2016
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2017 static int
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2018 get_lisp_to_sockaddr_size (address, familyp)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2019 Lisp_Object address;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2020 int *familyp;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2021 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2022 register struct Lisp_Vector *p;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2023
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2024 if (VECTORP (address))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2025 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2026 p = XVECTOR (address);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2027 if (p->size == 5)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2028 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2029 *familyp = AF_INET;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2030 return sizeof (struct sockaddr_in);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2031 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2032 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2033 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2034 else if (STRINGP (address))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2035 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2036 *familyp = AF_LOCAL;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2037 return sizeof (struct sockaddr_un);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2038 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2039 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2040 else if (CONSP (address) && INTEGERP (XCAR (address)) && VECTORP (XCDR (address)))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2041 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2042 struct sockaddr *sa;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2043 *familyp = XINT (XCAR (address));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2044 p = XVECTOR (XCDR (address));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2045 return p->size + sizeof (sa->sa_family);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2046 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2047 return 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2048 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2049
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2050 /* Convert an address object (vector or string) to an internal sockaddr.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2051 Format of address has already been validated by size_lisp_to_sockaddr. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2052
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2053 static void
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2054 conv_lisp_to_sockaddr (family, address, sa, len)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2055 int family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2056 Lisp_Object address;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2057 struct sockaddr *sa;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2058 int len;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2059 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2060 register struct Lisp_Vector *p;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2061 register unsigned char *cp;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2062 register int i;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2063
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2064 bzero (sa, len);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2065 sa->sa_family = family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2066
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2067 if (VECTORP (address))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2068 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2069 p = XVECTOR (address);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2070 if (family == AF_INET)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2071 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2072 struct sockaddr_in *sin = (struct sockaddr_in *) sa;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2073 len = sizeof (sin->sin_addr) + 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2074 i = XINT (p->contents[--len]);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2075 sin->sin_port = htons (i);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2076 cp = (unsigned char *)&sin->sin_addr;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2077 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2078 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2079 else if (STRINGP (address))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2080 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2081 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2082 if (family == AF_LOCAL)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2083 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2084 struct sockaddr_un *sun = (struct sockaddr_un *) sa;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2085 cp = XSTRING (address)->data;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2086 for (i = 0; i < sizeof (sun->sun_path) && *cp; i++)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2087 sun->sun_path[i] = *cp++;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2088 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2089 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2090 return;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2091 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2092 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2093 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2094 p = XVECTOR (XCDR (address));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2095 cp = (unsigned char *)sa + sizeof (sa->sa_family);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2096 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2097
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2098 for (i = 0; i < len; i++)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2099 if (INTEGERP (p->contents[i]))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2100 *cp++ = XFASTINT (p->contents[i]) & 0xff;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2101 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2102
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2103 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2104 DEFUN ("process-datagram-address", Fprocess_datagram_address, Sprocess_datagram_address,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2105 1, 1, 0,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2106 doc: /* Get the current datagram address associated with PROCESS. */)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2107 (process)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2108 Lisp_Object process;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2109 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2110 int channel;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2111
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2112 CHECK_PROCESS (process);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2113
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2114 if (!DATAGRAM_CONN_P (process))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2115 return Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2116
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2117 channel = XPROCESS (process)->infd;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2118 return conv_sockaddr_to_lisp (datagram_address[channel].sa,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2119 datagram_address[channel].len);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2120 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2121
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2122 DEFUN ("set-process-datagram-address", Fset_process_datagram_address, Sset_process_datagram_address,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2123 2, 2, 0,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2124 doc: /* Set the datagram address for PROCESS to ADDRESS.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2125 Returns nil upon error setting address, ADDRESS otherwise. */)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2126 (process, address)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2127 Lisp_Object process, address;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2128 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2129 int channel;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2130 int family, len;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2131
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2132 CHECK_PROCESS (process);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2133
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2134 if (!DATAGRAM_CONN_P (process))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2135 return Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2136
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2137 channel = XPROCESS (process)->infd;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2138
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2139 len = get_lisp_to_sockaddr_size (address, &family);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2140 if (datagram_address[channel].len != len)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2141 return Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2142 conv_lisp_to_sockaddr (family, address, datagram_address[channel].sa, len);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2143 return address;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2144 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2145 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2146
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2147
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2148 static struct socket_options {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2149 /* The name of this option. Should be lowercase version of option
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2150 name without SO_ prefix. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2151 char *name;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2152 /* Length of name. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2153 int nlen;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2154 /* Option level SOL_... */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2155 int optlevel;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2156 /* Option number SO_... */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2157 int optnum;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2158 enum { SOPT_UNKNOWN, SOPT_BOOL, SOPT_INT, SOPT_STR, SOPT_LINGER } opttype;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2159 } socket_options[] =
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2160 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2161 #ifdef SO_BINDTODEVICE
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2162 { "bindtodevice", 12, SOL_SOCKET, SO_BINDTODEVICE, SOPT_STR },
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2163 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2164 #ifdef SO_BROADCAST
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2165 { "broadcast", 9, SOL_SOCKET, SO_BROADCAST, SOPT_BOOL },
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2166 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2167 #ifdef SO_DONTROUTE
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2168 { "dontroute", 9, SOL_SOCKET, SO_DONTROUTE, SOPT_BOOL },
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2169 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2170 #ifdef SO_KEEPALIVE
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2171 { "keepalive", 9, SOL_SOCKET, SO_KEEPALIVE, SOPT_BOOL },
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2172 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2173 #ifdef SO_LINGER
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2174 { "linger", 6, SOL_SOCKET, SO_LINGER, SOPT_LINGER },
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2175 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2176 #ifdef SO_OOBINLINE
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2177 { "oobinline", 9, SOL_SOCKET, SO_OOBINLINE, SOPT_BOOL },
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2178 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2179 #ifdef SO_PRIORITY
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2180 { "priority", 8, SOL_SOCKET, SO_PRIORITY, SOPT_INT },
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2181 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2182 #ifdef SO_REUSEADDR
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2183 { "reuseaddr", 9, SOL_SOCKET, SO_REUSEADDR, SOPT_BOOL },
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2184 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2185 { 0, 0, 0, 0, SOPT_UNKNOWN }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2186 };
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2187
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2188 /* Process list of socket options OPTS on socket S.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2189 Only check if options are supported is S < 0.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2190 If NO_ERROR is non-zero, continue silently if an option
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2191 cannot be set.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2192
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2193 Each element specifies one option. An element is either a string
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2194 "OPTION=VALUE" or a cons (OPTION . VALUE) where OPTION is a string
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2195 or a symbol. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2196
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2197 static int
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2198 set_socket_options (s, opts, no_error)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2199 int s;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2200 Lisp_Object opts;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2201 int no_error;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2202 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2203 if (!CONSP (opts))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2204 opts = Fcons (opts, Qnil);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2205
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2206 while (CONSP (opts))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2207 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2208 Lisp_Object opt;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2209 Lisp_Object val;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2210 char *name, *arg;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2211 struct socket_options *sopt;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2212 int ret = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2213
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2214 opt = XCAR (opts);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2215 opts = XCDR (opts);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2216
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2217 name = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2218 val = Qt;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2219 if (CONSP (opt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2220 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2221 val = XCDR (opt);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2222 opt = XCAR (opt);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2223 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2224 if (STRINGP (opt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2225 name = (char *) XSTRING (opt)->data;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2226 else if (SYMBOLP (opt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2227 name = (char *) XSYMBOL (opt)->name->data;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2228 else {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2229 error ("Mal-formed option list");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2230 return 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2231 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2232
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2233 if (strncmp (name, "no", 2) == 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2234 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2235 val = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2236 name += 2;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2237 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2238
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2239 arg = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2240 for (sopt = socket_options; sopt->name; sopt++)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2241 if (strncmp (name, sopt->name, sopt->nlen) == 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2242 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2243 if (name[sopt->nlen] == 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2244 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2245 if (name[sopt->nlen] == '=')
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2246 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2247 arg = name + sopt->nlen + 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2248 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2249 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2250 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2251
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2252 switch (sopt->opttype)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2253 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2254 case SOPT_BOOL:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2255 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2256 int optval;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2257 if (s < 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2258 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2259 if (arg)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2260 optval = (*arg == '0' || *arg == 'n') ? 0 : 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2261 else if (INTEGERP (val))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2262 optval = XINT (val) == 0 ? 0 : 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2263 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2264 optval = NILP (val) ? 0 : 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2265 ret = setsockopt (s, sopt->optlevel, sopt->optnum,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2266 &optval, sizeof (optval));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2267 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2268 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2269
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2270 case SOPT_INT:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2271 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2272 int optval;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2273 if (arg)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2274 optval = atoi(arg);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2275 else if (INTEGERP (val))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2276 optval = XINT (val);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2277 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2278 error ("Bad option argument for %s", name);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2279 if (s < 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2280 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2281 ret = setsockopt (s, sopt->optlevel, sopt->optnum,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2282 &optval, sizeof (optval));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2283 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2284 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2285
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2286 case SOPT_STR:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2287 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2288 if (!arg)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2289 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2290 if (NILP (val))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2291 arg = "";
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2292 else if (STRINGP (val))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2293 arg = (char *) XSTRING (val)->data;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2294 else if (XSYMBOL (val))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2295 arg = (char *) XSYMBOL (val)->name->data;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2296 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2297 error ("Invalid argument to %s option", name);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2298 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2299 ret = setsockopt (s, sopt->optlevel, sopt->optnum,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2300 arg, strlen (arg));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2301 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2302
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2303 #ifdef SO_LINGER
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2304 case SOPT_LINGER:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2305 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2306 struct linger linger;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2307
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2308 linger.l_onoff = 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2309 linger.l_linger = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2310
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2311 if (s < 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2312 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2313
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2314 if (arg)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2315 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2316 if (*arg == 'n' || *arg == 't' || *arg == 'y')
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2317 linger.l_onoff = (*arg == 'n') ? 0 : 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2318 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2319 linger.l_linger = atoi(arg);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2320 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2321 else if (INTEGERP (val))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2322 linger.l_linger = XINT (val);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2323 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2324 linger.l_onoff = NILP (val) ? 0 : 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2325 ret = setsockopt (s, sopt->optlevel, sopt->optnum,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2326 &linger, sizeof (linger));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2327 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2328 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2329 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2330 default:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2331 if (s < 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2332 return 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2333 if (no_error)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2334 continue;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2335 error ("Unsupported option: %s", name);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2336 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2337 if (ret < 0 && ! no_error)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2338 report_file_error ("Cannot set network option: %s", opt);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2339 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2340 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2341 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2342
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2343 DEFUN ("set-network-process-options",
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2344 Fset_network_process_options, Sset_network_process_options,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2345 1, MANY, 0,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2346 doc: /* Set one or more options for network process PROCESS.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2347 Arguments are PROCESS &rest OPTIONS.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2348 Each option is either a string "OPT=VALUE" or a cons (OPT . VALUE).
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2349 A boolean value is false if it either zero or nil, true otherwise.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2350
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2351 The following options are known. Consult the relevant system manual
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2352 pages for more information.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2353
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2354 bindtodevice=NAME -- bind to interface NAME, or remove binding if nil.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2355 broadcast=BOOL -- Allow send and receive of datagram broadcasts.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2356 dontroute=BOOL -- Only send to directly connected hosts.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2357 keepalive=BOOL -- Send keep-alive messages on network stream.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2358 linger=BOOL or TIMEOUT -- Send queued messages before closing.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2359 oobinline=BOOL -- Place out-of-band data in receive data stream.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2360 priority=INT -- Set protocol defined priority for sent packets.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2361 reuseaddr=BOOL -- Allow reusing a recently used address. */)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2362 (nargs, args)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2363 int nargs;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2364 Lisp_Object *args;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2365 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2366 Lisp_Object process;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2367 Lisp_Object opts;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2368
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2369 process = args[0];
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2370 CHECK_PROCESS (process);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2371 if (nargs > 1 && XPROCESS (process)->infd >= 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2372 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2373 opts = Flist (nargs, args);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2374 set_socket_options (XPROCESS (process)->infd, opts, 0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2375 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2376 return process;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2377 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2378
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2379 /* Check whether a given KEY VALUE pair is supported on this system. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2380
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2381 static int
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2382 network_process_featurep (key, value)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2383 Lisp_Object key, value;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2384 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2385
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2386 if (EQ (key, QCnowait))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2387 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2388 #ifdef NON_BLOCKING_CONNECT
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2389 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2390 #else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2391 return NILP (value);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2392 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2393 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2394
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2395 if (EQ (key, QCdatagram))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2396 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2397 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2398 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2399 #else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2400 return NILP (value);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2401 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2402 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2403
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2404 if (EQ (key, QCfamily))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2405 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2406 if (NILP (value))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2407 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2408 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2409 if (EQ (key, Qlocal))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2410 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2411 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2412 return 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2413 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2414
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2415 if (EQ (key, QCname))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2416 return STRINGP (value);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2417
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2418 if (EQ (key, QCbuffer))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2419 return (NILP (value) || STRINGP (value) || BUFFERP (value));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2420
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2421 if (EQ (key, QClocal) || EQ (key, QCremote))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2422 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2423 int family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2424 return get_lisp_to_sockaddr_size (value, &family);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2425 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2426
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2427 if (EQ (key, QChost))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2428 return (NILP (value) || STRINGP (value));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2429
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2430 if (EQ (key, QCservice))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2431 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2432 #ifdef HAVE_GETSOCKNAME
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2433 if (EQ (value, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2434 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2435 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2436 return (INTEGERP (value) || STRINGP (value));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2437 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2438
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2439 if (EQ (key, QCserver))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2440 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2441 #ifndef TERM
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2442 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2443 #else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2444 return NILP (value);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2445 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2446 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2447
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2448 if (EQ (key, QCoptions))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2449 return set_socket_options (-1, value, 0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2450
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2451 if (EQ (key, QCcoding))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2452 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2453 if (EQ (key, QCsentinel))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2454 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2455 if (EQ (key, QCfilter))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2456 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2457 if (EQ (key, QClog))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2458 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2459 if (EQ (key, QCnoquery))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2460 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2461 if (EQ (key, QCstop))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2462 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2463
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2464 return 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2465 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2466
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2467 /* A version of request_sigio suitable for a record_unwind_protect. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2468
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2469 Lisp_Object
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2470 unwind_request_sigio (dummy)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2471 Lisp_Object dummy;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2472 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2473 if (interrupt_input)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2474 request_sigio ();
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2475 return Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2476 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2477
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2478 /* Create a network stream/datagram client/server process. Treated
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2479 exactly like a normal process when reading and writing. Primary
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2480 differences are in status display and process deletion. A network
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2481 connection has no PID; you cannot signal it. All you can do is
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2482 stop/continue it and deactivate/close it via delete-process */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2483
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2484 DEFUN ("make-network-process", Fmake_network_process, Smake_network_process,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2485 0, MANY, 0,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2486 doc: /* Create and return a network server or client process.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2487
43995
110955214222 (Fmake_network_process): Remove unused variable `sa'.
Pavel Janík <Pavel@Janik.cz>
parents: 43968
diff changeset
2488 In Emacs, network connections are represented by process objects, so
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2489 input and output work as for subprocesses and `delete-process' closes
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2490 a network connection. However, a network process has no process id,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2491 it cannot be signalled, and the status codes are different from normal
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2492 processes.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2493
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2494 Arguments are specified as keyword/argument pairs. The following
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2495 arguments are defined:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2496
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2497 :name NAME -- NAME is name for process. It is modified if necessary
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2498 to make it unique.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2499
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2500 :buffer BUFFER -- BUFFER is the buffer (or buffer-name) to associate
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2501 with the process. Process output goes at end of that buffer, unless
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2502 you specify an output stream or filter function to handle the output.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2503 BUFFER may be also nil, meaning that this process is not associated
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2504 with any buffer.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2505
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2506 :host HOST -- HOST is name of the host to connect to, or its IP
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2507 address. The symbol `local' specifies the local host. If specified
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2508 for a server process, it must be a valid name or address for the local
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2509 host, and only clients connecting to that address will be accepted.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2510
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2511 :service SERVICE -- SERVICE is name of the service desired, or an
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2512 integer specifying a port number to connect to. If SERVICE is t,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2513 a random port number is selected for the server.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2514
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2515 :family FAMILY -- FAMILY is the address (and protocol) family for the
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2516 service specified by HOST and SERVICE. The default address family is
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2517 Inet (or IPv4) for the host and port number specified by HOST and
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2518 SERVICE. Other address families supported are:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2519 local -- for a local (i.e. UNIX) address specified by SERVICE.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2520
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2521 :local ADDRESS -- ADDRESS is the local address used for the connection.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2522 This parameter is ignored when opening a client process. When specified
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2523 for a server process, the FAMILY, HOST and SERVICE args are ignored.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2524
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2525 :remote ADDRESS -- ADDRESS is the remote partner's address for the
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2526 connection. This parameter is ignored when opening a stream server
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2527 process. For a datagram server process, it specifies the initial
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2528 setting of the remote datagram address. When specified for a client
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2529 process, the FAMILY, HOST, and SERVICE args are ignored.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2530
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2531 The format of ADDRESS depends on the address family:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2532 - An IPv4 address is represented as an vector of integers [A B C D P]
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2533 corresponding to numeric IP address A.B.C.D and port number P.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2534 - A local address is represented as a string with the address in the
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2535 local address space.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2536 - An "unsupported family" address is represented by a cons (F . AV)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2537 where F is the family number and AV is a vector containing the socket
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2538 address data with one element per address data byte. Do not rely on
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2539 this format in portable code, as it may depend on implementation
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2540 defined constants, data sizes, and data structure alignment.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2541
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2542 :coding CODING -- CODING is coding system for this process.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2543
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2544 :datagram BOOL -- Create a datagram type connection if BOOL is
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2545 non-nil. Default is a stream type connection.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2546
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2547 :options OPTIONS -- Set the specified options for the network process.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2548 See `set-process-options' for details.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2549
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2550 :nowait BOOL -- If BOOL is non-nil for a stream type client process,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2551 return without waiting for the connection to complete; instead, the
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2552 sentinel function will be called with second arg matching "open" (if
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2553 successful) or "failed" when the connect completes. Default is to use
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2554 a blocking connect (i.e. wait) for stream type connections.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2555
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2556 :noquery BOOL -- Query the user unless BOOL is non-nil, and process is
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2557 running when emacs is exited.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2558
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2559 :stop BOOL -- Start process in the `stopped' state if BOOL non-nil.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2560 In the stopped state, a server process does not accept new
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2561 connections, and a client process does not handle incoming traffic.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2562 The stopped state is cleared by `continue-process' and set by
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2563 `stop-process'.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2564
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2565 :filter FILTER -- Install FILTER as the process filter.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2566
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2567 :sentinel SENTINEL -- Install SENTINEL as the process sentinel.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2568
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2569 :log LOG -- Install LOG as the server process log function. This
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2570 function is called as when the server accepts a network connection from a
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2571 client. The arguments are SERVER, CLIENT, and MESSAGE, where SERVER
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2572 is the server process, CLIENT is the new process for the connection,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2573 and MESSAGE is a string.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2574
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2575 :server BOOL -- if BOOL is non-nil, create a server process for the
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2576 specified FAMILY, SERVICE, and connection type (stream or datagram).
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2577 Default is a client process.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2578
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2579 A server process will listen for and accept connections from
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2580 clients. When a client connection is accepted, a new network process
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2581 is created for the connection with the following parameters:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2582 - The client's process name is constructed by concatenating the server
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2583 process' NAME and a client identification string.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2584 - If the FILTER argument is non-nil, the client process will not get a
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2585 separate process buffer; otherwise, the client's process buffer is a newly
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2586 created buffer named after the server process' BUFFER name or process
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2587 NAME concatenated with the client identification string.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2588 - The connection type and the process filter and sentinel parameters are
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2589 inherited from the server process' TYPE, FILTER and SENTINEL.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2590 - The client process' contact info is set according to the client's
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2591 addressing information (typically an IP address and a port number).
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2592
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2593 Notice that the FILTER and SENTINEL args are never used directly by
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2594 the server process. Also, the BUFFER argument is not used directly by
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2595 the server process, but via `network-server-log-function' hook, a log
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2596 of the accepted (and failed) connections may be recorded in the server
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2597 process' buffer.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2598
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2599 The following special call returns t iff a given KEY VALUE
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2600 pair is supported on this system:
43995
110955214222 (Fmake_network_process): Remove unused variable `sa'.
Pavel Janík <Pavel@Janik.cz>
parents: 43968
diff changeset
2601 (make-network-process :feature KEY VALUE)
110955214222 (Fmake_network_process): Remove unused variable `sa'.
Pavel Janík <Pavel@Janik.cz>
parents: 43968
diff changeset
2602
110955214222 (Fmake_network_process): Remove unused variable `sa'.
Pavel Janík <Pavel@Janik.cz>
parents: 43968
diff changeset
2603 usage: (make-network-process &rest ARGS) */)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2604 (nargs, args)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2605 int nargs;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2606 Lisp_Object *args;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2607 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2608 Lisp_Object proc;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2609 Lisp_Object contact;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2610 struct Lisp_Process *p;
32032
633b826a56f3 (Fopen_network_stream) [HAVE_GETADDRINFO]: Use
Gerd Moellmann <gerd@gnu.org>
parents: 31806
diff changeset
2611 #ifdef HAVE_GETADDRINFO
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2612 struct addrinfo ai, *res, *lres;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2613 struct addrinfo hints;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2614 char *portstring, portbuf[128];
32032
633b826a56f3 (Fopen_network_stream) [HAVE_GETADDRINFO]: Use
Gerd Moellmann <gerd@gnu.org>
parents: 31806
diff changeset
2615 #else /* HAVE_GETADDRINFO */
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2616 struct _emacs_addrinfo
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2617 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2618 int ai_family;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2619 int ai_socktype;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2620 int ai_protocol;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2621 int ai_addrlen;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2622 struct sockaddr *ai_addr;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2623 struct _emacs_addrinfo *ai_next;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2624 } ai, *res, *lres;
25262
ccf83ed7326a (Fopen_network_stream): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents: 25248
diff changeset
2625 #endif /* HAVE_GETADDRINFO */
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2626 struct sockaddr_in address_in;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2627 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2628 struct sockaddr_un address_un;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2629 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2630 int port;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2631 int ret = 0;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2632 int xerrno = 0;
25262
ccf83ed7326a (Fopen_network_stream): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents: 25248
diff changeset
2633 int s = -1, outch, inch;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2634 struct gcpro gcpro1;
7220
a33eb16cab9d (Fopen_network_stream): Retry the connect if EADDRINUSE. Ignore EISCONN.
Richard M. Stallman <rms@gnu.org>
parents: 7157
diff changeset
2635 int retry = 0;
7486
cfe4840ffde9 (Fopen_network_stream): Call bind_polling_period; later unbind the binding.
Richard M. Stallman <rms@gnu.org>
parents: 7454
diff changeset
2636 int count = specpdl_ptr - specpdl;
25705
1f109108fa7e (Fopen_network_stream): Avoid socket decriptor leak.
Andreas Schwab <schwab@suse.de>
parents: 25645
diff changeset
2637 int count1;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2638 Lisp_Object QCaddress; /* one of QClocal or QCremote */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2639 Lisp_Object tem;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2640 Lisp_Object name, buffer, host, service, address;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2641 Lisp_Object filter, sentinel;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2642 int is_non_blocking_client = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2643 int is_server = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2644 int socktype = SOCK_STREAM;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2645 int family = -1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2646
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2647 if (nargs == 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2648 return Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2649
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2650 /* Handle :feature KEY VALUE query. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2651 if (EQ (args[0], QCfeature))
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2652 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2653 if (nargs != 3)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2654 return Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2655 return network_process_featurep (args[1], args[2]) ? Qt : Qnil;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2656 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2657
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2658 /* Save arguments for process-contact and clone-process. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2659 contact = Flist (nargs, args);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2660 GCPRO1 (contact);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2661
15355
6bb377ef707f (Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents: 15092
diff changeset
2662 #ifdef WINDOWSNT
6bb377ef707f (Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents: 15092
diff changeset
2663 /* Ensure socket support is loaded if available. */
6bb377ef707f (Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents: 15092
diff changeset
2664 init_winsock (TRUE);
6bb377ef707f (Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents: 15092
diff changeset
2665 #endif
6bb377ef707f (Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents: 15092
diff changeset
2666
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2667 /* :datagram BOOL */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2668 tem = Fplist_get (contact, QCdatagram);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2669 if (!NILP (tem))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2670 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2671 #ifndef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2672 error ("Datagram connections not supported");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2673 #else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2674 socktype = SOCK_DGRAM;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2675 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2676 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2677
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2678 /* :server BOOL */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2679 tem = Fplist_get (contact, QCserver);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2680 if (!NILP (tem))
25248
f0fc8443bdbb (Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents: 25129
diff changeset
2681 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2682 #ifdef TERM
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2683 error ("Network servers not supported");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2684 #else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2685 is_server = 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2686 #endif
25248
f0fc8443bdbb (Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents: 25129
diff changeset
2687 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2688
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2689 /* Make QCaddress an alias for :local (server) or :remote (client). */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2690 QCaddress = is_server ? QClocal : QCremote;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2691
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2692 /* :wait BOOL */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2693 if (!is_server && socktype == SOCK_STREAM
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2694 && (tem = Fplist_get (contact, QCnowait), !NILP (tem)))
25248
f0fc8443bdbb (Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents: 25129
diff changeset
2695 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2696 #ifndef NON_BLOCKING_CONNECT
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2697 error ("Non-blocking connect not supported");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2698 #else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2699 is_non_blocking_client = 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2700 #endif
25248
f0fc8443bdbb (Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents: 25129
diff changeset
2701 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2702
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2703 name = Fplist_get (contact, QCname);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2704 buffer = Fplist_get (contact, QCbuffer);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2705 filter = Fplist_get (contact, QCfilter);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2706 sentinel = Fplist_get (contact, QCsentinel);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2707
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2708 CHECK_STRING (name);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2709
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2710 #ifdef TERM
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2711 /* Let's handle TERM before things get complicated ... */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2712 host = Fplist_get (contact, QChost);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2713 CHECK_STRING (host);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2714
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2715 service = Fplist_get (contact, QCservice);
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
2716 if (INTEGERP (service))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2717 port = htons ((unsigned short) XINT (service));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2718 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2719 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2720 struct servent *svc_info;
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
2721 CHECK_STRING (service);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2722 svc_info = getservbyname (XSTRING (service)->data, "tcp");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2723 if (svc_info == 0)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2724 error ("Unknown service: %s", XSTRING (service)->data);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2725 port = svc_info->s_port;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2726 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2727
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2728 s = connect_server (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2729 if (s < 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2730 report_file_error ("error creating socket", Fcons (name, Qnil));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2731 send_command (s, C_PORT, 0, "%s:%d", XSTRING (host)->data, ntohs (port));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2732 send_command (s, C_DUMB, 1, 0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2733
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2734 #else /* not TERM */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2735
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2736 /* Initialize addrinfo structure in case we don't use getaddrinfo. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2737 ai.ai_socktype = socktype;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2738 ai.ai_protocol = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2739 ai.ai_next = NULL;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2740 res = &ai;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2741
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2742 /* :local ADDRESS or :remote ADDRESS */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2743 address = Fplist_get (contact, QCaddress);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2744 if (!NILP (address))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2745 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2746 host = service = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2747
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2748 if (!(ai.ai_addrlen = get_lisp_to_sockaddr_size (address, &family)))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2749 error ("Malformed :address");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2750 ai.ai_family = family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2751 ai.ai_addr = alloca (ai.ai_addrlen);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2752 conv_lisp_to_sockaddr (family, address, ai.ai_addr, ai.ai_addrlen);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2753 goto open_socket;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2754 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2755
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2756 /* :family FAMILY -- nil (for Inet), local, or integer. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2757 tem = Fplist_get (contact, QCfamily);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2758 if (INTEGERP (tem))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2759 family = XINT (tem);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2760 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2761 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2762 if (NILP (tem))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2763 family = AF_INET;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2764 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2765 else if (EQ (tem, Qlocal))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2766 family = AF_LOCAL;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2767 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2768 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2769 if (family < 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2770 error ("Unknown address family");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2771 ai.ai_family = family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2772
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2773 /* :service SERVICE -- string, integer (port number), or t (random port). */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2774 service = Fplist_get (contact, QCservice);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2775
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2776 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2777 if (family == AF_LOCAL)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2778 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2779 /* Host is not used. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2780 host = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2781 CHECK_STRING (service);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2782 bzero (&address_un, sizeof address_un);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2783 address_un.sun_family = AF_LOCAL;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2784 strncpy (address_un.sun_path, XSTRING (service)->data, sizeof address_un.sun_path);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2785 ai.ai_addr = (struct sockaddr *) &address_un;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2786 ai.ai_addrlen = sizeof address_un;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2787 goto open_socket;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2788 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2789 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2790
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2791 /* :host HOST -- hostname, ip address, or 'local for localhost. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2792 host = Fplist_get (contact, QChost);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2793 if (!NILP (host))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2794 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2795 if (EQ (host, Qlocal))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2796 host = build_string ("localhost");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2797 CHECK_STRING (host);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2798 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2799
13777
5e0cbd5fcb46 (Fopen_network_stream): Call bind_polling_period earlier.
Karl Heuer <kwzh@gnu.org>
parents: 13709
diff changeset
2800 /* Slow down polling to every ten seconds.
5e0cbd5fcb46 (Fopen_network_stream): Call bind_polling_period earlier.
Karl Heuer <kwzh@gnu.org>
parents: 13709
diff changeset
2801 Some kernels have a bug which causes retrying connect to fail
5e0cbd5fcb46 (Fopen_network_stream): Call bind_polling_period earlier.
Karl Heuer <kwzh@gnu.org>
parents: 13709
diff changeset
2802 after a connect. Polling can interfere with gethostbyname too. */
5e0cbd5fcb46 (Fopen_network_stream): Call bind_polling_period earlier.
Karl Heuer <kwzh@gnu.org>
parents: 13709
diff changeset
2803 #ifdef POLL_FOR_INPUT
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2804 if (socktype == SOCK_STREAM)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2805 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2806 record_unwind_protect (unwind_stop_other_atimers, Qnil);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2807 bind_polling_period (10);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2808 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2809 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2810
25248
f0fc8443bdbb (Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents: 25129
diff changeset
2811 #ifdef HAVE_GETADDRINFO
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2812 /* If we have a host, use getaddrinfo to resolve both host and service.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2813 Otherwise, use getservbyname to lookup the service. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2814 if (!NILP (host))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2815 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2816
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2817 /* SERVICE can either be a string or int.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2818 Convert to a C string for later use by getaddrinfo. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2819 if (EQ (service, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2820 portstring = "0";
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2821 else if (INTEGERP (service))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2822 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2823 sprintf (portbuf, "%ld", (long) XINT (service));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2824 portstring = portbuf;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2825 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2826 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2827 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2828 CHECK_STRING (service);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2829 portstring = XSTRING (service)->data;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2830 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2831
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2832 immediate_quit = 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2833 QUIT;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2834 memset (&hints, 0, sizeof (hints));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2835 hints.ai_flags = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2836 hints.ai_family = NILP (Fplist_member (contact, QCfamily)) ? AF_UNSPEC : family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2837 hints.ai_socktype = socktype;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2838 hints.ai_protocol = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2839 ret = getaddrinfo (XSTRING (host)->data, portstring, &hints, &res);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2840 if (ret)
32074
a889f9fc59a7 (Fopen_network_stream): Use HAVE_GAI_STRERROR.
Dave Love <fx@gnu.org>
parents: 32032
diff changeset
2841 #ifdef HAVE_GAI_STRERROR
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2842 error ("%s/%s %s", XSTRING (host)->data, portstring, gai_strerror(ret));
32074
a889f9fc59a7 (Fopen_network_stream): Use HAVE_GAI_STRERROR.
Dave Love <fx@gnu.org>
parents: 32032
diff changeset
2843 #else
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2844 error ("%s/%s getaddrinfo error %d", XSTRING (host)->data, portstring, ret);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2845 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2846 immediate_quit = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2847
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2848 goto open_socket;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2849 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2850 #endif /* HAVE_GETADDRINFO */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2851
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2852 /* We end up here if getaddrinfo is not defined, or in case no hostname
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2853 has been specified (e.g. for a local server process). */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2854
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2855 if (EQ (service, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2856 port = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2857 else if (INTEGERP (service))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2858 port = htons ((unsigned short) XINT (service));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2859 else
8287
97c2535b7f37 (Fopen_network_stream): Retry gethostbyname after TRY_AGAIN failure.
Richard M. Stallman <rms@gnu.org>
parents: 8231
diff changeset
2860 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2861 struct servent *svc_info;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2862 CHECK_STRING (service);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2863 svc_info = getservbyname (XSTRING (service)->data,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2864 (socktype == SOCK_DGRAM ? "udp" : "tcp"));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2865 if (svc_info == 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2866 error ("Unknown service: %s", XSTRING (service)->data);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2867 port = svc_info->s_port;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2868 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2869
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2870 bzero (&address_in, sizeof address_in);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2871 address_in.sin_family = family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2872 address_in.sin_addr.s_addr = INADDR_ANY;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2873 address_in.sin_port = port;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2874
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2875 #ifndef HAVE_GETADDRINFO
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2876 if (!NILP (host))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2877 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2878 struct hostent *host_info_ptr;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2879
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2880 /* gethostbyname may fail with TRY_AGAIN, but we don't honour that,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2881 as it may `hang' emacs for a very long time. */
14758
849458c13c0c (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14736
diff changeset
2882 immediate_quit = 1;
849458c13c0c (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14736
diff changeset
2883 QUIT;
8287
97c2535b7f37 (Fopen_network_stream): Retry gethostbyname after TRY_AGAIN failure.
Richard M. Stallman <rms@gnu.org>
parents: 8231
diff changeset
2884 host_info_ptr = gethostbyname (XSTRING (host)->data);
14758
849458c13c0c (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14736
diff changeset
2885 immediate_quit = 0;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2886
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2887 if (host_info_ptr)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2888 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2889 bcopy (host_info_ptr->h_addr, (char *) &address_in.sin_addr,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2890 host_info_ptr->h_length);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2891 family = host_info_ptr->h_addrtype;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2892 address_in.sin_family = family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2893 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2894 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2895 /* Attempt to interpret host as numeric inet address */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2896 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2897 IN_ADDR numeric_addr;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2898 numeric_addr = inet_addr ((char *) XSTRING (host)->data);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2899 if (NUMERIC_ADDR_ERROR)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2900 error ("Unknown host \"%s\"", XSTRING (host)->data);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2901
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2902 bcopy ((char *)&numeric_addr, (char *) &address_in.sin_addr,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2903 sizeof (address_in.sin_addr));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2904 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2905
8287
97c2535b7f37 (Fopen_network_stream): Retry gethostbyname after TRY_AGAIN failure.
Richard M. Stallman <rms@gnu.org>
parents: 8231
diff changeset
2906 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2907 #endif /* not HAVE_GETADDRINFO */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2908
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2909 ai.ai_family = family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2910 ai.ai_addr = (struct sockaddr *) &address_in;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2911 ai.ai_addrlen = sizeof address_in;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2912
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2913 open_socket:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2914
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2915 /* Kernel bugs (on Ultrix at least) cause lossage (not just EINTR)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2916 when connect is interrupted. So let's not let it get interrupted.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2917 Note we do not turn off polling, because polling is only used
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2918 when not interrupt_input, and thus not normally used on the systems
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2919 which have this bug. On systems which use polling, there's no way
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2920 to quit if polling is turned off. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2921 if (interrupt_input
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2922 && !is_server && socktype == SOCK_STREAM)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2923 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2924 /* Comment from KFS: The original open-network-stream code
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2925 didn't unwind protect this, but it seems like the proper
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2926 thing to do. In any case, I don't see how it could harm to
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2927 do this -- and it makes cleanup (using unbind_to) easier. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2928 record_unwind_protect (unwind_request_sigio, Qnil);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2929 unrequest_sigio ();
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2930 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2931
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2932 /* Do this in case we never enter the for-loop below. */
25705
1f109108fa7e (Fopen_network_stream): Avoid socket decriptor leak.
Andreas Schwab <schwab@suse.de>
parents: 25645
diff changeset
2933 count1 = specpdl_ptr - specpdl;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2934 s = -1;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2935
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2936 for (lres = res; lres; lres = lres->ai_next)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2937 {
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2938 s = socket (lres->ai_family, lres->ai_socktype, lres->ai_protocol);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2939 if (s < 0)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2940 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2941 xerrno = errno;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2942 continue;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2943 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2944
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2945 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2946 if (!is_server && socktype == SOCK_DGRAM)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2947 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2948 #endif /* DATAGRAM_SOCKETS */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2949
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2950 #ifdef NON_BLOCKING_CONNECT
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2951 if (is_non_blocking_client)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2952 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2953 #ifdef O_NONBLOCK
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2954 ret = fcntl (s, F_SETFL, O_NONBLOCK);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2955 #else
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2956 ret = fcntl (s, F_SETFL, O_NDELAY);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2957 #endif
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2958 if (ret < 0)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2959 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2960 xerrno = errno;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2961 emacs_close (s);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2962 s = -1;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2963 continue;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2964 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2965 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2966 #endif
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2967
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2968 /* Make us close S if quit. */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2969 record_unwind_protect (close_file_unwind, make_number (s));
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2970
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2971 if (is_server)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2972 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2973 /* Configure as a server socket. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2974 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2975 if (family != AF_LOCAL)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2976 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2977 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2978 int optval = 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2979 if (setsockopt (s, SOL_SOCKET, SO_REUSEADDR, &optval, sizeof optval))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2980 report_file_error ("Cannot set reuse option on server socket.", Qnil);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2981 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2982
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2983 if (bind (s, lres->ai_addr, lres->ai_addrlen))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2984 report_file_error ("Cannot bind server socket", Qnil);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2985
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2986 #ifdef HAVE_GETSOCKNAME
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2987 if (EQ (service, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2988 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2989 struct sockaddr_in sa1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2990 int len1 = sizeof (sa1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2991 if (getsockname (s, (struct sockaddr *)&sa1, &len1) == 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2992 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2993 ((struct sockaddr_in *)(lres->ai_addr))->sin_port = sa1.sin_port;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2994 service = make_number (sa1.sin_port);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2995 contact = Fplist_put (contact, QCservice, service);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2996 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2997 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2998 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2999
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3000 if (socktype == SOCK_STREAM && listen (s, 5))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3001 report_file_error ("Cannot listen on server socket", Qnil);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3002
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3003 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3004 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3005
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3006 retry_connect:
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3007
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3008 immediate_quit = 1;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3009 QUIT;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3010
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3011 /* This turns off all alarm-based interrupts; the
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3012 bind_polling_period call above doesn't always turn all the
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3013 short-interval ones off, especially if interrupt_input is
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3014 set.
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3015
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3016 It'd be nice to be able to control the connect timeout
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3017 though. Would non-blocking connect calls be portable?
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3018
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3019 This used to be conditioned by HAVE_GETADDRINFO. Why? */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3020
43642
bfd9fa0143d9 (Fopen_network_stream): Always call turn_on_atimers around connect.
Kim F. Storm <storm@cua.dk>
parents: 43617
diff changeset
3021 turn_on_atimers (0);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3022
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3023 ret = connect (s, lres->ai_addr, lres->ai_addrlen);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3024 xerrno = errno;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3025
43642
bfd9fa0143d9 (Fopen_network_stream): Always call turn_on_atimers around connect.
Kim F. Storm <storm@cua.dk>
parents: 43617
diff changeset
3026 turn_on_atimers (1);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3027
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3028 if (ret == 0 || xerrno == EISCONN)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3029 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3030 /* The unwind-protect will be discarded afterwards.
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3031 Likewise for immediate_quit. */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3032 break;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3033 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3034
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3035 #ifdef NON_BLOCKING_CONNECT
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3036 #ifdef EINPROGRESS
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3037 if (is_non_blocking_client && xerrno == EINPROGRESS)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3038 break;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3039 #else
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3040 #ifdef EWOULDBLOCK
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3041 if (is_non_blocking_client && xerrno == EWOULDBLOCK)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3042 break;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3043 #endif
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3044 #endif
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3045 #endif
7220
a33eb16cab9d (Fopen_network_stream): Retry the connect if EADDRINUSE. Ignore EISCONN.
Richard M. Stallman <rms@gnu.org>
parents: 7157
diff changeset
3046
14671
0493e857a13b (Fopen_network_stream): Set immediate_quit for the connect.
Richard M. Stallman <rms@gnu.org>
parents: 14613
diff changeset
3047 immediate_quit = 0;
0493e857a13b (Fopen_network_stream): Set immediate_quit for the connect.
Richard M. Stallman <rms@gnu.org>
parents: 14613
diff changeset
3048
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3049 if (xerrno == EINTR)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3050 goto retry_connect;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3051 if (xerrno == EADDRINUSE && retry < 20)
7220
a33eb16cab9d (Fopen_network_stream): Retry the connect if EADDRINUSE. Ignore EISCONN.
Richard M. Stallman <rms@gnu.org>
parents: 7157
diff changeset
3052 {
12378
3171d5da8a86 (Fopen_network_stream): Sleep 1 sec before connect retry.
Richard M. Stallman <rms@gnu.org>
parents: 12324
diff changeset
3053 /* A delay here is needed on some FreeBSD systems,
3171d5da8a86 (Fopen_network_stream): Sleep 1 sec before connect retry.
Richard M. Stallman <rms@gnu.org>
parents: 12324
diff changeset
3054 and it is harmless, since this retrying takes time anyway
3171d5da8a86 (Fopen_network_stream): Sleep 1 sec before connect retry.
Richard M. Stallman <rms@gnu.org>
parents: 12324
diff changeset
3055 and should be infrequent. */
3171d5da8a86 (Fopen_network_stream): Sleep 1 sec before connect retry.
Richard M. Stallman <rms@gnu.org>
parents: 12324
diff changeset
3056 Fsleep_for (make_number (1), Qnil);
7220
a33eb16cab9d (Fopen_network_stream): Retry the connect if EADDRINUSE. Ignore EISCONN.
Richard M. Stallman <rms@gnu.org>
parents: 7157
diff changeset
3057 retry++;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3058 goto retry_connect;
7220
a33eb16cab9d (Fopen_network_stream): Retry the connect if EADDRINUSE. Ignore EISCONN.
Richard M. Stallman <rms@gnu.org>
parents: 7157
diff changeset
3059 }
a33eb16cab9d (Fopen_network_stream): Retry the connect if EADDRINUSE. Ignore EISCONN.
Richard M. Stallman <rms@gnu.org>
parents: 7157
diff changeset
3060
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3061 /* Discard the unwind protect closing S. */
25705
1f109108fa7e (Fopen_network_stream): Avoid socket decriptor leak.
Andreas Schwab <schwab@suse.de>
parents: 25645
diff changeset
3062 specpdl_ptr = specpdl + count1;
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
3063 emacs_close (s);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3064 s = -1;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3065 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3066
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3067 if (s >= 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3068 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3069 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3070 if (socktype == SOCK_DGRAM)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3071 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3072 if (datagram_address[s].sa)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3073 abort ();
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3074 datagram_address[s].sa = (struct sockaddr *) xmalloc (lres->ai_addrlen);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3075 datagram_address[s].len = lres->ai_addrlen;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3076 if (is_server)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3077 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3078 Lisp_Object remote;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3079 bzero (datagram_address[s].sa, lres->ai_addrlen);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3080 if (remote = Fplist_get (contact, QCremote), !NILP (remote))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3081 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3082 int rfamily, rlen;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3083 rlen = get_lisp_to_sockaddr_size (remote, &rfamily);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3084 if (rfamily == lres->ai_family && rlen == lres->ai_addrlen)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3085 conv_lisp_to_sockaddr (rfamily, remote,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3086 datagram_address[s].sa, rlen);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3087 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3088 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3089 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3090 bcopy (lres->ai_addr, datagram_address[s].sa, lres->ai_addrlen);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3091 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3092 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3093 contact = Fplist_put (contact, QCaddress,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3094 conv_sockaddr_to_lisp (lres->ai_addr, lres->ai_addrlen));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3095 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3096
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3097 #ifdef HAVE_GETADDRINFO
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3098 if (res != &ai)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3099 freeaddrinfo (res);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3100 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3101
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3102 immediate_quit = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3103
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3104 /* Discard the unwind protect for closing S, if any. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3105 specpdl_ptr = specpdl + count1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3106
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3107 /* Unwind bind_polling_period and request_sigio. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3108 unbind_to (count, Qnil);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3109
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3110 if (s < 0)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3111 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3112 /* If non-blocking got this far - and failed - assume non-blocking is
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3113 not supported after all. This is probably a wrong assumption, but
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3114 the normal blocking calls to open-network-stream handles this error
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3115 better. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3116 if (is_non_blocking_client)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3117 return Qnil;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3118
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3119 errno = xerrno;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3120 if (is_server)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3121 report_file_error ("make server process failed", contact);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3122 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3123 report_file_error ("make client process failed", contact);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3124 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3125
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3126 tem = Fplist_get (contact, QCoptions);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3127 if (!NILP (tem))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3128 set_socket_options (s, tem, 1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3129
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3130 #endif /* not TERM */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3131
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3132 inch = s;
17247
351006378b51 (Fopen_network_stream): Use same socket for in and out.
Richard M. Stallman <rms@gnu.org>
parents: 17224
diff changeset
3133 outch = s;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3134
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3135 if (!NILP (buffer))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3136 buffer = Fget_buffer_create (buffer);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3137 proc = make_process (name);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3138
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3139 chan_process[inch] = proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3140
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3141 #ifdef O_NONBLOCK
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3142 fcntl (inch, F_SETFL, O_NONBLOCK);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3143 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3144 #ifdef O_NDELAY
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3145 fcntl (inch, F_SETFL, O_NDELAY);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3146 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3147 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3148
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3149 p = XPROCESS (proc);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3150
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3151 p->childp = contact;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3152 p->buffer = buffer;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3153 p->sentinel = sentinel;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3154 p->filter = filter;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3155 p->log = Fplist_get (contact, QClog);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3156 if (tem = Fplist_get (contact, QCnoquery), !NILP (tem))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3157 p->kill_without_query = Qt;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3158 if ((tem = Fplist_get (contact, QCstop), !NILP (tem)))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3159 p->command = Qt;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3160 p->pid = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3161 XSETINT (p->infd, inch);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3162 XSETINT (p->outfd, outch);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3163 if (is_server && socktype == SOCK_STREAM)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3164 p->status = Qlisten;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3165
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3166 #ifdef NON_BLOCKING_CONNECT
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3167 if (is_non_blocking_client)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3168 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3169 /* We may get here if connect did succeed immediately. However,
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3170 in that case, we still need to signal this like a non-blocking
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3171 connection. */
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3172 p->status = Qconnect;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3173 if (!FD_ISSET (inch, &connect_wait_mask))
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3174 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3175 FD_SET (inch, &connect_wait_mask);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3176 num_pending_connects++;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3177 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3178 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3179 else
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3180 #endif
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3181 /* A server may have a client filter setting of Qt, but it must
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3182 still listen for incoming connects unless it is stopped. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3183 if ((!EQ (p->filter, Qt) && !EQ (p->command, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3184 || (EQ (p->status, Qlisten) && NILP (p->command)))
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3185 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3186 FD_SET (inch, &input_wait_mask);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3187 FD_SET (inch, &non_keyboard_wait_mask);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3188 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3189
7044
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3190 if (inch > max_process_desc)
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3191 max_process_desc = inch;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3192
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3193 tem = Fplist_member (contact, QCcoding);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3194 if (!NILP (tem) && (!CONSP (tem) || !CONSP (XCDR (tem))))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3195 tem = Qnil; /* No error message (too late!). */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3196
22019
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3197 {
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3198 /* Setup coding systems for communicating with the network stream. */
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3199 struct gcpro gcpro1;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3200 /* Qt denotes we have not yet called Ffind_operation_coding_system. */
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3201 Lisp_Object coding_systems = Qt;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3202 Lisp_Object args[5], val;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3203
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3204 if (!NILP (tem))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3205 val = XCAR (XCDR (tem));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3206 else if (!NILP (Vcoding_system_for_read))
22019
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3207 val = Vcoding_system_for_read;
25770
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
3208 else if ((!NILP (buffer) && NILP (XBUFFER (buffer)->enable_multibyte_characters))
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
3209 || (NILP (buffer) && NILP (buffer_defaults.enable_multibyte_characters)))
22019
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3210 /* We dare not decode end-of-line format by setting VAL to
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3211 Qraw_text, because the existing Emacs Lisp libraries
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3212 assume that they receive bare code including a sequene of
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3213 CR LF. */
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3214 val = Qnil;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3215 else
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3216 {
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3217 args[0] = Qopen_network_stream, args[1] = name,
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3218 args[2] = buffer, args[3] = host, args[4] = service;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3219 GCPRO1 (proc);
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3220 coding_systems = Ffind_operation_coding_system (5, args);
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3221 UNGCPRO;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3222 if (CONSP (coding_systems))
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
3223 val = XCAR (coding_systems);
22019
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3224 else if (CONSP (Vdefault_process_coding_system))
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
3225 val = XCAR (Vdefault_process_coding_system);
22019
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3226 else
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3227 val = Qnil;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3228 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3229 p->decode_coding_system = val;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3230
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3231 if (!NILP (tem))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3232 val = XCAR (XCDR (tem));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3233 else if (!NILP (Vcoding_system_for_write))
22019
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3234 val = Vcoding_system_for_write;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3235 else if (NILP (current_buffer->enable_multibyte_characters))
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3236 val = Qnil;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3237 else
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3238 {
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3239 if (EQ (coding_systems, Qt))
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3240 {
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3241 args[0] = Qopen_network_stream, args[1] = name,
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3242 args[2] = buffer, args[3] = host, args[4] = service;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3243 GCPRO1 (proc);
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3244 coding_systems = Ffind_operation_coding_system (5, args);
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3245 UNGCPRO;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3246 }
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3247 if (CONSP (coding_systems))
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
3248 val = XCDR (coding_systems);
22019
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3249 else if (CONSP (Vdefault_process_coding_system))
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
3250 val = XCDR (Vdefault_process_coding_system);
22019
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3251 else
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3252 val = Qnil;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3253 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3254 p->encode_coding_system = val;
22019
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3255 }
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3256
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3257 if (!proc_decode_coding_system[inch])
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3258 proc_decode_coding_system[inch]
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3259 = (struct coding_system *) xmalloc (sizeof (struct coding_system));
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3260 setup_coding_system (p->decode_coding_system,
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3261 proc_decode_coding_system[inch]);
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3262 if (!proc_encode_coding_system[outch])
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3263 proc_encode_coding_system[outch]
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3264 = (struct coding_system *) xmalloc (sizeof (struct coding_system));
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3265 setup_coding_system (p->encode_coding_system,
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3266 proc_encode_coding_system[outch]);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
3267
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3268 p->decoding_buf = make_uninit_string (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3269 p->decoding_carryover = make_number (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3270 p->encoding_buf = make_uninit_string (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3271 p->encoding_carryover = make_number (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3272
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3273 p->inherit_coding_system_flag
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3274 = (!NILP (tem) || NILP (buffer) || !inherit_process_coding_system
21848
050ea21cec87 (Fset_process_inherit_coding_system_flag, Fstart_process):
Richard M. Stallman <rms@gnu.org>
parents: 21798
diff changeset
3275 ? Qnil : Qt);
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
3276
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3277 UNGCPRO;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3278 return proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3279 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3280 #endif /* HAVE_SOCKETS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3281
20382
dbad9367d232 (create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents: 20225
diff changeset
3282 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3283 deactivate_process (proc)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3284 Lisp_Object proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3285 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3286 register int inchannel, outchannel;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3287 register struct Lisp_Process *p = XPROCESS (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3288
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3289 inchannel = XINT (p->infd);
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3290 outchannel = XINT (p->outfd);
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3291
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3292 if (inchannel >= 0)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3293 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3294 /* Beware SIGCHLD hereabouts. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3295 flush_pending_output (inchannel);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3296 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3297 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3298 VMS_PROC_STUFF *get_vms_process_pointer (), *vs;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3299 sys$dassgn (outchannel);
2357
9faa3a02ea97 * process.c [VMS] (DCL_PROMPT): Remove hack.
Jim Blandy <jimb@redhat.com>
parents: 2290
diff changeset
3300 vs = get_vms_process_pointer (p->pid);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3301 if (vs)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3302 give_back_vms_process_stuff (vs);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3303 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3304 #else
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
3305 emacs_close (inchannel);
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3306 if (outchannel >= 0 && outchannel != inchannel)
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
3307 emacs_close (outchannel);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3308 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3309
9277
21f6120be5ba (make_process, create_process, Fopen_network_stream, deactivate_process,
Karl Heuer <kwzh@gnu.org>
parents: 9115
diff changeset
3310 XSETINT (p->infd, -1);
21f6120be5ba (make_process, create_process, Fopen_network_stream, deactivate_process,
Karl Heuer <kwzh@gnu.org>
parents: 9115
diff changeset
3311 XSETINT (p->outfd, -1);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3312 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3313 if (DATAGRAM_CHAN_P (inchannel))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3314 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3315 xfree (datagram_address[inchannel].sa);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3316 datagram_address[inchannel].sa = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3317 datagram_address[inchannel].len = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3318 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3319 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3320 chan_process[inchannel] = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3321 FD_CLR (inchannel, &input_wait_mask);
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
3322 FD_CLR (inchannel, &non_keyboard_wait_mask);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3323 if (FD_ISSET (inchannel, &connect_wait_mask))
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3324 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3325 FD_CLR (inchannel, &connect_wait_mask);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3326 if (--num_pending_connects < 0)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3327 abort ();
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3328 }
7044
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3329 if (inchannel == max_process_desc)
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3330 {
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3331 int i;
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3332 /* We just closed the highest-numbered process input descriptor,
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3333 so recompute the highest-numbered one now. */
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3334 max_process_desc = 0;
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3335 for (i = 0; i < MAXDESC; i++)
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3336 if (!NILP (chan_process[i]))
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3337 max_process_desc = i;
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3338 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3339 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3340 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3341
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3342 /* Close all descriptors currently in use for communication
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3343 with subprocess. This is used in a newly-forked subprocess
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3344 to get rid of irrelevant descriptors. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3345
20382
dbad9367d232 (create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents: 20225
diff changeset
3346 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3347 close_process_descs ()
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3348 {
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
3349 #ifndef WINDOWSNT
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3350 int i;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3351 for (i = 0; i < MAXDESC; i++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3352 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3353 Lisp_Object process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3354 process = chan_process[i];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3355 if (!NILP (process))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3356 {
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3357 int in = XINT (XPROCESS (process)->infd);
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3358 int out = XINT (XPROCESS (process)->outfd);
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3359 if (in >= 0)
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
3360 emacs_close (in);
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3361 if (out >= 0 && in != out)
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
3362 emacs_close (out);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3363 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3364 }
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
3365 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3366 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3367
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3368 DEFUN ("accept-process-output", Faccept_process_output, Saccept_process_output,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
3369 0, 3, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
3370 doc: /* Allow any pending output from subprocesses to be read by Emacs.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
3371 It is read into the process' buffers or given to their filter functions.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
3372 Non-nil arg PROCESS means do not return until some output has been received
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
3373 from PROCESS.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
3374 Non-nil second arg TIMEOUT and third arg TIMEOUT-MSECS are number of
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
3375 seconds and microseconds to wait; return after that much time whether
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
3376 or not there is input.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
3377 Return non-nil iff we received any output before the timeout expired. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
3378 (process, timeout, timeout_msecs)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
3379 register Lisp_Object process, timeout, timeout_msecs;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3380 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3381 int seconds;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3382 int useconds;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3383
24598
078d53377010 (Faccept_process_output): Check validity of PROCESS.
Richard M. Stallman <rms@gnu.org>
parents: 24352
diff changeset
3384 if (! NILP (process))
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
3385 CHECK_PROCESS (process);
24598
078d53377010 (Faccept_process_output): Check validity of PROCESS.
Richard M. Stallman <rms@gnu.org>
parents: 24352
diff changeset
3386
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3387 if (! NILP (timeout_msecs))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3388 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
3389 CHECK_NUMBER (timeout_msecs);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3390 useconds = XINT (timeout_msecs);
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
3391 if (!INTEGERP (timeout))
9277
21f6120be5ba (make_process, create_process, Fopen_network_stream, deactivate_process,
Karl Heuer <kwzh@gnu.org>
parents: 9115
diff changeset
3392 XSETINT (timeout, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3393
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3394 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3395 int carry = useconds / 1000000;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3396
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3397 XSETINT (timeout, XINT (timeout) + carry);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3398 useconds -= carry * 1000000;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3399
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3400 /* I think this clause is necessary because C doesn't
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3401 guarantee a particular rounding direction for negative
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3402 integers. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3403 if (useconds < 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3404 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3405 XSETINT (timeout, XINT (timeout) - 1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3406 useconds += 1000000;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3407 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3408 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3409 }
1180
9bf82484415d (Faccept_process_output): Initialize useconds.
Richard M. Stallman <rms@gnu.org>
parents: 1047
diff changeset
3410 else
9bf82484415d (Faccept_process_output): Initialize useconds.
Richard M. Stallman <rms@gnu.org>
parents: 1047
diff changeset
3411 useconds = 0;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3412
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3413 if (! NILP (timeout))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3414 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
3415 CHECK_NUMBER (timeout);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3416 seconds = XINT (timeout);
14605
80196bfd8b94 (Faccept_process_output): Accept sub-second timeouts.
Erik Naggum <erik@naggum.no>
parents: 14544
diff changeset
3417 if (seconds < 0 || (seconds == 0 && useconds == 0))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3418 seconds = -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3419 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3420 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3421 {
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
3422 if (NILP (process))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3423 seconds = -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3424 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3425 seconds = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3426 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3427
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
3428 if (NILP (process))
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
3429 XSETFASTINT (process, 0);
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3430
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3431 return
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
3432 (wait_reading_process_input (seconds, useconds, process, 0)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3433 ? Qt : Qnil);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3434 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3435
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3436 /* Accept a connection for server process SERVER on CHANNEL. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3437
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3438 static int connect_counter = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3439
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3440 static void
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3441 server_accept_connection (server, channel)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3442 Lisp_Object server;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3443 int channel;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3444 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3445 Lisp_Object proc, caller, name, buffer;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3446 Lisp_Object contact, host, service;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3447 struct Lisp_Process *ps= XPROCESS (server);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3448 struct Lisp_Process *p;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3449 int s;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3450 union u_sockaddr {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3451 struct sockaddr sa;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3452 struct sockaddr_in in;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3453 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3454 struct sockaddr_un un;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3455 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3456 } saddr;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3457 int len = sizeof saddr;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3458
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3459 s = accept (channel, &saddr.sa, &len);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3460
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3461 if (s < 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3462 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3463 int code = errno;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3464
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3465 if (code == EAGAIN)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3466 return;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3467 #ifdef EWOULDBLOCK
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3468 if (code == EWOULDBLOCK)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3469 return;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3470 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3471
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3472 if (!NILP (ps->log))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3473 call3 (ps->log, server, Qnil,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3474 concat3 (build_string ("accept failed with code"),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3475 Fnumber_to_string (make_number (code)),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3476 build_string ("\n")));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3477 return;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3478 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3479
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3480 connect_counter++;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3481
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3482 /* Setup a new process to handle the connection. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3483
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3484 /* Generate a unique identification of the caller, and build contact
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3485 information for this process. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3486 host = Qt;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3487 service = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3488 switch (saddr.sa.sa_family)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3489 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3490 case AF_INET:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3491 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3492 Lisp_Object args[5];
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3493 unsigned char *ip = (unsigned char *)&saddr.in.sin_addr.s_addr;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3494 args[0] = build_string ("%d.%d.%d.%d");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3495 args[1] = make_number (*ip++);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3496 args[2] = make_number (*ip++);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3497 args[3] = make_number (*ip++);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3498 args[4] = make_number (*ip++);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3499 host = Fformat (5, args);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3500 service = make_number (ntohs (saddr.in.sin_port));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3501
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3502 args[0] = build_string (" <%s:%d>");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3503 args[1] = host;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3504 args[2] = service;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3505 caller = Fformat (3, args);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3506 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3507 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3508
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3509 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3510 case AF_LOCAL:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3511 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3512 default:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3513 caller = Fnumber_to_string (make_number (connect_counter));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3514 caller = concat3 (build_string (" <*"), caller, build_string ("*>"));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3515 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3516 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3517
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3518 /* Create a new buffer name for this process if it doesn't have a
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3519 filter. The new buffer name is based on the buffer name or
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3520 process name of the server process concatenated with the caller
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3521 identification. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3522
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3523 if (!NILP (ps->filter) && !EQ (ps->filter, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3524 buffer = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3525 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3526 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3527 buffer = ps->buffer;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3528 if (!NILP (buffer))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3529 buffer = Fbuffer_name (buffer);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3530 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3531 buffer = ps->name;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3532 if (!NILP (buffer))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3533 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3534 buffer = concat2 (buffer, caller);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3535 buffer = Fget_buffer_create (buffer);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3536 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3537 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3538
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3539 /* Generate a unique name for the new server process. Combine the
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3540 server process name with the caller identification. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3541
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3542 name = concat2 (ps->name, caller);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3543 proc = make_process (name);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3544
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3545 chan_process[s] = proc;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3546
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3547 #ifdef O_NONBLOCK
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3548 fcntl (s, F_SETFL, O_NONBLOCK);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3549 #else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3550 #ifdef O_NDELAY
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3551 fcntl (s, F_SETFL, O_NDELAY);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3552 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3553 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3554
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3555 p = XPROCESS (proc);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3556
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3557 /* Build new contact information for this setup. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3558 contact = Fcopy_sequence (ps->childp);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3559 contact = Fplist_put (contact, QCserver, Qnil);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3560 contact = Fplist_put (contact, QChost, host);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3561 if (!NILP (service))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3562 contact = Fplist_put (contact, QCservice, service);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3563 contact = Fplist_put (contact, QCremote,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3564 conv_sockaddr_to_lisp (&saddr.sa, len));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3565 #ifdef HAVE_GETSOCKNAME
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3566 len = sizeof saddr;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3567 if (getsockname (channel, &saddr.sa, &len) == 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3568 contact = Fplist_put (contact, QClocal,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3569 conv_sockaddr_to_lisp (&saddr.sa, len));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3570 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3571
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3572 p->childp = contact;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3573 p->buffer = buffer;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3574 p->sentinel = ps->sentinel;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3575 p->filter = ps->filter;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3576 p->command = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3577 p->pid = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3578 XSETINT (p->infd, s);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3579 XSETINT (p->outfd, s);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3580 p->status = Qrun;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3581
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3582 /* Client processes for accepted connections are not stopped initially. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3583 if (!EQ (p->filter, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3584 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3585 FD_SET (s, &input_wait_mask);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3586 FD_SET (s, &non_keyboard_wait_mask);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3587 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3588
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3589 if (s > max_process_desc)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3590 max_process_desc = s;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3591
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3592 /* Setup coding system for new process based on server process.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3593 This seems to be the proper thing to do, as the coding system
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3594 of the new process should reflect the settings at the time the
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3595 server socket was opened; not the current settings. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3596
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3597 p->decode_coding_system = ps->decode_coding_system;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3598 p->encode_coding_system = ps->encode_coding_system;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3599
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3600 if (!proc_decode_coding_system[s])
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3601 proc_decode_coding_system[s]
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3602 = (struct coding_system *) xmalloc (sizeof (struct coding_system));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3603 setup_coding_system (p->decode_coding_system,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3604 proc_decode_coding_system[s]);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3605 if (!proc_encode_coding_system[s])
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3606 proc_encode_coding_system[s]
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3607 = (struct coding_system *) xmalloc (sizeof (struct coding_system));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3608 setup_coding_system (p->encode_coding_system,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3609 proc_encode_coding_system[s]);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3610
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3611 p->decoding_buf = make_uninit_string (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3612 p->decoding_carryover = make_number (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3613 p->encoding_buf = make_uninit_string (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3614 p->encoding_carryover = make_number (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3615
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3616 p->inherit_coding_system_flag
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3617 = (NILP (buffer) ? Qnil : ps->inherit_coding_system_flag);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3618
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3619 if (!NILP (ps->log))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3620 call3 (ps->log, server, proc,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3621 concat3 (build_string ("accept from "),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3622 (STRINGP (host) ? host : build_string ("-")),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3623 build_string ("\n")));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3624
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3625 if (p->sentinel)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3626 exec_sentinel (proc,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3627 concat3 (build_string ("open from "),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3628 (STRINGP (host) ? host : build_string ("-")),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3629 build_string ("\n")));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3630 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3631
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3632 /* This variable is different from waiting_for_input in keyboard.c.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3633 It is used to communicate to a lisp process-filter/sentinel (via the
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3634 function Fwaiting_for_user_input_p below) whether emacs was waiting
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3635 for user-input when that process-filter was called.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3636 waiting_for_input cannot be used as that is by definition 0 when
8570
dd3dfde8f973 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 8390
diff changeset
3637 lisp code is being evalled.
dd3dfde8f973 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 8390
diff changeset
3638 This is also used in record_asynch_buffer_change.
dd3dfde8f973 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 8390
diff changeset
3639 For that purpose, this must be 0
dd3dfde8f973 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 8390
diff changeset
3640 when not inside wait_reading_process_input. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3641 static int waiting_for_user_input_p;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3642
14890
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3643 /* This is here so breakpoints can be put on it. */
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
3644 static void
14890
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3645 wait_reading_process_input_1 ()
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3646 {
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3647 }
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3648
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3649 /* Read and dispose of subprocess output while waiting for timeout to
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3650 elapse and/or keyboard input to be available.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3651
3953
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3652 TIME_LIMIT is:
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3653 timeout in seconds, or
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3654 zero for no limit, or
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3655 -1 means gobble data immediately available but don't wait for any.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3656
3953
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3657 MICROSECS is:
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3658 an additional duration to wait, measured in microseconds.
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3659 If this is nonzero and time_limit is 0, then the timeout
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3660 consists of MICROSECS only.
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3661
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3662 READ_KBD is a lisp value:
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3663 0 to ignore keyboard input, or
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3664 1 to return when input is available, or
2200
5e58643bb169 (wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents: 2120
diff changeset
3665 -1 meaning caller will actually read the input, so don't throw to
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3666 the quit handler, or
6569
9cde1228e2fa Fix typos in comments.
Karl Heuer <kwzh@gnu.org>
parents: 6515
diff changeset
3667 a cons cell, meaning wait until its car is non-nil
3953
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3668 (and gobble terminal input into the buffer if any arrives), or
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3669 a process object, meaning wait until something arrives from that
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3670 process. The return value is true iff we read some input from
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3671 that process.
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3672
3953
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3673 DO_DISPLAY != 0 means redisplay should be done to show subprocess
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3674 output that arrives.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3675
3953
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3676 If READ_KBD is a pointer to a struct Lisp_Process, then the
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3677 function returns true iff we received input from that process
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3678 before the timeout elapsed.
3591
507f64624555 Apply typo patches from Paul Eggert.
Jim Blandy <jimb@redhat.com>
parents: 3510
diff changeset
3679 Otherwise, return true iff we received input from any process. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3680
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
3681 int
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3682 wait_reading_process_input (time_limit, microsecs, read_kbd, do_display)
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3683 int time_limit, microsecs;
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3684 Lisp_Object read_kbd;
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3685 int do_display;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3686 {
25770
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
3687 register int channel, nfds;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3688 static SELECT_TYPE Available;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3689 static SELECT_TYPE Connecting;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3690 int check_connect, no_avail;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3691 int xerrno;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3692 Lisp_Object proc;
25770
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
3693 EMACS_TIME timeout, end_time;
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3694 int wait_channel = -1;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3695 struct Lisp_Process *wait_proc = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3696 int got_some_input = 0;
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
3697 /* Either nil or a cons cell, the car of which is of interest and
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
3698 may be changed outside of this routine. */
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
3699 Lisp_Object wait_for_cell = Qnil;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3700
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3701 FD_ZERO (&Available);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3702 FD_ZERO (&Connecting);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3703
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3704 /* If read_kbd is a process to watch, set wait_proc and wait_channel
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3705 accordingly. */
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
3706 if (PROCESSP (read_kbd))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3707 {
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3708 wait_proc = XPROCESS (read_kbd);
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3709 wait_channel = XINT (wait_proc->infd);
9318
a14cc1712337 (make_process, list_processes_1, create_process, Faccept_process_output,
Karl Heuer <kwzh@gnu.org>
parents: 9277
diff changeset
3710 XSETFASTINT (read_kbd, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3711 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3712
2200
5e58643bb169 (wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents: 2120
diff changeset
3713 /* If waiting for non-nil in a cell, record where. */
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
3714 if (CONSP (read_kbd))
2200
5e58643bb169 (wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents: 2120
diff changeset
3715 {
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
3716 wait_for_cell = read_kbd;
9318
a14cc1712337 (make_process, list_processes_1, create_process, Faccept_process_output,
Karl Heuer <kwzh@gnu.org>
parents: 9277
diff changeset
3717 XSETFASTINT (read_kbd, 0);
2200
5e58643bb169 (wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents: 2120
diff changeset
3718 }
5e58643bb169 (wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents: 2120
diff changeset
3719
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3720 waiting_for_user_input_p = XINT (read_kbd);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3721
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3722 /* Since we may need to wait several times,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3723 compute the absolute time to return at. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3724 if (time_limit || microsecs)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3725 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3726 EMACS_GET_TIME (end_time);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3727 EMACS_SET_SECS_USECS (timeout, time_limit, microsecs);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3728 EMACS_ADD_TIME (end_time, end_time, timeout);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3729 }
15661
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
3730 #ifdef hpux
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
3731 /* AlainF 5-Jul-1996
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
3732 HP-UX 10.10 seem to have problems with signals coming in
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
3733 Causes "poll: interrupted system call" messages when Emacs is run
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
3734 in an X window
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
3735 Turn off periodic alarms (in case they are in use) */
27430
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
3736 turn_on_atimers (0);
15661
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
3737 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3738
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3739 while (1)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3740 {
14458
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3741 int timeout_reduced_for_timers = 0;
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3742
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3743 /* If calling from keyboard input, do not quit
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3744 since we want to return C-g as an input character.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3745 Otherwise, do pending quit if requested. */
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3746 if (XINT (read_kbd) >= 0)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3747 QUIT;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3748
4639
76f242eb1fa8 Include syswait.h.
Richard M. Stallman <rms@gnu.org>
parents: 4320
diff changeset
3749 /* Exit now if the cell we're waiting for became non-nil. */
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
3750 if (! NILP (wait_for_cell) && ! NILP (XCAR (wait_for_cell)))
4639
76f242eb1fa8 Include syswait.h.
Richard M. Stallman <rms@gnu.org>
parents: 4320
diff changeset
3751 break;
76f242eb1fa8 Include syswait.h.
Richard M. Stallman <rms@gnu.org>
parents: 4320
diff changeset
3752
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3753 /* Compute time from now till when time limit is up */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3754 /* Exit if already run out */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3755 if (time_limit == -1)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3756 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3757 /* -1 specified for timeout means
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3758 gobble output available now
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3759 but don't wait at all. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3760
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3761 EMACS_SET_SECS_USECS (timeout, 0, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3762 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3763 else if (time_limit || microsecs)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3764 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3765 EMACS_GET_TIME (timeout);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3766 EMACS_SUB_TIME (timeout, end_time, timeout);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3767 if (EMACS_TIME_NEG_P (timeout))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3768 break;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3769 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3770 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3771 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3772 EMACS_SET_SECS_USECS (timeout, 100000, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3773 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3774
15064
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
3775 /* Normally we run timers here.
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
3776 But not if wait_for_cell; in those cases,
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
3777 the wait is supposed to be short,
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
3778 and those callers cannot handle running arbitrary Lisp code here. */
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
3779 if (NILP (wait_for_cell))
14404
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
3780 {
14458
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3781 EMACS_TIME timer_delay;
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3782
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3783 do
14890
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3784 {
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3785 int old_timers_run = timers_run;
37465
f790d83ea743 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 37413
diff changeset
3786 struct buffer *old_buffer = current_buffer;
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3787
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3788 timer_delay = timer_check (1);
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3789
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3790 /* If a timer has run, this might have changed buffers
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3791 an alike. Make read_key_sequence aware of that. */
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3792 if (timers_run != old_timers_run
37465
f790d83ea743 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 37413
diff changeset
3793 && old_buffer != current_buffer
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3794 && waiting_for_user_input_p == -1)
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3795 record_asynch_buffer_change ();
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3796
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3797 if (timers_run != old_timers_run && do_display)
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3798 /* We must retry, since a timer may have requeued itself
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3799 and that could alter the time_delay. */
35336
002c02db42d3 Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents: 34660
diff changeset
3800 redisplay_preserve_echo_area (9);
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3801 else
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3802 break;
14890
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3803 }
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3804 while (!detect_input_pending ());
14890
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3805
18230
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
3806 /* If there is unread keyboard input, also return. */
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
3807 if (XINT (read_kbd) != 0
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
3808 && requeued_events_pending_p ())
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
3809 break;
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
3810
14458
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3811 if (! EMACS_TIME_NEG_P (timer_delay) && time_limit != -1)
14404
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
3812 {
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
3813 EMACS_TIME difference;
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
3814 EMACS_SUB_TIME (difference, timer_delay, timeout);
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
3815 if (EMACS_TIME_NEG_P (difference))
14458
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3816 {
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3817 timeout = timer_delay;
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3818 timeout_reduced_for_timers = 1;
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3819 }
14404
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
3820 }
14935
3e0dc64a5cb8 (wait_reading_process_input): Don't call
Richard M. Stallman <rms@gnu.org>
parents: 14890
diff changeset
3821 /* If time_limit is -1, we are not going to wait at all. */
3e0dc64a5cb8 (wait_reading_process_input): Don't call
Richard M. Stallman <rms@gnu.org>
parents: 14890
diff changeset
3822 else if (time_limit != -1)
14890
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3823 {
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3824 /* This is so a breakpoint can be put here. */
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3825 wait_reading_process_input_1 ();
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3826 }
14404
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
3827 }
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
3828
2894
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3829 /* Cause C-g and alarm signals to take immediate action,
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3830 and cause input available signals to zero out timeout.
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3831
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3832 It is important that we do this before checking for process
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3833 activity. If we get a SIGCHLD after the explicit checks for
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3834 process activity, timeout is the only way we will know. */
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3835 if (XINT (read_kbd) < 0)
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3836 set_waiting_for_input (&timeout);
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3837
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3838 /* If status of something has changed, and no input is
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3839 available, notify the user of the change right away. After
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3840 this explicit check, we'll let the SIGCHLD handler zap
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3841 timeout to get our attention. */
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3842 if (update_tick != process_tick && do_display)
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3843 {
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3844 SELECT_TYPE Atemp, Ctemp;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3845
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3846 Atemp = input_wait_mask;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3847 Ctemp = connect_wait_mask;
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3848 EMACS_SET_SECS_USECS (timeout, 0, 0);
18492
668304de6f92 (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 18378
diff changeset
3849 if ((select (max (max_process_desc, max_keyboard_desc) + 1,
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3850 &Atemp,
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3851 (num_pending_connects > 0 ? &Ctemp : (SELECT_TYPE *)0),
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3852 (SELECT_TYPE *)0, &timeout)
11926
40d7e6f04ebe (create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents: 11845
diff changeset
3853 <= 0))
2894
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3854 {
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3855 /* It's okay for us to do this and then continue with
5534
7a0de0f56c86 Comment changes.
Richard M. Stallman <rms@gnu.org>
parents: 5404
diff changeset
3856 the loop, since timeout has already been zeroed out. */
2894
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3857 clear_waiting_for_input ();
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3858 status_notify ();
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3859 }
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3860 }
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3861
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3862 /* Don't wait for output from a non-running process. Just
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3863 read whatever data has already been received. */
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3864 if (wait_proc != 0 && !NILP (wait_proc->raw_status_low))
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3865 update_status (wait_proc);
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3866 if (wait_proc != 0
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3867 && ! EQ (wait_proc->status, Qrun)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3868 && ! EQ (wait_proc->status, Qconnect))
2893
4df57953d5d0 * process.c (wait_reading_process_input): Don't forget to call
Jim Blandy <jimb@redhat.com>
parents: 2887
diff changeset
3869 {
18946
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3870 int nread, total_nread = 0;
18267
29c37882ee1f (wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents: 18230
diff changeset
3871
2893
4df57953d5d0 * process.c (wait_reading_process_input): Don't forget to call
Jim Blandy <jimb@redhat.com>
parents: 2887
diff changeset
3872 clear_waiting_for_input ();
18267
29c37882ee1f (wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents: 18230
diff changeset
3873 XSETPROCESS (proc, wait_proc);
29c37882ee1f (wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents: 18230
diff changeset
3874
29c37882ee1f (wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents: 18230
diff changeset
3875 /* Read data from the process, until we exhaust it. */
25894
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3876 while (XINT (wait_proc->infd) >= 0)
18946
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3877 {
25894
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3878 nread = read_process_output (proc, XINT (wait_proc->infd));
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3879
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3880 if (nread == 0)
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3881 break;
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3882
18946
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3883 if (0 < nread)
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3884 total_nread += nread;
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3885 #ifdef EIO
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3886 else if (nread == -1 && EIO == errno)
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3887 break;
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3888 #endif
25894
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3889 #ifdef EAGAIN
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3890 else if (nread == -1 && EAGAIN == errno)
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3891 break;
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3892 #endif
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3893 #ifdef EWOULDBLOCK
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3894 else if (nread == -1 && EWOULDBLOCK == errno)
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3895 break;
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3896 #endif
18946
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3897 }
18267
29c37882ee1f (wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents: 18230
diff changeset
3898 if (total_nread > 0 && do_display)
35336
002c02db42d3 Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents: 34660
diff changeset
3899 redisplay_preserve_echo_area (10);
18267
29c37882ee1f (wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents: 18230
diff changeset
3900
2893
4df57953d5d0 * process.c (wait_reading_process_input): Don't forget to call
Jim Blandy <jimb@redhat.com>
parents: 2887
diff changeset
3901 break;
4df57953d5d0 * process.c (wait_reading_process_input): Don't forget to call
Jim Blandy <jimb@redhat.com>
parents: 2887
diff changeset
3902 }
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3903
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3904 /* Wait till there is something to do */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3905
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
3906 if (!NILP (wait_for_cell))
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3907 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3908 Available = non_process_wait_mask;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3909 check_connect = 0;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3910 }
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
3911 else
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3912 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3913 if (! XINT (read_kbd))
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3914 Available = non_keyboard_wait_mask;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3915 else
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3916 Available = input_wait_mask;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3917 check_connect = (num_pending_connects > 0);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3918 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3919
765
e4093444f9f8 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 692
diff changeset
3920 /* If frame size has changed or the window is newly mapped,
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
3921 redisplay now, before we start to wait. There is a race
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
3922 condition here; if a SIGIO arrives between now and the select
1655
05e84e6c7d04 Tue Dec 1 23:42:25 1992 Jim Blandy (jimb@totoro.cs.oberlin.edu)
Jim Blandy <jimb@redhat.com>
parents: 1594
diff changeset
3923 and indicates that a frame is trashed, the select may block
05e84e6c7d04 Tue Dec 1 23:42:25 1992 Jim Blandy (jimb@totoro.cs.oberlin.edu)
Jim Blandy <jimb@redhat.com>
parents: 1594
diff changeset
3924 displaying a trashed screen. */
6429
1dbe24a029fd (wait_reading_process_input, both versions): Don't call
Richard M. Stallman <rms@gnu.org>
parents: 6393
diff changeset
3925 if (frame_garbaged && do_display)
11728
affed1766d34 (wait_reading_process_input): Don't call prepare_menu_bars.
Richard M. Stallman <rms@gnu.org>
parents: 11695
diff changeset
3926 {
affed1766d34 (wait_reading_process_input): Don't call prepare_menu_bars.
Richard M. Stallman <rms@gnu.org>
parents: 11695
diff changeset
3927 clear_waiting_for_input ();
35336
002c02db42d3 Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents: 34660
diff changeset
3928 redisplay_preserve_echo_area (11);
11728
affed1766d34 (wait_reading_process_input): Don't call prepare_menu_bars.
Richard M. Stallman <rms@gnu.org>
parents: 11695
diff changeset
3929 if (XINT (read_kbd) < 0)
11744
52a2c8e81bb7 (wait_reading_process_input): Pass arg in new call to set_waiting_for_input.
Richard M. Stallman <rms@gnu.org>
parents: 11728
diff changeset
3930 set_waiting_for_input (&timeout);
11728
affed1766d34 (wait_reading_process_input): Don't call prepare_menu_bars.
Richard M. Stallman <rms@gnu.org>
parents: 11695
diff changeset
3931 }
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
3932
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3933 no_avail = 0;
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
3934 if (XINT (read_kbd) && detect_input_pending ())
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
3935 {
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
3936 nfds = 0;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3937 no_avail = 1;
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
3938 }
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
3939 else
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3940 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3941 if (check_connect)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3942 Connecting = connect_wait_mask;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3943 nfds = select (max (max_process_desc, max_keyboard_desc) + 1,
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3944 &Available,
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3945 (check_connect ? &Connecting : (SELECT_TYPE *)0),
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3946 (SELECT_TYPE *)0, &timeout);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3947 }
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
3948
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3949 xerrno = errno;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3950
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3951 /* Make C-g and alarm signals set flags again */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3952 clear_waiting_for_input ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3953
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3954 /* If we woke up due to SIGWINCH, actually change size now. */
25356
5db69f7aadca Call change_frame_size and do_pending_window_change with
Gerd Moellmann <gerd@gnu.org>
parents: 25262
diff changeset
3955 do_pending_window_change (0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3956
14458
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3957 if (time_limit && nfds == 0 && ! timeout_reduced_for_timers)
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3958 /* We wanted the full specified time, so return now. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3959 break;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3960 if (nfds < 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3961 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3962 if (xerrno == EINTR)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3963 no_avail = 1;
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
3964 #ifdef ultrix
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
3965 /* Ultrix select seems to return ENOMEM when it is
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
3966 interrupted. Treat it just like EINTR. Bleah. Note
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
3967 that we want to test for the "ultrix" CPP symbol, not
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
3968 "__ultrix__"; the latter is only defined under GCC, but
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
3969 not by DEC's bundled CC. -JimB */
1323
25b5b55a3916 * process.c (wait_reading_process_input): If the select returns
Jim Blandy <jimb@redhat.com>
parents: 1207
diff changeset
3970 else if (xerrno == ENOMEM)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3971 no_avail = 1;
1323
25b5b55a3916 * process.c (wait_reading_process_input): If the select returns
Jim Blandy <jimb@redhat.com>
parents: 1207
diff changeset
3972 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3973 #ifdef ALLIANT
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3974 /* This happens for no known reason on ALLIANT.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3975 I am guessing that this is the right response. -- RMS. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3976 else if (xerrno == EFAULT)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3977 no_avail = 1;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3978 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3979 else if (xerrno == EBADF)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3980 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3981 #ifdef AIX
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3982 /* AIX doesn't handle PTY closure the same way BSD does. On AIX,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3983 the child's closure of the pts gives the parent a SIGHUP, and
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3984 the ptc file descriptor is automatically closed,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3985 yielding EBADF here or at select() call above.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3986 So, SIGHUP is ignored (see def of PTY_TTY_NAME_SPRINTF
5534
7a0de0f56c86 Comment changes.
Richard M. Stallman <rms@gnu.org>
parents: 5404
diff changeset
3987 in m/ibmrt-aix.h), and here we just ignore the select error.
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3988 Cleanup occurs c/o status_notify after SIGCLD. */
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3989 no_avail = 1; /* Cannot depend on values returned */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3990 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3991 abort ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3992 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3993 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3994 else
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
3995 error ("select error: %s", emacs_strerror (xerrno));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3996 }
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3997
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3998 if (no_avail)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3999 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4000 FD_ZERO (&Available);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4001 check_connect = 0;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4002 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4003
2815
60f122cfe785 * process.c (wait_reading_process_input): If we're running
Jim Blandy <jimb@redhat.com>
parents: 2610
diff changeset
4004 #if defined(sun) && !defined(USG5_4)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4005 if (nfds > 0 && keyboard_bit_set (&Available)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4006 && interrupt_input)
2830
006c7fbdeab7 Document sun change.
Jim Blandy <jimb@redhat.com>
parents: 2815
diff changeset
4007 /* System sometimes fails to deliver SIGIO.
006c7fbdeab7 Document sun change.
Jim Blandy <jimb@redhat.com>
parents: 2815
diff changeset
4008
006c7fbdeab7 Document sun change.
Jim Blandy <jimb@redhat.com>
parents: 2815
diff changeset
4009 David J. Mackenzie says that Emacs doesn't compile under
006c7fbdeab7 Document sun change.
Jim Blandy <jimb@redhat.com>
parents: 2815
diff changeset
4010 Solaris if this code is enabled, thus the USG5_4 in the CPP
006c7fbdeab7 Document sun change.
Jim Blandy <jimb@redhat.com>
parents: 2815
diff changeset
4011 conditional. "I haven't noticed any ill effects so far.
006c7fbdeab7 Document sun change.
Jim Blandy <jimb@redhat.com>
parents: 2815
diff changeset
4012 If you find a Solaris expert somewhere, they might know
006c7fbdeab7 Document sun change.
Jim Blandy <jimb@redhat.com>
parents: 2815
diff changeset
4013 better." */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4014 kill (getpid (), SIGIO);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4015 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4016
18378
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4017 #if 0 /* When polling is used, interrupt_input is 0,
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4018 so get_input_pending should read the input.
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4019 So this should not be needed. */
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4020 /* If we are using polling for input,
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4021 and we see input available, make it get read now.
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4022 Otherwise it might not actually get read for a second.
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4023 And on hpux, since we turn off polling in wait_reading_process_input,
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4024 it might never get read at all if we don't spend much time
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4025 outside of wait_reading_process_input. */
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4026 if (XINT (read_kbd) && interrupt_input
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4027 && keyboard_bit_set (&Available)
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4028 && input_polling_used ())
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4029 kill (getpid (), SIGALRM);
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4030 #endif
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4031
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4032 /* Check for keyboard input */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4033 /* If there is any, return immediately
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4034 to give it higher priority than subprocesses */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4035
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4036 if (XINT (read_kbd) != 0)
14613
386831bc4a4e (wait_reading_process_input):
Karl Heuer <kwzh@gnu.org>
parents: 14605
diff changeset
4037 {
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4038 int old_timers_run = timers_run;
37465
f790d83ea743 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 37413
diff changeset
4039 struct buffer *old_buffer = current_buffer;
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4040 int leave = 0;
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4041
14758
849458c13c0c (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14736
diff changeset
4042 if (detect_input_pending_run_timers (do_display))
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4043 {
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4044 swallow_events (do_display);
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4045 if (detect_input_pending_run_timers (do_display))
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4046 leave = 1;
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4047 }
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4048
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4049 /* If a timer has run, this might have changed buffers
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4050 an alike. Make read_key_sequence aware of that. */
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4051 if (timers_run != old_timers_run
37465
f790d83ea743 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 37413
diff changeset
4052 && waiting_for_user_input_p == -1
f790d83ea743 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 37413
diff changeset
4053 && old_buffer != current_buffer)
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4054 record_asynch_buffer_change ();
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4055
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4056 if (leave)
14613
386831bc4a4e (wait_reading_process_input):
Karl Heuer <kwzh@gnu.org>
parents: 14605
diff changeset
4057 break;
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4058 }
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
4059
18230
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
4060 /* If there is unread keyboard input, also return. */
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
4061 if (XINT (read_kbd) != 0
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
4062 && requeued_events_pending_p ())
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
4063 break;
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
4064
19053
7b5642657857 (read_process_output): Don't call setup_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 18974
diff changeset
4065 /* If we are not checking for keyboard input now,
7b5642657857 (read_process_output): Don't call setup_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 18974
diff changeset
4066 do process events (but don't run any timers).
7b5642657857 (read_process_output): Don't call setup_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 18974
diff changeset
4067 This is so that X events will be processed.
18492
668304de6f92 (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 18378
diff changeset
4068 Otherwise they may have to wait until polling takes place.
19053
7b5642657857 (read_process_output): Don't call setup_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 18974
diff changeset
4069 That would causes delays in pasting selections, for example.
7b5642657857 (read_process_output): Don't call setup_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 18974
diff changeset
4070
7b5642657857 (read_process_output): Don't call setup_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 18974
diff changeset
4071 (We used to do this only if wait_for_cell.) */
7b5642657857 (read_process_output): Don't call setup_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 18974
diff changeset
4072 if (XINT (read_kbd) == 0 && detect_input_pending ())
15064
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
4073 {
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
4074 swallow_events (do_display);
18492
668304de6f92 (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 18378
diff changeset
4075 #if 0 /* Exiting when read_kbd doesn't request that seems wrong, though. */
15064
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
4076 if (detect_input_pending ())
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
4077 break;
18492
668304de6f92 (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 18378
diff changeset
4078 #endif
15064
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
4079 }
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
4080
2200
5e58643bb169 (wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents: 2120
diff changeset
4081 /* Exit now if the cell we're waiting for became non-nil. */
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
4082 if (! NILP (wait_for_cell) && ! NILP (XCAR (wait_for_cell)))
2200
5e58643bb169 (wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents: 2120
diff changeset
4083 break;
5e58643bb169 (wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents: 2120
diff changeset
4084
621
eca8812e61cd *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
4085 #ifdef SIGIO
18378
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4086 /* If we think we have keyboard input waiting, but didn't get SIGIO,
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4087 go read it. This can happen with X on BSD after logging out.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4088 In that case, there really is no input and no SIGIO,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4089 but select says there is input. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4090
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
4091 if (XINT (read_kbd) && interrupt_input
18378
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4092 && keyboard_bit_set (&Available))
14736
b17ec81a6294 (wait_reading_process_input): Use getpid when generating SIGIO.
Richard M. Stallman <rms@gnu.org>
parents: 14671
diff changeset
4093 kill (getpid (), SIGIO);
621
eca8812e61cd *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
4094 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4095
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4096 if (! wait_proc)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4097 got_some_input |= nfds > 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4098
624
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
4099 /* If checking input just got us a size-change event from X,
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
4100 obey it now if we should. */
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
4101 if (XINT (read_kbd) || ! NILP (wait_for_cell))
25356
5db69f7aadca Call change_frame_size and do_pending_window_change with
Gerd Moellmann <gerd@gnu.org>
parents: 25262
diff changeset
4102 do_pending_window_change (0);
624
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
4103
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
4104 /* Check for data from a process. */
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4105 if (no_avail || nfds == 0)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4106 continue;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4107
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
4108 /* Really FIRST_PROC_DESC should be 0 on Unix,
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
4109 but this is safer in the short run. */
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
4110 for (channel = 0; channel <= max_process_desc; channel++)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4111 {
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
4112 if (FD_ISSET (channel, &Available)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
4113 && FD_ISSET (channel, &non_keyboard_wait_mask))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4114 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4115 int nread;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4116
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4117 /* If waiting for this channel, arrange to return as
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4118 soon as no more input to be processed. No more
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4119 waiting. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4120 if (wait_channel == channel)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4121 {
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
4122 wait_channel = -1;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4123 time_limit = -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4124 got_some_input = 1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4125 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4126 proc = chan_process[channel];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4127 if (NILP (proc))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4128 continue;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4129
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4130 /* If this is a server stream socket, accept connection. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4131 if (EQ (XPROCESS (proc)->status, Qlisten))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4132 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4133 server_accept_connection (proc, channel);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4134 continue;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4135 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4136
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4137 /* Read data from the process, starting with our
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4138 buffered-ahead character if we have one. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4139
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4140 nread = read_process_output (proc, channel);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4141 if (nread > 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4142 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4143 /* Since read_process_output can run a filter,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4144 which can call accept-process-output,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4145 don't try to read from any other processes
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4146 before doing the select again. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4147 FD_ZERO (&Available);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4148
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4149 if (do_display)
35336
002c02db42d3 Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents: 34660
diff changeset
4150 redisplay_preserve_echo_area (12);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4151 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4152 #ifdef EWOULDBLOCK
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4153 else if (nread == -1 && errno == EWOULDBLOCK)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4154 ;
15405
c27bb6e69e2d (wait_reading_process_input): Move the O_NONBLOCK and
Richard M. Stallman <rms@gnu.org>
parents: 15368
diff changeset
4155 #endif
15406
7c205bc80624 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 15405
diff changeset
4156 /* ISC 4.1 defines both EWOULDBLOCK and O_NONBLOCK,
7c205bc80624 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 15405
diff changeset
4157 and Emacs uses O_NONBLOCK, so what we get is EAGAIN. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4158 #ifdef O_NONBLOCK
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4159 else if (nread == -1 && errno == EAGAIN)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4160 ;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4161 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4162 #ifdef O_NDELAY
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4163 else if (nread == -1 && errno == EAGAIN)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4164 ;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4165 /* Note that we cannot distinguish between no input
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4166 available now and a closed pipe.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4167 With luck, a closed pipe will be accompanied by
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4168 subprocess termination and SIGCHLD. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4169 else if (nread == 0 && !NETCONN_P (proc))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4170 ;
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4171 #endif /* O_NDELAY */
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4172 #endif /* O_NONBLOCK */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4173 #ifdef HAVE_PTYS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4174 /* On some OSs with ptys, when the process on one end of
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4175 a pty exits, the other end gets an error reading with
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4176 errno = EIO instead of getting an EOF (0 bytes read).
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4177 Therefore, if we get an error reading and errno =
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4178 EIO, just continue, because the child process has
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4179 exited and should clean itself up soon (e.g. when we
23035
8d68b82a4d8c (wait_reading_process_input): If a pty gives EIO,
Richard M. Stallman <rms@gnu.org>
parents: 22939
diff changeset
4180 get a SIGCHLD).
8d68b82a4d8c (wait_reading_process_input): If a pty gives EIO,
Richard M. Stallman <rms@gnu.org>
parents: 22939
diff changeset
4181
8d68b82a4d8c (wait_reading_process_input): If a pty gives EIO,
Richard M. Stallman <rms@gnu.org>
parents: 22939
diff changeset
4182 However, it has been known to happen that the SIGCHLD
8d68b82a4d8c (wait_reading_process_input): If a pty gives EIO,
Richard M. Stallman <rms@gnu.org>
parents: 22939
diff changeset
4183 got lost. So raise the signl again just in case.
8d68b82a4d8c (wait_reading_process_input): If a pty gives EIO,
Richard M. Stallman <rms@gnu.org>
parents: 22939
diff changeset
4184 It can't hurt. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4185 else if (nread == -1 && errno == EIO)
23035
8d68b82a4d8c (wait_reading_process_input): If a pty gives EIO,
Richard M. Stallman <rms@gnu.org>
parents: 22939
diff changeset
4186 kill (getpid (), SIGCHLD);
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4187 #endif /* HAVE_PTYS */
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4188 /* If we can detect process termination, don't consider the process
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4189 gone just because its pipe is closed. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4190 #ifdef SIGCHLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4191 else if (nread == 0 && !NETCONN_P (proc))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4192 ;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4193 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4194 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4195 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4196 /* Preserve status of processes already terminated. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4197 XSETINT (XPROCESS (proc)->tick, ++process_tick);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4198 deactivate_process (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4199 if (!NILP (XPROCESS (proc)->raw_status_low))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4200 update_status (XPROCESS (proc));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4201 if (EQ (XPROCESS (proc)->status, Qrun))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4202 XPROCESS (proc)->status
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4203 = Fcons (Qexit, Fcons (make_number (256), Qnil));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4204 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4205 }
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4206 #ifdef NON_BLOCKING_CONNECT
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4207 if (check_connect && FD_ISSET (channel, &Connecting))
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4208 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4209 struct Lisp_Process *p;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4210
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4211 FD_CLR (channel, &connect_wait_mask);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4212 if (--num_pending_connects < 0)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4213 abort ();
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4214
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4215 proc = chan_process[channel];
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4216 if (NILP (proc))
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4217 continue;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4218
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4219 p = XPROCESS (proc);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4220
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4221 #ifdef GNU_LINUX
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4222 /* getsockopt(,,SO_ERROR,,) is said to hang on some systems.
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4223 So only use it on systems where it is known to work. */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4224 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4225 int xlen = sizeof(xerrno);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4226 if (getsockopt(channel, SOL_SOCKET, SO_ERROR, &xerrno, &xlen))
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4227 xerrno = errno;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4228 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4229 #else
44013
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4230 {
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4231 struct sockaddr pname;
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4232 int pnamelen = sizeof(pname);
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4233
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4234 /* If connection failed, getpeername will fail. */
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4235 xerrno = 0;
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4236 if (getpeername(channel, &pname, &pnamelen) < 0)
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4237 {
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4238 /* Obtain connect failure code through error slippage. */
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4239 char dummy;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4240 xerrno = errno;
44013
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4241 if (errno == ENOTCONN && read(channel, &dummy, 1) < 0)
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4242 xerrno = errno;
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4243 }
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4244 }
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4245 #endif
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4246 if (xerrno)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4247 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4248 XSETINT (p->tick, ++process_tick);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4249 p->status = Fcons (Qfailed, Fcons (make_number (xerrno), Qnil));
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4250 deactivate_process (proc);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4251 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4252 else
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4253 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4254 p->status = Qrun;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4255 /* Execute the sentinel here. If we had relied on
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4256 status_notify to do it later, it will read input
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4257 from the process before calling the sentinel. */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4258 exec_sentinel (proc, build_string ("open\n"));
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4259 if (!EQ (p->filter, Qt) && !EQ (p->command, Qt))
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4260 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4261 FD_SET (XINT (p->infd), &input_wait_mask);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4262 FD_SET (XINT (p->infd), &non_keyboard_wait_mask);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4263 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4264 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4265 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4266 #endif /* NON_BLOCKING_CONNECT */
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4267 } /* end for each file descriptor */
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4268 } /* end while exit conditions not met */
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4269
8570
dd3dfde8f973 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 8390
diff changeset
4270 waiting_for_user_input_p = 0;
dd3dfde8f973 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 8390
diff changeset
4271
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4272 /* If calling from keyboard input, do not quit
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4273 since we want to return C-g as an input character.
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4274 Otherwise, do pending quit if requested. */
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
4275 if (XINT (read_kbd) >= 0)
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4276 {
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4277 /* Prevent input_pending from remaining set if we quit. */
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4278 clear_input_pending ();
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4279 QUIT;
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4280 }
15661
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
4281 #ifdef hpux
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
4282 /* AlainF 5-Jul-1996
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
4283 HP-UX 10.10 seems to have problems with signals coming in
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
4284 Causes "poll: interrupted system call" messages when Emacs is run
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
4285 in an X window
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
4286 Turn periodic alarms back on */
18378
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4287 start_polling ();
15661
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
4288 #endif
25009
5733af0b62ce (wait_reading_process_input): Show and hide busy
Gerd Moellmann <gerd@gnu.org>
parents: 24933
diff changeset
4289
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4290 return got_some_input;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4291 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4292
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4293 /* Given a list (FUNCTION ARGS...), apply FUNCTION to the ARGS. */
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4294
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4295 static Lisp_Object
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4296 read_process_output_call (fun_and_args)
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4297 Lisp_Object fun_and_args;
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4298 {
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
4299 return apply1 (XCAR (fun_and_args), XCDR (fun_and_args));
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4300 }
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4301
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4302 static Lisp_Object
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4303 read_process_output_error_handler (error)
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4304 Lisp_Object error;
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4305 {
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4306 cmd_error_internal (error, "error in process filter: ");
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4307 Vinhibit_quit = Qt;
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4308 update_echo_area ();
11277
d4547e4b0aab (read_process_output_error_handler)
Richard M. Stallman <rms@gnu.org>
parents: 11235
diff changeset
4309 Fsleep_for (make_number (2), Qnil);
27558
f99efd14b932 (Fstart_process): Doc fix.
Dave Love <fx@gnu.org>
parents: 27430
diff changeset
4310 return Qt;
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4311 }
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4312
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4313 /* Read pending output from the process channel,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4314 starting with our buffered-ahead character if we have one.
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4315 Yield number of decoded characters read.
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4316
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4317 This function reads at most 1024 characters.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4318 If you want to read all available subprocess output,
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4319 you must call it repeatedly until it returns zero.
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4320
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4321 The characters read are decoded according to PROC's coding-system
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4322 for decoding. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4323
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
4324 int
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4325 read_process_output (proc, channel)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4326 Lisp_Object proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4327 register int channel;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4328 {
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4329 register int nchars, nbytes;
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4330 char *chars;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4331 register Lisp_Object outstream;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4332 register struct buffer *old = current_buffer;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4333 register struct Lisp_Process *p = XPROCESS (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4334 register int opoint;
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
4335 struct coding_system *coding = proc_decode_coding_system[channel];
20715
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
4336 int carryover = XINT (p->decoding_carryover);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4337 int readmax = 1024;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4338
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4339 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4340 VMS_PROC_STUFF *vs, *get_vms_process_pointer();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4341
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4342 vs = get_vms_process_pointer (p->pid);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4343 if (vs)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4344 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4345 if (!vs->iosb[0])
25248
f0fc8443bdbb (Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents: 25129
diff changeset
4346 return (0); /* Really weird if it does this */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4347 if (!(vs->iosb[0] & 1))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4348 return -1; /* I/O error */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4349 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4350 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4351 error ("Could not get VMS process pointer");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4352 chars = vs->inputBuffer;
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4353 nbytes = clean_vms_buffer (chars, vs->iosb[1]);
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4354 if (nbytes <= 0)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4355 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4356 start_vms_process_read (vs); /* Crank up the next read on the process */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4357 return 1; /* Nothing worth printing, say we got 1 */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4358 }
20715
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
4359 if (carryover > 0)
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4360 {
20715
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
4361 /* The data carried over in the previous decoding (which are at
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
4362 the tail of decoding buffer) should be prepended to the new
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
4363 data read to decode all together. */
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4364 chars = (char *) alloca (nbytes + carryover);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4365 bcopy (XSTRING (p->decoding_buf)->data, buf, carryover);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4366 bcopy (vs->inputBuffer, chars + carryover, nbytes);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4367 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4368 #else /* not VMS */
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4369
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4370 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4371 /* A datagram is one packet; allow at least 1500+ bytes of data
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4372 corresponding to the typical Ethernet frame size. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4373 if (DATAGRAM_CHAN_P (channel))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4374 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4375 /* carryover = 0; */ /* Does carryover make sense for datagrams? */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4376 readmax += 1024;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4377 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4378 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4379
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4380 chars = (char *) alloca (carryover + readmax);
20715
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
4381 if (carryover)
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
4382 /* See the comment above. */
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4383 bcopy (XSTRING (p->decoding_buf)->data, chars, carryover);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4384
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4385 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4386 /* We have a working select, so proc_buffered_char is always -1. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4387 if (DATAGRAM_CHAN_P (channel))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4388 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4389 int len = datagram_address[channel].len;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4390 nbytes = recvfrom (channel, chars + carryover, readmax - carryover,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4391 0, datagram_address[channel].sa, &len);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4392 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4393 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4394 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4395 if (proc_buffered_char[channel] < 0)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4396 nbytes = emacs_read (channel, chars + carryover, readmax - carryover);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4397 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4398 {
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4399 chars[carryover] = proc_buffered_char[channel];
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4400 proc_buffered_char[channel] = -1;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4401 nbytes = emacs_read (channel, chars + carryover + 1, readmax - 1 - carryover);
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4402 if (nbytes < 0)
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4403 nbytes = 1;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4404 else
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4405 nbytes = nbytes + 1;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4406 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4407 #endif /* not VMS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4408
22523
b02a5ea8cf93 (read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents: 22019
diff changeset
4409 XSETINT (p->decoding_carryover, 0);
b02a5ea8cf93 (read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents: 22019
diff changeset
4410
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4411 /* At this point, NBYTES holds number of bytes just received
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4412 (including the one in proc_buffered_char[channel]). */
23879
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
4413 if (nbytes <= 0)
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
4414 {
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
4415 if (nbytes < 0 || coding->mode & CODING_MODE_LAST_BLOCK)
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
4416 return nbytes;
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
4417 coding->mode |= CODING_MODE_LAST_BLOCK;
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
4418 }
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4419
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4420 /* Now set NBYTES how many bytes we must decode. */
20715
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
4421 nbytes += carryover;
29017
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
4422
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4423 /* Read and dispose of the process output. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4424 outstream = p->filter;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4425 if (!NILP (outstream))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4426 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4427 /* We inhibit quit here instead of just catching it so that
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4428 hitting ^G when a filter happens to be running won't screw
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4429 it up. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4430 int count = specpdl_ptr - specpdl;
3510
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4431 Lisp_Object odeactivate;
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
4432 Lisp_Object obuffer, okeymap;
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4433 Lisp_Object text;
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4434 int outer_running_asynch_code = running_asynch_code;
23460
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
4435 int waiting = waiting_for_user_input_p;
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
4436
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
4437 /* No need to gcpro these, because all we do with them later
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
4438 is test them for EQness, and none of them should be a string. */
3510
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4439 odeactivate = Vdeactivate_mark;
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
4440 XSETBUFFER (obuffer, current_buffer);
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
4441 okeymap = current_buffer->keymap;
3510
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4442
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4443 specbind (Qinhibit_quit, Qt);
8231
5226ed89c1a6 (Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8063
diff changeset
4444 specbind (Qlast_nonmenu_event, Qt);
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4445
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4446 /* In case we get recursively called,
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4447 and we already saved the match data nonrecursively,
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4448 save the same match data in safely recursive fashion. */
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4449 if (outer_running_asynch_code)
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4450 {
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4451 Lisp_Object tem;
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4452 /* Don't clobber the CURRENT match data, either! */
16728
309a750fd5c0 (read_process_output, exec_sentinel):
Richard M. Stallman <rms@gnu.org>
parents: 16718
diff changeset
4453 tem = Fmatch_data (Qnil, Qnil);
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4454 restore_match_data ();
21177
73f8ae8312c8 (exec_sentinel, read_process_output): Fstore_match_data => Fset_match_data.
Richard M. Stallman <rms@gnu.org>
parents: 21049
diff changeset
4455 record_unwind_protect (Fset_match_data, Fmatch_data (Qnil, Qnil));
73f8ae8312c8 (exec_sentinel, read_process_output): Fstore_match_data => Fset_match_data.
Richard M. Stallman <rms@gnu.org>
parents: 21049
diff changeset
4456 Fset_match_data (tem);
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4457 }
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4458
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4459 /* For speed, if a search happens within this code,
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4460 save the match data in a special nonrecursive fashion. */
10032
f689803caa92 Added code for automatically saving and restoring the match data
Francesco Potortì <pot@gnu.org>
parents: 9969
diff changeset
4461 running_asynch_code = 1;
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4462
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4463 text = decode_coding_string (make_unibyte_string (chars, nbytes),
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4464 coding, 0);
31136
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4465 if (NILP (buffer_defaults.enable_multibyte_characters))
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4466 /* We had better return unibyte string. */
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4467 text = string_make_unibyte (text);
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4468
30582
280157ad4aa3 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 30580
diff changeset
4469 Vlast_coding_system_used = coding->symbol;
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4470 /* A new coding system might be found. */
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4471 if (!EQ (p->decode_coding_system, coding->symbol))
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4472 {
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4473 p->decode_coding_system = coding->symbol;
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4474
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4475 /* Don't call setup_coding_system for
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4476 proc_decode_coding_system[channel] here. It is done in
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4477 detect_coding called via decode_coding above. */
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4478
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4479 /* If a coding system for encoding is not yet decided, we set
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4480 it as the same as coding-system for decoding.
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4481
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4482 But, before doing that we must check if
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4483 proc_encode_coding_system[p->outfd] surely points to a
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4484 valid memory because p->outfd will be changed once EOF is
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4485 sent to the process. */
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4486 if (NILP (p->encode_coding_system)
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4487 && proc_encode_coding_system[XINT (p->outfd)])
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4488 {
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4489 p->encode_coding_system = coding->symbol;
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4490 setup_coding_system (coding->symbol,
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4491 proc_encode_coding_system[XINT (p->outfd)]);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4492 }
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4493 }
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4494
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4495 carryover = nbytes - coding->consumed;
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4496 bcopy (chars + coding->consumed, XSTRING (p->decoding_buf)->data,
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4497 carryover);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4498 XSETINT (p->decoding_carryover, carryover);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4499 nbytes = STRING_BYTES (XSTRING (text));
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4500 nchars = XSTRING (text)->size;
34647
1898b3c996ff (read_process_output): Don't run a filter if the code
Kenichi Handa <handa@m17n.org>
parents: 34352
diff changeset
4501 if (nbytes > 0)
1898b3c996ff (read_process_output): Don't run a filter if the code
Kenichi Handa <handa@m17n.org>
parents: 34352
diff changeset
4502 internal_condition_case_1 (read_process_output_call,
1898b3c996ff (read_process_output): Don't run a filter if the code
Kenichi Handa <handa@m17n.org>
parents: 34352
diff changeset
4503 Fcons (outstream,
1898b3c996ff (read_process_output): Don't run a filter if the code
Kenichi Handa <handa@m17n.org>
parents: 34352
diff changeset
4504 Fcons (proc, Fcons (text, Qnil))),
1898b3c996ff (read_process_output): Don't run a filter if the code
Kenichi Handa <handa@m17n.org>
parents: 34352
diff changeset
4505 !NILP (Vdebug_on_error) ? Qnil : Qerror,
1898b3c996ff (read_process_output): Don't run a filter if the code
Kenichi Handa <handa@m17n.org>
parents: 34352
diff changeset
4506 read_process_output_error_handler);
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4507
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4508 /* If we saved the match data nonrecursively, restore it now. */
10032
f689803caa92 Added code for automatically saving and restoring the match data
Francesco Potortì <pot@gnu.org>
parents: 9969
diff changeset
4509 restore_match_data ();
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4510 running_asynch_code = outer_running_asynch_code;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4511
3666
c7ff787b096f (read_process_output): Don't deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3608
diff changeset
4512 /* Handling the process output should not deactivate the mark. */
3510
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4513 Vdeactivate_mark = odeactivate;
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4514
23460
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
4515 /* Restore waiting_for_user_input_p as it was
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
4516 when we were called, in case the filter clobbered it. */
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
4517 waiting_for_user_input_p = waiting;
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
4518
12808
4db1f387e85f (read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents: 12749
diff changeset
4519 #if 0 /* Call record_asynch_buffer_change unconditionally,
4db1f387e85f (read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents: 12749
diff changeset
4520 because we might have changed minor modes or other things
4db1f387e85f (read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents: 12749
diff changeset
4521 that affect key bindings. */
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
4522 if (! EQ (Fcurrent_buffer (), obuffer)
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
4523 || ! EQ (current_buffer->keymap, okeymap))
12808
4db1f387e85f (read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents: 12749
diff changeset
4524 #endif
13159
2af96ac471bc (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 12808
diff changeset
4525 /* But do it only if the caller is actually going to read events.
2af96ac471bc (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 12808
diff changeset
4526 Otherwise there's no need to make him wake up, and it could
2af96ac471bc (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 12808
diff changeset
4527 cause trouble (for example it would make Fsit_for return). */
2af96ac471bc (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 12808
diff changeset
4528 if (waiting_for_user_input_p == -1)
2af96ac471bc (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 12808
diff changeset
4529 record_asynch_buffer_change ();
6748
b1cde622fa65 (read_process_output): If buffer changes, record that fact.
Karl Heuer <kwzh@gnu.org>
parents: 6569
diff changeset
4530
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4531 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4532 start_vms_process_read (vs);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4533 #endif
5561
fd7524d61a8d (read_process_output): Supply second arg to unbind_to.
Richard M. Stallman <rms@gnu.org>
parents: 5548
diff changeset
4534 unbind_to (count, Qnil);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4535 return nchars;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4536 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4537
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4538 /* If no filter, write into buffer if it isn't dead. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4539 if (!NILP (p->buffer) && !NILP (XBUFFER (p->buffer)->name))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4540 {
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4541 Lisp_Object old_read_only;
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4542 int old_begv, old_zv;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4543 int old_begv_byte, old_zv_byte;
3510
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4544 Lisp_Object odeactivate;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4545 int before, before_byte;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4546 int opoint_byte;
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4547 Lisp_Object text;
34352
642fb6c53a10 (read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents: 32864
diff changeset
4548 struct buffer *b;
3510
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4549
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4550 odeactivate = Vdeactivate_mark;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4551
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4552 Fset_buffer (p->buffer);
16039
855c8d8ba0f0 Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents: 15895
diff changeset
4553 opoint = PT;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4554 opoint_byte = PT_BYTE;
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4555 old_read_only = current_buffer->read_only;
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4556 old_begv = BEGV;
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4557 old_zv = ZV;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4558 old_begv_byte = BEGV_BYTE;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4559 old_zv_byte = ZV_BYTE;
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4560
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4561 current_buffer->read_only = Qnil;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4562
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4563 /* Insert new output into buffer
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4564 at the current end-of-output marker,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4565 thus preserving logical ordering of input and output. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4566 if (XMARKER (p->mark)->buffer)
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4567 SET_PT_BOTH (clip_to_bounds (BEGV, marker_position (p->mark), ZV),
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4568 clip_to_bounds (BEGV_BYTE, marker_byte_position (p->mark),
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4569 ZV_BYTE));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4570 else
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4571 SET_PT_BOTH (ZV, ZV_BYTE);
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4572 before = PT;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4573 before_byte = PT_BYTE;
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4574
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4575 /* If the output marker is outside of the visible region, save
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4576 the restriction and widen. */
16039
855c8d8ba0f0 Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents: 15895
diff changeset
4577 if (! (BEGV <= PT && PT <= ZV))
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4578 Fwiden ();
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4579
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4580 text = decode_coding_string (make_unibyte_string (chars, nbytes),
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4581 coding, 0);
30582
280157ad4aa3 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 30580
diff changeset
4582 Vlast_coding_system_used = coding->symbol;
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4583 /* A new coding system might be found. See the comment in the
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4584 similar code in the previous `if' block. */
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4585 if (!EQ (p->decode_coding_system, coding->symbol))
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4586 {
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4587 p->decode_coding_system = coding->symbol;
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4588 if (NILP (p->encode_coding_system)
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4589 && proc_encode_coding_system[XINT (p->outfd)])
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4590 {
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4591 p->encode_coding_system = coding->symbol;
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4592 setup_coding_system (coding->symbol,
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4593 proc_encode_coding_system[XINT (p->outfd)]);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4594 }
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4595 }
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4596 carryover = nbytes - coding->consumed;
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4597 bcopy (chars + coding->consumed, XSTRING (p->decoding_buf)->data,
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4598 carryover);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4599 XSETINT (p->decoding_carryover, carryover);
31419
bd258f4dc0fa (read_process_output): Before inserting the decoded
Kenichi Handa <handa@m17n.org>
parents: 31136
diff changeset
4600 /* Adjust the multibyteness of TEXT to that of the buffer. */
bd258f4dc0fa (read_process_output): Before inserting the decoded
Kenichi Handa <handa@m17n.org>
parents: 31136
diff changeset
4601 if (NILP (current_buffer->enable_multibyte_characters)
bd258f4dc0fa (read_process_output): Before inserting the decoded
Kenichi Handa <handa@m17n.org>
parents: 31136
diff changeset
4602 != ! STRING_MULTIBYTE (text))
bd258f4dc0fa (read_process_output): Before inserting the decoded
Kenichi Handa <handa@m17n.org>
parents: 31136
diff changeset
4603 text = (STRING_MULTIBYTE (text)
32395
11b8c07e5fed (read_process_output): Cancel previous change.
Kenichi Handa <handa@m17n.org>
parents: 32371
diff changeset
4604 ? Fstring_as_unibyte (text)
11b8c07e5fed (read_process_output): Cancel previous change.
Kenichi Handa <handa@m17n.org>
parents: 32371
diff changeset
4605 : Fstring_as_multibyte (text));
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4606 nbytes = STRING_BYTES (XSTRING (text));
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4607 nchars = XSTRING (text)->size;
32395
11b8c07e5fed (read_process_output): Cancel previous change.
Kenichi Handa <handa@m17n.org>
parents: 32371
diff changeset
4608 /* Insert before markers in case we are inserting where
11b8c07e5fed (read_process_output): Cancel previous change.
Kenichi Handa <handa@m17n.org>
parents: 32371
diff changeset
4609 the buffer's mark is, and the user's next command is Meta-y. */
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4610 insert_from_string_before_markers (text, 0, 0, nchars, nbytes, 0);
29017
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
4611
34352
642fb6c53a10 (read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents: 32864
diff changeset
4612 /* Make sure the process marker's position is valid when the
642fb6c53a10 (read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents: 32864
diff changeset
4613 process buffer is changed in the signal_after_change above.
642fb6c53a10 (read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents: 32864
diff changeset
4614 W3 is known to do that. */
642fb6c53a10 (read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents: 32864
diff changeset
4615 if (BUFFERP (p->buffer)
642fb6c53a10 (read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents: 32864
diff changeset
4616 && (b = XBUFFER (p->buffer), b != current_buffer))
642fb6c53a10 (read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents: 32864
diff changeset
4617 set_marker_both (p->mark, p->buffer, BUF_PT (b), BUF_PT_BYTE (b));
642fb6c53a10 (read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents: 32864
diff changeset
4618 else
642fb6c53a10 (read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents: 32864
diff changeset
4619 set_marker_both (p->mark, p->buffer, PT, PT_BYTE);
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4620
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4621 update_mode_lines++;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4622
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4623 /* Make sure opoint and the old restrictions
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4624 float ahead of any new text just as point would. */
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4625 if (opoint >= before)
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4626 {
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4627 opoint += PT - before;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4628 opoint_byte += PT_BYTE - before_byte;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4629 }
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4630 if (old_begv > before)
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4631 {
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4632 old_begv += PT - before;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4633 old_begv_byte += PT_BYTE - before_byte;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4634 }
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4635 if (old_zv >= before)
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4636 {
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4637 old_zv += PT - before;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4638 old_zv_byte += PT_BYTE - before_byte;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4639 }
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4640
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4641 /* If the restriction isn't what it should be, set it. */
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4642 if (old_begv != BEGV || old_zv != ZV)
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4643 Fnarrow_to_region (make_number (old_begv), make_number (old_zv));
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4644
3666
c7ff787b096f (read_process_output): Don't deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3608
diff changeset
4645 /* Handling the process output should not deactivate the mark. */
3510
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4646 Vdeactivate_mark = odeactivate;
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4647
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4648 current_buffer->read_only = old_read_only;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4649 SET_PT_BOTH (opoint, opoint_byte);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4650 set_buffer_internal (old);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4651 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4652 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4653 start_vms_process_read (vs);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4654 #endif
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4655 return nbytes;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4656 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4657
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4658 DEFUN ("waiting-for-user-input-p", Fwaiting_for_user_input_p, Swaiting_for_user_input_p,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4659 0, 0, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4660 doc: /* Returns non-nil if emacs is waiting for input from the user.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4661 This is intended for use by asynchronous process output filters and sentinels. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4662 ()
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4663 {
7352
ef89b78c1a92 (wait_reading_process_input): Don't call prepare_menu_bars
Richard M. Stallman <rms@gnu.org>
parents: 7266
diff changeset
4664 return (waiting_for_user_input_p ? Qt : Qnil);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4665 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4666
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4667 /* Sending data to subprocess */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4668
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4669 jmp_buf send_process_frame;
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4670 Lisp_Object process_sent_to;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4671
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4672 SIGTYPE
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4673 send_process_trap ()
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4674 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4675 #ifdef BSD4_1
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4676 sigrelse (SIGPIPE);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4677 sigrelse (SIGALRM);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4678 #endif /* BSD4_1 */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4679 longjmp (send_process_frame, 1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4680 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4681
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4682 /* Send some data to process PROC.
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4683 BUF is the beginning of the data; LEN is the number of characters.
32864
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4684 OBJECT is the Lisp object that the data comes from. If OBJECT is
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4685 nil or t, it means that the data comes from C string.
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4686
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4687 If OBJECT is not nil, the data is encoded by PROC's coding-system
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4688 for encoding before it is sent.
28157
336858b2b11a (send_process): Add a hint that the function
Gerd Moellmann <gerd@gnu.org>
parents: 28012
diff changeset
4689
336858b2b11a (send_process): Add a hint that the function
Gerd Moellmann <gerd@gnu.org>
parents: 28012
diff changeset
4690 This function can evaluate Lisp code and can garbage collect. */
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4691
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
4692 void
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4693 send_process (proc, buf, len, object)
11926
40d7e6f04ebe (create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents: 11845
diff changeset
4694 volatile Lisp_Object proc;
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4695 unsigned char *volatile buf;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4696 volatile int len;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4697 volatile Lisp_Object object;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4698 {
11926
40d7e6f04ebe (create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents: 11845
diff changeset
4699 /* Use volatile to protect variables from being clobbered by longjmp. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4700 int rv;
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4701 struct coding_system *coding;
15895
85112cca0b22 (send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents: 15717
diff changeset
4702 struct gcpro gcpro1;
85112cca0b22 (send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents: 15717
diff changeset
4703
85112cca0b22 (send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents: 15717
diff changeset
4704 GCPRO1 (object);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4705
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4706 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4707 struct Lisp_Process *p = XPROCESS (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4708 VMS_PROC_STUFF *vs, *get_vms_process_pointer();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4709 #endif /* VMS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4710
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4711 if (! NILP (XPROCESS (proc)->raw_status_low))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4712 update_status (XPROCESS (proc));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4713 if (! EQ (XPROCESS (proc)->status, Qrun))
28012
9c8bcd7e4a4f (send_process): Remove local variable `procname' that
Gerd Moellmann <gerd@gnu.org>
parents: 27861
diff changeset
4714 error ("Process %s not running",
9c8bcd7e4a4f (send_process): Remove local variable `procname' that
Gerd Moellmann <gerd@gnu.org>
parents: 27861
diff changeset
4715 XSTRING (XPROCESS (proc)->name)->data);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4716 if (XINT (XPROCESS (proc)->outfd) < 0)
28012
9c8bcd7e4a4f (send_process): Remove local variable `procname' that
Gerd Moellmann <gerd@gnu.org>
parents: 27861
diff changeset
4717 error ("Output file descriptor of %s is closed",
9c8bcd7e4a4f (send_process): Remove local variable `procname' that
Gerd Moellmann <gerd@gnu.org>
parents: 27861
diff changeset
4718 XSTRING (XPROCESS (proc)->name)->data);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4719
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
4720 coding = proc_encode_coding_system[XINT (XPROCESS (proc)->outfd)];
20433
a43789debf48 (read_process_output): Fix previous change, i.e, if
Kenichi Handa <handa@m17n.org>
parents: 20428
diff changeset
4721 Vlast_coding_system_used = coding->symbol;
a43789debf48 (read_process_output): Fix previous change, i.e, if
Kenichi Handa <handa@m17n.org>
parents: 20428
diff changeset
4722
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4723 if ((STRINGP (object) && STRING_MULTIBYTE (object))
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4724 || (BUFFERP (object)
32864
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4725 && !NILP (XBUFFER (object)->enable_multibyte_characters))
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4726 || EQ (object, Qt))
31136
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4727 {
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4728 if (!EQ (coding->symbol, XPROCESS (proc)->encode_coding_system))
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4729 /* The coding system for encoding was changed to raw-text
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4730 because we sent a unibyte text previously. Now we are
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4731 sending a multibyte text, thus we must encode it by the
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4732 original coding system specified for the current
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4733 process. */
42600
93254645e03b (send_process): Set src_multibyte to 1 after the call
Eli Zaretskii <eliz@gnu.org>
parents: 41969
diff changeset
4734 setup_coding_system (XPROCESS (proc)->encode_coding_system, coding);
93254645e03b (send_process): Set src_multibyte to 1 after the call
Eli Zaretskii <eliz@gnu.org>
parents: 41969
diff changeset
4735 /* src_multibyte should be set to 1 _after_ a call to
93254645e03b (send_process): Set src_multibyte to 1 after the call
Eli Zaretskii <eliz@gnu.org>
parents: 41969
diff changeset
4736 setup_coding_system, since it resets src_multibyte to
93254645e03b (send_process): Set src_multibyte to 1 after the call
Eli Zaretskii <eliz@gnu.org>
parents: 41969
diff changeset
4737 zero. */
93254645e03b (send_process): Set src_multibyte to 1 after the call
Eli Zaretskii <eliz@gnu.org>
parents: 41969
diff changeset
4738 coding->src_multibyte = 1;
31136
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4739 }
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4740 else
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4741 {
32864
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4742 /* For sending a unibyte text, character code conversion should
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4743 not take place but EOL conversion should. So, setup raw-text
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4744 or one of the subsidiary if we have not yet done it. */
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4745 if (coding->type != coding_type_raw_text)
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4746 {
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4747 if (CODING_REQUIRE_FLUSHING (coding))
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4748 {
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4749 /* But, before changing the coding, we must flush out data. */
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4750 coding->mode |= CODING_MODE_LAST_BLOCK;
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4751 send_process (proc, "", 0, Qt);
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4752 }
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4753 coding->src_multibyte = 0;
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4754 setup_raw_text_coding_system (coding);
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4755 }
31136
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4756 }
29017
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
4757 coding->dst_multibyte = 0;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
4758
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4759 if (CODING_REQUIRE_ENCODING (coding))
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4760 {
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4761 int require = encoding_buffer_size (coding, len);
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4762 int from_byte = -1, from = -1, to = -1;
18585
64184009811b (send_process): Make buf and temp_buf `unsigned char *'.
Richard M. Stallman <rms@gnu.org>
parents: 18540
diff changeset
4763 unsigned char *temp_buf = NULL;
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4764
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4765 if (BUFFERP (object))
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4766 {
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4767 from_byte = BUF_PTR_BYTE_POS (XBUFFER (object), buf);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4768 from = buf_bytepos_to_charpos (XBUFFER (object), from_byte);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4769 to = buf_bytepos_to_charpos (XBUFFER (object), from_byte + len);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4770 }
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4771 else if (STRINGP (object))
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4772 {
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4773 from_byte = buf - XSTRING (object)->data;
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4774 from = string_byte_to_char (object, from_byte);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4775 to = string_byte_to_char (object, from_byte + len);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4776 }
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4777
39429
9de129194439 (send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents: 39406
diff changeset
4778 if (coding->composing != COMPOSITION_DISABLED)
9de129194439 (send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents: 39406
diff changeset
4779 {
9de129194439 (send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents: 39406
diff changeset
4780 if (from_byte >= 0)
9de129194439 (send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents: 39406
diff changeset
4781 coding_save_composition (coding, from, to, object);
9de129194439 (send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents: 39406
diff changeset
4782 else
9de129194439 (send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents: 39406
diff changeset
4783 coding->composing = COMPOSITION_DISABLED;
9de129194439 (send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents: 39406
diff changeset
4784 }
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4785
21244
50929073a0ba Use STRING_BYTES and SET_STRING_BYTES.
Richard M. Stallman <rms@gnu.org>
parents: 21177
diff changeset
4786 if (STRING_BYTES (XSTRING (XPROCESS (proc)->encoding_buf)) < require)
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4787 XPROCESS (proc)->encoding_buf = make_uninit_string (require);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4788
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4789 if (from_byte >= 0)
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4790 buf = (BUFFERP (object)
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4791 ? BUF_BYTE_ADDRESS (XBUFFER (object), from_byte)
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4792 : XSTRING (object)->data + from_byte);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4793
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4794 object = XPROCESS (proc)->encoding_buf;
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4795 encode_coding (coding, (char *) buf, XSTRING (object)->data,
21244
50929073a0ba Use STRING_BYTES and SET_STRING_BYTES.
Richard M. Stallman <rms@gnu.org>
parents: 21177
diff changeset
4796 len, STRING_BYTES (XSTRING (object)));
20715
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
4797 len = coding->produced;
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4798 buf = XSTRING (object)->data;
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4799 if (temp_buf)
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4800 xfree (temp_buf);
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4801 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4802
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4803 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4804 vs = get_vms_process_pointer (p->pid);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4805 if (vs == 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4806 error ("Could not find this process: %x", p->pid);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4807 else if (write_to_vms_process (vs, buf, len))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4808 ;
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4809 #else /* not VMS */
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4810
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4811 if (pty_max_bytes == 0)
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4812 {
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4813 #if defined (HAVE_FPATHCONF) && defined (_PC_MAX_CANON)
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4814 pty_max_bytes = fpathconf (XFASTINT (XPROCESS (proc)->outfd),
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4815 _PC_MAX_CANON);
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4816 if (pty_max_bytes < 0)
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4817 pty_max_bytes = 250;
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4818 #else
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4819 pty_max_bytes = 250;
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4820 #endif
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4821 /* Deduct one, to leave space for the eof. */
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4822 pty_max_bytes--;
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4823 }
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4824
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4825 /* 2000-09-21: Emacs 20.7, sparc-sun-solaris-2.6, GCC 2.95.2,
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4826 CFLAGS="-g -O": The value of the parameter `proc' is clobbered
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4827 when returning with longjmp despite being declared volatile. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4828 if (!setjmp (send_process_frame))
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4829 {
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4830 process_sent_to = proc;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4831 while (len > 0)
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4832 {
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4833 int this = len;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4834 SIGTYPE (*old_sigpipe)();
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4835
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4836 /* Decide how much data we can send in one batch.
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4837 Long lines need to be split into multiple batches. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4838 if (!NILP (XPROCESS (proc)->pty_flag))
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4839 {
39812
66e0816837a8 Update calls to openp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39429
diff changeset
4840 /* Starting this at zero is always correct when not the first
66e0816837a8 Update calls to openp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39429
diff changeset
4841 iteration because the previous iteration ended by sending C-d.
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4842 It may not be correct for the first iteration
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4843 if a partial line was sent in a separate send_process call.
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4844 If that proves worth handling, we need to save linepos
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4845 in the process object. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4846 int linepos = 0;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4847 unsigned char *ptr = (unsigned char *) buf;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4848 unsigned char *end = (unsigned char *) buf + len;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4849
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4850 /* Scan through this text for a line that is too long. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4851 while (ptr != end && linepos < pty_max_bytes)
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4852 {
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4853 if (*ptr == '\n')
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4854 linepos = 0;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4855 else
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4856 linepos++;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4857 ptr++;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4858 }
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4859 /* If we found one, break the line there
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4860 and put in a C-d to force the buffer through. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4861 this = ptr - buf;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4862 }
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4863
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4864 /* Send this batch, using one or more write calls. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4865 while (this > 0)
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4866 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4867 int outfd = XINT (XPROCESS (proc)->outfd);
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4868 old_sigpipe = (SIGTYPE (*) ()) signal (SIGPIPE, send_process_trap);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4869 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4870 if (DATAGRAM_CHAN_P (outfd))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4871 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4872 rv = sendto (outfd, (char *) buf, this,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4873 0, datagram_address[outfd].sa,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4874 datagram_address[outfd].len);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4875 if (rv < 0 && errno == EMSGSIZE)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4876 report_file_error ("sending datagram", Fcons (proc, Qnil));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4877 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4878 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4879 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4880 rv = emacs_write (outfd, (char *) buf, this);
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4881 signal (SIGPIPE, old_sigpipe);
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4882
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4883 if (rv < 0)
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4884 {
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4885 if (0
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4886 #ifdef EWOULDBLOCK
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4887 || errno == EWOULDBLOCK
6158
6b81b2575071 Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 5891
diff changeset
4888 #endif
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4889 #ifdef EAGAIN
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4890 || errno == EAGAIN
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4891 #endif
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4892 )
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4893 /* Buffer is full. Wait, accepting input;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4894 that may allow the program
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4895 to finish doing output and read more. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4896 {
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4897 Lisp_Object zero;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4898 int offset = 0;
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4899
27705
2c53eb482802 (send_process) [BROKEN_PTY_READ_AFTER_EAGAIN]:
Gerd Moellmann <gerd@gnu.org>
parents: 27669
diff changeset
4900 #ifdef BROKEN_PTY_READ_AFTER_EAGAIN
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4901 /* A gross hack to work around a bug in FreeBSD.
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4902 In the following sequence, read(2) returns
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4903 bogus data:
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4904
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4905 write(2) 1022 bytes
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4906 write(2) 954 bytes, get EAGAIN
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4907 read(2) 1024 bytes in process_read_output
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4908 read(2) 11 bytes in process_read_output
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4909
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4910 That is, read(2) returns more bytes than have
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4911 ever been written successfully. The 1033 bytes
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4912 read are the 1022 bytes written successfully
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4913 after processing (for example with CRs added if
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4914 the terminal is set up that way which it is
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4915 here). The same bytes will be seen again in a
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4916 later read(2), without the CRs. */
27705
2c53eb482802 (send_process) [BROKEN_PTY_READ_AFTER_EAGAIN]:
Gerd Moellmann <gerd@gnu.org>
parents: 27669
diff changeset
4917
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4918 if (errno == EAGAIN)
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4919 {
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4920 int flags = FWRITE;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4921 ioctl (XINT (XPROCESS (proc)->outfd), TIOCFLUSH,
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4922 &flags);
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4923 }
27705
2c53eb482802 (send_process) [BROKEN_PTY_READ_AFTER_EAGAIN]:
Gerd Moellmann <gerd@gnu.org>
parents: 27669
diff changeset
4924 #endif /* BROKEN_PTY_READ_AFTER_EAGAIN */
2c53eb482802 (send_process) [BROKEN_PTY_READ_AFTER_EAGAIN]:
Gerd Moellmann <gerd@gnu.org>
parents: 27669
diff changeset
4925
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4926 /* Running filters might relocate buffers or strings.
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4927 Arrange to relocate BUF. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4928 if (BUFFERP (object))
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4929 offset = BUF_PTR_BYTE_POS (XBUFFER (object), buf);
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4930 else if (STRINGP (object))
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4931 offset = buf - XSTRING (object)->data;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4932
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4933 XSETFASTINT (zero, 0);
16718
ea26040865cb (send_process) [EMACS_HAS_USECS]:
Richard M. Stallman <rms@gnu.org>
parents: 16644
diff changeset
4934 #ifdef EMACS_HAS_USECS
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4935 wait_reading_process_input (0, 20000, zero, 0);
16718
ea26040865cb (send_process) [EMACS_HAS_USECS]:
Richard M. Stallman <rms@gnu.org>
parents: 16644
diff changeset
4936 #else
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4937 wait_reading_process_input (1, 0, zero, 0);
16718
ea26040865cb (send_process) [EMACS_HAS_USECS]:
Richard M. Stallman <rms@gnu.org>
parents: 16644
diff changeset
4938 #endif
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4939
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4940 if (BUFFERP (object))
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4941 buf = BUF_BYTE_ADDRESS (XBUFFER (object), offset);
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4942 else if (STRINGP (object))
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4943 buf = offset + XSTRING (object)->data;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4944
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4945 rv = 0;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4946 }
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4947 else
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4948 /* This is a real error. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4949 report_file_error ("writing to process", Fcons (proc, Qnil));
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4950 }
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4951 buf += rv;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4952 len -= rv;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4953 this -= rv;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4954 }
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4955
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4956 /* If we sent just part of the string, put in an EOF
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4957 to force it through, before we send the rest. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4958 if (len > 0)
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4959 Fprocess_send_eof (proc);
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4960 }
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4961 }
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4962 #endif /* not VMS */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4963 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4964 {
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4965 #ifndef VMS
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4966 proc = process_sent_to;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4967 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4968 XPROCESS (proc)->raw_status_low = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4969 XPROCESS (proc)->raw_status_high = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4970 XPROCESS (proc)->status = Fcons (Qexit, Fcons (make_number (256), Qnil));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4971 XSETINT (XPROCESS (proc)->tick, ++process_tick);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4972 deactivate_process (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4973 #ifdef VMS
28012
9c8bcd7e4a4f (send_process): Remove local variable `procname' that
Gerd Moellmann <gerd@gnu.org>
parents: 27861
diff changeset
4974 error ("Error writing to process %s; closed it",
9c8bcd7e4a4f (send_process): Remove local variable `procname' that
Gerd Moellmann <gerd@gnu.org>
parents: 27861
diff changeset
4975 XSTRING (XPROCESS (proc)->name)->data);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4976 #else
28012
9c8bcd7e4a4f (send_process): Remove local variable `procname' that
Gerd Moellmann <gerd@gnu.org>
parents: 27861
diff changeset
4977 error ("SIGPIPE raised on process %s; closed it",
9c8bcd7e4a4f (send_process): Remove local variable `procname' that
Gerd Moellmann <gerd@gnu.org>
parents: 27861
diff changeset
4978 XSTRING (XPROCESS (proc)->name)->data);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4979 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4980 }
15895
85112cca0b22 (send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents: 15717
diff changeset
4981
85112cca0b22 (send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents: 15717
diff changeset
4982 UNGCPRO;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4983 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4984
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4985 DEFUN ("process-send-region", Fprocess_send_region, Sprocess_send_region,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4986 3, 3, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4987 doc: /* Send current contents of region as input to PROCESS.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4988 PROCESS may be a process, a buffer, the name of a process or buffer, or
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4989 nil, indicating the current buffer's process.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4990 Called from program, takes three arguments, PROCESS, START and END.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4991 If the region is more than 500 characters long,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4992 it is sent in several bunches. This may happen even for shorter regions.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4993 Output from processes can arrive in between bunches. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4994 (process, start, end)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4995 Lisp_Object process, start, end;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4996 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4997 Lisp_Object proc;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4998 int start1, end1;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4999
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5000 proc = get_process (process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5001 validate_region (&start, &end);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5002
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5003 if (XINT (start) < GPT && XINT (end) > GPT)
18739
60f002497be1 (Fprocess_send_region): Convert move_gap argument to int.
Richard M. Stallman <rms@gnu.org>
parents: 18708
diff changeset
5004 move_gap (XINT (start));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5005
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5006 start1 = CHAR_TO_BYTE (XINT (start));
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5007 end1 = CHAR_TO_BYTE (XINT (end));
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5008 send_process (proc, BYTE_POS_ADDR (start1), end1 - start1,
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5009 Fcurrent_buffer ());
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5010
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5011 return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5012 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5013
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5014 DEFUN ("process-send-string", Fprocess_send_string, Sprocess_send_string,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5015 2, 2, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5016 doc: /* Send PROCESS the contents of STRING as input.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5017 PROCESS may be a process, a buffer, the name of a process or buffer, or
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5018 nil, indicating the current buffer's process.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5019 If STRING is more than 500 characters long,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5020 it is sent in several bunches. This may happen even for shorter strings.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5021 Output from processes can arrive in between bunches. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5022 (process, string)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5023 Lisp_Object process, string;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5024 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5025 Lisp_Object proc;
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
5026 CHECK_STRING (string);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5027 proc = get_process (process);
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
5028 send_process (proc, XSTRING (string)->data,
21244
50929073a0ba Use STRING_BYTES and SET_STRING_BYTES.
Richard M. Stallman <rms@gnu.org>
parents: 21177
diff changeset
5029 STRING_BYTES (XSTRING (string)), string);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5030 return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5031 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5032
24352
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5033 DEFUN ("process-running-child-p", Fprocess_running_child_p,
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5034 Sprocess_running_child_p, 0, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5035 doc: /* Return t if PROCESS has given the terminal to a child.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5036 If the operating system does not make it possible to find out,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5037 return t unconditionally. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5038 (process)
24352
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5039 Lisp_Object process;
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5040 {
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5041 /* Initialize in case ioctl doesn't exist or gives an error,
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5042 in a way that will cause returning t. */
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5043 int gid = 0;
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5044 Lisp_Object proc;
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5045 struct Lisp_Process *p;
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5046
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5047 proc = get_process (process);
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5048 p = XPROCESS (proc);
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5049
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5050 if (!EQ (p->childp, Qt))
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5051 error ("Process %s is not a subprocess",
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5052 XSTRING (p->name)->data);
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5053 if (XINT (p->infd) < 0)
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5054 error ("Process %s is not active",
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5055 XSTRING (p->name)->data);
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5056
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5057 #ifdef TIOCGPGRP
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5058 if (!NILP (p->subtty))
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5059 ioctl (XFASTINT (p->subtty), TIOCGPGRP, &gid);
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5060 else
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5061 ioctl (XINT (p->infd), TIOCGPGRP, &gid);
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5062 #endif /* defined (TIOCGPGRP ) */
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5063
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5064 if (gid == XFASTINT (p->pid))
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5065 return Qnil;
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5066 return Qt;
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5067 }
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5068
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5069 /* send a signal number SIGNO to PROCESS.
24352
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5070 If CURRENT_GROUP is t, that means send to the process group
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5071 that currently owns the terminal being used to communicate with PROCESS.
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5072 This is used for various commands in shell mode.
24352
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5073 If CURRENT_GROUP is lambda, that means send to the process group
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5074 that currently owns the terminal, but only if it is NOT the shell itself.
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5075
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5076 If NOMSG is zero, insert signal-announcements into process's buffers
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5077 right away.
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5078
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5079 If we can, we try to signal PROCESS by sending control characters
7220
a33eb16cab9d (Fopen_network_stream): Retry the connect if EADDRINUSE. Ignore EISCONN.
Richard M. Stallman <rms@gnu.org>
parents: 7157
diff changeset
5080 down the pty. This allows us to signal inferiors who have changed
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5081 their uid, for which killpg would return an EPERM error. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5082
1522
19ccf004b172 * process.c: (status_convert): Declare this to return a
Jim Blandy <jimb@redhat.com>
parents: 1323
diff changeset
5083 static void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5084 process_send_signal (process, signo, current_group, nomsg)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5085 Lisp_Object process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5086 int signo;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5087 Lisp_Object current_group;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5088 int nomsg;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5089 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5090 Lisp_Object proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5091 register struct Lisp_Process *p;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5092 int gid;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5093 int no_pgrp = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5094
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5095 proc = get_process (process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5096 p = XPROCESS (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5097
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5098 if (!EQ (p->childp, Qt))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5099 error ("Process %s is not a subprocess",
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5100 XSTRING (p->name)->data);
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5101 if (XINT (p->infd) < 0)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5102 error ("Process %s is not active",
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5103 XSTRING (p->name)->data);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5104
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5105 if (NILP (p->pty_flag))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5106 current_group = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5107
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5108 /* If we are using pgrps, get a pgrp number and make it negative. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5109 if (!NILP (current_group))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5110 {
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5111 #ifdef SIGNALS_VIA_CHARACTERS
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5112 /* If possible, send signals to the entire pgrp
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5113 by sending an input character to it. */
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5114
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5115 /* TERMIOS is the latest and bestest, and seems most likely to
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5116 work. If the system has it, use it. */
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5117 #ifdef HAVE_TERMIOS
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5118 struct termios t;
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5119
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5120 switch (signo)
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5121 {
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5122 case SIGINT:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5123 tcgetattr (XINT (p->infd), &t);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5124 send_process (proc, &t.c_cc[VINTR], 1, Qnil);
2120
fc3cdca22f8d * process.c (process_send_signal): In the TERMIOS code for sending
Jim Blandy <jimb@redhat.com>
parents: 1925
diff changeset
5125 return;
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5126
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5127 case SIGQUIT:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5128 tcgetattr (XINT (p->infd), &t);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5129 send_process (proc, &t.c_cc[VQUIT], 1, Qnil);
2120
fc3cdca22f8d * process.c (process_send_signal): In the TERMIOS code for sending
Jim Blandy <jimb@redhat.com>
parents: 1925
diff changeset
5130 return;
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5131
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5132 case SIGTSTP:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5133 tcgetattr (XINT (p->infd), &t);
7414
33e5afbb62bf (process_send_signal): If PREFER_VSUSP, use VSUSP instead of VSWTCH.
Richard M. Stallman <rms@gnu.org>
parents: 7352
diff changeset
5134 #if defined (VSWTCH) && !defined (PREFER_VSUSP)
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5135 send_process (proc, &t.c_cc[VSWTCH], 1, Qnil);
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5136 #else
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5137 send_process (proc, &t.c_cc[VSUSP], 1, Qnil);
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5138 #endif
2120
fc3cdca22f8d * process.c (process_send_signal): In the TERMIOS code for sending
Jim Blandy <jimb@redhat.com>
parents: 1925
diff changeset
5139 return;
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5140 }
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5141
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5142 #else /* ! HAVE_TERMIOS */
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5143
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5144 /* On Berkeley descendants, the following IOCTL's retrieve the
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5145 current control characters. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5146 #if defined (TIOCGLTC) && defined (TIOCGETC)
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5147
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5148 struct tchars c;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5149 struct ltchars lc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5150
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5151 switch (signo)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5152 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5153 case SIGINT:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5154 ioctl (XINT (p->infd), TIOCGETC, &c);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5155 send_process (proc, &c.t_intrc, 1, Qnil);
1522
19ccf004b172 * process.c: (status_convert): Declare this to return a
Jim Blandy <jimb@redhat.com>
parents: 1323
diff changeset
5156 return;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5157 case SIGQUIT:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5158 ioctl (XINT (p->infd), TIOCGETC, &c);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5159 send_process (proc, &c.t_quitc, 1, Qnil);
1522
19ccf004b172 * process.c: (status_convert): Declare this to return a
Jim Blandy <jimb@redhat.com>
parents: 1323
diff changeset
5160 return;
1012
a48ed1d416dd * process.c (process_send_signal): Don't send SIGTSTP if the
Jim Blandy <jimb@redhat.com>
parents: 849
diff changeset
5161 #ifdef SIGTSTP
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5162 case SIGTSTP:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5163 ioctl (XINT (p->infd), TIOCGLTC, &lc);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5164 send_process (proc, &lc.t_suspc, 1, Qnil);
1522
19ccf004b172 * process.c: (status_convert): Declare this to return a
Jim Blandy <jimb@redhat.com>
parents: 1323
diff changeset
5165 return;
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5166 #endif /* ! defined (SIGTSTP) */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5167 }
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5168
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5169 #else /* ! defined (TIOCGLTC) && defined (TIOCGETC) */
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5170
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5171 /* On SYSV descendants, the TCGETA ioctl retrieves the current control
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5172 characters. */
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5173 #ifdef TCGETA
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5174 struct termio t;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5175 switch (signo)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5176 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5177 case SIGINT:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5178 ioctl (XINT (p->infd), TCGETA, &t);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5179 send_process (proc, &t.c_cc[VINTR], 1, Qnil);
1522
19ccf004b172 * process.c: (status_convert): Declare this to return a
Jim Blandy <jimb@redhat.com>
parents: 1323
diff changeset
5180 return;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5181 case SIGQUIT:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5182 ioctl (XINT (p->infd), TCGETA, &t);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5183 send_process (proc, &t.c_cc[VQUIT], 1, Qnil);
1522
19ccf004b172 * process.c: (status_convert): Declare this to return a
Jim Blandy <jimb@redhat.com>
parents: 1323
diff changeset
5184 return;
1569
52a69b6a8f96 * process.c [SYSV]: Don't include <termios.h>, <termio.h>, or
Jim Blandy <jimb@redhat.com>
parents: 1522
diff changeset
5185 #ifdef SIGTSTP
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5186 case SIGTSTP:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5187 ioctl (XINT (p->infd), TCGETA, &t);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5188 send_process (proc, &t.c_cc[VSWTCH], 1, Qnil);
1522
19ccf004b172 * process.c: (status_convert): Declare this to return a
Jim Blandy <jimb@redhat.com>
parents: 1323
diff changeset
5189 return;
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5190 #endif /* ! defined (SIGTSTP) */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5191 }
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5192 #else /* ! defined (TCGETA) */
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5193 Your configuration files are messed up.
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5194 /* If your system configuration files define SIGNALS_VIA_CHARACTERS,
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5195 you'd better be using one of the alternatives above! */
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5196 #endif /* ! defined (TCGETA) */
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5197 #endif /* ! defined (TIOCGLTC) && defined (TIOCGETC) */
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5198 #endif /* ! defined HAVE_TERMIOS */
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5199 #endif /* ! defined (SIGNALS_VIA_CHARACTERS) */
849
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5200
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5201 #ifdef TIOCGPGRP
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5202 /* Get the pgrp using the tty itself, if we have that.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5203 Otherwise, use the pty to get the pgrp.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5204 On pfa systems, saka@pfu.fujitsu.co.JP writes:
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5205 "TIOCGPGRP symbol defined in sys/ioctl.h at E50.
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5206 But, TIOCGPGRP does not work on E50 ;-P works fine on E60"
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5207 His patch indicates that if TIOCGPGRP returns an error, then
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5208 we should just assume that p->pid is also the process group id. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5209 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5210 int err;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5211
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5212 if (!NILP (p->subtty))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5213 err = ioctl (XFASTINT (p->subtty), TIOCGPGRP, &gid);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5214 else
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5215 err = ioctl (XINT (p->infd), TIOCGPGRP, &gid);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5216
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5217 #ifdef pfa
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5218 if (err == -1)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5219 gid = - XFASTINT (p->pid);
849
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5220 #endif /* ! defined (pfa) */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5221 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5222 if (gid == -1)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5223 no_pgrp = 1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5224 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5225 gid = - gid;
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5226 #else /* ! defined (TIOCGPGRP ) */
849
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5227 /* Can't select pgrps on this system, so we know that
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5228 the child itself heads the pgrp. */
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5229 gid = - XFASTINT (p->pid);
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5230 #endif /* ! defined (TIOCGPGRP ) */
24352
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5231
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5232 /* If current_group is lambda, and the shell owns the terminal,
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5233 don't send any signal. */
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5234 if (EQ (current_group, Qlambda) && gid == - XFASTINT (p->pid))
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5235 return;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5236 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5237 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5238 gid = - XFASTINT (p->pid);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5239
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5240 switch (signo)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5241 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5242 #ifdef SIGCONT
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5243 case SIGCONT:
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5244 p->raw_status_low = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5245 p->raw_status_high = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5246 p->status = Qrun;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5247 XSETINT (p->tick, ++process_tick);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5248 if (!nomsg)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5249 status_notify ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5250 break;
849
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5251 #endif /* ! defined (SIGCONT) */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5252 case SIGINT:
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5253 #ifdef VMS
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5254 send_process (proc, "\003", 1, Qnil); /* ^C */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5255 goto whoosh;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5256 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5257 case SIGQUIT:
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5258 #ifdef VMS
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5259 send_process (proc, "\031", 1, Qnil); /* ^Y */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5260 goto whoosh;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5261 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5262 case SIGKILL:
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5263 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5264 sys$forcex (&(XFASTINT (p->pid)), 0, 1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5265 whoosh:
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5266 #endif
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5267 flush_pending_output (XINT (p->infd));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5268 break;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5269 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5270
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5271 /* If we don't have process groups, send the signal to the immediate
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5272 subprocess. That isn't really right, but it's better than any
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5273 obvious alternative. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5274 if (no_pgrp)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5275 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5276 kill (XFASTINT (p->pid), signo);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5277 return;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5278 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5279
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5280 /* gid may be a pid, or minus a pgrp's number */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5281 #ifdef TIOCSIGSEND
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5282 if (!NILP (current_group))
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5283 ioctl (XINT (p->infd), TIOCSIGSEND, signo);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5284 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5285 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5286 gid = - XFASTINT (p->pid);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5287 kill (gid, signo);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5288 }
849
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5289 #else /* ! defined (TIOCSIGSEND) */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5290 EMACS_KILLPG (-gid, signo);
849
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5291 #endif /* ! defined (TIOCSIGSEND) */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5292 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5293
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5294 DEFUN ("interrupt-process", Finterrupt_process, Sinterrupt_process, 0, 2, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5295 doc: /* Interrupt process PROCESS.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5296 PROCESS may be a process, a buffer, or the name of a process or buffer.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5297 nil or no arg means current buffer's process.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5298 Second arg CURRENT-GROUP non-nil means send signal to
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5299 the current process-group of the process's controlling terminal
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5300 rather than to the process's own process group.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5301 If the process is a shell, this means interrupt current subjob
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5302 rather than the shell.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5303
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5304 If CURRENT-GROUP is `lambda', and if the shell owns the terminal,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5305 don't send the signal. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5306 (process, current_group)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5307 Lisp_Object process, current_group;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5308 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5309 process_send_signal (process, SIGINT, current_group, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5310 return process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5311 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5312
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5313 DEFUN ("kill-process", Fkill_process, Skill_process, 0, 2, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5314 doc: /* Kill process PROCESS. May be process or name of one.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5315 See function `interrupt-process' for more details on usage. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5316 (process, current_group)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5317 Lisp_Object process, current_group;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5318 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5319 process_send_signal (process, SIGKILL, current_group, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5320 return process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5321 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5322
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5323 DEFUN ("quit-process", Fquit_process, Squit_process, 0, 2, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5324 doc: /* Send QUIT signal to process PROCESS. May be process or name of one.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5325 See function `interrupt-process' for more details on usage. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5326 (process, current_group)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5327 Lisp_Object process, current_group;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5328 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5329 process_send_signal (process, SIGQUIT, current_group, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5330 return process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5331 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5332
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5333 DEFUN ("stop-process", Fstop_process, Sstop_process, 0, 2, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5334 doc: /* Stop process PROCESS. May be process or name of one.
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5335 See function `interrupt-process' for more details on usage.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5336 If PROCESS is a network process, inhibit handling of incoming traffic. */)
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5337 (process, current_group)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5338 Lisp_Object process, current_group;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5339 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5340 #ifdef HAVE_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5341 if (PROCESSP (process) && NETCONN_P (process))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5342 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5343 struct Lisp_Process *p;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5344
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5345 p = XPROCESS (process);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5346 if (NILP (p->command)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5347 && XINT (p->infd) >= 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5348 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5349 FD_CLR (XINT (p->infd), &input_wait_mask);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5350 FD_CLR (XINT (p->infd), &non_keyboard_wait_mask);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5351 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5352 p->command = Qt;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5353 return process;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5354 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5355 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5356 #ifndef SIGTSTP
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5357 error ("no SIGTSTP support");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5358 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5359 process_send_signal (process, SIGTSTP, current_group, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5360 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5361 return process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5362 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5363
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5364 DEFUN ("continue-process", Fcontinue_process, Scontinue_process, 0, 2, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5365 doc: /* Continue process PROCESS. May be process or name of one.
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5366 See function `interrupt-process' for more details on usage.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5367 If PROCESS is a network process, resume handling of incoming traffic. */)
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5368 (process, current_group)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5369 Lisp_Object process, current_group;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5370 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5371 #ifdef HAVE_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5372 if (PROCESSP (process) && NETCONN_P (process))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5373 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5374 struct Lisp_Process *p;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5375
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5376 p = XPROCESS (process);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5377 if (EQ (p->command, Qt)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5378 && XINT (p->infd) >= 0
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5379 && (!EQ (p->filter, Qt) || EQ (p->status, Qlisten)))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5380 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5381 FD_SET (XINT (p->infd), &input_wait_mask);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5382 FD_SET (XINT (p->infd), &non_keyboard_wait_mask);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5383 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5384 p->command = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5385 return process;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5386 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5387 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5388 #ifdef SIGCONT
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5389 process_send_signal (process, SIGCONT, current_group, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5390 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5391 error ("no SIGCONT support");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5392 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5393 return process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5394 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5395
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5396 DEFUN ("signal-process", Fsignal_process, Ssignal_process,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5397 2, 2, "nProcess number: \nnSignal code: ",
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5398 doc: /* Send the process with process id PID the signal with code SIGCODE.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5399 PID must be an integer. The process need not be a child of this Emacs.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5400 SIGCODE may be an integer, or a symbol whose name is a signal name. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5401 (pid, sigcode)
11144
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5402 Lisp_Object pid, sigcode;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5403 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
5404 CHECK_NUMBER (pid);
11144
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5405
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5406 #define handle_signal(NAME, VALUE) \
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5407 else if (!strcmp (name, NAME)) \
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5408 XSETINT (sigcode, VALUE)
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5409
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5410 if (INTEGERP (sigcode))
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5411 ;
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5412 else
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5413 {
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5414 unsigned char *name;
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5415
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
5416 CHECK_SYMBOL (sigcode);
11144
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5417 name = XSYMBOL (sigcode)->name->data;
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5418
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5419 if (0)
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5420 ;
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5421 #ifdef SIGHUP
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5422 handle_signal ("SIGHUP", SIGHUP);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5423 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5424 #ifdef SIGINT
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5425 handle_signal ("SIGINT", SIGINT);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5426 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5427 #ifdef SIGQUIT
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5428 handle_signal ("SIGQUIT", SIGQUIT);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5429 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5430 #ifdef SIGILL
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5431 handle_signal ("SIGILL", SIGILL);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5432 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5433 #ifdef SIGABRT
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5434 handle_signal ("SIGABRT", SIGABRT);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5435 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5436 #ifdef SIGEMT
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5437 handle_signal ("SIGEMT", SIGEMT);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5438 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5439 #ifdef SIGKILL
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5440 handle_signal ("SIGKILL", SIGKILL);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5441 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5442 #ifdef SIGFPE
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5443 handle_signal ("SIGFPE", SIGFPE);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5444 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5445 #ifdef SIGBUS
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5446 handle_signal ("SIGBUS", SIGBUS);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5447 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5448 #ifdef SIGSEGV
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5449 handle_signal ("SIGSEGV", SIGSEGV);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5450 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5451 #ifdef SIGSYS
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5452 handle_signal ("SIGSYS", SIGSYS);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5453 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5454 #ifdef SIGPIPE
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5455 handle_signal ("SIGPIPE", SIGPIPE);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5456 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5457 #ifdef SIGALRM
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5458 handle_signal ("SIGALRM", SIGALRM);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5459 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5460 #ifdef SIGTERM
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5461 handle_signal ("SIGTERM", SIGTERM);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5462 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5463 #ifdef SIGURG
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5464 handle_signal ("SIGURG", SIGURG);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5465 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5466 #ifdef SIGSTOP
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5467 handle_signal ("SIGSTOP", SIGSTOP);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5468 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5469 #ifdef SIGTSTP
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5470 handle_signal ("SIGTSTP", SIGTSTP);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5471 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5472 #ifdef SIGCONT
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5473 handle_signal ("SIGCONT", SIGCONT);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5474 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5475 #ifdef SIGCHLD
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5476 handle_signal ("SIGCHLD", SIGCHLD);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5477 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5478 #ifdef SIGTTIN
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5479 handle_signal ("SIGTTIN", SIGTTIN);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5480 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5481 #ifdef SIGTTOU
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5482 handle_signal ("SIGTTOU", SIGTTOU);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5483 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5484 #ifdef SIGIO
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5485 handle_signal ("SIGIO", SIGIO);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5486 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5487 #ifdef SIGXCPU
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5488 handle_signal ("SIGXCPU", SIGXCPU);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5489 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5490 #ifdef SIGXFSZ
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5491 handle_signal ("SIGXFSZ", SIGXFSZ);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5492 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5493 #ifdef SIGVTALRM
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5494 handle_signal ("SIGVTALRM", SIGVTALRM);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5495 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5496 #ifdef SIGPROF
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5497 handle_signal ("SIGPROF", SIGPROF);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5498 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5499 #ifdef SIGWINCH
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5500 handle_signal ("SIGWINCH", SIGWINCH);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5501 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5502 #ifdef SIGINFO
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5503 handle_signal ("SIGINFO", SIGINFO);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5504 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5505 #ifdef SIGUSR1
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5506 handle_signal ("SIGUSR1", SIGUSR1);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5507 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5508 #ifdef SIGUSR2
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5509 handle_signal ("SIGUSR2", SIGUSR2);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5510 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5511 else
11148
117b32676686 (Fsignal_process): SIGCODE is a symbol, not a string.
Karl Heuer <kwzh@gnu.org>
parents: 11144
diff changeset
5512 error ("Undefined signal name %s", name);
11144
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5513 }
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5514
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5515 #undef handle_signal
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5516
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5517 return make_number (kill (XINT (pid), XINT (sigcode)));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5518 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5519
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5520 DEFUN ("process-send-eof", Fprocess_send_eof, Sprocess_send_eof, 0, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5521 doc: /* Make PROCESS see end-of-file in its input.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5522 EOF comes after any text already sent to it.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5523 PROCESS may be a process, a buffer, the name of a process or buffer, or
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5524 nil, indicating the current buffer's process.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5525 If PROCESS is a network connection, or is a process communicating
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5526 through a pipe (as opposed to a pty), then you cannot send any more
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5527 text to PROCESS after you call this function. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5528 (process)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5529 Lisp_Object process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5530 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5531 Lisp_Object proc;
23879
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5532 struct coding_system *coding;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5533
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5534 if (DATAGRAM_CONN_P (process))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5535 return process;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5536
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5537 proc = get_process (process);
23879
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5538 coding = proc_encode_coding_system[XINT (XPROCESS (proc)->outfd)];
2221
7edc78402205 (Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents: 2200
diff changeset
5539
7edc78402205 (Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents: 2200
diff changeset
5540 /* Make sure the process is really alive. */
7edc78402205 (Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents: 2200
diff changeset
5541 if (! NILP (XPROCESS (proc)->raw_status_low))
7edc78402205 (Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents: 2200
diff changeset
5542 update_status (XPROCESS (proc));
7edc78402205 (Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents: 2200
diff changeset
5543 if (! EQ (XPROCESS (proc)->status, Qrun))
2222
d81c60c5f9ce Fix typo in previous change.
Richard M. Stallman <rms@gnu.org>
parents: 2221
diff changeset
5544 error ("Process %s not running", XSTRING (XPROCESS (proc)->name)->data);
2221
7edc78402205 (Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents: 2200
diff changeset
5545
23879
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5546 if (CODING_REQUIRE_FLUSHING (coding))
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5547 {
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5548 coding->mode |= CODING_MODE_LAST_BLOCK;
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5549 send_process (proc, "", 0, Qnil);
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5550 }
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5551
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5552 #ifdef VMS
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5553 send_process (proc, "\032", 1, Qnil); /* ^z */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5554 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5555 if (!NILP (XPROCESS (proc)->pty_flag))
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5556 send_process (proc, "\004", 1, Qnil);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5557 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5558 {
22939
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5559 int old_outfd, new_outfd;
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5560
18329
ddaafa596bf5 (Fprocess_send_eof): Prooperly conditionalize prev. change.
Richard M. Stallman <rms@gnu.org>
parents: 18328
diff changeset
5561 #ifdef HAVE_SHUTDOWN
18328
0295bbed3c39 (Fprocess_send_eof): Use shutdown, if it's a socket.
Richard M. Stallman <rms@gnu.org>
parents: 18292
diff changeset
5562 /* If this is a network connection, or socketpair is used
0295bbed3c39 (Fprocess_send_eof): Use shutdown, if it's a socket.
Richard M. Stallman <rms@gnu.org>
parents: 18292
diff changeset
5563 for communication with the subprocess, call shutdown to cause EOF.
0295bbed3c39 (Fprocess_send_eof): Use shutdown, if it's a socket.
Richard M. Stallman <rms@gnu.org>
parents: 18292
diff changeset
5564 (In some old system, shutdown to socketpair doesn't work.
0295bbed3c39 (Fprocess_send_eof): Use shutdown, if it's a socket.
Richard M. Stallman <rms@gnu.org>
parents: 18292
diff changeset
5565 Then we just can't win.) */
0295bbed3c39 (Fprocess_send_eof): Use shutdown, if it's a socket.
Richard M. Stallman <rms@gnu.org>
parents: 18292
diff changeset
5566 if (NILP (XPROCESS (proc)->pid)
0295bbed3c39 (Fprocess_send_eof): Use shutdown, if it's a socket.
Richard M. Stallman <rms@gnu.org>
parents: 18292
diff changeset
5567 || XINT (XPROCESS (proc)->outfd) == XINT (XPROCESS (proc)->infd))
0295bbed3c39 (Fprocess_send_eof): Use shutdown, if it's a socket.
Richard M. Stallman <rms@gnu.org>
parents: 18292
diff changeset
5568 shutdown (XINT (XPROCESS (proc)->outfd), 1);
0295bbed3c39 (Fprocess_send_eof): Use shutdown, if it's a socket.
Richard M. Stallman <rms@gnu.org>
parents: 18292
diff changeset
5569 /* In case of socketpair, outfd == infd, so don't close it. */
0295bbed3c39 (Fprocess_send_eof): Use shutdown, if it's a socket.
Richard M. Stallman <rms@gnu.org>
parents: 18292
diff changeset
5570 if (XINT (XPROCESS (proc)->outfd) != XINT (XPROCESS (proc)->infd))
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
5571 emacs_close (XINT (XPROCESS (proc)->outfd));
18329
ddaafa596bf5 (Fprocess_send_eof): Prooperly conditionalize prev. change.
Richard M. Stallman <rms@gnu.org>
parents: 18328
diff changeset
5572 #else /* not HAVE_SHUTDOWN */
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
5573 emacs_close (XINT (XPROCESS (proc)->outfd));
18329
ddaafa596bf5 (Fprocess_send_eof): Prooperly conditionalize prev. change.
Richard M. Stallman <rms@gnu.org>
parents: 18328
diff changeset
5574 #endif /* not HAVE_SHUTDOWN */
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
5575 new_outfd = emacs_open (NULL_DEVICE, O_WRONLY, 0);
22939
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5576 old_outfd = XINT (XPROCESS (proc)->outfd);
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5577
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5578 if (!proc_encode_coding_system[new_outfd])
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5579 proc_encode_coding_system[new_outfd]
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5580 = (struct coding_system *) xmalloc (sizeof (struct coding_system));
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5581 bcopy (proc_encode_coding_system[old_outfd],
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5582 proc_encode_coding_system[new_outfd],
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5583 sizeof (struct coding_system));
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5584 bzero (proc_encode_coding_system[old_outfd],
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5585 sizeof (struct coding_system));
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5586
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5587 XSETINT (XPROCESS (proc)->outfd, new_outfd);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5588 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5589 #endif /* VMS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5590 return process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5591 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5592
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5593 /* Kill all processes associated with `buffer'.
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5594 If `buffer' is nil, kill all processes */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5595
20382
dbad9367d232 (create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents: 20225
diff changeset
5596 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5597 kill_buffer_processes (buffer)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5598 Lisp_Object buffer;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5599 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5600 Lisp_Object tail, proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5601
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
5602 for (tail = Vprocess_alist; GC_CONSP (tail); tail = XCDR (tail))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5603 {
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
5604 proc = XCDR (XCAR (tail));
9952
9daedd94a204 (NETCONN_P, kill_buffer_processes): Use the new type-test macros.
Karl Heuer <kwzh@gnu.org>
parents: 9882
diff changeset
5605 if (GC_PROCESSP (proc)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5606 && (NILP (buffer) || EQ (XPROCESS (proc)->buffer, buffer)))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5607 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5608 if (NETCONN_P (proc))
7764
fad00b057e50 (kill_buffer_processes): For net conn, use Fdelete_process.
Richard M. Stallman <rms@gnu.org>
parents: 7748
diff changeset
5609 Fdelete_process (proc);
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5610 else if (XINT (XPROCESS (proc)->infd) >= 0)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5611 process_send_signal (proc, SIGHUP, Qnil, 1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5612 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5613 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5614 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5615
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5616 /* On receipt of a signal that a child status has changed, loop asking
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5617 about children with changed statuses until the system says there
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5618 are no more.
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5619
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5620 All we do is change the status; we do not run sentinels or print
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5621 notifications. That is saved for the next time keyboard input is
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5622 done, in order to avoid timing errors.
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5623
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5624 ** WARNING: this can be called during garbage collection.
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5625 Therefore, it must not be fooled by the presence of mark bits in
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5626 Lisp objects.
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5627
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5628 ** USG WARNING: Although it is not obvious from the documentation
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5629 in signal(2), on a USG system the SIGCLD handler MUST NOT call
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5630 signal() before executing at least one wait(), otherwise the
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5631 handler will be called again, resulting in an infinite loop. The
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5632 relevant portion of the documentation reads "SIGCLD signals will be
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5633 queued and the signal-catching function will be continually
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5634 reentered until the queue is empty". Invoking signal() causes the
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5635 kernel to reexamine the SIGCLD queue. Fred Fish, UniSoft Systems
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5636 Inc. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5637
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5638 SIGTYPE
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5639 sigchld_handler (signo)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5640 int signo;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5641 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5642 int old_errno = errno;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5643 Lisp_Object proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5644 register struct Lisp_Process *p;
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5645 extern EMACS_TIME *input_available_clear_time;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5646
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5647 #ifdef BSD4_1
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5648 extern int sigheld;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5649 sigheld |= sigbit (SIGCHLD);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5650 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5651
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5652 while (1)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5653 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5654 register int pid;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5655 WAITTYPE w;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5656 Lisp_Object tail;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5657
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5658 #ifdef WNOHANG
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5659 #ifndef WUNTRACED
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5660 #define WUNTRACED 0
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5661 #endif /* no WUNTRACED */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5662 /* Keep trying to get a status until we get a definitive result. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5663 do
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5664 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5665 errno = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5666 pid = wait3 (&w, WNOHANG | WUNTRACED, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5667 }
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5668 while (pid < 0 && errno == EINTR);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5669
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5670 if (pid <= 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5671 {
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5672 /* PID == 0 means no processes found, PID == -1 means a real
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5673 failure. We have done all our job, so return. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5674
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5675 /* USG systems forget handlers when they are used;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5676 must reestablish each time */
16116
80a67b8f39e9 (create_process_1, sigchld_handler) [POSIX_SIGNALS]:
Richard M. Stallman <rms@gnu.org>
parents: 16076
diff changeset
5677 #if defined (USG) && !defined (POSIX_SIGNALS)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5678 signal (signo, sigchld_handler); /* WARNING - must come after wait3() */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5679 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5680 #ifdef BSD4_1
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5681 sigheld &= ~sigbit (SIGCHLD);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5682 sigrelse (SIGCHLD);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5683 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5684 errno = old_errno;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5685 return;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5686 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5687 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5688 pid = wait (&w);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5689 #endif /* no WNOHANG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5690
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5691 /* Find the process that signaled us, and record its status. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5692
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5693 p = 0;
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5694 for (tail = Vprocess_alist; GC_CONSP (tail); tail = XCDR (tail))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5695 {
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
5696 proc = XCDR (XCAR (tail));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5697 p = XPROCESS (proc);
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5698 if (GC_EQ (p->childp, Qt) && XINT (p->pid) == pid)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5699 break;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5700 p = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5701 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5702
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5703 /* Look for an asynchronous process whose pid hasn't been filled
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5704 in yet. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5705 if (p == 0)
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5706 for (tail = Vprocess_alist; GC_CONSP (tail); tail = XCDR (tail))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5707 {
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
5708 proc = XCDR (XCAR (tail));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5709 p = XPROCESS (proc);
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5710 if (GC_INTEGERP (p->pid) && XINT (p->pid) == -1)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5711 break;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5712 p = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5713 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5714
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5715 /* Change the status of the process that was found. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5716 if (p != 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5717 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5718 union { int i; WAITTYPE wt; } u;
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5719 int clear_desc_flag = 0;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5720
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5721 XSETINT (p->tick, ++process_tick);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5722 u.wt = w;
12324
41bd44279127 (sigchld_handler): Change XSETFASTINT to XSETINT.
Richard M. Stallman <rms@gnu.org>
parents: 12215
diff changeset
5723 XSETINT (p->raw_status_low, u.i & 0xffff);
41bd44279127 (sigchld_handler): Change XSETFASTINT to XSETINT.
Richard M. Stallman <rms@gnu.org>
parents: 12215
diff changeset
5724 XSETINT (p->raw_status_high, u.i >> 16);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5725
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5726 /* If process has terminated, stop waiting for its output. */
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5727 if ((WIFSIGNALED (w) || WIFEXITED (w))
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5728 && XINT (p->infd) >= 0)
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5729 clear_desc_flag = 1;
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5730
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5731 /* We use clear_desc_flag to avoid a compiler bug in Microsoft C. */
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5732 if (clear_desc_flag)
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5733 {
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5734 FD_CLR (XINT (p->infd), &input_wait_mask);
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5735 FD_CLR (XINT (p->infd), &non_keyboard_wait_mask);
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5736 }
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5737
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5738 /* Tell wait_reading_process_input that it needs to wake up and
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5739 look around. */
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5740 if (input_available_clear_time)
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5741 EMACS_SET_SECS_USECS (*input_available_clear_time, 0, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5742 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5743
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5744 /* There was no asynchronous process found for that id. Check
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5745 if we have a synchronous process. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5746 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5747 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5748 synch_process_alive = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5749
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5750 /* Report the status of the synchronous process. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5751 if (WIFEXITED (w))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5752 synch_process_retcode = WRETCODE (w);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5753 else if (WIFSIGNALED (w))
5579
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
5754 {
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
5755 int code = WTERMSIG (w);
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
5756 char *signame;
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
5757
26526
b7438760079b * callproc.c (strerror): Remove decl.
Paul Eggert <eggert@twinsun.com>
parents: 26313
diff changeset
5758 synchronize_system_messages_locale ();
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
5759 signame = strsignal (code);
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
5760
5579
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
5761 if (signame == 0)
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
5762 signame = "unknown";
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
5763
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
5764 synch_process_death = signame;
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
5765 }
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5766
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5767 /* Tell wait_reading_process_input that it needs to wake up and
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5768 look around. */
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5769 if (input_available_clear_time)
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5770 EMACS_SET_SECS_USECS (*input_available_clear_time, 0, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5771 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5772
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5773 /* On some systems, we must return right away.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5774 If any more processes want to signal us, we will
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5775 get another signal.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5776 Otherwise (on systems that have WNOHANG), loop around
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5777 to use up all the processes that have something to tell us. */
39406
9dd4ad9bc53e (sigchld_handler) [LINUX]: Don't return from
Gerd Moellmann <gerd@gnu.org>
parents: 39361
diff changeset
5778 #if (defined WINDOWSNT \
41969
e669966d496e Test GNU_LINUX, not LINUX.
Richard M. Stallman <rms@gnu.org>
parents: 41856
diff changeset
5779 || (defined USG && !defined GNU_LINUX \
39406
9dd4ad9bc53e (sigchld_handler) [LINUX]: Don't return from
Gerd Moellmann <gerd@gnu.org>
parents: 39361
diff changeset
5780 && !(defined HPUX && defined WNOHANG)))
16116
80a67b8f39e9 (create_process_1, sigchld_handler) [POSIX_SIGNALS]:
Richard M. Stallman <rms@gnu.org>
parents: 16076
diff changeset
5781 #if defined (USG) && ! defined (POSIX_SIGNALS)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5782 signal (signo, sigchld_handler);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5783 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5784 errno = old_errno;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5785 return;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5786 #endif /* USG, but not HPUX with WNOHANG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5787 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5788 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5789
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5790
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5791 static Lisp_Object
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5792 exec_sentinel_unwind (data)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5793 Lisp_Object data;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5794 {
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
5795 XPROCESS (XCAR (data))->sentinel = XCDR (data);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5796 return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5797 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5798
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5799 static Lisp_Object
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5800 exec_sentinel_error_handler (error)
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5801 Lisp_Object error;
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5802 {
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5803 cmd_error_internal (error, "error in process sentinel: ");
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5804 Vinhibit_quit = Qt;
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5805 update_echo_area ();
11277
d4547e4b0aab (read_process_output_error_handler)
Richard M. Stallman <rms@gnu.org>
parents: 11235
diff changeset
5806 Fsleep_for (make_number (2), Qnil);
27558
f99efd14b932 (Fstart_process): Doc fix.
Dave Love <fx@gnu.org>
parents: 27430
diff changeset
5807 return Qt;
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5808 }
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5809
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5810 static void
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5811 exec_sentinel (proc, reason)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5812 Lisp_Object proc, reason;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5813 {
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5814 Lisp_Object sentinel, obuffer, odeactivate, okeymap;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5815 register struct Lisp_Process *p = XPROCESS (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5816 int count = specpdl_ptr - specpdl;
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5817 int outer_running_asynch_code = running_asynch_code;
23460
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
5818 int waiting = waiting_for_user_input_p;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5819
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5820 /* No need to gcpro these, because all we do with them later
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5821 is test them for EQness, and none of them should be a string. */
7454
8d9e41a175fa (exec_sentinel): Don't deactivate the mark. Check for asynch buffer switch.
Karl Heuer <kwzh@gnu.org>
parents: 7414
diff changeset
5822 odeactivate = Vdeactivate_mark;
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5823 XSETBUFFER (obuffer, current_buffer);
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5824 okeymap = current_buffer->keymap;
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5825
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5826 sentinel = p->sentinel;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5827 if (NILP (sentinel))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5828 return;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5829
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5830 /* Zilch the sentinel while it's running, to avoid recursive invocations;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5831 assure that it gets restored no matter how the sentinel exits. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5832 p->sentinel = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5833 record_unwind_protect (exec_sentinel_unwind, Fcons (proc, sentinel));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5834 /* Inhibit quit so that random quits don't screw up a running filter. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5835 specbind (Qinhibit_quit, Qt);
8231
5226ed89c1a6 (Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8063
diff changeset
5836 specbind (Qlast_nonmenu_event, Qt);
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5837
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5838 /* In case we get recursively called,
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5839 and we already saved the match data nonrecursively,
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5840 save the same match data in safely recursive fashion. */
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5841 if (outer_running_asynch_code)
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5842 {
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5843 Lisp_Object tem;
16728
309a750fd5c0 (read_process_output, exec_sentinel):
Richard M. Stallman <rms@gnu.org>
parents: 16718
diff changeset
5844 tem = Fmatch_data (Qnil, Qnil);
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5845 restore_match_data ();
21177
73f8ae8312c8 (exec_sentinel, read_process_output): Fstore_match_data => Fset_match_data.
Richard M. Stallman <rms@gnu.org>
parents: 21049
diff changeset
5846 record_unwind_protect (Fset_match_data, Fmatch_data (Qnil, Qnil));
73f8ae8312c8 (exec_sentinel, read_process_output): Fstore_match_data => Fset_match_data.
Richard M. Stallman <rms@gnu.org>
parents: 21049
diff changeset
5847 Fset_match_data (tem);
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5848 }
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5849
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5850 /* For speed, if a search happens within this code,
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5851 save the match data in a special nonrecursive fashion. */
10032
f689803caa92 Added code for automatically saving and restoring the match data
Francesco Potortì <pot@gnu.org>
parents: 9969
diff changeset
5852 running_asynch_code = 1;
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5853
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5854 internal_condition_case_1 (read_process_output_call,
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5855 Fcons (sentinel,
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5856 Fcons (proc, Fcons (reason, Qnil))),
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5857 !NILP (Vdebug_on_error) ? Qnil : Qerror,
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5858 exec_sentinel_error_handler);
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5859
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5860 /* If we saved the match data nonrecursively, restore it now. */
10032
f689803caa92 Added code for automatically saving and restoring the match data
Francesco Potortì <pot@gnu.org>
parents: 9969
diff changeset
5861 restore_match_data ();
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5862 running_asynch_code = outer_running_asynch_code;
7454
8d9e41a175fa (exec_sentinel): Don't deactivate the mark. Check for asynch buffer switch.
Karl Heuer <kwzh@gnu.org>
parents: 7414
diff changeset
5863
8d9e41a175fa (exec_sentinel): Don't deactivate the mark. Check for asynch buffer switch.
Karl Heuer <kwzh@gnu.org>
parents: 7414
diff changeset
5864 Vdeactivate_mark = odeactivate;
23460
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
5865
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
5866 /* Restore waiting_for_user_input_p as it was
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
5867 when we were called, in case the filter clobbered it. */
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
5868 waiting_for_user_input_p = waiting;
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
5869
12808
4db1f387e85f (read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents: 12749
diff changeset
5870 #if 0
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5871 if (! EQ (Fcurrent_buffer (), obuffer)
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5872 || ! EQ (current_buffer->keymap, okeymap))
12808
4db1f387e85f (read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents: 12749
diff changeset
5873 #endif
13159
2af96ac471bc (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 12808
diff changeset
5874 /* But do it only if the caller is actually going to read events.
2af96ac471bc (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 12808
diff changeset
5875 Otherwise there's no need to make him wake up, and it could
2af96ac471bc (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 12808
diff changeset
5876 cause trouble (for example it would make Fsit_for return). */
2af96ac471bc (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 12808
diff changeset
5877 if (waiting_for_user_input_p == -1)
2af96ac471bc (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 12808
diff changeset
5878 record_asynch_buffer_change ();
7454
8d9e41a175fa (exec_sentinel): Don't deactivate the mark. Check for asynch buffer switch.
Karl Heuer <kwzh@gnu.org>
parents: 7414
diff changeset
5879
5561
fd7524d61a8d (read_process_output): Supply second arg to unbind_to.
Richard M. Stallman <rms@gnu.org>
parents: 5548
diff changeset
5880 unbind_to (count, Qnil);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5881 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5882
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5883 /* Report all recent events of a change in process status
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5884 (either run the sentinel or output a message).
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5885 This is done while Emacs is waiting for keyboard input. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5886
20382
dbad9367d232 (create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents: 20225
diff changeset
5887 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5888 status_notify ()
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5889 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5890 register Lisp_Object proc, buffer;
6515
df7438605e1e (status_notify): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6429
diff changeset
5891 Lisp_Object tail, msg;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5892 struct gcpro gcpro1, gcpro2;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5893
6515
df7438605e1e (status_notify): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6429
diff changeset
5894 tail = Qnil;
df7438605e1e (status_notify): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6429
diff changeset
5895 msg = Qnil;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5896 /* We need to gcpro tail; if read_process_output calls a filter
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5897 which deletes a process and removes the cons to which tail points
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5898 from Vprocess_alist, and then causes a GC, tail is an unprotected
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5899 reference. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5900 GCPRO2 (tail, msg);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5901
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5902 /* Set this now, so that if new processes are created by sentinels
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5903 that we run, we get called again to handle their status changes. */
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5904 update_tick = process_tick;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5905
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5906 for (tail = Vprocess_alist; !NILP (tail); tail = Fcdr (tail))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5907 {
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5908 Lisp_Object symbol;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5909 register struct Lisp_Process *p;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5910
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5911 proc = Fcdr (Fcar (tail));
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5912 p = XPROCESS (proc);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5913
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5914 if (XINT (p->tick) != XINT (p->update_tick))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5915 {
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5916 XSETINT (p->update_tick, XINT (p->tick));
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5917
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5918 /* If process is still active, read any output that remains. */
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5919 while (! EQ (p->filter, Qt)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
5920 && ! EQ (p->status, Qconnect)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5921 && ! EQ (p->status, Qlisten)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5922 && ! EQ (p->command, Qt) /* Network process not stopped. */
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5923 && XINT (p->infd) >= 0
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5924 && read_process_output (proc, XINT (p->infd)) > 0);
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5925
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5926 buffer = p->buffer;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5927
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5928 /* Get the text to use for the message. */
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5929 if (!NILP (p->raw_status_low))
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5930 update_status (p);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5931 msg = status_message (p->status);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5932
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5933 /* If process is terminated, deactivate it or delete it. */
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5934 symbol = p->status;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5935 if (CONSP (p->status))
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
5936 symbol = XCAR (p->status);
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5937
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5938 if (EQ (symbol, Qsignal) || EQ (symbol, Qexit)
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5939 || EQ (symbol, Qclosed))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5940 {
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5941 if (delete_exited_processes)
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5942 remove_process (proc);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5943 else
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5944 deactivate_process (proc);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5945 }
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5946
16464
c1f19d8e5b80 (status_notify): Update p->tick again
Richard M. Stallman <rms@gnu.org>
parents: 16220
diff changeset
5947 /* The actions above may have further incremented p->tick.
c1f19d8e5b80 (status_notify): Update p->tick again
Richard M. Stallman <rms@gnu.org>
parents: 16220
diff changeset
5948 So set p->update_tick again
c1f19d8e5b80 (status_notify): Update p->tick again
Richard M. Stallman <rms@gnu.org>
parents: 16220
diff changeset
5949 so that an error in the sentinel will not cause
c1f19d8e5b80 (status_notify): Update p->tick again
Richard M. Stallman <rms@gnu.org>
parents: 16220
diff changeset
5950 this code to be run again. */
c1f19d8e5b80 (status_notify): Update p->tick again
Richard M. Stallman <rms@gnu.org>
parents: 16220
diff changeset
5951 XSETINT (p->update_tick, XINT (p->tick));
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5952 /* Now output the message suitably. */
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5953 if (!NILP (p->sentinel))
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5954 exec_sentinel (proc, msg);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5955 /* Don't bother with a message in the buffer
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5956 when a process becomes runnable. */
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5957 else if (!EQ (symbol, Qrun) && !NILP (buffer))
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5958 {
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5959 Lisp_Object ro, tem;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5960 struct buffer *old = current_buffer;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5961 int opoint, opoint_byte;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5962 int before, before_byte;
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5963
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5964 ro = XBUFFER (buffer)->read_only;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5965
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5966 /* Avoid error if buffer is deleted
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5967 (probably that's why the process is dead, too) */
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5968 if (NILP (XBUFFER (buffer)->name))
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5969 continue;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5970 Fset_buffer (buffer);
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
5971
16039
855c8d8ba0f0 Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents: 15895
diff changeset
5972 opoint = PT;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5973 opoint_byte = PT_BYTE;
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5974 /* Insert new output into buffer
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5975 at the current end-of-output marker,
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5976 thus preserving logical ordering of input and output. */
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5977 if (XMARKER (p->mark)->buffer)
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5978 Fgoto_char (p->mark);
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5979 else
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5980 SET_PT_BOTH (ZV, ZV_BYTE);
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
5981
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
5982 before = PT;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5983 before_byte = PT_BYTE;
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5984
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5985 tem = current_buffer->read_only;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5986 current_buffer->read_only = Qnil;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5987 insert_string ("\nProcess ");
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5988 Finsert (1, &p->name);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5989 insert_string (" ");
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5990 Finsert (1, &msg);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5991 current_buffer->read_only = tem;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5992 set_marker_both (p->mark, p->buffer, PT, PT_BYTE);
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5993
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
5994 if (opoint >= before)
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5995 SET_PT_BOTH (opoint + (PT - before),
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5996 opoint_byte + (PT_BYTE - before_byte));
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
5997 else
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5998 SET_PT_BOTH (opoint, opoint_byte);
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
5999
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
6000 set_buffer_internal (old);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
6001 }
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
6002 }
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
6003 } /* end for */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6004
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6005 update_mode_lines++; /* in case buffers use %s in mode-line-format */
35336
002c02db42d3 Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents: 34660
diff changeset
6006 redisplay_preserve_echo_area (13);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6007
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6008 UNGCPRO;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6009 }
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6010
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6011
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6012 DEFUN ("set-process-coding-system", Fset_process_coding_system,
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6013 Sset_process_coding_system, 1, 3, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6014 doc: /* Set coding systems of PROCESS to DECODING and ENCODING.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6015 DECODING will be used to decode subprocess output and ENCODING to
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6016 encode subprocess input. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6017 (proc, decoding, encoding)
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6018 register Lisp_Object proc, decoding, encoding;
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6019 {
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6020 register struct Lisp_Process *p;
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6021
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
6022 CHECK_PROCESS (proc);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6023 p = XPROCESS (proc);
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6024 if (XINT (p->infd) < 0)
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6025 error ("Input file descriptor of %s closed", XSTRING (p->name)->data);
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6026 if (XINT (p->outfd) < 0)
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6027 error ("Output file descriptor of %s closed", XSTRING (p->name)->data);
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6028
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6029 p->decode_coding_system = Fcheck_coding_system (decoding);
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6030 p->encode_coding_system = Fcheck_coding_system (encoding);
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6031 setup_coding_system (decoding,
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
6032 proc_decode_coding_system[XINT (p->infd)]);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6033 setup_coding_system (encoding,
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
6034 proc_encode_coding_system[XINT (p->outfd)]);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6035
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6036 return Qnil;
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6037 }
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6038
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6039 DEFUN ("process-coding-system",
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6040 Fprocess_coding_system, Sprocess_coding_system, 1, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6041 doc: /* Return a cons of coding systems for decoding and encoding of PROCESS. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6042 (proc)
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6043 register Lisp_Object proc;
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6044 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
6045 CHECK_PROCESS (proc);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6046 return Fcons (XPROCESS (proc)->decode_coding_system,
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6047 XPROCESS (proc)->encode_coding_system);
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6048 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6049
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6050 /* The first time this is called, assume keyboard input comes from DESC
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6051 instead of from where we used to expect it.
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6052 Subsequent calls mean assume input keyboard can come from DESC
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6053 in addition to other places. */
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6054
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6055 static int add_keyboard_wait_descriptor_called_flag;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6056
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6057 void
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6058 add_keyboard_wait_descriptor (desc)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6059 int desc;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6060 {
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6061 if (! add_keyboard_wait_descriptor_called_flag)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6062 FD_CLR (0, &input_wait_mask);
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6063 add_keyboard_wait_descriptor_called_flag = 1;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6064 FD_SET (desc, &input_wait_mask);
17224
dd2545e79add (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 17110
diff changeset
6065 FD_SET (desc, &non_process_wait_mask);
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6066 if (desc > max_keyboard_desc)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6067 max_keyboard_desc = desc;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6068 }
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6069
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6070 /* From now on, do not expect DESC to give keyboard input. */
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6071
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6072 void
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6073 delete_keyboard_wait_descriptor (desc)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6074 int desc;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6075 {
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6076 int fd;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6077 int lim = max_keyboard_desc;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6078
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6079 FD_CLR (desc, &input_wait_mask);
17224
dd2545e79add (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 17110
diff changeset
6080 FD_CLR (desc, &non_process_wait_mask);
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6081
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6082 if (desc == max_keyboard_desc)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6083 for (fd = 0; fd < lim; fd++)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6084 if (FD_ISSET (fd, &input_wait_mask)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6085 && !FD_ISSET (fd, &non_keyboard_wait_mask))
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6086 max_keyboard_desc = fd;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6087 }
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6088
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6089 /* Return nonzero if *MASK has a bit set
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6090 that corresponds to one of the keyboard input descriptors. */
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6091
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6092 int
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6093 keyboard_bit_set (mask)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6094 SELECT_TYPE *mask;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6095 {
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6096 int fd;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6097
12541
33a4586124e9 (keyboard_bit_set): Fix one-off in loop end.
Karl Heuer <kwzh@gnu.org>
parents: 12491
diff changeset
6098 for (fd = 0; fd <= max_keyboard_desc; fd++)
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6099 if (FD_ISSET (fd, mask) && FD_ISSET (fd, &input_wait_mask)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6100 && !FD_ISSET (fd, &non_keyboard_wait_mask))
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6101 return 1;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6102
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6103 return 0;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6104 }
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6105
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
6106 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6107 init_process ()
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6108 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6109 register int i;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6110
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6111 #ifdef SIGCHLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6112 #ifndef CANNOT_DUMP
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6113 if (! noninteractive || initialized)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6114 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6115 signal (SIGCHLD, sigchld_handler);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6116 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6117
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6118 FD_ZERO (&input_wait_mask);
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6119 FD_ZERO (&non_keyboard_wait_mask);
17224
dd2545e79add (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 17110
diff changeset
6120 FD_ZERO (&non_process_wait_mask);
7044
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
6121 max_process_desc = 0;
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
6122
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6123 FD_SET (0, &input_wait_mask);
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
6124
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6125 Vprocess_alist = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6126 for (i = 0; i < MAXDESC; i++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6127 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6128 chan_process[i] = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6129 proc_buffered_char[i] = -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6130 }
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
6131 bzero (proc_decode_coding_system, sizeof proc_decode_coding_system);
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
6132 bzero (proc_encode_coding_system, sizeof proc_encode_coding_system);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6133 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6134 bzero (datagram_address, sizeof datagram_address);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6135 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6136 }
4231
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
6137
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
6138 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6139 syms_of_process ()
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6140 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6141 Qprocessp = intern ("processp");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6142 staticpro (&Qprocessp);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6143 Qrun = intern ("run");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6144 staticpro (&Qrun);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6145 Qstop = intern ("stop");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6146 staticpro (&Qstop);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6147 Qsignal = intern ("signal");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6148 staticpro (&Qsignal);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6149
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6150 /* Qexit is already staticpro'd by syms_of_eval; don't staticpro it
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6151 here again.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6152
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6153 Qexit = intern ("exit");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6154 staticpro (&Qexit); */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6155
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6156 Qopen = intern ("open");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6157 staticpro (&Qopen);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6158 Qclosed = intern ("closed");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6159 staticpro (&Qclosed);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
6160 Qconnect = intern ("connect");
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
6161 staticpro (&Qconnect);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
6162 Qfailed = intern ("failed");
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
6163 staticpro (&Qfailed);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6164 Qlisten = intern ("listen");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6165 staticpro (&Qlisten);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6166 Qlocal = intern ("local");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6167 staticpro (&Qlocal);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6168
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6169 QCname = intern (":name");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6170 staticpro (&QCname);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6171 QCbuffer = intern (":buffer");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6172 staticpro (&QCbuffer);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6173 QChost = intern (":host");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6174 staticpro (&QChost);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6175 QCservice = intern (":service");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6176 staticpro (&QCservice);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6177 QCfamily = intern (":family");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6178 staticpro (&QCfamily);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6179 QClocal = intern (":local");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6180 staticpro (&QClocal);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6181 QCremote = intern (":remote");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6182 staticpro (&QCremote);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6183 QCcoding = intern (":coding");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6184 staticpro (&QCcoding);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6185 QCserver = intern (":server");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6186 staticpro (&QCserver);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6187 QCdatagram = intern (":datagram");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6188 staticpro (&QCdatagram);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6189 QCnowait = intern (":nowait");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6190 staticpro (&QCnowait);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6191 QCfilter = intern (":filter");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6192 staticpro (&QCfilter);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6193 QCsentinel = intern (":sentinel");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6194 staticpro (&QCsentinel);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6195 QClog = intern (":log");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6196 staticpro (&QClog);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6197 QCnoquery = intern (":noquery");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6198 staticpro (&QCnoquery);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6199 QCstop = intern (":stop");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6200 staticpro (&QCstop);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6201 QCoptions = intern (":options");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6202 staticpro (&QCoptions);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6203 QCfeature = intern (":feature");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6204 staticpro (&QCfeature);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6205
8231
5226ed89c1a6 (Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8063
diff changeset
6206 Qlast_nonmenu_event = intern ("last-nonmenu-event");
5226ed89c1a6 (Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8063
diff changeset
6207 staticpro (&Qlast_nonmenu_event);
5226ed89c1a6 (Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8063
diff changeset
6208
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6209 staticpro (&Vprocess_alist);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6210
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6211 DEFVAR_BOOL ("delete-exited-processes", &delete_exited_processes,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6212 doc: /* *Non-nil means delete processes immediately when they exit.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6213 nil means don't delete them until `list-processes' is run. */);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6214
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6215 delete_exited_processes = 1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6216
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6217 DEFVAR_LISP ("process-connection-type", &Vprocess_connection_type,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6218 doc: /* Control type of device used to communicate with subprocesses.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6219 Values are nil to use a pipe, or t or `pty' to use a pty.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6220 The value has no effect if the system has no ptys or if all ptys are busy:
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6221 then a pipe is used in any case.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6222 The value takes effect when `start-process' is called. */);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6223 Vprocess_connection_type = Qt;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6224
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6225 defsubr (&Sprocessp);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6226 defsubr (&Sget_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6227 defsubr (&Sget_buffer_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6228 defsubr (&Sdelete_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6229 defsubr (&Sprocess_status);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6230 defsubr (&Sprocess_exit_status);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6231 defsubr (&Sprocess_id);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6232 defsubr (&Sprocess_name);
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
6233 defsubr (&Sprocess_tty_name);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6234 defsubr (&Sprocess_command);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6235 defsubr (&Sset_process_buffer);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6236 defsubr (&Sprocess_buffer);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6237 defsubr (&Sprocess_mark);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6238 defsubr (&Sset_process_filter);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6239 defsubr (&Sprocess_filter);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6240 defsubr (&Sset_process_sentinel);
16058
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
6241 defsubr (&Sprocess_sentinel);
6830
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
6242 defsubr (&Sset_process_window_size);
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6243 defsubr (&Sset_process_inherit_coding_system_flag);
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6244 defsubr (&Sprocess_inherit_coding_system_flag);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6245 defsubr (&Sset_process_query_on_exit_flag);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6246 defsubr (&Sprocess_query_on_exit_flag);
16058
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
6247 defsubr (&Sprocess_contact);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6248 defsubr (&Slist_processes);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6249 defsubr (&Sprocess_list);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6250 defsubr (&Sstart_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6251 #ifdef HAVE_SOCKETS
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6252 defsubr (&Sset_network_process_options);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6253 defsubr (&Smake_network_process);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6254 #endif /* HAVE_SOCKETS */
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6255 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6256 defsubr (&Sprocess_datagram_address);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6257 defsubr (&Sset_process_datagram_address);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6258 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6259 defsubr (&Saccept_process_output);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6260 defsubr (&Sprocess_send_region);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6261 defsubr (&Sprocess_send_string);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6262 defsubr (&Sinterrupt_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6263 defsubr (&Skill_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6264 defsubr (&Squit_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6265 defsubr (&Sstop_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6266 defsubr (&Scontinue_process);
24352
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
6267 defsubr (&Sprocess_running_child_p);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6268 defsubr (&Sprocess_send_eof);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6269 defsubr (&Ssignal_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6270 defsubr (&Swaiting_for_user_input_p);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6271 /* defsubr (&Sprocess_connection); */
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6272 defsubr (&Sset_process_coding_system);
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6273 defsubr (&Sprocess_coding_system);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6274 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6275
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6276
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6277 #else /* not subprocesses */
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6278
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6279 #include <sys/types.h>
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6280 #include <errno.h>
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6281
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6282 #include "lisp.h"
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6283 #include "systime.h"
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6284 #include "charset.h"
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6285 #include "coding.h"
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6286 #include "termopts.h"
12132
017f32786ed3 [!subprocesses]: Include sysselect.h.
Karl Heuer <kwzh@gnu.org>
parents: 11926
diff changeset
6287 #include "sysselect.h"
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6288
765
e4093444f9f8 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 692
diff changeset
6289 extern int frame_garbaged;
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6290
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6291 extern EMACS_TIME timer_check ();
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6292 extern int timers_run;
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6293
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6294 /* As described above, except assuming that there are no subprocesses:
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6295
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6296 Wait for timeout to elapse and/or keyboard input to be available.
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6297
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6298 time_limit is:
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6299 timeout in seconds, or
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6300 zero for no limit, or
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6301 -1 means gobble data immediately available but don't wait for any.
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6302
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
6303 read_kbd is a Lisp_Object:
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6304 0 to ignore keyboard input, or
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6305 1 to return when input is available, or
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6306 -1 means caller will actually read the input, so don't throw to
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6307 the quit handler.
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6308 a cons cell, meaning wait until its car is non-nil
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6309 (and gobble terminal input into the buffer if any arrives), or
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6310 We know that read_kbd will never be a Lisp_Process, since
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6311 `subprocesses' isn't defined.
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6312
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6313 do_display != 0 means redisplay should be done to show subprocess
6429
1dbe24a029fd (wait_reading_process_input, both versions): Don't call
Richard M. Stallman <rms@gnu.org>
parents: 6393
diff changeset
6314 output that arrives.
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6315
3591
507f64624555 Apply typo patches from Paul Eggert.
Jim Blandy <jimb@redhat.com>
parents: 3510
diff changeset
6316 Return true iff we received input from any process. */
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6317
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6318 int
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6319 wait_reading_process_input (time_limit, microsecs, read_kbd, do_display)
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
6320 int time_limit, microsecs;
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
6321 Lisp_Object read_kbd;
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
6322 int do_display;
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6323 {
22535
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6324 register int nfds;
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6325 EMACS_TIME end_time, timeout;
14278
3562c5f43780 (wait_reading_process_input) [not subprocesses]: Do
Karl Heuer <kwzh@gnu.org>
parents: 14186
diff changeset
6326 SELECT_TYPE waitchannels;
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6327 int xerrno;
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
6328 /* Either nil or a cons cell, the car of which is of interest and
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
6329 may be changed outside of this routine. */
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
6330 Lisp_Object wait_for_cell = Qnil;
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6331
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6332 /* If waiting for non-nil in a cell, record where. */
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6333 if (CONSP (read_kbd))
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6334 {
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
6335 wait_for_cell = read_kbd;
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6336 XSETFASTINT (read_kbd, 0);
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6337 }
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6338
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6339 /* What does time_limit really mean? */
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6340 if (time_limit || microsecs)
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6341 {
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6342 EMACS_GET_TIME (end_time);
22535
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6343 EMACS_SET_SECS_USECS (timeout, time_limit, microsecs);
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6344 EMACS_ADD_TIME (end_time, end_time, timeout);
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6345 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6346
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6347 /* Turn off periodic alarms (in case they are in use)
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6348 because the select emulator uses alarms. */
27430
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
6349 turn_on_atimers (0);
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6350
22535
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6351 while (1)
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6352 {
14802
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6353 int timeout_reduced_for_timers = 0;
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6354
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6355 /* If calling from keyboard input, do not quit
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6356 since we want to return C-g as an input character.
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6357 Otherwise, do pending quit if requested. */
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
6358 if (XINT (read_kbd) >= 0)
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6359 QUIT;
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6360
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6361 /* Exit now if the cell we're waiting for became non-nil. */
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
6362 if (! NILP (wait_for_cell) && ! NILP (XCAR (wait_for_cell)))
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6363 break;
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6364
14802
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6365 /* Compute time from now till when time limit is up */
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6366 /* Exit if already run out */
22535
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6367 if (time_limit == -1)
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6368 {
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6369 /* -1 specified for timeout means
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6370 gobble output available now
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6371 but don't wait at all. */
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6372
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6373 EMACS_SET_SECS_USECS (timeout, 0, 0);
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6374 }
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6375 else if (time_limit || microsecs)
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6376 {
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6377 EMACS_GET_TIME (timeout);
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6378 EMACS_SUB_TIME (timeout, end_time, timeout);
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6379 if (EMACS_TIME_NEG_P (timeout))
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6380 break;
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6381 }
22535
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6382 else
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6383 {
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6384 EMACS_SET_SECS_USECS (timeout, 100000, 0);
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6385 }
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6386
14802
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6387 /* If our caller will not immediately handle keyboard events,
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6388 run timer events directly.
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6389 (Callers that will immediately read keyboard events
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6390 call timer_delay on their own.) */
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
6391 if (NILP (wait_for_cell))
14802
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6392 {
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6393 EMACS_TIME timer_delay;
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6394
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6395 do
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6396 {
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6397 int old_timers_run = timers_run;
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6398 timer_delay = timer_check (1);
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6399 if (timers_run != old_timers_run && do_display)
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6400 /* We must retry, since a timer may have requeued itself
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6401 and that could alter the time delay. */
35336
002c02db42d3 Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents: 34660
diff changeset
6402 redisplay_preserve_echo_area (14);
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6403 else
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6404 break;
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6405 }
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6406 while (!detect_input_pending ());
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6407
22535
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6408 /* If there is unread keyboard input, also return. */
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6409 if (XINT (read_kbd) != 0
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6410 && requeued_events_pending_p ())
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6411 break;
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6412
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6413 if (! EMACS_TIME_NEG_P (timer_delay) && time_limit != -1)
14802
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6414 {
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6415 EMACS_TIME difference;
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6416 EMACS_SUB_TIME (difference, timer_delay, timeout);
14802
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6417 if (EMACS_TIME_NEG_P (difference))
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6418 {
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6419 timeout = timer_delay;
14802
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6420 timeout_reduced_for_timers = 1;
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6421 }
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6422 }
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6423 }
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6424
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6425 /* Cause C-g and alarm signals to take immediate action,
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6426 and cause input available signals to zero out timeout. */
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
6427 if (XINT (read_kbd) < 0)
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6428 set_waiting_for_input (&timeout);
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6429
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6430 /* Wait till there is something to do. */
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6431
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
6432 if (! XINT (read_kbd) && NILP (wait_for_cell))
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6433 FD_ZERO (&waitchannels);
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6434 else
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6435 FD_SET (0, &waitchannels);
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6436
765
e4093444f9f8 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 692
diff changeset
6437 /* If a frame has been newly mapped and needs updating,
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6438 reprocess its display stuff. */
6429
1dbe24a029fd (wait_reading_process_input, both versions): Don't call
Richard M. Stallman <rms@gnu.org>
parents: 6393
diff changeset
6439 if (frame_garbaged && do_display)
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6440 {
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6441 clear_waiting_for_input ();
35336
002c02db42d3 Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents: 34660
diff changeset
6442 redisplay_preserve_echo_area (15);
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6443 if (XINT (read_kbd) < 0)
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6444 set_waiting_for_input (&timeout);
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6445 }
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6446
15025
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6447 if (XINT (read_kbd) && detect_input_pending ())
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6448 {
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6449 nfds = 0;
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6450 FD_ZERO (&waitchannels);
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6451 }
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6452 else
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6453 nfds = select (1, &waitchannels, (SELECT_TYPE *)0, (SELECT_TYPE *)0,
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6454 &timeout);
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6455
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6456 xerrno = errno;
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6457
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6458 /* Make C-g and alarm signals set flags again */
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6459 clear_waiting_for_input ();
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6460
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6461 /* If we woke up due to SIGWINCH, actually change size now. */
25356
5db69f7aadca Call change_frame_size and do_pending_window_change with
Gerd Moellmann <gerd@gnu.org>
parents: 25262
diff changeset
6462 do_pending_window_change (0);
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6463
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6464 if (time_limit && nfds == 0 && ! timeout_reduced_for_timers)
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6465 /* We waited the full specified time, so return now. */
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6466 break;
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6467
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6468 if (nfds == -1)
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6469 {
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6470 /* If the system call was interrupted, then go around the
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6471 loop again. */
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6472 if (xerrno == EINTR)
14278
3562c5f43780 (wait_reading_process_input) [not subprocesses]: Do
Karl Heuer <kwzh@gnu.org>
parents: 14186
diff changeset
6473 FD_ZERO (&waitchannels);
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6474 else
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
6475 error ("select error: %s", emacs_strerror (xerrno));
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6476 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6477 #ifdef sun
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6478 else if (nfds > 0 && (waitchannels & 1) && interrupt_input)
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6479 /* System sometimes fails to deliver SIGIO. */
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6480 kill (getpid (), SIGIO);
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6481 #endif
3915
55ed7a65746e (wait_reading_process_input): Use SIGIO only if defined.
Richard M. Stallman <rms@gnu.org>
parents: 3826
diff changeset
6482 #ifdef SIGIO
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
6483 if (XINT (read_kbd) && interrupt_input && (waitchannels & 1))
14736
b17ec81a6294 (wait_reading_process_input): Use getpid when generating SIGIO.
Richard M. Stallman <rms@gnu.org>
parents: 14671
diff changeset
6484 kill (getpid (), SIGIO);
3915
55ed7a65746e (wait_reading_process_input): Use SIGIO only if defined.
Richard M. Stallman <rms@gnu.org>
parents: 3826
diff changeset
6485 #endif
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6486
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6487 /* Check for keyboard input */
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6488
37413
49147b9fe206 (wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents: 37398
diff changeset
6489 if ((XINT (read_kbd) != 0)
49147b9fe206 (wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents: 37398
diff changeset
6490 && detect_input_pending_run_timers (do_display))
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6491 {
37413
49147b9fe206 (wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents: 37398
diff changeset
6492 swallow_events (do_display);
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6493 if (detect_input_pending_run_timers (do_display))
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6494 break;
37413
49147b9fe206 (wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents: 37398
diff changeset
6495 }
49147b9fe206 (wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents: 37398
diff changeset
6496
22535
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6497 /* If there is unread keyboard input, also return. */
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6498 if (XINT (read_kbd) != 0
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6499 && requeued_events_pending_p ())
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6500 break;
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6501
15064
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6502 /* If wait_for_cell. check for keyboard input
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6503 but don't run any timers.
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6504 ??? (It seems wrong to me to check for keyboard
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6505 input at all when wait_for_cell, but the code
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6506 has been this way since July 1994.
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6507 Try changing this after version 19.31.) */
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
6508 if (! NILP (wait_for_cell)
15064
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6509 && detect_input_pending ())
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6510 {
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6511 swallow_events (do_display);
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6512 if (detect_input_pending ())
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6513 break;
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6514 }
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6515
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6516 /* Exit now if the cell we're waiting for became non-nil. */
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
6517 if (! NILP (wait_for_cell) && ! NILP (XCAR (wait_for_cell)))
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6518 break;
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6519 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6520
2120
fc3cdca22f8d * process.c (process_send_signal): In the TERMIOS code for sending
Jim Blandy <jimb@redhat.com>
parents: 1925
diff changeset
6521 start_polling ();
fc3cdca22f8d * process.c (process_send_signal): In the TERMIOS code for sending
Jim Blandy <jimb@redhat.com>
parents: 1925
diff changeset
6522
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6523 return 0;
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6524 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6525
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6526
39964
4ca5cbe5610d (process-inherit-coding-system-flag, get-buffer-process): Do not confuse
Pavel Janík <Pavel@Janik.cz>
parents: 39812
diff changeset
6527 /* Don't confuse make-docfile by having two doc strings for this function.
4ca5cbe5610d (process-inherit-coding-system-flag, get-buffer-process): Do not confuse
Pavel Janík <Pavel@Janik.cz>
parents: 39812
diff changeset
6528 make-docfile does not pay attention to #if, for good reason! */
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6529 DEFUN ("get-buffer-process", Fget_buffer_process, Sget_buffer_process, 1, 1, 0,
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6530 0)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6531 (name)
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6532 register Lisp_Object name;
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6533 {
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6534 return Qnil;
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6535 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6536
39964
4ca5cbe5610d (process-inherit-coding-system-flag, get-buffer-process): Do not confuse
Pavel Janík <Pavel@Janik.cz>
parents: 39812
diff changeset
6537 /* Don't confuse make-docfile by having two doc strings for this function.
4ca5cbe5610d (process-inherit-coding-system-flag, get-buffer-process): Do not confuse
Pavel Janík <Pavel@Janik.cz>
parents: 39812
diff changeset
6538 make-docfile does not pay attention to #if, for good reason! */
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6539 DEFUN ("process-inherit-coding-system-flag",
40103
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6540 Fprocess_inherit_coding_system_flag, Sprocess_inherit_coding_system_flag,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6541 1, 1, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6542 0)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6543 (process)
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6544 register Lisp_Object process;
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6545 {
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6546 /* Ignore the argument and return the value of
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6547 inherit-process-coding-system. */
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6548 return inherit_process_coding_system ? Qt : Qnil;
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6549 }
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6550
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6551 /* Kill all processes associated with `buffer'.
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6552 If `buffer' is nil, kill all processes.
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6553 Since we have no subprocesses, this does nothing. */
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6554
21414
aac7354edaed (kill_buffer_processes): Make consistent with
Karl Heuer <kwzh@gnu.org>
parents: 21281
diff changeset
6555 void
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6556 kill_buffer_processes (buffer)
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6557 Lisp_Object buffer;
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6558 {
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6559 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6560
21978
ba8852d809f6 (init_process, syms_of_process): Make definition consistent with
Eli Zaretskii <eliz@gnu.org>
parents: 21950
diff changeset
6561 void
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6562 init_process ()
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6563 {
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6564 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6565
21978
ba8852d809f6 (init_process, syms_of_process): Make definition consistent with
Eli Zaretskii <eliz@gnu.org>
parents: 21950
diff changeset
6566 void
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6567 syms_of_process ()
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6568 {
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6569 defsubr (&Sget_buffer_process);
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6570 defsubr (&Sprocess_inherit_coding_system_flag);
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6571 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6572
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6573
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6574 #endif /* not subprocesses */