annotate src/process.c @ 47980:5492d1831d2a

From Michael Albinus. * README: Target for Info file is `make info'. * files.texi (File Name Components): Fixed typos in `file-name-sans-extension'. (Magic File Names): Complete list of operations for magic file name handlers.
author Kai Großjohann <kgrossjo@eu.uu.net>
date Wed, 23 Oct 2002 09:34:45 +0000
parents 62a08cd28e83
children b30942bd85f3
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;
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
128 Lisp_Object Qlocal, Qdatagram;
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
129 Lisp_Object QCname, QCbuffer, QChost, QCservice, QCtype;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
130 Lisp_Object QClocal, QCremote, QCcoding;
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
131 Lisp_Object QCserver, QCnowait, QCnoquery, QCstop;
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
132 Lisp_Object QCsentinel, QClog, QCoptions;
8231
5226ed89c1a6 (Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8063
diff changeset
133 Lisp_Object Qlast_nonmenu_event;
44041
134644f94850 (QCfamily, QCfiler): Remove duplicate declaration and initialization.
Jason Rumney <jasonr@gnu.org>
parents: 44038
diff changeset
134 /* QCfamily is declared and initialized in xfaces.c,
134644f94850 (QCfamily, QCfiler): Remove duplicate declaration and initialization.
Jason Rumney <jasonr@gnu.org>
parents: 44038
diff changeset
135 QCfilter in keyboard.c. */
134644f94850 (QCfamily, QCfiler): Remove duplicate declaration and initialization.
Jason Rumney <jasonr@gnu.org>
parents: 44038
diff changeset
136 extern Lisp_Object QCfamily, QCfilter;
134644f94850 (QCfamily, QCfiler): Remove duplicate declaration and initialization.
Jason Rumney <jasonr@gnu.org>
parents: 44038
diff changeset
137
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
138 /* Qexit is declared and initialized in eval.c. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
139
44890
01b93e5e53a7 Patch for building Emacs on Mac OS X. April 26, 2002. See ChangeLog,
Andrew Choi <akochoi@shaw.ca>
parents: 44372
diff changeset
140 /* QCfamily is defined in xfaces.c. */
01b93e5e53a7 Patch for building Emacs on Mac OS X. April 26, 2002. See ChangeLog,
Andrew Choi <akochoi@shaw.ca>
parents: 44372
diff changeset
141 extern Lisp_Object QCfamily;
01b93e5e53a7 Patch for building Emacs on Mac OS X. April 26, 2002. See ChangeLog,
Andrew Choi <akochoi@shaw.ca>
parents: 44372
diff changeset
142 /* QCfilter is defined in keyboard.c. */
01b93e5e53a7 Patch for building Emacs on Mac OS X. April 26, 2002. See ChangeLog,
Andrew Choi <akochoi@shaw.ca>
parents: 44372
diff changeset
143 extern Lisp_Object QCfilter;
01b93e5e53a7 Patch for building Emacs on Mac OS X. April 26, 2002. See ChangeLog,
Andrew Choi <akochoi@shaw.ca>
parents: 44372
diff changeset
144
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
145 /* 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
146 Qt nor Qnil but is instead a cons cell (HOSTNAME PORTNUM). */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
147
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
148 #ifdef HAVE_SOCKETS
16058
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
149 #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
150 #define NETCONN1_P(p) (GC_CONSP ((p)->childp))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
151 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
152 #define NETCONN_P(p) 0
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
153 #define NETCONN1_P(p) 0
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
154 #endif /* HAVE_SOCKETS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
155
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
156 /* Define first descriptor number available for subprocesses. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
157 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
158 #define FIRST_PROC_DESC 1
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
159 #else /* Not VMS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
160 #define FIRST_PROC_DESC 3
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
161 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
162
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
163 /* Define SIGCHLD as an alias for SIGCLD. There are many conditionals
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
164 testing SIGCHLD. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
165
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
166 #if !defined (SIGCHLD) && defined (SIGCLD)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
167 #define SIGCHLD SIGCLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
168 #endif /* SIGCLD */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
169
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
170 #include "syssignal.h"
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
171
4639
76f242eb1fa8 Include syswait.h.
Richard M. Stallman <rms@gnu.org>
parents: 4320
diff changeset
172 #include "syswait.h"
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
173
25770
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
174 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
175
31099
0fe5afca71e4 Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents: 30582
diff changeset
176 #ifndef USE_CRT_DLL
5543
dbc1d920ef5c Don't declare sys_nerr.
Roland McGrath <roland@gnu.org>
parents: 5534
diff changeset
177 extern int errno;
31099
0fe5afca71e4 Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents: 30582
diff changeset
178 #endif
5543
dbc1d920ef5c Don't declare sys_nerr.
Roland McGrath <roland@gnu.org>
parents: 5534
diff changeset
179 #ifdef VMS
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
180 extern char *sys_errlist[];
5543
dbc1d920ef5c Don't declare sys_nerr.
Roland McGrath <roland@gnu.org>
parents: 5534
diff changeset
181 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
182
8331
14ddb4c66461 [!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents: 8287
diff changeset
183 #ifndef HAVE_H_ERRNO
14ddb4c66461 [!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents: 8287
diff changeset
184 extern int h_errno;
14ddb4c66461 [!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents: 8287
diff changeset
185 #endif
14ddb4c66461 [!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents: 8287
diff changeset
186
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
187 /* t means use pty, nil means use a pipe,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
188 maybe other values to come. */
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
189 static Lisp_Object Vprocess_connection_type;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
190
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
191 #ifdef SKTPAIR
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
192 #ifndef HAVE_SOCKETS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
193 #include <sys/socket.h>
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
194 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
195 #endif /* SKTPAIR */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
196
10548
dcae4394587d (process_tick, update_tick): Make non-static.
Karl Heuer <kwzh@gnu.org>
parents: 10527
diff changeset
197 /* 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
198 emulation of `select'. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
199 /* 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
200 int process_tick;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
201 /* 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
202 int update_tick;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
203
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
204 /* 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
205
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
206 #ifdef BROKEN_NON_BLOCKING_CONNECT
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
207 #undef NON_BLOCKING_CONNECT
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
208 #else
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
209 #ifndef NON_BLOCKING_CONNECT
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
210 #ifdef HAVE_SOCKETS
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
211 #ifdef HAVE_SELECT
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
212 #if defined (HAVE_GETPEERNAME) || defined (GNU_LINUX)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
213 #if defined (O_NONBLOCK) || defined (O_NDELAY)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
214 #if defined (EWOULDBLOCK) || defined (EINPROGRESS)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
215 #define NON_BLOCKING_CONNECT
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
216 #endif /* EWOULDBLOCK || EINPROGRESS */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
217 #endif /* O_NONBLOCK || O_NDELAY */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
218 #endif /* HAVE_GETPEERNAME || GNU_LINUX */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
219 #endif /* HAVE_SELECT */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
220 #endif /* HAVE_SOCKETS */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
221 #endif /* NON_BLOCKING_CONNECT */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
222 #endif /* BROKEN_NON_BLOCKING_CONNECT */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
223
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
224 /* 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
225 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
226 "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
227 or emulation of select using FIONREAD. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
228
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
229 #ifdef BROKEN_DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
230 #undef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
231 #else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
232 #ifndef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
233 #ifdef HAVE_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
234 #if defined (HAVE_SELECT) || defined (FIONREAD)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
235 #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
236 #define DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
237 #endif /* HAVE_SENDTO && HAVE_RECVFROM && EMSGSIZE */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
238 #endif /* HAVE_SELECT || FIONREAD */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
239 #endif /* HAVE_SOCKETS */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
240 #endif /* DATAGRAM_SOCKETS */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
241 #endif /* BROKEN_DATAGRAM_SOCKETS */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
242
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
243 #ifdef TERM
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
244 #undef NON_BLOCKING_CONNECT
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
245 #undef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
246 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
247
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
248
10527
68b8191091a7 #include sysselect.h instead of defining things by hand.
Karl Heuer <kwzh@gnu.org>
parents: 10032
diff changeset
249 #include "sysselect.h"
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
250
25770
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
251 extern int keyboard_bit_set P_ ((SELECT_TYPE *));
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
252
13414
b035c6e41457 [HAVE_NTGUI] (POLL_FOR_INPUT): Define macro.
Geoff Voelker <voelker@cs.washington.edu>
parents: 13159
diff changeset
253 /* 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
254 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
255 #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
256 #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
257 #endif
cfe4840ffde9 (Fopen_network_stream): Call bind_polling_period; later unbind the binding.
Richard M. Stallman <rms@gnu.org>
parents: 7454
diff changeset
258
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
259 /* Mask of bits indicating the descriptors that we wait for input on. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
260
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
261 static SELECT_TYPE input_wait_mask;
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
262
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
263 /* Mask that excludes keyboard input descriptor (s). */
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
264
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
265 static SELECT_TYPE non_keyboard_wait_mask;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
266
17224
dd2545e79add (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 17110
diff changeset
267 /* 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
268
dd2545e79add (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 17110
diff changeset
269 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
270
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
271 /* 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
272 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
273 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
274
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
275 static SELECT_TYPE connect_wait_mask;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
276
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
277 /* Number of bits set in connect_wait_mask. */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
278 static int num_pending_connects;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
279
7044
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
280 /* 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
281 static int max_process_desc;
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
282
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
283 /* 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
284 static int max_keyboard_desc;
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
285
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
286 /* 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
287 static int delete_exited_processes;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
288
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
289 /* 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
290 Lisp_Object chan_process[MAXDESC];
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
291
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
292 /* Alist of elements (NAME . PROCESS) */
6164
d047d5a48e0e (chan_process, Vprocess_alist): No longer static.
Richard M. Stallman <rms@gnu.org>
parents: 6158
diff changeset
293 Lisp_Object Vprocess_alist;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
294
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
295 /* Buffered-ahead input char from process, indexed by channel.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
296 -1 means empty (no char is buffered).
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
297 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
298 output from the process is to read at least one char.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
299 Always -1 on systems that support FIONREAD. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
300
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
301 /* 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
302 int proc_buffered_char[MAXDESC];
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
303
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
304 /* 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
305 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
306 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
307
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
308 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
309 /* Table of `partner address' for datagram sockets. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
310 struct sockaddr_and_len {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
311 struct sockaddr *sa;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
312 int len;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
313 } datagram_address[MAXDESC];
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
314 #define DATAGRAM_CHAN_P(chan) (datagram_address[chan].sa != 0)
44314
f76a1425eb34 (DATAGRAM_CONN_P, list_processes_1)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44194
diff changeset
315 #define DATAGRAM_CONN_P(proc) (PROCESSP (proc) && datagram_address[XINT (XPROCESS (proc)->infd)].sa != 0)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
316 #else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
317 #define DATAGRAM_CHAN_P(chan) (0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
318 #define DATAGRAM_CONN_P(proc) (0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
319 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
320
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
321 static Lisp_Object get_process ();
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
322 static void exec_sentinel ();
6158
6b81b2575071 Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 5891
diff changeset
323
14404
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
324 extern EMACS_TIME timer_check ();
14785
e4a9806c1e83 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14758
diff changeset
325 extern int timers_run;
14404
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
326
6158
6b81b2575071 Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 5891
diff changeset
327 /* 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
328 static int pty_max_bytes;
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
329
21049
01e626b0a624 (Vdefault_file_name_coding_system): Extern it.
Kenichi Handa <handa@m17n.org>
parents: 20715
diff changeset
330 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
331
11609
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
332 #ifdef HAVE_PTYS
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
333 /* 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
334
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
335 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
336 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
337
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
338 /* Compute the Lisp form of the process status, p->status, from
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
339 the numeric status that was returned by `wait'. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
340
1522
19ccf004b172 * process.c: (status_convert): Declare this to return a
Jim Blandy <jimb@redhat.com>
parents: 1323
diff changeset
341 Lisp_Object status_convert ();
19ccf004b172 * process.c: (status_convert): Declare this to return a
Jim Blandy <jimb@redhat.com>
parents: 1323
diff changeset
342
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
343 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
344 update_status (p)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
345 struct Lisp_Process *p;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
346 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
347 union { int i; WAITTYPE wt; } u;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
348 u.i = XFASTINT (p->raw_status_low) + (XFASTINT (p->raw_status_high) << 16);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
349 p->status = status_convert (u.wt);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
350 p->raw_status_low = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
351 p->raw_status_high = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
352 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
353
3608
Jim Blandy <jimb@redhat.com>
parents: 3593
diff changeset
354 /* Convert a process status word in Unix format to
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
355 the list that we use internally. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
356
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
357 Lisp_Object
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
358 status_convert (w)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
359 WAITTYPE w;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
360 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
361 if (WIFSTOPPED (w))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
362 return Fcons (Qstop, Fcons (make_number (WSTOPSIG (w)), Qnil));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
363 else if (WIFEXITED (w))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
364 return Fcons (Qexit, Fcons (make_number (WRETCODE (w)),
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
365 WCOREDUMP (w) ? Qt : Qnil));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
366 else if (WIFSIGNALED (w))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
367 return Fcons (Qsignal, Fcons (make_number (WTERMSIG (w)),
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
368 WCOREDUMP (w) ? Qt : Qnil));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
369 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
370 return Qrun;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
371 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
372
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
373 /* Given a status-list, extract the three pieces of information
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
374 and store them individually through the three pointers. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
375
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
376 void
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
377 decode_status (l, symbol, code, coredump)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
378 Lisp_Object l;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
379 Lisp_Object *symbol;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
380 int *code;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
381 int *coredump;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
382 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
383 Lisp_Object tem;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
384
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
385 if (SYMBOLP (l))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
386 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
387 *symbol = l;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
388 *code = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
389 *coredump = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
390 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
391 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
392 {
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
393 *symbol = XCAR (l);
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
394 tem = XCDR (l);
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
395 *code = XFASTINT (XCAR (tem));
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
396 tem = XCDR (tem);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
397 *coredump = !NILP (tem);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
398 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
399 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
400
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
401 /* Return a string describing a process status list. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
402
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
403 Lisp_Object
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
404 status_message (status)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
405 Lisp_Object status;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
406 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
407 Lisp_Object symbol;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
408 int code, coredump;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
409 Lisp_Object string, string2;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
410
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
411 decode_status (status, &symbol, &code, &coredump);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
412
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
413 if (EQ (symbol, Qsignal) || EQ (symbol, Qstop))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
414 {
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
415 char *signame;
26526
b7438760079b * callproc.c (strerror): Remove decl.
Paul Eggert <eggert@twinsun.com>
parents: 26313
diff changeset
416 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
417 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
418 if (signame == 0)
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
419 signame = "unknown";
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
420 string = build_string (signame);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
421 string2 = build_string (coredump ? " (core dumped)\n" : "\n");
46431
db28853d1e82 * process.c (status_message): Use SSET.
Ken Raeburn <raeburn@raeburn.org>
parents: 46411
diff changeset
422 SSET (string, 0, DOWNCASE (SREF (string, 0)));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
423 return concat2 (string, string2);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
424 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
425 else if (EQ (symbol, Qexit))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
426 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
427 if (code == 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
428 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
429 string = Fnumber_to_string (make_number (code));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
430 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
431 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
432 string, string2);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
433 }
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
434 else if (EQ (symbol, Qfailed))
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
435 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
436 string = Fnumber_to_string (make_number (code));
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
437 string2 = build_string ("\n");
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
438 return concat3 (build_string ("failed with code "),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
439 string, string2);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
440 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
441 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
442 return Fcopy_sequence (Fsymbol_name (symbol));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
443 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
444
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
445 #ifdef HAVE_PTYS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
446
11609
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
447 /* 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
448 Return -1 on failure.
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
449 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
450 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
451
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
452 int
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
453 allocate_pty ()
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
454 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
455 struct stat stb;
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
456 register int c, i;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
457 int fd;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
458
624
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
459 /* Some systems name their pseudoterminals so that there are gaps in
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
460 the usual sequence - for example, on HP9000/S700 systems, there
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
461 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
462 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
463 end of the ptys. */
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
464 int failed_count = 0;
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
465
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
466 #ifdef PTY_ITERATION
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
467 PTY_ITERATION
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
468 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
469 for (c = FIRST_PTY_LETTER; c <= 'z'; c++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
470 for (i = 0; i < 16; i++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
471 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
472 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
473 #ifdef PTY_NAME_SPRINTF
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
474 PTY_NAME_SPRINTF
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
475 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
476 sprintf (pty_name, "/dev/pty%c%x", c, i);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
477 #endif /* no PTY_NAME_SPRINTF */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
478
822
c6e94e13926c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 808
diff changeset
479 #ifdef PTY_OPEN
c6e94e13926c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 808
diff changeset
480 PTY_OPEN;
c6e94e13926c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 808
diff changeset
481 #else /* no PTY_OPEN */
624
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
482 #ifdef IRIS
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
483 /* 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
484 *ptyv = emacs_open ("/dev/ptc", O_RDWR | O_NDELAY, 0);
624
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
485 if (fd < 0)
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
486 return -1;
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
487 if (fstat (fd, &stb) < 0)
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
488 return -1;
822
c6e94e13926c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 808
diff changeset
489 #else /* not IRIS */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
490 if (stat (pty_name, &stb) < 0)
624
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
491 {
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
492 failed_count++;
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
493 if (failed_count >= 3)
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
494 return -1;
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
495 }
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
496 else
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
497 failed_count = 0;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
498 #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
499 fd = emacs_open (pty_name, O_RDWR | O_NONBLOCK, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
500 #else
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
501 fd = emacs_open (pty_name, O_RDWR | O_NDELAY, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
502 #endif
822
c6e94e13926c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 808
diff changeset
503 #endif /* not IRIS */
c6e94e13926c *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 808
diff changeset
504 #endif /* no PTY_OPEN */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
505
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
506 if (fd >= 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
507 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
508 /* check to make certain that both sides are available
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
509 this avoids a nasty yet stupid bug in rlogins */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
510 #ifdef PTY_TTY_NAME_SPRINTF
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
511 PTY_TTY_NAME_SPRINTF
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 sprintf (pty_name, "/dev/tty%c%x", c, i);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
514 #endif /* no PTY_TTY_NAME_SPRINTF */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
515 #ifndef UNIPLUS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
516 if (access (pty_name, 6) != 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
517 {
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
518 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
519 #if !defined(IRIS) && !defined(__sgi)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
520 continue;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
521 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
522 return -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
523 #endif /* IRIS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
524 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
525 #endif /* not UNIPLUS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
526 setup_pty (fd);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
527 return fd;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
528 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
529 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
530 return -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
531 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
532 #endif /* HAVE_PTYS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
533
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
534 Lisp_Object
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
535 make_process (name)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
536 Lisp_Object name;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
537 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
538 register Lisp_Object val, tem, name1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
539 register struct Lisp_Process *p;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
540 char suffix[10];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
541 register int i;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
542
36434
40cfe4976f04 (make_process): Use allocate_process.
Gerd Moellmann <gerd@gnu.org>
parents: 35336
diff changeset
543 p = allocate_process ();
9969
007d93b04e1f (make_process): Use allocate_vectorlike and VECSIZE.
Karl Heuer <kwzh@gnu.org>
parents: 9952
diff changeset
544
9277
21f6120be5ba (make_process, create_process, Fopen_network_stream, deactivate_process,
Karl Heuer <kwzh@gnu.org>
parents: 9115
diff changeset
545 XSETINT (p->infd, -1);
21f6120be5ba (make_process, create_process, Fopen_network_stream, deactivate_process,
Karl Heuer <kwzh@gnu.org>
parents: 9115
diff changeset
546 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
547 XSETFASTINT (p->pid, 0);
a14cc1712337 (make_process, list_processes_1, create_process, Faccept_process_output,
Karl Heuer <kwzh@gnu.org>
parents: 9277
diff changeset
548 XSETFASTINT (p->tick, 0);
a14cc1712337 (make_process, list_processes_1, create_process, Faccept_process_output,
Karl Heuer <kwzh@gnu.org>
parents: 9277
diff changeset
549 XSETFASTINT (p->update_tick, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
550 p->raw_status_low = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
551 p->raw_status_high = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
552 p->status = Qrun;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
553 p->mark = Fmake_marker ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
554
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
555 /* If name is already in use, modify it until it is unused. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
556
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
557 name1 = name;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
558 for (i = 1; ; i++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
559 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
560 tem = Fget_process (name1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
561 if (NILP (tem)) break;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
562 sprintf (suffix, "<%d>", i);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
563 name1 = concat2 (name, build_string (suffix));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
564 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
565 name = name1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
566 p->name = name;
9969
007d93b04e1f (make_process): Use allocate_vectorlike and VECSIZE.
Karl Heuer <kwzh@gnu.org>
parents: 9952
diff changeset
567 XSETPROCESS (val, p);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
568 Vprocess_alist = Fcons (Fcons (name, val), Vprocess_alist);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
569 return val;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
570 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
571
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
572 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
573 remove_process (proc)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
574 register Lisp_Object proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
575 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
576 register Lisp_Object pair;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
577
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
578 pair = Frassq (proc, Vprocess_alist);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
579 Vprocess_alist = Fdelq (pair, Vprocess_alist);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
580
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
581 deactivate_process (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
582 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
583
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
584 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
585 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
586 (object)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
587 Lisp_Object object;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
588 {
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
589 return PROCESSP (object) ? Qt : Qnil;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
590 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
591
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
592 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
593 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
594 (name)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
595 register Lisp_Object name;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
596 {
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
597 if (PROCESSP (name))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
598 return name;
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
599 CHECK_STRING (name);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
600 return Fcdr (Fassoc (name, Vprocess_alist));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
601 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
602
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
603 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
604 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
605 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
606 (buffer)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
607 register Lisp_Object buffer;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
608 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
609 register Lisp_Object buf, tail, proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
610
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
611 if (NILP (buffer)) return Qnil;
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
612 buf = Fget_buffer (buffer);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
613 if (NILP (buf)) return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
614
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
615 for (tail = Vprocess_alist; !NILP (tail); tail = Fcdr (tail))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
616 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
617 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
618 if (PROCESSP (proc) && EQ (XPROCESS (proc)->buffer, buf))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
619 return proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
620 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
621 return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
622 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
623
808
707866b2a190 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 765
diff changeset
624 /* This is how commands for the user decode process arguments. It
707866b2a190 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 765
diff changeset
625 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
626 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
627 current buffer. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
628
4994
4146a65b9f02 (get_process): Add `static' to definition.
Richard M. Stallman <rms@gnu.org>
parents: 4914
diff changeset
629 static Lisp_Object
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
630 get_process (name)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
631 register Lisp_Object name;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
632 {
6313
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
633 register Lisp_Object proc, obj;
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
634 if (STRINGP (name))
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
635 {
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
636 obj = Fget_process (name);
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
637 if (NILP (obj))
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
638 obj = Fget_buffer (name);
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
639 if (NILP (obj))
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
640 error ("Process %s does not exist", SDATA (name));
6313
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 else if (NILP (name))
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
643 obj = Fcurrent_buffer ();
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
644 else
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
645 obj = name;
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
646
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
647 /* 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
648 */
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
649 if (BUFFERP (obj))
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
650 {
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
651 proc = Fget_buffer_process (obj);
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
652 if (NILP (proc))
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
653 error ("Buffer %s has no process", SDATA (XBUFFER (obj)->name));
6313
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
654 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
655 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
656 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
657 CHECK_PROCESS (obj);
6313
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
658 proc = obj;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
659 }
6313
9a6531e6de5d (get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents: 6253
diff changeset
660 return proc;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
661 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
662
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
663 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
664 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
665 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
666 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
667 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
668 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
669 {
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
670 process = get_process (process);
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
671 XPROCESS (process)->raw_status_low = Qnil;
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
672 XPROCESS (process)->raw_status_high = Qnil;
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
673 if (NETCONN_P (process))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
674 {
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
675 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
676 XSETINT (XPROCESS (process)->tick, ++process_tick);
578
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 else if (XINT (XPROCESS (process)->infd) >= 0)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
679 {
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
680 Fkill_process (process, Qnil);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
681 /* 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
682 XPROCESS (process)->status
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
683 = 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
684 XSETINT (XPROCESS (process)->tick, ++process_tick);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
685 status_notify ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
686 }
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
687 remove_process (process);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
688 return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
689 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
690
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
691 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
692 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
693 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
694 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
695 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
696 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
697 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
698 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
699 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
700 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
701 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
702 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
703 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
704 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
705 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
706 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
707 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
708 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
709 register struct Lisp_Process *p;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
710 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
711
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
712 if (STRINGP (process))
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
713 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
714 else
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
715 process = get_process (process);
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
716
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
717 if (NILP (process))
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
718 return process;
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
719
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
720 p = XPROCESS (process);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
721 if (!NILP (p->raw_status_low))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
722 update_status (p);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
723 status = p->status;
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
724 if (CONSP (status))
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
725 status = XCAR (status);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
726 if (NETCONN1_P (p))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
727 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
728 if (EQ (status, Qexit))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
729 status = Qclosed;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
730 else if (EQ (p->command, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
731 status = Qstop;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
732 else if (EQ (status, Qrun))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
733 status = Qopen;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
734 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
735 return status;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
736 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
737
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
738 DEFUN ("process-exit-status", Fprocess_exit_status, Sprocess_exit_status,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
739 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
740 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
741 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
742 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
743 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
744 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
745 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
746 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
747 update_status (XPROCESS (process));
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
748 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
749 return XCAR (XCDR (XPROCESS (process)->status));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
750 return make_number (0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
751 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
752
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
753 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
754 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
755 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
756 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
757 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
758 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
759 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
760 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
761 return XPROCESS (process)->pid;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
762 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
763
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
764 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
765 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
766 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
767 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
768 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
769 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
770 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
771 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
772 return XPROCESS (process)->name;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
773 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
774
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
775 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
776 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
777 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
778 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
779 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
780 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
781 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
782 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
783 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
784 return XPROCESS (process)->command;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
785 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
786
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
787 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
788 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
789 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
790 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
791 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
792 register Lisp_Object process;
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
793 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
794 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
795 return XPROCESS (process)->tty_name;
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
796 }
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
797
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
798 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
799 2, 2, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
800 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
801 (process, buffer)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
802 register Lisp_Object process, buffer;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
803 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
804 struct Lisp_Process *p;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
805
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
806 CHECK_PROCESS (process);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
807 if (!NILP (buffer))
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
808 CHECK_BUFFER (buffer);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
809 p = XPROCESS (process);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
810 p->buffer = buffer;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
811 if (NETCONN1_P (p))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
812 p->childp = Fplist_put (p->childp, QCbuffer, buffer);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
813 return buffer;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
814 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
815
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
816 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
817 1, 1, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
818 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
819 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
820 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
821 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
822 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
823 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
824 return XPROCESS (process)->buffer;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
825 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
826
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
827 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
828 1, 1, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
829 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
830 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
831 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
832 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
833 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
834 return XPROCESS (process)->mark;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
835 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
836
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
837 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
838 2, 2, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
839 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
840 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
841 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
842 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
843 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
844 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
845 (process, filter)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
846 register Lisp_Object process, filter;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
847 {
36623
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
848 struct Lisp_Process *p;
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
849
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
850 CHECK_PROCESS (process);
36623
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
851 p = XPROCESS (process);
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
852
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
853 /* 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
854 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
855 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
856
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
857 (setq process (start-process ...))
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
858 (debug)
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
859 (set-process-filter process ...) */
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
860
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
861 if (XINT (p->infd) >= 0)
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
862 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
863 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
864 {
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
865 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
866 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
867 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
868 else if (EQ (p->filter, Qt)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
869 && !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
870 {
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
871 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
872 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
873 }
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
874 }
36623
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
875
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
876 p->filter = filter;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
877 if (NETCONN1_P (p))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
878 p->childp = Fplist_put (p->childp, QCfilter, filter);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
879 return filter;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
880 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
881
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
882 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
883 1, 1, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
884 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
885 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
886 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
887 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
888 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
889 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
890 return XPROCESS (process)->filter;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
891 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
892
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
893 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
894 2, 2, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
895 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
896 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
897 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
898 (process, sentinel)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
899 register Lisp_Object process, sentinel;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
900 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
901 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
902 XPROCESS (process)->sentinel = sentinel;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
903 return sentinel;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
904 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
905
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
906 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
907 1, 1, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
908 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
909 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
910 (process)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
911 register Lisp_Object process;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
912 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
913 CHECK_PROCESS (process);
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
914 return XPROCESS (process)->sentinel;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
915 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
916
6830
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
917 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
918 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
919 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
920 (process, height, width)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
921 register Lisp_Object process, height, width;
6830
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
922 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
923 CHECK_PROCESS (process);
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
924 CHECK_NATNUM (height);
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
925 CHECK_NATNUM (width);
36623
9fde2182c68a (Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents: 36434
diff changeset
926
36659
c1c5ad73f700 (Fset_process_window_size): Fix a typo.
Gerd Moellmann <gerd@gnu.org>
parents: 36623
diff changeset
927 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
928 || 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
929 XINT (height), XINT (width)) <= 0)
6830
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
930 return Qnil;
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
931 else
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
932 return Qt;
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
933 }
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
934
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
935 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
936 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
937 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
938 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
939 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
940 `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
941 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
942 the process output.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
943
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
944 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
945 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
946 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
947 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
948
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
949 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
950 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
951 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
952 (process, flag)
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
953 register Lisp_Object process, flag;
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
954 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
955 CHECK_PROCESS (process);
21848
050ea21cec87 (Fset_process_inherit_coding_system_flag, Fstart_process):
Richard M. Stallman <rms@gnu.org>
parents: 21798
diff changeset
956 XPROCESS (process)->inherit_coding_system_flag = flag;
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
957 return flag;
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
958 }
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
959
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
960 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
961 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
962 1, 1, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
963 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
964 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
965 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
966 the process output. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
967 (process)
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
968 register Lisp_Object process;
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
969 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
970 CHECK_PROCESS (process);
21848
050ea21cec87 (Fset_process_inherit_coding_system_flag, Fstart_process):
Richard M. Stallman <rms@gnu.org>
parents: 21798
diff changeset
971 return XPROCESS (process)->inherit_coding_system_flag;
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
972 }
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
973
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
974 DEFUN ("set-process-query-on-exit-flag",
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
975 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
976 2, 2, 0,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
977 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
978 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
979 exiting if PROCESS is running. */)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
980 (process, flag)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
981 register Lisp_Object process, flag;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
982 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
983 CHECK_PROCESS (process);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
984 XPROCESS (process)->kill_without_query = Fnull (flag);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
985 return flag;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
986 }
4231
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
987
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
988 DEFUN ("process-query-on-exit-flag",
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
989 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
990 1, 1, 0,
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
991 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
992 (process)
16058
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
993 register Lisp_Object process;
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
994 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
995 CHECK_PROCESS (process);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
996 return Fnull (XPROCESS (process)->kill_without_query);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
997 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
998
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
999 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1000 Lisp_Object Fprocess_datagram_address ();
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1001 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1002
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1003 DEFUN ("process-contact", Fprocess_contact, Sprocess_contact,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1004 1, 2, 0,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1005 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
1006 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
1007 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
1008 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
1009 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
1010 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
1011 (process, key)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1012 register Lisp_Object process, key;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1013 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1014 Lisp_Object contact;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1015
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1016 CHECK_PROCESS (process);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1017 contact = XPROCESS (process)->childp;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1018
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1019 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1020 if (DATAGRAM_CONN_P (process)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1021 && (EQ (key, Qt) || EQ (key, QCremote)))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1022 contact = Fplist_put (contact, QCremote,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1023 Fprocess_datagram_address (process));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1024 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1025
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1026 if (!NETCONN_P (process) || EQ (key, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1027 return contact;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1028 if (NILP (key))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1029 return Fcons (Fplist_get (contact, QChost),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1030 Fcons (Fplist_get (contact, QCservice), Qnil));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1031 return Fplist_get (contact, key);
16058
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
1032 }
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
1033
4231
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1034 #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
1035 in the process. Perhaps add it. */
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1036 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
1037 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
1038 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
1039 a socket connection. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1040 (process)
4231
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1041 Lisp_Object process;
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1042 {
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1043 return XPROCESS (process)->type;
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1044 }
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
1045 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1046
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1047 Lisp_Object
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1048 list_processes_1 (query_only)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1049 Lisp_Object query_only;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1050 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1051 register Lisp_Object tail, tem;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1052 Lisp_Object proc, minspace, tem1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1053 register struct Lisp_Process *p;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1054 char tembuf[300];
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1055 int w_proc, w_buffer, w_tty;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1056 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
1057
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1058 w_proc = 4; /* Proc */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1059 w_buffer = 6; /* Buffer */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1060 w_tty = 0; /* Omit if no ttys */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1061
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1062 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
1063 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1064 int i;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1065
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1066 proc = Fcdr (Fcar (tail));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1067 p = XPROCESS (proc);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1068 if (NILP (p->childp))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1069 continue;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1070 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
1071 continue;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1072 if (STRINGP (p->name)
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
1073 && ( i = SCHARS (p->name), (i > w_proc)))
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1074 w_proc = i;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1075 if (!NILP (p->buffer))
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 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
1078 w_buffer = 8; /* (Killed) */
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
1079 else if ((i = SCHARS (XBUFFER (p->buffer)->name), (i > w_buffer)))
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1080 w_buffer = i;
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 if (STRINGP (p->tty_name)
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
1083 && (i = SCHARS (p->tty_name), (i > w_tty)))
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1084 w_tty = i;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1085 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1086
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1087 XSETFASTINT (i_status, w_proc + 1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1088 XSETFASTINT (i_buffer, XFASTINT (i_status) + 9);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1089 if (w_tty)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1090 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1091 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
1092 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
1093 } else {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1094 i_tty = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1095 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
1096 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1097
9318
a14cc1712337 (make_process, list_processes_1, create_process, Faccept_process_output,
Karl Heuer <kwzh@gnu.org>
parents: 9277
diff changeset
1098 XSETFASTINT (minspace, 1);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1099
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1100 set_buffer_internal (XBUFFER (Vstandard_output));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1101 Fbuffer_disable_undo (Vstandard_output);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1102
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1103 current_buffer->truncate_lines = Qt;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1104
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1105 write_string ("Proc", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1106 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
1107 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
1108 if (!NILP (i_tty))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1109 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1110 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
1111 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1112 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
1113 write_string ("\n", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1114
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1115 write_string ("----", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1116 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
1117 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
1118 if (!NILP (i_tty))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1119 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1120 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
1121 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1122 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
1123 write_string ("\n", -1);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1124
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1125 for (tail = Vprocess_alist; !NILP (tail); tail = Fcdr (tail))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1126 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1127 Lisp_Object symbol;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1128
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1129 proc = Fcdr (Fcar (tail));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1130 p = XPROCESS (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1131 if (NILP (p->childp))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1132 continue;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1133 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
1134 continue;
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 Finsert (1, &p->name);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1137 Findent_to (i_status, minspace);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1138
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1139 if (!NILP (p->raw_status_low))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1140 update_status (p);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1141 symbol = p->status;
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
1142 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
1143 symbol = XCAR (p->status);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1144
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1145
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1146 if (EQ (symbol, Qsignal))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1147 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1148 Lisp_Object tem;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1149 tem = Fcar (Fcdr (p->status));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1150 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1151 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
1152 write_string (sys_errlist [XINT (tem)], -1);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1153 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1154 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1155 Fprinc (symbol, Qnil);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1156 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1157 else if (NETCONN1_P (p))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1158 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1159 if (EQ (symbol, Qexit))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1160 write_string ("closed", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1161 else if (EQ (p->command, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1162 write_string ("stopped", -1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1163 else if (EQ (symbol, Qrun))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1164 write_string ("open", -1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1165 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1166 Fprinc (symbol, Qnil);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1167 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1168 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1169 Fprinc (symbol, Qnil);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1170
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1171 if (EQ (symbol, Qexit))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1172 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1173 Lisp_Object tem;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1174 tem = Fcar (Fcdr (p->status));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1175 if (XFASTINT (tem))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1176 {
11695
0f9b9c375416 (list_processes_1): Cast XFASTINT for passing to sprintf.
Richard M. Stallman <rms@gnu.org>
parents: 11609
diff changeset
1177 sprintf (tembuf, " %d", (int) XFASTINT (tem));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1178 write_string (tembuf, -1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1179 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1180 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1181
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1182 if (EQ (symbol, Qsignal) || EQ (symbol, Qexit))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1183 remove_process (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1184
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1185 Findent_to (i_buffer, minspace);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1186 if (NILP (p->buffer))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1187 insert_string ("(none)");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1188 else if (NILP (XBUFFER (p->buffer)->name))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1189 insert_string ("(Killed)");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1190 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1191 Finsert (1, &XBUFFER (p->buffer)->name);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1192
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1193 if (!NILP (i_tty))
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 Findent_to (i_tty, minspace);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1196 if (STRINGP (p->tty_name))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1197 Finsert (1, &p->tty_name);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1198 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1199
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1200 Findent_to (i_command, minspace);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1201
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1202 if (EQ (p->status, Qlisten))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1203 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1204 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
1205 if (INTEGERP (port))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1206 port = Fnumber_to_string (port);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1207 sprintf (tembuf, "(network %s server on %s)\n",
44314
f76a1425eb34 (DATAGRAM_CONN_P, list_processes_1)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44194
diff changeset
1208 (DATAGRAM_CHAN_P (XINT (p->infd)) ? "datagram" : "stream"),
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
1209 SDATA (port));
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1210 insert_string (tembuf);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1211 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1212 else if (NETCONN1_P (p))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1213 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1214 /* 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
1215 so display service instead. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1216 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
1217 if (!STRINGP (host))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1218 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1219 host = Fplist_get (p->childp, QCservice);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1220 if (INTEGERP (host))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1221 host = Fnumber_to_string (host);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1222 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1223 sprintf (tembuf, "(network %s connection to %s)\n",
44314
f76a1425eb34 (DATAGRAM_CONN_P, list_processes_1)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44194
diff changeset
1224 (DATAGRAM_CHAN_P (XINT (p->infd)) ? "datagram" : "stream"),
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
1225 SDATA (host));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1226 insert_string (tembuf);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1227 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1228 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1229 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1230 tem = p->command;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1231 while (1)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1232 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1233 tem1 = Fcar (tem);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1234 Finsert (1, &tem1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1235 tem = Fcdr (tem);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1236 if (NILP (tem))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1237 break;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1238 insert_string (" ");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1239 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1240 insert_string ("\n");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1241 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1242 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1243 return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1244 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1245
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1246 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
1247 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
1248 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
1249 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
1250 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
1251 after the listing is made. */)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1252 (query_only)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1253 Lisp_Object query_only;
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 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
1256 list_processes_1, query_only);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1257 return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1258 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1259
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1260 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
1261 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
1262 ()
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1263 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1264 return Fmapcar (Qcdr, Vprocess_alist);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1265 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1266
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1267 /* 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
1268
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1269 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
1270
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1271 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
1272 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
1273 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
1274 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
1275 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
1276 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
1277 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
1278 with any buffer.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
1279 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
1280 Remaining arguments are strings to give program as arguments.
44170
888d736c0e91 (set-network-process-options): Add usage.
Pavel Janík <Pavel@Janik.cz>
parents: 44073
diff changeset
1281
40641
d94fc1022312 (Fstart_process): Add usage to doc-string.
Pavel Janík <Pavel@Janik.cz>
parents: 40231
diff changeset
1282 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
1283 (nargs, args)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1284 int nargs;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1285 register Lisp_Object *args;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1286 {
1683
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1287 Lisp_Object buffer, name, program, proc, current_dir, tem;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1288 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1289 register unsigned char *new_argv;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1290 int len;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1291 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1292 register unsigned char **new_argv;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1293 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1294 register int i;
46293
1fb8f75062c6 Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents: 45410
diff changeset
1295 int count = SPECPDL_INDEX ();
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1296
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1297 buffer = args[1];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1298 if (!NILP (buffer))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1299 buffer = Fget_buffer_create (buffer);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1300
1683
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1301 /* 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
1302 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
1303 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
1304 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
1305
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1306 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
1307 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
1308 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
1309 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
1310 {
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1311 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
1312
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1313 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
1314
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1315 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
1316
10744
54a76e0b97ec (Fstart_process): Make process marker point into proc buf.
Richard M. Stallman <rms@gnu.org>
parents: 10548
diff changeset
1317 current_dir
54a76e0b97ec (Fstart_process): Make process marker point into proc buf.
Richard M. Stallman <rms@gnu.org>
parents: 10548
diff changeset
1318 = 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
1319 Qnil);
1683
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1320 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
1321 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
1322 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
1323
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1324 UNGCPRO;
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1325 }
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1326
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1327 name = args[0];
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
1328 CHECK_STRING (name);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1329
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1330 program = args[2];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1331
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
1332 CHECK_STRING (program);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1333
29017
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1334 proc = make_process (name);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1335 /* 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
1336 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
1337 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
1338 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
1339 record_unwind_protect (start_process_unwind, proc);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1340
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1341 XPROCESS (proc)->childp = Qt;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1342 XPROCESS (proc)->command_channel_p = Qnil;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1343 XPROCESS (proc)->buffer = buffer;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1344 XPROCESS (proc)->sentinel = Qnil;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1345 XPROCESS (proc)->filter = Qnil;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1346 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
1347
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1348 /* 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
1349 if (!NILP (buffer))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1350 set_marker_both (XPROCESS (proc)->mark, buffer,
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1351 BUF_ZV (XBUFFER (buffer)),
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1352 BUF_ZV_BYTE (XBUFFER (buffer)));
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 {
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1355 /* 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
1356 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
1357 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
1358
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1359 /* 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
1360 Lisp_Object coding_systems = Qt;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1361 Lisp_Object val, *args2;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1362 struct gcpro gcpro1, gcpro2;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1363
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1364 val = Vcoding_system_for_read;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1365 if (NILP (val))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1366 {
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1367 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
1368 args2[0] = Qstart_process;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1369 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
1370 GCPRO2 (proc, current_dir);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1371 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
1372 UNGCPRO;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1373 if (CONSP (coding_systems))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1374 val = XCAR (coding_systems);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1375 else if (CONSP (Vdefault_process_coding_system))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1376 val = XCAR (Vdefault_process_coding_system);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1377 }
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1378 XPROCESS (proc)->decode_coding_system = val;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1379
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1380 val = Vcoding_system_for_write;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1381 if (NILP (val))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1382 {
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1383 if (EQ (coding_systems, Qt))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1384 {
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1385 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
1386 args2[0] = Qstart_process;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1387 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
1388 GCPRO2 (proc, current_dir);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1389 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
1390 UNGCPRO;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1391 }
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1392 if (CONSP (coding_systems))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1393 val = XCDR (coding_systems);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1394 else if (CONSP (Vdefault_process_coding_system))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1395 val = XCDR (Vdefault_process_coding_system);
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1396 }
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1397 XPROCESS (proc)->encode_coding_system = val;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1398 }
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1399
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1400 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1401 /* Make a one member argv with all args concatenated
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1402 together separated by a blank. */
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
1403 len = SBYTES (program) + 2;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1404 for (i = 3; i < nargs; i++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1405 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1406 tem = args[i];
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
1407 CHECK_STRING (tem);
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
1408 len += SBYTES (tem) + 1; /* count the blank */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1409 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1410 new_argv = (unsigned char *) alloca (len);
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
1411 strcpy (new_argv, SDATA (program));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1412 for (i = 3; i < nargs; i++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1413 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1414 tem = args[i];
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
1415 CHECK_STRING (tem);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1416 strcat (new_argv, " ");
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
1417 strcat (new_argv, SDATA (tem));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1418 }
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1419 /* 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
1420
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1421 #else /* not VMS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1422 new_argv = (unsigned char **) alloca ((nargs - 1) * sizeof (char *));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1423
47020
de9a20871faa (Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents: 46431
diff changeset
1424 /* If program file name is not absolute, search our path for it.
de9a20871faa (Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents: 46431
diff changeset
1425 Put the name we will really use in TEM. */
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
1426 if (!IS_DIRECTORY_SEP (SREF (program, 0))
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
1427 && !(SCHARS (program) > 1
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
1428 && IS_DEVICE_SEP (SREF (program, 1))))
6390
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1429 {
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1430 struct gcpro gcpro1, gcpro2, gcpro3, gcpro4;
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1431
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1432 tem = Qnil;
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1433 GCPRO4 (name, program, buffer, current_dir);
45005
084928cfcfcb (Fstart_process): Update call to openp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44890
diff changeset
1434 openp (Vexec_path, program, Vexec_suffixes, &tem, make_number (X_OK));
6390
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1435 UNGCPRO;
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1436 if (NILP (tem))
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1437 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
1438 tem = Fexpand_file_name (tem, Qnil);
6390
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1439 }
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1440 else
12491
4ad7be34ece1 (Fstart_process): Expand PROGRAM.
Richard M. Stallman <rms@gnu.org>
parents: 12378
diff changeset
1441 {
4ad7be34ece1 (Fstart_process): Expand PROGRAM.
Richard M. Stallman <rms@gnu.org>
parents: 12378
diff changeset
1442 if (!NILP (Ffile_directory_p (program)))
4ad7be34ece1 (Fstart_process): Expand PROGRAM.
Richard M. Stallman <rms@gnu.org>
parents: 12378
diff changeset
1443 error ("Specified program for new process is a directory");
47020
de9a20871faa (Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents: 46431
diff changeset
1444 tem = program;
12491
4ad7be34ece1 (Fstart_process): Expand PROGRAM.
Richard M. Stallman <rms@gnu.org>
parents: 12378
diff changeset
1445 }
6390
9f8ce71435de (Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents: 6345
diff changeset
1446
47020
de9a20871faa (Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents: 46431
diff changeset
1447 /* If program file name starts with /: for quoting a magic name,
de9a20871faa (Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents: 46431
diff changeset
1448 discard that. */
de9a20871faa (Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents: 46431
diff changeset
1449 if (SBYTES (tem) > 2 && SREF (tem, 0) == '/'
de9a20871faa (Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents: 46431
diff changeset
1450 && SREF (tem, 1) == ':')
de9a20871faa (Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents: 46431
diff changeset
1451 tem = Fsubstring (tem, make_number (2), Qnil);
de9a20871faa (Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents: 46431
diff changeset
1452
de9a20871faa (Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents: 46431
diff changeset
1453 /* Encode the file name and put it in NEW_ARGV.
de9a20871faa (Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents: 46431
diff changeset
1454 That's where the child will use it to execute the program. */
de9a20871faa (Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents: 46431
diff changeset
1455 tem = ENCODE_FILE (tem);
de9a20871faa (Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents: 46431
diff changeset
1456 new_argv[0] = SDATA (tem);
de9a20871faa (Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents: 46431
diff changeset
1457
29017
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1458 /* 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
1459 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
1460 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
1461 process. */
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1462
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1463 for (i = 3; i < nargs; i++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1464 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1465 tem = args[i];
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
1466 CHECK_STRING (tem);
29017
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1467 if (STRING_MULTIBYTE (tem))
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1468 tem = (code_convert_string_norecord
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
1469 (tem, XPROCESS (proc)->encode_coding_system, 1));
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
1470 new_argv[i - 2] = SDATA (tem);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1471 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1472 new_argv[i - 2] = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1473 #endif /* not VMS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1474
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
1475 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
1476 XPROCESS (proc)->decoding_carryover = make_number (0);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
1477 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
1478 XPROCESS (proc)->encoding_carryover = make_number (0);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
1479
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
1480 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
1481 = (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
1482 ? Qnil : Qt);
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
1483
20382
dbad9367d232 (create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents: 20225
diff changeset
1484 create_process (proc, (char **) new_argv, current_dir);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1485
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1486 return unbind_to (count, proc);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1487 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1488
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1489 /* This function is the unwind_protect form for Fstart_process. If
14036
621a575db6f7 Comment fixes.
Karl Heuer <kwzh@gnu.org>
parents: 13777
diff changeset
1490 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
1491 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
1492 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
1493 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
1494 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
1495 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
1496 {
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
1497 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
1498 abort ();
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1499
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1500 /* Was PROC started successfully? */
3685
47d7fda8a609 (start_process_unwind): Use XINT.
Richard M. Stallman <rms@gnu.org>
parents: 3666
diff changeset
1501 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
1502 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
1503
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1504 return Qnil;
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1505 }
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
1506
27430
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1507 void
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1508 create_process_1 (timer)
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1509 struct atimer *timer;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1510 {
27430
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1511 /* Nothing to do. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1512 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1513
27430
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1514
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1515 #if 0 /* This doesn't work; see the note before sigchld_handler. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1516 #ifdef USG
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1517 #ifdef SIGCHLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1518 /* Mimic blocking of signals on system V, which doesn't really have it. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1519
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1520 /* Nonzero means we got a SIGCHLD when it was supposed to be blocked. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1521 int sigchld_deferred;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1522
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1523 SIGTYPE
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1524 create_process_sigchld ()
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1525 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1526 signal (SIGCHLD, create_process_sigchld);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1527
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1528 sigchld_deferred = 1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1529 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1530 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1531 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1532 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1533
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1534 #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
1535 void
1683
a0a41de51400 Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents: 1655
diff changeset
1536 create_process (process, new_argv, current_dir)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1537 Lisp_Object process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1538 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
1539 Lisp_Object current_dir;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1540 {
11926
40d7e6f04ebe (create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents: 11845
diff changeset
1541 int pid, inchannel, outchannel;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1542 int sv[2];
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1543 #ifdef POSIX_SIGNALS
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1544 sigset_t procmask;
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1545 sigset_t blocked;
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1546 struct sigaction sigint_action;
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1547 struct sigaction sigquit_action;
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1548 #ifdef AIX
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1549 struct sigaction sighup_action;
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1550 #endif
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1551 #else /* !POSIX_SIGNALS */
25770
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
1552 #if 0
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1553 #ifdef SIGCHLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1554 SIGTYPE (*sigchld)();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1555 #endif
25770
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
1556 #endif /* 0 */
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1557 #endif /* !POSIX_SIGNALS */
11926
40d7e6f04ebe (create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents: 11845
diff changeset
1558 /* 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
1559 volatile int forkin, forkout;
40d7e6f04ebe (create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents: 11845
diff changeset
1560 volatile int pty_flag = 0;
31099
0fe5afca71e4 Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents: 30582
diff changeset
1561 #ifndef USE_CRT_DLL
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1562 extern char **environ;
31099
0fe5afca71e4 Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents: 30582
diff changeset
1563 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1564
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1565 inchannel = outchannel = -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1566
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1567 #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
1568 if (!NILP (Vprocess_connection_type))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1569 outchannel = inchannel = allocate_pty ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1570
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1571 if (inchannel >= 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1572 {
46411
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
1573 #if ! defined (USG) || defined (USG_SUBTTY_WORKS)
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
1574 /* On most USG systems it does not work to open the pty's tty here,
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
1575 then close it and reopen it in the child. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1576 #ifdef O_NOCTTY
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1577 /* Don't let this terminal become our controlling terminal
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1578 (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
1579 forkout = forkin = emacs_open (pty_name, O_RDWR | O_NOCTTY, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1580 #else
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1581 forkout = forkin = emacs_open (pty_name, O_RDWR, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1582 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1583 if (forkin < 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1584 report_file_error ("Opening pty", Qnil);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1585 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1586 forkin = forkout = -1;
46411
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
1587 #endif /* not USG, or USG_SUBTTY_WORKS */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1588 pty_flag = 1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1589 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1590 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1591 #endif /* HAVE_PTYS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1592 #ifdef SKTPAIR
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1593 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1594 if (socketpair (AF_UNIX, SOCK_STREAM, 0, sv) < 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1595 report_file_error ("Opening socketpair", Qnil);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1596 outchannel = inchannel = sv[0];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1597 forkout = forkin = sv[1];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1598 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1599 #else /* not SKTPAIR */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1600 {
25129
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1601 int tem;
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1602 tem = pipe (sv);
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1603 if (tem < 0)
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1604 report_file_error ("Creating pipe", Qnil);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1605 inchannel = sv[0];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1606 forkout = sv[1];
25129
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1607 tem = pipe (sv);
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1608 if (tem < 0)
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1609 {
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1610 emacs_close (inchannel);
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1611 emacs_close (forkout);
25129
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1612 report_file_error ("Creating pipe", Qnil);
4f3c8f1cec96 (create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents: 25009
diff changeset
1613 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1614 outchannel = sv[1];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1615 forkin = sv[0];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1616 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1617 #endif /* not SKTPAIR */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1618
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1619 #if 0
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1620 /* Replaced by close_process_descs */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1621 set_exclusive_use (inchannel);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1622 set_exclusive_use (outchannel);
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
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1625 /* Stride people say it's a mystery why this is needed
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1626 as well as the O_NDELAY, but that it fails without this. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1627 #if defined (STRIDE) || (defined (pfa) && defined (HAVE_PTYS))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1628 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1629 int one = 1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1630 ioctl (inchannel, FIONBIO, &one);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1631 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1632 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1633
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1634 #ifdef O_NONBLOCK
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1635 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
1636 fcntl (outchannel, F_SETFL, O_NONBLOCK);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1637 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1638 #ifdef O_NDELAY
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1639 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
1640 fcntl (outchannel, F_SETFL, O_NDELAY);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1641 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1642 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1643
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1644 /* Record this as an active process, with its channels.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1645 As a result, child_setup will close Emacs's side of the pipes. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1646 chan_process[inchannel] = process;
9277
21f6120be5ba (make_process, create_process, Fopen_network_stream, deactivate_process,
Karl Heuer <kwzh@gnu.org>
parents: 9115
diff changeset
1647 XSETINT (XPROCESS (process)->infd, inchannel);
21f6120be5ba (make_process, create_process, Fopen_network_stream, deactivate_process,
Karl Heuer <kwzh@gnu.org>
parents: 9115
diff changeset
1648 XSETINT (XPROCESS (process)->outfd, outchannel);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1649 /* Record the tty descriptor used in the subprocess. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1650 if (forkin < 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1651 XPROCESS (process)->subtty = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1652 else
9318
a14cc1712337 (make_process, list_processes_1, create_process, Faccept_process_output,
Karl Heuer <kwzh@gnu.org>
parents: 9277
diff changeset
1653 XSETFASTINT (XPROCESS (process)->subtty, forkin);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1654 XPROCESS (process)->pty_flag = (pty_flag ? Qt : Qnil);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1655 XPROCESS (process)->status = Qrun;
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
1656 if (!proc_decode_coding_system[inchannel])
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
1657 proc_decode_coding_system[inchannel]
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
1658 = (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
1659 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
1660 proc_decode_coding_system[inchannel]);
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
1661 if (!proc_encode_coding_system[outchannel])
22848
f17131794fbc Whitespace change.
Richard M. Stallman <rms@gnu.org>
parents: 22763
diff changeset
1662 proc_encode_coding_system[outchannel]
f17131794fbc Whitespace change.
Richard M. Stallman <rms@gnu.org>
parents: 22763
diff changeset
1663 = (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
1664 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
1665 proc_encode_coding_system[outchannel]);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1666
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1667 /* Delay interrupts until we have a chance to store
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1668 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
1669 #ifdef POSIX_SIGNALS
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1670 sigemptyset (&blocked);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1671 #ifdef SIGCHLD
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1672 sigaddset (&blocked, SIGCHLD);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1673 #endif
41856
0028402ed7d1 (create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents: 40656
diff changeset
1674 #ifdef HAVE_WORKING_VFORK
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1675 /* 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
1676 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
1677 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
1678 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
1679 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
1680 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
1681 #ifdef AIX
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1682 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
1683 #endif
41856
0028402ed7d1 (create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents: 40656
diff changeset
1684 #endif /* HAVE_WORKING_VFORK */
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1685 sigprocmask (SIG_BLOCK, &blocked, &procmask);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1686 #else /* !POSIX_SIGNALS */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1687 #ifdef SIGCHLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1688 #ifdef BSD4_1
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1689 sighold (SIGCHLD);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1690 #else /* not BSD4_1 */
16220
02044b05d8e0 Replaced symbol BSD with BSD_SYSTEM.
Karl Heuer <kwzh@gnu.org>
parents: 16206
diff changeset
1691 #if defined (BSD_SYSTEM) || defined (UNIPLUS) || defined (HPUX)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1692 sigsetmask (sigmask (SIGCHLD));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1693 #else /* ordinary USG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1694 #if 0
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1695 sigchld_deferred = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1696 sigchld = signal (SIGCHLD, create_process_sigchld);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1697 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1698 #endif /* ordinary USG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1699 #endif /* not BSD4_1 */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1700 #endif /* SIGCHLD */
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1701 #endif /* !POSIX_SIGNALS */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1702
7893
e54617027a47 (create_process): Set input_wait_mask before forking.
Karl Heuer <kwzh@gnu.org>
parents: 7884
diff changeset
1703 FD_SET (inchannel, &input_wait_mask);
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
1704 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
1705 if (inchannel > max_process_desc)
e54617027a47 (create_process): Set input_wait_mask before forking.
Karl Heuer <kwzh@gnu.org>
parents: 7884
diff changeset
1706 max_process_desc = inchannel;
e54617027a47 (create_process): Set input_wait_mask before forking.
Karl Heuer <kwzh@gnu.org>
parents: 7884
diff changeset
1707
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1708 /* Until we store the proper pid, enable sigchld_handler
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1709 to recognize an unknown pid as standing for this process.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1710 It is very important not to let this `marker' value stay
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1711 in the table after this function has returned; if it does
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1712 it might cause call-process to hang and subsequent asynchronous
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1713 processes to get their return values scrambled. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1714 XSETINT (XPROCESS (process)->pid, -1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1715
16780
e9dc2569cb12 Include blockinput.h.
Richard M. Stallman <rms@gnu.org>
parents: 16728
diff changeset
1716 BLOCK_INPUT;
e9dc2569cb12 Include blockinput.h.
Richard M. Stallman <rms@gnu.org>
parents: 16728
diff changeset
1717
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1718 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1719 /* child_setup must clobber environ on systems with true vfork.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1720 Protect it from permanent change. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1721 char **save_environ = environ;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1722
21049
01e626b0a624 (Vdefault_file_name_coding_system): Extern it.
Kenichi Handa <handa@m17n.org>
parents: 20715
diff changeset
1723 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
1724
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1725 #ifndef WINDOWSNT
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1726 pid = vfork ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1727 if (pid == 0)
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1728 #endif /* not WINDOWSNT */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1729 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1730 int xforkin = forkin;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1731 int xforkout = forkout;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1732
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1733 #if 0 /* This was probably a mistake--it duplicates code later on,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1734 but fails to handle all the cases. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1735 /* Make sure SIGCHLD is not blocked in the child. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1736 sigsetmask (SIGEMPTYMASK);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1737 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1738
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1739 /* Make the pty be the controlling terminal of the process. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1740 #ifdef HAVE_PTYS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1741 /* First, disconnect its current controlling terminal. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1742 #ifdef HAVE_SETSID
7266
f87808bd90e9 (create_process): Undo April 19 setsid change.
Richard M. Stallman <rms@gnu.org>
parents: 7238
diff changeset
1743 /* 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
1744 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
1745 setsid ();
1030
9934251d8219 (WCOREDUMP): Define only if not defined.
Richard M. Stallman <rms@gnu.org>
parents: 1012
diff changeset
1746 /* 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
1747 if (pty_flag)
6975
b7411e378b65 (create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 6947
diff changeset
1748 {
b7411e378b65 (create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 6947
diff changeset
1749 #ifdef TIOCSCTTY
b7411e378b65 (create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 6947
diff changeset
1750 /* We ignore the return value
b7411e378b65 (create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 6947
diff changeset
1751 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
1752 ioctl (xforkin, TIOCSCTTY, 0);
1030
9934251d8219 (WCOREDUMP): Define only if not defined.
Richard M. Stallman <rms@gnu.org>
parents: 1012
diff changeset
1753 #endif
6975
b7411e378b65 (create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 6947
diff changeset
1754 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1755 #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
1756 #ifdef USG
5347
21bffe027a7d (create_process) [NTTYDISC]: Set the tty line discipline.
Richard M. Stallman <rms@gnu.org>
parents: 5332
diff changeset
1757 /* It's very important to call setpgrp here and no time
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1758 afterwards. Otherwise, we lose our controlling tty which
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1759 is set when we open the pty. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1760 setpgrp ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1761 #endif /* USG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1762 #endif /* not HAVE_SETSID */
7116
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1763 #if defined (HAVE_TERMIOS) && defined (LDISC1)
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1764 if (pty_flag && xforkin >= 0)
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1765 {
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1766 struct termios t;
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1767 tcgetattr (xforkin, &t);
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1768 t.c_lflag = LDISC1;
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1769 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
1770 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
1771 }
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1772 #else
6947
c5f990fad6bb (create_process): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 6928
diff changeset
1773 #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
1774 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
1775 {
36d2fd17f833 (create_process): Set line discipline only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 5543
diff changeset
1776 /* Use new line discipline. */
36d2fd17f833 (create_process): Set line discipline only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 5543
diff changeset
1777 int ldisc = NTTYDISC;
7605
53186c2698e5 (create_process): Don't complain about error from TIOCSETD.
Richard M. Stallman <rms@gnu.org>
parents: 7486
diff changeset
1778 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
1779 }
5347
21bffe027a7d (create_process) [NTTYDISC]: Set the tty line discipline.
Richard M. Stallman <rms@gnu.org>
parents: 5332
diff changeset
1780 #endif
7116
d35b11eed89f (create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents: 7059
diff changeset
1781 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1782 #ifdef TIOCNOTTY
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1783 /* In 4.3BSD, the TIOCSPGRP bug has been fixed, and now you
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1784 can do TIOCSPGRP only to the process's controlling tty. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1785 if (pty_flag)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1786 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1787 /* I wonder: would just ioctl (0, TIOCNOTTY, 0) work here?
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1788 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
1789 int j = emacs_open ("/dev/tty", O_RDWR, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1790 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
1791 emacs_close (j);
3826
647bef18618f Changes for Irix 4.0, tested this time:
Jim Blandy <jimb@redhat.com>
parents: 3810
diff changeset
1792 #ifndef USG
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1793 /* In order to get a controlling terminal on some versions
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1794 of BSD, it is necessary to put the process in pgrp 0
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1795 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
1796 #ifdef HAVE_SETPGID
9882
ccc5562a7194 (create_process) [OSF1]: Use setpgid, not setpgrp.
Richard M. Stallman <rms@gnu.org>
parents: 9793
diff changeset
1797 setpgid (0, 0);
ccc5562a7194 (create_process) [OSF1]: Use setpgid, not setpgrp.
Richard M. Stallman <rms@gnu.org>
parents: 9793
diff changeset
1798 #else
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1799 setpgrp (0, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1800 #endif
9882
ccc5562a7194 (create_process) [OSF1]: Use setpgid, not setpgrp.
Richard M. Stallman <rms@gnu.org>
parents: 9793
diff changeset
1801 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1802 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1803 #endif /* TIOCNOTTY */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1804
16076
5d1e0290bbd0 (create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 16058
diff changeset
1805 #if !defined (RTU) && !defined (UNIPLUS) && !defined (DONT_REOPEN_PTY)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1806 /*** 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
1807 conditional on TIOCSPGRP,
5d1e0290bbd0 (create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 16058
diff changeset
1808 or !(defined (HAVE_SETSID) && defined (TIOCSCTTY)).
5d1e0290bbd0 (create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 16058
diff changeset
1809 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
1810 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
1811 both HAVE_SETSID and TIOCSCTTY are defined. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1812 /* Now close the pty (if we had it open) and reopen it.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1813 This makes the pty the controlling terminal of the subprocess. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1814 if (pty_flag)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
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 int pgrp = getpid ();
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
1818 #endif
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
1819
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1820 /* 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
1821 would work? */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1822 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
1823 emacs_close (xforkin);
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1824 xforkout = xforkin = emacs_open (pty_name, O_RDWR, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1825
11514
321726163a65 (create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents: 11376
diff changeset
1826 if (xforkin < 0)
321726163a65 (create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents: 11376
diff changeset
1827 {
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
1828 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
1829 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
1830 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
1831 _exit (1);
321726163a65 (create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents: 11376
diff changeset
1832 }
321726163a65 (create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents: 11376
diff changeset
1833
5240
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
1834 #ifdef SET_CHILD_PTY_PGRP
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
1835 ioctl (xforkin, TIOCSPGRP, &pgrp);
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
1836 ioctl (xforkout, TIOCSPGRP, &pgrp);
eed870591987 (Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents: 5239
diff changeset
1837 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1838 }
16076
5d1e0290bbd0 (create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents: 16058
diff changeset
1839 #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
1840
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1841 #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
1842 if (pty_flag)
1855e568a9b8 (create_process): Use SETUP_SLAVE_PTY only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 7044
diff changeset
1843 {
1855e568a9b8 (create_process): Use SETUP_SLAVE_PTY only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 7044
diff changeset
1844 SETUP_SLAVE_PTY;
1855e568a9b8 (create_process): Use SETUP_SLAVE_PTY only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 7044
diff changeset
1845 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1846 #endif /* SETUP_SLAVE_PTY */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1847 #ifdef AIX
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1848 /* 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
1849 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
1850 if (pty_flag)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1851 signal (SIGHUP, SIG_DFL);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1852 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1853 #endif /* HAVE_PTYS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1854
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1855 signal (SIGINT, SIG_DFL);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1856 signal (SIGQUIT, SIG_DFL);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1857
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1858 /* Stop blocking signals in the child. */
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1859 #ifdef POSIX_SIGNALS
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1860 sigprocmask (SIG_SETMASK, &procmask, 0);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1861 #else /* !POSIX_SIGNALS */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1862 #ifdef SIGCHLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1863 #ifdef BSD4_1
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1864 sigrelse (SIGCHLD);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1865 #else /* not BSD4_1 */
16220
02044b05d8e0 Replaced symbol BSD with BSD_SYSTEM.
Karl Heuer <kwzh@gnu.org>
parents: 16206
diff changeset
1866 #if defined (BSD_SYSTEM) || defined (UNIPLUS) || defined (HPUX)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1867 sigsetmask (SIGEMPTYMASK);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1868 #else /* ordinary USG */
1207
af619d68a576 * process.c [SIGCHLD && !BSD && !UNIPLUS && !HPUX]
Jim Blandy <jimb@redhat.com>
parents: 1180
diff changeset
1869 #if 0
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1870 signal (SIGCHLD, sigchld);
1207
af619d68a576 * process.c [SIGCHLD && !BSD && !UNIPLUS && !HPUX]
Jim Blandy <jimb@redhat.com>
parents: 1180
diff changeset
1871 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1872 #endif /* ordinary USG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1873 #endif /* not BSD4_1 */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1874 #endif /* SIGCHLD */
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1875 #endif /* !POSIX_SIGNALS */
8390
ee13e8728666 (create_process): Set default handling for SIGINT, etc.
Richard M. Stallman <rms@gnu.org>
parents: 8354
diff changeset
1876
7059
6a55de48ade5 (create_process): Use child_setup_tty only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 7058
diff changeset
1877 if (pty_flag)
6a55de48ade5 (create_process): Use child_setup_tty only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents: 7058
diff changeset
1878 child_setup_tty (xforkout);
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1879 #ifdef WINDOWSNT
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1880 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
1881 new_argv, 1, current_dir);
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1882 #else /* not WINDOWSNT */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1883 child_setup (xforkin, xforkout, xforkout,
638
40b255f55df3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 624
diff changeset
1884 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
1885 #endif /* not WINDOWSNT */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1886 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1887 environ = save_environ;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1888 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1889
16780
e9dc2569cb12 Include blockinput.h.
Richard M. Stallman <rms@gnu.org>
parents: 16728
diff changeset
1890 UNBLOCK_INPUT;
e9dc2569cb12 Include blockinput.h.
Richard M. Stallman <rms@gnu.org>
parents: 16728
diff changeset
1891
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1892 /* This runs in the Emacs process. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1893 if (pid < 0)
7157
3f4fc9d682b4 (create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents: 7116
diff changeset
1894 {
3f4fc9d682b4 (create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents: 7116
diff changeset
1895 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
1896 emacs_close (forkin);
7157
3f4fc9d682b4 (create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents: 7116
diff changeset
1897 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
1898 emacs_close (forkout);
7157
3f4fc9d682b4 (create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents: 7116
diff changeset
1899 }
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1900 else
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1901 {
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1902 /* vfork succeeded. */
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1903 XSETFASTINT (XPROCESS (process)->pid, pid);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1904
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1905 #ifdef WINDOWSNT
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1906 register_child (pid, inchannel);
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1907 #endif /* WINDOWSNT */
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
1908
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1909 /* If the subfork execv fails, and it exits,
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1910 this close hangs. I don't know why.
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1911 So have an interrupt jar it loose. */
27430
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1912 {
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1913 struct atimer *timer;
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1914 EMACS_TIME offset;
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1915
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1916 stop_polling ();
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1917 EMACS_SET_SECS_USECS (offset, 1, 0);
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1918 timer = start_atimer (ATIMER_RELATIVE, offset, create_process_1, 0);
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1919
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1920 XPROCESS (process)->subtty = Qnil;
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1921 if (forkin >= 0)
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1922 emacs_close (forkin);
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1923
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1924 cancel_atimer (timer);
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1925 start_polling ();
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1926 }
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
1927
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1928 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
1929 emacs_close (forkout);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1930
11609
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
1931 #ifdef HAVE_PTYS
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1932 if (pty_flag)
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1933 XPROCESS (process)->tty_name = build_string (pty_name);
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1934 else
11609
3b2dacb1bfe9 (create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents: 11514
diff changeset
1935 #endif
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1936 XPROCESS (process)->tty_name = Qnil;
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1937 }
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1938
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1939 /* 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
1940 (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
1941 #ifdef POSIX_SIGNALS
41856
0028402ed7d1 (create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents: 40656
diff changeset
1942 #ifdef HAVE_WORKING_VFORK
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1943 /* Restore the parent's signal handlers. */
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1944 sigaction (SIGINT, &sigint_action, 0);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1945 sigaction (SIGQUIT, &sigquit_action, 0);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1946 #ifdef AIX
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1947 sigaction (SIGHUP, &sighup_action, 0);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1948 #endif
41856
0028402ed7d1 (create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents: 40656
diff changeset
1949 #endif /* HAVE_WORKING_VFORK */
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1950 /* Stop blocking signals in the parent. */
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1951 sigprocmask (SIG_SETMASK, &procmask, 0);
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1952 #else /* !POSIX_SIGNALS */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1953 #ifdef SIGCHLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1954 #ifdef BSD4_1
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1955 sigrelse (SIGCHLD);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1956 #else /* not BSD4_1 */
16220
02044b05d8e0 Replaced symbol BSD with BSD_SYSTEM.
Karl Heuer <kwzh@gnu.org>
parents: 16206
diff changeset
1957 #if defined (BSD_SYSTEM) || defined (UNIPLUS) || defined (HPUX)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1958 sigsetmask (SIGEMPTYMASK);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1959 #else /* ordinary USG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1960 #if 0
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1961 signal (SIGCHLD, sigchld);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1962 /* Now really handle any of these signals
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1963 that came in during this function. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1964 if (sigchld_deferred)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1965 kill (getpid (), SIGCHLD);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1966 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1967 #endif /* ordinary USG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1968 #endif /* not BSD4_1 */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1969 #endif /* SIGCHLD */
13709
d16f31ae8adf (create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents: 13414
diff changeset
1970 #endif /* !POSIX_SIGNALS */
14131
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1971
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1972 /* Now generate the error if vfork failed. */
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1973 if (pid < 0)
7717b68abd2e (create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents: 14085
diff changeset
1974 report_file_error ("Doing vfork", Qnil);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1975 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1976 #endif /* not VMS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1977
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1978
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1979 #ifdef HAVE_SOCKETS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1980
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1981 /* 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
1982 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
1983
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1984 static Lisp_Object
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1985 conv_sockaddr_to_lisp (sa, len)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1986 struct sockaddr *sa;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1987 int len;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1988 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1989 Lisp_Object address;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1990 int i;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1991 unsigned char *cp;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1992 register struct Lisp_Vector *p;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1993
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1994 switch (sa->sa_family)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1995 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1996 case AF_INET:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1997 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
1998 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
1999 len = sizeof (sin->sin_addr) + 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2000 address = Fmake_vector (make_number (len), Qnil);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2001 p = XVECTOR (address);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2002 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
2003 cp = (unsigned char *)&sin->sin_addr;
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 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2007 case AF_LOCAL:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2008 {
44038
e2339254ba48 (conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 44013
diff changeset
2009 struct sockaddr_un *sockun = (struct sockaddr_un *) sa;
e2339254ba48 (conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 44013
diff changeset
2010 for (i = 0; i < sizeof (sockun->sun_path); i++)
e2339254ba48 (conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 44013
diff changeset
2011 if (sockun->sun_path[i] == 0)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2012 break;
44038
e2339254ba48 (conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 44013
diff changeset
2013 return make_unibyte_string (sockun->sun_path, i);
43968
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 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2016 default:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2017 len -= sizeof (sa->sa_family);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2018 address = Fcons (make_number (sa->sa_family),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2019 Fmake_vector (make_number (len), Qnil));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2020 p = XVECTOR (XCDR (address));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2021 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
2022 break;
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
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2025 i = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2026 while (i < len)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2027 p->contents[i++] = make_number (*cp++);
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 return address;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2030 }
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 /* 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
2034
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2035 static int
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2036 get_lisp_to_sockaddr_size (address, familyp)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2037 Lisp_Object address;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2038 int *familyp;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2039 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2040 register struct Lisp_Vector *p;
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 if (VECTORP (address))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2043 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2044 p = XVECTOR (address);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2045 if (p->size == 5)
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 *familyp = AF_INET;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2048 return sizeof (struct sockaddr_in);
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 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2051 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2052 else if (STRINGP (address))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2053 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2054 *familyp = AF_LOCAL;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2055 return sizeof (struct sockaddr_un);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2056 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2057 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2058 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
2059 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2060 struct sockaddr *sa;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2061 *familyp = XINT (XCAR (address));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2062 p = XVECTOR (XCDR (address));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2063 return p->size + sizeof (sa->sa_family);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2064 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2065 return 0;
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
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2068 /* 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
2069 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
2070
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2071 static void
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2072 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
2073 int family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2074 Lisp_Object address;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2075 struct sockaddr *sa;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2076 int len;
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 register struct Lisp_Vector *p;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2079 register unsigned char *cp;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2080 register int i;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2081
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2082 bzero (sa, len);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2083 sa->sa_family = family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2084
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2085 if (VECTORP (address))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2086 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2087 p = XVECTOR (address);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2088 if (family == AF_INET)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2089 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2090 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
2091 len = sizeof (sin->sin_addr) + 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2092 i = XINT (p->contents[--len]);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2093 sin->sin_port = htons (i);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2094 cp = (unsigned char *)&sin->sin_addr;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2095 }
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 else if (STRINGP (address))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2098 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2099 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2100 if (family == AF_LOCAL)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2101 {
44038
e2339254ba48 (conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 44013
diff changeset
2102 struct sockaddr_un *sockun = (struct sockaddr_un *) sa;
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2103 cp = SDATA (address);
44038
e2339254ba48 (conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 44013
diff changeset
2104 for (i = 0; i < sizeof (sockun->sun_path) && *cp; i++)
e2339254ba48 (conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents: 44013
diff changeset
2105 sockun->sun_path[i] = *cp++;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2106 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2107 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2108 return;
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 else
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 p = XVECTOR (XCDR (address));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2113 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
2114 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2115
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2116 for (i = 0; i < len; i++)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2117 if (INTEGERP (p->contents[i]))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2118 *cp++ = XFASTINT (p->contents[i]) & 0xff;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2119 }
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 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2122 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
2123 1, 1, 0,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2124 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
2125 (process)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2126 Lisp_Object process;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2127 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2128 int channel;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2129
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2130 CHECK_PROCESS (process);
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 if (!DATAGRAM_CONN_P (process))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2133 return Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2134
44314
f76a1425eb34 (DATAGRAM_CONN_P, list_processes_1)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44194
diff changeset
2135 channel = XINT (XPROCESS (process)->infd);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2136 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
2137 datagram_address[channel].len);
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
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2140 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
2141 2, 2, 0,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2142 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
2143 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
2144 (process, address)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2145 Lisp_Object process, address;
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 int channel;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2148 int family, len;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2149
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2150 CHECK_PROCESS (process);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2151
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2152 if (!DATAGRAM_CONN_P (process))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2153 return Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2154
44314
f76a1425eb34 (DATAGRAM_CONN_P, list_processes_1)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44194
diff changeset
2155 channel = XINT (XPROCESS (process)->infd);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2156
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2157 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
2158 if (datagram_address[channel].len != len)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2159 return Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2160 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
2161 return address;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2162 }
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
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2165
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2166 static struct socket_options {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2167 /* 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
2168 name without SO_ prefix. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2169 char *name;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2170 /* Length of name. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2171 int nlen;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2172 /* Option level SOL_... */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2173 int optlevel;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2174 /* Option number SO_... */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2175 int optnum;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2176 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
2177 } socket_options[] =
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2178 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2179 #ifdef SO_BINDTODEVICE
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2180 { "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
2181 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2182 #ifdef SO_BROADCAST
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2183 { "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
2184 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2185 #ifdef SO_DONTROUTE
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2186 { "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
2187 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2188 #ifdef SO_KEEPALIVE
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2189 { "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
2190 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2191 #ifdef SO_LINGER
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2192 { "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
2193 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2194 #ifdef SO_OOBINLINE
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2195 { "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
2196 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2197 #ifdef SO_PRIORITY
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2198 { "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
2199 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2200 #ifdef SO_REUSEADDR
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2201 { "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
2202 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2203 { 0, 0, 0, 0, SOPT_UNKNOWN }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2204 };
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 /* 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
2207 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
2208 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
2209 cannot be set.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2210
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2211 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
2212 "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
2213 or a symbol. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2214
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2215 static int
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2216 set_socket_options (s, opts, no_error)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2217 int s;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2218 Lisp_Object opts;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2219 int no_error;
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 if (!CONSP (opts))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2222 opts = Fcons (opts, Qnil);
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 while (CONSP (opts))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2225 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2226 Lisp_Object opt;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2227 Lisp_Object val;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2228 char *name, *arg;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2229 struct socket_options *sopt;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2230 int ret = 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 opt = XCAR (opts);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2233 opts = XCDR (opts);
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 name = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2236 val = Qt;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2237 if (CONSP (opt))
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 val = XCDR (opt);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2240 opt = XCAR (opt);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2241 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2242 if (STRINGP (opt))
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2243 name = (char *) SDATA (opt);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2244 else if (SYMBOLP (opt))
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2245 name = (char *) SDATA (SYMBOL_NAME (opt));
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2246 else {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2247 error ("Mal-formed option list");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2248 return 0;
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 if (strncmp (name, "no", 2) == 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2252 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2253 val = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2254 name += 2;
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
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2257 arg = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2258 for (sopt = socket_options; sopt->name; sopt++)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2259 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
2260 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2261 if (name[sopt->nlen] == 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2262 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2263 if (name[sopt->nlen] == '=')
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2264 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2265 arg = name + sopt->nlen + 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2266 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2267 }
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 switch (sopt->opttype)
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 case SOPT_BOOL:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2273 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2274 int optval;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2275 if (s < 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2276 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2277 if (arg)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2278 optval = (*arg == '0' || *arg == 'n') ? 0 : 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2279 else if (INTEGERP (val))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2280 optval = XINT (val) == 0 ? 0 : 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2281 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2282 optval = NILP (val) ? 0 : 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2283 ret = setsockopt (s, sopt->optlevel, sopt->optnum,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2284 &optval, sizeof (optval));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2285 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2286 }
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 case SOPT_INT:
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 int optval;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2291 if (arg)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2292 optval = atoi(arg);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2293 else if (INTEGERP (val))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2294 optval = XINT (val);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2295 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2296 error ("Bad option argument for %s", name);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2297 if (s < 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2298 return 1;
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 &optval, sizeof (optval));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2301 break;
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
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2304 case SOPT_STR:
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 if (!arg)
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 if (NILP (val))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2309 arg = "";
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2310 else if (STRINGP (val))
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2311 arg = (char *) SDATA (val);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2312 else if (XSYMBOL (val))
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2313 arg = (char *) SDATA (SYMBOL_NAME (val));
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2314 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2315 error ("Invalid argument to %s option", name);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2316 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2317 ret = setsockopt (s, sopt->optlevel, sopt->optnum,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2318 arg, strlen (arg));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2319 }
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 #ifdef SO_LINGER
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2322 case SOPT_LINGER:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2323 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2324 struct linger linger;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2325
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2326 linger.l_onoff = 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2327 linger.l_linger = 0;
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 if (s < 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2330 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2331
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2332 if (arg)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2333 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2334 if (*arg == 'n' || *arg == 't' || *arg == 'y')
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2335 linger.l_onoff = (*arg == 'n') ? 0 : 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2336 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2337 linger.l_linger = atoi(arg);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2338 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2339 else if (INTEGERP (val))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2340 linger.l_linger = XINT (val);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2341 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2342 linger.l_onoff = NILP (val) ? 0 : 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2343 ret = setsockopt (s, sopt->optlevel, sopt->optnum,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2344 &linger, sizeof (linger));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2345 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2346 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2347 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2348 default:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2349 if (s < 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2350 return 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2351 if (no_error)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2352 continue;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2353 error ("Unsupported option: %s", name);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2354 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2355 if (ret < 0 && ! no_error)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2356 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
2357 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2358 return 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2359 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2360
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2361 DEFUN ("set-network-process-options",
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2362 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
2363 1, MANY, 0,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2364 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
2365 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
2366 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
2367
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2368 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
2369 pages for more information.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2370
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2371 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
2372 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
2373 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
2374 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
2375 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
2376 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
2377 priority=INT -- Set protocol defined priority for sent packets.
44170
888d736c0e91 (set-network-process-options): Add usage.
Pavel Janík <Pavel@Janik.cz>
parents: 44073
diff changeset
2378 reuseaddr=BOOL -- Allow reusing a recently used address.
888d736c0e91 (set-network-process-options): Add usage.
Pavel Janík <Pavel@Janik.cz>
parents: 44073
diff changeset
2379
888d736c0e91 (set-network-process-options): Add usage.
Pavel Janík <Pavel@Janik.cz>
parents: 44073
diff changeset
2380 usage: (set-network-process-options PROCESS &rest OPTIONS) */)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2381 (nargs, args)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2382 int nargs;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2383 Lisp_Object *args;
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 Lisp_Object process;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2386 Lisp_Object opts;
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 process = args[0];
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2389 CHECK_PROCESS (process);
44314
f76a1425eb34 (DATAGRAM_CONN_P, list_processes_1)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44194
diff changeset
2390 if (nargs > 1 && XINT (XPROCESS (process)->infd) >= 0)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2391 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2392 opts = Flist (nargs, args);
44314
f76a1425eb34 (DATAGRAM_CONN_P, list_processes_1)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44194
diff changeset
2393 set_socket_options (XINT (XPROCESS (process)->infd), opts, 0);
43968
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 return process;
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
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2398 /* 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
2399
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2400 Lisp_Object
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2401 unwind_request_sigio (dummy)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2402 Lisp_Object dummy;
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 (interrupt_input)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2405 request_sigio ();
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2406 return Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2407 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2408
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2409 /* 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
2410 exactly like a normal process when reading and writing. Primary
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2411 differences are in status display and process deletion. A network
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2412 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
2413 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
2414
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2415 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
2416 0, MANY, 0,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2417 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
2418
43995
110955214222 (Fmake_network_process): Remove unused variable `sa'.
Pavel Janík <Pavel@Janik.cz>
parents: 43968
diff changeset
2419 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
2420 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
2421 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
2422 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
2423 processes.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2424
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2425 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
2426 arguments are defined:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2427
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2428 :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
2429 to make it unique.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2430
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2431 :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
2432 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
2433 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
2434 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
2435 with any buffer.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2436
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2437 :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
2438 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
2439 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
2440 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
2441
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2442 :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
2443 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
2444 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
2445
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
2446 :type TYPE -- TYPE is the type of connection. The default (nil) is a
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
2447 stream type connection, `datagram' creates a datagram type connection.
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
2448
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2449 :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
2450 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
2451 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
2452 SERVICE. Other address families supported are:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2453 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
2454
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2455 :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
2456 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
2457 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
2458
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2459 :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
2460 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
2461 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
2462 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
2463 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
2464
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2465 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
2466 - 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
2467 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
2468 - 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
2469 local address space.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2470 - 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
2471 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
2472 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
2473 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
2474 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
2475
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2476 :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
2477
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2478 :options OPTIONS -- Set the specified options for the network process.
44170
888d736c0e91 (set-network-process-options): Add usage.
Pavel Janík <Pavel@Janik.cz>
parents: 44073
diff changeset
2479 See `set-network-process-options' for details.
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2480
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2481 :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
2482 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
2483 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
2484 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
2485 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
2486
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2487 :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
2488 running when emacs is exited.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2489
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2490 :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
2491 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
2492 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
2493 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
2494 `stop-process'.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2495
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2496 :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
2497
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2498 :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
2499
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2500 :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
2501 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
2502 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
2503 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
2504 and MESSAGE is a string.
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 :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
2507 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
2508 Default is a client process.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2509
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2510 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
2511 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
2512 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
2513 - 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
2514 process' NAME and a client identification string.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2515 - 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
2516 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
2517 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
2518 NAME concatenated with the client identification string.
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2519 - 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
2520 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
2521 - 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
2522 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
2523
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2524 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
2525 the server process. Also, the BUFFER argument is not used directly by
47542
62a08cd28e83 (make-network-process): Doc fix (there is no network-server-log-function hook).
Kim F. Storm <storm@cua.dk>
parents: 47431
diff changeset
2526 the server process, but via the optional :log function, accepted (and
62a08cd28e83 (make-network-process): Doc fix (there is no network-server-log-function hook).
Kim F. Storm <storm@cua.dk>
parents: 47431
diff changeset
2527 failed) connections may be logged in the server process' buffer.
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2528
43995
110955214222 (Fmake_network_process): Remove unused variable `sa'.
Pavel Janík <Pavel@Janik.cz>
parents: 43968
diff changeset
2529 usage: (make-network-process &rest ARGS) */)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2530 (nargs, args)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2531 int nargs;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2532 Lisp_Object *args;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2533 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2534 Lisp_Object proc;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2535 Lisp_Object contact;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2536 struct Lisp_Process *p;
32032
633b826a56f3 (Fopen_network_stream) [HAVE_GETADDRINFO]: Use
Gerd Moellmann <gerd@gnu.org>
parents: 31806
diff changeset
2537 #ifdef HAVE_GETADDRINFO
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2538 struct addrinfo ai, *res, *lres;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2539 struct addrinfo hints;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2540 char *portstring, portbuf[128];
32032
633b826a56f3 (Fopen_network_stream) [HAVE_GETADDRINFO]: Use
Gerd Moellmann <gerd@gnu.org>
parents: 31806
diff changeset
2541 #else /* HAVE_GETADDRINFO */
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2542 struct _emacs_addrinfo
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2543 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2544 int ai_family;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2545 int ai_socktype;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2546 int ai_protocol;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2547 int ai_addrlen;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2548 struct sockaddr *ai_addr;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2549 struct _emacs_addrinfo *ai_next;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2550 } ai, *res, *lres;
25262
ccf83ed7326a (Fopen_network_stream): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents: 25248
diff changeset
2551 #endif /* HAVE_GETADDRINFO */
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2552 struct sockaddr_in address_in;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2553 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2554 struct sockaddr_un address_un;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2555 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2556 int port;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2557 int ret = 0;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2558 int xerrno = 0;
25262
ccf83ed7326a (Fopen_network_stream): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents: 25248
diff changeset
2559 int s = -1, outch, inch;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2560 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
2561 int retry = 0;
46293
1fb8f75062c6 Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents: 45410
diff changeset
2562 int count = SPECPDL_INDEX ();
25705
1f109108fa7e (Fopen_network_stream): Avoid socket decriptor leak.
Andreas Schwab <schwab@suse.de>
parents: 25645
diff changeset
2563 int count1;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2564 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
2565 Lisp_Object tem;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2566 Lisp_Object name, buffer, host, service, address;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2567 Lisp_Object filter, sentinel;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2568 int is_non_blocking_client = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2569 int is_server = 0;
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
2570 int socktype;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2571 int family = -1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2572
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2573 if (nargs == 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2574 return Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2575
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2576 /* 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
2577 contact = Flist (nargs, args);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2578 GCPRO1 (contact);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2579
15355
6bb377ef707f (Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents: 15092
diff changeset
2580 #ifdef WINDOWSNT
6bb377ef707f (Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents: 15092
diff changeset
2581 /* Ensure socket support is loaded if available. */
6bb377ef707f (Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents: 15092
diff changeset
2582 init_winsock (TRUE);
6bb377ef707f (Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents: 15092
diff changeset
2583 #endif
6bb377ef707f (Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents: 15092
diff changeset
2584
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
2585 /* :type TYPE (nil: stream, datagram */
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
2586 tem = Fplist_get (contact, QCtype);
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
2587 if (NILP (tem))
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
2588 socktype = SOCK_STREAM;
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
2589 #ifdef DATAGRAM_SOCKETS
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
2590 else if (EQ (tem, Qdatagram))
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
2591 socktype = SOCK_DGRAM;
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
2592 #endif
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
2593 else
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
2594 error ("Unsupported connection type");
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2595
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2596 /* :server BOOL */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2597 tem = Fplist_get (contact, QCserver);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2598 if (!NILP (tem))
25248
f0fc8443bdbb (Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents: 25129
diff changeset
2599 {
45099
8a33d836b6fb (Fmake_network_process): Only support server sockets
Jason Rumney <jasonr@gnu.org>
parents: 45005
diff changeset
2600 /* Don't support network sockets when non-blocking mode is
8a33d836b6fb (Fmake_network_process): Only support server sockets
Jason Rumney <jasonr@gnu.org>
parents: 45005
diff changeset
2601 not available, since a blocked Emacs is not useful. */
8a33d836b6fb (Fmake_network_process): Only support server sockets
Jason Rumney <jasonr@gnu.org>
parents: 45005
diff changeset
2602 #if defined(TERM) || (!defined(O_NONBLOCK) && !defined(O_NDELAY))
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2603 error ("Network servers not supported");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2604 #else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2605 is_server = 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2606 #endif
25248
f0fc8443bdbb (Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents: 25129
diff changeset
2607 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2608
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2609 /* 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
2610 QCaddress = is_server ? QClocal : QCremote;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2611
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2612 /* :wait BOOL */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2613 if (!is_server && socktype == SOCK_STREAM
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2614 && (tem = Fplist_get (contact, QCnowait), !NILP (tem)))
25248
f0fc8443bdbb (Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents: 25129
diff changeset
2615 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2616 #ifndef NON_BLOCKING_CONNECT
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2617 error ("Non-blocking connect not supported");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2618 #else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2619 is_non_blocking_client = 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2620 #endif
25248
f0fc8443bdbb (Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents: 25129
diff changeset
2621 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2622
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2623 name = Fplist_get (contact, QCname);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2624 buffer = Fplist_get (contact, QCbuffer);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2625 filter = Fplist_get (contact, QCfilter);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2626 sentinel = Fplist_get (contact, QCsentinel);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2627
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2628 CHECK_STRING (name);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2629
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2630 #ifdef TERM
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2631 /* 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
2632 host = Fplist_get (contact, QChost);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2633 CHECK_STRING (host);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2634
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2635 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
2636 if (INTEGERP (service))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2637 port = htons ((unsigned short) XINT (service));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2638 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2639 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2640 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
2641 CHECK_STRING (service);
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2642 svc_info = getservbyname (SDATA (service), "tcp");
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2643 if (svc_info == 0)
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2644 error ("Unknown service: %s", SDATA (service));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2645 port = svc_info->s_port;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2646 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2647
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2648 s = connect_server (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2649 if (s < 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2650 report_file_error ("error creating socket", Fcons (name, Qnil));
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2651 send_command (s, C_PORT, 0, "%s:%d", SDATA (host), ntohs (port));
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2652 send_command (s, C_DUMB, 1, 0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2653
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2654 #else /* not TERM */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2655
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2656 /* 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
2657 ai.ai_socktype = socktype;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2658 ai.ai_protocol = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2659 ai.ai_next = NULL;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2660 res = &ai;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2661
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2662 /* :local ADDRESS or :remote ADDRESS */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2663 address = Fplist_get (contact, QCaddress);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2664 if (!NILP (address))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2665 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2666 host = service = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2667
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2668 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
2669 error ("Malformed :address");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2670 ai.ai_family = family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2671 ai.ai_addr = alloca (ai.ai_addrlen);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2672 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
2673 goto open_socket;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2674 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2675
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2676 /* :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
2677 tem = Fplist_get (contact, QCfamily);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2678 if (INTEGERP (tem))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2679 family = XINT (tem);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2680 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2681 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2682 if (NILP (tem))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2683 family = AF_INET;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2684 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2685 else if (EQ (tem, Qlocal))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2686 family = AF_LOCAL;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2687 #endif
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 if (family < 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2690 error ("Unknown address family");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2691 ai.ai_family = family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2692
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2693 /* :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
2694 service = Fplist_get (contact, QCservice);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2695
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2696 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2697 if (family == AF_LOCAL)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2698 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2699 /* Host is not used. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2700 host = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2701 CHECK_STRING (service);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2702 bzero (&address_un, sizeof address_un);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2703 address_un.sun_family = AF_LOCAL;
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2704 strncpy (address_un.sun_path, SDATA (service), sizeof address_un.sun_path);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2705 ai.ai_addr = (struct sockaddr *) &address_un;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2706 ai.ai_addrlen = sizeof address_un;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2707 goto open_socket;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2708 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2709 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2710
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2711 /* :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
2712 host = Fplist_get (contact, QChost);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2713 if (!NILP (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 if (EQ (host, Qlocal))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2716 host = build_string ("localhost");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2717 CHECK_STRING (host);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2718 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2719
13777
5e0cbd5fcb46 (Fopen_network_stream): Call bind_polling_period earlier.
Karl Heuer <kwzh@gnu.org>
parents: 13709
diff changeset
2720 /* 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
2721 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
2722 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
2723 #ifdef POLL_FOR_INPUT
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2724 if (socktype == SOCK_STREAM)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2725 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2726 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
2727 bind_polling_period (10);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2728 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2729 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2730
25248
f0fc8443bdbb (Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents: 25129
diff changeset
2731 #ifdef HAVE_GETADDRINFO
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2732 /* 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
2733 Otherwise, use getservbyname to lookup the service. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2734 if (!NILP (host))
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
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2737 /* 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
2738 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
2739 if (EQ (service, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2740 portstring = "0";
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2741 else if (INTEGERP (service))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2742 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2743 sprintf (portbuf, "%ld", (long) XINT (service));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2744 portstring = portbuf;
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 else
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 CHECK_STRING (service);
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2749 portstring = SDATA (service);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2750 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2751
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2752 immediate_quit = 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2753 QUIT;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2754 memset (&hints, 0, sizeof (hints));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2755 hints.ai_flags = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2756 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
2757 hints.ai_socktype = socktype;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2758 hints.ai_protocol = 0;
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2759 ret = getaddrinfo (SDATA (host), portstring, &hints, &res);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2760 if (ret)
32074
a889f9fc59a7 (Fopen_network_stream): Use HAVE_GAI_STRERROR.
Dave Love <fx@gnu.org>
parents: 32032
diff changeset
2761 #ifdef HAVE_GAI_STRERROR
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2762 error ("%s/%s %s", SDATA (host), portstring, gai_strerror(ret));
32074
a889f9fc59a7 (Fopen_network_stream): Use HAVE_GAI_STRERROR.
Dave Love <fx@gnu.org>
parents: 32032
diff changeset
2763 #else
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2764 error ("%s/%s getaddrinfo error %d", SDATA (host), portstring, ret);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2765 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2766 immediate_quit = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2767
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2768 goto open_socket;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2769 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2770 #endif /* HAVE_GETADDRINFO */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2771
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2772 /* 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
2773 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
2774
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2775 if (EQ (service, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2776 port = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2777 else if (INTEGERP (service))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2778 port = htons ((unsigned short) XINT (service));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2779 else
8287
97c2535b7f37 (Fopen_network_stream): Retry gethostbyname after TRY_AGAIN failure.
Richard M. Stallman <rms@gnu.org>
parents: 8231
diff changeset
2780 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2781 struct servent *svc_info;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2782 CHECK_STRING (service);
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2783 svc_info = getservbyname (SDATA (service),
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2784 (socktype == SOCK_DGRAM ? "udp" : "tcp"));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2785 if (svc_info == 0)
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2786 error ("Unknown service: %s", SDATA (service));
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2787 port = svc_info->s_port;
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
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2790 bzero (&address_in, sizeof address_in);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2791 address_in.sin_family = family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2792 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
2793 address_in.sin_port = port;
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 #ifndef HAVE_GETADDRINFO
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2796 if (!NILP (host))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2797 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2798 struct hostent *host_info_ptr;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2799
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2800 /* 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
2801 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
2802 immediate_quit = 1;
849458c13c0c (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14736
diff changeset
2803 QUIT;
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2804 host_info_ptr = gethostbyname (SDATA (host));
14758
849458c13c0c (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14736
diff changeset
2805 immediate_quit = 0;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2806
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2807 if (host_info_ptr)
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 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
2810 host_info_ptr->h_length);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2811 family = host_info_ptr->h_addrtype;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2812 address_in.sin_family = family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2813 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2814 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2815 /* 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
2816 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2817 IN_ADDR numeric_addr;
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2818 numeric_addr = inet_addr ((char *) SDATA (host));
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2819 if (NUMERIC_ADDR_ERROR)
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
2820 error ("Unknown host \"%s\"", SDATA (host));
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2821
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2822 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
2823 sizeof (address_in.sin_addr));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2824 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2825
8287
97c2535b7f37 (Fopen_network_stream): Retry gethostbyname after TRY_AGAIN failure.
Richard M. Stallman <rms@gnu.org>
parents: 8231
diff changeset
2826 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2827 #endif /* not HAVE_GETADDRINFO */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2828
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2829 ai.ai_family = family;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2830 ai.ai_addr = (struct sockaddr *) &address_in;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2831 ai.ai_addrlen = sizeof address_in;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2832
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2833 open_socket:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2834
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2835 /* 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
2836 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
2837 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
2838 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
2839 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
2840 to quit if polling is turned off. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2841 if (interrupt_input
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2842 && !is_server && socktype == SOCK_STREAM)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2843 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2844 /* 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
2845 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
2846 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
2847 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
2848 record_unwind_protect (unwind_request_sigio, Qnil);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2849 unrequest_sigio ();
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2850 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2851
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2852 /* Do this in case we never enter the for-loop below. */
46293
1fb8f75062c6 Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents: 45410
diff changeset
2853 count1 = SPECPDL_INDEX ();
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2854 s = -1;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2855
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2856 for (lres = res; lres; lres = lres->ai_next)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
2857 {
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2858 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
2859 if (s < 0)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2860 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2861 xerrno = errno;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2862 continue;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2863 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2864
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2865 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2866 if (!is_server && socktype == SOCK_DGRAM)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2867 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2868 #endif /* DATAGRAM_SOCKETS */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2869
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2870 #ifdef NON_BLOCKING_CONNECT
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2871 if (is_non_blocking_client)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2872 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2873 #ifdef O_NONBLOCK
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2874 ret = fcntl (s, F_SETFL, O_NONBLOCK);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2875 #else
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2876 ret = fcntl (s, F_SETFL, O_NDELAY);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2877 #endif
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2878 if (ret < 0)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2879 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2880 xerrno = errno;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2881 emacs_close (s);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2882 s = -1;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2883 continue;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2884 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2885 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2886 #endif
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2887
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2888 /* Make us close S if quit. */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2889 record_unwind_protect (close_file_unwind, make_number (s));
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2890
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2891 if (is_server)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2892 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2893 /* Configure as a server socket. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2894 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2895 if (family != AF_LOCAL)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2896 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2897 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2898 int optval = 1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2899 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
2900 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
2901 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2902
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2903 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
2904 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
2905
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2906 #ifdef HAVE_GETSOCKNAME
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2907 if (EQ (service, Qt))
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 struct sockaddr_in sa1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2910 int len1 = sizeof (sa1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2911 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
2912 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2913 ((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
2914 service = make_number (sa1.sin_port);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2915 contact = Fplist_put (contact, QCservice, service);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2916 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2917 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2918 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2919
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2920 if (socktype == SOCK_STREAM && listen (s, 5))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2921 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
2922
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2923 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2924 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2925
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2926 retry_connect:
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2927
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2928 immediate_quit = 1;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2929 QUIT;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2930
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2931 /* This turns off all alarm-based interrupts; the
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2932 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
2933 short-interval ones off, especially if interrupt_input is
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2934 set.
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 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
2937 though. Would non-blocking connect calls be portable?
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2938
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2939 This used to be conditioned by HAVE_GETADDRINFO. Why? */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2940
43642
bfd9fa0143d9 (Fopen_network_stream): Always call turn_on_atimers around connect.
Kim F. Storm <storm@cua.dk>
parents: 43617
diff changeset
2941 turn_on_atimers (0);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2942
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2943 ret = connect (s, lres->ai_addr, lres->ai_addrlen);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2944 xerrno = errno;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2945
43642
bfd9fa0143d9 (Fopen_network_stream): Always call turn_on_atimers around connect.
Kim F. Storm <storm@cua.dk>
parents: 43617
diff changeset
2946 turn_on_atimers (1);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2947
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2948 if (ret == 0 || xerrno == EISCONN)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2949 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2950 /* The unwind-protect will be discarded afterwards.
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2951 Likewise for immediate_quit. */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2952 break;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2953 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2954
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2955 #ifdef NON_BLOCKING_CONNECT
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2956 #ifdef EINPROGRESS
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2957 if (is_non_blocking_client && xerrno == EINPROGRESS)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2958 break;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2959 #else
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2960 #ifdef EWOULDBLOCK
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2961 if (is_non_blocking_client && xerrno == EWOULDBLOCK)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2962 break;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2963 #endif
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2964 #endif
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2965 #endif
7220
a33eb16cab9d (Fopen_network_stream): Retry the connect if EADDRINUSE. Ignore EISCONN.
Richard M. Stallman <rms@gnu.org>
parents: 7157
diff changeset
2966
14671
0493e857a13b (Fopen_network_stream): Set immediate_quit for the connect.
Richard M. Stallman <rms@gnu.org>
parents: 14613
diff changeset
2967 immediate_quit = 0;
0493e857a13b (Fopen_network_stream): Set immediate_quit for the connect.
Richard M. Stallman <rms@gnu.org>
parents: 14613
diff changeset
2968
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2969 if (xerrno == EINTR)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2970 goto retry_connect;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2971 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
2972 {
12378
3171d5da8a86 (Fopen_network_stream): Sleep 1 sec before connect retry.
Richard M. Stallman <rms@gnu.org>
parents: 12324
diff changeset
2973 /* 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
2974 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
2975 and should be infrequent. */
3171d5da8a86 (Fopen_network_stream): Sleep 1 sec before connect retry.
Richard M. Stallman <rms@gnu.org>
parents: 12324
diff changeset
2976 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
2977 retry++;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2978 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
2979 }
a33eb16cab9d (Fopen_network_stream): Retry the connect if EADDRINUSE. Ignore EISCONN.
Richard M. Stallman <rms@gnu.org>
parents: 7157
diff changeset
2980
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2981 /* Discard the unwind protect closing S. */
25705
1f109108fa7e (Fopen_network_stream): Avoid socket decriptor leak.
Andreas Schwab <schwab@suse.de>
parents: 25645
diff changeset
2982 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
2983 emacs_close (s);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2984 s = -1;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2985 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
2986
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2987 if (s >= 0)
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 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2990 if (socktype == SOCK_DGRAM)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2991 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2992 if (datagram_address[s].sa)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2993 abort ();
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2994 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
2995 datagram_address[s].len = lres->ai_addrlen;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2996 if (is_server)
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 Lisp_Object remote;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
2999 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
3000 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
3001 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3002 int rfamily, rlen;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3003 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
3004 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
3005 conv_lisp_to_sockaddr (rfamily, remote,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3006 datagram_address[s].sa, rlen);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3007 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3008 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3009 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3010 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
3011 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3012 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3013 contact = Fplist_put (contact, QCaddress,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3014 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
3015 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3016
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3017 #ifdef HAVE_GETADDRINFO
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3018 if (res != &ai)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3019 freeaddrinfo (res);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3020 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3021
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3022 immediate_quit = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3023
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3024 /* 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
3025 specpdl_ptr = specpdl + count1;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3026
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3027 /* Unwind bind_polling_period and request_sigio. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3028 unbind_to (count, Qnil);
43598
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 if (s < 0)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3031 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3032 /* 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
3033 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
3034 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
3035 better. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3036 if (is_non_blocking_client)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3037 return Qnil;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3038
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3039 errno = xerrno;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3040 if (is_server)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3041 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
3042 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3043 report_file_error ("make client process failed", contact);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3044 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3045
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3046 tem = Fplist_get (contact, QCoptions);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3047 if (!NILP (tem))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3048 set_socket_options (s, tem, 1);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3049
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3050 #endif /* not TERM */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3051
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3052 inch = s;
17247
351006378b51 (Fopen_network_stream): Use same socket for in and out.
Richard M. Stallman <rms@gnu.org>
parents: 17224
diff changeset
3053 outch = s;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3054
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3055 if (!NILP (buffer))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3056 buffer = Fget_buffer_create (buffer);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3057 proc = make_process (name);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3058
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3059 chan_process[inch] = proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3060
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3061 #ifdef O_NONBLOCK
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3062 fcntl (inch, F_SETFL, O_NONBLOCK);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3063 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3064 #ifdef O_NDELAY
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3065 fcntl (inch, F_SETFL, O_NDELAY);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3066 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3067 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3068
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3069 p = XPROCESS (proc);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3070
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3071 p->childp = contact;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3072 p->buffer = buffer;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3073 p->sentinel = sentinel;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3074 p->filter = filter;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3075 p->log = Fplist_get (contact, QClog);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3076 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
3077 p->kill_without_query = Qt;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3078 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
3079 p->command = Qt;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3080 p->pid = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3081 XSETINT (p->infd, inch);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3082 XSETINT (p->outfd, outch);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3083 if (is_server && socktype == SOCK_STREAM)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3084 p->status = Qlisten;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3085
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3086 #ifdef NON_BLOCKING_CONNECT
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3087 if (is_non_blocking_client)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3088 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3089 /* 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
3090 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
3091 connection. */
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3092 p->status = Qconnect;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3093 if (!FD_ISSET (inch, &connect_wait_mask))
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3094 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3095 FD_SET (inch, &connect_wait_mask);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3096 num_pending_connects++;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3097 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3098 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3099 else
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3100 #endif
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3101 /* 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
3102 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
3103 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
3104 || (EQ (p->status, Qlisten) && NILP (p->command)))
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3105 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3106 FD_SET (inch, &input_wait_mask);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3107 FD_SET (inch, &non_keyboard_wait_mask);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3108 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3109
7044
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3110 if (inch > max_process_desc)
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3111 max_process_desc = inch;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3112
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3113 tem = Fplist_member (contact, QCcoding);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3114 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
3115 tem = Qnil; /* No error message (too late!). */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3116
22019
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3117 {
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3118 /* 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
3119 struct gcpro gcpro1;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3120 /* 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
3121 Lisp_Object coding_systems = Qt;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3122 Lisp_Object args[5], val;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3123
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3124 if (!NILP (tem))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3125 val = XCAR (XCDR (tem));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3126 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
3127 val = Vcoding_system_for_read;
25770
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
3128 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
3129 || (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
3130 /* 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
3131 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
3132 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
3133 CR LF. */
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3134 val = Qnil;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3135 else
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3136 {
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3137 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
3138 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
3139 GCPRO1 (proc);
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3140 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
3141 UNGCPRO;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3142 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
3143 val = XCAR (coding_systems);
22019
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3144 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
3145 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
3146 else
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3147 val = Qnil;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3148 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3149 p->decode_coding_system = val;
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 if (!NILP (tem))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3152 val = XCAR (XCDR (tem));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3153 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
3154 val = Vcoding_system_for_write;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3155 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
3156 val = Qnil;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3157 else
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3158 {
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3159 if (EQ (coding_systems, Qt))
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3160 {
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3161 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
3162 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
3163 GCPRO1 (proc);
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3164 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
3165 UNGCPRO;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3166 }
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3167 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
3168 val = XCDR (coding_systems);
22019
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3169 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
3170 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
3171 else
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3172 val = Qnil;
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3173 }
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3174 p->encode_coding_system = val;
22019
bb9dd4758e7e (Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents: 21978
diff changeset
3175 }
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3176
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3177 if (!proc_decode_coding_system[inch])
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3178 proc_decode_coding_system[inch]
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3179 = (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
3180 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
3181 proc_decode_coding_system[inch]);
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3182 if (!proc_encode_coding_system[outch])
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3183 proc_encode_coding_system[outch]
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
3184 = (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
3185 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
3186 proc_encode_coding_system[outch]);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
3187
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3188 p->decoding_buf = make_uninit_string (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3189 p->decoding_carryover = make_number (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3190 p->encoding_buf = make_uninit_string (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3191 p->encoding_carryover = make_number (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3192
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3193 p->inherit_coding_system_flag
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3194 = (!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
3195 ? Qnil : Qt);
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
3196
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3197 UNGCPRO;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3198 return proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3199 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3200 #endif /* HAVE_SOCKETS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3201
20382
dbad9367d232 (create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents: 20225
diff changeset
3202 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3203 deactivate_process (proc)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3204 Lisp_Object proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3205 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3206 register int inchannel, outchannel;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3207 register struct Lisp_Process *p = XPROCESS (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3208
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3209 inchannel = XINT (p->infd);
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3210 outchannel = XINT (p->outfd);
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3211
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3212 if (inchannel >= 0)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3213 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3214 /* Beware SIGCHLD hereabouts. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3215 flush_pending_output (inchannel);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3216 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3217 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3218 VMS_PROC_STUFF *get_vms_process_pointer (), *vs;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3219 sys$dassgn (outchannel);
2357
9faa3a02ea97 * process.c [VMS] (DCL_PROMPT): Remove hack.
Jim Blandy <jimb@redhat.com>
parents: 2290
diff changeset
3220 vs = get_vms_process_pointer (p->pid);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3221 if (vs)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3222 give_back_vms_process_stuff (vs);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3223 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3224 #else
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
3225 emacs_close (inchannel);
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3226 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
3227 emacs_close (outchannel);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3228 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3229
9277
21f6120be5ba (make_process, create_process, Fopen_network_stream, deactivate_process,
Karl Heuer <kwzh@gnu.org>
parents: 9115
diff changeset
3230 XSETINT (p->infd, -1);
21f6120be5ba (make_process, create_process, Fopen_network_stream, deactivate_process,
Karl Heuer <kwzh@gnu.org>
parents: 9115
diff changeset
3231 XSETINT (p->outfd, -1);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3232 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3233 if (DATAGRAM_CHAN_P (inchannel))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3234 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3235 xfree (datagram_address[inchannel].sa);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3236 datagram_address[inchannel].sa = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3237 datagram_address[inchannel].len = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3238 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3239 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3240 chan_process[inchannel] = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3241 FD_CLR (inchannel, &input_wait_mask);
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
3242 FD_CLR (inchannel, &non_keyboard_wait_mask);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3243 if (FD_ISSET (inchannel, &connect_wait_mask))
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3244 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3245 FD_CLR (inchannel, &connect_wait_mask);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3246 if (--num_pending_connects < 0)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3247 abort ();
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3248 }
7044
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3249 if (inchannel == max_process_desc)
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3250 {
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3251 int i;
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3252 /* 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
3253 so recompute the highest-numbered one now. */
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3254 max_process_desc = 0;
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3255 for (i = 0; i < MAXDESC; i++)
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3256 if (!NILP (chan_process[i]))
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3257 max_process_desc = i;
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
3258 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3259 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3260 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3261
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3262 /* Close all descriptors currently in use for communication
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3263 with subprocess. This is used in a newly-forked subprocess
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3264 to get rid of irrelevant descriptors. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3265
20382
dbad9367d232 (create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents: 20225
diff changeset
3266 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3267 close_process_descs ()
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3268 {
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
3269 #ifndef WINDOWSNT
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3270 int i;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3271 for (i = 0; i < MAXDESC; i++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3272 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3273 Lisp_Object process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3274 process = chan_process[i];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3275 if (!NILP (process))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3276 {
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3277 int in = XINT (XPROCESS (process)->infd);
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3278 int out = XINT (XPROCESS (process)->outfd);
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3279 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
3280 emacs_close (in);
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3281 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
3282 emacs_close (out);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3283 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3284 }
9793
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
3285 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3286 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3287
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3288 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
3289 0, 3, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
3290 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
3291 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
3292 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
3293 from PROCESS.
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
3294 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
3295 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
3296 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
3297 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
3298 (process, timeout, timeout_msecs)
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
3299 register Lisp_Object process, timeout, timeout_msecs;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3300 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3301 int seconds;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3302 int useconds;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3303
24598
078d53377010 (Faccept_process_output): Check validity of PROCESS.
Richard M. Stallman <rms@gnu.org>
parents: 24352
diff changeset
3304 if (! NILP (process))
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
3305 CHECK_PROCESS (process);
24598
078d53377010 (Faccept_process_output): Check validity of PROCESS.
Richard M. Stallman <rms@gnu.org>
parents: 24352
diff changeset
3306
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3307 if (! NILP (timeout_msecs))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3308 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
3309 CHECK_NUMBER (timeout_msecs);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3310 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
3311 if (!INTEGERP (timeout))
9277
21f6120be5ba (make_process, create_process, Fopen_network_stream, deactivate_process,
Karl Heuer <kwzh@gnu.org>
parents: 9115
diff changeset
3312 XSETINT (timeout, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3313
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3314 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3315 int carry = useconds / 1000000;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3316
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3317 XSETINT (timeout, XINT (timeout) + carry);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3318 useconds -= carry * 1000000;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3319
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3320 /* I think this clause is necessary because C doesn't
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3321 guarantee a particular rounding direction for negative
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3322 integers. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3323 if (useconds < 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3324 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3325 XSETINT (timeout, XINT (timeout) - 1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3326 useconds += 1000000;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3327 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3328 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3329 }
1180
9bf82484415d (Faccept_process_output): Initialize useconds.
Richard M. Stallman <rms@gnu.org>
parents: 1047
diff changeset
3330 else
9bf82484415d (Faccept_process_output): Initialize useconds.
Richard M. Stallman <rms@gnu.org>
parents: 1047
diff changeset
3331 useconds = 0;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3332
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3333 if (! NILP (timeout))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3334 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
3335 CHECK_NUMBER (timeout);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3336 seconds = XINT (timeout);
14605
80196bfd8b94 (Faccept_process_output): Accept sub-second timeouts.
Erik Naggum <erik@naggum.no>
parents: 14544
diff changeset
3337 if (seconds < 0 || (seconds == 0 && useconds == 0))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3338 seconds = -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3339 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3340 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3341 {
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
3342 if (NILP (process))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3343 seconds = -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3344 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3345 seconds = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3346 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3347
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
3348 if (NILP (process))
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
3349 XSETFASTINT (process, 0);
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3350
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3351 return
14085
85ce7bab31dc (Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents: 14036
diff changeset
3352 (wait_reading_process_input (seconds, useconds, process, 0)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3353 ? Qt : Qnil);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3354 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3355
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3356 /* 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
3357
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3358 static int connect_counter = 0;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3359
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3360 static void
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3361 server_accept_connection (server, channel)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3362 Lisp_Object server;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3363 int channel;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3364 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3365 Lisp_Object proc, caller, name, buffer;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3366 Lisp_Object contact, host, service;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3367 struct Lisp_Process *ps= XPROCESS (server);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3368 struct Lisp_Process *p;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3369 int s;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3370 union u_sockaddr {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3371 struct sockaddr sa;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3372 struct sockaddr_in in;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3373 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3374 struct sockaddr_un un;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3375 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3376 } saddr;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3377 int len = sizeof saddr;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3378
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3379 s = accept (channel, &saddr.sa, &len);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3380
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3381 if (s < 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3382 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3383 int code = errno;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3384
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3385 if (code == EAGAIN)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3386 return;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3387 #ifdef EWOULDBLOCK
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3388 if (code == EWOULDBLOCK)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3389 return;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3390 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3391
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3392 if (!NILP (ps->log))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3393 call3 (ps->log, server, Qnil,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3394 concat3 (build_string ("accept failed with code"),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3395 Fnumber_to_string (make_number (code)),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3396 build_string ("\n")));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3397 return;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3398 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3399
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3400 connect_counter++;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3401
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3402 /* 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
3403
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3404 /* 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
3405 information for this process. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3406 host = Qt;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3407 service = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3408 switch (saddr.sa.sa_family)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3409 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3410 case AF_INET:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3411 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3412 Lisp_Object args[5];
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3413 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
3414 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
3415 args[1] = make_number (*ip++);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3416 args[2] = make_number (*ip++);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3417 args[3] = make_number (*ip++);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3418 args[4] = make_number (*ip++);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3419 host = Fformat (5, args);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3420 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
3421
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3422 args[0] = build_string (" <%s:%d>");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3423 args[1] = host;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3424 args[2] = service;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3425 caller = Fformat (3, args);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3426 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3427 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3428
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3429 #ifdef HAVE_LOCAL_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3430 case AF_LOCAL:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3431 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3432 default:
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3433 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
3434 caller = concat3 (build_string (" <*"), caller, build_string ("*>"));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3435 break;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3436 }
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 /* 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
3439 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
3440 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
3441 identification. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3442
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3443 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
3444 buffer = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3445 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3446 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3447 buffer = ps->buffer;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3448 if (!NILP (buffer))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3449 buffer = Fbuffer_name (buffer);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3450 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3451 buffer = ps->name;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3452 if (!NILP (buffer))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3453 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3454 buffer = concat2 (buffer, caller);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3455 buffer = Fget_buffer_create (buffer);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3456 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3457 }
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 /* 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
3460 server process name with the caller identification. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3461
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3462 name = concat2 (ps->name, caller);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3463 proc = make_process (name);
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 chan_process[s] = proc;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3466
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3467 #ifdef O_NONBLOCK
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3468 fcntl (s, F_SETFL, O_NONBLOCK);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3469 #else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3470 #ifdef O_NDELAY
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3471 fcntl (s, F_SETFL, O_NDELAY);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3472 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3473 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3474
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3475 p = XPROCESS (proc);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3476
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3477 /* Build new contact information for this setup. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3478 contact = Fcopy_sequence (ps->childp);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3479 contact = Fplist_put (contact, QCserver, Qnil);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3480 contact = Fplist_put (contact, QChost, host);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3481 if (!NILP (service))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3482 contact = Fplist_put (contact, QCservice, service);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3483 contact = Fplist_put (contact, QCremote,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3484 conv_sockaddr_to_lisp (&saddr.sa, len));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3485 #ifdef HAVE_GETSOCKNAME
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3486 len = sizeof saddr;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3487 if (getsockname (channel, &saddr.sa, &len) == 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3488 contact = Fplist_put (contact, QClocal,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3489 conv_sockaddr_to_lisp (&saddr.sa, len));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3490 #endif
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 p->childp = contact;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3493 p->buffer = buffer;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3494 p->sentinel = ps->sentinel;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3495 p->filter = ps->filter;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3496 p->command = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3497 p->pid = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3498 XSETINT (p->infd, s);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3499 XSETINT (p->outfd, s);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3500 p->status = Qrun;
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 /* 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
3503 if (!EQ (p->filter, Qt))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3504 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3505 FD_SET (s, &input_wait_mask);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3506 FD_SET (s, &non_keyboard_wait_mask);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3507 }
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 if (s > max_process_desc)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3510 max_process_desc = s;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3511
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3512 /* 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
3513 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
3514 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
3515 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
3516
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3517 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
3518 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
3519
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3520 if (!proc_decode_coding_system[s])
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3521 proc_decode_coding_system[s]
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3522 = (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
3523 setup_coding_system (p->decode_coding_system,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3524 proc_decode_coding_system[s]);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3525 if (!proc_encode_coding_system[s])
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3526 proc_encode_coding_system[s]
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3527 = (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
3528 setup_coding_system (p->encode_coding_system,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3529 proc_encode_coding_system[s]);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3530
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3531 p->decoding_buf = make_uninit_string (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3532 p->decoding_carryover = make_number (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3533 p->encoding_buf = make_uninit_string (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3534 p->encoding_carryover = make_number (0);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3535
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3536 p->inherit_coding_system_flag
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3537 = (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
3538
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3539 if (!NILP (ps->log))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3540 call3 (ps->log, server, proc,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3541 concat3 (build_string ("accept from "),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3542 (STRINGP (host) ? host : build_string ("-")),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3543 build_string ("\n")));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3544
44314
f76a1425eb34 (DATAGRAM_CONN_P, list_processes_1)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 44194
diff changeset
3545 if (!NILP (p->sentinel))
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3546 exec_sentinel (proc,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3547 concat3 (build_string ("open from "),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3548 (STRINGP (host) ? host : build_string ("-")),
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3549 build_string ("\n")));
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3550 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
3551
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3552 /* This variable is different from waiting_for_input in keyboard.c.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3553 It is used to communicate to a lisp process-filter/sentinel (via the
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3554 function Fwaiting_for_user_input_p below) whether emacs was waiting
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3555 for user-input when that process-filter was called.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3556 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
3557 lisp code is being evalled.
dd3dfde8f973 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 8390
diff changeset
3558 This is also used in record_asynch_buffer_change.
dd3dfde8f973 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 8390
diff changeset
3559 For that purpose, this must be 0
dd3dfde8f973 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 8390
diff changeset
3560 when not inside wait_reading_process_input. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3561 static int waiting_for_user_input_p;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3562
14890
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3563 /* This is here so breakpoints can be put on it. */
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
3564 static void
14890
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3565 wait_reading_process_input_1 ()
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3566 {
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3567 }
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3568
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3569 /* Read and dispose of subprocess output while waiting for timeout to
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3570 elapse and/or keyboard input to be available.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3571
3953
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3572 TIME_LIMIT is:
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3573 timeout in seconds, or
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3574 zero for no limit, or
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3575 -1 means gobble data immediately available but don't wait for any.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3576
3953
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3577 MICROSECS is:
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3578 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
3579 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
3580 consists of MICROSECS only.
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3581
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3582 READ_KBD is a lisp value:
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3583 0 to ignore keyboard input, or
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3584 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
3585 -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
3586 the quit handler, or
6569
9cde1228e2fa Fix typos in comments.
Karl Heuer <kwzh@gnu.org>
parents: 6515
diff changeset
3587 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
3588 (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
3589 a process object, meaning wait until something arrives from that
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3590 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
3591 that process.
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3592
3953
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3593 DO_DISPLAY != 0 means redisplay should be done to show subprocess
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3594 output that arrives.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3595
3953
d0c23febc08c (wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents: 3915
diff changeset
3596 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
3597 function returns true iff we received input from that process
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3598 before the timeout elapsed.
3591
507f64624555 Apply typo patches from Paul Eggert.
Jim Blandy <jimb@redhat.com>
parents: 3510
diff changeset
3599 Otherwise, return true iff we received input from any process. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3600
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
3601 int
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3602 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
3603 int time_limit, microsecs;
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3604 Lisp_Object read_kbd;
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3605 int do_display;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3606 {
25770
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
3607 register int channel, nfds;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3608 static SELECT_TYPE Available;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3609 static SELECT_TYPE Connecting;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3610 int check_connect, no_avail;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3611 int xerrno;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3612 Lisp_Object proc;
25770
3a44b5298cd5 (list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents: 25760
diff changeset
3613 EMACS_TIME timeout, end_time;
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3614 int wait_channel = -1;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3615 struct Lisp_Process *wait_proc = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3616 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
3617 /* 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
3618 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
3619 Lisp_Object wait_for_cell = Qnil;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3620
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3621 FD_ZERO (&Available);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3622 FD_ZERO (&Connecting);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3623
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3624 /* 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
3625 accordingly. */
9115
59bc2d010b5f (decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents: 9034
diff changeset
3626 if (PROCESSP (read_kbd))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3627 {
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3628 wait_proc = XPROCESS (read_kbd);
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
3629 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
3630 XSETFASTINT (read_kbd, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3631 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3632
2200
5e58643bb169 (wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents: 2120
diff changeset
3633 /* 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
3634 if (CONSP (read_kbd))
2200
5e58643bb169 (wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents: 2120
diff changeset
3635 {
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
3636 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
3637 XSETFASTINT (read_kbd, 0);
2200
5e58643bb169 (wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents: 2120
diff changeset
3638 }
5e58643bb169 (wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents: 2120
diff changeset
3639
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3640 waiting_for_user_input_p = XINT (read_kbd);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3641
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3642 /* Since we may need to wait several times,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3643 compute the absolute time to return at. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3644 if (time_limit || microsecs)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3645 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3646 EMACS_GET_TIME (end_time);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3647 EMACS_SET_SECS_USECS (timeout, time_limit, microsecs);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3648 EMACS_ADD_TIME (end_time, end_time, timeout);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3649 }
15661
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
3650 #ifdef hpux
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
3651 /* AlainF 5-Jul-1996
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
3652 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
3653 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
3654 in an X window
47431
8871e67384e4 (wait_reading_process_input, both versions):
Richard M. Stallman <rms@gnu.org>
parents: 47020
diff changeset
3655 Turn off periodic alarms (in case they are in use),
8871e67384e4 (wait_reading_process_input, both versions):
Richard M. Stallman <rms@gnu.org>
parents: 47020
diff changeset
3656 and then turn off any other atimers. */
8871e67384e4 (wait_reading_process_input, both versions):
Richard M. Stallman <rms@gnu.org>
parents: 47020
diff changeset
3657 stop_polling ();
27430
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
3658 turn_on_atimers (0);
15661
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
3659 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3660
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3661 while (1)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3662 {
14458
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3663 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
3664
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3665 /* If calling from keyboard input, do not quit
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3666 since we want to return C-g as an input character.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3667 Otherwise, do pending quit if requested. */
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
3668 if (XINT (read_kbd) >= 0)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3669 QUIT;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3670
4639
76f242eb1fa8 Include syswait.h.
Richard M. Stallman <rms@gnu.org>
parents: 4320
diff changeset
3671 /* 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
3672 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
3673 break;
76f242eb1fa8 Include syswait.h.
Richard M. Stallman <rms@gnu.org>
parents: 4320
diff changeset
3674
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3675 /* Compute time from now till when time limit is up */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3676 /* Exit if already run out */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3677 if (time_limit == -1)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3678 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3679 /* -1 specified for timeout means
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3680 gobble output available now
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3681 but don't wait at all. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3682
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3683 EMACS_SET_SECS_USECS (timeout, 0, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3684 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3685 else if (time_limit || microsecs)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3686 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3687 EMACS_GET_TIME (timeout);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3688 EMACS_SUB_TIME (timeout, end_time, timeout);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3689 if (EMACS_TIME_NEG_P (timeout))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3690 break;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3691 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3692 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3693 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3694 EMACS_SET_SECS_USECS (timeout, 100000, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3695 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3696
15064
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
3697 /* Normally we run timers here.
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
3698 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
3699 the wait is supposed to be short,
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
3700 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
3701 if (NILP (wait_for_cell))
14404
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
3702 {
14458
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3703 EMACS_TIME timer_delay;
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3704
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3705 do
14890
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3706 {
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3707 int old_timers_run = timers_run;
37465
f790d83ea743 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 37413
diff changeset
3708 struct buffer *old_buffer = current_buffer;
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3709
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3710 timer_delay = timer_check (1);
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3711
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3712 /* 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
3713 an alike. Make read_key_sequence aware of that. */
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3714 if (timers_run != old_timers_run
37465
f790d83ea743 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 37413
diff changeset
3715 && old_buffer != current_buffer
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3716 && waiting_for_user_input_p == -1)
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3717 record_asynch_buffer_change ();
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3718
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3719 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
3720 /* 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
3721 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
3722 redisplay_preserve_echo_area (9);
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3723 else
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3724 break;
14890
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3725 }
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
3726 while (!detect_input_pending ());
14890
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3727
18230
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
3728 /* 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
3729 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
3730 && requeued_events_pending_p ())
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
3731 break;
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
3732
14458
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3733 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
3734 {
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
3735 EMACS_TIME difference;
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
3736 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
3737 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
3738 {
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3739 timeout = timer_delay;
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3740 timeout_reduced_for_timers = 1;
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3741 }
14404
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
3742 }
14935
3e0dc64a5cb8 (wait_reading_process_input): Don't call
Richard M. Stallman <rms@gnu.org>
parents: 14890
diff changeset
3743 /* 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
3744 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
3745 {
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3746 /* 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
3747 wait_reading_process_input_1 ();
71c2cf461805 (wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents: 14863
diff changeset
3748 }
14404
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
3749 }
cba05f90ee57 (wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents: 14278
diff changeset
3750
2894
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3751 /* 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
3752 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
3753
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3754 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
3755 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
3756 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
3757 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
3758 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
3759
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3760 /* 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
3761 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
3762 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
3763 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
3764 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
3765 {
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3766 SELECT_TYPE Atemp, Ctemp;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3767
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3768 Atemp = input_wait_mask;
44890
01b93e5e53a7 Patch for building Emacs on Mac OS X. April 26, 2002. See ChangeLog,
Andrew Choi <akochoi@shaw.ca>
parents: 44372
diff changeset
3769 #ifdef MAC_OSX
01b93e5e53a7 Patch for building Emacs on Mac OS X. April 26, 2002. See ChangeLog,
Andrew Choi <akochoi@shaw.ca>
parents: 44372
diff changeset
3770 /* On Mac OS X, the SELECT system call always says input is
01b93e5e53a7 Patch for building Emacs on Mac OS X. April 26, 2002. See ChangeLog,
Andrew Choi <akochoi@shaw.ca>
parents: 44372
diff changeset
3771 present (for reading) at stdin, even when none is. This
45318
b80d723ad7cc Fix typo.
Juanma Barranquero <lekktu@gmail.com>
parents: 45118
diff changeset
3772 causes the call to SELECT below to return 1 and
44890
01b93e5e53a7 Patch for building Emacs on Mac OS X. April 26, 2002. See ChangeLog,
Andrew Choi <akochoi@shaw.ca>
parents: 44372
diff changeset
3773 status_notify not to be called. As a result output of
01b93e5e53a7 Patch for building Emacs on Mac OS X. April 26, 2002. See ChangeLog,
Andrew Choi <akochoi@shaw.ca>
parents: 44372
diff changeset
3774 subprocesses are incorrectly discarded. */
01b93e5e53a7 Patch for building Emacs on Mac OS X. April 26, 2002. See ChangeLog,
Andrew Choi <akochoi@shaw.ca>
parents: 44372
diff changeset
3775 FD_CLR (0, &Atemp);
01b93e5e53a7 Patch for building Emacs on Mac OS X. April 26, 2002. See ChangeLog,
Andrew Choi <akochoi@shaw.ca>
parents: 44372
diff changeset
3776 #endif
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3777 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
3778 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
3779 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
3780 &Atemp,
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3781 (num_pending_connects > 0 ? &Ctemp : (SELECT_TYPE *)0),
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3782 (SELECT_TYPE *)0, &timeout)
11926
40d7e6f04ebe (create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents: 11845
diff changeset
3783 <= 0))
2894
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3784 {
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3785 /* 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
3786 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
3787 clear_waiting_for_input ();
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3788 status_notify ();
646c5beae647 * process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents: 2893
diff changeset
3789 }
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3790 }
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3791
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3792 /* 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
3793 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
3794 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
3795 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
3796 if (wait_proc != 0
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3797 && ! EQ (wait_proc->status, Qrun)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3798 && ! 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
3799 {
18946
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3800 int nread, total_nread = 0;
18267
29c37882ee1f (wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents: 18230
diff changeset
3801
2893
4df57953d5d0 * process.c (wait_reading_process_input): Don't forget to call
Jim Blandy <jimb@redhat.com>
parents: 2887
diff changeset
3802 clear_waiting_for_input ();
18267
29c37882ee1f (wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents: 18230
diff changeset
3803 XSETPROCESS (proc, wait_proc);
29c37882ee1f (wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents: 18230
diff changeset
3804
29c37882ee1f (wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents: 18230
diff changeset
3805 /* 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
3806 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
3807 {
25894
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3808 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
3809
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3810 if (nread == 0)
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3811 break;
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3812
18946
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3813 if (0 < nread)
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3814 total_nread += nread;
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3815 #ifdef EIO
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3816 else if (nread == -1 && EIO == errno)
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3817 break;
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3818 #endif
25894
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3819 #ifdef EAGAIN
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3820 else if (nread == -1 && EAGAIN == errno)
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3821 break;
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3822 #endif
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3823 #ifdef EWOULDBLOCK
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3824 else if (nread == -1 && EWOULDBLOCK == errno)
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3825 break;
8bd3e6fbf42f (wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents: 25770
diff changeset
3826 #endif
18946
84b78d90cd45 (wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents: 18739
diff changeset
3827 }
18267
29c37882ee1f (wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents: 18230
diff changeset
3828 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
3829 redisplay_preserve_echo_area (10);
18267
29c37882ee1f (wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents: 18230
diff changeset
3830
2893
4df57953d5d0 * process.c (wait_reading_process_input): Don't forget to call
Jim Blandy <jimb@redhat.com>
parents: 2887
diff changeset
3831 break;
4df57953d5d0 * process.c (wait_reading_process_input): Don't forget to call
Jim Blandy <jimb@redhat.com>
parents: 2887
diff changeset
3832 }
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
3833
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3834 /* Wait till there is something to do */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3835
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
3836 if (!NILP (wait_for_cell))
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3837 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3838 Available = non_process_wait_mask;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3839 check_connect = 0;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3840 }
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
3841 else
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3842 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3843 if (! XINT (read_kbd))
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3844 Available = non_keyboard_wait_mask;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3845 else
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3846 Available = input_wait_mask;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3847 check_connect = (num_pending_connects > 0);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3848 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3849
765
e4093444f9f8 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 692
diff changeset
3850 /* 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
3851 redisplay now, before we start to wait. There is a race
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
3852 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
3853 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
3854 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
3855 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
3856 {
affed1766d34 (wait_reading_process_input): Don't call prepare_menu_bars.
Richard M. Stallman <rms@gnu.org>
parents: 11695
diff changeset
3857 clear_waiting_for_input ();
35336
002c02db42d3 Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents: 34660
diff changeset
3858 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
3859 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
3860 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
3861 }
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
3862
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3863 no_avail = 0;
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
3864 if (XINT (read_kbd) && detect_input_pending ())
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
3865 {
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
3866 nfds = 0;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3867 no_avail = 1;
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
3868 }
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
3869 else
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3870 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3871 if (check_connect)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3872 Connecting = connect_wait_mask;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3873 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
3874 &Available,
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3875 (check_connect ? &Connecting : (SELECT_TYPE *)0),
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3876 (SELECT_TYPE *)0, &timeout);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3877 }
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
3878
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3879 xerrno = errno;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3880
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3881 /* Make C-g and alarm signals set flags again */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3882 clear_waiting_for_input ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3883
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3884 /* 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
3885 do_pending_window_change (0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3886
14458
2bb4652305c1 (wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents: 14405
diff changeset
3887 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
3888 /* We wanted the full specified time, so return now. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3889 break;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3890 if (nfds < 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3891 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3892 if (xerrno == EINTR)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3893 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
3894 #ifdef ultrix
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
3895 /* 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
3896 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
3897 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
3898 "__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
3899 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
3900 else if (xerrno == ENOMEM)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3901 no_avail = 1;
1323
25b5b55a3916 * process.c (wait_reading_process_input): If the select returns
Jim Blandy <jimb@redhat.com>
parents: 1207
diff changeset
3902 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3903 #ifdef ALLIANT
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3904 /* This happens for no known reason on ALLIANT.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3905 I am guessing that this is the right response. -- RMS. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3906 else if (xerrno == EFAULT)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3907 no_avail = 1;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3908 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3909 else if (xerrno == EBADF)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3910 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3911 #ifdef AIX
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3912 /* AIX doesn't handle PTY closure the same way BSD does. On AIX,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3913 the child's closure of the pts gives the parent a SIGHUP, and
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3914 the ptc file descriptor is automatically closed,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3915 yielding EBADF here or at select() call above.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3916 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
3917 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
3918 Cleanup occurs c/o status_notify after SIGCLD. */
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3919 no_avail = 1; /* Cannot depend on values returned */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3920 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3921 abort ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3922 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3923 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3924 else
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
3925 error ("select error: %s", emacs_strerror (xerrno));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3926 }
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3927
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3928 if (no_avail)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3929 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3930 FD_ZERO (&Available);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3931 check_connect = 0;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3932 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3933
2815
60f122cfe785 * process.c (wait_reading_process_input): If we're running
Jim Blandy <jimb@redhat.com>
parents: 2610
diff changeset
3934 #if defined(sun) && !defined(USG5_4)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3935 if (nfds > 0 && keyboard_bit_set (&Available)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
3936 && interrupt_input)
2830
006c7fbdeab7 Document sun change.
Jim Blandy <jimb@redhat.com>
parents: 2815
diff changeset
3937 /* System sometimes fails to deliver SIGIO.
006c7fbdeab7 Document sun change.
Jim Blandy <jimb@redhat.com>
parents: 2815
diff changeset
3938
006c7fbdeab7 Document sun change.
Jim Blandy <jimb@redhat.com>
parents: 2815
diff changeset
3939 David J. Mackenzie says that Emacs doesn't compile under
006c7fbdeab7 Document sun change.
Jim Blandy <jimb@redhat.com>
parents: 2815
diff changeset
3940 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
3941 conditional. "I haven't noticed any ill effects so far.
006c7fbdeab7 Document sun change.
Jim Blandy <jimb@redhat.com>
parents: 2815
diff changeset
3942 If you find a Solaris expert somewhere, they might know
006c7fbdeab7 Document sun change.
Jim Blandy <jimb@redhat.com>
parents: 2815
diff changeset
3943 better." */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3944 kill (getpid (), SIGIO);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3945 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3946
18378
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
3947 #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
3948 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
3949 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
3950 /* 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
3951 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
3952 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
3953 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
3954 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
3955 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
3956 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
3957 && keyboard_bit_set (&Available)
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
3958 && input_polling_used ())
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
3959 kill (getpid (), SIGALRM);
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
3960 #endif
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
3961
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3962 /* Check for keyboard input */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3963 /* If there is any, return immediately
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3964 to give it higher priority than subprocesses */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
3965
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3966 if (XINT (read_kbd) != 0)
14613
386831bc4a4e (wait_reading_process_input):
Karl Heuer <kwzh@gnu.org>
parents: 14605
diff changeset
3967 {
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3968 int old_timers_run = timers_run;
37465
f790d83ea743 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 37413
diff changeset
3969 struct buffer *old_buffer = current_buffer;
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3970 int leave = 0;
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3971
14758
849458c13c0c (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14736
diff changeset
3972 if (detect_input_pending_run_timers (do_display))
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3973 {
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3974 swallow_events (do_display);
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3975 if (detect_input_pending_run_timers (do_display))
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3976 leave = 1;
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3977 }
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3978
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3979 /* 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
3980 an alike. Make read_key_sequence aware of that. */
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3981 if (timers_run != old_timers_run
37465
f790d83ea743 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 37413
diff changeset
3982 && waiting_for_user_input_p == -1
f790d83ea743 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 37413
diff changeset
3983 && old_buffer != current_buffer)
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3984 record_asynch_buffer_change ();
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3985
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3986 if (leave)
14613
386831bc4a4e (wait_reading_process_input):
Karl Heuer <kwzh@gnu.org>
parents: 14605
diff changeset
3987 break;
37398
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3988 }
756d2f4e4058 (wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents: 36659
diff changeset
3989
18230
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
3990 /* 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
3991 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
3992 && requeued_events_pending_p ())
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
3993 break;
2f1f942f25ca (wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents: 18183
diff changeset
3994
19053
7b5642657857 (read_process_output): Don't call setup_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 18974
diff changeset
3995 /* 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
3996 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
3997 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
3998 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
3999 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
4000
7b5642657857 (read_process_output): Don't call setup_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 18974
diff changeset
4001 (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
4002 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
4003 {
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
4004 swallow_events (do_display);
18492
668304de6f92 (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 18378
diff changeset
4005 #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
4006 if (detect_input_pending ())
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
4007 break;
18492
668304de6f92 (wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents: 18378
diff changeset
4008 #endif
15064
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
4009 }
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
4010
2200
5e58643bb169 (wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents: 2120
diff changeset
4011 /* 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
4012 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
4013 break;
5e58643bb169 (wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents: 2120
diff changeset
4014
621
eca8812e61cd *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
4015 #ifdef SIGIO
18378
22cd8d7dd5aa (wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents: 18329
diff changeset
4016 /* 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
4017 go read it. This can happen with X on BSD after logging out.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4018 In that case, there really is no input and no SIGIO,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4019 but select says there is input. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4020
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
4021 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
4022 && 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
4023 kill (getpid (), SIGIO);
621
eca8812e61cd *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 604
diff changeset
4024 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4025
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4026 if (! wait_proc)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4027 got_some_input |= nfds > 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4028
624
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
4029 /* 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
4030 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
4031 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
4032 do_pending_window_change (0);
624
2bb7f23b7ea5 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 621
diff changeset
4033
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
4034 /* Check for data from a process. */
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4035 if (no_avail || nfds == 0)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4036 continue;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4037
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
4038 /* Really FIRST_PROC_DESC should be 0 on Unix,
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
4039 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
4040 for (channel = 0; channel <= max_process_desc; channel++)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4041 {
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
4042 if (FD_ISSET (channel, &Available)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
4043 && FD_ISSET (channel, &non_keyboard_wait_mask))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4044 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4045 int nread;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4046
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4047 /* If waiting for this channel, arrange to return as
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4048 soon as no more input to be processed. No more
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4049 waiting. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4050 if (wait_channel == channel)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4051 {
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
4052 wait_channel = -1;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4053 time_limit = -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4054 got_some_input = 1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4055 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4056 proc = chan_process[channel];
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4057 if (NILP (proc))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4058 continue;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4059
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4060 /* 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
4061 if (EQ (XPROCESS (proc)->status, Qlisten))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4062 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4063 server_accept_connection (proc, channel);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4064 continue;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4065 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4066
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4067 /* Read data from the process, starting with our
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4068 buffered-ahead character if we have one. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4069
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4070 nread = read_process_output (proc, channel);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4071 if (nread > 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4072 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4073 /* Since read_process_output can run a filter,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4074 which can call accept-process-output,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4075 don't try to read from any other processes
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4076 before doing the select again. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4077 FD_ZERO (&Available);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4078
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4079 if (do_display)
35336
002c02db42d3 Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents: 34660
diff changeset
4080 redisplay_preserve_echo_area (12);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4081 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4082 #ifdef EWOULDBLOCK
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4083 else if (nread == -1 && errno == EWOULDBLOCK)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4084 ;
15405
c27bb6e69e2d (wait_reading_process_input): Move the O_NONBLOCK and
Richard M. Stallman <rms@gnu.org>
parents: 15368
diff changeset
4085 #endif
15406
7c205bc80624 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 15405
diff changeset
4086 /* ISC 4.1 defines both EWOULDBLOCK and O_NONBLOCK,
7c205bc80624 Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 15405
diff changeset
4087 and Emacs uses O_NONBLOCK, so what we get is EAGAIN. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4088 #ifdef O_NONBLOCK
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4089 else if (nread == -1 && errno == EAGAIN)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4090 ;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4091 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4092 #ifdef O_NDELAY
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4093 else if (nread == -1 && errno == EAGAIN)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4094 ;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4095 /* Note that we cannot distinguish between no input
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4096 available now and a closed pipe.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4097 With luck, a closed pipe will be accompanied by
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4098 subprocess termination and SIGCHLD. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4099 else if (nread == 0 && !NETCONN_P (proc))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4100 ;
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4101 #endif /* O_NDELAY */
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4102 #endif /* O_NONBLOCK */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4103 #ifdef HAVE_PTYS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4104 /* On some OSs with ptys, when the process on one end of
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4105 a pty exits, the other end gets an error reading with
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4106 errno = EIO instead of getting an EOF (0 bytes read).
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4107 Therefore, if we get an error reading and errno =
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4108 EIO, just continue, because the child process has
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4109 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
4110 get a SIGCHLD).
8d68b82a4d8c (wait_reading_process_input): If a pty gives EIO,
Richard M. Stallman <rms@gnu.org>
parents: 22939
diff changeset
4111
8d68b82a4d8c (wait_reading_process_input): If a pty gives EIO,
Richard M. Stallman <rms@gnu.org>
parents: 22939
diff changeset
4112 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
4113 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
4114 It can't hurt. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4115 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
4116 kill (getpid (), SIGCHLD);
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4117 #endif /* HAVE_PTYS */
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4118 /* If we can detect process termination, don't consider the process
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4119 gone just because its pipe is closed. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4120 #ifdef SIGCHLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4121 else if (nread == 0 && !NETCONN_P (proc))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4122 ;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4123 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4124 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4125 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4126 /* Preserve status of processes already terminated. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4127 XSETINT (XPROCESS (proc)->tick, ++process_tick);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4128 deactivate_process (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4129 if (!NILP (XPROCESS (proc)->raw_status_low))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4130 update_status (XPROCESS (proc));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4131 if (EQ (XPROCESS (proc)->status, Qrun))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4132 XPROCESS (proc)->status
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4133 = Fcons (Qexit, Fcons (make_number (256), Qnil));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4134 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4135 }
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4136 #ifdef NON_BLOCKING_CONNECT
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4137 if (check_connect && FD_ISSET (channel, &Connecting))
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4138 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4139 struct Lisp_Process *p;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4140
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4141 FD_CLR (channel, &connect_wait_mask);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4142 if (--num_pending_connects < 0)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4143 abort ();
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4144
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4145 proc = chan_process[channel];
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4146 if (NILP (proc))
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4147 continue;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4148
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4149 p = XPROCESS (proc);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4150
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4151 #ifdef GNU_LINUX
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4152 /* 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
4153 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
4154 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4155 int xlen = sizeof(xerrno);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4156 if (getsockopt(channel, SOL_SOCKET, SO_ERROR, &xerrno, &xlen))
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4157 xerrno = errno;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4158 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4159 #else
44013
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4160 {
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4161 struct sockaddr pname;
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4162 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
4163
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4164 /* 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
4165 xerrno = 0;
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4166 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
4167 {
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4168 /* 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
4169 char dummy;
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4170 xerrno = errno;
44013
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4171 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
4172 xerrno = errno;
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4173 }
da239fc7bb6c (wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents: 43999
diff changeset
4174 }
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4175 #endif
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4176 if (xerrno)
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4177 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4178 XSETINT (p->tick, ++process_tick);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4179 p->status = Fcons (Qfailed, Fcons (make_number (xerrno), Qnil));
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4180 deactivate_process (proc);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4181 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4182 else
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4183 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4184 p->status = Qrun;
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4185 /* Execute the sentinel here. If we had relied on
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4186 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
4187 from the process before calling the sentinel. */
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4188 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
4189 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
4190 {
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4191 FD_SET (XINT (p->infd), &input_wait_mask);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4192 FD_SET (XINT (p->infd), &non_keyboard_wait_mask);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4193 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4194 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4195 }
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
4196 #endif /* NON_BLOCKING_CONNECT */
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4197 } /* end for each file descriptor */
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4198 } /* end while exit conditions not met */
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4199
8570
dd3dfde8f973 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 8390
diff changeset
4200 waiting_for_user_input_p = 0;
dd3dfde8f973 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 8390
diff changeset
4201
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4202 /* If calling from keyboard input, do not quit
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4203 since we want to return C-g as an input character.
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4204 Otherwise, do pending quit if requested. */
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
4205 if (XINT (read_kbd) >= 0)
648
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4206 {
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4207 /* Prevent input_pending from remaining set if we quit. */
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4208 clear_input_pending ();
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4209 QUIT;
70b112526394 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 638
diff changeset
4210 }
15661
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
4211 #ifdef hpux
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
4212 /* AlainF 5-Jul-1996
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
4213 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
4214 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
4215 in an X window
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
4216 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
4217 start_polling ();
15661
96debed5fb36 (wait_reading_process_input) [hpux]: Workaround for
Karl Heuer <kwzh@gnu.org>
parents: 15406
diff changeset
4218 #endif
25009
5733af0b62ce (wait_reading_process_input): Show and hide busy
Gerd Moellmann <gerd@gnu.org>
parents: 24933
diff changeset
4219
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4220 return got_some_input;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4221 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4222
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4223 /* 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
4224
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4225 static Lisp_Object
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4226 read_process_output_call (fun_and_args)
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4227 Lisp_Object fun_and_args;
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4228 {
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
4229 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
4230 }
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4231
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4232 static Lisp_Object
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4233 read_process_output_error_handler (error)
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4234 Lisp_Object error;
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4235 {
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4236 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
4237 Vinhibit_quit = Qt;
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4238 update_echo_area ();
11277
d4547e4b0aab (read_process_output_error_handler)
Richard M. Stallman <rms@gnu.org>
parents: 11235
diff changeset
4239 Fsleep_for (make_number (2), Qnil);
27558
f99efd14b932 (Fstart_process): Doc fix.
Dave Love <fx@gnu.org>
parents: 27430
diff changeset
4240 return Qt;
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4241 }
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4242
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4243 /* Read pending output from the process channel,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4244 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
4245 Yield number of decoded characters read.
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4246
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4247 This function reads at most 1024 characters.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4248 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
4249 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
4250
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4251 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
4252 for decoding. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4253
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
4254 int
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4255 read_process_output (proc, channel)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4256 Lisp_Object proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4257 register int channel;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4258 {
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4259 register int nchars, nbytes;
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4260 char *chars;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4261 register Lisp_Object outstream;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4262 register struct buffer *old = current_buffer;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4263 register struct Lisp_Process *p = XPROCESS (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4264 register int opoint;
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
4265 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
4266 int carryover = XINT (p->decoding_carryover);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4267 int readmax = 1024;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4268
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4269 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4270 VMS_PROC_STUFF *vs, *get_vms_process_pointer();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4271
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4272 vs = get_vms_process_pointer (p->pid);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4273 if (vs)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4274 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4275 if (!vs->iosb[0])
25248
f0fc8443bdbb (Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents: 25129
diff changeset
4276 return (0); /* Really weird if it does this */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4277 if (!(vs->iosb[0] & 1))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4278 return -1; /* I/O error */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4279 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4280 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4281 error ("Could not get VMS process pointer");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4282 chars = vs->inputBuffer;
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4283 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
4284 if (nbytes <= 0)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4285 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4286 start_vms_process_read (vs); /* Crank up the next read on the process */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4287 return 1; /* Nothing worth printing, say we got 1 */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4288 }
20715
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
4289 if (carryover > 0)
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4290 {
20715
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
4291 /* 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
4292 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
4293 data read to decode all together. */
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4294 chars = (char *) alloca (nbytes + carryover);
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4295 bcopy (SDATA (p->decoding_buf), buf, carryover);
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4296 bcopy (vs->inputBuffer, chars + carryover, nbytes);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4297 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4298 #else /* not VMS */
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4299
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4300 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4301 /* 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
4302 corresponding to the typical Ethernet frame size. */
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4303 if (DATAGRAM_CHAN_P (channel))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4304 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4305 /* 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
4306 readmax += 1024;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4307 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4308 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4309
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4310 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
4311 if (carryover)
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
4312 /* See the comment above. */
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4313 bcopy (SDATA (p->decoding_buf), chars, carryover);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4314
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4315 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4316 /* 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
4317 if (DATAGRAM_CHAN_P (channel))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4318 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4319 int len = datagram_address[channel].len;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4320 nbytes = recvfrom (channel, chars + carryover, readmax - carryover,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4321 0, datagram_address[channel].sa, &len);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4322 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4323 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4324 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4325 if (proc_buffered_char[channel] < 0)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4326 nbytes = emacs_read (channel, chars + carryover, readmax - carryover);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4327 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4328 {
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4329 chars[carryover] = proc_buffered_char[channel];
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4330 proc_buffered_char[channel] = -1;
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4331 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
4332 if (nbytes < 0)
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4333 nbytes = 1;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4334 else
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4335 nbytes = nbytes + 1;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4336 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4337 #endif /* not VMS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4338
22523
b02a5ea8cf93 (read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents: 22019
diff changeset
4339 XSETINT (p->decoding_carryover, 0);
b02a5ea8cf93 (read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents: 22019
diff changeset
4340
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4341 /* 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
4342 (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
4343 if (nbytes <= 0)
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
4344 {
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
4345 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
4346 return nbytes;
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
4347 coding->mode |= CODING_MODE_LAST_BLOCK;
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
4348 }
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4349
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4350 /* 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
4351 nbytes += carryover;
29017
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
4352
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4353 /* Read and dispose of the process output. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4354 outstream = p->filter;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4355 if (!NILP (outstream))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4356 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4357 /* We inhibit quit here instead of just catching it so that
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4358 hitting ^G when a filter happens to be running won't screw
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4359 it up. */
46293
1fb8f75062c6 Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents: 45410
diff changeset
4360 int count = SPECPDL_INDEX ();
3510
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4361 Lisp_Object odeactivate;
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
4362 Lisp_Object obuffer, okeymap;
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4363 Lisp_Object text;
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4364 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
4365 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
4366
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
4367 /* 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
4368 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
4369 odeactivate = Vdeactivate_mark;
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
4370 XSETBUFFER (obuffer, current_buffer);
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
4371 okeymap = current_buffer->keymap;
3510
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4372
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4373 specbind (Qinhibit_quit, Qt);
8231
5226ed89c1a6 (Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8063
diff changeset
4374 specbind (Qlast_nonmenu_event, Qt);
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
4375
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4376 /* In case we get recursively called,
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4377 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
4378 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
4379 if (outer_running_asynch_code)
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4380 {
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4381 Lisp_Object tem;
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4382 /* 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
4383 tem = Fmatch_data (Qnil, Qnil);
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4384 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
4385 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
4386 Fset_match_data (tem);
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4387 }
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4388
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4389 /* 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
4390 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
4391 running_asynch_code = 1;
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4392
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4393 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
4394 coding, 0);
31136
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4395 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
4396 /* 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
4397 text = string_make_unibyte (text);
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4398
30582
280157ad4aa3 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 30580
diff changeset
4399 Vlast_coding_system_used = coding->symbol;
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4400 /* A new coding system might be found. */
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4401 if (!EQ (p->decode_coding_system, coding->symbol))
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4402 {
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4403 p->decode_coding_system = coding->symbol;
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4404
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4405 /* Don't call setup_coding_system for
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4406 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
4407 detect_coding called via decode_coding above. */
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4408
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4409 /* 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
4410 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
4411
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4412 But, before doing that we must check if
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4413 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
4414 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
4415 sent to the process. */
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4416 if (NILP (p->encode_coding_system)
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4417 && proc_encode_coding_system[XINT (p->outfd)])
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4418 {
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4419 p->encode_coding_system = coding->symbol;
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4420 setup_coding_system (coding->symbol,
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4421 proc_encode_coding_system[XINT (p->outfd)]);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4422 }
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4423 }
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4424
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4425 carryover = nbytes - coding->consumed;
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4426 bcopy (chars + coding->consumed, SDATA (p->decoding_buf),
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4427 carryover);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4428 XSETINT (p->decoding_carryover, carryover);
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4429 nbytes = SBYTES (text);
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4430 nchars = SCHARS (text);
34647
1898b3c996ff (read_process_output): Don't run a filter if the code
Kenichi Handa <handa@m17n.org>
parents: 34352
diff changeset
4431 if (nbytes > 0)
1898b3c996ff (read_process_output): Don't run a filter if the code
Kenichi Handa <handa@m17n.org>
parents: 34352
diff changeset
4432 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
4433 Fcons (outstream,
1898b3c996ff (read_process_output): Don't run a filter if the code
Kenichi Handa <handa@m17n.org>
parents: 34352
diff changeset
4434 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
4435 !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
4436 read_process_output_error_handler);
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4437
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4438 /* 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
4439 restore_match_data ();
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
4440 running_asynch_code = outer_running_asynch_code;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4441
3666
c7ff787b096f (read_process_output): Don't deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3608
diff changeset
4442 /* 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
4443 Vdeactivate_mark = odeactivate;
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4444
23460
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
4445 /* 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
4446 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
4447 waiting_for_user_input_p = waiting;
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
4448
12808
4db1f387e85f (read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents: 12749
diff changeset
4449 #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
4450 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
4451 that affect key bindings. */
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
4452 if (! EQ (Fcurrent_buffer (), obuffer)
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
4453 || ! EQ (current_buffer->keymap, okeymap))
12808
4db1f387e85f (read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents: 12749
diff changeset
4454 #endif
13159
2af96ac471bc (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 12808
diff changeset
4455 /* 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
4456 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
4457 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
4458 if (waiting_for_user_input_p == -1)
2af96ac471bc (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 12808
diff changeset
4459 record_asynch_buffer_change ();
6748
b1cde622fa65 (read_process_output): If buffer changes, record that fact.
Karl Heuer <kwzh@gnu.org>
parents: 6569
diff changeset
4460
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4461 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4462 start_vms_process_read (vs);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4463 #endif
5561
fd7524d61a8d (read_process_output): Supply second arg to unbind_to.
Richard M. Stallman <rms@gnu.org>
parents: 5548
diff changeset
4464 unbind_to (count, Qnil);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4465 return nchars;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4466 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4467
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4468 /* If no filter, write into buffer if it isn't dead. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4469 if (!NILP (p->buffer) && !NILP (XBUFFER (p->buffer)->name))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4470 {
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4471 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
4472 int old_begv, old_zv;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4473 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
4474 Lisp_Object odeactivate;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4475 int before, before_byte;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4476 int opoint_byte;
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4477 Lisp_Object text;
34352
642fb6c53a10 (read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents: 32864
diff changeset
4478 struct buffer *b;
3510
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4479
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4480 odeactivate = Vdeactivate_mark;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4481
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4482 Fset_buffer (p->buffer);
16039
855c8d8ba0f0 Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents: 15895
diff changeset
4483 opoint = PT;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4484 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
4485 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
4486 old_begv = BEGV;
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4487 old_zv = ZV;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4488 old_begv_byte = BEGV_BYTE;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4489 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
4490
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4491 current_buffer->read_only = Qnil;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4492
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4493 /* Insert new output into buffer
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4494 at the current end-of-output marker,
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4495 thus preserving logical ordering of input and output. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4496 if (XMARKER (p->mark)->buffer)
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4497 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
4498 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
4499 ZV_BYTE));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4500 else
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4501 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
4502 before = PT;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4503 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
4504
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4505 /* 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
4506 the restriction and widen. */
16039
855c8d8ba0f0 Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents: 15895
diff changeset
4507 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
4508 Fwiden ();
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4509
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4510 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
4511 coding, 0);
30582
280157ad4aa3 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 30580
diff changeset
4512 Vlast_coding_system_used = coding->symbol;
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4513 /* 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
4514 similar code in the previous `if' block. */
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4515 if (!EQ (p->decode_coding_system, coding->symbol))
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4516 {
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4517 p->decode_coding_system = coding->symbol;
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4518 if (NILP (p->encode_coding_system)
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4519 && proc_encode_coding_system[XINT (p->outfd)])
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4520 {
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4521 p->encode_coding_system = coding->symbol;
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4522 setup_coding_system (coding->symbol,
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4523 proc_encode_coding_system[XINT (p->outfd)]);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4524 }
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4525 }
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4526 carryover = nbytes - coding->consumed;
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4527 bcopy (chars + coding->consumed, SDATA (p->decoding_buf),
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4528 carryover);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4529 XSETINT (p->decoding_carryover, carryover);
31419
bd258f4dc0fa (read_process_output): Before inserting the decoded
Kenichi Handa <handa@m17n.org>
parents: 31136
diff changeset
4530 /* 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
4531 if (NILP (current_buffer->enable_multibyte_characters)
bd258f4dc0fa (read_process_output): Before inserting the decoded
Kenichi Handa <handa@m17n.org>
parents: 31136
diff changeset
4532 != ! STRING_MULTIBYTE (text))
bd258f4dc0fa (read_process_output): Before inserting the decoded
Kenichi Handa <handa@m17n.org>
parents: 31136
diff changeset
4533 text = (STRING_MULTIBYTE (text)
32395
11b8c07e5fed (read_process_output): Cancel previous change.
Kenichi Handa <handa@m17n.org>
parents: 32371
diff changeset
4534 ? Fstring_as_unibyte (text)
11b8c07e5fed (read_process_output): Cancel previous change.
Kenichi Handa <handa@m17n.org>
parents: 32371
diff changeset
4535 : Fstring_as_multibyte (text));
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4536 nbytes = SBYTES (text);
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4537 nchars = SCHARS (text);
32395
11b8c07e5fed (read_process_output): Cancel previous change.
Kenichi Handa <handa@m17n.org>
parents: 32371
diff changeset
4538 /* 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
4539 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
4540 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
4541
34352
642fb6c53a10 (read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents: 32864
diff changeset
4542 /* 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
4543 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
4544 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
4545 if (BUFFERP (p->buffer)
642fb6c53a10 (read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents: 32864
diff changeset
4546 && (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
4547 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
4548 else
642fb6c53a10 (read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents: 32864
diff changeset
4549 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
4550
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4551 update_mode_lines++;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4552
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4553 /* 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
4554 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
4555 if (opoint >= before)
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4556 {
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4557 opoint += PT - before;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4558 opoint_byte += PT_BYTE - before_byte;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4559 }
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4560 if (old_begv > before)
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4561 {
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4562 old_begv += PT - before;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4563 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
4564 }
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4565 if (old_zv >= before)
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4566 {
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4567 old_zv += PT - before;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4568 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
4569 }
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
4570
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4571 /* 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
4572 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
4573 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
4574
3666
c7ff787b096f (read_process_output): Don't deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3608
diff changeset
4575 /* 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
4576 Vdeactivate_mark = odeactivate;
b4a552ca4e99 (read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents: 3238
diff changeset
4577
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
4578 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
4579 SET_PT_BOTH (opoint, opoint_byte);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4580 set_buffer_internal (old);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4581 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4582 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4583 start_vms_process_read (vs);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4584 #endif
20594
6e5a5afbe628 (read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents: 20551
diff changeset
4585 return nbytes;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4586 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4587
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4588 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
4589 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
4590 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
4591 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
4592 ()
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4593 {
7352
ef89b78c1a92 (wait_reading_process_input): Don't call prepare_menu_bars
Richard M. Stallman <rms@gnu.org>
parents: 7266
diff changeset
4594 return (waiting_for_user_input_p ? Qt : Qnil);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4595 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4596
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4597 /* Sending data to subprocess */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4598
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4599 jmp_buf send_process_frame;
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4600 Lisp_Object process_sent_to;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4601
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4602 SIGTYPE
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4603 send_process_trap ()
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4604 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4605 #ifdef BSD4_1
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4606 sigrelse (SIGPIPE);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4607 sigrelse (SIGALRM);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4608 #endif /* BSD4_1 */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4609 longjmp (send_process_frame, 1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4610 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4611
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4612 /* Send some data to process PROC.
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4613 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
4614 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
4615 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
4616
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4617 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
4618 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
4619
336858b2b11a (send_process): Add a hint that the function
Gerd Moellmann <gerd@gnu.org>
parents: 28012
diff changeset
4620 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
4621
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
4622 void
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4623 send_process (proc, buf, len, object)
11926
40d7e6f04ebe (create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents: 11845
diff changeset
4624 volatile Lisp_Object proc;
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4625 unsigned char *volatile buf;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4626 volatile int len;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4627 volatile Lisp_Object object;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4628 {
11926
40d7e6f04ebe (create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents: 11845
diff changeset
4629 /* Use volatile to protect variables from being clobbered by longjmp. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4630 int rv;
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4631 struct coding_system *coding;
15895
85112cca0b22 (send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents: 15717
diff changeset
4632 struct gcpro gcpro1;
85112cca0b22 (send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents: 15717
diff changeset
4633
85112cca0b22 (send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents: 15717
diff changeset
4634 GCPRO1 (object);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4635
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4636 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4637 struct Lisp_Process *p = XPROCESS (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4638 VMS_PROC_STUFF *vs, *get_vms_process_pointer();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4639 #endif /* VMS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4640
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4641 if (! NILP (XPROCESS (proc)->raw_status_low))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4642 update_status (XPROCESS (proc));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4643 if (! EQ (XPROCESS (proc)->status, Qrun))
28012
9c8bcd7e4a4f (send_process): Remove local variable `procname' that
Gerd Moellmann <gerd@gnu.org>
parents: 27861
diff changeset
4644 error ("Process %s not running",
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4645 SDATA (XPROCESS (proc)->name));
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4646 if (XINT (XPROCESS (proc)->outfd) < 0)
28012
9c8bcd7e4a4f (send_process): Remove local variable `procname' that
Gerd Moellmann <gerd@gnu.org>
parents: 27861
diff changeset
4647 error ("Output file descriptor of %s is closed",
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4648 SDATA (XPROCESS (proc)->name));
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4649
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
4650 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
4651 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
4652
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4653 if ((STRINGP (object) && STRING_MULTIBYTE (object))
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4654 || (BUFFERP (object)
32864
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4655 && !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
4656 || EQ (object, Qt))
31136
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4657 {
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4658 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
4659 /* 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
4660 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
4661 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
4662 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
4663 process. */
42600
93254645e03b (send_process): Set src_multibyte to 1 after the call
Eli Zaretskii <eliz@gnu.org>
parents: 41969
diff changeset
4664 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
4665 /* 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
4666 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
4667 zero. */
93254645e03b (send_process): Set src_multibyte to 1 after the call
Eli Zaretskii <eliz@gnu.org>
parents: 41969
diff changeset
4668 coding->src_multibyte = 1;
31136
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4669 }
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4670 else
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4671 {
32864
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4672 /* 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
4673 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
4674 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
4675 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
4676 {
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4677 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
4678 {
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4679 /* 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
4680 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
4681 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
4682 }
21acd0c60f5d (send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents: 32395
diff changeset
4683 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
4684 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
4685 }
31136
d1344c992a9a (create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents: 31099
diff changeset
4686 }
29017
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
4687 coding->dst_multibyte = 0;
8f10362eb5ff (Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents: 28157
diff changeset
4688
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4689 if (CODING_REQUIRE_ENCODING (coding))
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4690 {
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4691 int require = encoding_buffer_size (coding, len);
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4692 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
4693 unsigned char *temp_buf = NULL;
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4694
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4695 if (BUFFERP (object))
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4696 {
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4697 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
4698 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
4699 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
4700 }
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4701 else if (STRINGP (object))
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4702 {
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4703 from_byte = buf - SDATA (object);
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4704 from = string_byte_to_char (object, from_byte);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4705 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
4706 }
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4707
39429
9de129194439 (send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents: 39406
diff changeset
4708 if (coding->composing != COMPOSITION_DISABLED)
9de129194439 (send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents: 39406
diff changeset
4709 {
9de129194439 (send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents: 39406
diff changeset
4710 if (from_byte >= 0)
9de129194439 (send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents: 39406
diff changeset
4711 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
4712 else
9de129194439 (send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents: 39406
diff changeset
4713 coding->composing = COMPOSITION_DISABLED;
9de129194439 (send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents: 39406
diff changeset
4714 }
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4715
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4716 if (SBYTES (XPROCESS (proc)->encoding_buf) < require)
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4717 XPROCESS (proc)->encoding_buf = make_uninit_string (require);
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4718
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4719 if (from_byte >= 0)
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4720 buf = (BUFFERP (object)
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4721 ? BUF_BYTE_ADDRESS (XBUFFER (object), from_byte)
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4722 : SDATA (object) + from_byte);
30580
5d92193ed196 (read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents: 29921
diff changeset
4723
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4724 object = XPROCESS (proc)->encoding_buf;
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4725 encode_coding (coding, (char *) buf, SDATA (object),
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4726 len, SBYTES (object));
20715
5e983ddb85c9 (Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents: 20708
diff changeset
4727 len = coding->produced;
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4728 buf = SDATA (object);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4729 if (temp_buf)
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4730 xfree (temp_buf);
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
4731 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4732
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4733 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4734 vs = get_vms_process_pointer (p->pid);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4735 if (vs == 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4736 error ("Could not find this process: %x", p->pid);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4737 else if (write_to_vms_process (vs, buf, len))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4738 ;
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4739 #else /* not VMS */
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4740
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4741 if (pty_max_bytes == 0)
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4742 {
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4743 #if defined (HAVE_FPATHCONF) && defined (_PC_MAX_CANON)
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4744 pty_max_bytes = fpathconf (XFASTINT (XPROCESS (proc)->outfd),
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4745 _PC_MAX_CANON);
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4746 if (pty_max_bytes < 0)
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4747 pty_max_bytes = 250;
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4748 #else
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4749 pty_max_bytes = 250;
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4750 #endif
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4751 /* Deduct one, to leave space for the eof. */
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4752 pty_max_bytes--;
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4753 }
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4754
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4755 /* 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
4756 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
4757 when returning with longjmp despite being declared volatile. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4758 if (!setjmp (send_process_frame))
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4759 {
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4760 process_sent_to = proc;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4761 while (len > 0)
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4762 {
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4763 int this = len;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4764 SIGTYPE (*old_sigpipe)();
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4765
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4766 /* 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
4767 Long lines need to be split into multiple batches. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4768 if (!NILP (XPROCESS (proc)->pty_flag))
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4769 {
39812
66e0816837a8 Update calls to openp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39429
diff changeset
4770 /* 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
4771 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
4772 It may not be correct for the first iteration
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4773 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
4774 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
4775 in the process object. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4776 int linepos = 0;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4777 unsigned char *ptr = (unsigned char *) buf;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4778 unsigned char *end = (unsigned char *) buf + len;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4779
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4780 /* 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
4781 while (ptr != end && linepos < pty_max_bytes)
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4782 {
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4783 if (*ptr == '\n')
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4784 linepos = 0;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4785 else
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4786 linepos++;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4787 ptr++;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4788 }
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4789 /* If we found one, break the line there
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4790 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
4791 this = ptr - buf;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4792 }
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4793
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4794 /* Send this batch, using one or more write calls. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4795 while (this > 0)
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4796 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4797 int outfd = XINT (XPROCESS (proc)->outfd);
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4798 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
4799 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4800 if (DATAGRAM_CHAN_P (outfd))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4801 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4802 rv = sendto (outfd, (char *) buf, this,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4803 0, datagram_address[outfd].sa,
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4804 datagram_address[outfd].len);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4805 if (rv < 0 && errno == EMSGSIZE)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4806 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
4807 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4808 else
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4809 #endif
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
4810 rv = emacs_write (outfd, (char *) buf, this);
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4811 signal (SIGPIPE, old_sigpipe);
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4812
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4813 if (rv < 0)
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4814 {
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4815 if (0
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4816 #ifdef EWOULDBLOCK
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4817 || errno == EWOULDBLOCK
6158
6b81b2575071 Include unistd.h.
Richard M. Stallman <rms@gnu.org>
parents: 5891
diff changeset
4818 #endif
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4819 #ifdef EAGAIN
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4820 || errno == EAGAIN
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4821 #endif
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4822 )
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4823 /* Buffer is full. Wait, accepting input;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4824 that may allow the program
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4825 to finish doing output and read more. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4826 {
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4827 Lisp_Object zero;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4828 int offset = 0;
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4829
27705
2c53eb482802 (send_process) [BROKEN_PTY_READ_AFTER_EAGAIN]:
Gerd Moellmann <gerd@gnu.org>
parents: 27669
diff changeset
4830 #ifdef BROKEN_PTY_READ_AFTER_EAGAIN
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4831 /* 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
4832 In the following sequence, read(2) returns
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4833 bogus data:
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4834
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4835 write(2) 1022 bytes
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4836 write(2) 954 bytes, get EAGAIN
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4837 read(2) 1024 bytes in process_read_output
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4838 read(2) 11 bytes in process_read_output
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4839
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4840 That is, read(2) returns more bytes than have
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4841 ever been written successfully. The 1033 bytes
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4842 read are the 1022 bytes written successfully
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4843 after processing (for example with CRs added if
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4844 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
4845 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
4846 later read(2), without the CRs. */
27705
2c53eb482802 (send_process) [BROKEN_PTY_READ_AFTER_EAGAIN]:
Gerd Moellmann <gerd@gnu.org>
parents: 27669
diff changeset
4847
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4848 if (errno == EAGAIN)
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 int flags = FWRITE;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4851 ioctl (XINT (XPROCESS (proc)->outfd), TIOCFLUSH,
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4852 &flags);
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4853 }
27705
2c53eb482802 (send_process) [BROKEN_PTY_READ_AFTER_EAGAIN]:
Gerd Moellmann <gerd@gnu.org>
parents: 27669
diff changeset
4854 #endif /* BROKEN_PTY_READ_AFTER_EAGAIN */
2c53eb482802 (send_process) [BROKEN_PTY_READ_AFTER_EAGAIN]:
Gerd Moellmann <gerd@gnu.org>
parents: 27669
diff changeset
4855
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4856 /* Running filters might relocate buffers or strings.
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4857 Arrange to relocate BUF. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4858 if (BUFFERP (object))
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4859 offset = BUF_PTR_BYTE_POS (XBUFFER (object), buf);
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4860 else if (STRINGP (object))
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4861 offset = buf - SDATA (object);
31806
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 XSETFASTINT (zero, 0);
16718
ea26040865cb (send_process) [EMACS_HAS_USECS]:
Richard M. Stallman <rms@gnu.org>
parents: 16644
diff changeset
4864 #ifdef EMACS_HAS_USECS
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4865 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
4866 #else
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4867 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
4868 #endif
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
4869
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4870 if (BUFFERP (object))
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4871 buf = BUF_BYTE_ADDRESS (XBUFFER (object), offset);
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4872 else if (STRINGP (object))
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4873 buf = offset + SDATA (object);
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4874
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4875 rv = 0;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4876 }
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4877 else
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4878 /* This is a real error. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4879 report_file_error ("writing to process", Fcons (proc, Qnil));
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4880 }
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4881 buf += rv;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4882 len -= rv;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4883 this -= rv;
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
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4886 /* 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
4887 to force it through, before we send the rest. */
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4888 if (len > 0)
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4889 Fprocess_send_eof (proc);
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4890 }
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4891 }
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4892 #endif /* not VMS */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4893 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4894 {
31806
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4895 #ifndef VMS
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4896 proc = process_sent_to;
b148beb59511 (process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 31419
diff changeset
4897 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4898 XPROCESS (proc)->raw_status_low = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4899 XPROCESS (proc)->raw_status_high = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4900 XPROCESS (proc)->status = Fcons (Qexit, Fcons (make_number (256), Qnil));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4901 XSETINT (XPROCESS (proc)->tick, ++process_tick);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4902 deactivate_process (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4903 #ifdef VMS
28012
9c8bcd7e4a4f (send_process): Remove local variable `procname' that
Gerd Moellmann <gerd@gnu.org>
parents: 27861
diff changeset
4904 error ("Error writing to process %s; closed it",
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4905 SDATA (XPROCESS (proc)->name));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4906 #else
28012
9c8bcd7e4a4f (send_process): Remove local variable `procname' that
Gerd Moellmann <gerd@gnu.org>
parents: 27861
diff changeset
4907 error ("SIGPIPE raised on process %s; closed it",
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4908 SDATA (XPROCESS (proc)->name));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4909 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4910 }
15895
85112cca0b22 (send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents: 15717
diff changeset
4911
85112cca0b22 (send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents: 15717
diff changeset
4912 UNGCPRO;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4913 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4914
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4915 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
4916 3, 3, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4917 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
4918 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
4919 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
4920 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
4921 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
4922 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
4923 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
4924 (process, start, end)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4925 Lisp_Object process, start, end;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4926 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4927 Lisp_Object proc;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4928 int start1, end1;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4929
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4930 proc = get_process (process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4931 validate_region (&start, &end);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4932
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4933 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
4934 move_gap (XINT (start));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4935
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4936 start1 = CHAR_TO_BYTE (XINT (start));
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4937 end1 = CHAR_TO_BYTE (XINT (end));
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
4938 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
4939 Fcurrent_buffer ());
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4940
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4941 return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4942 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4943
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4944 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
4945 2, 2, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4946 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
4947 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
4948 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
4949 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
4950 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
4951 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
4952 (process, string)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4953 Lisp_Object process, string;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4954 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4955 Lisp_Object proc;
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
4956 CHECK_STRING (string);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4957 proc = get_process (process);
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4958 send_process (proc, SDATA (string),
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4959 SBYTES (string), string);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4960 return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4961 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4962
24352
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4963 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
4964 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
4965 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
4966 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
4967 return t unconditionally. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
4968 (process)
24352
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4969 Lisp_Object process;
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4970 {
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4971 /* 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
4972 in a way that will cause returning t. */
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4973 int gid = 0;
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4974 Lisp_Object proc;
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4975 struct Lisp_Process *p;
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4976
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4977 proc = get_process (process);
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4978 p = XPROCESS (proc);
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4979
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4980 if (!EQ (p->childp, Qt))
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4981 error ("Process %s is not a subprocess",
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4982 SDATA (p->name));
24352
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4983 if (XINT (p->infd) < 0)
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4984 error ("Process %s is not active",
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
4985 SDATA (p->name));
24352
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4986
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4987 #ifdef TIOCGPGRP
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4988 if (!NILP (p->subtty))
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4989 ioctl (XFASTINT (p->subtty), TIOCGPGRP, &gid);
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4990 else
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4991 ioctl (XINT (p->infd), TIOCGPGRP, &gid);
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4992 #endif /* defined (TIOCGPGRP ) */
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4993
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4994 if (gid == XFASTINT (p->pid))
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4995 return Qnil;
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4996 return Qt;
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4997 }
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
4998
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
4999 /* send a signal number SIGNO to PROCESS.
24352
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5000 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
5001 that currently owns the terminal being used to communicate with PROCESS.
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5002 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
5003 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
5004 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
5005
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5006 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
5007 right away.
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5008
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5009 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
5010 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
5011 their uid, for which killpg would return an EPERM error. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5012
1522
19ccf004b172 * process.c: (status_convert): Declare this to return a
Jim Blandy <jimb@redhat.com>
parents: 1323
diff changeset
5013 static void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5014 process_send_signal (process, signo, current_group, nomsg)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5015 Lisp_Object process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5016 int signo;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5017 Lisp_Object current_group;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5018 int nomsg;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5019 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5020 Lisp_Object proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5021 register struct Lisp_Process *p;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5022 int gid;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5023 int no_pgrp = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5024
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5025 proc = get_process (process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5026 p = XPROCESS (proc);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5027
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5028 if (!EQ (p->childp, Qt))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5029 error ("Process %s is not a subprocess",
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
5030 SDATA (p->name));
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5031 if (XINT (p->infd) < 0)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5032 error ("Process %s is not active",
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
5033 SDATA (p->name));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5034
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5035 if (NILP (p->pty_flag))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5036 current_group = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5037
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5038 /* If we are using pgrps, get a pgrp number and make it negative. */
46411
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5039 if (NILP (current_group))
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5040 /* Send the signal to the shell's process group. */
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5041 gid = XFASTINT (p->pid);
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5042 else
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5043 {
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5044 #ifdef SIGNALS_VIA_CHARACTERS
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5045 /* If possible, send signals to the entire pgrp
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5046 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
5047
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5048 /* 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
5049 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
5050 #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
5051 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
5052
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5053 switch (signo)
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5054 {
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5055 case SIGINT:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5056 tcgetattr (XINT (p->infd), &t);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5057 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
5058 return;
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5059
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5060 case SIGQUIT:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5061 tcgetattr (XINT (p->infd), &t);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5062 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
5063 return;
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5064
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5065 case SIGTSTP:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5066 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
5067 #if defined (VSWTCH) && !defined (PREFER_VSUSP)
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5068 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
5069 #else
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5070 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
5071 #endif
2120
fc3cdca22f8d * process.c (process_send_signal): In the TERMIOS code for sending
Jim Blandy <jimb@redhat.com>
parents: 1925
diff changeset
5072 return;
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5073 }
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5074
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5075 #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
5076
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5077 /* 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
5078 current control characters. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5079 #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
5080
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5081 struct tchars c;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5082 struct ltchars lc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5083
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5084 switch (signo)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5085 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5086 case SIGINT:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5087 ioctl (XINT (p->infd), TIOCGETC, &c);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5088 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
5089 return;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5090 case SIGQUIT:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5091 ioctl (XINT (p->infd), TIOCGETC, &c);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5092 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
5093 return;
1012
a48ed1d416dd * process.c (process_send_signal): Don't send SIGTSTP if the
Jim Blandy <jimb@redhat.com>
parents: 849
diff changeset
5094 #ifdef SIGTSTP
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5095 case SIGTSTP:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5096 ioctl (XINT (p->infd), TIOCGLTC, &lc);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5097 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
5098 return;
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5099 #endif /* ! defined (SIGTSTP) */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5100 }
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5101
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5102 #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
5103
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5104 /* 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
5105 characters. */
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5106 #ifdef TCGETA
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5107 struct termio t;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5108 switch (signo)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5109 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5110 case SIGINT:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5111 ioctl (XINT (p->infd), TCGETA, &t);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5112 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
5113 return;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5114 case SIGQUIT:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5115 ioctl (XINT (p->infd), TCGETA, &t);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5116 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
5117 return;
1569
52a69b6a8f96 * process.c [SYSV]: Don't include <termios.h>, <termio.h>, or
Jim Blandy <jimb@redhat.com>
parents: 1522
diff changeset
5118 #ifdef SIGTSTP
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5119 case SIGTSTP:
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5120 ioctl (XINT (p->infd), TCGETA, &t);
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5121 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
5122 return;
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5123 #endif /* ! defined (SIGTSTP) */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5124 }
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5125 #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
5126 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
5127 /* 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
5128 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
5129 #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
5130 #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
5131 #endif /* ! defined HAVE_TERMIOS */
46314
7c8eab7f2bd6 (process_send_signal): Add abort call.
Richard M. Stallman <rms@gnu.org>
parents: 46293
diff changeset
5132 abort ();
7c8eab7f2bd6 (process_send_signal): Add abort call.
Richard M. Stallman <rms@gnu.org>
parents: 46293
diff changeset
5133 /* The code above always returns from the function. */
7c8eab7f2bd6 (process_send_signal): Add abort call.
Richard M. Stallman <rms@gnu.org>
parents: 46293
diff changeset
5134 #endif /* defined (SIGNALS_VIA_CHARACTERS) */
849
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5135
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5136 #ifdef TIOCGPGRP
46411
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5137 /* Get the current pgrp using the tty itself, if we have that.
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5138 Otherwise, use the pty to get the pgrp.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5139 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
5140 "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
5141 But, TIOCGPGRP does not work on E50 ;-P works fine on E60"
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5142 His patch indicates that if TIOCGPGRP returns an error, then
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5143 we should just assume that p->pid is also the process group id. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5144 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5145 int err;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5146
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5147 if (!NILP (p->subtty))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5148 err = ioctl (XFASTINT (p->subtty), TIOCGPGRP, &gid);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5149 else
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5150 err = ioctl (XINT (p->infd), TIOCGPGRP, &gid);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5151
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5152 if (err == -1)
46411
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5153 /* If we can't get the information, assume
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5154 the shell owns the tty. */
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5155 gid = XFASTINT (p->pid);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5156 }
46411
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5157
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5158 /* It is not clear whether anything really can set GID to -1.
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5159 Perhaps on some system one of those ioctls can or could do so.
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5160 Or perhaps this is vestigial. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5161 if (gid == -1)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5162 no_pgrp = 1;
1594
b476a97ad17e * systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents: 1569
diff changeset
5163 #else /* ! defined (TIOCGPGRP ) */
849
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5164 /* Can't select pgrps on this system, so we know that
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5165 the child itself heads the pgrp. */
46411
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5166 gid = XFASTINT (p->pid);
849
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5167 #endif /* ! defined (TIOCGPGRP ) */
24352
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5168
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5169 /* 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
5170 don't send any signal. */
46411
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5171 if (EQ (current_group, Qlambda) && gid == XFASTINT (p->pid))
24352
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
5172 return;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5173 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5174
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 #ifdef SIGCONT
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5178 case SIGCONT:
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5179 p->raw_status_low = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5180 p->raw_status_high = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5181 p->status = Qrun;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5182 XSETINT (p->tick, ++process_tick);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5183 if (!nomsg)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5184 status_notify ();
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5185 break;
849
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5186 #endif /* ! defined (SIGCONT) */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5187 case SIGINT:
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5188 #ifdef VMS
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5189 send_process (proc, "\003", 1, Qnil); /* ^C */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5190 goto whoosh;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5191 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5192 case SIGQUIT:
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5193 #ifdef VMS
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5194 send_process (proc, "\031", 1, Qnil); /* ^Y */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5195 goto whoosh;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5196 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5197 case SIGKILL:
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5198 #ifdef VMS
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5199 sys$forcex (&(XFASTINT (p->pid)), 0, 1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5200 whoosh:
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5201 #endif
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5202 flush_pending_output (XINT (p->infd));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5203 break;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5204 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5205
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5206 /* If we don't have process groups, send the signal to the immediate
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5207 subprocess. That isn't really right, but it's better than any
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5208 obvious alternative. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5209 if (no_pgrp)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5210 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5211 kill (XFASTINT (p->pid), signo);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5212 return;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5213 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5214
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5215 /* gid may be a pid, or minus a pgrp's number */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5216 #ifdef TIOCSIGSEND
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5217 if (!NILP (current_group))
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5218 ioctl (XINT (p->infd), TIOCSIGSEND, signo);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5219 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5220 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5221 gid = - XFASTINT (p->pid);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5222 kill (gid, signo);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5223 }
849
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5224 #else /* ! defined (TIOCSIGSEND) */
46411
d17e7d2c1766 (create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents: 46370
diff changeset
5225 EMACS_KILLPG (gid, signo);
849
c7b49118e101 entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 822
diff changeset
5226 #endif /* ! defined (TIOCSIGSEND) */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5227 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5228
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5229 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
5230 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
5231 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
5232 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
5233 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
5234 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
5235 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
5236 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
5237 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
5238
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5239 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
5240 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
5241 (process, current_group)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5242 Lisp_Object process, current_group;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5243 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5244 process_send_signal (process, SIGINT, current_group, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5245 return process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5246 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5247
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5248 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
5249 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
5250 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
5251 (process, current_group)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5252 Lisp_Object process, current_group;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5253 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5254 process_send_signal (process, SIGKILL, current_group, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5255 return process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5256 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5257
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5258 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
5259 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
5260 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
5261 (process, current_group)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5262 Lisp_Object process, current_group;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5263 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5264 process_send_signal (process, SIGQUIT, current_group, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5265 return process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5266 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5267
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5268 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
5269 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
5270 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
5271 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
5272 (process, current_group)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5273 Lisp_Object process, current_group;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5274 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5275 #ifdef HAVE_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5276 if (PROCESSP (process) && NETCONN_P (process))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5277 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5278 struct Lisp_Process *p;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5279
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5280 p = XPROCESS (process);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5281 if (NILP (p->command)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5282 && XINT (p->infd) >= 0)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5283 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5284 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
5285 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
5286 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5287 p->command = Qt;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5288 return process;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5289 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5290 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5291 #ifndef SIGTSTP
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5292 error ("no SIGTSTP support");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5293 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5294 process_send_signal (process, SIGTSTP, current_group, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5295 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5296 return process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5297 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5298
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5299 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
5300 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
5301 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
5302 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
5303 (process, current_group)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5304 Lisp_Object process, current_group;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5305 {
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5306 #ifdef HAVE_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5307 if (PROCESSP (process) && NETCONN_P (process))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5308 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5309 struct Lisp_Process *p;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5310
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5311 p = XPROCESS (process);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5312 if (EQ (p->command, Qt)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5313 && XINT (p->infd) >= 0
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5314 && (!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
5315 {
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5316 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
5317 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
5318 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5319 p->command = Qnil;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5320 return process;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5321 }
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5322 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5323 #ifdef SIGCONT
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5324 process_send_signal (process, SIGCONT, current_group, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5325 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5326 error ("no SIGCONT support");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5327 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5328 return process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5329 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5330
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5331 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
5332 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
5333 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
5334 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
5335 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
5336 (pid, sigcode)
11144
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5337 Lisp_Object pid, sigcode;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5338 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
5339 CHECK_NUMBER (pid);
11144
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5340
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5341 #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
5342 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
5343 XSETINT (sigcode, VALUE)
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5344
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5345 if (INTEGERP (sigcode))
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5346 ;
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5347 else
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5348 {
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5349 unsigned char *name;
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5350
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
5351 CHECK_SYMBOL (sigcode);
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
5352 name = SDATA (SYMBOL_NAME (sigcode));
11144
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5353
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5354 if (0)
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5355 ;
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5356 #ifdef SIGHUP
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5357 handle_signal ("SIGHUP", SIGHUP);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5358 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5359 #ifdef SIGINT
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5360 handle_signal ("SIGINT", SIGINT);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5361 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5362 #ifdef SIGQUIT
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5363 handle_signal ("SIGQUIT", SIGQUIT);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5364 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5365 #ifdef SIGILL
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5366 handle_signal ("SIGILL", SIGILL);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5367 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5368 #ifdef SIGABRT
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5369 handle_signal ("SIGABRT", SIGABRT);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5370 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5371 #ifdef SIGEMT
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5372 handle_signal ("SIGEMT", SIGEMT);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5373 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5374 #ifdef SIGKILL
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5375 handle_signal ("SIGKILL", SIGKILL);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5376 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5377 #ifdef SIGFPE
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5378 handle_signal ("SIGFPE", SIGFPE);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5379 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5380 #ifdef SIGBUS
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5381 handle_signal ("SIGBUS", SIGBUS);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5382 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5383 #ifdef SIGSEGV
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5384 handle_signal ("SIGSEGV", SIGSEGV);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5385 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5386 #ifdef SIGSYS
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5387 handle_signal ("SIGSYS", SIGSYS);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5388 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5389 #ifdef SIGPIPE
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5390 handle_signal ("SIGPIPE", SIGPIPE);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5391 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5392 #ifdef SIGALRM
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5393 handle_signal ("SIGALRM", SIGALRM);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5394 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5395 #ifdef SIGTERM
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5396 handle_signal ("SIGTERM", SIGTERM);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5397 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5398 #ifdef SIGURG
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5399 handle_signal ("SIGURG", SIGURG);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5400 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5401 #ifdef SIGSTOP
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5402 handle_signal ("SIGSTOP", SIGSTOP);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5403 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5404 #ifdef SIGTSTP
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5405 handle_signal ("SIGTSTP", SIGTSTP);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5406 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5407 #ifdef SIGCONT
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5408 handle_signal ("SIGCONT", SIGCONT);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5409 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5410 #ifdef SIGCHLD
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5411 handle_signal ("SIGCHLD", SIGCHLD);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5412 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5413 #ifdef SIGTTIN
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5414 handle_signal ("SIGTTIN", SIGTTIN);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5415 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5416 #ifdef SIGTTOU
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5417 handle_signal ("SIGTTOU", SIGTTOU);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5418 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5419 #ifdef SIGIO
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5420 handle_signal ("SIGIO", SIGIO);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5421 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5422 #ifdef SIGXCPU
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5423 handle_signal ("SIGXCPU", SIGXCPU);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5424 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5425 #ifdef SIGXFSZ
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5426 handle_signal ("SIGXFSZ", SIGXFSZ);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5427 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5428 #ifdef SIGVTALRM
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5429 handle_signal ("SIGVTALRM", SIGVTALRM);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5430 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5431 #ifdef SIGPROF
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5432 handle_signal ("SIGPROF", SIGPROF);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5433 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5434 #ifdef SIGWINCH
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5435 handle_signal ("SIGWINCH", SIGWINCH);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5436 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5437 #ifdef SIGINFO
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5438 handle_signal ("SIGINFO", SIGINFO);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5439 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5440 #ifdef SIGUSR1
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5441 handle_signal ("SIGUSR1", SIGUSR1);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5442 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5443 #ifdef SIGUSR2
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5444 handle_signal ("SIGUSR2", SIGUSR2);
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5445 #endif
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5446 else
11148
117b32676686 (Fsignal_process): SIGCODE is a symbol, not a string.
Karl Heuer <kwzh@gnu.org>
parents: 11144
diff changeset
5447 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
5448 }
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5449
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5450 #undef handle_signal
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5451
c2b689aeb934 (Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents: 10914
diff changeset
5452 return make_number (kill (XINT (pid), XINT (sigcode)));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5453 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5454
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5455 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
5456 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
5457 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
5458 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
5459 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
5460 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
5461 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
5462 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
5463 (process)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5464 Lisp_Object process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5465 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5466 Lisp_Object proc;
23879
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5467 struct coding_system *coding;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5468
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5469 if (DATAGRAM_CONN_P (process))
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5470 return process;
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5471
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5472 proc = get_process (process);
23879
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5473 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
5474
7edc78402205 (Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents: 2200
diff changeset
5475 /* 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
5476 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
5477 update_status (XPROCESS (proc));
7edc78402205 (Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents: 2200
diff changeset
5478 if (! EQ (XPROCESS (proc)->status, Qrun))
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
5479 error ("Process %s not running", SDATA (XPROCESS (proc)->name));
2221
7edc78402205 (Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents: 2200
diff changeset
5480
23879
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5481 if (CODING_REQUIRE_FLUSHING (coding))
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5482 {
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5483 coding->mode |= CODING_MODE_LAST_BLOCK;
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5484 send_process (proc, "", 0, Qnil);
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5485 }
18e5d1cfa74b (read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents: 23762
diff changeset
5486
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5487 #ifdef VMS
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5488 send_process (proc, "\032", 1, Qnil); /* ^z */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5489 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5490 if (!NILP (XPROCESS (proc)->pty_flag))
8063
30861f2f4f84 (send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents: 7937
diff changeset
5491 send_process (proc, "\004", 1, Qnil);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5492 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5493 {
22939
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5494 int old_outfd, new_outfd;
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5495
18329
ddaafa596bf5 (Fprocess_send_eof): Prooperly conditionalize prev. change.
Richard M. Stallman <rms@gnu.org>
parents: 18328
diff changeset
5496 #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
5497 /* 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
5498 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
5499 (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
5500 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
5501 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
5502 || 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
5503 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
5504 /* 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
5505 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
5506 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
5507 #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
5508 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
5509 #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
5510 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
5511 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
5512
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5513 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
5514 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
5515 = (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
5516 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
5517 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
5518 sizeof (struct coding_system));
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5519 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
5520 sizeof (struct coding_system));
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5521
572895549f80 (Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents: 22864
diff changeset
5522 XSETINT (XPROCESS (proc)->outfd, new_outfd);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5523 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5524 #endif /* VMS */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5525 return process;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5526 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5527
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5528 /* 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
5529 If `buffer' is nil, kill all processes */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5530
20382
dbad9367d232 (create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents: 20225
diff changeset
5531 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5532 kill_buffer_processes (buffer)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5533 Lisp_Object buffer;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5534 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5535 Lisp_Object tail, proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5536
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
5537 for (tail = Vprocess_alist; GC_CONSP (tail); tail = XCDR (tail))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5538 {
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
5539 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
5540 if (GC_PROCESSP (proc)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5541 && (NILP (buffer) || EQ (XPROCESS (proc)->buffer, buffer)))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5542 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5543 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
5544 Fdelete_process (proc);
5134
0a4e46e15304 (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 4998
diff changeset
5545 else if (XINT (XPROCESS (proc)->infd) >= 0)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5546 process_send_signal (proc, SIGHUP, Qnil, 1);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5547 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5548 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5549 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5550
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5551 /* 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
5552 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
5553 are no more.
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5554
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5555 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
5556 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
5557 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
5558
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5559 ** 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
5560 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
5561 Lisp objects.
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5562
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5563 ** 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
5564 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
5565 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
5566 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
5567 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
5568 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
5569 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
5570 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
5571 Inc. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5572
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5573 SIGTYPE
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5574 sigchld_handler (signo)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5575 int signo;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5576 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5577 int old_errno = errno;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5578 Lisp_Object proc;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5579 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
5580 extern EMACS_TIME *input_available_clear_time;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5581
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5582 #ifdef BSD4_1
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5583 extern int sigheld;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5584 sigheld |= sigbit (SIGCHLD);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5585 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5586
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5587 while (1)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5588 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5589 register int pid;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5590 WAITTYPE w;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5591 Lisp_Object tail;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5592
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5593 #ifdef WNOHANG
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5594 #ifndef WUNTRACED
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5595 #define WUNTRACED 0
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5596 #endif /* no WUNTRACED */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5597 /* Keep trying to get a status until we get a definitive result. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5598 do
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5599 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5600 errno = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5601 pid = wait3 (&w, WNOHANG | WUNTRACED, 0);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5602 }
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5603 while (pid < 0 && errno == EINTR);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5604
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5605 if (pid <= 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5606 {
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5607 /* 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
5608 failure. We have done all our job, so return. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5609
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5610 /* USG systems forget handlers when they are used;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5611 must reestablish each time */
16116
80a67b8f39e9 (create_process_1, sigchld_handler) [POSIX_SIGNALS]:
Richard M. Stallman <rms@gnu.org>
parents: 16076
diff changeset
5612 #if defined (USG) && !defined (POSIX_SIGNALS)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5613 signal (signo, sigchld_handler); /* WARNING - must come after wait3() */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5614 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5615 #ifdef BSD4_1
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5616 sigheld &= ~sigbit (SIGCHLD);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5617 sigrelse (SIGCHLD);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5618 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5619 errno = old_errno;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5620 return;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5621 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5622 #else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5623 pid = wait (&w);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5624 #endif /* no WNOHANG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5625
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5626 /* Find the process that signaled us, and record its status. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5627
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5628 p = 0;
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5629 for (tail = Vprocess_alist; GC_CONSP (tail); tail = XCDR (tail))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5630 {
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
5631 proc = XCDR (XCAR (tail));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5632 p = XPROCESS (proc);
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5633 if (GC_EQ (p->childp, Qt) && XINT (p->pid) == pid)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5634 break;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5635 p = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5636 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5637
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5638 /* Look for an asynchronous process whose pid hasn't been filled
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5639 in yet. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5640 if (p == 0)
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5641 for (tail = Vprocess_alist; GC_CONSP (tail); tail = XCDR (tail))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5642 {
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
5643 proc = XCDR (XCAR (tail));
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5644 p = XPROCESS (proc);
39361
2d3bee6a3848 (sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents: 37758
diff changeset
5645 if (GC_INTEGERP (p->pid) && XINT (p->pid) == -1)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5646 break;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5647 p = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5648 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5649
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5650 /* Change the status of the process that was found. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5651 if (p != 0)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5652 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5653 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
5654 int clear_desc_flag = 0;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5655
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5656 XSETINT (p->tick, ++process_tick);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5657 u.wt = w;
12324
41bd44279127 (sigchld_handler): Change XSETFASTINT to XSETINT.
Richard M. Stallman <rms@gnu.org>
parents: 12215
diff changeset
5658 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
5659 XSETINT (p->raw_status_high, u.i >> 16);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5660
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5661 /* 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
5662 if ((WIFSIGNALED (w) || WIFEXITED (w))
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5663 && XINT (p->infd) >= 0)
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5664 clear_desc_flag = 1;
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5665
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5666 /* 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
5667 if (clear_desc_flag)
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5668 {
28267fcc61be Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents: 9705
diff changeset
5669 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
5670 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
5671 }
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5672
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5673 /* 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
5674 look around. */
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5675 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
5676 EMACS_SET_SECS_USECS (*input_available_clear_time, 0, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5677 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5678
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5679 /* There was no asynchronous process found for that id. Check
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5680 if we have a synchronous process. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5681 else
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5682 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5683 synch_process_alive = 0;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5684
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5685 /* Report the status of the synchronous process. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5686 if (WIFEXITED (w))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5687 synch_process_retcode = WRETCODE (w);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5688 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
5689 {
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
5690 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
5691 char *signame;
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
5692
26526
b7438760079b * callproc.c (strerror): Remove decl.
Paul Eggert <eggert@twinsun.com>
parents: 26313
diff changeset
5693 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
5694 signame = strsignal (code);
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
5695
5579
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
5696 if (signame == 0)
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
5697 signame = "unknown";
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
5698
466bc8ef8e21 (sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents: 5561
diff changeset
5699 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
5700 }
1925
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5701
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5702 /* 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
5703 look around. */
3ddb163a9201 * process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents: 1886
diff changeset
5704 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
5705 EMACS_SET_SECS_USECS (*input_available_clear_time, 0, 0);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5706 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5707
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5708 /* On some systems, we must return right away.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5709 If any more processes want to signal us, we will
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5710 get another signal.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5711 Otherwise (on systems that have WNOHANG), loop around
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5712 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
5713 #if (defined WINDOWSNT \
41969
e669966d496e Test GNU_LINUX, not LINUX.
Richard M. Stallman <rms@gnu.org>
parents: 41856
diff changeset
5714 || (defined USG && !defined GNU_LINUX \
39406
9dd4ad9bc53e (sigchld_handler) [LINUX]: Don't return from
Gerd Moellmann <gerd@gnu.org>
parents: 39361
diff changeset
5715 && !(defined HPUX && defined WNOHANG)))
16116
80a67b8f39e9 (create_process_1, sigchld_handler) [POSIX_SIGNALS]:
Richard M. Stallman <rms@gnu.org>
parents: 16076
diff changeset
5716 #if defined (USG) && ! defined (POSIX_SIGNALS)
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5717 signal (signo, sigchld_handler);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5718 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5719 errno = old_errno;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5720 return;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5721 #endif /* USG, but not HPUX with WNOHANG */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5722 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5723 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5724
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5725
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5726 static Lisp_Object
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5727 exec_sentinel_unwind (data)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5728 Lisp_Object data;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5729 {
25645
a14111a2a100 Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents: 25356
diff changeset
5730 XPROCESS (XCAR (data))->sentinel = XCDR (data);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5731 return Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5732 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5733
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5734 static Lisp_Object
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5735 exec_sentinel_error_handler (error)
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5736 Lisp_Object error;
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5737 {
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5738 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
5739 Vinhibit_quit = Qt;
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5740 update_echo_area ();
11277
d4547e4b0aab (read_process_output_error_handler)
Richard M. Stallman <rms@gnu.org>
parents: 11235
diff changeset
5741 Fsleep_for (make_number (2), Qnil);
27558
f99efd14b932 (Fstart_process): Doc fix.
Dave Love <fx@gnu.org>
parents: 27430
diff changeset
5742 return Qt;
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5743 }
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5744
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5745 static void
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5746 exec_sentinel (proc, reason)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5747 Lisp_Object proc, reason;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5748 {
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5749 Lisp_Object sentinel, obuffer, odeactivate, okeymap;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5750 register struct Lisp_Process *p = XPROCESS (proc);
46293
1fb8f75062c6 Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents: 45410
diff changeset
5751 int count = SPECPDL_INDEX ();
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5752 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
5753 int waiting = waiting_for_user_input_p;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5754
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5755 /* 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
5756 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
5757 odeactivate = Vdeactivate_mark;
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5758 XSETBUFFER (obuffer, current_buffer);
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5759 okeymap = current_buffer->keymap;
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5760
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5761 sentinel = p->sentinel;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5762 if (NILP (sentinel))
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5763 return;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5764
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5765 /* Zilch the sentinel while it's running, to avoid recursive invocations;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5766 assure that it gets restored no matter how the sentinel exits. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5767 p->sentinel = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5768 record_unwind_protect (exec_sentinel_unwind, Fcons (proc, sentinel));
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5769 /* Inhibit quit so that random quits don't screw up a running filter. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5770 specbind (Qinhibit_quit, Qt);
8231
5226ed89c1a6 (Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8063
diff changeset
5771 specbind (Qlast_nonmenu_event, Qt);
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5772
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5773 /* In case we get recursively called,
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5774 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
5775 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
5776 if (outer_running_asynch_code)
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5777 {
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5778 Lisp_Object tem;
16728
309a750fd5c0 (read_process_output, exec_sentinel):
Richard M. Stallman <rms@gnu.org>
parents: 16718
diff changeset
5779 tem = Fmatch_data (Qnil, Qnil);
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5780 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
5781 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
5782 Fset_match_data (tem);
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5783 }
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5784
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5785 /* 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
5786 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
5787 running_asynch_code = 1;
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5788
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5789 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
5790 Fcons (sentinel,
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5791 Fcons (proc, Fcons (reason, Qnil))),
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5792 !NILP (Vdebug_on_error) ? Qnil : Qerror,
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
5793 exec_sentinel_error_handler);
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5794
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5795 /* 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
5796 restore_match_data ();
16644
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5797 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
5798
8d9e41a175fa (exec_sentinel): Don't deactivate the mark. Check for asynch buffer switch.
Karl Heuer <kwzh@gnu.org>
parents: 7414
diff changeset
5799 Vdeactivate_mark = odeactivate;
23460
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
5800
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
5801 /* 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
5802 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
5803 waiting_for_user_input_p = waiting;
94f4ba741f22 (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 23405
diff changeset
5804
12808
4db1f387e85f (read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents: 12749
diff changeset
5805 #if 0
10914
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5806 if (! EQ (Fcurrent_buffer (), obuffer)
413d44c0bd41 (exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents: 10744
diff changeset
5807 || ! EQ (current_buffer->keymap, okeymap))
12808
4db1f387e85f (read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents: 12749
diff changeset
5808 #endif
13159
2af96ac471bc (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 12808
diff changeset
5809 /* 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
5810 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
5811 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
5812 if (waiting_for_user_input_p == -1)
2af96ac471bc (exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents: 12808
diff changeset
5813 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
5814
5561
fd7524d61a8d (read_process_output): Supply second arg to unbind_to.
Richard M. Stallman <rms@gnu.org>
parents: 5548
diff changeset
5815 unbind_to (count, Qnil);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5816 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5817
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5818 /* Report all recent events of a change in process status
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5819 (either run the sentinel or output a message).
44372
65c0edf0d53c Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 44314
diff changeset
5820 This is usually done while Emacs is waiting for keyboard input
65c0edf0d53c Comment change.
Richard M. Stallman <rms@gnu.org>
parents: 44314
diff changeset
5821 but can be done at other times. */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5822
20382
dbad9367d232 (create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents: 20225
diff changeset
5823 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5824 status_notify ()
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5825 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5826 register Lisp_Object proc, buffer;
6515
df7438605e1e (status_notify): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6429
diff changeset
5827 Lisp_Object tail, msg;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5828 struct gcpro gcpro1, gcpro2;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5829
6515
df7438605e1e (status_notify): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6429
diff changeset
5830 tail = Qnil;
df7438605e1e (status_notify): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents: 6429
diff changeset
5831 msg = Qnil;
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5832 /* We need to gcpro tail; if read_process_output calls a filter
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5833 which deletes a process and removes the cons to which tail points
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5834 from Vprocess_alist, and then causes a GC, tail is an unprotected
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5835 reference. */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5836 GCPRO2 (tail, msg);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5837
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5838 /* 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
5839 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
5840 update_tick = process_tick;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5841
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5842 for (tail = Vprocess_alist; !NILP (tail); tail = Fcdr (tail))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5843 {
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5844 Lisp_Object symbol;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5845 register struct Lisp_Process *p;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5846
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5847 proc = Fcdr (Fcar (tail));
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5848 p = XPROCESS (proc);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5849
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5850 if (XINT (p->tick) != XINT (p->update_tick))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5851 {
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5852 XSETINT (p->update_tick, XINT (p->tick));
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5853
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5854 /* 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
5855 while (! EQ (p->filter, Qt)
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
5856 && ! EQ (p->status, Qconnect)
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5857 && ! EQ (p->status, Qlisten)
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
5858 && ! 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
5859 && XINT (p->infd) >= 0
3a93437adce1 (status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents: 16464
diff changeset
5860 && 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
5861
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5862 buffer = p->buffer;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5863
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5864 /* 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
5865 if (!NILP (p->raw_status_low))
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5866 update_status (p);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5867 msg = status_message (p->status);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5868
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5869 /* 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
5870 symbol = p->status;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5871 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
5872 symbol = XCAR (p->status);
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5873
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5874 if (EQ (symbol, Qsignal) || EQ (symbol, Qexit)
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5875 || EQ (symbol, Qclosed))
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5876 {
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5877 if (delete_exited_processes)
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5878 remove_process (proc);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5879 else
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5880 deactivate_process (proc);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5881 }
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5882
16464
c1f19d8e5b80 (status_notify): Update p->tick again
Richard M. Stallman <rms@gnu.org>
parents: 16220
diff changeset
5883 /* 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
5884 So set p->update_tick again
c1f19d8e5b80 (status_notify): Update p->tick again
Richard M. Stallman <rms@gnu.org>
parents: 16220
diff changeset
5885 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
5886 this code to be run again. */
c1f19d8e5b80 (status_notify): Update p->tick again
Richard M. Stallman <rms@gnu.org>
parents: 16220
diff changeset
5887 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
5888 /* Now output the message suitably. */
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5889 if (!NILP (p->sentinel))
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5890 exec_sentinel (proc, msg);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5891 /* 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
5892 when a process becomes runnable. */
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5893 else if (!EQ (symbol, Qrun) && !NILP (buffer))
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5894 {
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5895 Lisp_Object ro, tem;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5896 struct buffer *old = current_buffer;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5897 int opoint, opoint_byte;
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5898 int before, before_byte;
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5899
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5900 ro = XBUFFER (buffer)->read_only;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5901
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5902 /* Avoid error if buffer is deleted
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5903 (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
5904 if (NILP (XBUFFER (buffer)->name))
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5905 continue;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5906 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
5907
16039
855c8d8ba0f0 Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents: 15895
diff changeset
5908 opoint = PT;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5909 opoint_byte = PT_BYTE;
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5910 /* Insert new output into buffer
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5911 at the current end-of-output marker,
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5912 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
5913 if (XMARKER (p->mark)->buffer)
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5914 Fgoto_char (p->mark);
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5915 else
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5916 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
5917
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
5918 before = PT;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5919 before_byte = PT_BYTE;
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5920
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5921 tem = current_buffer->read_only;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5922 current_buffer->read_only = Qnil;
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5923 insert_string ("\nProcess ");
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5924 Finsert (1, &p->name);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5925 insert_string (" ");
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5926 Finsert (1, &msg);
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5927 current_buffer->read_only = tem;
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5928 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
5929
17604
77b137e2d9a7 (read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents: 17247
diff changeset
5930 if (opoint >= before)
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5931 SET_PT_BOTH (opoint + (PT - before),
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5932 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
5933 else
20551
5f17380c85f1 (status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents: 20433
diff changeset
5934 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
5935
12215
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5936 set_buffer_internal (old);
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 }
2f1f03964f08 (status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents: 12132
diff changeset
5939 } /* end for */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5940
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5941 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
5942 redisplay_preserve_echo_area (13);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5943
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5944 UNGCPRO;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5945 }
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5946
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5947
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5948 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
5949 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
5950 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
5951 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
5952 encode subprocess input. */)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
5953 (proc, decoding, encoding)
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5954 register Lisp_Object proc, decoding, encoding;
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5955 {
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5956 register struct Lisp_Process *p;
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5957
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
5958 CHECK_PROCESS (proc);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5959 p = XPROCESS (proc);
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5960 if (XINT (p->infd) < 0)
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
5961 error ("Input file descriptor of %s closed", SDATA (p->name));
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5962 if (XINT (p->outfd) < 0)
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 46314
diff changeset
5963 error ("Output file descriptor of %s closed", SDATA (p->name));
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5964
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5965 p->decode_coding_system = Fcheck_coding_system (decoding);
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5966 p->encode_coding_system = Fcheck_coding_system (encoding);
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5967 setup_coding_system (decoding,
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
5968 proc_decode_coding_system[XINT (p->infd)]);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5969 setup_coding_system (encoding,
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
5970 proc_encode_coding_system[XINT (p->outfd)]);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5971
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5972 return Qnil;
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5973 }
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5974
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5975 DEFUN ("process-coding-system",
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5976 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
5977 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
5978 (proc)
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5979 register Lisp_Object proc;
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5980 {
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40641
diff changeset
5981 CHECK_PROCESS (proc);
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5982 return Fcons (XPROCESS (proc)->decode_coding_system,
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5983 XPROCESS (proc)->encode_coding_system);
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
5984 }
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
5985
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
5986 /* 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
5987 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
5988 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
5989 in addition to other places. */
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
5990
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
5991 static int add_keyboard_wait_descriptor_called_flag;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
5992
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
5993 void
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
5994 add_keyboard_wait_descriptor (desc)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
5995 int desc;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
5996 {
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
5997 if (! add_keyboard_wait_descriptor_called_flag)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
5998 FD_CLR (0, &input_wait_mask);
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
5999 add_keyboard_wait_descriptor_called_flag = 1;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6000 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
6001 FD_SET (desc, &non_process_wait_mask);
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6002 if (desc > max_keyboard_desc)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6003 max_keyboard_desc = desc;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6004 }
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6005
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6006 /* 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
6007
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6008 void
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6009 delete_keyboard_wait_descriptor (desc)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6010 int desc;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6011 {
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6012 int fd;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6013 int lim = max_keyboard_desc;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6014
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6015 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
6016 FD_CLR (desc, &non_process_wait_mask);
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6017
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6018 if (desc == max_keyboard_desc)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6019 for (fd = 0; fd < lim; fd++)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6020 if (FD_ISSET (fd, &input_wait_mask)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6021 && !FD_ISSET (fd, &non_keyboard_wait_mask))
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6022 max_keyboard_desc = fd;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6023 }
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6024
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6025 /* Return nonzero if *MASK has a bit set
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6026 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
6027
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6028 int
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6029 keyboard_bit_set (mask)
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6030 SELECT_TYPE *mask;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6031 {
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6032 int fd;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6033
12541
33a4586124e9 (keyboard_bit_set): Fix one-off in loop end.
Karl Heuer <kwzh@gnu.org>
parents: 12491
diff changeset
6034 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
6035 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
6036 && !FD_ISSET (fd, &non_keyboard_wait_mask))
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6037 return 1;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6038
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6039 return 0;
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6040 }
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6041
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
6042 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6043 init_process ()
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6044 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6045 register int i;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6046
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6047 #ifdef SIGCHLD
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6048 #ifndef CANNOT_DUMP
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6049 if (! noninteractive || initialized)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6050 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6051 signal (SIGCHLD, sigchld_handler);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6052 #endif
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6053
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6054 FD_ZERO (&input_wait_mask);
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6055 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
6056 FD_ZERO (&non_process_wait_mask);
7044
7032d07f5ad9 (max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7013
diff changeset
6057 max_process_desc = 0;
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
6058
9686
cd788aa8cb2a Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents: 9334
diff changeset
6059 FD_SET (0, &input_wait_mask);
4682
c4d471244116 (keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 4639
diff changeset
6060
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6061 Vprocess_alist = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6062 for (i = 0; i < MAXDESC; i++)
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6063 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6064 chan_process[i] = Qnil;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6065 proc_buffered_char[i] = -1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6066 }
17110
3a348cbb354f (Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents: 17041
diff changeset
6067 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
6068 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
6069 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6070 bzero (datagram_address, sizeof datagram_address);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6071 #endif
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6072
44073
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6073 #ifdef HAVE_SOCKETS
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6074 {
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6075 Lisp_Object subfeatures = Qnil;
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6076 #define ADD_SUBFEATURE(key, val) \
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6077 subfeatures = Fcons (Fcons (key, Fcons (val, Qnil)), subfeatures)
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6078
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6079 #ifdef NON_BLOCKING_CONNECT
44073
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6080 ADD_SUBFEATURE (QCnowait, Qt);
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6081 #endif
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6082 #ifdef DATAGRAM_SOCKETS
44073
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6083 ADD_SUBFEATURE (QCtype, Qdatagram);
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6084 #endif
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6085 #ifdef HAVE_LOCAL_SOCKETS
44073
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6086 ADD_SUBFEATURE (QCfamily, Qlocal);
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6087 #endif
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6088 #ifdef HAVE_GETSOCKNAME
44073
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6089 ADD_SUBFEATURE (QCservice, Qt);
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6090 #endif
45118
cc30538ffb5c (init_process): Only add server subfeature if we can
Jason Rumney <jasonr@gnu.org>
parents: 45099
diff changeset
6091 #if !defined(TERM) && (defined(O_NONBLOCK) || defined(O_NDELAY))
44073
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6092 ADD_SUBFEATURE (QCserver, Qt);
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6093 #endif
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6094 #ifdef SO_BINDTODEVICE
44073
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6095 ADD_SUBFEATURE (QCoptions, intern ("bindtodevice"));
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6096 #endif
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6097 #ifdef SO_BROADCAST
44073
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6098 ADD_SUBFEATURE (QCoptions, intern ("broadcast"));
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6099 #endif
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6100 #ifdef SO_DONTROUTE
44073
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6101 ADD_SUBFEATURE (QCoptions, intern ("dontroute"));
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6102 #endif
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6103 #ifdef SO_KEEPALIVE
44073
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6104 ADD_SUBFEATURE (QCoptions, intern ("keepalive"));
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6105 #endif
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6106 #ifdef SO_LINGER
44073
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6107 ADD_SUBFEATURE (QCoptions, intern ("linger"));
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6108 #endif
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6109 #ifdef SO_OOBINLINE
44073
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6110 ADD_SUBFEATURE (QCoptions, intern ("oobinline"));
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6111 #endif
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6112 #ifdef SO_PRIORITY
44073
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6113 ADD_SUBFEATURE (QCoptions, intern ("priority"));
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6114 #endif
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6115 #ifdef SO_REUSEADDR
44073
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6116 ADD_SUBFEATURE (QCoptions, intern ("reuseaddr"));
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6117 #endif
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6118 Fprovide (intern ("make-network-process"), subfeatures);
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6119 }
9984126a7008 (init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents: 44067
diff changeset
6120 #endif /* HAVE_SOCKETS */
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6121 }
4231
91a883c56382 (Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents: 4057
diff changeset
6122
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21414
diff changeset
6123 void
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6124 syms_of_process ()
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6125 {
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6126 Qprocessp = intern ("processp");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6127 staticpro (&Qprocessp);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6128 Qrun = intern ("run");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6129 staticpro (&Qrun);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6130 Qstop = intern ("stop");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6131 staticpro (&Qstop);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6132 Qsignal = intern ("signal");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6133 staticpro (&Qsignal);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6134
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6135 /* Qexit is already staticpro'd by syms_of_eval; don't staticpro it
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6136 here again.
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6137
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6138 Qexit = intern ("exit");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6139 staticpro (&Qexit); */
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6140
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6141 Qopen = intern ("open");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6142 staticpro (&Qopen);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6143 Qclosed = intern ("closed");
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6144 staticpro (&Qclosed);
43598
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
6145 Qconnect = intern ("connect");
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
6146 staticpro (&Qconnect);
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
6147 Qfailed = intern ("failed");
f49377cf2e3c (Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents: 42600
diff changeset
6148 staticpro (&Qfailed);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6149 Qlisten = intern ("listen");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6150 staticpro (&Qlisten);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6151 Qlocal = intern ("local");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6152 staticpro (&Qlocal);
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6153 Qdatagram = intern ("datagram");
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6154 staticpro (&Qdatagram);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6155
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6156 QCname = intern (":name");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6157 staticpro (&QCname);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6158 QCbuffer = intern (":buffer");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6159 staticpro (&QCbuffer);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6160 QChost = intern (":host");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6161 staticpro (&QChost);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6162 QCservice = intern (":service");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6163 staticpro (&QCservice);
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6164 QCtype = intern (":type");
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6165 staticpro (&QCtype);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6166 QClocal = intern (":local");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6167 staticpro (&QClocal);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6168 QCremote = intern (":remote");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6169 staticpro (&QCremote);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6170 QCcoding = intern (":coding");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6171 staticpro (&QCcoding);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6172 QCserver = intern (":server");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6173 staticpro (&QCserver);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6174 QCnowait = intern (":nowait");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6175 staticpro (&QCnowait);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6176 QCsentinel = intern (":sentinel");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6177 staticpro (&QCsentinel);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6178 QClog = intern (":log");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6179 staticpro (&QClog);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6180 QCnoquery = intern (":noquery");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6181 staticpro (&QCnoquery);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6182 QCstop = intern (":stop");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6183 staticpro (&QCstop);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6184 QCoptions = intern (":options");
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6185 staticpro (&QCoptions);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6186
8231
5226ed89c1a6 (Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8063
diff changeset
6187 Qlast_nonmenu_event = intern ("last-nonmenu-event");
5226ed89c1a6 (Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8063
diff changeset
6188 staticpro (&Qlast_nonmenu_event);
5226ed89c1a6 (Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 8063
diff changeset
6189
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6190 staticpro (&Vprocess_alist);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6191
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6192 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
6193 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
6194 nil means don't delete them until `list-processes' is run. */);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6195
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6196 delete_exited_processes = 1;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6197
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6198 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
6199 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
6200 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
6201 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
6202 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
6203 The value takes effect when `start-process' is called. */);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6204 Vprocess_connection_type = Qt;
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6205
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6206 defsubr (&Sprocessp);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6207 defsubr (&Sget_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6208 defsubr (&Sget_buffer_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6209 defsubr (&Sdelete_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6210 defsubr (&Sprocess_status);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6211 defsubr (&Sprocess_exit_status);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6212 defsubr (&Sprocess_id);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6213 defsubr (&Sprocess_name);
9030
b14532c71632 (exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8570
diff changeset
6214 defsubr (&Sprocess_tty_name);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6215 defsubr (&Sprocess_command);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6216 defsubr (&Sset_process_buffer);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6217 defsubr (&Sprocess_buffer);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6218 defsubr (&Sprocess_mark);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6219 defsubr (&Sset_process_filter);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6220 defsubr (&Sprocess_filter);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6221 defsubr (&Sset_process_sentinel);
16058
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
6222 defsubr (&Sprocess_sentinel);
6830
bcaddbe53068 (Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents: 6823
diff changeset
6223 defsubr (&Sset_process_window_size);
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6224 defsubr (&Sset_process_inherit_coding_system_flag);
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6225 defsubr (&Sprocess_inherit_coding_system_flag);
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6226 defsubr (&Sset_process_query_on_exit_flag);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6227 defsubr (&Sprocess_query_on_exit_flag);
16058
924aeb9ed7c3 (Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents: 16053
diff changeset
6228 defsubr (&Sprocess_contact);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6229 defsubr (&Slist_processes);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6230 defsubr (&Sprocess_list);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6231 defsubr (&Sstart_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6232 #ifdef HAVE_SOCKETS
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6233 defsubr (&Sset_network_process_options);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6234 defsubr (&Smake_network_process);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6235 #endif /* HAVE_SOCKETS */
43968
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6236 #ifdef DATAGRAM_SOCKETS
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6237 defsubr (&Sprocess_datagram_address);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6238 defsubr (&Sset_process_datagram_address);
7ec801358b7e (Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents: 43642
diff changeset
6239 #endif
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6240 defsubr (&Saccept_process_output);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6241 defsubr (&Sprocess_send_region);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6242 defsubr (&Sprocess_send_string);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6243 defsubr (&Sinterrupt_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6244 defsubr (&Skill_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6245 defsubr (&Squit_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6246 defsubr (&Sstop_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6247 defsubr (&Scontinue_process);
24352
023601636a18 (syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents: 23930
diff changeset
6248 defsubr (&Sprocess_running_child_p);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6249 defsubr (&Sprocess_send_eof);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6250 defsubr (&Ssignal_process);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6251 defsubr (&Swaiting_for_user_input_p);
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6252 /* defsubr (&Sprocess_connection); */
17041
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6253 defsubr (&Sset_process_coding_system);
b61cbe595be5 Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents: 16780
diff changeset
6254 defsubr (&Sprocess_coding_system);
578
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6255 }
a4591b4d5435 Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
6256
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6257
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6258 #else /* not subprocesses */
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6259
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6260 #include <sys/types.h>
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6261 #include <errno.h>
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6262
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6263 #include "lisp.h"
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6264 #include "systime.h"
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6265 #include "charset.h"
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6266 #include "coding.h"
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6267 #include "termopts.h"
12132
017f32786ed3 [!subprocesses]: Include sysselect.h.
Karl Heuer <kwzh@gnu.org>
parents: 11926
diff changeset
6268 #include "sysselect.h"
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6269
765
e4093444f9f8 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 692
diff changeset
6270 extern int frame_garbaged;
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6271
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6272 extern EMACS_TIME timer_check ();
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6273 extern int timers_run;
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6274
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6275 Lisp_Object QCtype;
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6276
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6277 /* As described above, except assuming that there are no 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 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
6280
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6281 time_limit is:
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6282 timeout in seconds, or
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6283 zero for no limit, or
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6284 -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
6285
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
6286 read_kbd is a Lisp_Object:
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6287 0 to ignore keyboard input, or
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6288 1 to return when input is available, or
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6289 -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
6290 the quit handler.
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6291 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
6292 (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
6293 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
6294 `subprocesses' isn't defined.
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 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
6297 output that arrives.
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6298
3591
507f64624555 Apply typo patches from Paul Eggert.
Jim Blandy <jimb@redhat.com>
parents: 3510
diff changeset
6299 Return true iff we received input from any process. */
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6300
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6301 int
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6302 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
6303 int time_limit, microsecs;
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
6304 Lisp_Object read_kbd;
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
6305 int do_display;
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6306 {
22535
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6307 register int nfds;
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6308 EMACS_TIME end_time, timeout;
14278
3562c5f43780 (wait_reading_process_input) [not subprocesses]: Do
Karl Heuer <kwzh@gnu.org>
parents: 14186
diff changeset
6309 SELECT_TYPE waitchannels;
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6310 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
6311 /* 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
6312 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
6313 Lisp_Object wait_for_cell = Qnil;
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6314
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6315 /* 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
6316 if (CONSP (read_kbd))
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6317 {
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
6318 wait_for_cell = read_kbd;
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6319 XSETFASTINT (read_kbd, 0);
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6320 }
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6321
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6322 /* What does time_limit really mean? */
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6323 if (time_limit || microsecs)
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6324 {
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6325 EMACS_GET_TIME (end_time);
22535
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6326 EMACS_SET_SECS_USECS (timeout, time_limit, microsecs);
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6327 EMACS_ADD_TIME (end_time, end_time, timeout);
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6328 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6329
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6330 /* Turn off periodic alarms (in case they are in use)
47431
8871e67384e4 (wait_reading_process_input, both versions):
Richard M. Stallman <rms@gnu.org>
parents: 47020
diff changeset
6331 and then turn off any other atimers,
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6332 because the select emulator uses alarms. */
47431
8871e67384e4 (wait_reading_process_input, both versions):
Richard M. Stallman <rms@gnu.org>
parents: 47020
diff changeset
6333 stop_polling ();
27430
1aa71680fe50 (toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents: 27028
diff changeset
6334 turn_on_atimers (0);
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6335
22535
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6336 while (1)
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6337 {
14802
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6338 int timeout_reduced_for_timers = 0;
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6339
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6340 /* If calling from keyboard input, do not quit
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6341 since we want to return C-g as an input character.
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6342 Otherwise, do pending quit if requested. */
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
6343 if (XINT (read_kbd) >= 0)
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6344 QUIT;
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6345
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6346 /* 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
6347 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
6348 break;
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6349
14802
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6350 /* 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
6351 /* Exit if already run out */
22535
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6352 if (time_limit == -1)
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6353 {
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6354 /* -1 specified for timeout means
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6355 gobble output available now
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6356 but don't wait at all. */
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6357
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6358 EMACS_SET_SECS_USECS (timeout, 0, 0);
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6359 }
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6360 else if (time_limit || microsecs)
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6361 {
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6362 EMACS_GET_TIME (timeout);
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6363 EMACS_SUB_TIME (timeout, end_time, timeout);
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6364 if (EMACS_TIME_NEG_P (timeout))
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6365 break;
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6366 }
22535
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6367 else
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 EMACS_SET_SECS_USECS (timeout, 100000, 0);
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6370 }
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6371
14802
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6372 /* 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
6373 run timer events directly.
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6374 (Callers that will immediately read keyboard events
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6375 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
6376 if (NILP (wait_for_cell))
14802
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6377 {
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6378 EMACS_TIME timer_delay;
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6379
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6380 do
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6381 {
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6382 int old_timers_run = timers_run;
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6383 timer_delay = timer_check (1);
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6384 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
6385 /* 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
6386 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
6387 redisplay_preserve_echo_area (14);
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6388 else
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6389 break;
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6390 }
34660
75866a7ebaec (wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents: 34647
diff changeset
6391 while (!detect_input_pending ());
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6392
22535
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6393 /* 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
6394 if (XINT (read_kbd) != 0
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6395 && requeued_events_pending_p ())
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6396 break;
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6397
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6398 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
6399 {
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6400 EMACS_TIME difference;
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6401 EMACS_SUB_TIME (difference, timer_delay, timeout);
14802
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6402 if (EMACS_TIME_NEG_P (difference))
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6403 {
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6404 timeout = timer_delay;
14802
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6405 timeout_reduced_for_timers = 1;
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6406 }
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6407 }
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6408 }
45827a5afe4d [!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents: 14785
diff changeset
6409
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6410 /* Cause C-g and alarm signals to take immediate action,
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6411 and cause input available signals to zero out timeout. */
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
6412 if (XINT (read_kbd) < 0)
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6413 set_waiting_for_input (&timeout);
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6414
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6415 /* Wait till there is something to do. */
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6416
39973
579177964efa Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents: 39964
diff changeset
6417 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
6418 FD_ZERO (&waitchannels);
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6419 else
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6420 FD_SET (0, &waitchannels);
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6421
765
e4093444f9f8 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 692
diff changeset
6422 /* If a frame has been newly mapped and needs updating,
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6423 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
6424 if (frame_garbaged && do_display)
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6425 {
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6426 clear_waiting_for_input ();
35336
002c02db42d3 Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents: 34660
diff changeset
6427 redisplay_preserve_echo_area (15);
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6428 if (XINT (read_kbd) < 0)
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6429 set_waiting_for_input (&timeout);
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6430 }
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6431
15025
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6432 if (XINT (read_kbd) && detect_input_pending ())
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6433 {
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6434 nfds = 0;
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6435 FD_ZERO (&waitchannels);
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6436 }
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6437 else
e5f54fd1c352 (wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents: 15021
diff changeset
6438 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
6439 &timeout);
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6440
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6441 xerrno = errno;
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6442
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6443 /* Make C-g and alarm signals set flags again */
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6444 clear_waiting_for_input ();
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6445
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6446 /* 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
6447 do_pending_window_change (0);
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6448
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6449 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
6450 /* 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
6451 break;
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6452
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6453 if (nfds == -1)
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6454 {
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6455 /* If the system call was interrupted, then go around the
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6456 loop again. */
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6457 if (xerrno == EINTR)
14278
3562c5f43780 (wait_reading_process_input) [not subprocesses]: Do
Karl Heuer <kwzh@gnu.org>
parents: 14186
diff changeset
6458 FD_ZERO (&waitchannels);
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6459 else
26088
b7aa6ac26872 Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents: 26019
diff changeset
6460 error ("select error: %s", emacs_strerror (xerrno));
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6461 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6462 #ifdef sun
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6463 else if (nfds > 0 && (waitchannels & 1) && interrupt_input)
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6464 /* System sometimes fails to deliver SIGIO. */
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6465 kill (getpid (), SIGIO);
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6466 #endif
3915
55ed7a65746e (wait_reading_process_input): Use SIGIO only if defined.
Richard M. Stallman <rms@gnu.org>
parents: 3826
diff changeset
6467 #ifdef SIGIO
650
39f0e62a8511 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 648
diff changeset
6468 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
6469 kill (getpid (), SIGIO);
3915
55ed7a65746e (wait_reading_process_input): Use SIGIO only if defined.
Richard M. Stallman <rms@gnu.org>
parents: 3826
diff changeset
6470 #endif
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6471
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6472 /* Check for keyboard input */
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6473
37413
49147b9fe206 (wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents: 37398
diff changeset
6474 if ((XINT (read_kbd) != 0)
49147b9fe206 (wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents: 37398
diff changeset
6475 && detect_input_pending_run_timers (do_display))
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6476 {
37413
49147b9fe206 (wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents: 37398
diff changeset
6477 swallow_events (do_display);
14806
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6478 if (detect_input_pending_run_timers (do_display))
232b90ad50e8 (wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents: 14802
diff changeset
6479 break;
37413
49147b9fe206 (wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents: 37398
diff changeset
6480 }
49147b9fe206 (wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents: 37398
diff changeset
6481
22535
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6482 /* 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
6483 if (XINT (read_kbd) != 0
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6484 && requeued_events_pending_p ())
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6485 break;
fd9324c5a498 (wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents: 22523
diff changeset
6486
15064
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6487 /* 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
6488 but don't run any timers.
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6489 ??? (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
6490 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
6491 has been this way since July 1994.
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6492 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
6493 if (! NILP (wait_for_cell)
15064
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6494 && detect_input_pending ())
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6495 {
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6496 swallow_events (do_display);
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6497 if (detect_input_pending ())
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6498 break;
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6499 }
fb0f2804c34a (wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents: 15025
diff changeset
6500
15021
af36df262fc5 (wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents: 14998
diff changeset
6501 /* 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
6502 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
6503 break;
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6504 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6505
2120
fc3cdca22f8d * process.c (process_send_signal): In the TERMIOS code for sending
Jim Blandy <jimb@redhat.com>
parents: 1925
diff changeset
6506 start_polling ();
fc3cdca22f8d * process.c (process_send_signal): In the TERMIOS code for sending
Jim Blandy <jimb@redhat.com>
parents: 1925
diff changeset
6507
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6508 return 0;
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6509 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6510
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6511
39964
4ca5cbe5610d (process-inherit-coding-system-flag, get-buffer-process): Do not confuse
Pavel Janík <Pavel@Janik.cz>
parents: 39812
diff changeset
6512 /* 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
6513 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
6514 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
6515 0)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6516 (name)
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6517 register Lisp_Object name;
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6518 {
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6519 return Qnil;
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6520 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6521
39964
4ca5cbe5610d (process-inherit-coding-system-flag, get-buffer-process): Do not confuse
Pavel Janík <Pavel@Janik.cz>
parents: 39812
diff changeset
6522 /* 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
6523 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
6524 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
6525 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
6526 1, 1, 0,
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6527 0)
6b389fb978bc Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 39973
diff changeset
6528 (process)
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6529 register Lisp_Object process;
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6530 {
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6531 /* Ignore the argument and return the value of
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6532 inherit-process-coding-system. */
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6533 return inherit_process_coding_system ? Qt : Qnil;
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6534 }
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6535
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6536 /* Kill all processes associated with `buffer'.
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6537 If `buffer' is nil, kill all processes.
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6538 Since we have no subprocesses, this does nothing. */
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6539
21414
aac7354edaed (kill_buffer_processes): Make consistent with
Karl Heuer <kwzh@gnu.org>
parents: 21281
diff changeset
6540 void
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6541 kill_buffer_processes (buffer)
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6542 Lisp_Object buffer;
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6543 {
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6544 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6545
21978
ba8852d809f6 (init_process, syms_of_process): Make definition consistent with
Eli Zaretskii <eliz@gnu.org>
parents: 21950
diff changeset
6546 void
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6547 init_process ()
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6548 {
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6549 }
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6550
21978
ba8852d809f6 (init_process, syms_of_process): Make definition consistent with
Eli Zaretskii <eliz@gnu.org>
parents: 21950
diff changeset
6551 void
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6552 syms_of_process ()
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6553 {
44067
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6554 QCtype = intern (":type");
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6555 staticpro (&QCtype);
e8a136850817 (QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents: 44041
diff changeset
6556
588
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6557 defsubr (&Sget_buffer_process);
21656
bb39a5863a82 (Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents: 21530
diff changeset
6558 defsubr (&Sprocess_inherit_coding_system_flag);
588
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
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6561
f284b1a71fb3 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 578
diff changeset
6562 #endif /* not subprocesses */