Mercurial > emacs
annotate src/process.c @ 103384:1a60127fa212
(Viewing Info files outside of Emacs): Xinfo is no more.
(Help installing Emacs): Remove reference to deleted X11 node.
(Associating modes with files): Interpreter-mode-alist is no longer
subservient to auto-mode-alist.
(Installing Emacs): Change future Emacs version.
(Linking with -lX11 fails): Remove old section.
(Packages that do not come with Emacs): Update ELL location.
Emacs Lisp archive is dead.
(Emacs for Windows): Remove reference to old CE port.
(Emacs for OS/2, Emacs for Atari ST, Emacs for the Amiga ):
Remove old ports.
(Emacs for GNUstep): Rename from "Emacs for NeXTSTEP" and update.
(Removing flashing messages): Remove section about non-existent Gnus option.
author | Glenn Morris <rgm@gnu.org> |
---|---|
date | Fri, 12 Jun 2009 02:47:25 +0000 |
parents | 3fb472c8bc3c |
children | c849cd055fab |
rev | line source |
---|---|
578 | 1 /* Asynchronous subprocess control for GNU Emacs. |
64770
a0d1312ede66
Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
64084
diff
changeset
|
2 Copyright (C) 1985, 1986, 1987, 1988, 1993, 1994, 1995, |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
3 1996, 1998, 1999, 2001, 2002, 2003, 2004, |
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
4 2005, 2006, 2007, 2008, 2009 Free Software Foundation, Inc. |
578 | 5 |
6 This file is part of GNU Emacs. | |
7 | |
94963
8971ddf55736
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93896
diff
changeset
|
8 GNU Emacs is free software: you can redistribute it and/or modify |
578 | 9 it under the terms of the GNU General Public License as published by |
94963
8971ddf55736
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93896
diff
changeset
|
10 the Free Software Foundation, either version 3 of the License, or |
8971ddf55736
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93896
diff
changeset
|
11 (at your option) any later version. |
578 | 12 |
13 GNU Emacs is distributed in the hope that it will be useful, | |
14 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
16 GNU General Public License for more details. | |
17 | |
18 You should have received a copy of the GNU General Public License | |
94963
8971ddf55736
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93896
diff
changeset
|
19 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */ |
578 | 20 |
21 | |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
22 #include <config.h> |
578 | 23 #include <signal.h> |
24 | |
588 | 25 /* This file is split into two parts by the following preprocessor |
26 conditional. The 'then' clause contains all of the support for | |
27 asynchronous subprocesses. The 'else' clause contains stub | |
28 versions of some of the asynchronous subprocess routines that are | |
29 often called elsewhere in Emacs, so we don't have to #ifdef the | |
30 sections that call them. */ | |
31 | |
32 | |
578 | 33 #ifdef subprocesses |
34 | |
35 #include <stdio.h> | |
36 #include <errno.h> | |
37 #include <setjmp.h> | |
38 #include <sys/types.h> /* some typedefs are used in sys/file.h */ | |
39 #include <sys/file.h> | |
40 #include <sys/stat.h> | |
68146
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
41 #ifdef HAVE_INTTYPES_H |
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
42 #include <inttypes.h> |
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
43 #endif |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
44 #ifdef STDC_HEADERS |
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
45 #include <stdlib.h> |
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
46 #endif |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
47 |
6158 | 48 #ifdef HAVE_UNISTD_H |
49 #include <unistd.h> | |
50 #endif | |
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
51 #include <fcntl.h> |
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
52 |
578 | 53 #ifdef HAVE_SOCKETS /* TCP connection support, if kernel can do it */ |
54 #include <sys/socket.h> | |
55 #include <netdb.h> | |
56 #include <netinet/in.h> | |
57 #include <arpa/inet.h> | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
58 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
59 /* Are local (unix) sockets supported? */ |
91702
b7a5a89054dc
* configure.in (LIBX11_MACHINE, HAVE_XFREE386): Remove code
Dan Nicolaescu <dann@ics.uci.edu>
parents:
91551
diff
changeset
|
60 #if defined (HAVE_SYS_UN_H) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
61 #if !defined (AF_LOCAL) && defined (AF_UNIX) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
62 #define AF_LOCAL AF_UNIX |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
63 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
64 #ifdef AF_LOCAL |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
65 #define HAVE_LOCAL_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
66 #include <sys/un.h> |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
67 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
68 #endif |
578 | 69 #endif /* HAVE_SOCKETS */ |
70 | |
87730 | 71 #if defined(BSD_SYSTEM) |
578 | 72 #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
|
73 #if !defined (O_NDELAY) && defined (HAVE_PTYS) && !defined(USG5) |
578 | 74 #include <fcntl.h> |
75 #endif /* HAVE_PTYS and no O_NDELAY */ | |
87730 | 76 #endif /* BSD_SYSTEM */ |
5240
eed870591987
(Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents:
5239
diff
changeset
|
77 |
578 | 78 #ifdef NEED_BSDTTY |
79 #include <bsdtty.h> | |
80 #endif | |
81 | |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
82 /* Can we use SIOCGIFCONF and/or SIOCGIFADDR */ |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
83 #ifdef HAVE_SOCKETS |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
84 #if defined(HAVE_SYS_IOCTL_H) && defined(HAVE_NET_IF_H) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
85 /* sys/ioctl.h may have been included already */ |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
86 #ifndef SIOCGIFADDR |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
87 #include <sys/ioctl.h> |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
88 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
89 #include <net/if.h> |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
90 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
91 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
92 |
48088 | 93 #ifdef HAVE_SYS_WAIT |
94 #include <sys/wait.h> | |
95 #endif | |
578 | 96 |
85362
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
97 #ifdef HAVE_RES_INIT |
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
98 #include <netinet/in.h> |
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
99 #include <arpa/nameser.h> |
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
100 #include <resolv.h> |
68022
e213d76ca446
[WINDOWSNT]: Undef AF_INET6 to disable IPv6 support for w32.
Eli Zaretskii <eliz@gnu.org>
parents:
68008
diff
changeset
|
101 #endif |
e213d76ca446
[WINDOWSNT]: Undef AF_INET6 to disable IPv6 support for w32.
Eli Zaretskii <eliz@gnu.org>
parents:
68008
diff
changeset
|
102 |
65764
375ab086d366
* image.c (slurp_file, xbm_read_bitmap_data): Cast to the correct
Dan Nicolaescu <dann@ics.uci.edu>
parents:
65713
diff
changeset
|
103 #include "lisp.h" |
578 | 104 #include "systime.h" |
1047
1ab1ed32e82a
* process.c: Include "systty.h", not "systerm.h".
Jim Blandy <jimb@redhat.com>
parents:
1030
diff
changeset
|
105 #include "systty.h" |
578 | 106 |
107 #include "window.h" | |
108 #include "buffer.h" | |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
109 #include "character.h" |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
110 #include "coding.h" |
578 | 111 #include "process.h" |
83004
7900111db01c
Converted display hooks to be display-local. Plus many bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents:
82993
diff
changeset
|
112 #include "frame.h" |
578 | 113 #include "termhooks.h" |
114 #include "termopts.h" | |
115 #include "commands.h" | |
31099
0fe5afca71e4
Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents:
30582
diff
changeset
|
116 #include "keyboard.h" |
16780 | 117 #include "blockinput.h" |
21514 | 118 #include "dispextern.h" |
26868 | 119 #include "composite.h" |
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
120 #include "atimer.h" |
578 | 121 |
4682
c4d471244116
(keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
4639
diff
changeset
|
122 Lisp_Object Qprocessp; |
74749 | 123 Lisp_Object Qrun, Qstop, Qsignal; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
124 Lisp_Object Qopen, Qclosed, Qconnect, Qfailed, Qlisten; |
68008 | 125 Lisp_Object Qlocal, Qipv4, Qdatagram; |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
126 Lisp_Object Qreal, Qnetwork, Qserial; |
68008 | 127 #ifdef AF_INET6 |
128 Lisp_Object Qipv6; | |
129 #endif | |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
130 Lisp_Object QCport, QCspeed, QCprocess; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
131 Lisp_Object QCbytesize, QCstopbits, QCparity, Qodd, Qeven; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
132 Lisp_Object QCflowcontrol, Qhw, Qsw, QCsummary; |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
133 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
|
134 Lisp_Object QClocal, QCremote, QCcoding; |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
135 Lisp_Object QCserver, QCnowait, QCnoquery, QCstop; |
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
136 Lisp_Object QCsentinel, QClog, QCoptions, QCplist; |
8231
5226ed89c1a6
(Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
8063
diff
changeset
|
137 Lisp_Object Qlast_nonmenu_event; |
44041
134644f94850
(QCfamily, QCfiler): Remove duplicate declaration and initialization.
Jason Rumney <jasonr@gnu.org>
parents:
44038
diff
changeset
|
138 /* 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
|
139 QCfilter in keyboard.c. */ |
134644f94850
(QCfamily, QCfiler): Remove duplicate declaration and initialization.
Jason Rumney <jasonr@gnu.org>
parents:
44038
diff
changeset
|
140 extern Lisp_Object QCfamily, QCfilter; |
134644f94850
(QCfamily, QCfiler): Remove duplicate declaration and initialization.
Jason Rumney <jasonr@gnu.org>
parents:
44038
diff
changeset
|
141 |
578 | 142 /* Qexit is declared and initialized in eval.c. */ |
143 | |
44890
01b93e5e53a7
Patch for building Emacs on Mac OS X. April 26, 2002. See ChangeLog,
Andrew Choi <akochoi@shaw.ca>
parents:
44372
diff
changeset
|
144 /* 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
|
145 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
|
146 /* 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
|
147 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
|
148 |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
149 Lisp_Object Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess, Qttname, Qtpgid; |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
150 Lisp_Object Qminflt, Qmajflt, Qcminflt, Qcmajflt, Qutime, Qstime, Qcstime; |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
151 Lisp_Object Qcutime, Qpri, Qnice, Qthcount, Qstart, Qvsize, Qrss, Qargs; |
100828
0b30d1767fab
(top level) <Qtime, Qctime>: New variables.
Eli Zaretskii <eliz@gnu.org>
parents:
100824
diff
changeset
|
152 Lisp_Object Quser, Qgroup, Qetime, Qpcpu, Qpmem, Qtime, Qctime; |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
153 |
578 | 154 #ifdef HAVE_SOCKETS |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
155 #define NETCONN_P(p) (EQ (XPROCESS (p)->type, Qnetwork)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
156 #define NETCONN1_P(p) (EQ ((p)->type, Qnetwork)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
157 #define SERIALCONN_P(p) (EQ (XPROCESS (p)->type, Qserial)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
158 #define SERIALCONN1_P(p) (EQ ((p)->type, Qserial)) |
578 | 159 #else |
160 #define NETCONN_P(p) 0 | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
161 #define NETCONN1_P(p) 0 |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
162 #define SERIALCONN_P(p) 0 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
163 #define SERIALCONN1_P(p) 0 |
578 | 164 #endif /* HAVE_SOCKETS */ |
165 | |
166 /* Define first descriptor number available for subprocesses. */ | |
167 #define FIRST_PROC_DESC 3 | |
168 | |
169 /* Define SIGCHLD as an alias for SIGCLD. There are many conditionals | |
170 testing SIGCHLD. */ | |
171 | |
172 #if !defined (SIGCHLD) && defined (SIGCLD) | |
173 #define SIGCHLD SIGCLD | |
174 #endif /* SIGCLD */ | |
175 | |
176 #include "syssignal.h" | |
177 | |
4639 | 178 #include "syswait.h" |
578 | 179 |
59689
007a1a6d92de
* s/darwin.h: Removed PTY_ITERATION from here.
Steven Tamm <steventamm@mac.com>
parents:
59113
diff
changeset
|
180 extern char *get_operating_system_release (); |
25770
3a44b5298cd5
(list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents:
25760
diff
changeset
|
181 |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
182 /* Serial processes require termios or Windows. */ |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
183 #if defined (HAVE_TERMIOS) || defined (WINDOWSNT) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
184 #define HAVE_SERIAL |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
185 #endif |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
186 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
187 #ifdef HAVE_SERIAL |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
188 /* From sysdep.c or w32.c */ |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
189 extern int serial_open (char *port); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
190 extern void serial_configure (struct Lisp_Process *p, Lisp_Object contact); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
191 #endif |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
192 |
31099
0fe5afca71e4
Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents:
30582
diff
changeset
|
193 #ifndef USE_CRT_DLL |
5543 | 194 extern int errno; |
31099
0fe5afca71e4
Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents:
30582
diff
changeset
|
195 #endif |
578 | 196 |
8331
14ddb4c66461
[!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents:
8287
diff
changeset
|
197 #ifndef HAVE_H_ERRNO |
14ddb4c66461
[!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents:
8287
diff
changeset
|
198 extern int h_errno; |
14ddb4c66461
[!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents:
8287
diff
changeset
|
199 #endif |
14ddb4c66461
[!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents:
8287
diff
changeset
|
200 |
578 | 201 /* t means use pty, nil means use a pipe, |
202 maybe other values to come. */ | |
4682
c4d471244116
(keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
4639
diff
changeset
|
203 static Lisp_Object Vprocess_connection_type; |
578 | 204 |
10548
dcae4394587d
(process_tick, update_tick): Make non-static.
Karl Heuer <kwzh@gnu.org>
parents:
10527
diff
changeset
|
205 /* 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
|
206 emulation of `select'. */ |
578 | 207 /* 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
|
208 int process_tick; |
578 | 209 /* 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
|
210 int update_tick; |
578 | 211 |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
212 /* 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
|
213 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
214 #ifdef BROKEN_NON_BLOCKING_CONNECT |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
215 #undef NON_BLOCKING_CONNECT |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
216 #else |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
217 #ifndef NON_BLOCKING_CONNECT |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
218 #ifdef HAVE_SOCKETS |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
219 #ifdef HAVE_SELECT |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
220 #if defined (HAVE_GETPEERNAME) || defined (GNU_LINUX) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
221 #if defined (O_NONBLOCK) || defined (O_NDELAY) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
222 #if defined (EWOULDBLOCK) || defined (EINPROGRESS) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
223 #define NON_BLOCKING_CONNECT |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
224 #endif /* EWOULDBLOCK || EINPROGRESS */ |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
225 #endif /* O_NONBLOCK || O_NDELAY */ |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
226 #endif /* HAVE_GETPEERNAME || GNU_LINUX */ |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
227 #endif /* HAVE_SELECT */ |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
228 #endif /* HAVE_SOCKETS */ |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
229 #endif /* NON_BLOCKING_CONNECT */ |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
230 #endif /* BROKEN_NON_BLOCKING_CONNECT */ |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
231 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
232 /* 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
|
233 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
|
234 "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
|
235 or emulation of select using FIONREAD. */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
236 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
237 #ifdef BROKEN_DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
238 #undef DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
239 #else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
240 #ifndef DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
241 #ifdef HAVE_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
242 #if defined (HAVE_SELECT) || defined (FIONREAD) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
243 #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
|
244 #define DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
245 #endif /* HAVE_SENDTO && HAVE_RECVFROM && EMSGSIZE */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
246 #endif /* HAVE_SELECT || FIONREAD */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
247 #endif /* HAVE_SOCKETS */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
248 #endif /* DATAGRAM_SOCKETS */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
249 #endif /* BROKEN_DATAGRAM_SOCKETS */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
250 |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
251 #if !defined (ADAPTIVE_READ_BUFFERING) && !defined (NO_ADAPTIVE_READ_BUFFERING) |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
252 #ifdef EMACS_HAS_USECS |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
253 #define ADAPTIVE_READ_BUFFERING |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
254 #endif |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
255 #endif |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
256 |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
257 #ifdef ADAPTIVE_READ_BUFFERING |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
258 #define READ_OUTPUT_DELAY_INCREMENT 10000 |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
259 #define READ_OUTPUT_DELAY_MAX (READ_OUTPUT_DELAY_INCREMENT * 5) |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
260 #define READ_OUTPUT_DELAY_MAX_MAX (READ_OUTPUT_DELAY_INCREMENT * 7) |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
261 |
63114
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
262 /* Number of processes which have a non-zero read_output_delay, |
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
263 and therefore might be delayed for adaptive read buffering. */ |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
264 |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
265 static int process_output_delay_count; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
266 |
63114
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
267 /* Non-zero if any process has non-nil read_output_skip. */ |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
268 |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
269 static int process_output_skip; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
270 |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
271 /* Non-nil means to delay reading process output to improve buffering. |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
272 A value of t means that delay is reset after each send, any other |
63114
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
273 non-nil value does not reset the delay. A value of nil disables |
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
274 adaptive read buffering completely. */ |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
275 static Lisp_Object Vprocess_adaptive_read_buffering; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
276 #else |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
277 #define process_output_delay_count 0 |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
278 #endif |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
279 |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
280 |
10527
68b8191091a7
#include sysselect.h instead of defining things by hand.
Karl Heuer <kwzh@gnu.org>
parents:
10032
diff
changeset
|
281 #include "sysselect.h" |
578 | 282 |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
283 static int keyboard_bit_set P_ ((SELECT_TYPE *)); |
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
284 static void deactivate_process P_ ((Lisp_Object)); |
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
285 static void status_notify P_ ((struct Lisp_Process *)); |
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
286 static int read_process_output P_ ((Lisp_Object, int)); |
25770
3a44b5298cd5
(list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents:
25760
diff
changeset
|
287 |
13414
b035c6e41457
[HAVE_NTGUI] (POLL_FOR_INPUT): Define macro.
Geoff Voelker <voelker@cs.washington.edu>
parents:
13159
diff
changeset
|
288 /* 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
|
289 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
|
290 #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
|
291 #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
|
292 #endif |
cfe4840ffde9
(Fopen_network_stream): Call bind_polling_period; later unbind the binding.
Richard M. Stallman <rms@gnu.org>
parents:
7454
diff
changeset
|
293 |
72727
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
294 static Lisp_Object get_process (); |
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
295 static void exec_sentinel (); |
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
296 |
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
297 extern EMACS_TIME timer_check (); |
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
298 extern int timers_run; |
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
299 |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
300 /* Mask of bits indicating the descriptors that we wait for input on. */ |
578 | 301 |
4682
c4d471244116
(keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
4639
diff
changeset
|
302 static SELECT_TYPE input_wait_mask; |
c4d471244116
(keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
4639
diff
changeset
|
303 |
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
304 /* Mask that excludes keyboard input descriptor(s). */ |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
305 |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
306 static SELECT_TYPE non_keyboard_wait_mask; |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
307 |
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
308 /* Mask that excludes process input descriptor(s). */ |
17224
dd2545e79add
(wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents:
17110
diff
changeset
|
309 |
dd2545e79add
(wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents:
17110
diff
changeset
|
310 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
|
311 |
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
312 /* Mask for the gpm mouse input descriptor. */ |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
313 |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
314 static SELECT_TYPE gpm_wait_mask; |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
315 |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
316 #ifdef NON_BLOCKING_CONNECT |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
317 /* 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
|
318 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
|
319 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
|
320 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
321 static SELECT_TYPE connect_wait_mask; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
322 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
323 /* Number of bits set in connect_wait_mask. */ |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
324 static int num_pending_connects; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
325 |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
326 #define IF_NON_BLOCKING_CONNECT(s) s |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
327 #else |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
328 #define IF_NON_BLOCKING_CONNECT(s) |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
329 #endif |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
330 |
7044
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
331 /* 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
|
332 static int max_process_desc; |
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
333 |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
334 /* 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
|
335 static int max_keyboard_desc; |
4682
c4d471244116
(keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
4639
diff
changeset
|
336 |
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
337 /* The largest descriptor currently in use for gpm mouse input. */ |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
338 static int max_gpm_desc; |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
339 |
4682
c4d471244116
(keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
4639
diff
changeset
|
340 /* 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
|
341 static int delete_exited_processes; |
578 | 342 |
343 /* 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
|
344 Lisp_Object chan_process[MAXDESC]; |
578 | 345 |
346 /* Alist of elements (NAME . PROCESS) */ | |
6164
d047d5a48e0e
(chan_process, Vprocess_alist): No longer static.
Richard M. Stallman <rms@gnu.org>
parents:
6158
diff
changeset
|
347 Lisp_Object Vprocess_alist; |
578 | 348 |
349 /* Buffered-ahead input char from process, indexed by channel. | |
350 -1 means empty (no char is buffered). | |
351 Used on sys V where the only way to tell if there is any | |
352 output from the process is to read at least one char. | |
353 Always -1 on systems that support FIONREAD. */ | |
354 | |
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
355 /* 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
|
356 int proc_buffered_char[MAXDESC]; |
4682
c4d471244116
(keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
4639
diff
changeset
|
357 |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
358 /* 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
|
359 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
|
360 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
|
361 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
362 #ifdef DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
363 /* Table of `partner address' for datagram sockets. */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
364 struct sockaddr_and_len { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
365 struct sockaddr *sa; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
366 int len; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
367 } datagram_address[MAXDESC]; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
368 #define DATAGRAM_CHAN_P(chan) (datagram_address[chan].sa != 0) |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
369 #define DATAGRAM_CONN_P(proc) (PROCESSP (proc) && datagram_address[XPROCESS (proc)->infd].sa != 0) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
370 #else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
371 #define DATAGRAM_CHAN_P(chan) (0) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
372 #define DATAGRAM_CONN_P(proc) (0) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
373 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
374 |
6158 | 375 /* Maximum number of bytes to send to a pty without an eof. */ |
376 static int pty_max_bytes; | |
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
377 |
72727
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
378 /* Nonzero means don't run process sentinels. This is used |
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
379 when exiting. */ |
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
380 int inhibit_sentinels; |
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
381 |
11609
3b2dacb1bfe9
(create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents:
11514
diff
changeset
|
382 #ifdef HAVE_PTYS |
48088 | 383 #ifdef HAVE_PTY_H |
384 #include <pty.h> | |
385 #endif | |
11609
3b2dacb1bfe9
(create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents:
11514
diff
changeset
|
386 /* 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
|
387 |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
388 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
|
389 #endif |
578 | 390 |
391 /* Compute the Lisp form of the process status, p->status, from | |
392 the numeric status that was returned by `wait'. */ | |
393 | |
96620
3bea8ede5bd0
* syswait.h: Remove old if 0 code. Do not define WAITTYPE, it was
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96361
diff
changeset
|
394 static Lisp_Object status_convert (int); |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
395 |
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
396 static void |
578 | 397 update_status (p) |
398 struct Lisp_Process *p; | |
399 { | |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
400 eassert (p->raw_status_new); |
96620
3bea8ede5bd0
* syswait.h: Remove old if 0 code. Do not define WAITTYPE, it was
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96361
diff
changeset
|
401 p->status = status_convert (p->raw_status); |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
402 p->raw_status_new = 0; |
578 | 403 } |
404 | |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
405 /* Convert a process status word in Unix format to |
578 | 406 the list that we use internally. */ |
407 | |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
408 static Lisp_Object |
96620
3bea8ede5bd0
* syswait.h: Remove old if 0 code. Do not define WAITTYPE, it was
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96361
diff
changeset
|
409 status_convert (int w) |
578 | 410 { |
411 if (WIFSTOPPED (w)) | |
412 return Fcons (Qstop, Fcons (make_number (WSTOPSIG (w)), Qnil)); | |
413 else if (WIFEXITED (w)) | |
414 return Fcons (Qexit, Fcons (make_number (WRETCODE (w)), | |
415 WCOREDUMP (w) ? Qt : Qnil)); | |
416 else if (WIFSIGNALED (w)) | |
417 return Fcons (Qsignal, Fcons (make_number (WTERMSIG (w)), | |
418 WCOREDUMP (w) ? Qt : Qnil)); | |
419 else | |
420 return Qrun; | |
421 } | |
422 | |
423 /* Given a status-list, extract the three pieces of information | |
424 and store them individually through the three pointers. */ | |
425 | |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
426 static void |
578 | 427 decode_status (l, symbol, code, coredump) |
428 Lisp_Object l; | |
429 Lisp_Object *symbol; | |
430 int *code; | |
431 int *coredump; | |
432 { | |
433 Lisp_Object tem; | |
434 | |
9115
59bc2d010b5f
(decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents:
9034
diff
changeset
|
435 if (SYMBOLP (l)) |
578 | 436 { |
437 *symbol = l; | |
438 *code = 0; | |
439 *coredump = 0; | |
440 } | |
441 else | |
442 { | |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
443 *symbol = XCAR (l); |
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
444 tem = XCDR (l); |
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
445 *code = XFASTINT (XCAR (tem)); |
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
446 tem = XCDR (tem); |
578 | 447 *coredump = !NILP (tem); |
448 } | |
449 } | |
450 | |
451 /* Return a string describing a process status list. */ | |
452 | |
55962
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
453 static Lisp_Object |
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
454 status_message (p) |
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
455 struct Lisp_Process *p; |
578 | 456 { |
55962
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
457 Lisp_Object status = p->status; |
578 | 458 Lisp_Object symbol; |
459 int code, coredump; | |
460 Lisp_Object string, string2; | |
461 | |
462 decode_status (status, &symbol, &code, &coredump); | |
463 | |
464 if (EQ (symbol, Qsignal) || EQ (symbol, Qstop)) | |
465 { | |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
466 char *signame; |
103363
3fb472c8bc3c
* process.c (status_message): Fix handling of multibyte signal
Chong Yidong <cyd@stupidchicken.com>
parents:
103134
diff
changeset
|
467 int c; |
26526
b7438760079b
* callproc.c (strerror): Remove decl.
Paul Eggert <eggert@twinsun.com>
parents:
26313
diff
changeset
|
468 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
|
469 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
|
470 if (signame == 0) |
466bc8ef8e21
(sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents:
5561
diff
changeset
|
471 signame = "unknown"; |
466bc8ef8e21
(sigchld_handler, status_message): Handle a NULL in sys_siglist.
Richard M. Stallman <rms@gnu.org>
parents:
5561
diff
changeset
|
472 string = build_string (signame); |
578 | 473 string2 = build_string (coredump ? " (core dumped)\n" : "\n"); |
103363
3fb472c8bc3c
* process.c (status_message): Fix handling of multibyte signal
Chong Yidong <cyd@stupidchicken.com>
parents:
103134
diff
changeset
|
474 c = STRING_CHAR ((char *) SDATA (string), 0); |
3fb472c8bc3c
* process.c (status_message): Fix handling of multibyte signal
Chong Yidong <cyd@stupidchicken.com>
parents:
103134
diff
changeset
|
475 Faset (string, 0, make_number (DOWNCASE (c))); |
578 | 476 return concat2 (string, string2); |
477 } | |
478 else if (EQ (symbol, Qexit)) | |
479 { | |
55962
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
480 if (NETCONN1_P (p)) |
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
481 return build_string (code == 0 ? "deleted\n" : "connection broken by remote peer\n"); |
578 | 482 if (code == 0) |
483 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
|
484 string = Fnumber_to_string (make_number (code)); |
578 | 485 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
|
486 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
|
487 string, string2); |
578 | 488 } |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
489 else if (EQ (symbol, Qfailed)) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
490 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
491 string = Fnumber_to_string (make_number (code)); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
492 string2 = build_string ("\n"); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
493 return concat3 (build_string ("failed with code "), |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
494 string, string2); |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
495 } |
578 | 496 else |
497 return Fcopy_sequence (Fsymbol_name (symbol)); | |
498 } | |
499 | |
500 #ifdef HAVE_PTYS | |
501 | |
11609
3b2dacb1bfe9
(create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents:
11514
diff
changeset
|
502 /* 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
|
503 Return -1 on failure. |
3b2dacb1bfe9
(create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents:
11514
diff
changeset
|
504 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
|
505 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
|
506 |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
507 static int |
578 | 508 allocate_pty () |
509 { | |
21514 | 510 register int c, i; |
578 | 511 int fd; |
512 | |
513 #ifdef PTY_ITERATION | |
514 PTY_ITERATION | |
515 #else | |
516 for (c = FIRST_PTY_LETTER; c <= 'z'; c++) | |
517 for (i = 0; i < 16; i++) | |
518 #endif | |
519 { | |
51473
58061223557c
(allocate_pty): Revert part of the previous patch.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51233
diff
changeset
|
520 struct stat stb; /* Used in some PTY_OPEN. */ |
578 | 521 #ifdef PTY_NAME_SPRINTF |
522 PTY_NAME_SPRINTF | |
523 #else | |
524 sprintf (pty_name, "/dev/pty%c%x", c, i); | |
525 #endif /* no PTY_NAME_SPRINTF */ | |
526 | |
822
c6e94e13926c
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
527 #ifdef PTY_OPEN |
c6e94e13926c
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
528 PTY_OPEN; |
c6e94e13926c
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
529 #else /* no PTY_OPEN */ |
51233
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
530 { |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
531 { /* Some systems name their pseudoterminals so that there are gaps in |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
532 the usual sequence - for example, on HP9000/S700 systems, there |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
533 are no pseudoterminals with names ending in 'f'. So we wait for |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
534 three failures in a row before deciding that we've reached the |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
535 end of the ptys. */ |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
536 int failed_count = 0; |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
537 |
51233
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
538 if (stat (pty_name, &stb) < 0) |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
539 { |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
540 failed_count++; |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
541 if (failed_count >= 3) |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
542 return -1; |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
543 } |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
544 else |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
545 failed_count = 0; |
624 | 546 } |
51233
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
547 # ifdef O_NONBLOCK |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
548 fd = emacs_open (pty_name, O_RDWR | O_NONBLOCK, 0); |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
549 # else |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
550 fd = emacs_open (pty_name, O_RDWR | O_NDELAY, 0); |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
551 # endif |
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
552 } |
822
c6e94e13926c
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
553 #endif /* no PTY_OPEN */ |
578 | 554 |
555 if (fd >= 0) | |
556 { | |
557 /* check to make certain that both sides are available | |
558 this avoids a nasty yet stupid bug in rlogins */ | |
559 #ifdef PTY_TTY_NAME_SPRINTF | |
560 PTY_TTY_NAME_SPRINTF | |
561 #else | |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
562 sprintf (pty_name, "/dev/tty%c%x", c, i); |
578 | 563 #endif /* no PTY_TTY_NAME_SPRINTF */ |
564 if (access (pty_name, 6) != 0) | |
565 { | |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
566 emacs_close (fd); |
96732
1e0b67e40d48
* systty.h: Remove code for Aix on 386, unsupported platform.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96675
diff
changeset
|
567 # ifndef __sgi |
578 | 568 continue; |
51233
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
569 # else |
578 | 570 return -1; |
96732
1e0b67e40d48
* systty.h: Remove code for Aix on 386, unsupported platform.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96675
diff
changeset
|
571 # endif /* __sgi */ |
578 | 572 } |
573 setup_pty (fd); | |
574 return fd; | |
575 } | |
576 } | |
577 return -1; | |
578 } | |
579 #endif /* HAVE_PTYS */ | |
580 | |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
581 static Lisp_Object |
578 | 582 make_process (name) |
583 Lisp_Object name; | |
584 { | |
585 register Lisp_Object val, tem, name1; | |
586 register struct Lisp_Process *p; | |
587 char suffix[10]; | |
588 register int i; | |
589 | |
36434
40cfe4976f04
(make_process): Use allocate_process.
Gerd Moellmann <gerd@gnu.org>
parents:
35336
diff
changeset
|
590 p = allocate_process (); |
9969
007d93b04e1f
(make_process): Use allocate_vectorlike and VECSIZE.
Karl Heuer <kwzh@gnu.org>
parents:
9952
diff
changeset
|
591 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
592 p->infd = -1; |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
593 p->outfd = -1; |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
594 p->tick = 0; |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
595 p->update_tick = 0; |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
596 p->pid = 0; |
87470 | 597 p->pty_flag = 0; |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
598 p->raw_status_new = 0; |
578 | 599 p->status = Qrun; |
600 p->mark = Fmake_marker (); | |
97498
e4a1b306a650
(make_process): Initialize kill_without_query struct member.
Chong Yidong <cyd@stupidchicken.com>
parents:
97405
diff
changeset
|
601 p->kill_without_query = 0; |
578 | 602 |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
603 #ifdef ADAPTIVE_READ_BUFFERING |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
604 p->adaptive_read_buffering = 0; |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
605 p->read_output_delay = 0; |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
606 p->read_output_skip = 0; |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
607 #endif |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
608 |
578 | 609 /* If name is already in use, modify it until it is unused. */ |
610 | |
611 name1 = name; | |
612 for (i = 1; ; i++) | |
613 { | |
614 tem = Fget_process (name1); | |
615 if (NILP (tem)) break; | |
616 sprintf (suffix, "<%d>", i); | |
617 name1 = concat2 (name, build_string (suffix)); | |
618 } | |
619 name = name1; | |
620 p->name = name; | |
9969
007d93b04e1f
(make_process): Use allocate_vectorlike and VECSIZE.
Karl Heuer <kwzh@gnu.org>
parents:
9952
diff
changeset
|
621 XSETPROCESS (val, p); |
578 | 622 Vprocess_alist = Fcons (Fcons (name, val), Vprocess_alist); |
623 return val; | |
624 } | |
625 | |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
626 static void |
578 | 627 remove_process (proc) |
628 register Lisp_Object proc; | |
629 { | |
630 register Lisp_Object pair; | |
631 | |
632 pair = Frassq (proc, Vprocess_alist); | |
633 Vprocess_alist = Fdelq (pair, Vprocess_alist); | |
634 | |
635 deactivate_process (proc); | |
636 } | |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
637 |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
638 /* Setup coding systems of PROCESS. */ |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
639 |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
640 void |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
641 setup_process_coding_systems (process) |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
642 Lisp_Object process; |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
643 { |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
644 struct Lisp_Process *p = XPROCESS (process); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
645 int inch = p->infd; |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
646 int outch = p->outfd; |
89483 | 647 Lisp_Object coding_system; |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
648 |
49872
012ced9cf144
(setup_process_coding_systems): If the process's
Kenichi Handa <handa@m17n.org>
parents:
49680
diff
changeset
|
649 if (inch < 0 || outch < 0) |
012ced9cf144
(setup_process_coding_systems): If the process's
Kenichi Handa <handa@m17n.org>
parents:
49680
diff
changeset
|
650 return; |
012ced9cf144
(setup_process_coding_systems): If the process's
Kenichi Handa <handa@m17n.org>
parents:
49680
diff
changeset
|
651 |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
652 if (!proc_decode_coding_system[inch]) |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
653 proc_decode_coding_system[inch] |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
654 = (struct coding_system *) xmalloc (sizeof (struct coding_system)); |
89483 | 655 coding_system = p->decode_coding_system; |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
656 if (! NILP (p->filter)) |
93201
5dbe361f12c2
* process.h (struct Lisp_Process): Remove filter_multibyte.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92266
diff
changeset
|
657 ; |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
658 else if (BUFFERP (p->buffer)) |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
659 { |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
660 if (NILP (XBUFFER (p->buffer)->enable_multibyte_characters)) |
89483 | 661 coding_system = raw_text_coding_system (coding_system); |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
662 } |
89483 | 663 setup_coding_system (coding_system, proc_decode_coding_system[inch]); |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
664 |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
665 if (!proc_encode_coding_system[outch]) |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
666 proc_encode_coding_system[outch] |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
667 = (struct coding_system *) xmalloc (sizeof (struct coding_system)); |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
668 setup_coding_system (p->encode_coding_system, |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
669 proc_encode_coding_system[outch]); |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
670 } |
578 | 671 |
672 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
|
673 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
|
674 (object) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
675 Lisp_Object object; |
578 | 676 { |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
677 return PROCESSP (object) ? Qt : Qnil; |
578 | 678 } |
679 | |
680 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
|
681 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
|
682 (name) |
578 | 683 register Lisp_Object name; |
684 { | |
9115
59bc2d010b5f
(decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents:
9034
diff
changeset
|
685 if (PROCESSP (name)) |
578 | 686 return name; |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
687 CHECK_STRING (name); |
578 | 688 return Fcdr (Fassoc (name, Vprocess_alist)); |
689 } | |
690 | |
691 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
|
692 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
|
693 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
|
694 (buffer) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
695 register Lisp_Object buffer; |
578 | 696 { |
697 register Lisp_Object buf, tail, proc; | |
698 | |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
699 if (NILP (buffer)) return Qnil; |
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
700 buf = Fget_buffer (buffer); |
578 | 701 if (NILP (buf)) return Qnil; |
702 | |
85372
f7d19cfed7da
* xselect.c (x_own_selection, x_handle_selection_clear)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
85362
diff
changeset
|
703 for (tail = Vprocess_alist; CONSP (tail); tail = XCDR (tail)) |
578 | 704 { |
85372
f7d19cfed7da
* xselect.c (x_own_selection, x_handle_selection_clear)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
85362
diff
changeset
|
705 proc = Fcdr (XCAR (tail)); |
9115
59bc2d010b5f
(decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents:
9034
diff
changeset
|
706 if (PROCESSP (proc) && EQ (XPROCESS (proc)->buffer, buf)) |
578 | 707 return proc; |
708 } | |
709 return Qnil; | |
710 } | |
711 | |
808 | 712 /* This is how commands for the user decode process arguments. It |
713 accepts a process, a process name, a buffer, a buffer name, or nil. | |
714 Buffers denote the first process in the buffer, and nil denotes the | |
715 current buffer. */ | |
578 | 716 |
4994
4146a65b9f02
(get_process): Add `static' to definition.
Richard M. Stallman <rms@gnu.org>
parents:
4914
diff
changeset
|
717 static Lisp_Object |
578 | 718 get_process (name) |
719 register Lisp_Object name; | |
720 { | |
6313
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
721 register Lisp_Object proc, obj; |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
722 if (STRINGP (name)) |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
723 { |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
724 obj = Fget_process (name); |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
725 if (NILP (obj)) |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
726 obj = Fget_buffer (name); |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
727 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
|
728 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
|
729 } |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
730 else if (NILP (name)) |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
731 obj = Fcurrent_buffer (); |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
732 else |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
733 obj = name; |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
734 |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
735 /* 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
|
736 */ |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
737 if (BUFFERP (obj)) |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
738 { |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
739 proc = Fget_buffer_process (obj); |
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
740 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
|
741 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
|
742 } |
578 | 743 else |
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 (obj); |
6313
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
746 proc = obj; |
578 | 747 } |
6313
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
748 return proc; |
578 | 749 } |
750 | |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
751 |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
752 #ifdef SIGCHLD |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
753 /* Fdelete_process promises to immediately forget about the process, but in |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
754 reality, Emacs needs to remember those processes until they have been |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
755 treated by sigchld_handler; otherwise this handler would consider the |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
756 process as being synchronous and say that the synchronous process is |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
757 dead. */ |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
758 static Lisp_Object deleted_pid_list; |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
759 #endif |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
760 |
578 | 761 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
|
762 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
|
763 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
|
764 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
|
765 (process) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
766 register Lisp_Object process; |
578 | 767 { |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
768 register struct Lisp_Process *p; |
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
769 |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
770 process = get_process (process); |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
771 p = XPROCESS (process); |
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
772 |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
773 p->raw_status_new = 0; |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
774 if (NETCONN1_P (p) || SERIALCONN1_P (p)) |
578 | 775 { |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
776 p->status = Fcons (Qexit, Fcons (make_number (0), Qnil)); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
777 p->tick = ++process_tick; |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
778 status_notify (p); |
578 | 779 } |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
780 else if (p->infd >= 0) |
578 | 781 { |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
782 #ifdef SIGCHLD |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
783 Lisp_Object symbol; |
75220
1b003fe28dfe
(Fdelete_process, Fprocess_id, sigchld_handler): Copy PID into EMACS_INT
Eli Zaretskii <eliz@gnu.org>
parents:
74946
diff
changeset
|
784 /* Assignment to EMACS_INT stops GCC whining about limited range |
1b003fe28dfe
(Fdelete_process, Fprocess_id, sigchld_handler): Copy PID into EMACS_INT
Eli Zaretskii <eliz@gnu.org>
parents:
74946
diff
changeset
|
785 of data type. */ |
76494
f0a25b5d3ba0
(Fdelete_process): Properly handle deletion of first element of
Chong Yidong <cyd@stupidchicken.com>
parents:
76493
diff
changeset
|
786 EMACS_INT pid = p->pid; |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
787 |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
788 /* No problem storing the pid here, as it is still in Vprocess_alist. */ |
75220
1b003fe28dfe
(Fdelete_process, Fprocess_id, sigchld_handler): Copy PID into EMACS_INT
Eli Zaretskii <eliz@gnu.org>
parents:
74946
diff
changeset
|
789 deleted_pid_list = Fcons (make_fixnum_or_float (pid), |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
790 /* GC treated elements set to nil. */ |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
791 Fdelq (Qnil, deleted_pid_list)); |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
792 /* If the process has already signaled, remove it from the list. */ |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
793 if (p->raw_status_new) |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
794 update_status (p); |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
795 symbol = p->status; |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
796 if (CONSP (p->status)) |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
797 symbol = XCAR (p->status); |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
798 if (EQ (symbol, Qsignal) || EQ (symbol, Qexit)) |
76494
f0a25b5d3ba0
(Fdelete_process): Properly handle deletion of first element of
Chong Yidong <cyd@stupidchicken.com>
parents:
76493
diff
changeset
|
799 deleted_pid_list |
f0a25b5d3ba0
(Fdelete_process): Properly handle deletion of first element of
Chong Yidong <cyd@stupidchicken.com>
parents:
76493
diff
changeset
|
800 = Fdelete (make_fixnum_or_float (pid), deleted_pid_list); |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
801 else |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
802 #endif |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
803 { |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
804 Fkill_process (process, Qnil); |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
805 /* Do this now, since remove_process will make sigchld_handler do nothing. */ |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
806 p->status |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
807 = Fcons (Qsignal, Fcons (make_number (SIGKILL), Qnil)); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
808 p->tick = ++process_tick; |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
809 status_notify (p); |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
810 } |
578 | 811 } |
55962
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
812 remove_process (process); |
578 | 813 return Qnil; |
814 } | |
815 | |
816 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
|
817 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
|
818 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
|
819 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
|
820 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
|
821 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
|
822 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
|
823 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
|
824 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
|
825 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
|
826 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
|
827 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
|
828 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
|
829 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
|
830 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
|
831 (process) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
832 register Lisp_Object process; |
578 | 833 { |
834 register struct Lisp_Process *p; | |
835 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
|
836 |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
837 if (STRINGP (process)) |
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
838 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
|
839 else |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
840 process = get_process (process); |
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
841 |
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
842 if (NILP (process)) |
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
843 return process; |
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
844 |
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
845 p = XPROCESS (process); |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
846 if (p->raw_status_new) |
578 | 847 update_status (p); |
848 status = p->status; | |
9115
59bc2d010b5f
(decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents:
9034
diff
changeset
|
849 if (CONSP (status)) |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
850 status = XCAR (status); |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
851 if (NETCONN1_P (p) || SERIALCONN1_P (p)) |
578 | 852 { |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
853 if (EQ (status, Qexit)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
854 status = Qclosed; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
855 else if (EQ (p->command, Qt)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
856 status = Qstop; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
857 else if (EQ (status, Qrun)) |
578 | 858 status = Qopen; |
859 } | |
860 return status; | |
861 } | |
862 | |
863 DEFUN ("process-exit-status", Fprocess_exit_status, Sprocess_exit_status, | |
864 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
|
865 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
|
866 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
|
867 (process) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
868 register Lisp_Object process; |
578 | 869 { |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
870 CHECK_PROCESS (process); |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
871 if (XPROCESS (process)->raw_status_new) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
872 update_status (XPROCESS (process)); |
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
873 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
|
874 return XCAR (XCDR (XPROCESS (process)->status)); |
578 | 875 return make_number (0); |
876 } | |
877 | |
878 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
|
879 doc: /* Return the process id of PROCESS. |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
880 This is the pid of the external process which PROCESS uses or talks to. |
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
881 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
|
882 (process) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
883 register Lisp_Object process; |
578 | 884 { |
75220
1b003fe28dfe
(Fdelete_process, Fprocess_id, sigchld_handler): Copy PID into EMACS_INT
Eli Zaretskii <eliz@gnu.org>
parents:
74946
diff
changeset
|
885 /* Assignment to EMACS_INT stops GCC whining about limited range of |
1b003fe28dfe
(Fdelete_process, Fprocess_id, sigchld_handler): Copy PID into EMACS_INT
Eli Zaretskii <eliz@gnu.org>
parents:
74946
diff
changeset
|
886 data type. */ |
1b003fe28dfe
(Fdelete_process, Fprocess_id, sigchld_handler): Copy PID into EMACS_INT
Eli Zaretskii <eliz@gnu.org>
parents:
74946
diff
changeset
|
887 EMACS_INT pid; |
1b003fe28dfe
(Fdelete_process, Fprocess_id, sigchld_handler): Copy PID into EMACS_INT
Eli Zaretskii <eliz@gnu.org>
parents:
74946
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); |
75220
1b003fe28dfe
(Fdelete_process, Fprocess_id, sigchld_handler): Copy PID into EMACS_INT
Eli Zaretskii <eliz@gnu.org>
parents:
74946
diff
changeset
|
890 pid = XPROCESS (process)->pid; |
1b003fe28dfe
(Fdelete_process, Fprocess_id, sigchld_handler): Copy PID into EMACS_INT
Eli Zaretskii <eliz@gnu.org>
parents:
74946
diff
changeset
|
891 return (pid ? make_fixnum_or_float (pid) : Qnil); |
578 | 892 } |
893 | |
894 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
|
895 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
|
896 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
|
897 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
|
898 (process) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
899 register Lisp_Object process; |
578 | 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 return XPROCESS (process)->name; |
578 | 903 } |
904 | |
905 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
|
906 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
|
907 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
|
908 and the rest of the strings being the arguments given to it. |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
909 For a network or serial process, this is nil (process is running) or t |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
910 \(process is stopped). */) |
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
911 (process) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
912 register Lisp_Object process; |
578 | 913 { |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
914 CHECK_PROCESS (process); |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
915 return XPROCESS (process)->command; |
578 | 916 } |
917 | |
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
918 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
|
919 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
|
920 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
|
921 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
|
922 (process) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
923 register Lisp_Object process; |
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
924 { |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
925 CHECK_PROCESS (process); |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
926 return XPROCESS (process)->tty_name; |
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
927 } |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
928 |
578 | 929 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
|
930 2, 2, 0, |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
931 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
|
932 (process, buffer) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
933 register Lisp_Object process, buffer; |
578 | 934 { |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
935 struct Lisp_Process *p; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
936 |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
937 CHECK_PROCESS (process); |
578 | 938 if (!NILP (buffer)) |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
939 CHECK_BUFFER (buffer); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
940 p = XPROCESS (process); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
941 p->buffer = buffer; |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
942 if (NETCONN1_P (p) || SERIALCONN1_P (p)) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
943 p->childp = Fplist_put (p->childp, QCbuffer, buffer); |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
944 setup_process_coding_systems (process); |
578 | 945 return buffer; |
946 } | |
947 | |
948 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
|
949 1, 1, 0, |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
950 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
|
951 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
|
952 (process) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
953 register Lisp_Object process; |
578 | 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); |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
956 return XPROCESS (process)->buffer; |
578 | 957 } |
958 | |
959 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
|
960 1, 1, 0, |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
961 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
|
962 (process) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
963 register Lisp_Object process; |
578 | 964 { |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
965 CHECK_PROCESS (process); |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
966 return XPROCESS (process)->mark; |
578 | 967 } |
968 | |
969 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
|
970 2, 2, 0, |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
971 doc: /* Give PROCESS the filter function FILTER; nil means no filter. |
79147
f7416cac39e0
(Fset_process_filter): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents:
78840
diff
changeset
|
972 A value of t means stop accepting output from the process. |
49281
f9e4999d3025
(set-process-filter): Document unibyte/multibyte-ness of string argument.
Kim F. Storm <storm@cua.dk>
parents:
49229
diff
changeset
|
973 |
f9e4999d3025
(set-process-filter): Document unibyte/multibyte-ness of string argument.
Kim F. Storm <storm@cua.dk>
parents:
49229
diff
changeset
|
974 When a process has a filter, its buffer is not used for output. |
f9e4999d3025
(set-process-filter): Document unibyte/multibyte-ness of string argument.
Kim F. Storm <storm@cua.dk>
parents:
49229
diff
changeset
|
975 Instead, each time it does output, the entire string of output is |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
976 passed to the filter. |
49281
f9e4999d3025
(set-process-filter): Document unibyte/multibyte-ness of string argument.
Kim F. Storm <storm@cua.dk>
parents:
49229
diff
changeset
|
977 |
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
978 The filter gets two arguments: the process and the string of output. |
49281
f9e4999d3025
(set-process-filter): Document unibyte/multibyte-ness of string argument.
Kim F. Storm <storm@cua.dk>
parents:
49229
diff
changeset
|
979 The string argument is normally a multibyte string, except: |
f9e4999d3025
(set-process-filter): Document unibyte/multibyte-ness of string argument.
Kim F. Storm <storm@cua.dk>
parents:
49229
diff
changeset
|
980 - if the process' input coding system is no-conversion or raw-text, |
f9e4999d3025
(set-process-filter): Document unibyte/multibyte-ness of string argument.
Kim F. Storm <storm@cua.dk>
parents:
49229
diff
changeset
|
981 it is a unibyte string (the non-converted input), or else |
f9e4999d3025
(set-process-filter): Document unibyte/multibyte-ness of string argument.
Kim F. Storm <storm@cua.dk>
parents:
49229
diff
changeset
|
982 - if `default-enable-multibyte-characters' is nil, it is a unibyte |
f9e4999d3025
(set-process-filter): Document unibyte/multibyte-ness of string argument.
Kim F. Storm <storm@cua.dk>
parents:
49229
diff
changeset
|
983 string (the result of converting the decoded input multibyte |
f9e4999d3025
(set-process-filter): Document unibyte/multibyte-ness of string argument.
Kim F. Storm <storm@cua.dk>
parents:
49229
diff
changeset
|
984 string to unibyte with `string-make-unibyte'). */) |
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
985 (process, filter) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
986 register Lisp_Object process, filter; |
578 | 987 { |
36623
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
988 struct Lisp_Process *p; |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
989 |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
990 CHECK_PROCESS (process); |
36623
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
991 p = XPROCESS (process); |
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
992 |
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
993 /* 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
|
994 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
|
995 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
|
996 |
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
997 (setq process (start-process ...)) |
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
998 (debug) |
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
999 (set-process-filter process ...) */ |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
1000 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1001 if (p->infd >= 0) |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
1002 { |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1003 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
|
1004 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1005 FD_CLR (p->infd, &input_wait_mask); |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1006 FD_CLR (p->infd, &non_keyboard_wait_mask); |
36623
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
1007 } |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1008 else if (EQ (p->filter, Qt) |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1009 /* Network or serial process not stopped: */ |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1010 && !EQ (p->command, Qt)) |
36623
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
1011 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1012 FD_SET (p->infd, &input_wait_mask); |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1013 FD_SET (p->infd, &non_keyboard_wait_mask); |
36623
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
1014 } |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
1015 } |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
1016 |
36623
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
1017 p->filter = filter; |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1018 if (NETCONN1_P (p) || SERIALCONN1_P (p)) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1019 p->childp = Fplist_put (p->childp, QCfilter, filter); |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
1020 setup_process_coding_systems (process); |
578 | 1021 return filter; |
1022 } | |
1023 | |
1024 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
|
1025 1, 1, 0, |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1026 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
|
1027 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
|
1028 (process) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1029 register Lisp_Object process; |
578 | 1030 { |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1031 CHECK_PROCESS (process); |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1032 return XPROCESS (process)->filter; |
578 | 1033 } |
1034 | |
1035 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
|
1036 2, 2, 0, |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1037 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
|
1038 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
|
1039 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
|
1040 (process, sentinel) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1041 register Lisp_Object process, sentinel; |
578 | 1042 { |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
1043 struct Lisp_Process *p; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
1044 |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1045 CHECK_PROCESS (process); |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
1046 p = XPROCESS (process); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
1047 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
1048 p->sentinel = sentinel; |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1049 if (NETCONN1_P (p) || SERIALCONN1_P (p)) |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
1050 p->childp = Fplist_put (p->childp, QCsentinel, sentinel); |
578 | 1051 return sentinel; |
1052 } | |
1053 | |
1054 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
|
1055 1, 1, 0, |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1056 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
|
1057 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
|
1058 (process) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1059 register Lisp_Object process; |
578 | 1060 { |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1061 CHECK_PROCESS (process); |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1062 return XPROCESS (process)->sentinel; |
578 | 1063 } |
1064 | |
6830
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
1065 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
|
1066 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
|
1067 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
|
1068 (process, height, width) |
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1069 register Lisp_Object process, height, width; |
6830
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
1070 { |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1071 CHECK_PROCESS (process); |
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1072 CHECK_NATNUM (height); |
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1073 CHECK_NATNUM (width); |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
1074 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1075 if (XPROCESS (process)->infd < 0 |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1076 || set_window_size (XPROCESS (process)->infd, |
36623
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
1077 XINT (height), XINT (width)) <= 0) |
6830
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
1078 return Qnil; |
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
1079 else |
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
1080 return Qt; |
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
1081 } |
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
1082 |
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1083 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
|
1084 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
|
1085 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
|
1086 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
|
1087 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
|
1088 `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
|
1089 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
|
1090 the process output. |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1091 |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1092 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
|
1093 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
|
1094 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
|
1095 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
|
1096 |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1097 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
|
1098 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
|
1099 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
|
1100 (process, flag) |
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1101 register Lisp_Object process, flag; |
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1102 { |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1103 CHECK_PROCESS (process); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1104 XPROCESS (process)->inherit_coding_system_flag = !NILP (flag); |
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1105 return flag; |
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1106 } |
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1107 |
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1108 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
|
1109 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
|
1110 1, 1, 0, |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1111 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
|
1112 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
|
1113 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
|
1114 the process output. */) |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1115 (process) |
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1116 register Lisp_Object process; |
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1117 { |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1118 CHECK_PROCESS (process); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1119 return XPROCESS (process)->inherit_coding_system_flag ? Qt : Qnil; |
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1120 } |
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1121 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1122 DEFUN ("set-process-query-on-exit-flag", |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1123 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
|
1124 2, 2, 0, |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1125 doc: /* Specify if query is needed for PROCESS when Emacs is exited. |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
1126 If the second argument FLAG is non-nil, Emacs will query the user before |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1127 exiting if PROCESS is running. */) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1128 (process, flag) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1129 register Lisp_Object process, flag; |
578 | 1130 { |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1131 CHECK_PROCESS (process); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1132 XPROCESS (process)->kill_without_query = NILP (flag); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1133 return flag; |
578 | 1134 } |
4231
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1135 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1136 DEFUN ("process-query-on-exit-flag", |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1137 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
|
1138 1, 1, 0, |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
1139 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
|
1140 (process) |
16058
924aeb9ed7c3
(Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16053
diff
changeset
|
1141 register Lisp_Object process; |
924aeb9ed7c3
(Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16053
diff
changeset
|
1142 { |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1143 CHECK_PROCESS (process); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1144 return (XPROCESS (process)->kill_without_query ? Qnil : Qt); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1145 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1146 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1147 #ifdef DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1148 Lisp_Object Fprocess_datagram_address (); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1149 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1150 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1151 DEFUN ("process-contact", Fprocess_contact, Sprocess_contact, |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1152 1, 2, 0, |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1153 doc: /* Return the contact info of PROCESS; t for a real child. |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1154 For a network or serial connection, the value depends on the optional |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1155 KEY arg. If KEY is nil, value is a cons cell of the form (HOST |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1156 SERVICE) for a network connection or (PORT SPEED) for a serial |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1157 connection. If KEY is t, the complete contact information for the |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1158 connection is returned, else the specific value for the keyword KEY is |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1159 returned. See `make-network-process' or `make-serial-process' for a |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1160 list of keywords. */) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1161 (process, key) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1162 register Lisp_Object process, key; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1163 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1164 Lisp_Object contact; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1165 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1166 CHECK_PROCESS (process); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1167 contact = XPROCESS (process)->childp; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1168 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1169 #ifdef DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1170 if (DATAGRAM_CONN_P (process) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1171 && (EQ (key, Qt) || EQ (key, QCremote))) |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
1172 contact = Fplist_put (contact, QCremote, |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1173 Fprocess_datagram_address (process)); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1174 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1175 |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1176 if ((!NETCONN_P (process) && !SERIALCONN_P (process)) || EQ (key, Qt)) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1177 return contact; |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1178 if (NILP (key) && NETCONN_P (process)) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1179 return Fcons (Fplist_get (contact, QChost), |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1180 Fcons (Fplist_get (contact, QCservice), Qnil)); |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1181 if (NILP (key) && SERIALCONN_P (process)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1182 return Fcons (Fplist_get (contact, QCport), |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1183 Fcons (Fplist_get (contact, QCspeed), Qnil)); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1184 return Fplist_get (contact, key); |
16058
924aeb9ed7c3
(Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16053
diff
changeset
|
1185 } |
924aeb9ed7c3
(Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16053
diff
changeset
|
1186 |
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1187 DEFUN ("process-plist", Fprocess_plist, Sprocess_plist, |
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1188 1, 1, 0, |
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1189 doc: /* Return the plist of PROCESS. */) |
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1190 (process) |
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1191 register Lisp_Object process; |
49164 | 1192 { |
1193 CHECK_PROCESS (process); | |
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1194 return XPROCESS (process)->plist; |
49164 | 1195 } |
1196 | |
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1197 DEFUN ("set-process-plist", Fset_process_plist, Sset_process_plist, |
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1198 2, 2, 0, |
49229
a3af03912e6f
(Fset_process_plist): Fixed return value.
Kim F. Storm <storm@cua.dk>
parents:
49223
diff
changeset
|
1199 doc: /* Replace the plist of PROCESS with PLIST. Returns PLIST. */) |
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1200 (process, plist) |
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1201 register Lisp_Object process, plist; |
49142
8dca38bc0261
(Fset_process_contact): New function.
Kim F. Storm <storm@cua.dk>
parents:
49119
diff
changeset
|
1202 { |
8dca38bc0261
(Fset_process_contact): New function.
Kim F. Storm <storm@cua.dk>
parents:
49119
diff
changeset
|
1203 CHECK_PROCESS (process); |
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1204 CHECK_LIST (plist); |
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1205 |
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1206 XPROCESS (process)->plist = plist; |
49229
a3af03912e6f
(Fset_process_plist): Fixed return value.
Kim F. Storm <storm@cua.dk>
parents:
49223
diff
changeset
|
1207 return plist; |
49142
8dca38bc0261
(Fset_process_contact): New function.
Kim F. Storm <storm@cua.dk>
parents:
49119
diff
changeset
|
1208 } |
8dca38bc0261
(Fset_process_contact): New function.
Kim F. Storm <storm@cua.dk>
parents:
49119
diff
changeset
|
1209 |
4231
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1210 #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
|
1211 in the process. Perhaps add it. */ |
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1212 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
|
1213 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
|
1214 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
|
1215 a socket connection. */) |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1216 (process) |
4231
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1217 Lisp_Object process; |
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1218 { |
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1219 return XPROCESS (process)->type; |
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1220 } |
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1221 #endif |
98456
a68b7a895cb6
(Faccept_process_output): Fix doc-string.
Martin Rudalics <rudalics@gmx.at>
parents:
98248
diff
changeset
|
1222 |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1223 DEFUN ("process-type", Fprocess_type, Sprocess_type, 1, 1, 0, |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1224 doc: /* Return the connection type of PROCESS. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1225 The value is either the symbol `real', `network', or `serial'. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1226 PROCESS may be a process, a buffer, the name of a process or buffer, or |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1227 nil, indicating the current buffer's process. */) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1228 (process) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1229 Lisp_Object process; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1230 { |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1231 Lisp_Object proc; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1232 proc = get_process (process); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1233 return XPROCESS (proc)->type; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1234 } |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1235 |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1236 #ifdef HAVE_SOCKETS |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1237 DEFUN ("format-network-address", Fformat_network_address, Sformat_network_address, |
49114
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1238 1, 2, 0, |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1239 doc: /* Convert network ADDRESS from internal format to a string. |
68008 | 1240 A 4 or 5 element vector represents an IPv4 address (with port number). |
1241 An 8 or 9 element vector represents an IPv6 address (with port number). | |
49114
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1242 If optional second argument OMIT-PORT is non-nil, don't include a port |
68008 | 1243 number in the string, even when present in ADDRESS. |
1244 Returns nil if format of ADDRESS is invalid. */) | |
49114
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1245 (address, omit_port) |
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1246 Lisp_Object address, omit_port; |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1247 { |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1248 if (NILP (address)) |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1249 return Qnil; |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1250 |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1251 if (STRINGP (address)) /* AF_LOCAL */ |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1252 return address; |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1253 |
68008 | 1254 if (VECTORP (address)) /* AF_INET or AF_INET6 */ |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1255 { |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1256 register struct Lisp_Vector *p = XVECTOR (address); |
76760
c21bd0559ef9
(Fformat_network_address): Make room in args array to format IPv6 addresses.
Juanma Barranquero <lekktu@gmail.com>
parents:
76738
diff
changeset
|
1257 Lisp_Object args[10]; |
49114
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1258 int nargs, i; |
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1259 |
68008 | 1260 if (p->size == 4 || (p->size == 5 && !NILP (omit_port))) |
49114
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1261 { |
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1262 args[0] = build_string ("%d.%d.%d.%d"); |
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1263 nargs = 4; |
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1264 } |
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1265 else if (p->size == 5) |
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1266 { |
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1267 args[0] = build_string ("%d.%d.%d.%d:%d"); |
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1268 nargs = 5; |
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1269 } |
68008 | 1270 else if (p->size == 8 || (p->size == 9 && !NILP (omit_port))) |
1271 { | |
1272 args[0] = build_string ("%x:%x:%x:%x:%x:%x:%x:%x"); | |
1273 nargs = 8; | |
1274 } | |
1275 else if (p->size == 9) | |
1276 { | |
1277 args[0] = build_string ("[%x:%x:%x:%x:%x:%x:%x:%x]:%d"); | |
1278 nargs = 9; | |
1279 } | |
49114
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1280 else |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1281 return Qnil; |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1282 |
49114
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1283 for (i = 0; i < nargs; i++) |
76789
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1284 { |
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1285 EMACS_INT element = XINT (p->contents[i]); |
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1286 |
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1287 if (element < 0 || element > 65535) |
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1288 return Qnil; |
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1289 |
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1290 if (nargs <= 5 /* IPv4 */ |
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1291 && i < 4 /* host, not port */ |
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1292 && element > 255) |
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1293 return Qnil; |
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1294 |
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1295 args[i+1] = p->contents[i]; |
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1296 } |
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1297 |
49114
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1298 return Fformat (nargs+1, args); |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1299 } |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1300 |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1301 if (CONSP (address)) |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1302 { |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1303 Lisp_Object args[2]; |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1304 args[0] = build_string ("<Family %d>"); |
48097
21d7f2c18976
(Fformat_network_address): Fix int/Lisp_Object mixup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
48088
diff
changeset
|
1305 args[1] = Fcar (address); |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1306 return Fformat (2, args); |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1307 } |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1308 |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1309 return Qnil; |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1310 } |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1311 #endif |
578 | 1312 |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
1313 static Lisp_Object |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1314 list_processes_1 (query_only) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1315 Lisp_Object query_only; |
578 | 1316 { |
1317 register Lisp_Object tail, tem; | |
1318 Lisp_Object proc, minspace, tem1; | |
1319 register struct Lisp_Process *p; | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1320 char tembuf[300]; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1321 int w_proc, w_buffer, w_tty; |
73225
ff880e40efba
(list_processes_1): Run sentinels before removing dead
Kim F. Storm <storm@cua.dk>
parents:
72727
diff
changeset
|
1322 int exited = 0; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1323 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
|
1324 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1325 w_proc = 4; /* Proc */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1326 w_buffer = 6; /* Buffer */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1327 w_tty = 0; /* Omit if no ttys */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1328 |
85372
f7d19cfed7da
* xselect.c (x_own_selection, x_handle_selection_clear)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
85362
diff
changeset
|
1329 for (tail = Vprocess_alist; CONSP (tail); tail = XCDR (tail)) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1330 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1331 int i; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1332 |
85372
f7d19cfed7da
* xselect.c (x_own_selection, x_handle_selection_clear)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
85362
diff
changeset
|
1333 proc = Fcdr (XCAR (tail)); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1334 p = XPROCESS (proc); |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1335 if (NILP (p->type)) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1336 continue; |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1337 if (!NILP (query_only) && p->kill_without_query) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1338 continue; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1339 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
|
1340 && ( 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
|
1341 w_proc = i; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1342 if (!NILP (p->buffer)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1343 { |
87849
8f7e97005eef
(list_processes_1): Don't use SCHARS on a nil buffer name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
87730
diff
changeset
|
1344 if (NILP (XBUFFER (p->buffer)->name)) |
8f7e97005eef
(list_processes_1): Don't use SCHARS on a nil buffer name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
87730
diff
changeset
|
1345 { |
8f7e97005eef
(list_processes_1): Don't use SCHARS on a nil buffer name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
87730
diff
changeset
|
1346 if (w_buffer < 8) |
8f7e97005eef
(list_processes_1): Don't use SCHARS on a nil buffer name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
87730
diff
changeset
|
1347 w_buffer = 8; /* (Killed) */ |
8f7e97005eef
(list_processes_1): Don't use SCHARS on a nil buffer name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
87730
diff
changeset
|
1348 } |
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46314
diff
changeset
|
1349 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
|
1350 w_buffer = i; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1351 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1352 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
|
1353 && (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
|
1354 w_tty = i; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1355 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1356 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1357 XSETFASTINT (i_status, w_proc + 1); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1358 XSETFASTINT (i_buffer, XFASTINT (i_status) + 9); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1359 if (w_tty) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1360 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1361 XSETFASTINT (i_tty, XFASTINT (i_buffer) + w_buffer + 1); |
79486
c2586e2e84d3
(list_processes_1): Fix indentation level of the
Andreas Schwab <schwab@suse.de>
parents:
79147
diff
changeset
|
1362 XSETFASTINT (i_command, XFASTINT (i_tty) + w_tty + 1); |
c2586e2e84d3
(list_processes_1): Fix indentation level of the
Andreas Schwab <schwab@suse.de>
parents:
79147
diff
changeset
|
1363 } |
c2586e2e84d3
(list_processes_1): Fix indentation level of the
Andreas Schwab <schwab@suse.de>
parents:
79147
diff
changeset
|
1364 else |
c2586e2e84d3
(list_processes_1): Fix indentation level of the
Andreas Schwab <schwab@suse.de>
parents:
79147
diff
changeset
|
1365 { |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1366 i_tty = Qnil; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1367 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
|
1368 } |
578 | 1369 |
9318
a14cc1712337
(make_process, list_processes_1, create_process, Faccept_process_output,
Karl Heuer <kwzh@gnu.org>
parents:
9277
diff
changeset
|
1370 XSETFASTINT (minspace, 1); |
578 | 1371 |
1372 set_buffer_internal (XBUFFER (Vstandard_output)); | |
59113
8cf8b4fa2543
(list_processes_1): Set undo_list instead of calling Fbuffer_undo_list.
Richard M. Stallman <rms@gnu.org>
parents:
58986
diff
changeset
|
1373 current_buffer->undo_list = Qt; |
578 | 1374 |
1375 current_buffer->truncate_lines = Qt; | |
1376 | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1377 write_string ("Proc", -1); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1378 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
|
1379 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
|
1380 if (!NILP (i_tty)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1381 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1382 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
|
1383 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1384 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
|
1385 write_string ("\n", -1); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1386 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1387 write_string ("----", -1); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1388 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
|
1389 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
|
1390 if (!NILP (i_tty)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1391 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1392 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
|
1393 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1394 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
|
1395 write_string ("\n", -1); |
578 | 1396 |
85372
f7d19cfed7da
* xselect.c (x_own_selection, x_handle_selection_clear)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
85362
diff
changeset
|
1397 for (tail = Vprocess_alist; CONSP (tail); tail = XCDR (tail)) |
578 | 1398 { |
1399 Lisp_Object symbol; | |
1400 | |
85372
f7d19cfed7da
* xselect.c (x_own_selection, x_handle_selection_clear)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
85362
diff
changeset
|
1401 proc = Fcdr (XCAR (tail)); |
578 | 1402 p = XPROCESS (proc); |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1403 if (NILP (p->type)) |
578 | 1404 continue; |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1405 if (!NILP (query_only) && p->kill_without_query) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1406 continue; |
578 | 1407 |
1408 Finsert (1, &p->name); | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1409 Findent_to (i_status, minspace); |
578 | 1410 |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
1411 if (p->raw_status_new) |
578 | 1412 update_status (p); |
1413 symbol = p->status; | |
9115
59bc2d010b5f
(decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents:
9034
diff
changeset
|
1414 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
|
1415 symbol = XCAR (p->status); |
578 | 1416 |
1417 if (EQ (symbol, Qsignal)) | |
1418 { | |
1419 Lisp_Object tem; | |
1420 tem = Fcar (Fcdr (p->status)); | |
97142 | 1421 Fprinc (symbol, Qnil); |
578 | 1422 } |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1423 else if (NETCONN1_P (p) || SERIALCONN1_P (p)) |
578 | 1424 { |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1425 if (EQ (symbol, Qexit)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1426 write_string ("closed", -1); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1427 else if (EQ (p->command, Qt)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1428 write_string ("stopped", -1); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1429 else if (EQ (symbol, Qrun)) |
578 | 1430 write_string ("open", -1); |
1431 else | |
1432 Fprinc (symbol, Qnil); | |
1433 } | |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1434 else if (SERIALCONN1_P (p)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1435 { |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1436 write_string ("running", -1); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1437 } |
578 | 1438 else |
1439 Fprinc (symbol, Qnil); | |
1440 | |
1441 if (EQ (symbol, Qexit)) | |
1442 { | |
1443 Lisp_Object tem; | |
1444 tem = Fcar (Fcdr (p->status)); | |
1445 if (XFASTINT (tem)) | |
1446 { | |
11695
0f9b9c375416
(list_processes_1): Cast XFASTINT for passing to sprintf.
Richard M. Stallman <rms@gnu.org>
parents:
11609
diff
changeset
|
1447 sprintf (tembuf, " %d", (int) XFASTINT (tem)); |
578 | 1448 write_string (tembuf, -1); |
1449 } | |
1450 } | |
1451 | |
73225
ff880e40efba
(list_processes_1): Run sentinels before removing dead
Kim F. Storm <storm@cua.dk>
parents:
72727
diff
changeset
|
1452 if (EQ (symbol, Qsignal) || EQ (symbol, Qexit) || EQ (symbol, Qclosed)) |
ff880e40efba
(list_processes_1): Run sentinels before removing dead
Kim F. Storm <storm@cua.dk>
parents:
72727
diff
changeset
|
1453 exited++; |
578 | 1454 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1455 Findent_to (i_buffer, minspace); |
578 | 1456 if (NILP (p->buffer)) |
1457 insert_string ("(none)"); | |
1458 else if (NILP (XBUFFER (p->buffer)->name)) | |
1459 insert_string ("(Killed)"); | |
1460 else | |
1461 Finsert (1, &XBUFFER (p->buffer)->name); | |
1462 | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1463 if (!NILP (i_tty)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1464 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1465 Findent_to (i_tty, minspace); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1466 if (STRINGP (p->tty_name)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1467 Finsert (1, &p->tty_name); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1468 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1469 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1470 Findent_to (i_command, minspace); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1471 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1472 if (EQ (p->status, Qlisten)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1473 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1474 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
|
1475 if (INTEGERP (port)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1476 port = Fnumber_to_string (port); |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1477 if (NILP (port)) |
49114
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1478 port = Fformat_network_address (Fplist_get (p->childp, QClocal), Qnil); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1479 sprintf (tembuf, "(network %s server on %s)\n", |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1480 (DATAGRAM_CHAN_P (p->infd) ? "datagram" : "stream"), |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1481 (STRINGP (port) ? (char *)SDATA (port) : "?")); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1482 insert_string (tembuf); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1483 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1484 else if (NETCONN1_P (p)) |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
1485 { |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1486 /* 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
|
1487 so display service instead. */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1488 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
|
1489 if (!STRINGP (host)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1490 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1491 host = Fplist_get (p->childp, QCservice); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1492 if (INTEGERP (host)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1493 host = Fnumber_to_string (host); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1494 } |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1495 if (NILP (host)) |
49114
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1496 host = Fformat_network_address (Fplist_get (p->childp, QCremote), Qnil); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1497 sprintf (tembuf, "(network %s connection to %s)\n", |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1498 (DATAGRAM_CHAN_P (p->infd) ? "datagram" : "stream"), |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1499 (STRINGP (host) ? (char *)SDATA (host) : "?")); |
578 | 1500 insert_string (tembuf); |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
1501 } |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1502 else if (SERIALCONN1_P (p)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1503 { |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1504 Lisp_Object port = Fplist_get (p->childp, QCport); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1505 Lisp_Object speed = Fplist_get (p->childp, QCspeed); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1506 insert_string ("(serial port "); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1507 if (STRINGP (port)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1508 insert_string (SDATA (port)); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1509 else |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1510 insert_string ("?"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1511 if (INTEGERP (speed)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1512 { |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1513 sprintf (tembuf, " at %d b/s", XINT (speed)); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1514 insert_string (tembuf); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1515 } |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1516 insert_string (")\n"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1517 } |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
1518 else |
578 | 1519 { |
1520 tem = p->command; | |
1521 while (1) | |
1522 { | |
1523 tem1 = Fcar (tem); | |
1524 Finsert (1, &tem1); | |
1525 tem = Fcdr (tem); | |
1526 if (NILP (tem)) | |
1527 break; | |
1528 insert_string (" "); | |
1529 } | |
1530 insert_string ("\n"); | |
1531 } | |
1532 } | |
73225
ff880e40efba
(list_processes_1): Run sentinels before removing dead
Kim F. Storm <storm@cua.dk>
parents:
72727
diff
changeset
|
1533 if (exited) |
ff880e40efba
(list_processes_1): Run sentinels before removing dead
Kim F. Storm <storm@cua.dk>
parents:
72727
diff
changeset
|
1534 status_notify (NULL); |
578 | 1535 return Qnil; |
1536 } | |
1537 | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1538 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
|
1539 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
|
1540 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
|
1541 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
|
1542 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
|
1543 after the listing is made. */) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1544 (query_only) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1545 Lisp_Object query_only; |
578 | 1546 { |
1547 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
|
1548 list_processes_1, query_only); |
578 | 1549 return Qnil; |
1550 } | |
1551 | |
1552 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
|
1553 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
|
1554 () |
578 | 1555 { |
1556 return Fmapcar (Qcdr, Vprocess_alist); | |
1557 } | |
1558 | |
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1559 /* 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
|
1560 |
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1561 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
|
1562 |
578 | 1563 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
|
1564 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
|
1565 NAME is name for process. It is modified if necessary to make it unique. |
55504
05e8ea84c376
(Fstart_process): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
55444
diff
changeset
|
1566 BUFFER is the buffer (or buffer name) to associate with the process. |
77440 | 1567 |
1568 Process output (both standard output and standard error streams) goes | |
1569 at end of BUFFER, unless you specify an output stream or filter | |
1570 function to handle the output. BUFFER may also be nil, meaning that | |
77462
4f679f6070a0
(Fstart_process): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
77440
diff
changeset
|
1571 this process is not associated with any buffer. |
4f679f6070a0
(Fstart_process): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
77440
diff
changeset
|
1572 |
4f679f6070a0
(Fstart_process): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
77440
diff
changeset
|
1573 PROGRAM is the program file name. It is searched for in PATH. |
4f679f6070a0
(Fstart_process): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
77440
diff
changeset
|
1574 Remaining arguments are strings to give program as arguments. |
77440 | 1575 |
1576 If you want to separate standard output from standard error, invoke | |
1577 the command through a shell and redirect one of them using the shell | |
1578 syntax. | |
44170
888d736c0e91
(set-network-process-options): Add usage.
Pavel Janík <Pavel@Janik.cz>
parents:
44073
diff
changeset
|
1579 |
40641
d94fc1022312
(Fstart_process): Add usage to doc-string.
Pavel Janík <Pavel@Janik.cz>
parents:
40231
diff
changeset
|
1580 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
|
1581 (nargs, args) |
578 | 1582 int nargs; |
1583 register Lisp_Object *args; | |
1584 { | |
1683
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1585 Lisp_Object buffer, name, program, proc, current_dir, tem; |
578 | 1586 register unsigned char **new_argv; |
1587 register int i; | |
46293
1fb8f75062c6
Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents:
45410
diff
changeset
|
1588 int count = SPECPDL_INDEX (); |
578 | 1589 |
1590 buffer = args[1]; | |
1591 if (!NILP (buffer)) | |
1592 buffer = Fget_buffer_create (buffer); | |
1593 | |
1683
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1594 /* 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
|
1595 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
|
1596 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
|
1597 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
|
1598 |
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1599 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
|
1600 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
|
1601 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
|
1602 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
|
1603 { |
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1604 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
|
1605 |
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1606 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
|
1607 |
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1608 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
|
1609 |
91551
f14242124fd7
* process.c (Fstart_process):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91367
diff
changeset
|
1610 current_dir = Funhandled_file_name_directory (current_dir); |
f14242124fd7
* process.c (Fstart_process):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91367
diff
changeset
|
1611 if (NILP (current_dir)) |
f14242124fd7
* process.c (Fstart_process):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91367
diff
changeset
|
1612 /* If the file name handler says that current_dir is unreachable, use |
f14242124fd7
* process.c (Fstart_process):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91367
diff
changeset
|
1613 a sensible default. */ |
f14242124fd7
* process.c (Fstart_process):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91367
diff
changeset
|
1614 current_dir = build_string ("~/"); |
f14242124fd7
* process.c (Fstart_process):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91367
diff
changeset
|
1615 current_dir = expand_and_dir_to_file (current_dir, Qnil); |
1683
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1616 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
|
1617 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
|
1618 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
|
1619 |
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1620 UNGCPRO; |
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1621 } |
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1622 |
578 | 1623 name = args[0]; |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1624 CHECK_STRING (name); |
578 | 1625 |
1626 program = args[2]; | |
1627 | |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1628 CHECK_STRING (program); |
578 | 1629 |
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1630 proc = make_process (name); |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1631 /* 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
|
1632 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
|
1633 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
|
1634 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
|
1635 record_unwind_protect (start_process_unwind, proc); |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1636 |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1637 XPROCESS (proc)->childp = Qt; |
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1638 XPROCESS (proc)->plist = Qnil; |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1639 XPROCESS (proc)->type = Qreal; |
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1640 XPROCESS (proc)->buffer = buffer; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1641 XPROCESS (proc)->sentinel = Qnil; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1642 XPROCESS (proc)->filter = Qnil; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1643 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
|
1644 |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
1645 #ifdef ADAPTIVE_READ_BUFFERING |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1646 XPROCESS (proc)->adaptive_read_buffering |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1647 = (NILP (Vprocess_adaptive_read_buffering) ? 0 |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1648 : EQ (Vprocess_adaptive_read_buffering, Qt) ? 1 : 2); |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
1649 #endif |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
1650 |
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1651 /* Make the process marker point into the process buffer (if any). */ |
69151
08c9c1760e1c
(Fmake_network_process): Init the process's mark.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68651
diff
changeset
|
1652 if (BUFFERP (buffer)) |
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1653 set_marker_both (XPROCESS (proc)->mark, buffer, |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1654 BUF_ZV (XBUFFER (buffer)), |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1655 BUF_ZV_BYTE (XBUFFER (buffer))); |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1656 |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1657 { |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1658 /* 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
|
1659 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
|
1660 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
|
1661 |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1662 /* 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
|
1663 Lisp_Object coding_systems = Qt; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1664 Lisp_Object val, *args2; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1665 struct gcpro gcpro1, gcpro2; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1666 |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1667 val = Vcoding_system_for_read; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1668 if (NILP (val)) |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1669 { |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1670 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
|
1671 args2[0] = Qstart_process; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1672 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
|
1673 GCPRO2 (proc, current_dir); |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1674 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
|
1675 UNGCPRO; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1676 if (CONSP (coding_systems)) |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1677 val = XCAR (coding_systems); |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1678 else if (CONSP (Vdefault_process_coding_system)) |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1679 val = XCAR (Vdefault_process_coding_system); |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1680 } |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1681 XPROCESS (proc)->decode_coding_system = val; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1682 |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1683 val = Vcoding_system_for_write; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1684 if (NILP (val)) |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1685 { |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1686 if (EQ (coding_systems, Qt)) |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1687 { |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1688 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
|
1689 args2[0] = Qstart_process; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1690 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
|
1691 GCPRO2 (proc, current_dir); |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1692 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
|
1693 UNGCPRO; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1694 } |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1695 if (CONSP (coding_systems)) |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1696 val = XCDR (coding_systems); |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1697 else if (CONSP (Vdefault_process_coding_system)) |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1698 val = XCDR (Vdefault_process_coding_system); |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1699 } |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1700 XPROCESS (proc)->encode_coding_system = val; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1701 } |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1702 |
47020
de9a20871faa
(Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents:
46431
diff
changeset
|
1703 /* 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
|
1704 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
|
1705 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
|
1706 && !(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
|
1707 && IS_DEVICE_SEP (SREF (program, 1)))) |
6390
9f8ce71435de
(Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents:
6345
diff
changeset
|
1708 { |
9f8ce71435de
(Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents:
6345
diff
changeset
|
1709 struct gcpro gcpro1, gcpro2, gcpro3, gcpro4; |
9f8ce71435de
(Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents:
6345
diff
changeset
|
1710 |
9f8ce71435de
(Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents:
6345
diff
changeset
|
1711 tem = Qnil; |
9f8ce71435de
(Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents:
6345
diff
changeset
|
1712 GCPRO4 (name, program, buffer, current_dir); |
45005
084928cfcfcb
(Fstart_process): Update call to openp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44890
diff
changeset
|
1713 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
|
1714 UNGCPRO; |
9f8ce71435de
(Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents:
6345
diff
changeset
|
1715 if (NILP (tem)) |
9f8ce71435de
(Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents:
6345
diff
changeset
|
1716 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
|
1717 tem = Fexpand_file_name (tem, Qnil); |
6390
9f8ce71435de
(Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents:
6345
diff
changeset
|
1718 } |
9f8ce71435de
(Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents:
6345
diff
changeset
|
1719 else |
12491
4ad7be34ece1
(Fstart_process): Expand PROGRAM.
Richard M. Stallman <rms@gnu.org>
parents:
12378
diff
changeset
|
1720 { |
4ad7be34ece1
(Fstart_process): Expand PROGRAM.
Richard M. Stallman <rms@gnu.org>
parents:
12378
diff
changeset
|
1721 if (!NILP (Ffile_directory_p (program))) |
4ad7be34ece1
(Fstart_process): Expand PROGRAM.
Richard M. Stallman <rms@gnu.org>
parents:
12378
diff
changeset
|
1722 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
|
1723 tem = program; |
12491
4ad7be34ece1
(Fstart_process): Expand PROGRAM.
Richard M. Stallman <rms@gnu.org>
parents:
12378
diff
changeset
|
1724 } |
6390
9f8ce71435de
(Fstart_process): GCPRO some things.
Karl Heuer <kwzh@gnu.org>
parents:
6345
diff
changeset
|
1725 |
47020
de9a20871faa
(Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents:
46431
diff
changeset
|
1726 /* 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
|
1727 discard that. */ |
de9a20871faa
(Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents:
46431
diff
changeset
|
1728 if (SBYTES (tem) > 2 && SREF (tem, 0) == '/' |
de9a20871faa
(Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents:
46431
diff
changeset
|
1729 && SREF (tem, 1) == ':') |
de9a20871faa
(Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents:
46431
diff
changeset
|
1730 tem = Fsubstring (tem, make_number (2), Qnil); |
de9a20871faa
(Fstart_process): Remove /: from program name.
Richard M. Stallman <rms@gnu.org>
parents:
46431
diff
changeset
|
1731 |
103095
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1732 { |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1733 struct gcpro gcpro1; |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1734 GCPRO1 (tem); |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1735 |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1736 /* Encode the file name and put it in NEW_ARGV. |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1737 That's where the child will use it to execute the program. */ |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1738 tem = Fcons (ENCODE_FILE (tem), Qnil); |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1739 |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1740 /* Here we encode arguments by the coding system used for sending |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1741 data to the process. We don't support using different coding |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1742 systems for encoding arguments and for encoding data sent to the |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1743 process. */ |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1744 |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1745 for (i = 3; i < nargs; i++) |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1746 { |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1747 tem = Fcons (args[i], tem); |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1748 CHECK_STRING (XCAR (tem)); |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1749 if (STRING_MULTIBYTE (XCAR (tem))) |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1750 XSETCAR (tem, |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1751 code_convert_string_norecord |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1752 (XCAR (tem), XPROCESS (proc)->encode_coding_system, 1)); |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1753 } |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1754 |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1755 UNGCPRO; |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1756 } |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1757 |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1758 /* Now that everything is encoded we can collect the strings into |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1759 NEW_ARGV. */ |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1760 new_argv = (unsigned char **) alloca ((nargs - 1) * sizeof (char *)); |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1761 new_argv[nargs - 2] = 0; |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1762 |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1763 for (i = nargs - 3; i >= 0; i--) |
578 | 1764 { |
103095
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1765 new_argv[i] = SDATA (XCAR (tem)); |
65cc22e2c624
* fns.c (Flocale_info): Protect vector from GC during decoding.
Andreas Schwab <schwab@linux-m68k.org>
parents:
102205
diff
changeset
|
1766 tem = XCDR (tem); |
578 | 1767 } |
1768 | |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
1769 XPROCESS (proc)->decoding_buf = make_uninit_string (0); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1770 XPROCESS (proc)->decoding_carryover = 0; |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
1771 XPROCESS (proc)->encoding_buf = make_uninit_string (0); |
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
1772 |
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1773 XPROCESS (proc)->inherit_coding_system_flag |
81926
50da0700fc26
(Fstart_process, Fmake_network_process, read_process_output):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
81876
diff
changeset
|
1774 = !(NILP (buffer) || !inherit_process_coding_system); |
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1775 |
20382
dbad9367d232
(create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents:
20225
diff
changeset
|
1776 create_process (proc, (char **) new_argv, current_dir); |
578 | 1777 |
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1778 return unbind_to (count, proc); |
578 | 1779 } |
1780 | |
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1781 /* This function is the unwind_protect form for Fstart_process. If |
14036 | 1782 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
|
1783 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
|
1784 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
|
1785 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
|
1786 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
|
1787 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
|
1788 { |
9115
59bc2d010b5f
(decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents:
9034
diff
changeset
|
1789 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
|
1790 abort (); |
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1791 |
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1792 /* Was PROC started successfully? */ |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
1793 if (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
|
1794 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
|
1795 |
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1796 return Qnil; |
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1797 } |
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1798 |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
1799 static void |
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
1800 create_process_1 (timer) |
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
1801 struct atimer *timer; |
578 | 1802 { |
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
1803 /* Nothing to do. */ |
578 | 1804 } |
1805 | |
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
1806 |
578 | 1807 #if 0 /* This doesn't work; see the note before sigchld_handler. */ |
1808 #ifdef USG | |
1809 #ifdef SIGCHLD | |
1810 /* Mimic blocking of signals on system V, which doesn't really have it. */ | |
1811 | |
1812 /* Nonzero means we got a SIGCHLD when it was supposed to be blocked. */ | |
1813 int sigchld_deferred; | |
1814 | |
1815 SIGTYPE | |
1816 create_process_sigchld () | |
1817 { | |
1818 signal (SIGCHLD, create_process_sigchld); | |
1819 | |
1820 sigchld_deferred = 1; | |
1821 } | |
1822 #endif | |
1823 #endif | |
1824 #endif | |
1825 | |
20382
dbad9367d232
(create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents:
20225
diff
changeset
|
1826 void |
1683
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1827 create_process (process, new_argv, current_dir) |
578 | 1828 Lisp_Object process; |
1829 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
|
1830 Lisp_Object current_dir; |
578 | 1831 { |
76494
f0a25b5d3ba0
(Fdelete_process): Properly handle deletion of first element of
Chong Yidong <cyd@stupidchicken.com>
parents:
76493
diff
changeset
|
1832 int inchannel, outchannel; |
f0a25b5d3ba0
(Fdelete_process): Properly handle deletion of first element of
Chong Yidong <cyd@stupidchicken.com>
parents:
76493
diff
changeset
|
1833 pid_t pid; |
578 | 1834 int sv[2]; |
80610
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1835 #if !defined (WINDOWSNT) && defined (FD_CLOEXEC) |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1836 int wait_child_setup[2]; |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1837 #endif |
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1838 #ifdef POSIX_SIGNALS |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1839 sigset_t procmask; |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1840 sigset_t blocked; |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1841 struct sigaction sigint_action; |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1842 struct sigaction sigquit_action; |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1843 #ifdef AIX |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1844 struct sigaction sighup_action; |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1845 #endif |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1846 #else /* !POSIX_SIGNALS */ |
25770
3a44b5298cd5
(list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents:
25760
diff
changeset
|
1847 #if 0 |
578 | 1848 #ifdef SIGCHLD |
1849 SIGTYPE (*sigchld)(); | |
1850 #endif | |
25770
3a44b5298cd5
(list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents:
25760
diff
changeset
|
1851 #endif /* 0 */ |
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1852 #endif /* !POSIX_SIGNALS */ |
11926
40d7e6f04ebe
(create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents:
11845
diff
changeset
|
1853 /* 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
|
1854 volatile int forkin, forkout; |
40d7e6f04ebe
(create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents:
11845
diff
changeset
|
1855 volatile int pty_flag = 0; |
31099
0fe5afca71e4
Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents:
30582
diff
changeset
|
1856 #ifndef USE_CRT_DLL |
578 | 1857 extern char **environ; |
31099
0fe5afca71e4
Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents:
30582
diff
changeset
|
1858 #endif |
578 | 1859 |
1860 inchannel = outchannel = -1; | |
1861 | |
1862 #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
|
1863 if (!NILP (Vprocess_connection_type)) |
578 | 1864 outchannel = inchannel = allocate_pty (); |
1865 | |
1866 if (inchannel >= 0) | |
1867 { | |
46411
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
1868 #if ! defined (USG) || defined (USG_SUBTTY_WORKS) |
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
1869 /* 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
|
1870 then close it and reopen it in the child. */ |
578 | 1871 #ifdef O_NOCTTY |
1872 /* Don't let this terminal become our controlling terminal | |
1873 (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
|
1874 forkout = forkin = emacs_open (pty_name, O_RDWR | O_NOCTTY, 0); |
578 | 1875 #else |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
1876 forkout = forkin = emacs_open (pty_name, O_RDWR, 0); |
578 | 1877 #endif |
1878 if (forkin < 0) | |
1879 report_file_error ("Opening pty", Qnil); | |
1880 #else | |
1881 forkin = forkout = -1; | |
46411
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
1882 #endif /* not USG, or USG_SUBTTY_WORKS */ |
578 | 1883 pty_flag = 1; |
1884 } | |
1885 else | |
1886 #endif /* HAVE_PTYS */ | |
1887 { | |
25129
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1888 int tem; |
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1889 tem = pipe (sv); |
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1890 if (tem < 0) |
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1891 report_file_error ("Creating pipe", Qnil); |
578 | 1892 inchannel = sv[0]; |
1893 forkout = sv[1]; | |
25129
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1894 tem = pipe (sv); |
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1895 if (tem < 0) |
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1896 { |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
1897 emacs_close (inchannel); |
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); |
25129
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1899 report_file_error ("Creating pipe", Qnil); |
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1900 } |
578 | 1901 outchannel = sv[1]; |
1902 forkin = sv[0]; | |
1903 } | |
1904 | |
80610
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1905 #if !defined (WINDOWSNT) && defined (FD_CLOEXEC) |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1906 { |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1907 int tem; |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1908 |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1909 tem = pipe (wait_child_setup); |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1910 if (tem < 0) |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1911 report_file_error ("Creating pipe", Qnil); |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1912 tem = fcntl (wait_child_setup[1], F_GETFD, 0); |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1913 if (tem >= 0) |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1914 tem = fcntl (wait_child_setup[1], F_SETFD, tem | FD_CLOEXEC); |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1915 if (tem < 0) |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1916 { |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1917 emacs_close (wait_child_setup[0]); |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1918 emacs_close (wait_child_setup[1]); |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1919 report_file_error ("Setting file descriptor flags", Qnil); |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1920 } |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1921 } |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1922 #endif |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1923 |
578 | 1924 #if 0 |
1925 /* Replaced by close_process_descs */ | |
1926 set_exclusive_use (inchannel); | |
1927 set_exclusive_use (outchannel); | |
1928 #endif | |
1929 | |
1930 #ifdef O_NONBLOCK | |
1931 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
|
1932 fcntl (outchannel, F_SETFL, O_NONBLOCK); |
578 | 1933 #else |
1934 #ifdef O_NDELAY | |
1935 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
|
1936 fcntl (outchannel, F_SETFL, O_NDELAY); |
578 | 1937 #endif |
1938 #endif | |
1939 | |
1940 /* Record this as an active process, with its channels. | |
1941 As a result, child_setup will close Emacs's side of the pipes. */ | |
1942 chan_process[inchannel] = process; | |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1943 XPROCESS (process)->infd = inchannel; |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1944 XPROCESS (process)->outfd = outchannel; |
49903
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
1945 |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
1946 /* Previously we recorded the tty descriptor used in the subprocess. |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
1947 It was only used for getting the foreground tty process, so now |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
1948 we just reopen the device (see emacs_get_tty_pgrp) as this is |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
1949 more portable (see USG_SUBTTY_WORKS above). */ |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
1950 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1951 XPROCESS (process)->pty_flag = pty_flag; |
578 | 1952 XPROCESS (process)->status = Qrun; |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
1953 setup_process_coding_systems (process); |
578 | 1954 |
1955 /* Delay interrupts until we have a chance to store | |
1956 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
|
1957 #ifdef POSIX_SIGNALS |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1958 sigemptyset (&blocked); |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1959 #ifdef SIGCHLD |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1960 sigaddset (&blocked, SIGCHLD); |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1961 #endif |
41856
0028402ed7d1
(create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents:
40656
diff
changeset
|
1962 #ifdef HAVE_WORKING_VFORK |
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1963 /* 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
|
1964 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
|
1965 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
|
1966 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
|
1967 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
|
1968 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
|
1969 #ifdef AIX |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1970 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
|
1971 #endif |
41856
0028402ed7d1
(create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents:
40656
diff
changeset
|
1972 #endif /* HAVE_WORKING_VFORK */ |
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1973 sigprocmask (SIG_BLOCK, &blocked, &procmask); |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1974 #else /* !POSIX_SIGNALS */ |
578 | 1975 #ifdef SIGCHLD |
87730 | 1976 #if defined (BSD_SYSTEM) || defined (HPUX) |
578 | 1977 sigsetmask (sigmask (SIGCHLD)); |
1978 #else /* ordinary USG */ | |
1979 #if 0 | |
1980 sigchld_deferred = 0; | |
1981 sigchld = signal (SIGCHLD, create_process_sigchld); | |
1982 #endif | |
1983 #endif /* ordinary USG */ | |
1984 #endif /* SIGCHLD */ | |
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1985 #endif /* !POSIX_SIGNALS */ |
578 | 1986 |
7893
e54617027a47
(create_process): Set input_wait_mask before forking.
Karl Heuer <kwzh@gnu.org>
parents:
7884
diff
changeset
|
1987 FD_SET (inchannel, &input_wait_mask); |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
1988 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
|
1989 if (inchannel > max_process_desc) |
e54617027a47
(create_process): Set input_wait_mask before forking.
Karl Heuer <kwzh@gnu.org>
parents:
7884
diff
changeset
|
1990 max_process_desc = inchannel; |
e54617027a47
(create_process): Set input_wait_mask before forking.
Karl Heuer <kwzh@gnu.org>
parents:
7884
diff
changeset
|
1991 |
578 | 1992 /* Until we store the proper pid, enable sigchld_handler |
1993 to recognize an unknown pid as standing for this process. | |
1994 It is very important not to let this `marker' value stay | |
1995 in the table after this function has returned; if it does | |
1996 it might cause call-process to hang and subsequent asynchronous | |
1997 processes to get their return values scrambled. */ | |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
1998 XPROCESS (process)->pid = -1; |
578 | 1999 |
16780 | 2000 BLOCK_INPUT; |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2001 |
578 | 2002 { |
2003 /* child_setup must clobber environ on systems with true vfork. | |
2004 Protect it from permanent change. */ | |
2005 char **save_environ = environ; | |
2006 | |
21049
01e626b0a624
(Vdefault_file_name_coding_system): Extern it.
Kenichi Handa <handa@m17n.org>
parents:
20715
diff
changeset
|
2007 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
|
2008 |
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
2009 #ifndef WINDOWSNT |
578 | 2010 pid = vfork (); |
2011 if (pid == 0) | |
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
2012 #endif /* not WINDOWSNT */ |
578 | 2013 { |
2014 int xforkin = forkin; | |
2015 int xforkout = forkout; | |
2016 | |
2017 #if 0 /* This was probably a mistake--it duplicates code later on, | |
2018 but fails to handle all the cases. */ | |
2019 /* Make sure SIGCHLD is not blocked in the child. */ | |
2020 sigsetmask (SIGEMPTYMASK); | |
2021 #endif | |
2022 | |
2023 /* Make the pty be the controlling terminal of the process. */ | |
2024 #ifdef HAVE_PTYS | |
2025 /* First, disconnect its current controlling terminal. */ | |
2026 #ifdef HAVE_SETSID | |
7266
f87808bd90e9
(create_process): Undo April 19 setsid change.
Richard M. Stallman <rms@gnu.org>
parents:
7238
diff
changeset
|
2027 /* 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
|
2028 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
|
2029 setsid (); |
1030
9934251d8219
(WCOREDUMP): Define only if not defined.
Richard M. Stallman <rms@gnu.org>
parents:
1012
diff
changeset
|
2030 /* 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
|
2031 if (pty_flag) |
6975
b7411e378b65
(create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
6947
diff
changeset
|
2032 { |
b7411e378b65
(create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
6947
diff
changeset
|
2033 #ifdef TIOCSCTTY |
b7411e378b65
(create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
6947
diff
changeset
|
2034 /* We ignore the return value |
b7411e378b65
(create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
6947
diff
changeset
|
2035 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
|
2036 ioctl (xforkin, TIOCSCTTY, 0); |
1030
9934251d8219
(WCOREDUMP): Define only if not defined.
Richard M. Stallman <rms@gnu.org>
parents:
1012
diff
changeset
|
2037 #endif |
6975
b7411e378b65
(create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
6947
diff
changeset
|
2038 } |
578 | 2039 #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
|
2040 #ifdef USG |
5347
21bffe027a7d
(create_process) [NTTYDISC]: Set the tty line discipline.
Richard M. Stallman <rms@gnu.org>
parents:
5332
diff
changeset
|
2041 /* It's very important to call setpgrp here and no time |
578 | 2042 afterwards. Otherwise, we lose our controlling tty which |
2043 is set when we open the pty. */ | |
2044 setpgrp (); | |
2045 #endif /* USG */ | |
2046 #endif /* not HAVE_SETSID */ | |
7116
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
2047 #if defined (HAVE_TERMIOS) && defined (LDISC1) |
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
2048 if (pty_flag && xforkin >= 0) |
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
2049 { |
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
2050 struct termios t; |
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
2051 tcgetattr (xforkin, &t); |
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
2052 t.c_lflag = LDISC1; |
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
2053 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
|
2054 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
|
2055 } |
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
2056 #else |
6947
c5f990fad6bb
(create_process): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents:
6928
diff
changeset
|
2057 #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
|
2058 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
|
2059 { |
36d2fd17f833
(create_process): Set line discipline only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
5543
diff
changeset
|
2060 /* Use new line discipline. */ |
36d2fd17f833
(create_process): Set line discipline only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
5543
diff
changeset
|
2061 int ldisc = NTTYDISC; |
7605
53186c2698e5
(create_process): Don't complain about error from TIOCSETD.
Richard M. Stallman <rms@gnu.org>
parents:
7486
diff
changeset
|
2062 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
|
2063 } |
5347
21bffe027a7d
(create_process) [NTTYDISC]: Set the tty line discipline.
Richard M. Stallman <rms@gnu.org>
parents:
5332
diff
changeset
|
2064 #endif |
7116
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
2065 #endif |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2066 #ifdef TIOCNOTTY |
578 | 2067 /* In 4.3BSD, the TIOCSPGRP bug has been fixed, and now you |
2068 can do TIOCSPGRP only to the process's controlling tty. */ | |
2069 if (pty_flag) | |
2070 { | |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2071 /* I wonder: would just ioctl (0, TIOCNOTTY, 0) work here? |
578 | 2072 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
|
2073 int j = emacs_open ("/dev/tty", O_RDWR, 0); |
578 | 2074 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
|
2075 emacs_close (j); |
3826
647bef18618f
Changes for Irix 4.0, tested this time:
Jim Blandy <jimb@redhat.com>
parents:
3810
diff
changeset
|
2076 #ifndef USG |
578 | 2077 /* In order to get a controlling terminal on some versions |
2078 of BSD, it is necessary to put the process in pgrp 0 | |
2079 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
|
2080 #ifdef HAVE_SETPGID |
9882
ccc5562a7194
(create_process) [OSF1]: Use setpgid, not setpgrp.
Richard M. Stallman <rms@gnu.org>
parents:
9793
diff
changeset
|
2081 setpgid (0, 0); |
ccc5562a7194
(create_process) [OSF1]: Use setpgid, not setpgrp.
Richard M. Stallman <rms@gnu.org>
parents:
9793
diff
changeset
|
2082 #else |
578 | 2083 setpgrp (0, 0); |
2084 #endif | |
9882
ccc5562a7194
(create_process) [OSF1]: Use setpgid, not setpgrp.
Richard M. Stallman <rms@gnu.org>
parents:
9793
diff
changeset
|
2085 #endif |
578 | 2086 } |
2087 #endif /* TIOCNOTTY */ | |
2088 | |
87730 | 2089 #if !defined (DONT_REOPEN_PTY) |
578 | 2090 /*** 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
|
2091 conditional on TIOCSPGRP, |
5d1e0290bbd0
(create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents:
16058
diff
changeset
|
2092 or !(defined (HAVE_SETSID) && defined (TIOCSCTTY)). |
5d1e0290bbd0
(create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents:
16058
diff
changeset
|
2093 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
|
2094 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
|
2095 both HAVE_SETSID and TIOCSCTTY are defined. */ |
578 | 2096 /* Now close the pty (if we had it open) and reopen it. |
2097 This makes the pty the controlling terminal of the subprocess. */ | |
2098 if (pty_flag) | |
2099 { | |
5240
eed870591987
(Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents:
5239
diff
changeset
|
2100 |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
2101 /* 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
|
2102 would work? */ |
578 | 2103 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
|
2104 emacs_close (xforkin); |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
2105 xforkout = xforkin = emacs_open (pty_name, O_RDWR, 0); |
578 | 2106 |
11514
321726163a65
(create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents:
11376
diff
changeset
|
2107 if (xforkin < 0) |
321726163a65
(create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents:
11376
diff
changeset
|
2108 { |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
2109 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
|
2110 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
|
2111 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
|
2112 _exit (1); |
321726163a65
(create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents:
11376
diff
changeset
|
2113 } |
321726163a65
(create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents:
11376
diff
changeset
|
2114 |
578 | 2115 } |
87730 | 2116 #endif /* not DONT_REOPEN_PTY */ |
15368
6229fb866493
(create_process): Add DONT_OPEN_PTY conditional.
Richard M. Stallman <rms@gnu.org>
parents:
15355
diff
changeset
|
2117 |
578 | 2118 #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
|
2119 if (pty_flag) |
1855e568a9b8
(create_process): Use SETUP_SLAVE_PTY only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
7044
diff
changeset
|
2120 { |
1855e568a9b8
(create_process): Use SETUP_SLAVE_PTY only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
7044
diff
changeset
|
2121 SETUP_SLAVE_PTY; |
1855e568a9b8
(create_process): Use SETUP_SLAVE_PTY only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
7044
diff
changeset
|
2122 } |
578 | 2123 #endif /* SETUP_SLAVE_PTY */ |
2124 #ifdef AIX | |
2125 /* On AIX, we've disabled SIGHUP above once we start a child on a pty. | |
2126 Now reenable it in the child, so it will die when we want it to. */ | |
2127 if (pty_flag) | |
2128 signal (SIGHUP, SIG_DFL); | |
2129 #endif | |
2130 #endif /* HAVE_PTYS */ | |
2131 | |
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2132 signal (SIGINT, SIG_DFL); |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2133 signal (SIGQUIT, SIG_DFL); |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2134 |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2135 /* Stop blocking signals in the child. */ |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2136 #ifdef POSIX_SIGNALS |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2137 sigprocmask (SIG_SETMASK, &procmask, 0); |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2138 #else /* !POSIX_SIGNALS */ |
578 | 2139 #ifdef SIGCHLD |
87730 | 2140 #if defined (BSD_SYSTEM) || defined (HPUX) |
578 | 2141 sigsetmask (SIGEMPTYMASK); |
2142 #else /* ordinary USG */ | |
1207
af619d68a576
* process.c [SIGCHLD && !BSD && !UNIPLUS && !HPUX]
Jim Blandy <jimb@redhat.com>
parents:
1180
diff
changeset
|
2143 #if 0 |
578 | 2144 signal (SIGCHLD, sigchld); |
1207
af619d68a576
* process.c [SIGCHLD && !BSD && !UNIPLUS && !HPUX]
Jim Blandy <jimb@redhat.com>
parents:
1180
diff
changeset
|
2145 #endif |
578 | 2146 #endif /* ordinary USG */ |
2147 #endif /* SIGCHLD */ | |
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2148 #endif /* !POSIX_SIGNALS */ |
8390
ee13e8728666
(create_process): Set default handling for SIGINT, etc.
Richard M. Stallman <rms@gnu.org>
parents:
8354
diff
changeset
|
2149 |
7059
6a55de48ade5
(create_process): Use child_setup_tty only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
7058
diff
changeset
|
2150 if (pty_flag) |
6a55de48ade5
(create_process): Use child_setup_tty only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
7058
diff
changeset
|
2151 child_setup_tty (xforkout); |
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
2152 #ifdef WINDOWSNT |
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
2153 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
|
2154 new_argv, 1, current_dir); |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2155 #else /* not WINDOWSNT */ |
80610
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2156 #ifdef FD_CLOEXEC |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2157 emacs_close (wait_child_setup[0]); |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2158 #endif |
578 | 2159 child_setup (xforkin, xforkout, xforkout, |
638 | 2160 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
|
2161 #endif /* not WINDOWSNT */ |
578 | 2162 } |
2163 environ = save_environ; | |
2164 } | |
2165 | |
16780 | 2166 UNBLOCK_INPUT; |
2167 | |
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2168 /* This runs in the Emacs process. */ |
578 | 2169 if (pid < 0) |
7157
3f4fc9d682b4
(create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents:
7116
diff
changeset
|
2170 { |
3f4fc9d682b4
(create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents:
7116
diff
changeset
|
2171 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
|
2172 emacs_close (forkin); |
7157
3f4fc9d682b4
(create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents:
7116
diff
changeset
|
2173 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
|
2174 emacs_close (forkout); |
7157
3f4fc9d682b4
(create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents:
7116
diff
changeset
|
2175 } |
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2176 else |
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2177 { |
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2178 /* vfork succeeded. */ |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
2179 XPROCESS (process)->pid = pid; |
578 | 2180 |
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
2181 #ifdef WINDOWSNT |
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2182 register_child (pid, inchannel); |
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
2183 #endif /* WINDOWSNT */ |
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
2184 |
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2185 /* If the subfork execv fails, and it exits, |
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2186 this close hangs. I don't know why. |
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2187 So have an interrupt jar it loose. */ |
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2188 { |
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2189 struct atimer *timer; |
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2190 EMACS_TIME offset; |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2191 |
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2192 stop_polling (); |
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2193 EMACS_SET_SECS_USECS (offset, 1, 0); |
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2194 timer = start_atimer (ATIMER_RELATIVE, offset, create_process_1, 0); |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2195 |
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2196 if (forkin >= 0) |
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2197 emacs_close (forkin); |
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2198 |
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2199 cancel_atimer (timer); |
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2200 start_polling (); |
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2201 } |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2202 |
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2203 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
|
2204 emacs_close (forkout); |
578 | 2205 |
11609
3b2dacb1bfe9
(create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents:
11514
diff
changeset
|
2206 #ifdef HAVE_PTYS |
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2207 if (pty_flag) |
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2208 XPROCESS (process)->tty_name = build_string (pty_name); |
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2209 else |
11609
3b2dacb1bfe9
(create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents:
11514
diff
changeset
|
2210 #endif |
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2211 XPROCESS (process)->tty_name = Qnil; |
80610
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2212 |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2213 #if !defined (WINDOWSNT) && defined (FD_CLOEXEC) |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2214 /* Wait for child_setup to complete in case that vfork is |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2215 actually defined as fork. The descriptor wait_child_setup[1] |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2216 of a pipe is closed at the child side either by close-on-exec |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2217 on successful execvp or the _exit call in child_setup. */ |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2218 { |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2219 char dummy; |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2220 |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2221 emacs_close (wait_child_setup[1]); |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2222 emacs_read (wait_child_setup[0], &dummy, 1); |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2223 emacs_close (wait_child_setup[0]); |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2224 } |
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2225 #endif |
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2226 } |
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2227 |
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2228 /* 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
|
2229 (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
|
2230 #ifdef POSIX_SIGNALS |
41856
0028402ed7d1
(create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents:
40656
diff
changeset
|
2231 #ifdef HAVE_WORKING_VFORK |
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2232 /* Restore the parent's signal handlers. */ |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2233 sigaction (SIGINT, &sigint_action, 0); |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2234 sigaction (SIGQUIT, &sigquit_action, 0); |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2235 #ifdef AIX |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2236 sigaction (SIGHUP, &sighup_action, 0); |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2237 #endif |
41856
0028402ed7d1
(create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents:
40656
diff
changeset
|
2238 #endif /* HAVE_WORKING_VFORK */ |
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2239 /* Stop blocking signals in the parent. */ |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2240 sigprocmask (SIG_SETMASK, &procmask, 0); |
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2241 #else /* !POSIX_SIGNALS */ |
578 | 2242 #ifdef SIGCHLD |
87730 | 2243 #if defined (BSD_SYSTEM) || defined (HPUX) |
578 | 2244 sigsetmask (SIGEMPTYMASK); |
2245 #else /* ordinary USG */ | |
2246 #if 0 | |
2247 signal (SIGCHLD, sigchld); | |
2248 /* Now really handle any of these signals | |
2249 that came in during this function. */ | |
2250 if (sigchld_deferred) | |
2251 kill (getpid (), SIGCHLD); | |
2252 #endif | |
2253 #endif /* ordinary USG */ | |
2254 #endif /* SIGCHLD */ | |
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2255 #endif /* !POSIX_SIGNALS */ |
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2256 |
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2257 /* Now generate the error if vfork failed. */ |
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2258 if (pid < 0) |
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2259 report_file_error ("Doing vfork", Qnil); |
578 | 2260 } |
2261 | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2262 |
578 | 2263 #ifdef HAVE_SOCKETS |
2264 | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2265 /* 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
|
2266 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
|
2267 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2268 static Lisp_Object |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2269 conv_sockaddr_to_lisp (sa, len) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2270 struct sockaddr *sa; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2271 int len; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2272 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2273 Lisp_Object address; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2274 int i; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2275 unsigned char *cp; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2276 register struct Lisp_Vector *p; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2277 |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
2278 /* Workaround for a bug in getsockname on BSD: Names bound to |
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
2279 sockets in the UNIX domain are inaccessible; getsockname returns |
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
2280 a zero length name. */ |
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
2281 if (len < OFFSETOF (struct sockaddr, sa_family) + sizeof (sa->sa_family)) |
101276
dd95cb42c0aa
* dbusbind.c (Fdbus_register_signal):
Juanma Barranquero <lekktu@gmail.com>
parents:
100860
diff
changeset
|
2282 return empty_unibyte_string; |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
2283 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2284 switch (sa->sa_family) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2285 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2286 case AF_INET: |
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 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
|
2289 len = sizeof (sin->sin_addr) + 1; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2290 address = Fmake_vector (make_number (len), Qnil); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2291 p = XVECTOR (address); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2292 p->contents[--len] = make_number (ntohs (sin->sin_port)); |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
2293 cp = (unsigned char *) &sin->sin_addr; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2294 break; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2295 } |
68008 | 2296 #ifdef AF_INET6 |
2297 case AF_INET6: | |
2298 { | |
2299 struct sockaddr_in6 *sin6 = (struct sockaddr_in6 *) sa; | |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
2300 uint16_t *ip6 = (uint16_t *) &sin6->sin6_addr; |
68008 | 2301 len = sizeof (sin6->sin6_addr)/2 + 1; |
2302 address = Fmake_vector (make_number (len), Qnil); | |
2303 p = XVECTOR (address); | |
2304 p->contents[--len] = make_number (ntohs (sin6->sin6_port)); | |
2305 for (i = 0; i < len; i++) | |
2306 p->contents[i] = make_number (ntohs (ip6[i])); | |
2307 return address; | |
2308 } | |
2309 #endif | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2310 #ifdef HAVE_LOCAL_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2311 case AF_LOCAL: |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2312 { |
44038
e2339254ba48
(conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents:
44013
diff
changeset
|
2313 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
|
2314 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
|
2315 if (sockun->sun_path[i] == 0) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2316 break; |
44038
e2339254ba48
(conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents:
44013
diff
changeset
|
2317 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
|
2318 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2319 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2320 default: |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
2321 len -= OFFSETOF (struct sockaddr, sa_family) + sizeof (sa->sa_family); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2322 address = Fcons (make_number (sa->sa_family), |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2323 Fmake_vector (make_number (len), Qnil)); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2324 p = XVECTOR (XCDR (address)); |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
2325 cp = (unsigned char *) &sa->sa_family + sizeof (sa->sa_family); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2326 break; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2327 } |
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 i = 0; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2330 while (i < len) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2331 p->contents[i++] = make_number (*cp++); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2332 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2333 return address; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2334 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2335 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2336 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2337 /* 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
|
2338 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2339 static int |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2340 get_lisp_to_sockaddr_size (address, familyp) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2341 Lisp_Object address; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2342 int *familyp; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2343 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2344 register struct Lisp_Vector *p; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2345 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2346 if (VECTORP (address)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2347 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2348 p = XVECTOR (address); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2349 if (p->size == 5) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2350 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2351 *familyp = AF_INET; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2352 return sizeof (struct sockaddr_in); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2353 } |
68008 | 2354 #ifdef AF_INET6 |
2355 else if (p->size == 9) | |
2356 { | |
2357 *familyp = AF_INET6; | |
2358 return sizeof (struct sockaddr_in6); | |
2359 } | |
2360 #endif | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2361 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2362 #ifdef HAVE_LOCAL_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2363 else if (STRINGP (address)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2364 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2365 *familyp = AF_LOCAL; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2366 return sizeof (struct sockaddr_un); |
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 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2369 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
|
2370 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2371 struct sockaddr *sa; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2372 *familyp = XINT (XCAR (address)); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2373 p = XVECTOR (XCDR (address)); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2374 return p->size + sizeof (sa->sa_family); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2375 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2376 return 0; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2377 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2378 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2379 /* Convert an address object (vector or string) to an internal sockaddr. |
69981
9fb9e33ecf2d
(conv_lisp_to_sockaddr): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents:
69974
diff
changeset
|
2380 |
9fb9e33ecf2d
(conv_lisp_to_sockaddr): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents:
69974
diff
changeset
|
2381 The address format has been basically validated by |
9fb9e33ecf2d
(conv_lisp_to_sockaddr): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents:
69974
diff
changeset
|
2382 get_lisp_to_sockaddr_size, but this does not mean FAMILY is valid; |
9fb9e33ecf2d
(conv_lisp_to_sockaddr): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents:
69974
diff
changeset
|
2383 it could have come from user data. So if FAMILY is not valid, |
9fb9e33ecf2d
(conv_lisp_to_sockaddr): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents:
69974
diff
changeset
|
2384 we return after zeroing *SA. */ |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2385 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2386 static void |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2387 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
|
2388 int family; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2389 Lisp_Object address; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2390 struct sockaddr *sa; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2391 int len; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2392 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2393 register struct Lisp_Vector *p; |
51233
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
2394 register unsigned char *cp = NULL; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2395 register int i; |
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 bzero (sa, len); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2398 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2399 if (VECTORP (address)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2400 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2401 p = XVECTOR (address); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2402 if (family == AF_INET) |
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 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
|
2405 len = sizeof (sin->sin_addr) + 1; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2406 i = XINT (p->contents[--len]); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2407 sin->sin_port = htons (i); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2408 cp = (unsigned char *)&sin->sin_addr; |
69981
9fb9e33ecf2d
(conv_lisp_to_sockaddr): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents:
69974
diff
changeset
|
2409 sa->sa_family = family; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2410 } |
68008 | 2411 #ifdef AF_INET6 |
2412 else if (family == AF_INET6) | |
2413 { | |
2414 struct sockaddr_in6 *sin6 = (struct sockaddr_in6 *) sa; | |
2415 uint16_t *ip6 = (uint16_t *)&sin6->sin6_addr; | |
2416 len = sizeof (sin6->sin6_addr) + 1; | |
2417 i = XINT (p->contents[--len]); | |
2418 sin6->sin6_port = htons (i); | |
2419 for (i = 0; i < len; i++) | |
2420 if (INTEGERP (p->contents[i])) | |
2421 { | |
2422 int j = XFASTINT (p->contents[i]) & 0xffff; | |
2423 ip6[i] = ntohs (j); | |
2424 } | |
69981
9fb9e33ecf2d
(conv_lisp_to_sockaddr): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents:
69974
diff
changeset
|
2425 sa->sa_family = family; |
68008 | 2426 } |
2427 #endif | |
69973
dc4e5cc51e66
(conv_lisp_to_sockaddr): If FAMILY unknown, just return.
Richard M. Stallman <rms@gnu.org>
parents:
69873
diff
changeset
|
2428 return; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2429 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2430 else if (STRINGP (address)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2431 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2432 #ifdef HAVE_LOCAL_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2433 if (family == AF_LOCAL) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2434 { |
44038
e2339254ba48
(conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents:
44013
diff
changeset
|
2435 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
|
2436 cp = SDATA (address); |
44038
e2339254ba48
(conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents:
44013
diff
changeset
|
2437 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
|
2438 sockun->sun_path[i] = *cp++; |
69981
9fb9e33ecf2d
(conv_lisp_to_sockaddr): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents:
69974
diff
changeset
|
2439 sa->sa_family = family; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2440 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2441 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2442 return; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2443 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2444 else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2445 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2446 p = XVECTOR (XCDR (address)); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2447 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
|
2448 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2449 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2450 for (i = 0; i < len; i++) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2451 if (INTEGERP (p->contents[i])) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2452 *cp++ = XFASTINT (p->contents[i]) & 0xff; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2453 } |
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 #ifdef DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2456 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
|
2457 1, 1, 0, |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2458 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
|
2459 (process) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2460 Lisp_Object process; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2461 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2462 int channel; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2463 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2464 CHECK_PROCESS (process); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2465 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2466 if (!DATAGRAM_CONN_P (process)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2467 return Qnil; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2468 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
2469 channel = XPROCESS (process)->infd; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2470 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
|
2471 datagram_address[channel].len); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2472 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2473 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2474 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
|
2475 2, 2, 0, |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2476 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
|
2477 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
|
2478 (process, address) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2479 Lisp_Object process, address; |
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 int channel; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2482 int family, len; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2483 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2484 CHECK_PROCESS (process); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2485 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2486 if (!DATAGRAM_CONN_P (process)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2487 return Qnil; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2488 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
2489 channel = XPROCESS (process)->infd; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2490 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2491 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
|
2492 if (datagram_address[channel].len != len) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2493 return Qnil; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2494 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
|
2495 return address; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2496 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2497 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2498 |
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 static struct socket_options { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2501 /* The name of this option. Should be lowercase version of option |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2502 name without SO_ prefix. */ |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2503 char *name; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2504 /* Option level SOL_... */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2505 int optlevel; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2506 /* Option number SO_... */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2507 int optnum; |
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2508 enum { SOPT_UNKNOWN, SOPT_BOOL, SOPT_INT, SOPT_IFNAME, SOPT_LINGER } opttype; |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2509 enum { OPIX_NONE=0, OPIX_MISC=1, OPIX_REUSEADDR=2 } optbit; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2510 } socket_options[] = |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2511 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2512 #ifdef SO_BINDTODEVICE |
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2513 { ":bindtodevice", SOL_SOCKET, SO_BINDTODEVICE, SOPT_IFNAME, OPIX_MISC }, |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2514 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2515 #ifdef SO_BROADCAST |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2516 { ":broadcast", SOL_SOCKET, SO_BROADCAST, SOPT_BOOL, OPIX_MISC }, |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2517 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2518 #ifdef SO_DONTROUTE |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2519 { ":dontroute", SOL_SOCKET, SO_DONTROUTE, SOPT_BOOL, OPIX_MISC }, |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2520 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2521 #ifdef SO_KEEPALIVE |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2522 { ":keepalive", SOL_SOCKET, SO_KEEPALIVE, SOPT_BOOL, OPIX_MISC }, |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2523 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2524 #ifdef SO_LINGER |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2525 { ":linger", SOL_SOCKET, SO_LINGER, SOPT_LINGER, OPIX_MISC }, |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2526 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2527 #ifdef SO_OOBINLINE |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2528 { ":oobinline", SOL_SOCKET, SO_OOBINLINE, SOPT_BOOL, OPIX_MISC }, |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2529 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2530 #ifdef SO_PRIORITY |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2531 { ":priority", SOL_SOCKET, SO_PRIORITY, SOPT_INT, OPIX_MISC }, |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2532 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2533 #ifdef SO_REUSEADDR |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2534 { ":reuseaddr", SOL_SOCKET, SO_REUSEADDR, SOPT_BOOL, OPIX_REUSEADDR }, |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2535 #endif |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2536 { 0, 0, 0, SOPT_UNKNOWN, OPIX_NONE } |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2537 }; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2538 |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2539 /* Set option OPT to value VAL on socket S. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2540 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2541 Returns (1<<socket_options[OPT].optbit) if option is known, 0 otherwise. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2542 Signals an error if setting a known option fails. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2543 */ |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2544 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2545 static int |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2546 set_socket_option (s, opt, val) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2547 int s; |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2548 Lisp_Object opt, val; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2549 { |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2550 char *name; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2551 struct socket_options *sopt; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2552 int ret = 0; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2553 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2554 CHECK_SYMBOL (opt); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2555 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2556 name = (char *) SDATA (SYMBOL_NAME (opt)); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2557 for (sopt = socket_options; sopt->name; sopt++) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2558 if (strcmp (name, sopt->name) == 0) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2559 break; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2560 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2561 switch (sopt->opttype) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2562 { |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2563 case SOPT_BOOL: |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2564 { |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2565 int optval; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2566 optval = NILP (val) ? 0 : 1; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2567 ret = setsockopt (s, sopt->optlevel, sopt->optnum, |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2568 &optval, sizeof (optval)); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2569 break; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2570 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2571 |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2572 case SOPT_INT: |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2573 { |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2574 int optval; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2575 if (INTEGERP (val)) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2576 optval = XINT (val); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2577 else |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2578 error ("Bad option value for %s", name); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2579 ret = setsockopt (s, sopt->optlevel, sopt->optnum, |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2580 &optval, sizeof (optval)); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2581 break; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2582 } |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2583 |
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2584 #ifdef SO_BINDTODEVICE |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2585 case SOPT_IFNAME: |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2586 { |
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2587 char devname[IFNAMSIZ+1]; |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2588 |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2589 /* This is broken, at least in the Linux 2.4 kernel. |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2590 To unbind, the arg must be a zero integer, not the empty string. |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2591 This should work on all systems. KFS. 2003-09-23. */ |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2592 bzero (devname, sizeof devname); |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2593 if (STRINGP (val)) |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2594 { |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2595 char *arg = (char *) SDATA (val); |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2596 int len = min (strlen (arg), IFNAMSIZ); |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2597 bcopy (arg, devname, len); |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2598 } |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2599 else if (!NILP (val)) |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2600 error ("Bad option value for %s", name); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2601 ret = setsockopt (s, sopt->optlevel, sopt->optnum, |
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2602 devname, IFNAMSIZ); |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2603 break; |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2604 } |
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2605 #endif |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2606 |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2607 #ifdef SO_LINGER |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2608 case SOPT_LINGER: |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2609 { |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2610 struct linger linger; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2611 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2612 linger.l_onoff = 1; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2613 linger.l_linger = 0; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2614 if (INTEGERP (val)) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2615 linger.l_linger = XINT (val); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2616 else |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2617 linger.l_onoff = NILP (val) ? 0 : 1; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2618 ret = setsockopt (s, sopt->optlevel, sopt->optnum, |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2619 &linger, sizeof (linger)); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2620 break; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2621 } |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2622 #endif |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2623 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2624 default: |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2625 return 0; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2626 } |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2627 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2628 if (ret < 0) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2629 report_file_error ("Cannot set network option", |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2630 Fcons (opt, Fcons (val, Qnil))); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2631 return (1 << sopt->optbit); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2632 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2633 |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2634 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2635 DEFUN ("set-network-process-option", |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2636 Fset_network_process_option, Sset_network_process_option, |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2637 3, 4, 0, |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2638 doc: /* For network process PROCESS set option OPTION to value VALUE. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2639 See `make-network-process' for a list of options and values. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2640 If optional fourth arg NO-ERROR is non-nil, don't signal an error if |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2641 OPTION is not a supported option, return nil instead; otherwise return t. */) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2642 (process, option, value, no_error) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2643 Lisp_Object process, option, value; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2644 Lisp_Object no_error; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2645 { |
52527
3ea59ac8dfa5
(Fnetwork_interface_info): Fix type error.
Dave Love <fx@gnu.org>
parents:
52525
diff
changeset
|
2646 int s; |
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2647 struct Lisp_Process *p; |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2648 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2649 CHECK_PROCESS (process); |
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2650 p = XPROCESS (process); |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2651 if (!NETCONN1_P (p)) |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2652 error ("Process is not a network process"); |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2653 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
2654 s = p->infd; |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2655 if (s < 0) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2656 error ("Process is not running"); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2657 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2658 if (set_socket_option (s, option, value)) |
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2659 { |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2660 p->childp = Fplist_put (p->childp, option, value); |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2661 return Qt; |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2662 } |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2663 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2664 if (NILP (no_error)) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2665 error ("Unknown or unsupported option"); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2666 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2667 return Qnil; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2668 } |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2669 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2670 |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2671 #ifdef HAVE_SERIAL |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2672 DEFUN ("serial-process-configure", |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2673 Fserial_process_configure, |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2674 Sserial_process_configure, |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2675 0, MANY, 0, |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2676 doc: /* Configure speed, bytesize, etc. of a serial process. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2677 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2678 Arguments are specified as keyword/argument pairs. Attributes that |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2679 are not given are re-initialized from the process's current |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2680 configuration (available via the function `process-contact') or set to |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2681 reasonable default values. The following arguments are defined: |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2682 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2683 :process PROCESS |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2684 :name NAME |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2685 :buffer BUFFER |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2686 :port PORT |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2687 -- Any of these arguments can be given to identify the process that is |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2688 to be configured. If none of these arguments is given, the current |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2689 buffer's process is used. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2690 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2691 :speed SPEED -- SPEED is the speed of the serial port in bits per |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2692 second, also called baud rate. Any value can be given for SPEED, but |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2693 most serial ports work only at a few defined values between 1200 and |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2694 115200, with 9600 being the most common value. If SPEED is nil, the |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2695 serial port is not configured any further, i.e., all other arguments |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2696 are ignored. This may be useful for special serial ports such as |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2697 Bluetooth-to-serial converters which can only be configured through AT |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2698 commands. A value of nil for SPEED can be used only when passed |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2699 through `make-serial-process' or `serial-term'. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2700 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2701 :bytesize BYTESIZE -- BYTESIZE is the number of bits per byte, which |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2702 can be 7 or 8. If BYTESIZE is not given or nil, a value of 8 is used. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2703 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2704 :parity PARITY -- PARITY can be nil (don't use parity), the symbol |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2705 `odd' (use odd parity), or the symbol `even' (use even parity). If |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2706 PARITY is not given, no parity is used. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2707 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2708 :stopbits STOPBITS -- STOPBITS is the number of stopbits used to |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2709 terminate a byte transmission. STOPBITS can be 1 or 2. If STOPBITS |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2710 is not given or nil, 1 stopbit is used. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2711 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2712 :flowcontrol FLOWCONTROL -- FLOWCONTROL determines the type of |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2713 flowcontrol to be used, which is either nil (don't use flowcontrol), |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2714 the symbol `hw' (use RTS/CTS hardware flowcontrol), or the symbol `sw' |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2715 \(use XON/XOFF software flowcontrol). If FLOWCONTROL is not given, no |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2716 flowcontrol is used. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2717 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2718 `serial-process-configure' is called by `make-serial-process' for the |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2719 initial configuration of the serial port. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2720 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2721 Examples: |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2722 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2723 \(serial-process-configure :process "/dev/ttyS0" :speed 1200) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2724 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2725 \(serial-process-configure |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2726 :buffer "COM1" :stopbits 1 :parity 'odd :flowcontrol 'hw) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2727 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2728 \(serial-process-configure :port "\\\\.\\COM13" :bytesize 7) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2729 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2730 usage: (serial-process-configure &rest ARGS) */) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2731 (nargs, args) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2732 int nargs; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2733 Lisp_Object *args; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2734 { |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2735 struct Lisp_Process *p; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2736 Lisp_Object contact = Qnil; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2737 Lisp_Object proc = Qnil; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2738 struct gcpro gcpro1; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2739 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2740 contact = Flist (nargs, args); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2741 GCPRO1 (contact); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2742 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2743 proc = Fplist_get (contact, QCprocess); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2744 if (NILP (proc)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2745 proc = Fplist_get (contact, QCname); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2746 if (NILP (proc)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2747 proc = Fplist_get (contact, QCbuffer); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2748 if (NILP (proc)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2749 proc = Fplist_get (contact, QCport); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2750 proc = get_process (proc); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2751 p = XPROCESS (proc); |
95900
99342636fa96
(Fserial_process_configure, Fprocess_send_eof):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95884
diff
changeset
|
2752 if (!EQ (p->type, Qserial)) |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2753 error ("Not a serial process"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2754 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2755 if (NILP (Fplist_get (p->childp, QCspeed))) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2756 { |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2757 UNGCPRO; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2758 return Qnil; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2759 } |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2760 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2761 serial_configure (p, contact); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2762 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2763 UNGCPRO; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2764 return Qnil; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2765 } |
96833
c06568fd3844
* s/usg5-4.h (LIBS_SYSTEM): Remove, system for which this was
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96774
diff
changeset
|
2766 |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2767 /* Used by make-serial-process to recover from errors. */ |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2768 Lisp_Object make_serial_process_unwind (Lisp_Object proc) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2769 { |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2770 if (!PROCESSP (proc)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2771 abort (); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2772 remove_process (proc); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2773 return Qnil; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2774 } |
96833
c06568fd3844
* s/usg5-4.h (LIBS_SYSTEM): Remove, system for which this was
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96774
diff
changeset
|
2775 |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2776 DEFUN ("make-serial-process", Fmake_serial_process, Smake_serial_process, |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2777 0, MANY, 0, |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2778 doc: /* Create and return a serial port process. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2779 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2780 In Emacs, serial port connections are represented by process objects, |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2781 so input and output work as for subprocesses, and `delete-process' |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2782 closes a serial port connection. However, a serial process has no |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2783 process id, it cannot be signaled, and the status codes are different |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2784 from normal processes. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2785 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2786 `make-serial-process' creates a process and a buffer, on which you |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2787 probably want to use `process-send-string'. Try \\[serial-term] for |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2788 an interactive terminal. See below for examples. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2789 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2790 Arguments are specified as keyword/argument pairs. The following |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2791 arguments are defined: |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2792 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2793 :port PORT -- (mandatory) PORT is the path or name of the serial port. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2794 For example, this could be "/dev/ttyS0" on Unix. On Windows, this |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2795 could be "COM1", or "\\\\.\\COM10" for ports higher than COM9 (double |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2796 the backslashes in strings). |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2797 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2798 :speed SPEED -- (mandatory) is handled by `serial-process-configure', |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2799 which is called by `make-serial-process'. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2800 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2801 :name NAME -- NAME is the name of the process. If NAME is not given, |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2802 the value of PORT is used. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2803 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2804 :buffer BUFFER -- BUFFER is the buffer (or buffer-name) to associate |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2805 with the process. Process output goes at the end of that buffer, |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2806 unless you specify an output stream or filter function to handle the |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2807 output. If BUFFER is not given, the value of NAME is used. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2808 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2809 :coding CODING -- If CODING is a symbol, it specifies the coding |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2810 system used for both reading and writing for this process. If CODING |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2811 is a cons (DECODING . ENCODING), DECODING is used for reading, and |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2812 ENCODING is used for writing. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2813 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2814 :noquery BOOL -- When exiting Emacs, query the user if BOOL is nil and |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2815 the process is running. If BOOL is not given, query before exiting. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2816 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2817 :stop BOOL -- Start process in the `stopped' state if BOOL is non-nil. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2818 In the stopped state, a serial process does not accept incoming data, |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2819 but you can send outgoing data. The stopped state is cleared by |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2820 `continue-process' and set by `stop-process'. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2821 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2822 :filter FILTER -- Install FILTER as the process filter. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2823 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2824 :sentinel SENTINEL -- Install SENTINEL as the process sentinel. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2825 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2826 :plist PLIST -- Install PLIST as the initial plist of the process. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2827 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2828 :speed |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2829 :bytesize |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2830 :parity |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2831 :stopbits |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2832 :flowcontrol |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2833 -- These arguments are handled by `serial-process-configure', which is |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2834 called by `make-serial-process'. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2835 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2836 The original argument list, possibly modified by later configuration, |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2837 is available via the function `process-contact'. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2838 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2839 Examples: |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2840 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2841 \(make-serial-process :port "/dev/ttyS0" :speed 9600) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2842 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2843 \(make-serial-process :port "COM1" :speed 115200 :stopbits 2) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2844 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2845 \(make-serial-process :port "\\\\.\\COM13" :speed 1200 :bytesize 7 :parity 'odd) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2846 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2847 \(make-serial-process :port "/dev/tty.BlueConsole-SPP-1" :speed nil) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2848 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2849 usage: (make-serial-process &rest ARGS) */) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2850 (nargs, args) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2851 int nargs; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2852 Lisp_Object *args; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2853 { |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2854 int fd = -1; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2855 Lisp_Object proc, contact, port; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2856 struct Lisp_Process *p; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2857 struct gcpro gcpro1; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2858 Lisp_Object name, buffer; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2859 Lisp_Object tem, val; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2860 int specpdl_count = -1; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2861 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2862 if (nargs == 0) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2863 return Qnil; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2864 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2865 contact = Flist (nargs, args); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2866 GCPRO1 (contact); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2867 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2868 port = Fplist_get (contact, QCport); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2869 if (NILP (port)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2870 error ("No port specified"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2871 CHECK_STRING (port); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2872 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2873 if (NILP (Fplist_member (contact, QCspeed))) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2874 error (":speed not specified"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2875 if (!NILP (Fplist_get (contact, QCspeed))) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2876 CHECK_NUMBER (Fplist_get (contact, QCspeed)); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2877 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2878 name = Fplist_get (contact, QCname); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2879 if (NILP (name)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2880 name = port; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2881 CHECK_STRING (name); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2882 proc = make_process (name); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2883 specpdl_count = SPECPDL_INDEX (); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2884 record_unwind_protect (make_serial_process_unwind, proc); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2885 p = XPROCESS (proc); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2886 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2887 fd = serial_open ((char*) SDATA (port)); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2888 p->infd = fd; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2889 p->outfd = fd; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2890 if (fd > max_process_desc) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2891 max_process_desc = fd; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2892 chan_process[fd] = proc; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2893 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2894 buffer = Fplist_get (contact, QCbuffer); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2895 if (NILP (buffer)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2896 buffer = name; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2897 buffer = Fget_buffer_create (buffer); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2898 p->buffer = buffer; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2899 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2900 p->childp = contact; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2901 p->plist = Fcopy_sequence (Fplist_get (contact, QCplist)); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2902 p->type = Qserial; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2903 p->sentinel = Fplist_get (contact, QCsentinel); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2904 p->filter = Fplist_get (contact, QCfilter); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2905 p->log = Qnil; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2906 if (tem = Fplist_get (contact, QCnoquery), !NILP (tem)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2907 p->kill_without_query = 1; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2908 if (tem = Fplist_get (contact, QCstop), !NILP (tem)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2909 p->command = Qt; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2910 p->pty_flag = 0; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2911 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2912 if (!EQ (p->command, Qt)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2913 { |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2914 FD_SET (fd, &input_wait_mask); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2915 FD_SET (fd, &non_keyboard_wait_mask); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2916 } |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2917 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2918 if (BUFFERP (buffer)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2919 { |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2920 set_marker_both (p->mark, buffer, |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2921 BUF_ZV (XBUFFER (buffer)), |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2922 BUF_ZV_BYTE (XBUFFER (buffer))); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2923 } |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2924 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2925 tem = Fplist_member (contact, QCcoding); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2926 if (!NILP (tem) && (!CONSP (tem) || !CONSP (XCDR (tem)))) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2927 tem = Qnil; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2928 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2929 val = Qnil; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2930 if (!NILP (tem)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2931 { |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2932 val = XCAR (XCDR (tem)); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2933 if (CONSP (val)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2934 val = XCAR (val); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2935 } |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2936 else if (!NILP (Vcoding_system_for_read)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2937 val = Vcoding_system_for_read; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2938 else if ((!NILP (buffer) && NILP (XBUFFER (buffer)->enable_multibyte_characters)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2939 || (NILP (buffer) && NILP (buffer_defaults.enable_multibyte_characters))) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2940 val = Qnil; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2941 p->decode_coding_system = val; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2942 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2943 val = Qnil; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2944 if (!NILP (tem)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2945 { |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2946 val = XCAR (XCDR (tem)); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2947 if (CONSP (val)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2948 val = XCDR (val); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2949 } |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2950 else if (!NILP (Vcoding_system_for_write)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2951 val = Vcoding_system_for_write; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2952 else if ((!NILP (buffer) && NILP (XBUFFER (buffer)->enable_multibyte_characters)) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2953 || (NILP (buffer) && NILP (buffer_defaults.enable_multibyte_characters))) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2954 val = Qnil; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2955 p->encode_coding_system = val; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2956 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2957 setup_process_coding_systems (proc); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2958 p->decoding_buf = make_uninit_string (0); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2959 p->decoding_carryover = 0; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2960 p->encoding_buf = make_uninit_string (0); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2961 p->inherit_coding_system_flag |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2962 = !(!NILP (tem) || NILP (buffer) || !inherit_process_coding_system); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2963 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2964 Fserial_process_configure(nargs, args); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2965 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2966 specpdl_ptr = specpdl + specpdl_count; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2967 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2968 UNGCPRO; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2969 return proc; |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2970 } |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2971 #endif /* HAVE_SERIAL */ |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2972 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2973 /* 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
|
2974 exactly like a normal process when reading and writing. Primary |
578 | 2975 differences are in status display and process deletion. A network |
2976 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
|
2977 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
|
2978 |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2979 DEFUN ("make-network-process", Fmake_network_process, Smake_network_process, |
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2980 0, MANY, 0, |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2981 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
|
2982 |
43995
110955214222
(Fmake_network_process): Remove unused variable `sa'.
Pavel Janík <Pavel@Janik.cz>
parents:
43968
diff
changeset
|
2983 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
|
2984 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
|
2985 a network connection. However, a network process has no process id, |
63615
be4c8c1258c1
(Fmake_network_process): Fix spellings.
Juanma Barranquero <lekktu@gmail.com>
parents:
63278
diff
changeset
|
2986 it cannot be signaled, and the status codes are different from normal |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2987 processes. |
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 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
|
2990 arguments are defined: |
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 :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
|
2993 to make it unique. |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2994 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2995 :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
|
2996 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
|
2997 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
|
2998 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
|
2999 with any buffer. |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3000 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3001 :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
|
3002 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
|
3003 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
|
3004 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
|
3005 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3006 :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
|
3007 integer specifying a port number to connect to. If SERVICE is t, |
78840
b0f2d245629d
(Fmake_network_process): Doc fix.
Glenn Morris <rgm@gnu.org>
parents:
78501
diff
changeset
|
3008 a random port number is selected for the server. (If Emacs was |
b0f2d245629d
(Fmake_network_process): Doc fix.
Glenn Morris <rgm@gnu.org>
parents:
78501
diff
changeset
|
3009 compiled with getaddrinfo, a port number can also be specified as a |
b0f2d245629d
(Fmake_network_process): Doc fix.
Glenn Morris <rgm@gnu.org>
parents:
78501
diff
changeset
|
3010 string, e.g. "80", as well as an integer. This is not portable.) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3011 |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3012 :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
|
3013 stream type connection, `datagram' creates a datagram type connection. |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3014 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3015 :family FAMILY -- FAMILY is the address (and protocol) family for the |
68008 | 3016 service specified by HOST and SERVICE. The default (nil) is to use |
3017 whatever address family (IPv4 or IPv6) that is defined for the host | |
3018 and port number specified by HOST and SERVICE. Other address families | |
3019 supported are: | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3020 local -- for a local (i.e. UNIX) address specified by SERVICE. |
68008 | 3021 ipv4 -- use IPv4 address family only. |
3022 ipv6 -- use IPv6 address family only. | |
43968
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 :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
|
3025 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
|
3026 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
|
3027 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3028 :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
|
3029 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
|
3030 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
|
3031 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
|
3032 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
|
3033 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3034 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
|
3035 - 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
|
3036 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
|
3037 - 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
|
3038 local address space. |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3039 - 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
|
3040 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
|
3041 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
|
3042 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
|
3043 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
|
3044 |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3045 :coding CODING -- If CODING is a symbol, it specifies the coding |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3046 system used for both reading and writing for this process. If CODING |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3047 is a cons (DECODING . ENCODING), DECODING is used for reading, and |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3048 ENCODING is used for writing. |
43968
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 :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
|
3051 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
|
3052 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
|
3053 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
|
3054 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
|
3055 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3056 :noquery BOOL -- Query the user unless BOOL is non-nil, and process is |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
3057 running when Emacs is exited. |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3058 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3059 :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
|
3060 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
|
3061 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
|
3062 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
|
3063 `stop-process'. |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3064 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3065 :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
|
3066 |
49680 | 3067 :filter-multibyte BOOL -- If BOOL is non-nil, strings given to the |
3068 process filter are multibyte, otherwise they are unibyte. | |
78501 | 3069 If this keyword is not specified, the strings are multibyte if |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
3070 `default-enable-multibyte-characters' is non-nil. |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
3071 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3072 :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
|
3073 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3074 :log LOG -- Install LOG as the server process log function. This |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3075 function is called when the server accepts a network connection from a |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3076 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
|
3077 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
|
3078 and MESSAGE is a string. |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3079 |
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
3080 :plist PLIST -- Install PLIST as the new process' initial plist. |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3081 |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3082 :server QLEN -- if QLEN is non-nil, create a server process for the |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3083 specified FAMILY, SERVICE, and connection type (stream or datagram). |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3084 If QLEN is an integer, it is used as the max. length of the server's |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3085 pending connection queue (also known as the backlog); the default |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3086 queue length is 5. Default is to create a client process. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3087 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3088 The following network options can be specified for this connection: |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3089 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3090 :broadcast BOOL -- Allow send and receive of datagram broadcasts. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3091 :dontroute BOOL -- Only send to directly connected hosts. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3092 :keepalive BOOL -- Send keep-alive messages on network stream. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3093 :linger BOOL or TIMEOUT -- Send queued messages before closing. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3094 :oobinline BOOL -- Place out-of-band data in receive data stream. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3095 :priority INT -- Set protocol defined priority for sent packets. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3096 :reuseaddr BOOL -- Allow reusing a recently used local address |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3097 (this is allowed by default for a server process). |
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
3098 :bindtodevice NAME -- bind to interface NAME. Using this may require |
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
3099 special privileges on some systems. |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3100 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3101 Consult the relevant system programmer's manual pages for more |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3102 information on using these options. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3103 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3104 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3105 A server process will listen for and accept connections from clients. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3106 When a client connection is accepted, a new network process is created |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3107 for the connection with the following parameters: |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3108 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3109 - 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
|
3110 process' NAME and a client identification string. |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3111 - 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
|
3112 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
|
3113 created buffer named after the server process' BUFFER name or process |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3114 NAME concatenated with the client identification string. |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3115 - 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
|
3116 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
|
3117 - 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
|
3118 addressing information (typically an IP address and a port number). |
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
3119 - The client process' plist is initialized from the server's plist. |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3120 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3121 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
|
3122 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
|
3123 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
|
3124 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
|
3125 |
49142
8dca38bc0261
(Fset_process_contact): New function.
Kim F. Storm <storm@cua.dk>
parents:
49119
diff
changeset
|
3126 The original argument list, modified with the actual connection |
8dca38bc0261
(Fset_process_contact): New function.
Kim F. Storm <storm@cua.dk>
parents:
49119
diff
changeset
|
3127 information, is available via the `process-contact' function. |
8dca38bc0261
(Fset_process_contact): New function.
Kim F. Storm <storm@cua.dk>
parents:
49119
diff
changeset
|
3128 |
43995
110955214222
(Fmake_network_process): Remove unused variable `sa'.
Pavel Janík <Pavel@Janik.cz>
parents:
43968
diff
changeset
|
3129 usage: (make-network-process &rest ARGS) */) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3130 (nargs, args) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3131 int nargs; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3132 Lisp_Object *args; |
578 | 3133 { |
3134 Lisp_Object proc; | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3135 Lisp_Object contact; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3136 struct Lisp_Process *p; |
32032
633b826a56f3
(Fopen_network_stream) [HAVE_GETADDRINFO]: Use
Gerd Moellmann <gerd@gnu.org>
parents:
31806
diff
changeset
|
3137 #ifdef HAVE_GETADDRINFO |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3138 struct addrinfo ai, *res, *lres; |
68008 | 3139 struct addrinfo hints; |
3140 char *portstring, portbuf[128]; | |
32032
633b826a56f3
(Fopen_network_stream) [HAVE_GETADDRINFO]: Use
Gerd Moellmann <gerd@gnu.org>
parents:
31806
diff
changeset
|
3141 #else /* HAVE_GETADDRINFO */ |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3142 struct _emacs_addrinfo |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3143 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3144 int ai_family; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3145 int ai_socktype; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3146 int ai_protocol; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3147 int ai_addrlen; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3148 struct sockaddr *ai_addr; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3149 struct _emacs_addrinfo *ai_next; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3150 } ai, *res, *lres; |
25262
ccf83ed7326a
(Fopen_network_stream): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents:
25248
diff
changeset
|
3151 #endif /* HAVE_GETADDRINFO */ |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3152 struct sockaddr_in address_in; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3153 #ifdef HAVE_LOCAL_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3154 struct sockaddr_un address_un; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3155 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3156 int port; |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3157 int ret = 0; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3158 int xerrno = 0; |
25262
ccf83ed7326a
(Fopen_network_stream): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents:
25248
diff
changeset
|
3159 int s = -1, outch, inch; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3160 struct gcpro gcpro1; |
46293
1fb8f75062c6
Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents:
45410
diff
changeset
|
3161 int count = SPECPDL_INDEX (); |
25705
1f109108fa7e
(Fopen_network_stream): Avoid socket decriptor leak.
Andreas Schwab <schwab@suse.de>
parents:
25645
diff
changeset
|
3162 int count1; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3163 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
|
3164 Lisp_Object tem; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3165 Lisp_Object name, buffer, host, service, address; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3166 Lisp_Object filter, sentinel; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3167 int is_non_blocking_client = 0; |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3168 int is_server = 0, backlog = 5; |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3169 int socktype; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3170 int family = -1; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3171 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3172 if (nargs == 0) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3173 return Qnil; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3174 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3175 /* 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
|
3176 contact = Flist (nargs, args); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3177 GCPRO1 (contact); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3178 |
15355
6bb377ef707f
(Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents:
15092
diff
changeset
|
3179 #ifdef WINDOWSNT |
6bb377ef707f
(Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents:
15092
diff
changeset
|
3180 /* Ensure socket support is loaded if available. */ |
6bb377ef707f
(Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents:
15092
diff
changeset
|
3181 init_winsock (TRUE); |
6bb377ef707f
(Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents:
15092
diff
changeset
|
3182 #endif |
6bb377ef707f
(Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents:
15092
diff
changeset
|
3183 |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3184 /* :type TYPE (nil: stream, datagram */ |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3185 tem = Fplist_get (contact, QCtype); |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3186 if (NILP (tem)) |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3187 socktype = SOCK_STREAM; |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3188 #ifdef DATAGRAM_SOCKETS |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3189 else if (EQ (tem, Qdatagram)) |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3190 socktype = SOCK_DGRAM; |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3191 #endif |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3192 else |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3193 error ("Unsupported connection type"); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3194 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3195 /* :server BOOL */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3196 tem = Fplist_get (contact, QCserver); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3197 if (!NILP (tem)) |
25248
f0fc8443bdbb
(Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents:
25129
diff
changeset
|
3198 { |
45099
8a33d836b6fb
(Fmake_network_process): Only support server sockets
Jason Rumney <jasonr@gnu.org>
parents:
45005
diff
changeset
|
3199 /* 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
|
3200 not available, since a blocked Emacs is not useful. */ |
96732
1e0b67e40d48
* systty.h: Remove code for Aix on 386, unsupported platform.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96675
diff
changeset
|
3201 #if !defined(O_NONBLOCK) && !defined(O_NDELAY) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3202 error ("Network servers not supported"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3203 #else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3204 is_server = 1; |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3205 if (INTEGERP (tem)) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3206 backlog = XINT (tem); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3207 #endif |
25248
f0fc8443bdbb
(Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents:
25129
diff
changeset
|
3208 } |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3209 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3210 /* 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
|
3211 QCaddress = is_server ? QClocal : QCremote; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3212 |
74946 | 3213 /* :nowait BOOL */ |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3214 if (!is_server && socktype == SOCK_STREAM |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3215 && (tem = Fplist_get (contact, QCnowait), !NILP (tem))) |
25248
f0fc8443bdbb
(Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents:
25129
diff
changeset
|
3216 { |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3217 #ifndef NON_BLOCKING_CONNECT |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3218 error ("Non-blocking connect not supported"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3219 #else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3220 is_non_blocking_client = 1; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3221 #endif |
25248
f0fc8443bdbb
(Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents:
25129
diff
changeset
|
3222 } |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3223 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3224 name = Fplist_get (contact, QCname); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3225 buffer = Fplist_get (contact, QCbuffer); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3226 filter = Fplist_get (contact, QCfilter); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3227 sentinel = Fplist_get (contact, QCsentinel); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3228 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3229 CHECK_STRING (name); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3230 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3231 /* 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
|
3232 ai.ai_socktype = socktype; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3233 ai.ai_protocol = 0; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3234 ai.ai_next = NULL; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3235 res = &ai; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3236 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3237 /* :local ADDRESS or :remote ADDRESS */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3238 address = Fplist_get (contact, QCaddress); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3239 if (!NILP (address)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3240 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3241 host = service = Qnil; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3242 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3243 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
|
3244 error ("Malformed :address"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3245 ai.ai_family = family; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3246 ai.ai_addr = alloca (ai.ai_addrlen); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3247 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
|
3248 goto open_socket; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3249 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3250 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3251 /* :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
|
3252 tem = Fplist_get (contact, QCfamily); |
68008 | 3253 if (NILP (tem)) |
3254 { | |
68041
b7409cbd6d99
(Fmake_network_process): Use AF_INET instead of
Kim F. Storm <storm@cua.dk>
parents:
68022
diff
changeset
|
3255 #if defined(HAVE_GETADDRINFO) && defined(AF_INET6) |
68008 | 3256 family = AF_UNSPEC; |
3257 #else | |
3258 family = AF_INET; | |
3259 #endif | |
3260 } | |
3261 #ifdef HAVE_LOCAL_SOCKETS | |
3262 else if (EQ (tem, Qlocal)) | |
3263 family = AF_LOCAL; | |
3264 #endif | |
3265 #ifdef AF_INET6 | |
3266 else if (EQ (tem, Qipv6)) | |
3267 family = AF_INET6; | |
3268 #endif | |
3269 else if (EQ (tem, Qipv4)) | |
3270 family = AF_INET; | |
3271 else if (INTEGERP (tem)) | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3272 family = XINT (tem); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3273 else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3274 error ("Unknown address family"); |
68008 | 3275 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3276 ai.ai_family = family; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3277 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3278 /* :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
|
3279 service = Fplist_get (contact, QCservice); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3280 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3281 #ifdef HAVE_LOCAL_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3282 if (family == AF_LOCAL) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3283 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3284 /* Host is not used. */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3285 host = Qnil; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3286 CHECK_STRING (service); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3287 bzero (&address_un, sizeof address_un); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3288 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
|
3289 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
|
3290 ai.ai_addr = (struct sockaddr *) &address_un; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3291 ai.ai_addrlen = sizeof address_un; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3292 goto open_socket; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3293 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3294 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3295 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3296 /* :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
|
3297 host = Fplist_get (contact, QChost); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3298 if (!NILP (host)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3299 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3300 if (EQ (host, Qlocal)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3301 host = build_string ("localhost"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3302 CHECK_STRING (host); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3303 } |
578 | 3304 |
13777
5e0cbd5fcb46
(Fopen_network_stream): Call bind_polling_period earlier.
Karl Heuer <kwzh@gnu.org>
parents:
13709
diff
changeset
|
3305 /* 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
|
3306 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
|
3307 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
|
3308 #ifdef POLL_FOR_INPUT |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3309 if (socktype == SOCK_STREAM) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3310 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3311 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
|
3312 bind_polling_period (10); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3313 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3314 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3315 |
25248
f0fc8443bdbb
(Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents:
25129
diff
changeset
|
3316 #ifdef HAVE_GETADDRINFO |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3317 /* 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
|
3318 Otherwise, use getservbyname to lookup the service. */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3319 if (!NILP (host)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3320 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3321 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3322 /* 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
|
3323 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
|
3324 if (EQ (service, Qt)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3325 portstring = "0"; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3326 else if (INTEGERP (service)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3327 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3328 sprintf (portbuf, "%ld", (long) XINT (service)); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3329 portstring = portbuf; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3330 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3331 else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3332 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3333 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
|
3334 portstring = SDATA (service); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3335 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3336 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3337 immediate_quit = 1; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3338 QUIT; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3339 memset (&hints, 0, sizeof (hints)); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3340 hints.ai_flags = 0; |
68008 | 3341 hints.ai_family = family; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3342 hints.ai_socktype = socktype; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3343 hints.ai_protocol = 0; |
85362
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3344 |
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3345 #ifdef HAVE_RES_INIT |
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3346 res_init (); |
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3347 #endif |
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3348 |
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46314
diff
changeset
|
3349 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
|
3350 if (ret) |
32074
a889f9fc59a7
(Fopen_network_stream): Use HAVE_GAI_STRERROR.
Dave Love <fx@gnu.org>
parents:
32032
diff
changeset
|
3351 #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
|
3352 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
|
3353 #else |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
3354 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
|
3355 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3356 immediate_quit = 0; |
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 goto open_socket; |
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 #endif /* HAVE_GETADDRINFO */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3361 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3362 /* 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
|
3363 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
|
3364 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3365 if (EQ (service, Qt)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3366 port = 0; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3367 else if (INTEGERP (service)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3368 port = htons ((unsigned short) XINT (service)); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3369 else |
8287
97c2535b7f37
(Fopen_network_stream): Retry gethostbyname after TRY_AGAIN failure.
Richard M. Stallman <rms@gnu.org>
parents:
8231
diff
changeset
|
3370 { |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3371 struct servent *svc_info; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3372 CHECK_STRING (service); |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3373 svc_info = getservbyname (SDATA (service), |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3374 (socktype == SOCK_DGRAM ? "udp" : "tcp")); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3375 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
|
3376 error ("Unknown service: %s", SDATA (service)); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3377 port = svc_info->s_port; |
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 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3380 bzero (&address_in, sizeof address_in); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3381 address_in.sin_family = family; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3382 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
|
3383 address_in.sin_port = port; |
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 #ifndef HAVE_GETADDRINFO |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3386 if (!NILP (host)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3387 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3388 struct hostent *host_info_ptr; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3389 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3390 /* gethostbyname may fail with TRY_AGAIN, but we don't honour that, |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
3391 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
|
3392 immediate_quit = 1; |
849458c13c0c
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14736
diff
changeset
|
3393 QUIT; |
85362
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3394 |
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3395 #ifdef HAVE_RES_INIT |
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3396 res_init (); |
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3397 #endif |
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3398 |
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46314
diff
changeset
|
3399 host_info_ptr = gethostbyname (SDATA (host)); |
14758
849458c13c0c
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14736
diff
changeset
|
3400 immediate_quit = 0; |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3401 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3402 if (host_info_ptr) |
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 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
|
3405 host_info_ptr->h_length); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3406 family = host_info_ptr->h_addrtype; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3407 address_in.sin_family = family; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3408 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3409 else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3410 /* 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
|
3411 { |
91702
b7a5a89054dc
* configure.in (LIBX11_MACHINE, HAVE_XFREE386): Remove code
Dan Nicolaescu <dann@ics.uci.edu>
parents:
91551
diff
changeset
|
3412 unsigned long 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
|
3413 numeric_addr = inet_addr ((char *) SDATA (host)); |
91702
b7a5a89054dc
* configure.in (LIBX11_MACHINE, HAVE_XFREE386): Remove code
Dan Nicolaescu <dann@ics.uci.edu>
parents:
91551
diff
changeset
|
3414 if (numeric_addr == -1) |
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46314
diff
changeset
|
3415 error ("Unknown host \"%s\"", SDATA (host)); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3416 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3417 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
|
3418 sizeof (address_in.sin_addr)); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3419 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3420 |
8287
97c2535b7f37
(Fopen_network_stream): Retry gethostbyname after TRY_AGAIN failure.
Richard M. Stallman <rms@gnu.org>
parents:
8231
diff
changeset
|
3421 } |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3422 #endif /* not HAVE_GETADDRINFO */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3423 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3424 ai.ai_family = family; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3425 ai.ai_addr = (struct sockaddr *) &address_in; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3426 ai.ai_addrlen = sizeof address_in; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3427 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3428 open_socket: |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3429 |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3430 /* 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
|
3431 count1 = SPECPDL_INDEX (); |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3432 s = -1; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3433 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3434 for (lres = res; lres; lres = lres->ai_next) |
578 | 3435 { |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3436 int optn, optbits; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3437 |
58072
4ebc52bf6429
(Fmake_network_process): Remove kludge for interrupted
Kim F. Storm <storm@cua.dk>
parents:
57840
diff
changeset
|
3438 retry_connect: |
4ebc52bf6429
(Fmake_network_process): Remove kludge for interrupted
Kim F. Storm <storm@cua.dk>
parents:
57840
diff
changeset
|
3439 |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3440 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
|
3441 if (s < 0) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3442 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3443 xerrno = errno; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3444 continue; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3445 } |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3446 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3447 #ifdef DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3448 if (!is_server && socktype == SOCK_DGRAM) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3449 break; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3450 #endif /* DATAGRAM_SOCKETS */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3451 |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3452 #ifdef NON_BLOCKING_CONNECT |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3453 if (is_non_blocking_client) |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3454 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3455 #ifdef O_NONBLOCK |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3456 ret = fcntl (s, F_SETFL, O_NONBLOCK); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3457 #else |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3458 ret = fcntl (s, F_SETFL, O_NDELAY); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3459 #endif |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3460 if (ret < 0) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3461 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3462 xerrno = errno; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3463 emacs_close (s); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3464 s = -1; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3465 continue; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3466 } |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3467 } |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3468 #endif |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3469 |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3470 /* Make us close S if quit. */ |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3471 record_unwind_protect (close_file_unwind, make_number (s)); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3472 |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3473 /* Parse network options in the arg list. |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3474 We simply ignore anything which isn't a known option (including other keywords). |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
3475 An error is signaled if setting a known option fails. */ |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3476 for (optn = optbits = 0; optn < nargs-1; optn += 2) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3477 optbits |= set_socket_option (s, args[optn], args[optn+1]); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3478 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3479 if (is_server) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3480 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3481 /* Configure as a server socket. */ |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3482 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3483 /* SO_REUSEADDR = 1 is default for server sockets; must specify |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3484 explicit :reuseaddr key to override this. */ |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3485 #ifdef HAVE_LOCAL_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3486 if (family != AF_LOCAL) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3487 #endif |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3488 if (!(optbits & (1 << OPIX_REUSEADDR))) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3489 { |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3490 int optval = 1; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3491 if (setsockopt (s, SOL_SOCKET, SO_REUSEADDR, &optval, sizeof optval)) |
53072
8787289602d1
Remove period at end of error message.
Jan Djärv <jan.h.d@swipnet.se>
parents:
52633
diff
changeset
|
3492 report_file_error ("Cannot set reuse option on server socket", Qnil); |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3493 } |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3494 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3495 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
|
3496 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
|
3497 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3498 #ifdef HAVE_GETSOCKNAME |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3499 if (EQ (service, Qt)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3500 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3501 struct sockaddr_in sa1; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3502 int len1 = sizeof (sa1); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3503 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
|
3504 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3505 ((struct sockaddr_in *)(lres->ai_addr))->sin_port = sa1.sin_port; |
49119
938f153410ae
(Fmake_network_process): Convert new port number
Kim F. Storm <storm@cua.dk>
parents:
49114
diff
changeset
|
3506 service = make_number (ntohs (sa1.sin_port)); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3507 contact = Fplist_put (contact, QCservice, service); |
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 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3510 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3511 |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3512 if (socktype == SOCK_STREAM && listen (s, backlog)) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3513 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
|
3514 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3515 break; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3516 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3517 |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3518 immediate_quit = 1; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3519 QUIT; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3520 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3521 /* This turns off all alarm-based interrupts; the |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3522 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
|
3523 short-interval ones off, especially if interrupt_input is |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3524 set. |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3525 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3526 It'd be nice to be able to control the connect timeout |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3527 though. Would non-blocking connect calls be portable? |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3528 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3529 This used to be conditioned by HAVE_GETADDRINFO. Why? */ |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3530 |
43642
bfd9fa0143d9
(Fopen_network_stream): Always call turn_on_atimers around connect.
Kim F. Storm <storm@cua.dk>
parents:
43617
diff
changeset
|
3531 turn_on_atimers (0); |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3532 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3533 ret = connect (s, lres->ai_addr, lres->ai_addrlen); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3534 xerrno = errno; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3535 |
43642
bfd9fa0143d9
(Fopen_network_stream): Always call turn_on_atimers around connect.
Kim F. Storm <storm@cua.dk>
parents:
43617
diff
changeset
|
3536 turn_on_atimers (1); |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3537 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3538 if (ret == 0 || xerrno == EISCONN) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3539 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3540 /* The unwind-protect will be discarded afterwards. |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3541 Likewise for immediate_quit. */ |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3542 break; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3543 } |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3544 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3545 #ifdef NON_BLOCKING_CONNECT |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3546 #ifdef EINPROGRESS |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3547 if (is_non_blocking_client && xerrno == EINPROGRESS) |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3548 break; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3549 #else |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3550 #ifdef EWOULDBLOCK |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3551 if (is_non_blocking_client && xerrno == EWOULDBLOCK) |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3552 break; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3553 #endif |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3554 #endif |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3555 #endif |
7220
a33eb16cab9d
(Fopen_network_stream): Retry the connect if EADDRINUSE. Ignore EISCONN.
Richard M. Stallman <rms@gnu.org>
parents:
7157
diff
changeset
|
3556 |
14671
0493e857a13b
(Fopen_network_stream): Set immediate_quit for the connect.
Richard M. Stallman <rms@gnu.org>
parents:
14613
diff
changeset
|
3557 immediate_quit = 0; |
0493e857a13b
(Fopen_network_stream): Set immediate_quit for the connect.
Richard M. Stallman <rms@gnu.org>
parents:
14613
diff
changeset
|
3558 |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3559 /* Discard the unwind protect closing S. */ |
25705
1f109108fa7e
(Fopen_network_stream): Avoid socket decriptor leak.
Andreas Schwab <schwab@suse.de>
parents:
25645
diff
changeset
|
3560 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
|
3561 emacs_close (s); |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3562 s = -1; |
58072
4ebc52bf6429
(Fmake_network_process): Remove kludge for interrupted
Kim F. Storm <storm@cua.dk>
parents:
57840
diff
changeset
|
3563 |
4ebc52bf6429
(Fmake_network_process): Remove kludge for interrupted
Kim F. Storm <storm@cua.dk>
parents:
57840
diff
changeset
|
3564 if (xerrno == EINTR) |
4ebc52bf6429
(Fmake_network_process): Remove kludge for interrupted
Kim F. Storm <storm@cua.dk>
parents:
57840
diff
changeset
|
3565 goto retry_connect; |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3566 } |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3567 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3568 if (s >= 0) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3569 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3570 #ifdef DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3571 if (socktype == SOCK_DGRAM) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3572 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3573 if (datagram_address[s].sa) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3574 abort (); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3575 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
|
3576 datagram_address[s].len = lres->ai_addrlen; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3577 if (is_server) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3578 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3579 Lisp_Object remote; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3580 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
|
3581 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
|
3582 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3583 int rfamily, rlen; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3584 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
|
3585 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
|
3586 conv_lisp_to_sockaddr (rfamily, remote, |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3587 datagram_address[s].sa, rlen); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3588 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3589 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3590 else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3591 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
|
3592 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3593 #endif |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3594 contact = Fplist_put (contact, QCaddress, |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3595 conv_sockaddr_to_lisp (lres->ai_addr, lres->ai_addrlen)); |
49111
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3596 #ifdef HAVE_GETSOCKNAME |
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3597 if (!is_server) |
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3598 { |
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3599 struct sockaddr_in sa1; |
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3600 int len1 = sizeof (sa1); |
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3601 if (getsockname (s, (struct sockaddr *)&sa1, &len1) == 0) |
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3602 contact = Fplist_put (contact, QClocal, |
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3603 conv_sockaddr_to_lisp (&sa1, len1)); |
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3604 } |
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3605 #endif |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3606 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3607 |
76626
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3608 immediate_quit = 0; |
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3609 |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3610 #ifdef HAVE_GETADDRINFO |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3611 if (res != &ai) |
76626
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3612 { |
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3613 BLOCK_INPUT; |
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3614 freeaddrinfo (res); |
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3615 UNBLOCK_INPUT; |
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3616 } |
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3617 #endif |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3618 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3619 /* 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
|
3620 specpdl_ptr = specpdl + count1; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3621 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3622 /* Unwind bind_polling_period and request_sigio. */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3623 unbind_to (count, Qnil); |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3624 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3625 if (s < 0) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3626 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3627 /* 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
|
3628 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
|
3629 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
|
3630 better. */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3631 if (is_non_blocking_client) |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3632 return Qnil; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3633 |
578 | 3634 errno = xerrno; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3635 if (is_server) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3636 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
|
3637 else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3638 report_file_error ("make client process failed", contact); |
578 | 3639 } |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3640 |
578 | 3641 inch = s; |
17247
351006378b51
(Fopen_network_stream): Use same socket for in and out.
Richard M. Stallman <rms@gnu.org>
parents:
17224
diff
changeset
|
3642 outch = s; |
578 | 3643 |
3644 if (!NILP (buffer)) | |
3645 buffer = Fget_buffer_create (buffer); | |
3646 proc = make_process (name); | |
3647 | |
3648 chan_process[inch] = proc; | |
3649 | |
3650 #ifdef O_NONBLOCK | |
3651 fcntl (inch, F_SETFL, O_NONBLOCK); | |
3652 #else | |
3653 #ifdef O_NDELAY | |
3654 fcntl (inch, F_SETFL, O_NDELAY); | |
3655 #endif | |
3656 #endif | |
3657 | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3658 p = XPROCESS (proc); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3659 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3660 p->childp = contact; |
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
3661 p->plist = Fcopy_sequence (Fplist_get (contact, QCplist)); |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
3662 p->type = Qnetwork; |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3663 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3664 p->buffer = buffer; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3665 p->sentinel = sentinel; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3666 p->filter = filter; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3667 p->log = Fplist_get (contact, QClog); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3668 if (tem = Fplist_get (contact, QCnoquery), !NILP (tem)) |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
3669 p->kill_without_query = 1; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3670 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
|
3671 p->command = Qt; |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
3672 p->pid = 0; |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
3673 p->infd = inch; |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
3674 p->outfd = outch; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3675 if (is_server && socktype == SOCK_STREAM) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3676 p->status = Qlisten; |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3677 |
69151
08c9c1760e1c
(Fmake_network_process): Init the process's mark.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68651
diff
changeset
|
3678 /* Make the process marker point into the process buffer (if any). */ |
08c9c1760e1c
(Fmake_network_process): Init the process's mark.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68651
diff
changeset
|
3679 if (BUFFERP (buffer)) |
08c9c1760e1c
(Fmake_network_process): Init the process's mark.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68651
diff
changeset
|
3680 set_marker_both (p->mark, buffer, |
08c9c1760e1c
(Fmake_network_process): Init the process's mark.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68651
diff
changeset
|
3681 BUF_ZV (XBUFFER (buffer)), |
08c9c1760e1c
(Fmake_network_process): Init the process's mark.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68651
diff
changeset
|
3682 BUF_ZV_BYTE (XBUFFER (buffer))); |
08c9c1760e1c
(Fmake_network_process): Init the process's mark.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68651
diff
changeset
|
3683 |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3684 #ifdef NON_BLOCKING_CONNECT |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3685 if (is_non_blocking_client) |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3686 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3687 /* 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
|
3688 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
|
3689 connection. */ |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3690 p->status = Qconnect; |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3691 if (!FD_ISSET (inch, &connect_wait_mask)) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3692 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3693 FD_SET (inch, &connect_wait_mask); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3694 num_pending_connects++; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3695 } |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3696 } |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3697 else |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3698 #endif |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3699 /* 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
|
3700 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
|
3701 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
|
3702 || (EQ (p->status, Qlisten) && NILP (p->command))) |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3703 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3704 FD_SET (inch, &input_wait_mask); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3705 FD_SET (inch, &non_keyboard_wait_mask); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3706 } |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3707 |
7044
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
3708 if (inch > max_process_desc) |
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
3709 max_process_desc = inch; |
578 | 3710 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3711 tem = Fplist_member (contact, QCcoding); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3712 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
|
3713 tem = Qnil; /* No error message (too late!). */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3714 |
22019
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3715 { |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3716 /* 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
|
3717 struct gcpro gcpro1; |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3718 /* 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
|
3719 Lisp_Object coding_systems = Qt; |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3720 Lisp_Object args[5], val; |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3721 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3722 if (!NILP (tem)) |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3723 { |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3724 val = XCAR (XCDR (tem)); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3725 if (CONSP (val)) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3726 val = XCAR (val); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3727 } |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3728 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
|
3729 val = Vcoding_system_for_read; |
25770
3a44b5298cd5
(list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents:
25760
diff
changeset
|
3730 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
|
3731 || (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
|
3732 /* 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
|
3733 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
|
3734 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
|
3735 CR LF. */ |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3736 val = Qnil; |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3737 else |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3738 { |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3739 if (NILP (host) || NILP (service)) |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3740 coding_systems = Qnil; |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3741 else |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3742 { |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3743 args[0] = Qopen_network_stream, args[1] = name, |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3744 args[2] = buffer, args[3] = host, args[4] = service; |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3745 GCPRO1 (proc); |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3746 coding_systems = Ffind_operation_coding_system (5, args); |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3747 UNGCPRO; |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3748 } |
22019
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3749 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
|
3750 val = XCAR (coding_systems); |
22019
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3751 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
|
3752 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
|
3753 else |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3754 val = Qnil; |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3755 } |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3756 p->decode_coding_system = val; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3757 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3758 if (!NILP (tem)) |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3759 { |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3760 val = XCAR (XCDR (tem)); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3761 if (CONSP (val)) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3762 val = XCDR (val); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3763 } |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3764 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
|
3765 val = Vcoding_system_for_write; |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3766 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
|
3767 val = Qnil; |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3768 else |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3769 { |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3770 if (EQ (coding_systems, Qt)) |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3771 { |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3772 if (NILP (host) || NILP (service)) |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3773 coding_systems = Qnil; |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3774 else |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3775 { |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3776 args[0] = Qopen_network_stream, args[1] = name, |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3777 args[2] = buffer, args[3] = host, args[4] = service; |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3778 GCPRO1 (proc); |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3779 coding_systems = Ffind_operation_coding_system (5, args); |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3780 UNGCPRO; |
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3781 } |
22019
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3782 } |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3783 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
|
3784 val = XCDR (coding_systems); |
22019
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3785 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
|
3786 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
|
3787 else |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3788 val = Qnil; |
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3789 } |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3790 p->encode_coding_system = val; |
22019
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3791 } |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
3792 setup_process_coding_systems (proc); |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
3793 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3794 p->decoding_buf = make_uninit_string (0); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
3795 p->decoding_carryover = 0; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3796 p->encoding_buf = make_uninit_string (0); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3797 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3798 p->inherit_coding_system_flag |
81926
50da0700fc26
(Fstart_process, Fmake_network_process, read_process_output):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
81876
diff
changeset
|
3799 = !(!NILP (tem) || NILP (buffer) || !inherit_process_coding_system); |
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
3800 |
578 | 3801 UNGCPRO; |
3802 return proc; | |
3803 } | |
3804 #endif /* HAVE_SOCKETS */ | |
3805 | |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3806 |
52525
fd2be6cea0e7
(Fnetwork_interface_list, Fnetwork_interface_info):
Kim F. Storm <storm@cua.dk>
parents:
52516
diff
changeset
|
3807 #if defined(HAVE_SOCKETS) && defined(HAVE_NET_IF_H) && defined(HAVE_SYS_IOCTL_H) |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3808 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3809 #ifdef SIOCGIFCONF |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3810 DEFUN ("network-interface-list", Fnetwork_interface_list, Snetwork_interface_list, 0, 0, 0, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3811 doc: /* Return an alist of all network interfaces and their network address. |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3812 Each element is a cons, the car of which is a string containing the |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3813 interface name, and the cdr is the network address in internal |
52527
3ea59ac8dfa5
(Fnetwork_interface_info): Fix type error.
Dave Love <fx@gnu.org>
parents:
52525
diff
changeset
|
3814 format; see the description of ADDRESS in `make-network-process'. */) |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3815 () |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3816 { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3817 struct ifconf ifconf; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3818 struct ifreq *ifreqs = NULL; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3819 int ifaces = 0; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3820 int buf_size, s; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3821 Lisp_Object res; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3822 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3823 s = socket (AF_INET, SOCK_STREAM, 0); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3824 if (s < 0) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3825 return Qnil; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3826 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3827 again: |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3828 ifaces += 25; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3829 buf_size = ifaces * sizeof(ifreqs[0]); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3830 ifreqs = (struct ifreq *)xrealloc(ifreqs, buf_size); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3831 if (!ifreqs) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3832 { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3833 close (s); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3834 return Qnil; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3835 } |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3836 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3837 ifconf.ifc_len = buf_size; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3838 ifconf.ifc_req = ifreqs; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3839 if (ioctl (s, SIOCGIFCONF, &ifconf)) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3840 { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3841 close (s); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3842 return Qnil; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3843 } |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3844 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3845 if (ifconf.ifc_len == buf_size) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3846 goto again; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3847 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3848 close (s); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3849 ifaces = ifconf.ifc_len / sizeof (ifreqs[0]); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3850 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3851 res = Qnil; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3852 while (--ifaces >= 0) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3853 { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3854 struct ifreq *ifq = &ifreqs[ifaces]; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3855 char namebuf[sizeof (ifq->ifr_name) + 1]; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3856 if (ifq->ifr_addr.sa_family != AF_INET) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3857 continue; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3858 bcopy (ifq->ifr_name, namebuf, sizeof (ifq->ifr_name)); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3859 namebuf[sizeof (ifq->ifr_name)] = 0; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3860 res = Fcons (Fcons (build_string (namebuf), |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3861 conv_sockaddr_to_lisp (&ifq->ifr_addr, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3862 sizeof (struct sockaddr))), |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3863 res); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3864 } |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3865 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3866 return res; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3867 } |
52525
fd2be6cea0e7
(Fnetwork_interface_list, Fnetwork_interface_info):
Kim F. Storm <storm@cua.dk>
parents:
52516
diff
changeset
|
3868 #endif /* SIOCGIFCONF */ |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3869 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3870 #if defined(SIOCGIFADDR) || defined(SIOCGIFHWADDR) || defined(SIOCGIFFLAGS) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3871 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3872 struct ifflag_def { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3873 int flag_bit; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3874 char *flag_sym; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3875 }; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3876 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3877 static struct ifflag_def ifflag_table[] = { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3878 #ifdef IFF_UP |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3879 { IFF_UP, "up" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3880 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3881 #ifdef IFF_BROADCAST |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3882 { IFF_BROADCAST, "broadcast" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3883 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3884 #ifdef IFF_DEBUG |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3885 { IFF_DEBUG, "debug" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3886 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3887 #ifdef IFF_LOOPBACK |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3888 { IFF_LOOPBACK, "loopback" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3889 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3890 #ifdef IFF_POINTOPOINT |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3891 { IFF_POINTOPOINT, "pointopoint" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3892 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3893 #ifdef IFF_RUNNING |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3894 { IFF_RUNNING, "running" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3895 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3896 #ifdef IFF_NOARP |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3897 { IFF_NOARP, "noarp" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3898 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3899 #ifdef IFF_PROMISC |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3900 { IFF_PROMISC, "promisc" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3901 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3902 #ifdef IFF_NOTRAILERS |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3903 { IFF_NOTRAILERS, "notrailers" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3904 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3905 #ifdef IFF_ALLMULTI |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3906 { IFF_ALLMULTI, "allmulti" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3907 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3908 #ifdef IFF_MASTER |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3909 { IFF_MASTER, "master" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3910 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3911 #ifdef IFF_SLAVE |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3912 { IFF_SLAVE, "slave" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3913 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3914 #ifdef IFF_MULTICAST |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3915 { IFF_MULTICAST, "multicast" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3916 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3917 #ifdef IFF_PORTSEL |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3918 { IFF_PORTSEL, "portsel" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3919 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3920 #ifdef IFF_AUTOMEDIA |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3921 { IFF_AUTOMEDIA, "automedia" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3922 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3923 #ifdef IFF_DYNAMIC |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3924 { IFF_DYNAMIC, "dynamic" }, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3925 #endif |
68146
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
3926 #ifdef IFF_OACTIVE |
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
3927 { IFF_OACTIVE, "oactive" }, /* OpenBSD: transmission in progress */ |
68008 | 3928 #endif |
3929 #ifdef IFF_SIMPLEX | |
3930 { IFF_SIMPLEX, "simplex" }, /* OpenBSD: can't hear own transmissions */ | |
3931 #endif | |
3932 #ifdef IFF_LINK0 | |
3933 { IFF_LINK0, "link0" }, /* OpenBSD: per link layer defined bit */ | |
3934 #endif | |
3935 #ifdef IFF_LINK1 | |
3936 { IFF_LINK1, "link1" }, /* OpenBSD: per link layer defined bit */ | |
3937 #endif | |
3938 #ifdef IFF_LINK2 | |
3939 { IFF_LINK2, "link2" }, /* OpenBSD: per link layer defined bit */ | |
3940 #endif | |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3941 { 0, 0 } |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3942 }; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3943 |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3944 DEFUN ("network-interface-info", Fnetwork_interface_info, Snetwork_interface_info, 1, 1, 0, |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3945 doc: /* Return information about network interface named IFNAME. |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3946 The return value is a list (ADDR BCAST NETMASK HWADDR FLAGS), |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3947 where ADDR is the layer 3 address, BCAST is the layer 3 broadcast address, |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3948 NETMASK is the layer 3 network mask, HWADDR is the layer 2 addres, and |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3949 FLAGS is the current flags of the interface. */) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3950 (ifname) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3951 Lisp_Object ifname; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3952 { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3953 struct ifreq rq; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3954 Lisp_Object res = Qnil; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3955 Lisp_Object elt; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3956 int s; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3957 int any = 0; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3958 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3959 CHECK_STRING (ifname); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3960 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3961 bzero (rq.ifr_name, sizeof rq.ifr_name); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3962 strncpy (rq.ifr_name, SDATA (ifname), sizeof (rq.ifr_name)); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3963 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3964 s = socket (AF_INET, SOCK_STREAM, 0); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3965 if (s < 0) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3966 return Qnil; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3967 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3968 elt = Qnil; |
52591 | 3969 #if defined(SIOCGIFFLAGS) && defined(HAVE_STRUCT_IFREQ_IFR_FLAGS) |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3970 if (ioctl (s, SIOCGIFFLAGS, &rq) == 0) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3971 { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3972 int flags = rq.ifr_flags; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3973 struct ifflag_def *fp; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3974 int fnum; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3975 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3976 any++; |
67920
8f3c10fea90b
(Fnetwork_interface_info): Correctly terminate the
Andreas Schwab <schwab@suse.de>
parents:
66752
diff
changeset
|
3977 for (fp = ifflag_table; flags != 0 && fp->flag_sym; fp++) |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3978 { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3979 if (flags & fp->flag_bit) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3980 { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3981 elt = Fcons (intern (fp->flag_sym), elt); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3982 flags -= fp->flag_bit; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3983 } |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3984 } |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3985 for (fnum = 0; flags && fnum < 32; fnum++) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3986 { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3987 if (flags & (1 << fnum)) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3988 { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3989 elt = Fcons (make_number (fnum), elt); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3990 } |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3991 } |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3992 } |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3993 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3994 res = Fcons (elt, res); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3995 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3996 elt = Qnil; |
52591 | 3997 #if defined(SIOCGIFHWADDR) && defined(HAVE_STRUCT_IFREQ_IFR_HWADDR) |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3998 if (ioctl (s, SIOCGIFHWADDR, &rq) == 0) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3999 { |
52525
fd2be6cea0e7
(Fnetwork_interface_list, Fnetwork_interface_info):
Kim F. Storm <storm@cua.dk>
parents:
52516
diff
changeset
|
4000 Lisp_Object hwaddr = Fmake_vector (make_number (6), Qnil); |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4001 register struct Lisp_Vector *p = XVECTOR (hwaddr); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4002 int n; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4003 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4004 any++; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4005 for (n = 0; n < 6; n++) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4006 p->contents[n] = make_number (((unsigned char *)&rq.ifr_hwaddr.sa_data[0])[n]); |
52527
3ea59ac8dfa5
(Fnetwork_interface_info): Fix type error.
Dave Love <fx@gnu.org>
parents:
52525
diff
changeset
|
4007 elt = Fcons (make_number (rq.ifr_hwaddr.sa_family), hwaddr); |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4008 } |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4009 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4010 res = Fcons (elt, res); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4011 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4012 elt = Qnil; |
68146
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
4013 #if defined(SIOCGIFNETMASK) && (defined(HAVE_STRUCT_IFREQ_IFR_NETMASK) || defined(HAVE_STRUCT_IFREQ_IFR_ADDR)) |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4014 if (ioctl (s, SIOCGIFNETMASK, &rq) == 0) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4015 { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4016 any++; |
68146
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
4017 #ifdef HAVE_STRUCT_IFREQ_IFR_NETMASK |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4018 elt = conv_sockaddr_to_lisp (&rq.ifr_netmask, sizeof (rq.ifr_netmask)); |
68146
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
4019 #else |
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
4020 elt = conv_sockaddr_to_lisp (&rq.ifr_addr, sizeof (rq.ifr_addr)); |
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
4021 #endif |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4022 } |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4023 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4024 res = Fcons (elt, res); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4025 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4026 elt = Qnil; |
52591 | 4027 #if defined(SIOCGIFBRDADDR) && defined(HAVE_STRUCT_IFREQ_IFR_BROADADDR) |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4028 if (ioctl (s, SIOCGIFBRDADDR, &rq) == 0) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4029 { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4030 any++; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4031 elt = conv_sockaddr_to_lisp (&rq.ifr_broadaddr, sizeof (rq.ifr_broadaddr)); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4032 } |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4033 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4034 res = Fcons (elt, res); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4035 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4036 elt = Qnil; |
52591 | 4037 #if defined(SIOCGIFADDR) && defined(HAVE_STRUCT_IFREQ_IFR_ADDR) |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4038 if (ioctl (s, SIOCGIFADDR, &rq) == 0) |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4039 { |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4040 any++; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4041 elt = conv_sockaddr_to_lisp (&rq.ifr_addr, sizeof (rq.ifr_addr)); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4042 } |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4043 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4044 res = Fcons (elt, res); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4045 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4046 close (s); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4047 |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4048 return any ? res : Qnil; |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4049 } |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4050 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4051 #endif /* HAVE_SOCKETS */ |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4052 |
56092 | 4053 /* Turn off input and output for process PROC. */ |
4054 | |
20382
dbad9367d232
(create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents:
20225
diff
changeset
|
4055 void |
578 | 4056 deactivate_process (proc) |
4057 Lisp_Object proc; | |
4058 { | |
4059 register int inchannel, outchannel; | |
4060 register struct Lisp_Process *p = XPROCESS (proc); | |
4061 | |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4062 inchannel = p->infd; |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4063 outchannel = p->outfd; |
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4064 |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4065 #ifdef ADAPTIVE_READ_BUFFERING |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4066 if (p->read_output_delay > 0) |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4067 { |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4068 if (--process_output_delay_count < 0) |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4069 process_output_delay_count = 0; |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4070 p->read_output_delay = 0; |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4071 p->read_output_skip = 0; |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4072 } |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4073 #endif |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
4074 |
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4075 if (inchannel >= 0) |
578 | 4076 { |
4077 /* Beware SIGCHLD hereabouts. */ | |
4078 flush_pending_output (inchannel); | |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
4079 emacs_close (inchannel); |
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4080 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
|
4081 emacs_close (outchannel); |
578 | 4082 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4083 p->infd = -1; |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4084 p->outfd = -1; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4085 #ifdef DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4086 if (DATAGRAM_CHAN_P (inchannel)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4087 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4088 xfree (datagram_address[inchannel].sa); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4089 datagram_address[inchannel].sa = 0; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4090 datagram_address[inchannel].len = 0; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4091 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4092 #endif |
578 | 4093 chan_process[inchannel] = Qnil; |
4094 FD_CLR (inchannel, &input_wait_mask); | |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
4095 FD_CLR (inchannel, &non_keyboard_wait_mask); |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4096 #ifdef NON_BLOCKING_CONNECT |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4097 if (FD_ISSET (inchannel, &connect_wait_mask)) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4098 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4099 FD_CLR (inchannel, &connect_wait_mask); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4100 if (--num_pending_connects < 0) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4101 abort (); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4102 } |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4103 #endif |
7044
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4104 if (inchannel == max_process_desc) |
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4105 { |
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4106 int i; |
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4107 /* 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
|
4108 so recompute the highest-numbered one now. */ |
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4109 max_process_desc = 0; |
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4110 for (i = 0; i < MAXDESC; i++) |
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4111 if (!NILP (chan_process[i])) |
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4112 max_process_desc = i; |
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4113 } |
578 | 4114 } |
4115 } | |
4116 | |
4117 /* Close all descriptors currently in use for communication | |
4118 with subprocess. This is used in a newly-forked subprocess | |
4119 to get rid of irrelevant descriptors. */ | |
4120 | |
20382
dbad9367d232
(create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents:
20225
diff
changeset
|
4121 void |
578 | 4122 close_process_descs () |
4123 { | |
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
4124 #ifndef WINDOWSNT |
578 | 4125 int i; |
4126 for (i = 0; i < MAXDESC; i++) | |
4127 { | |
4128 Lisp_Object process; | |
4129 process = chan_process[i]; | |
4130 if (!NILP (process)) | |
4131 { | |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4132 int in = XPROCESS (process)->infd; |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4133 int out = XPROCESS (process)->outfd; |
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4134 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
|
4135 emacs_close (in); |
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4136 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
|
4137 emacs_close (out); |
578 | 4138 } |
4139 } | |
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
4140 #endif |
578 | 4141 } |
4142 | |
4143 DEFUN ("accept-process-output", Faccept_process_output, Saccept_process_output, | |
56701
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4144 0, 4, 0, |
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
4145 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
|
4146 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
|
4147 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
|
4148 from PROCESS. |
69634
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4149 |
98456
a68b7a895cb6
(Faccept_process_output): Fix doc-string.
Martin Rudalics <rudalics@gmx.at>
parents:
98248
diff
changeset
|
4150 Non-nil second arg SECONDS and third arg MILLISEC are number of seconds |
a68b7a895cb6
(Faccept_process_output): Fix doc-string.
Martin Rudalics <rudalics@gmx.at>
parents:
98248
diff
changeset
|
4151 and milliseconds to wait; return after that much time whether or not |
a68b7a895cb6
(Faccept_process_output): Fix doc-string.
Martin Rudalics <rudalics@gmx.at>
parents:
98248
diff
changeset
|
4152 there is any subprocess output. If SECONDS is a floating point number, |
69634
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4153 it specifies a fractional number of seconds to wait. |
95387
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4154 The MILLISEC argument is obsolete and should be avoided. |
69634
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4155 |
56701
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4156 If optional fourth arg JUST-THIS-ONE is non-nil, only accept output |
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4157 from PROCESS, suspending reading output from other processes. |
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4158 If JUST-THIS-ONE is an integer, don't run any timers either. |
78501 | 4159 Return non-nil if we received any output before the timeout expired. */) |
77654 | 4160 (process, seconds, millisec, just_this_one) |
4161 register Lisp_Object process, seconds, millisec, just_this_one; | |
578 | 4162 { |
69634
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4163 int secs, usecs = 0; |
578 | 4164 |
24598
078d53377010
(Faccept_process_output): Check validity of PROCESS.
Richard M. Stallman <rms@gnu.org>
parents:
24352
diff
changeset
|
4165 if (! NILP (process)) |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
4166 CHECK_PROCESS (process); |
56701
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4167 else |
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4168 just_this_one = Qnil; |
24598
078d53377010
(Faccept_process_output): Check validity of PROCESS.
Richard M. Stallman <rms@gnu.org>
parents:
24352
diff
changeset
|
4169 |
95387
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4170 if (!NILP (millisec)) |
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4171 { /* Obsolete calling convention using integers rather than floats. */ |
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4172 CHECK_NUMBER (millisec); |
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4173 if (NILP (seconds)) |
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4174 seconds = make_float (XINT (millisec) / 1000.0); |
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4175 else |
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4176 { |
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4177 CHECK_NUMBER (seconds); |
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4178 seconds = make_float (XINT (millisec) / 1000.0 + XINT (seconds)); |
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4179 } |
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4180 } |
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4181 |
69634
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4182 if (!NILP (seconds)) |
578 | 4183 { |
69634
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4184 if (INTEGERP (seconds)) |
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4185 secs = XINT (seconds); |
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4186 else if (FLOATP (seconds)) |
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4187 { |
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4188 double timeout = XFLOAT_DATA (seconds); |
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4189 secs = (int) timeout; |
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4190 usecs = (int) ((timeout - (double) secs) * 1000000); |
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4191 } |
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4192 else |
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4193 wrong_type_argument (Qnumberp, seconds); |
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4194 |
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4195 if (secs < 0 || (secs == 0 && usecs == 0)) |
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4196 secs = -1, usecs = 0; |
578 | 4197 } |
1180
9bf82484415d
(Faccept_process_output): Initialize useconds.
Richard M. Stallman <rms@gnu.org>
parents:
1047
diff
changeset
|
4198 else |
69634
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4199 secs = NILP (process) ? -1 : 0; |
578 | 4200 |
4201 return | |
69634
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4202 (wait_reading_process_output (secs, usecs, 0, 0, |
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
4203 Qnil, |
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
4204 !NILP (process) ? XPROCESS (process) : NULL, |
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
4205 NILP (just_this_one) ? 0 : |
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
4206 !INTEGERP (just_this_one) ? 1 : -1) |
578 | 4207 ? Qt : Qnil); |
4208 } | |
4209 | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4210 /* 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
|
4211 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4212 static int connect_counter = 0; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4213 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4214 static void |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4215 server_accept_connection (server, channel) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4216 Lisp_Object server; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4217 int channel; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4218 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4219 Lisp_Object proc, caller, name, buffer; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4220 Lisp_Object contact, host, service; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4221 struct Lisp_Process *ps= XPROCESS (server); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4222 struct Lisp_Process *p; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4223 int s; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4224 union u_sockaddr { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4225 struct sockaddr sa; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4226 struct sockaddr_in in; |
68008 | 4227 #ifdef AF_INET6 |
4228 struct sockaddr_in6 in6; | |
4229 #endif | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4230 #ifdef HAVE_LOCAL_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4231 struct sockaddr_un un; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4232 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4233 } saddr; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4234 int len = sizeof saddr; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4235 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4236 s = accept (channel, &saddr.sa, &len); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4237 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4238 if (s < 0) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4239 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4240 int code = errno; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4241 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4242 if (code == EAGAIN) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4243 return; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4244 #ifdef EWOULDBLOCK |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4245 if (code == EWOULDBLOCK) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4246 return; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4247 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4248 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4249 if (!NILP (ps->log)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4250 call3 (ps->log, server, Qnil, |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4251 concat3 (build_string ("accept failed with code"), |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4252 Fnumber_to_string (make_number (code)), |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4253 build_string ("\n"))); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4254 return; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4255 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4256 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4257 connect_counter++; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4258 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4259 /* 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
|
4260 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4261 /* 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
|
4262 information for this process. */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4263 host = Qt; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4264 service = Qnil; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4265 switch (saddr.sa.sa_family) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4266 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4267 case AF_INET: |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4268 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4269 Lisp_Object args[5]; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4270 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
|
4271 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
|
4272 args[1] = make_number (*ip++); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4273 args[2] = make_number (*ip++); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4274 args[3] = make_number (*ip++); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4275 args[4] = make_number (*ip++); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4276 host = Fformat (5, args); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4277 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
|
4278 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4279 args[0] = build_string (" <%s:%d>"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4280 args[1] = host; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4281 args[2] = service; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4282 caller = Fformat (3, args); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4283 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4284 break; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4285 |
68008 | 4286 #ifdef AF_INET6 |
4287 case AF_INET6: | |
4288 { | |
4289 Lisp_Object args[9]; | |
4290 uint16_t *ip6 = (uint16_t *)&saddr.in6.sin6_addr; | |
4291 int i; | |
4292 args[0] = build_string ("%x:%x:%x:%x:%x:%x:%x:%x"); | |
4293 for (i = 0; i < 8; i++) | |
4294 args[i+1] = make_number (ntohs(ip6[i])); | |
4295 host = Fformat (9, args); | |
4296 service = make_number (ntohs (saddr.in.sin_port)); | |
4297 | |
4298 args[0] = build_string (" <[%s]:%d>"); | |
4299 args[1] = host; | |
4300 args[2] = service; | |
4301 caller = Fformat (3, args); | |
4302 } | |
4303 break; | |
4304 #endif | |
4305 | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4306 #ifdef HAVE_LOCAL_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4307 case AF_LOCAL: |
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 default: |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4310 caller = Fnumber_to_string (make_number (connect_counter)); |
93324
41f9d37301a2
(server_accept_connection): Simplify naming.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93201
diff
changeset
|
4311 caller = concat3 (build_string (" <"), caller, build_string (">")); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4312 break; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4313 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4314 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4315 /* 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
|
4316 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
|
4317 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
|
4318 identification. */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4319 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4320 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
|
4321 buffer = Qnil; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4322 else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4323 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4324 buffer = ps->buffer; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4325 if (!NILP (buffer)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4326 buffer = Fbuffer_name (buffer); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4327 else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4328 buffer = ps->name; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4329 if (!NILP (buffer)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4330 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4331 buffer = concat2 (buffer, caller); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4332 buffer = Fget_buffer_create (buffer); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4333 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4334 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4335 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4336 /* 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
|
4337 server process name with the caller identification. */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4338 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4339 name = concat2 (ps->name, caller); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4340 proc = make_process (name); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4341 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4342 chan_process[s] = proc; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4343 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4344 #ifdef O_NONBLOCK |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4345 fcntl (s, F_SETFL, O_NONBLOCK); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4346 #else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4347 #ifdef O_NDELAY |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4348 fcntl (s, F_SETFL, O_NDELAY); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4349 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4350 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4351 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4352 p = XPROCESS (proc); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4353 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4354 /* Build new contact information for this setup. */ |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4355 contact = Fcopy_sequence (ps->childp); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4356 contact = Fplist_put (contact, QCserver, Qnil); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4357 contact = Fplist_put (contact, QChost, host); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4358 if (!NILP (service)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4359 contact = Fplist_put (contact, QCservice, service); |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4360 contact = Fplist_put (contact, QCremote, |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4361 conv_sockaddr_to_lisp (&saddr.sa, len)); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4362 #ifdef HAVE_GETSOCKNAME |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4363 len = sizeof saddr; |
49111
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
4364 if (getsockname (s, &saddr.sa, &len) == 0) |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4365 contact = Fplist_put (contact, QClocal, |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4366 conv_sockaddr_to_lisp (&saddr.sa, len)); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4367 #endif |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4368 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4369 p->childp = contact; |
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
4370 p->plist = Fcopy_sequence (ps->plist); |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
4371 p->type = Qnetwork; |
49164 | 4372 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4373 p->buffer = buffer; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4374 p->sentinel = ps->sentinel; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4375 p->filter = ps->filter; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4376 p->command = Qnil; |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
4377 p->pid = 0; |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4378 p->infd = s; |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4379 p->outfd = s; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4380 p->status = Qrun; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4381 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4382 /* 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
|
4383 if (!EQ (p->filter, Qt)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4384 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4385 FD_SET (s, &input_wait_mask); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4386 FD_SET (s, &non_keyboard_wait_mask); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4387 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4388 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4389 if (s > max_process_desc) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4390 max_process_desc = s; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4391 |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4392 /* Setup coding system for new process based on server process. |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4393 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
|
4394 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
|
4395 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
|
4396 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4397 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
|
4398 p->encode_coding_system = ps->encode_coding_system; |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
4399 setup_process_coding_systems (proc); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4400 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4401 p->decoding_buf = make_uninit_string (0); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4402 p->decoding_carryover = 0; |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4403 p->encoding_buf = make_uninit_string (0); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4404 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4405 p->inherit_coding_system_flag |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4406 = (NILP (buffer) ? 0 : ps->inherit_coding_system_flag); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4407 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4408 if (!NILP (ps->log)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4409 call3 (ps->log, server, proc, |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4410 concat3 (build_string ("accept from "), |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4411 (STRINGP (host) ? host : build_string ("-")), |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4412 build_string ("\n"))); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4413 |
44314
f76a1425eb34
(DATAGRAM_CONN_P, list_processes_1)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44194
diff
changeset
|
4414 if (!NILP (p->sentinel)) |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4415 exec_sentinel (proc, |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4416 concat3 (build_string ("open from "), |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4417 (STRINGP (host) ? host : build_string ("-")), |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4418 build_string ("\n"))); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4419 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4420 |
578 | 4421 /* This variable is different from waiting_for_input in keyboard.c. |
4422 It is used to communicate to a lisp process-filter/sentinel (via the | |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
4423 function Fwaiting_for_user_input_p below) whether Emacs was waiting |
578 | 4424 for user-input when that process-filter was called. |
4425 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
|
4426 lisp code is being evalled. |
dd3dfde8f973
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
8390
diff
changeset
|
4427 This is also used in record_asynch_buffer_change. |
dd3dfde8f973
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
8390
diff
changeset
|
4428 For that purpose, this must be 0 |
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
4429 when not inside wait_reading_process_output. */ |
578 | 4430 static int waiting_for_user_input_p; |
4431 | |
72277
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4432 static Lisp_Object |
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4433 wait_reading_process_output_unwind (data) |
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4434 Lisp_Object data; |
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4435 { |
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4436 waiting_for_user_input_p = XINT (data); |
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4437 return Qnil; |
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4438 } |
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4439 |
14890
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4440 /* This is here so breakpoints can be put on it. */ |
21514 | 4441 static void |
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
4442 wait_reading_process_output_1 () |
14890
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4443 { |
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4444 } |
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4445 |
71109
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4446 /* Use a wrapper around select to work around a bug in gdb 5.3. |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4447 Normally, the wrapper is optimzed away by inlining. |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4448 |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4449 If emacs is stopped inside select, the gdb backtrace doesn't |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4450 show the function which called select, so it is practically |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4451 impossible to step through wait_reading_process_output. */ |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4452 |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4453 #ifndef select |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4454 static INLINE int |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4455 select_wrapper (n, rfd, wfd, xfd, tmo) |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4456 int n; |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4457 SELECT_TYPE *rfd, *wfd, *xfd; |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4458 EMACS_TIME *tmo; |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4459 { |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4460 return select (n, rfd, wfd, xfd, tmo); |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4461 } |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4462 #define select select_wrapper |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4463 #endif |
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4464 |
578 | 4465 /* Read and dispose of subprocess output while waiting for timeout to |
4466 elapse and/or keyboard input to be available. | |
4467 | |
3953
d0c23febc08c
(wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents:
3915
diff
changeset
|
4468 TIME_LIMIT is: |
578 | 4469 timeout in seconds, or |
4470 zero for no limit, or | |
4471 -1 means gobble data immediately available but don't wait for any. | |
4472 | |
3953
d0c23febc08c
(wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents:
3915
diff
changeset
|
4473 MICROSECS is: |
d0c23febc08c
(wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents:
3915
diff
changeset
|
4474 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
|
4475 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
|
4476 consists of MICROSECS only. |
d0c23febc08c
(wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents:
3915
diff
changeset
|
4477 |
d0c23febc08c
(wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents:
3915
diff
changeset
|
4478 READ_KBD is a lisp value: |
578 | 4479 0 to ignore keyboard input, or |
4480 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
|
4481 -1 meaning caller will actually read the input, so don't throw to |
578 | 4482 the quit handler, or |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4483 |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4484 DO_DISPLAY != 0 means redisplay should be done to show subprocess |
56701
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4485 output that arrives. |
578 | 4486 |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4487 If WAIT_FOR_CELL is a cons cell, wait until its car is non-nil |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4488 (and gobble terminal input into the buffer if any arrives). |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4489 |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4490 If WAIT_PROC is specified, wait until something arrives from that |
78501 | 4491 process. The return value is true if we read some input from |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4492 that process. |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4493 |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4494 If JUST_WAIT_PROC is non-nil, handle only output from WAIT_PROC |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4495 (suspending output from other processes). A negative value |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4496 means don't run any timers either. |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4497 |
78501 | 4498 If WAIT_PROC is specified, then the function returns true if we |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4499 received input from that process before the timeout elapsed. |
78501 | 4500 Otherwise, return true if we received input from any process. */ |
578 | 4501 |
21514 | 4502 int |
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
4503 wait_reading_process_output (time_limit, microsecs, read_kbd, do_display, |
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
4504 wait_for_cell, wait_proc, just_wait_proc) |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4505 int time_limit, microsecs, read_kbd, do_display; |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4506 Lisp_Object wait_for_cell; |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4507 struct Lisp_Process *wait_proc; |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4508 int just_wait_proc; |
578 | 4509 { |
25770
3a44b5298cd5
(list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents:
25760
diff
changeset
|
4510 register int channel, nfds; |
55579
234873044c2a
(wait_reading_process_input): Make reentrant.
Kim F. Storm <storm@cua.dk>
parents:
55534
diff
changeset
|
4511 SELECT_TYPE Available; |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4512 #ifdef NON_BLOCKING_CONNECT |
55579
234873044c2a
(wait_reading_process_input): Make reentrant.
Kim F. Storm <storm@cua.dk>
parents:
55534
diff
changeset
|
4513 SELECT_TYPE Connecting; |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4514 int check_connect; |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4515 #endif |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4516 int check_delay, no_avail; |
578 | 4517 int xerrno; |
4518 Lisp_Object proc; | |
25770
3a44b5298cd5
(list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents:
25760
diff
changeset
|
4519 EMACS_TIME timeout, end_time; |
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4520 int wait_channel = -1; |
578 | 4521 int got_some_input = 0; |
72277
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4522 int count = SPECPDL_INDEX (); |
578 | 4523 |
4524 FD_ZERO (&Available); | |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4525 #ifdef NON_BLOCKING_CONNECT |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4526 FD_ZERO (&Connecting); |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4527 #endif |
578 | 4528 |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4529 /* If wait_proc is a process to watch, set wait_channel accordingly. */ |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4530 if (wait_proc != NULL) |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4531 wait_channel = wait_proc->infd; |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4532 |
72277
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4533 record_unwind_protect (wait_reading_process_output_unwind, |
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4534 make_number (waiting_for_user_input_p)); |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4535 waiting_for_user_input_p = read_kbd; |
578 | 4536 |
4537 /* Since we may need to wait several times, | |
4538 compute the absolute time to return at. */ | |
4539 if (time_limit || microsecs) | |
4540 { | |
4541 EMACS_GET_TIME (end_time); | |
4542 EMACS_SET_SECS_USECS (timeout, time_limit, microsecs); | |
4543 EMACS_ADD_TIME (end_time, end_time, timeout); | |
4544 } | |
4545 | |
4546 while (1) | |
4547 { | |
14458
2bb4652305c1
(wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents:
14405
diff
changeset
|
4548 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
|
4549 |
578 | 4550 /* If calling from keyboard input, do not quit |
4551 since we want to return C-g as an input character. | |
4552 Otherwise, do pending quit if requested. */ | |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4553 if (read_kbd >= 0) |
578 | 4554 QUIT; |
53659
291acfb4bf40
(wait_reading_process_input) [SYNC_INPUT]: Check interrupt_input_pending.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53637
diff
changeset
|
4555 #ifdef SYNC_INPUT |
93896
0c2f4b91340c
(wait_reading_process_output): If SYNC_INPUT and pending_atimers, run atimers.
Jan Djärv <jan.h.d@swipnet.se>
parents:
93324
diff
changeset
|
4556 else |
101649
bd66da73ef9f
(wait_reading_process_output): Use process_pending_signals.
Chong Yidong <cyd@stupidchicken.com>
parents:
101276
diff
changeset
|
4557 process_pending_signals (); |
53659
291acfb4bf40
(wait_reading_process_input) [SYNC_INPUT]: Check interrupt_input_pending.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53637
diff
changeset
|
4558 #endif |
578 | 4559 |
4639 | 4560 /* 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
|
4561 if (! NILP (wait_for_cell) && ! NILP (XCAR (wait_for_cell))) |
4639 | 4562 break; |
4563 | |
578 | 4564 /* Compute time from now till when time limit is up */ |
4565 /* Exit if already run out */ | |
4566 if (time_limit == -1) | |
4567 { | |
4568 /* -1 specified for timeout means | |
4569 gobble output available now | |
4570 but don't wait at all. */ | |
4571 | |
4572 EMACS_SET_SECS_USECS (timeout, 0, 0); | |
4573 } | |
4574 else if (time_limit || microsecs) | |
4575 { | |
4576 EMACS_GET_TIME (timeout); | |
4577 EMACS_SUB_TIME (timeout, end_time, timeout); | |
4578 if (EMACS_TIME_NEG_P (timeout)) | |
4579 break; | |
4580 } | |
4581 else | |
4582 { | |
4583 EMACS_SET_SECS_USECS (timeout, 100000, 0); | |
4584 } | |
4585 | |
15064
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4586 /* Normally we run timers here. |
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4587 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
|
4588 the wait is supposed to be short, |
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4589 and those callers cannot handle running arbitrary Lisp code here. */ |
56701
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4590 if (NILP (wait_for_cell) |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4591 && just_wait_proc >= 0) |
14404
cba05f90ee57
(wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents:
14278
diff
changeset
|
4592 { |
14458
2bb4652305c1
(wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents:
14405
diff
changeset
|
4593 EMACS_TIME timer_delay; |
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4594 |
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4595 do |
14890
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4596 { |
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4597 int old_timers_run = timers_run; |
37465
f790d83ea743
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
37413
diff
changeset
|
4598 struct buffer *old_buffer = current_buffer; |
80225
2958d9bca9be
(wait_reading_process_output): Check for window changes caused by timers.
Chong Yidong <cyd@stupidchicken.com>
parents:
79807
diff
changeset
|
4599 Lisp_Object old_window = selected_window; |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4600 |
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4601 timer_delay = timer_check (1); |
37398
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4602 |
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4603 /* 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
|
4604 an alike. Make read_key_sequence aware of that. */ |
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4605 if (timers_run != old_timers_run |
80225
2958d9bca9be
(wait_reading_process_output): Check for window changes caused by timers.
Chong Yidong <cyd@stupidchicken.com>
parents:
79807
diff
changeset
|
4606 && (old_buffer != current_buffer |
2958d9bca9be
(wait_reading_process_output): Check for window changes caused by timers.
Chong Yidong <cyd@stupidchicken.com>
parents:
79807
diff
changeset
|
4607 || !EQ (old_window, selected_window)) |
37398
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4608 && waiting_for_user_input_p == -1) |
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4609 record_asynch_buffer_change (); |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4610 |
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4611 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
|
4612 /* 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
|
4613 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
|
4614 redisplay_preserve_echo_area (9); |
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4615 else |
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4616 break; |
14890
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4617 } |
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4618 while (!detect_input_pending ()); |
14890
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4619 |
18230
2f1f942f25ca
(wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents:
18183
diff
changeset
|
4620 /* If there is unread keyboard input, also return. */ |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4621 if (read_kbd != 0 |
18230
2f1f942f25ca
(wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents:
18183
diff
changeset
|
4622 && requeued_events_pending_p ()) |
2f1f942f25ca
(wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents:
18183
diff
changeset
|
4623 break; |
2f1f942f25ca
(wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents:
18183
diff
changeset
|
4624 |
14458
2bb4652305c1
(wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents:
14405
diff
changeset
|
4625 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
|
4626 { |
cba05f90ee57
(wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents:
14278
diff
changeset
|
4627 EMACS_TIME difference; |
cba05f90ee57
(wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents:
14278
diff
changeset
|
4628 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
|
4629 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
|
4630 { |
2bb4652305c1
(wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents:
14405
diff
changeset
|
4631 timeout = timer_delay; |
2bb4652305c1
(wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents:
14405
diff
changeset
|
4632 timeout_reduced_for_timers = 1; |
2bb4652305c1
(wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents:
14405
diff
changeset
|
4633 } |
14404
cba05f90ee57
(wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents:
14278
diff
changeset
|
4634 } |
14935
3e0dc64a5cb8
(wait_reading_process_input): Don't call
Richard M. Stallman <rms@gnu.org>
parents:
14890
diff
changeset
|
4635 /* 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
|
4636 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
|
4637 { |
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4638 /* This is so a breakpoint can be put here. */ |
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
4639 wait_reading_process_output_1 (); |
14890
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4640 } |
14404
cba05f90ee57
(wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents:
14278
diff
changeset
|
4641 } |
cba05f90ee57
(wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents:
14278
diff
changeset
|
4642 |
2894
646c5beae647
* process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents:
2893
diff
changeset
|
4643 /* 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
|
4644 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
|
4645 |
646c5beae647
* process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents:
2893
diff
changeset
|
4646 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
|
4647 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
|
4648 process activity, timeout is the only way we will know. */ |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4649 if (read_kbd < 0) |
2894
646c5beae647
* process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents:
2893
diff
changeset
|
4650 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
|
4651 |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
4652 /* 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
|
4653 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
|
4654 this explicit check, we'll let the SIGCHLD handler zap |
95111
f3a094e70d91
(wait_reading_process_output): Always check status when in batch mode.
Chong Yidong <cyd@stupidchicken.com>
parents:
94963
diff
changeset
|
4655 timeout to get our attention. When Emacs is run |
f3a094e70d91
(wait_reading_process_output): Always check status when in batch mode.
Chong Yidong <cyd@stupidchicken.com>
parents:
94963
diff
changeset
|
4656 interactively, only do this with a nonzero DO_DISPLAY |
f3a094e70d91
(wait_reading_process_output): Always check status when in batch mode.
Chong Yidong <cyd@stupidchicken.com>
parents:
94963
diff
changeset
|
4657 argument, because status_notify triggers redisplay. */ |
f3a094e70d91
(wait_reading_process_output): Always check status when in batch mode.
Chong Yidong <cyd@stupidchicken.com>
parents:
94963
diff
changeset
|
4658 if (update_tick != process_tick |
f3a094e70d91
(wait_reading_process_output): Always check status when in batch mode.
Chong Yidong <cyd@stupidchicken.com>
parents:
94963
diff
changeset
|
4659 && (do_display || noninteractive)) |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
4660 { |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4661 SELECT_TYPE Atemp; |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4662 #ifdef NON_BLOCKING_CONNECT |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4663 SELECT_TYPE Ctemp; |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4664 #endif |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4665 |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
4666 Atemp = input_wait_mask; |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4667 IF_NON_BLOCKING_CONNECT (Ctemp = connect_wait_mask); |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4668 |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
4669 EMACS_SET_SECS_USECS (timeout, 0, 0); |
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
4670 if ((select (max (max (max_process_desc, max_keyboard_desc), |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
4671 max_gpm_desc) + 1, |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4672 &Atemp, |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4673 #ifdef NON_BLOCKING_CONNECT |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4674 (num_pending_connects > 0 ? &Ctemp : (SELECT_TYPE *)0), |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4675 #else |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4676 (SELECT_TYPE *)0, |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4677 #endif |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4678 (SELECT_TYPE *)0, &timeout) |
11926
40d7e6f04ebe
(create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents:
11845
diff
changeset
|
4679 <= 0)) |
2894
646c5beae647
* process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents:
2893
diff
changeset
|
4680 { |
646c5beae647
* process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents:
2893
diff
changeset
|
4681 /* It's okay for us to do this and then continue with |
5534 | 4682 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
|
4683 clear_waiting_for_input (); |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
4684 status_notify (NULL); |
2894
646c5beae647
* process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents:
2893
diff
changeset
|
4685 } |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
4686 } |
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
4687 |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4688 /* Don't wait for output from a non-running process. Just |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4689 read whatever data has already been received. */ |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
4690 if (wait_proc && wait_proc->raw_status_new) |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
4691 update_status (wait_proc); |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
4692 if (wait_proc |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4693 && ! EQ (wait_proc->status, Qrun) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4694 && ! 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
|
4695 { |
18946
84b78d90cd45
(wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents:
18739
diff
changeset
|
4696 int nread, total_nread = 0; |
18267
29c37882ee1f
(wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents:
18230
diff
changeset
|
4697 |
2893
4df57953d5d0
* process.c (wait_reading_process_input): Don't forget to call
Jim Blandy <jimb@redhat.com>
parents:
2887
diff
changeset
|
4698 clear_waiting_for_input (); |
18267
29c37882ee1f
(wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents:
18230
diff
changeset
|
4699 XSETPROCESS (proc, wait_proc); |
29c37882ee1f
(wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents:
18230
diff
changeset
|
4700 |
29c37882ee1f
(wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents:
18230
diff
changeset
|
4701 /* Read data from the process, until we exhaust it. */ |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4702 while (wait_proc->infd >= 0) |
18946
84b78d90cd45
(wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents:
18739
diff
changeset
|
4703 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4704 nread = read_process_output (proc, wait_proc->infd); |
25894
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4705 |
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4706 if (nread == 0) |
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4707 break; |
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4708 |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4709 if (0 < nread) |
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4710 { |
95387
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4711 total_nread += nread; |
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4712 got_some_input = 1; |
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4713 } |
18946
84b78d90cd45
(wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents:
18739
diff
changeset
|
4714 #ifdef EIO |
84b78d90cd45
(wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents:
18739
diff
changeset
|
4715 else if (nread == -1 && EIO == errno) |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4716 break; |
18946
84b78d90cd45
(wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents:
18739
diff
changeset
|
4717 #endif |
25894
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4718 #ifdef EAGAIN |
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4719 else if (nread == -1 && EAGAIN == errno) |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4720 break; |
25894
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4721 #endif |
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4722 #ifdef EWOULDBLOCK |
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4723 else if (nread == -1 && EWOULDBLOCK == errno) |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4724 break; |
25894
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4725 #endif |
18946
84b78d90cd45
(wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents:
18739
diff
changeset
|
4726 } |
18267
29c37882ee1f
(wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents:
18230
diff
changeset
|
4727 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
|
4728 redisplay_preserve_echo_area (10); |
18267
29c37882ee1f
(wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents:
18230
diff
changeset
|
4729 |
2893
4df57953d5d0
* process.c (wait_reading_process_input): Don't forget to call
Jim Blandy <jimb@redhat.com>
parents:
2887
diff
changeset
|
4730 break; |
4df57953d5d0
* process.c (wait_reading_process_input): Don't forget to call
Jim Blandy <jimb@redhat.com>
parents:
2887
diff
changeset
|
4731 } |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
4732 |
578 | 4733 /* Wait till there is something to do */ |
4734 | |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4735 if (wait_proc && just_wait_proc) |
56701
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4736 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4737 if (wait_proc->infd < 0) /* Terminated */ |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4738 break; |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4739 FD_SET (wait_proc->infd, &Available); |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4740 check_delay = 0; |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4741 IF_NON_BLOCKING_CONNECT (check_connect = 0); |
56701
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4742 } |
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4743 else if (!NILP (wait_for_cell)) |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4744 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4745 Available = non_process_wait_mask; |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4746 check_delay = 0; |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4747 IF_NON_BLOCKING_CONNECT (check_connect = 0); |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4748 } |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
4749 else |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4750 { |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4751 if (! read_kbd) |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4752 Available = non_keyboard_wait_mask; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4753 else |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4754 Available = input_wait_mask; |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4755 IF_NON_BLOCKING_CONNECT (check_connect = (num_pending_connects > 0)); |
53835
ad9da392f358
(wait_reading_process_input): Don't do adaptive read
Kim F. Storm <storm@cua.dk>
parents:
53732
diff
changeset
|
4756 check_delay = wait_channel >= 0 ? 0 : process_output_delay_count; |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4757 } |
578 | 4758 |
765 | 4759 /* If frame size has changed or the window is newly mapped, |
648 | 4760 redisplay now, before we start to wait. There is a race |
4761 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
|
4762 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
|
4763 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
|
4764 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
|
4765 { |
affed1766d34
(wait_reading_process_input): Don't call prepare_menu_bars.
Richard M. Stallman <rms@gnu.org>
parents:
11695
diff
changeset
|
4766 clear_waiting_for_input (); |
35336
002c02db42d3
Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents:
34660
diff
changeset
|
4767 redisplay_preserve_echo_area (11); |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4768 if (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
|
4769 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
|
4770 } |
648 | 4771 |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4772 no_avail = 0; |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4773 if (read_kbd && detect_input_pending ()) |
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
4774 { |
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
4775 nfds = 0; |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4776 no_avail = 1; |
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
4777 } |
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
4778 else |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4779 { |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4780 #ifdef NON_BLOCKING_CONNECT |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4781 if (check_connect) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4782 Connecting = connect_wait_mask; |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4783 #endif |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4784 |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4785 #ifdef ADAPTIVE_READ_BUFFERING |
63114
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
4786 /* Set the timeout for adaptive read buffering if any |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4787 process has non-zero read_output_skip and non-zero |
63114
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
4788 read_output_delay, and we are not reading output for a |
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
4789 specific wait_channel. It is not executed if |
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
4790 Vprocess_adaptive_read_buffering is nil. */ |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4791 if (process_output_skip && check_delay > 0) |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4792 { |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4793 int usecs = EMACS_USECS (timeout); |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4794 if (EMACS_SECS (timeout) > 0 || usecs > READ_OUTPUT_DELAY_MAX) |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4795 usecs = READ_OUTPUT_DELAY_MAX; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4796 for (channel = 0; check_delay > 0 && channel <= max_process_desc; channel++) |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4797 { |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4798 proc = chan_process[channel]; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4799 if (NILP (proc)) |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4800 continue; |
63114
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
4801 /* Find minimum non-zero read_output_delay among the |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4802 processes with non-zero read_output_skip. */ |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4803 if (XPROCESS (proc)->read_output_delay > 0) |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4804 { |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4805 check_delay--; |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4806 if (!XPROCESS (proc)->read_output_skip) |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4807 continue; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4808 FD_CLR (channel, &Available); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4809 XPROCESS (proc)->read_output_skip = 0; |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4810 if (XPROCESS (proc)->read_output_delay < usecs) |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4811 usecs = XPROCESS (proc)->read_output_delay; |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4812 } |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4813 } |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4814 EMACS_SET_SECS_USECS (timeout, 0, usecs); |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4815 process_output_skip = 0; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4816 } |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4817 #endif |
96675
d45acf0c8d23
merging Emacs.app (NeXTstep port)
Adrian Robert <Adrian.B.Robert@gmail.com>
parents:
96620
diff
changeset
|
4818 #ifdef HAVE_NS |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4819 nfds = ns_select |
96675
d45acf0c8d23
merging Emacs.app (NeXTstep port)
Adrian Robert <Adrian.B.Robert@gmail.com>
parents:
96620
diff
changeset
|
4820 #else |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4821 nfds = select |
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4822 #endif |
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4823 (max (max (max_process_desc, max_keyboard_desc), |
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
4824 max_gpm_desc) + 1, |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4825 &Available, |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4826 #ifdef NON_BLOCKING_CONNECT |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4827 (check_connect ? &Connecting : (SELECT_TYPE *)0), |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4828 #else |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4829 (SELECT_TYPE *)0, |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4830 #endif |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4831 (SELECT_TYPE *)0, &timeout); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4832 } |
588 | 4833 |
578 | 4834 xerrno = errno; |
4835 | |
4836 /* Make C-g and alarm signals set flags again */ | |
4837 clear_waiting_for_input (); | |
4838 | |
4839 /* 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
|
4840 do_pending_window_change (0); |
578 | 4841 |
14458
2bb4652305c1
(wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents:
14405
diff
changeset
|
4842 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
|
4843 /* We wanted the full specified time, so return now. */ |
578 | 4844 break; |
4845 if (nfds < 0) | |
4846 { | |
4847 if (xerrno == EINTR) | |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4848 no_avail = 1; |
578 | 4849 else if (xerrno == EBADF) |
4850 { | |
4851 #ifdef AIX | |
4852 /* AIX doesn't handle PTY closure the same way BSD does. On AIX, | |
4853 the child's closure of the pts gives the parent a SIGHUP, and | |
4854 the ptc file descriptor is automatically closed, | |
4855 yielding EBADF here or at select() call above. | |
4856 So, SIGHUP is ignored (see def of PTY_TTY_NAME_SPRINTF | |
5534 | 4857 in m/ibmrt-aix.h), and here we just ignore the select error. |
578 | 4858 Cleanup occurs c/o status_notify after SIGCLD. */ |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4859 no_avail = 1; /* Cannot depend on values returned */ |
578 | 4860 #else |
4861 abort (); | |
4862 #endif | |
4863 } | |
4864 else | |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
4865 error ("select error: %s", emacs_strerror (xerrno)); |
578 | 4866 } |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4867 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4868 if (no_avail) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4869 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4870 FD_ZERO (&Available); |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4871 IF_NON_BLOCKING_CONNECT (check_connect = 0); |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4872 } |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4873 |
18378
22cd8d7dd5aa
(wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents:
18329
diff
changeset
|
4874 #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
|
4875 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
|
4876 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
|
4877 /* 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
|
4878 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
|
4879 Otherwise it might not actually get read for a second. |
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
4880 And on hpux, since we turn off polling in wait_reading_process_output, |
18378
22cd8d7dd5aa
(wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents:
18329
diff
changeset
|
4881 it might never get read at all if we don't spend much time |
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
4882 outside of wait_reading_process_output. */ |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4883 if (read_kbd && interrupt_input |
18378
22cd8d7dd5aa
(wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents:
18329
diff
changeset
|
4884 && keyboard_bit_set (&Available) |
22cd8d7dd5aa
(wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents:
18329
diff
changeset
|
4885 && input_polling_used ()) |
22cd8d7dd5aa
(wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents:
18329
diff
changeset
|
4886 kill (getpid (), SIGALRM); |
22cd8d7dd5aa
(wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents:
18329
diff
changeset
|
4887 #endif |
22cd8d7dd5aa
(wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents:
18329
diff
changeset
|
4888 |
578 | 4889 /* Check for keyboard input */ |
4890 /* If there is any, return immediately | |
4891 to give it higher priority than subprocesses */ | |
4892 | |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4893 if (read_kbd != 0) |
14613 | 4894 { |
37398
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4895 int old_timers_run = timers_run; |
37465
f790d83ea743
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
37413
diff
changeset
|
4896 struct buffer *old_buffer = current_buffer; |
79807
6292ea8947eb
Chong Yidong <cyd at stupidchicken.com>
Glenn Morris <rgm@gnu.org>
parents:
79759
diff
changeset
|
4897 Lisp_Object old_window = selected_window; |
37398
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4898 int leave = 0; |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4899 |
14758
849458c13c0c
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14736
diff
changeset
|
4900 if (detect_input_pending_run_timers (do_display)) |
37398
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4901 { |
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4902 swallow_events (do_display); |
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4903 if (detect_input_pending_run_timers (do_display)) |
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4904 leave = 1; |
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4905 } |
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4906 |
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4907 /* 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
|
4908 an alike. Make read_key_sequence aware of that. */ |
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4909 if (timers_run != old_timers_run |
37465
f790d83ea743
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
37413
diff
changeset
|
4910 && waiting_for_user_input_p == -1 |
79807
6292ea8947eb
Chong Yidong <cyd at stupidchicken.com>
Glenn Morris <rgm@gnu.org>
parents:
79759
diff
changeset
|
4911 && (old_buffer != current_buffer |
6292ea8947eb
Chong Yidong <cyd at stupidchicken.com>
Glenn Morris <rgm@gnu.org>
parents:
79759
diff
changeset
|
4912 || !EQ (old_window, selected_window))) |
37398
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4913 record_asynch_buffer_change (); |
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4914 |
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4915 if (leave) |
14613 | 4916 break; |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4917 } |
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4918 |
18230
2f1f942f25ca
(wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents:
18183
diff
changeset
|
4919 /* If there is unread keyboard input, also return. */ |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4920 if (read_kbd != 0 |
18230
2f1f942f25ca
(wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents:
18183
diff
changeset
|
4921 && requeued_events_pending_p ()) |
2f1f942f25ca
(wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents:
18183
diff
changeset
|
4922 break; |
2f1f942f25ca
(wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents:
18183
diff
changeset
|
4923 |
19053
7b5642657857
(read_process_output): Don't call setup_coding_system
Richard M. Stallman <rms@gnu.org>
parents:
18974
diff
changeset
|
4924 /* 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
|
4925 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
|
4926 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
|
4927 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
|
4928 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
|
4929 |
7b5642657857
(read_process_output): Don't call setup_coding_system
Richard M. Stallman <rms@gnu.org>
parents:
18974
diff
changeset
|
4930 (We used to do this only if wait_for_cell.) */ |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4931 if (read_kbd == 0 && detect_input_pending ()) |
15064
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4932 { |
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4933 swallow_events (do_display); |
18492
668304de6f92
(wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents:
18378
diff
changeset
|
4934 #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
|
4935 if (detect_input_pending ()) |
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4936 break; |
18492
668304de6f92
(wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents:
18378
diff
changeset
|
4937 #endif |
15064
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4938 } |
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4939 |
2200
5e58643bb169
(wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents:
2120
diff
changeset
|
4940 /* 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
|
4941 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
|
4942 break; |
5e58643bb169
(wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents:
2120
diff
changeset
|
4943 |
621 | 4944 #ifdef SIGIO |
18378
22cd8d7dd5aa
(wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents:
18329
diff
changeset
|
4945 /* If we think we have keyboard input waiting, but didn't get SIGIO, |
578 | 4946 go read it. This can happen with X on BSD after logging out. |
4947 In that case, there really is no input and no SIGIO, | |
4948 but select says there is input. */ | |
4949 | |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4950 if (read_kbd && interrupt_input |
51637
745eaece4a11
(wait_reading_process_input): Don't signal SIGIO in batch mode.
Richard M. Stallman <rms@gnu.org>
parents:
51473
diff
changeset
|
4951 && keyboard_bit_set (&Available) && ! noninteractive) |
14736
b17ec81a6294
(wait_reading_process_input): Use getpid when generating SIGIO.
Richard M. Stallman <rms@gnu.org>
parents:
14671
diff
changeset
|
4952 kill (getpid (), SIGIO); |
621 | 4953 #endif |
578 | 4954 |
4955 if (! wait_proc) | |
4956 got_some_input |= nfds > 0; | |
4957 | |
624 | 4958 /* If checking input just got us a size-change event from X, |
4959 obey it now if we should. */ | |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4960 if (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
|
4961 do_pending_window_change (0); |
624 | 4962 |
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4963 /* Check for data from a process. */ |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4964 if (no_avail || nfds == 0) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4965 continue; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4966 |
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4967 /* Really FIRST_PROC_DESC should be 0 on Unix, |
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4968 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
|
4969 for (channel = 0; channel <= max_process_desc; channel++) |
578 | 4970 { |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
4971 if (FD_ISSET (channel, &Available) |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
4972 && FD_ISSET (channel, &non_keyboard_wait_mask)) |
578 | 4973 { |
4974 int nread; | |
4975 | |
4976 /* If waiting for this channel, arrange to return as | |
4977 soon as no more input to be processed. No more | |
4978 waiting. */ | |
4979 if (wait_channel == channel) | |
4980 { | |
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4981 wait_channel = -1; |
578 | 4982 time_limit = -1; |
4983 got_some_input = 1; | |
4984 } | |
4985 proc = chan_process[channel]; | |
4986 if (NILP (proc)) | |
4987 continue; | |
4988 | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4989 /* 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
|
4990 if (EQ (XPROCESS (proc)->status, Qlisten)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4991 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4992 server_accept_connection (proc, channel); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4993 continue; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4994 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4995 |
578 | 4996 /* Read data from the process, starting with our |
4997 buffered-ahead character if we have one. */ | |
4998 | |
4999 nread = read_process_output (proc, channel); | |
5000 if (nread > 0) | |
5001 { | |
5002 /* Since read_process_output can run a filter, | |
5003 which can call accept-process-output, | |
5004 don't try to read from any other processes | |
5005 before doing the select again. */ | |
5006 FD_ZERO (&Available); | |
5007 | |
5008 if (do_display) | |
35336
002c02db42d3
Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents:
34660
diff
changeset
|
5009 redisplay_preserve_echo_area (12); |
578 | 5010 } |
5011 #ifdef EWOULDBLOCK | |
5012 else if (nread == -1 && errno == EWOULDBLOCK) | |
5013 ; | |
15405
c27bb6e69e2d
(wait_reading_process_input): Move the O_NONBLOCK and
Richard M. Stallman <rms@gnu.org>
parents:
15368
diff
changeset
|
5014 #endif |
15406 | 5015 /* ISC 4.1 defines both EWOULDBLOCK and O_NONBLOCK, |
5016 and Emacs uses O_NONBLOCK, so what we get is EAGAIN. */ | |
578 | 5017 #ifdef O_NONBLOCK |
5018 else if (nread == -1 && errno == EAGAIN) | |
5019 ; | |
5020 #else | |
5021 #ifdef O_NDELAY | |
5022 else if (nread == -1 && errno == EAGAIN) | |
5023 ; | |
5024 /* Note that we cannot distinguish between no input | |
5025 available now and a closed pipe. | |
5026 With luck, a closed pipe will be accompanied by | |
5027 subprocess termination and SIGCHLD. */ | |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
5028 else if (nread == 0 && !NETCONN_P (proc) && !SERIALCONN_P (proc)) |
578 | 5029 ; |
76794
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5030 #endif /* O_NDELAY */ |
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5031 #endif /* O_NONBLOCK */ |
578 | 5032 #ifdef HAVE_PTYS |
5033 /* On some OSs with ptys, when the process on one end of | |
5034 a pty exits, the other end gets an error reading with | |
5035 errno = EIO instead of getting an EOF (0 bytes read). | |
5036 Therefore, if we get an error reading and errno = | |
5037 EIO, just continue, because the child process has | |
5038 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
|
5039 get a SIGCHLD). |
8d68b82a4d8c
(wait_reading_process_input): If a pty gives EIO,
Richard M. Stallman <rms@gnu.org>
parents:
22939
diff
changeset
|
5040 |
8d68b82a4d8c
(wait_reading_process_input): If a pty gives EIO,
Richard M. Stallman <rms@gnu.org>
parents:
22939
diff
changeset
|
5041 However, it has been known to happen that the SIGCHLD |
76794
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5042 got lost. So raise the signal again just in case. |
23035
8d68b82a4d8c
(wait_reading_process_input): If a pty gives EIO,
Richard M. Stallman <rms@gnu.org>
parents:
22939
diff
changeset
|
5043 It can't hurt. */ |
578 | 5044 else if (nread == -1 && errno == EIO) |
76794
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5045 { |
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5046 /* Clear the descriptor now, so we only raise the signal once. */ |
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5047 FD_CLR (channel, &input_wait_mask); |
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5048 FD_CLR (channel, &non_keyboard_wait_mask); |
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5049 |
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5050 kill (getpid (), SIGCHLD); |
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5051 } |
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5052 #endif /* HAVE_PTYS */ |
648 | 5053 /* If we can detect process termination, don't consider the process |
5054 gone just because its pipe is closed. */ | |
578 | 5055 #ifdef SIGCHLD |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
5056 else if (nread == 0 && !NETCONN_P (proc) && !SERIALCONN_P (proc)) |
578 | 5057 ; |
5058 #endif | |
5059 else | |
5060 { | |
5061 /* Preserve status of processes already terminated. */ | |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5062 XPROCESS (proc)->tick = ++process_tick; |
578 | 5063 deactivate_process (proc); |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
5064 if (XPROCESS (proc)->raw_status_new) |
578 | 5065 update_status (XPROCESS (proc)); |
5066 if (EQ (XPROCESS (proc)->status, Qrun)) | |
5067 XPROCESS (proc)->status | |
5068 = Fcons (Qexit, Fcons (make_number (256), Qnil)); | |
5069 } | |
5070 } | |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
5071 #ifdef NON_BLOCKING_CONNECT |
55766
d5fe47c900ee
(wait_reading_process_input): Check connect_wait_mask
Kim F. Storm <storm@cua.dk>
parents:
55579
diff
changeset
|
5072 if (check_connect && FD_ISSET (channel, &Connecting) |
d5fe47c900ee
(wait_reading_process_input): Check connect_wait_mask
Kim F. Storm <storm@cua.dk>
parents:
55579
diff
changeset
|
5073 && FD_ISSET (channel, &connect_wait_mask)) |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5074 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5075 struct Lisp_Process *p; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5076 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5077 FD_CLR (channel, &connect_wait_mask); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5078 if (--num_pending_connects < 0) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5079 abort (); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5080 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5081 proc = chan_process[channel]; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5082 if (NILP (proc)) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5083 continue; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5084 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5085 p = XPROCESS (proc); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5086 |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5087 #ifdef GNU_LINUX |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5088 /* getsockopt(,,SO_ERROR,,) is said to hang on some systems. |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
5089 So only use it on systems where it is known to work. */ |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5090 { |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5091 int xlen = sizeof(xerrno); |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5092 if (getsockopt(channel, SOL_SOCKET, SO_ERROR, &xerrno, &xlen)) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5093 xerrno = errno; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5094 } |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5095 #else |
44013
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5096 { |
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5097 struct sockaddr pname; |
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5098 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
|
5099 |
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5100 /* 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
|
5101 xerrno = 0; |
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5102 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
|
5103 { |
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5104 /* 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
|
5105 char dummy; |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5106 xerrno = errno; |
44013
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5107 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
|
5108 xerrno = errno; |
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5109 } |
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Janík <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5110 } |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5111 #endif |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5112 if (xerrno) |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5113 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5114 p->tick = ++process_tick; |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5115 p->status = Fcons (Qfailed, Fcons (make_number (xerrno), Qnil)); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5116 deactivate_process (proc); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5117 } |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5118 else |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5119 { |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5120 p->status = Qrun; |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5121 /* Execute the sentinel here. If we had relied on |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5122 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
|
5123 from the process before calling the sentinel. */ |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5124 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
|
5125 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
|
5126 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5127 FD_SET (p->infd, &input_wait_mask); |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5128 FD_SET (p->infd, &non_keyboard_wait_mask); |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5129 } |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5130 } |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5131 } |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5132 #endif /* NON_BLOCKING_CONNECT */ |
648 | 5133 } /* end for each file descriptor */ |
5134 } /* end while exit conditions not met */ | |
5135 | |
72277
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
5136 unbind_to (count, Qnil); |
8570
dd3dfde8f973
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
8390
diff
changeset
|
5137 |
648 | 5138 /* If calling from keyboard input, do not quit |
5139 since we want to return C-g as an input character. | |
5140 Otherwise, do pending quit if requested. */ | |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
5141 if (read_kbd >= 0) |
648 | 5142 { |
5143 /* Prevent input_pending from remaining set if we quit. */ | |
5144 clear_input_pending (); | |
5145 QUIT; | |
5146 } | |
25009
5733af0b62ce
(wait_reading_process_input): Show and hide busy
Gerd Moellmann <gerd@gnu.org>
parents:
24933
diff
changeset
|
5147 |
578 | 5148 return got_some_input; |
5149 } | |
5150 | |
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5151 /* 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
|
5152 |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5153 static Lisp_Object |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5154 read_process_output_call (fun_and_args) |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5155 Lisp_Object fun_and_args; |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5156 { |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
5157 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
|
5158 } |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5159 |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5160 static Lisp_Object |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5161 read_process_output_error_handler (error) |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5162 Lisp_Object error; |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5163 { |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5164 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
|
5165 Vinhibit_quit = Qt; |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5166 update_echo_area (); |
11277
d4547e4b0aab
(read_process_output_error_handler)
Richard M. Stallman <rms@gnu.org>
parents:
11235
diff
changeset
|
5167 Fsleep_for (make_number (2), Qnil); |
27558 | 5168 return Qt; |
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5169 } |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5170 |
578 | 5171 /* Read pending output from the process channel, |
5172 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
|
5173 Yield number of decoded characters read. |
578 | 5174 |
55962
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
5175 This function reads at most 4096 characters. |
578 | 5176 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
|
5177 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
|
5178 |
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5179 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
|
5180 for decoding. */ |
578 | 5181 |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
5182 static int |
578 | 5183 read_process_output (proc, channel) |
5184 Lisp_Object proc; | |
5185 register int channel; | |
5186 { | |
52527
3ea59ac8dfa5
(Fnetwork_interface_info): Fix type error.
Dave Love <fx@gnu.org>
parents:
52525
diff
changeset
|
5187 register int nbytes; |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5188 char *chars; |
578 | 5189 register Lisp_Object outstream; |
5190 register struct Lisp_Process *p = XPROCESS (proc); | |
5191 register int opoint; | |
17110
3a348cbb354f
(Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents:
17041
diff
changeset
|
5192 struct coding_system *coding = proc_decode_coding_system[channel]; |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5193 int carryover = p->decoding_carryover; |
55962
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
5194 int readmax = 4096; |
578 | 5195 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5196 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
|
5197 if (carryover) |
5e983ddb85c9
(Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
5198 /* 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
|
5199 bcopy (SDATA (p->decoding_buf), chars, carryover); |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5200 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5201 #ifdef DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5202 /* 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
|
5203 if (DATAGRAM_CHAN_P (channel)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5204 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5205 int len = datagram_address[channel].len; |
56583
64ae47cb68ff
(read_process_output): Use whole read buffer.
Kim F. Storm <storm@cua.dk>
parents:
56477
diff
changeset
|
5206 nbytes = recvfrom (channel, chars + carryover, readmax, |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5207 0, datagram_address[channel].sa, &len); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5208 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5209 else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5210 #endif |
578 | 5211 if (proc_buffered_char[channel] < 0) |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5212 { |
56583
64ae47cb68ff
(read_process_output): Use whole read buffer.
Kim F. Storm <storm@cua.dk>
parents:
56477
diff
changeset
|
5213 nbytes = emacs_read (channel, chars + carryover, readmax); |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5214 #ifdef ADAPTIVE_READ_BUFFERING |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5215 if (nbytes > 0 && p->adaptive_read_buffering) |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5216 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5217 int delay = p->read_output_delay; |
53520
2a54a8df1973
(read_process_output): Only activate adaptive
Kim F. Storm <storm@cua.dk>
parents:
53472
diff
changeset
|
5218 if (nbytes < 256) |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5219 { |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5220 if (delay < READ_OUTPUT_DELAY_MAX_MAX) |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5221 { |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5222 if (delay == 0) |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5223 process_output_delay_count++; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5224 delay += READ_OUTPUT_DELAY_INCREMENT * 2; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5225 } |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5226 } |
56583
64ae47cb68ff
(read_process_output): Use whole read buffer.
Kim F. Storm <storm@cua.dk>
parents:
56477
diff
changeset
|
5227 else if (delay > 0 && (nbytes == readmax)) |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5228 { |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5229 delay -= READ_OUTPUT_DELAY_INCREMENT; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5230 if (delay == 0) |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5231 process_output_delay_count--; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5232 } |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5233 p->read_output_delay = delay; |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5234 if (delay) |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5235 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5236 p->read_output_skip = 1; |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5237 process_output_skip = 1; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5238 } |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5239 } |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5240 #endif |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5241 } |
578 | 5242 else |
5243 { | |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5244 chars[carryover] = proc_buffered_char[channel]; |
578 | 5245 proc_buffered_char[channel] = -1; |
56583
64ae47cb68ff
(read_process_output): Use whole read buffer.
Kim F. Storm <storm@cua.dk>
parents:
56477
diff
changeset
|
5246 nbytes = emacs_read (channel, chars + carryover + 1, readmax - 1); |
20594
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5247 if (nbytes < 0) |
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5248 nbytes = 1; |
578 | 5249 else |
20594
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5250 nbytes = nbytes + 1; |
578 | 5251 } |
5252 | |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5253 p->decoding_carryover = 0; |
22523
b02a5ea8cf93
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
22019
diff
changeset
|
5254 |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5255 /* 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
|
5256 (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
|
5257 if (nbytes <= 0) |
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
5258 { |
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
5259 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
|
5260 return nbytes; |
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
5261 coding->mode |= CODING_MODE_LAST_BLOCK; |
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
5262 } |
20594
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5263 |
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5264 /* 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
|
5265 nbytes += carryover; |
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
5266 |
20594
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5267 /* Read and dispose of the process output. */ |
578 | 5268 outstream = p->filter; |
5269 if (!NILP (outstream)) | |
5270 { | |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
5271 /* We inhibit quit here instead of just catching it so that |
578 | 5272 hitting ^G when a filter happens to be running won't screw |
5273 it up. */ | |
46293
1fb8f75062c6
Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents:
45410
diff
changeset
|
5274 int count = SPECPDL_INDEX (); |
3510
b4a552ca4e99
(read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents:
3238
diff
changeset
|
5275 Lisp_Object odeactivate; |
10914
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
5276 Lisp_Object obuffer, okeymap; |
20594
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5277 Lisp_Object text; |
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5278 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
|
5279 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
|
5280 |
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
5281 /* 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
|
5282 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
|
5283 odeactivate = Vdeactivate_mark; |
10914
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
5284 XSETBUFFER (obuffer, current_buffer); |
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
5285 okeymap = current_buffer->keymap; |
3510
b4a552ca4e99
(read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents:
3238
diff
changeset
|
5286 |
578 | 5287 specbind (Qinhibit_quit, Qt); |
8231
5226ed89c1a6
(Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
8063
diff
changeset
|
5288 specbind (Qlast_nonmenu_event, Qt); |
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5289 |
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5290 /* In case we get recursively called, |
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5291 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
|
5292 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
|
5293 if (outer_running_asynch_code) |
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5294 { |
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5295 Lisp_Object tem; |
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5296 /* Don't clobber the CURRENT match data, either! */ |
63147
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
5297 tem = Fmatch_data (Qnil, Qnil, Qnil); |
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
5298 restore_search_regs (); |
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
5299 record_unwind_save_match_data (); |
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
5300 Fset_match_data (tem, Qt); |
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5301 } |
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5302 |
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5303 /* 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
|
5304 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
|
5305 running_asynch_code = 1; |
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5306 |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5307 decode_coding_c_string (coding, chars, nbytes, Qt); |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5308 text = coding->dst_object; |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5309 Vlast_coding_system_used = CODING_ID_NAME (coding->id); |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5310 /* A new coding system might be found. */ |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5311 if (!EQ (p->decode_coding_system, Vlast_coding_system_used)) |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5312 { |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5313 p->decode_coding_system = Vlast_coding_system_used; |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5314 |
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5315 /* Don't call setup_coding_system for |
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5316 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
|
5317 detect_coding called via decode_coding above. */ |
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5318 |
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5319 /* 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
|
5320 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
|
5321 |
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5322 But, before doing that we must check if |
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5323 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
|
5324 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
|
5325 sent to the process. */ |
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5326 if (NILP (p->encode_coding_system) |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5327 && proc_encode_coding_system[p->outfd]) |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5328 { |
90392
8b24a6ec5090
(setup_process_coding_systems): Fix synching with
Kenichi Handa <handa@m17n.org>
parents:
90389
diff
changeset
|
5329 p->encode_coding_system |
8b24a6ec5090
(setup_process_coding_systems): Fix synching with
Kenichi Handa <handa@m17n.org>
parents:
90389
diff
changeset
|
5330 = coding_inherit_eol_type (Vlast_coding_system_used, Qnil); |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5331 setup_coding_system (p->encode_coding_system, |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5332 proc_encode_coding_system[p->outfd]); |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5333 } |
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5334 } |
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5335 |
89459
3e4c75be8383
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
88554
diff
changeset
|
5336 if (coding->carryover_bytes > 0) |
3e4c75be8383
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
88554
diff
changeset
|
5337 { |
89938
ab6b6e8cffe6
(read_process_output): Grow decoding_buf when needed;
Kenichi Handa <handa@m17n.org>
parents:
89909
diff
changeset
|
5338 if (SCHARS (p->decoding_buf) < coding->carryover_bytes) |
ab6b6e8cffe6
(read_process_output): Grow decoding_buf when needed;
Kenichi Handa <handa@m17n.org>
parents:
89909
diff
changeset
|
5339 p->decoding_buf = make_uninit_string (coding->carryover_bytes); |
89483 | 5340 bcopy (coding->carryover, SDATA (p->decoding_buf), |
89459
3e4c75be8383
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
88554
diff
changeset
|
5341 coding->carryover_bytes); |
90982 | 5342 p->decoding_carryover = coding->carryover_bytes; |
89459
3e4c75be8383
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
88554
diff
changeset
|
5343 } |
52093
25ad7be098ba
(read_process_output): Return the actually read bytes
Kenichi Handa <handa@m17n.org>
parents:
51637
diff
changeset
|
5344 if (SBYTES (text) > 0) |
34647
1898b3c996ff
(read_process_output): Don't run a filter if the code
Kenichi Handa <handa@m17n.org>
parents:
34352
diff
changeset
|
5345 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
|
5346 Fcons (outstream, |
1898b3c996ff
(read_process_output): Don't run a filter if the code
Kenichi Handa <handa@m17n.org>
parents:
34352
diff
changeset
|
5347 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
|
5348 !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
|
5349 read_process_output_error_handler); |
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5350 |
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5351 /* If we saved the match data nonrecursively, restore it now. */ |
63147
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
5352 restore_search_regs (); |
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5353 running_asynch_code = outer_running_asynch_code; |
578 | 5354 |
3666
c7ff787b096f
(read_process_output): Don't deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents:
3608
diff
changeset
|
5355 /* 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
|
5356 Vdeactivate_mark = odeactivate; |
b4a552ca4e99
(read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents:
3238
diff
changeset
|
5357 |
23460
94f4ba741f22
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
23405
diff
changeset
|
5358 /* 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
|
5359 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
|
5360 waiting_for_user_input_p = waiting; |
94f4ba741f22
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
23405
diff
changeset
|
5361 |
12808
4db1f387e85f
(read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents:
12749
diff
changeset
|
5362 #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
|
5363 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
|
5364 that affect key bindings. */ |
10914
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
5365 if (! EQ (Fcurrent_buffer (), obuffer) |
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
5366 || ! EQ (current_buffer->keymap, okeymap)) |
12808
4db1f387e85f
(read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents:
12749
diff
changeset
|
5367 #endif |
13159
2af96ac471bc
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
12808
diff
changeset
|
5368 /* 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
|
5369 Otherwise there's no need to make him wake up, and it could |
71762 | 5370 cause trouble (for example it would make sit_for return). */ |
13159
2af96ac471bc
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
12808
diff
changeset
|
5371 if (waiting_for_user_input_p == -1) |
2af96ac471bc
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
12808
diff
changeset
|
5372 record_asynch_buffer_change (); |
6748
b1cde622fa65
(read_process_output): If buffer changes, record that fact.
Karl Heuer <kwzh@gnu.org>
parents:
6569
diff
changeset
|
5373 |
5561
fd7524d61a8d
(read_process_output): Supply second arg to unbind_to.
Richard M. Stallman <rms@gnu.org>
parents:
5548
diff
changeset
|
5374 unbind_to (count, Qnil); |
52093
25ad7be098ba
(read_process_output): Return the actually read bytes
Kenichi Handa <handa@m17n.org>
parents:
51637
diff
changeset
|
5375 return nbytes; |
578 | 5376 } |
5377 | |
5378 /* If no filter, write into buffer if it isn't dead. */ | |
5379 if (!NILP (p->buffer) && !NILP (XBUFFER (p->buffer)->name)) | |
5380 { | |
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5381 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
|
5382 int old_begv, old_zv; |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5383 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
|
5384 Lisp_Object odeactivate; |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5385 int before, before_byte; |
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5386 int opoint_byte; |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5387 Lisp_Object text; |
34352
642fb6c53a10
(read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents:
32864
diff
changeset
|
5388 struct buffer *b; |
103134
9569175bb813
(read_process_output): Make sure the current buffer is
Andreas Schwab <schwab@linux-m68k.org>
parents:
103108
diff
changeset
|
5389 int count = SPECPDL_INDEX (); |
3510
b4a552ca4e99
(read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents:
3238
diff
changeset
|
5390 |
b4a552ca4e99
(read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents:
3238
diff
changeset
|
5391 odeactivate = Vdeactivate_mark; |
578 | 5392 |
103134
9569175bb813
(read_process_output): Make sure the current buffer is
Andreas Schwab <schwab@linux-m68k.org>
parents:
103108
diff
changeset
|
5393 record_unwind_protect (Fset_buffer, Fcurrent_buffer ()); |
578 | 5394 Fset_buffer (p->buffer); |
16039
855c8d8ba0f0
Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents:
15895
diff
changeset
|
5395 opoint = PT; |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5396 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
|
5397 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
|
5398 old_begv = BEGV; |
77b137e2d9a7
(read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents:
17247
diff
changeset
|
5399 old_zv = ZV; |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5400 old_begv_byte = BEGV_BYTE; |
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5401 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
|
5402 |
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5403 current_buffer->read_only = Qnil; |
578 | 5404 |
5405 /* Insert new output into buffer | |
5406 at the current end-of-output marker, | |
5407 thus preserving logical ordering of input and output. */ | |
5408 if (XMARKER (p->mark)->buffer) | |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5409 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
|
5410 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
|
5411 ZV_BYTE)); |
578 | 5412 else |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5413 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
|
5414 before = PT; |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5415 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
|
5416 |
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5417 /* 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
|
5418 the restriction and widen. */ |
16039
855c8d8ba0f0
Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents:
15895
diff
changeset
|
5419 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
|
5420 Fwiden (); |
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5421 |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5422 decode_coding_c_string (coding, chars, nbytes, Qt); |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5423 text = coding->dst_object; |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5424 Vlast_coding_system_used = CODING_ID_NAME (coding->id); |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5425 /* 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
|
5426 similar code in the previous `if' block. */ |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5427 if (!EQ (p->decode_coding_system, Vlast_coding_system_used)) |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5428 { |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5429 p->decode_coding_system = Vlast_coding_system_used; |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5430 if (NILP (p->encode_coding_system) |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5431 && proc_encode_coding_system[p->outfd]) |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5432 { |
90392
8b24a6ec5090
(setup_process_coding_systems): Fix synching with
Kenichi Handa <handa@m17n.org>
parents:
90389
diff
changeset
|
5433 p->encode_coding_system |
8b24a6ec5090
(setup_process_coding_systems): Fix synching with
Kenichi Handa <handa@m17n.org>
parents:
90389
diff
changeset
|
5434 = coding_inherit_eol_type (Vlast_coding_system_used, Qnil); |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5435 setup_coding_system (p->encode_coding_system, |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5436 proc_encode_coding_system[p->outfd]); |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5437 } |
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5438 } |
89459
3e4c75be8383
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
88554
diff
changeset
|
5439 if (coding->carryover_bytes > 0) |
3e4c75be8383
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
88554
diff
changeset
|
5440 { |
89938
ab6b6e8cffe6
(read_process_output): Grow decoding_buf when needed;
Kenichi Handa <handa@m17n.org>
parents:
89909
diff
changeset
|
5441 if (SCHARS (p->decoding_buf) < coding->carryover_bytes) |
ab6b6e8cffe6
(read_process_output): Grow decoding_buf when needed;
Kenichi Handa <handa@m17n.org>
parents:
89909
diff
changeset
|
5442 p->decoding_buf = make_uninit_string (coding->carryover_bytes); |
89483 | 5443 bcopy (coding->carryover, SDATA (p->decoding_buf), |
89459
3e4c75be8383
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
88554
diff
changeset
|
5444 coding->carryover_bytes); |
90982 | 5445 p->decoding_carryover = coding->carryover_bytes; |
89459
3e4c75be8383
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
88554
diff
changeset
|
5446 } |
31419
bd258f4dc0fa
(read_process_output): Before inserting the decoded
Kenichi Handa <handa@m17n.org>
parents:
31136
diff
changeset
|
5447 /* 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
|
5448 if (NILP (current_buffer->enable_multibyte_characters) |
bd258f4dc0fa
(read_process_output): Before inserting the decoded
Kenichi Handa <handa@m17n.org>
parents:
31136
diff
changeset
|
5449 != ! STRING_MULTIBYTE (text)) |
bd258f4dc0fa
(read_process_output): Before inserting the decoded
Kenichi Handa <handa@m17n.org>
parents:
31136
diff
changeset
|
5450 text = (STRING_MULTIBYTE (text) |
32395
11b8c07e5fed
(read_process_output): Cancel previous change.
Kenichi Handa <handa@m17n.org>
parents:
32371
diff
changeset
|
5451 ? Fstring_as_unibyte (text) |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
5452 : Fstring_to_multibyte (text)); |
32395
11b8c07e5fed
(read_process_output): Cancel previous change.
Kenichi Handa <handa@m17n.org>
parents:
32371
diff
changeset
|
5453 /* 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
|
5454 the buffer's mark is, and the user's next command is Meta-y. */ |
52093
25ad7be098ba
(read_process_output): Return the actually read bytes
Kenichi Handa <handa@m17n.org>
parents:
51637
diff
changeset
|
5455 insert_from_string_before_markers (text, 0, 0, |
25ad7be098ba
(read_process_output): Return the actually read bytes
Kenichi Handa <handa@m17n.org>
parents:
51637
diff
changeset
|
5456 SCHARS (text), SBYTES (text), 0); |
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
5457 |
34352
642fb6c53a10
(read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents:
32864
diff
changeset
|
5458 /* 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
|
5459 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
|
5460 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
|
5461 if (BUFFERP (p->buffer) |
642fb6c53a10
(read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents:
32864
diff
changeset
|
5462 && (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
|
5463 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
|
5464 else |
642fb6c53a10
(read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents:
32864
diff
changeset
|
5465 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
|
5466 |
578 | 5467 update_mode_lines++; |
5468 | |
17604
77b137e2d9a7
(read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents:
17247
diff
changeset
|
5469 /* 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
|
5470 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
|
5471 if (opoint >= before) |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5472 { |
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5473 opoint += PT - before; |
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5474 opoint_byte += PT_BYTE - before_byte; |
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5475 } |
17604
77b137e2d9a7
(read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents:
17247
diff
changeset
|
5476 if (old_begv > before) |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5477 { |
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5478 old_begv += PT - before; |
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5479 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
|
5480 } |
17604
77b137e2d9a7
(read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents:
17247
diff
changeset
|
5481 if (old_zv >= before) |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5482 { |
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5483 old_zv += PT - before; |
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5484 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
|
5485 } |
17604
77b137e2d9a7
(read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents:
17247
diff
changeset
|
5486 |
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5487 /* 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
|
5488 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
|
5489 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
|
5490 |
3666
c7ff787b096f
(read_process_output): Don't deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents:
3608
diff
changeset
|
5491 /* 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
|
5492 Vdeactivate_mark = odeactivate; |
b4a552ca4e99
(read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents:
3238
diff
changeset
|
5493 |
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5494 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
|
5495 SET_PT_BOTH (opoint, opoint_byte); |
103134
9569175bb813
(read_process_output): Make sure the current buffer is
Andreas Schwab <schwab@linux-m68k.org>
parents:
103108
diff
changeset
|
5496 unbind_to (count, Qnil); |
578 | 5497 } |
20594
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5498 return nbytes; |
578 | 5499 } |
5500 | |
5501 DEFUN ("waiting-for-user-input-p", Fwaiting_for_user_input_p, Swaiting_for_user_input_p, | |
5502 0, 0, 0, | |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
5503 doc: /* Returns non-nil if Emacs is waiting for input from the user. |
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
5504 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
|
5505 () |
578 | 5506 { |
7352
ef89b78c1a92
(wait_reading_process_input): Don't call prepare_menu_bars
Richard M. Stallman <rms@gnu.org>
parents:
7266
diff
changeset
|
5507 return (waiting_for_user_input_p ? Qt : Qnil); |
578 | 5508 } |
5509 | |
5510 /* Sending data to subprocess */ | |
5511 | |
5512 jmp_buf send_process_frame; | |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5513 Lisp_Object process_sent_to; |
578 | 5514 |
5515 SIGTYPE | |
5516 send_process_trap () | |
5517 { | |
58986
59945307b86b
* syssignal.h: Declare main_thread.
Jan Djärv <jan.h.d@swipnet.se>
parents:
58082
diff
changeset
|
5518 SIGNAL_THREAD_CHECK (SIGPIPE); |
62334
f9dc4e8a41fe
(send_process_trap): Unblock SIGPIPE.
Richard M. Stallman <rms@gnu.org>
parents:
60892
diff
changeset
|
5519 sigunblock (sigmask (SIGPIPE)); |
578 | 5520 longjmp (send_process_frame, 1); |
5521 } | |
5522 | |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5523 /* Send some data to process PROC. |
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5524 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
|
5525 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
|
5526 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
|
5527 |
21acd0c60f5d
(send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents:
32395
diff
changeset
|
5528 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
|
5529 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
|
5530 |
336858b2b11a
(send_process): Add a hint that the function
Gerd Moellmann <gerd@gnu.org>
parents:
28012
diff
changeset
|
5531 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
|
5532 |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
5533 static void |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5534 send_process (proc, buf, len, object) |
11926
40d7e6f04ebe
(create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents:
11845
diff
changeset
|
5535 volatile Lisp_Object proc; |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5536 unsigned char *volatile buf; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5537 volatile int len; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5538 volatile Lisp_Object object; |
578 | 5539 { |
11926
40d7e6f04ebe
(create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents:
11845
diff
changeset
|
5540 /* Use volatile to protect variables from being clobbered by longjmp. */ |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5541 struct Lisp_Process *p = XPROCESS (proc); |
578 | 5542 int rv; |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5543 struct coding_system *coding; |
15895
85112cca0b22
(send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents:
15717
diff
changeset
|
5544 struct gcpro gcpro1; |
62604
324a4f7ffebc
(send_process): Move misplaced volatile.
Andreas Schwab <schwab@suse.de>
parents:
62602
diff
changeset
|
5545 SIGTYPE (*volatile old_sigpipe) (); |
15895
85112cca0b22
(send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents:
15717
diff
changeset
|
5546 |
85112cca0b22
(send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents:
15717
diff
changeset
|
5547 GCPRO1 (object); |
578 | 5548 |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
5549 if (p->raw_status_new) |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5550 update_status (p); |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5551 if (! EQ (p->status, Qrun)) |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5552 error ("Process %s not running", SDATA (p->name)); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5553 if (p->outfd < 0) |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5554 error ("Output file descriptor of %s is closed", SDATA (p->name)); |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5555 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5556 coding = proc_encode_coding_system[p->outfd]; |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5557 Vlast_coding_system_used = CODING_ID_NAME (coding->id); |
20433
a43789debf48
(read_process_output): Fix previous change, i.e, if
Kenichi Handa <handa@m17n.org>
parents:
20428
diff
changeset
|
5558 |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5559 if ((STRINGP (object) && STRING_MULTIBYTE (object)) |
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5560 || (BUFFERP (object) |
32864
21acd0c60f5d
(send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents:
32395
diff
changeset
|
5561 && !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
|
5562 || EQ (object, Qt)) |
31136
d1344c992a9a
(create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents:
31099
diff
changeset
|
5563 { |
89909 | 5564 if (!EQ (Vlast_coding_system_used, p->encode_coding_system)) |
31136
d1344c992a9a
(create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents:
31099
diff
changeset
|
5565 /* 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
|
5566 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
|
5567 sending a multibyte text, thus we must encode it by the |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5568 original coding system specified for the current process. */ |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5569 setup_coding_system (p->encode_coding_system, coding); |
42600
93254645e03b
(send_process): Set src_multibyte to 1 after the call
Eli Zaretskii <eliz@gnu.org>
parents:
41969
diff
changeset
|
5570 coding->src_multibyte = 1; |
31136
d1344c992a9a
(create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents:
31099
diff
changeset
|
5571 } |
d1344c992a9a
(create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents:
31099
diff
changeset
|
5572 else |
d1344c992a9a
(create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents:
31099
diff
changeset
|
5573 { |
32864
21acd0c60f5d
(send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents:
32395
diff
changeset
|
5574 /* 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
|
5575 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
|
5576 or one of the subsidiary if we have not yet done it. */ |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5577 if (CODING_REQUIRE_ENCODING (coding)) |
32864
21acd0c60f5d
(send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents:
32395
diff
changeset
|
5578 { |
21acd0c60f5d
(send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents:
32395
diff
changeset
|
5579 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
|
5580 { |
21acd0c60f5d
(send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents:
32395
diff
changeset
|
5581 /* 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
|
5582 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
|
5583 send_process (proc, "", 0, Qt); |
89483 | 5584 coding->mode &= CODING_MODE_LAST_BLOCK; |
32864
21acd0c60f5d
(send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents:
32395
diff
changeset
|
5585 } |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5586 setup_coding_system (raw_text_coding_system |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5587 (Vlast_coding_system_used), |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5588 coding); |
32864
21acd0c60f5d
(send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents:
32395
diff
changeset
|
5589 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
|
5590 } |
31136
d1344c992a9a
(create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents:
31099
diff
changeset
|
5591 } |
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
5592 coding->dst_multibyte = 0; |
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
5593 |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5594 if (CODING_REQUIRE_ENCODING (coding)) |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5595 { |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5596 coding->dst_object = Qt; |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5597 if (BUFFERP (object)) |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5598 { |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5599 int from_byte, from, to; |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5600 int save_pt, save_pt_byte; |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5601 struct buffer *cur = current_buffer; |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5602 |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5603 set_buffer_internal (XBUFFER (object)); |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5604 save_pt = PT, save_pt_byte = PT_BYTE; |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5605 |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5606 from_byte = PTR_BYTE_POS (buf); |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5607 from = BYTE_TO_CHAR (from_byte); |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5608 to = BYTE_TO_CHAR (from_byte + len); |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5609 TEMP_SET_PT_BOTH (from, from_byte); |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5610 encode_coding_object (coding, object, from, from_byte, |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5611 to, from_byte + len, Qt); |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5612 TEMP_SET_PT_BOTH (save_pt, save_pt_byte); |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5613 set_buffer_internal (cur); |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5614 } |
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5615 else if (STRINGP (object)) |
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5616 { |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5617 encode_coding_string (coding, object, 1); |
39429
9de129194439
(send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents:
39406
diff
changeset
|
5618 } |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5619 else |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5620 { |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5621 coding->dst_object = make_unibyte_string (buf, len); |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5622 coding->produced = len; |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5623 } |
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5624 |
20715
5e983ddb85c9
(Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
5625 len = coding->produced; |
89483 | 5626 buf = SDATA (coding->dst_object); |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5627 } |
578 | 5628 |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5629 if (pty_max_bytes == 0) |
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5630 { |
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5631 #if defined (HAVE_FPATHCONF) && defined (_PC_MAX_CANON) |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5632 pty_max_bytes = fpathconf (p->outfd, _PC_MAX_CANON); |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5633 if (pty_max_bytes < 0) |
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5634 pty_max_bytes = 250; |
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5635 #else |
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5636 pty_max_bytes = 250; |
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5637 #endif |
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5638 /* Deduct one, to leave space for the eof. */ |
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5639 pty_max_bytes--; |
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5640 } |
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5641 |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5642 /* 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
|
5643 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
|
5644 when returning with longjmp despite being declared volatile. */ |
578 | 5645 if (!setjmp (send_process_frame)) |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5646 { |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5647 process_sent_to = proc; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5648 while (len > 0) |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5649 { |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5650 int this = len; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5651 |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5652 /* 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
|
5653 Long lines need to be split into multiple batches. */ |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5654 if (p->pty_flag) |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5655 { |
39812
66e0816837a8
Update calls to openp.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
39429
diff
changeset
|
5656 /* Starting this at zero is always correct when not the first |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
5657 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
|
5658 It may not be correct for the first iteration |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5659 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
|
5660 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
|
5661 in the process object. */ |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5662 int linepos = 0; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5663 unsigned char *ptr = (unsigned char *) buf; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5664 unsigned char *end = (unsigned char *) buf + len; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5665 |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5666 /* 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
|
5667 while (ptr != end && linepos < pty_max_bytes) |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5668 { |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5669 if (*ptr == '\n') |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5670 linepos = 0; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5671 else |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5672 linepos++; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5673 ptr++; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5674 } |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5675 /* If we found one, break the line there |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5676 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
|
5677 this = ptr - buf; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5678 } |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5679 |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5680 /* Send this batch, using one or more write calls. */ |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5681 while (this > 0) |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5682 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5683 int outfd = p->outfd; |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5684 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
|
5685 #ifdef DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5686 if (DATAGRAM_CHAN_P (outfd)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5687 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5688 rv = sendto (outfd, (char *) buf, this, |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5689 0, datagram_address[outfd].sa, |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5690 datagram_address[outfd].len); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5691 if (rv < 0 && errno == EMSGSIZE) |
62334
f9dc4e8a41fe
(send_process_trap): Unblock SIGPIPE.
Richard M. Stallman <rms@gnu.org>
parents:
60892
diff
changeset
|
5692 { |
f9dc4e8a41fe
(send_process_trap): Unblock SIGPIPE.
Richard M. Stallman <rms@gnu.org>
parents:
60892
diff
changeset
|
5693 signal (SIGPIPE, old_sigpipe); |
f9dc4e8a41fe
(send_process_trap): Unblock SIGPIPE.
Richard M. Stallman <rms@gnu.org>
parents:
60892
diff
changeset
|
5694 report_file_error ("sending datagram", |
f9dc4e8a41fe
(send_process_trap): Unblock SIGPIPE.
Richard M. Stallman <rms@gnu.org>
parents:
60892
diff
changeset
|
5695 Fcons (proc, Qnil)); |
f9dc4e8a41fe
(send_process_trap): Unblock SIGPIPE.
Richard M. Stallman <rms@gnu.org>
parents:
60892
diff
changeset
|
5696 } |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5697 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5698 else |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5699 #endif |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5700 { |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5701 rv = emacs_write (outfd, (char *) buf, this); |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5702 #ifdef ADAPTIVE_READ_BUFFERING |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5703 if (p->read_output_delay > 0 |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5704 && p->adaptive_read_buffering == 1) |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5705 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5706 p->read_output_delay = 0; |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5707 process_output_delay_count--; |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5708 p->read_output_skip = 0; |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5709 } |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5710 #endif |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5711 } |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5712 signal (SIGPIPE, old_sigpipe); |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5713 |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5714 if (rv < 0) |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5715 { |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5716 if (0 |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5717 #ifdef EWOULDBLOCK |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5718 || errno == EWOULDBLOCK |
6158 | 5719 #endif |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5720 #ifdef EAGAIN |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5721 || errno == EAGAIN |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5722 #endif |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5723 ) |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
5724 /* Buffer is full. Wait, accepting input; |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5725 that may allow the program |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5726 to finish doing output and read more. */ |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5727 { |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5728 int offset = 0; |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5729 |
27705
2c53eb482802
(send_process) [BROKEN_PTY_READ_AFTER_EAGAIN]:
Gerd Moellmann <gerd@gnu.org>
parents:
27669
diff
changeset
|
5730 #ifdef BROKEN_PTY_READ_AFTER_EAGAIN |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5731 /* 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
|
5732 In the following sequence, read(2) returns |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5733 bogus data: |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5734 |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5735 write(2) 1022 bytes |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5736 write(2) 954 bytes, get EAGAIN |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5737 read(2) 1024 bytes in process_read_output |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5738 read(2) 11 bytes in process_read_output |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5739 |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5740 That is, read(2) returns more bytes than have |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5741 ever been written successfully. The 1033 bytes |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5742 read are the 1022 bytes written successfully |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5743 after processing (for example with CRs added if |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5744 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
|
5745 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
|
5746 later read(2), without the CRs. */ |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
5747 |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5748 if (errno == EAGAIN) |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5749 { |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5750 int flags = FWRITE; |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5751 ioctl (p->outfd, TIOCFLUSH, &flags); |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5752 } |
27705
2c53eb482802
(send_process) [BROKEN_PTY_READ_AFTER_EAGAIN]:
Gerd Moellmann <gerd@gnu.org>
parents:
27669
diff
changeset
|
5753 #endif /* BROKEN_PTY_READ_AFTER_EAGAIN */ |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
5754 |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5755 /* Running filters might relocate buffers or strings. |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5756 Arrange to relocate BUF. */ |
101932
06f397da7b55
(send_process): Properly relocate pointer into data
Andreas Schwab <schwab@suse.de>
parents:
101649
diff
changeset
|
5757 if (CODING_REQUIRE_ENCODING (coding)) |
06f397da7b55
(send_process): Properly relocate pointer into data
Andreas Schwab <schwab@suse.de>
parents:
101649
diff
changeset
|
5758 offset = buf - SDATA (coding->dst_object); |
06f397da7b55
(send_process): Properly relocate pointer into data
Andreas Schwab <schwab@suse.de>
parents:
101649
diff
changeset
|
5759 else if (BUFFERP (object)) |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5760 offset = BUF_PTR_BYTE_POS (XBUFFER (object), buf); |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5761 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
|
5762 offset = buf - SDATA (object); |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5763 |
16718
ea26040865cb
(send_process) [EMACS_HAS_USECS]:
Richard M. Stallman <rms@gnu.org>
parents:
16644
diff
changeset
|
5764 #ifdef EMACS_HAS_USECS |
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
5765 wait_reading_process_output (0, 20000, 0, 0, Qnil, NULL, 0); |
16718
ea26040865cb
(send_process) [EMACS_HAS_USECS]:
Richard M. Stallman <rms@gnu.org>
parents:
16644
diff
changeset
|
5766 #else |
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
5767 wait_reading_process_output (1, 0, 0, 0, Qnil, NULL, 0); |
16718
ea26040865cb
(send_process) [EMACS_HAS_USECS]:
Richard M. Stallman <rms@gnu.org>
parents:
16644
diff
changeset
|
5768 #endif |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5769 |
101932
06f397da7b55
(send_process): Properly relocate pointer into data
Andreas Schwab <schwab@suse.de>
parents:
101649
diff
changeset
|
5770 if (CODING_REQUIRE_ENCODING (coding)) |
06f397da7b55
(send_process): Properly relocate pointer into data
Andreas Schwab <schwab@suse.de>
parents:
101649
diff
changeset
|
5771 buf = offset + SDATA (coding->dst_object); |
06f397da7b55
(send_process): Properly relocate pointer into data
Andreas Schwab <schwab@suse.de>
parents:
101649
diff
changeset
|
5772 else if (BUFFERP (object)) |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5773 buf = BUF_BYTE_ADDRESS (XBUFFER (object), offset); |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5774 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
|
5775 buf = offset + SDATA (object); |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5776 |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5777 rv = 0; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5778 } |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5779 else |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5780 /* This is a real error. */ |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5781 report_file_error ("writing to process", Fcons (proc, Qnil)); |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5782 } |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5783 buf += rv; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5784 len -= rv; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5785 this -= rv; |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5786 } |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5787 |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
5788 /* If we sent just part of the string, put in an EOF (C-d) |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5789 to force it through, before we send the rest. */ |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5790 if (len > 0) |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5791 Fprocess_send_eof (proc); |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5792 } |
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5793 } |
578 | 5794 else |
5795 { | |
62581
7f6a053bbca4
(send_process): Restore the SIGPIPE handler if we catch a SIGPIPE.
Eli Zaretskii <eliz@gnu.org>
parents:
62334
diff
changeset
|
5796 signal (SIGPIPE, old_sigpipe); |
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5797 proc = process_sent_to; |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5798 p = XPROCESS (proc); |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
5799 p->raw_status_new = 0; |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5800 p->status = Fcons (Qexit, Fcons (make_number (256), Qnil)); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5801 p->tick = ++process_tick; |
578 | 5802 deactivate_process (proc); |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5803 error ("SIGPIPE raised on process %s; closed it", SDATA (p->name)); |
578 | 5804 } |
15895
85112cca0b22
(send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents:
15717
diff
changeset
|
5805 |
85112cca0b22
(send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents:
15717
diff
changeset
|
5806 UNGCPRO; |
578 | 5807 } |
5808 | |
5809 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
|
5810 3, 3, 0, |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
5811 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
|
5812 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
|
5813 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
|
5814 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
|
5815 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
|
5816 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
|
5817 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
|
5818 (process, start, end) |
578 | 5819 Lisp_Object process, start, end; |
5820 { | |
5821 Lisp_Object proc; | |
90777
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5822 int start1, end1; |
578 | 5823 |
5824 proc = get_process (process); | |
5825 validate_region (&start, &end); | |
90777
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5826 |
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5827 if (XINT (start) < GPT && XINT (end) > GPT) |
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5828 move_gap (XINT (start)); |
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5829 |
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5830 start1 = CHAR_TO_BYTE (XINT (start)); |
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5831 end1 = CHAR_TO_BYTE (XINT (end)); |
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5832 send_process (proc, BYTE_POS_ADDR (start1), end1 - start1, |
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5833 Fcurrent_buffer ()); |
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5834 |
578 | 5835 return Qnil; |
5836 } | |
5837 | |
5838 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
|
5839 2, 2, 0, |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
5840 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
|
5841 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
|
5842 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
|
5843 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
|
5844 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
|
5845 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
|
5846 (process, string) |
578 | 5847 Lisp_Object process, string; |
5848 { | |
5849 Lisp_Object proc; | |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
5850 CHECK_STRING (string); |
578 | 5851 proc = get_process (process); |
90777
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5852 send_process (proc, SDATA (string), |
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5853 SBYTES (string), string); |
578 | 5854 return Qnil; |
5855 } | |
5856 | |
49903
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5857 /* Return the foreground process group for the tty/pty that |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5858 the process P uses. */ |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5859 static int |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5860 emacs_get_tty_pgrp (p) |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5861 struct Lisp_Process *p; |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5862 { |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5863 int gid = -1; |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5864 |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
5865 #ifdef TIOCGPGRP |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5866 if (ioctl (p->infd, TIOCGPGRP, &gid) == -1 && ! NILP (p->tty_name)) |
49903
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5867 { |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5868 int fd; |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5869 /* Some OS:es (Solaris 8/9) does not allow TIOCGPGRP from the |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5870 master side. Try the slave side. */ |
93324
41f9d37301a2
(server_accept_connection): Simplify naming.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93201
diff
changeset
|
5871 fd = emacs_open (SDATA (p->tty_name), O_RDONLY, 0); |
49903
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5872 |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5873 if (fd != -1) |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5874 { |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5875 ioctl (fd, TIOCGPGRP, &gid); |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5876 emacs_close (fd); |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5877 } |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5878 } |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5879 #endif /* defined (TIOCGPGRP ) */ |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5880 |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5881 return gid; |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5882 } |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5883 |
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5884 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
|
5885 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
|
5886 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
|
5887 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
|
5888 return t unconditionally. */) |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
5889 (process) |
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5890 Lisp_Object process; |
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5891 { |
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5892 /* 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
|
5893 in a way that will cause returning t. */ |
49903
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5894 int gid; |
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5895 Lisp_Object proc; |
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5896 struct Lisp_Process *p; |
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5897 |
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5898 proc = get_process (process); |
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5899 p = XPROCESS (proc); |
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5900 |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
5901 if (!EQ (p->type, Qreal)) |
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5902 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
|
5903 SDATA (p->name)); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5904 if (p->infd < 0) |
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5905 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
|
5906 SDATA (p->name)); |
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5907 |
49903
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5908 gid = emacs_get_tty_pgrp (p); |
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5909 |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
5910 if (gid == p->pid) |
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5911 return Qnil; |
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5912 return Qt; |
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5913 } |
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5914 |
578 | 5915 /* send a signal number SIGNO to PROCESS. |
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5916 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
|
5917 that currently owns the terminal being used to communicate with PROCESS. |
578 | 5918 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
|
5919 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
|
5920 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
|
5921 |
578 | 5922 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
|
5923 right away. |
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5924 |
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5925 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
|
5926 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
|
5927 their uid, for which killpg would return an EPERM error. */ |
578 | 5928 |
1522
19ccf004b172
* process.c: (status_convert): Declare this to return a
Jim Blandy <jimb@redhat.com>
parents:
1323
diff
changeset
|
5929 static void |
578 | 5930 process_send_signal (process, signo, current_group, nomsg) |
5931 Lisp_Object process; | |
5932 int signo; | |
5933 Lisp_Object current_group; | |
5934 int nomsg; | |
5935 { | |
5936 Lisp_Object proc; | |
5937 register struct Lisp_Process *p; | |
5938 int gid; | |
5939 int no_pgrp = 0; | |
5940 | |
5941 proc = get_process (process); | |
5942 p = XPROCESS (proc); | |
5943 | |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
5944 if (!EQ (p->type, Qreal)) |
578 | 5945 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
|
5946 SDATA (p->name)); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5947 if (p->infd < 0) |
578 | 5948 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
|
5949 SDATA (p->name)); |
578 | 5950 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5951 if (!p->pty_flag) |
578 | 5952 current_group = Qnil; |
5953 | |
5954 /* 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
|
5955 if (NILP (current_group)) |
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
5956 /* Send the signal to the shell's process group. */ |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
5957 gid = p->pid; |
46411
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
5958 else |
578 | 5959 { |
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5960 #ifdef SIGNALS_VIA_CHARACTERS |
578 | 5961 /* If possible, send signals to the entire pgrp |
5962 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
|
5963 |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5964 /* TERMIOS is the latest and bestest, and seems most likely to |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
5965 work. If the system has it, use it. */ |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5966 #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
|
5967 struct termios t; |
56695
62660593b0a2
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
Richard M. Stallman <rms@gnu.org>
parents:
56583
diff
changeset
|
5968 cc_t *sig_char = NULL; |
62660593b0a2
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
Richard M. Stallman <rms@gnu.org>
parents:
56583
diff
changeset
|
5969 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5970 tcgetattr (p->infd, &t); |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5971 |
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5972 switch (signo) |
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5973 { |
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5974 case SIGINT: |
56695
62660593b0a2
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
Richard M. Stallman <rms@gnu.org>
parents:
56583
diff
changeset
|
5975 sig_char = &t.c_cc[VINTR]; |
62660593b0a2
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
Richard M. Stallman <rms@gnu.org>
parents:
56583
diff
changeset
|
5976 break; |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5977 |
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5978 case SIGQUIT: |
56695
62660593b0a2
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
Richard M. Stallman <rms@gnu.org>
parents:
56583
diff
changeset
|
5979 sig_char = &t.c_cc[VQUIT]; |
62660593b0a2
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
Richard M. Stallman <rms@gnu.org>
parents:
56583
diff
changeset
|
5980 break; |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5981 |
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5982 case SIGTSTP: |
7414
33e5afbb62bf
(process_send_signal): If PREFER_VSUSP, use VSUSP instead of VSWTCH.
Richard M. Stallman <rms@gnu.org>
parents:
7352
diff
changeset
|
5983 #if defined (VSWTCH) && !defined (PREFER_VSUSP) |
56695
62660593b0a2
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
Richard M. Stallman <rms@gnu.org>
parents:
56583
diff
changeset
|
5984 sig_char = &t.c_cc[VSWTCH]; |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5985 #else |
56695
62660593b0a2
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
Richard M. Stallman <rms@gnu.org>
parents:
56583
diff
changeset
|
5986 sig_char = &t.c_cc[VSUSP]; |
62660593b0a2
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
Richard M. Stallman <rms@gnu.org>
parents:
56583
diff
changeset
|
5987 #endif |
62660593b0a2
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
Richard M. Stallman <rms@gnu.org>
parents:
56583
diff
changeset
|
5988 break; |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5989 } |
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5990 |
56713
7e315ff338bf
(process_send_signal): Use CDISABLE.
Kim F. Storm <storm@cua.dk>
parents:
56701
diff
changeset
|
5991 if (sig_char && *sig_char != CDISABLE) |
56770
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
5992 { |
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
5993 send_process (proc, sig_char, 1, Qnil); |
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
5994 return; |
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
5995 } |
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
5996 /* If we can't send the signal with a character, |
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
5997 fall through and send it another way. */ |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5998 #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
|
5999 |
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
6000 /* 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
|
6001 current control characters. */ |
578 | 6002 #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
|
6003 |
578 | 6004 struct tchars c; |
6005 struct ltchars lc; | |
6006 | |
6007 switch (signo) | |
6008 { | |
6009 case SIGINT: | |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6010 ioctl (p->infd, TIOCGETC, &c); |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
6011 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
|
6012 return; |
578 | 6013 case SIGQUIT: |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6014 ioctl (p->infd, TIOCGETC, &c); |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
6015 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
|
6016 return; |
1012
a48ed1d416dd
* process.c (process_send_signal): Don't send SIGTSTP if the
Jim Blandy <jimb@redhat.com>
parents:
849
diff
changeset
|
6017 #ifdef SIGTSTP |
578 | 6018 case SIGTSTP: |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6019 ioctl (p->infd, TIOCGLTC, &lc); |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
6020 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
|
6021 return; |
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
6022 #endif /* ! defined (SIGTSTP) */ |
578 | 6023 } |
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
6024 |
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
6025 #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
|
6026 |
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
6027 /* 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
|
6028 characters. */ |
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
6029 #ifdef TCGETA |
578 | 6030 struct termio t; |
6031 switch (signo) | |
6032 { | |
6033 case SIGINT: | |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6034 ioctl (p->infd, TCGETA, &t); |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
6035 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
|
6036 return; |
578 | 6037 case SIGQUIT: |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6038 ioctl (p->infd, TCGETA, &t); |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
6039 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
|
6040 return; |
1569
52a69b6a8f96
* process.c [SYSV]: Don't include <termios.h>, <termio.h>, or
Jim Blandy <jimb@redhat.com>
parents:
1522
diff
changeset
|
6041 #ifdef SIGTSTP |
578 | 6042 case SIGTSTP: |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6043 ioctl (p->infd, TCGETA, &t); |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
6044 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
|
6045 return; |
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
6046 #endif /* ! defined (SIGTSTP) */ |
578 | 6047 } |
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
6048 #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
|
6049 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
|
6050 /* 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
|
6051 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
|
6052 #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
|
6053 #endif /* ! defined (TIOCGLTC) && defined (TIOCGETC) */ |
93324
41f9d37301a2
(server_accept_connection): Simplify naming.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93201
diff
changeset
|
6054 /* In this case, the code above should alway return. */ |
46314
7c8eab7f2bd6
(process_send_signal): Add abort call.
Richard M. Stallman <rms@gnu.org>
parents:
46293
diff
changeset
|
6055 abort (); |
56770
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
6056 #endif /* ! defined HAVE_TERMIOS */ |
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
6057 |
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
6058 /* The code above may fall through if it can't |
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
6059 handle the signal. */ |
46314
7c8eab7f2bd6
(process_send_signal): Add abort call.
Richard M. Stallman <rms@gnu.org>
parents:
46293
diff
changeset
|
6060 #endif /* defined (SIGNALS_VIA_CHARACTERS) */ |
849 | 6061 |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6062 #ifdef TIOCGPGRP |
46411
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
6063 /* Get the current pgrp using the tty itself, if we have that. |
578 | 6064 Otherwise, use the pty to get the pgrp. |
6065 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
|
6066 "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
|
6067 But, TIOCGPGRP does not work on E50 ;-P works fine on E60" |
578 | 6068 His patch indicates that if TIOCGPGRP returns an error, then |
6069 we should just assume that p->pid is also the process group id. */ | |
49903
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
6070 |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
6071 gid = emacs_get_tty_pgrp (p); |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6072 |
49903
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
6073 if (gid == -1) |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
6074 /* If we can't get the information, assume |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
6075 the shell owns the tty. */ |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6076 gid = p->pid; |
46411
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
6077 |
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
6078 /* 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
|
6079 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
|
6080 Or perhaps this is vestigial. */ |
578 | 6081 if (gid == -1) |
6082 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
|
6083 #else /* ! defined (TIOCGPGRP ) */ |
849 | 6084 /* Can't select pgrps on this system, so we know that |
6085 the child itself heads the pgrp. */ | |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6086 gid = p->pid; |
849 | 6087 #endif /* ! defined (TIOCGPGRP ) */ |
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
6088 |
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
6089 /* 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
|
6090 don't send any signal. */ |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6091 if (EQ (current_group, Qlambda) && gid == p->pid) |
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
6092 return; |
578 | 6093 } |
6094 | |
6095 switch (signo) | |
6096 { | |
6097 #ifdef SIGCONT | |
6098 case SIGCONT: | |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6099 p->raw_status_new = 0; |
578 | 6100 p->status = Qrun; |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6101 p->tick = ++process_tick; |
578 | 6102 if (!nomsg) |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
6103 status_notify (NULL); |
578 | 6104 break; |
849 | 6105 #endif /* ! defined (SIGCONT) */ |
578 | 6106 case SIGINT: |
6107 case SIGQUIT: | |
6108 case SIGKILL: | |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6109 flush_pending_output (p->infd); |
578 | 6110 break; |
6111 } | |
6112 | |
6113 /* If we don't have process groups, send the signal to the immediate | |
6114 subprocess. That isn't really right, but it's better than any | |
6115 obvious alternative. */ | |
6116 if (no_pgrp) | |
6117 { | |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6118 kill (p->pid, signo); |
578 | 6119 return; |
6120 } | |
6121 | |
6122 /* gid may be a pid, or minus a pgrp's number */ | |
6123 #ifdef TIOCSIGSEND | |
6124 if (!NILP (current_group)) | |
49903
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
6125 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6126 if (ioctl (p->infd, TIOCSIGSEND, signo) == -1) |
49903
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
6127 EMACS_KILLPG (gid, signo); |
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Djärv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
6128 } |
578 | 6129 else |
6130 { | |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6131 gid = - p->pid; |
578 | 6132 kill (gid, signo); |
6133 } | |
849 | 6134 #else /* ! defined (TIOCSIGSEND) */ |
46411
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
6135 EMACS_KILLPG (gid, signo); |
849 | 6136 #endif /* ! defined (TIOCSIGSEND) */ |
578 | 6137 } |
6138 | |
6139 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
|
6140 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
|
6141 PROCESS may be a process, a buffer, or the name of a process or buffer. |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6142 No arg or nil means current buffer's process. |
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
6143 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
|
6144 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
|
6145 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
|
6146 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
|
6147 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
|
6148 |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
6149 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
|
6150 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
|
6151 (process, current_group) |
578 | 6152 Lisp_Object process, current_group; |
6153 { | |
6154 process_send_signal (process, SIGINT, current_group, 0); | |
6155 return process; | |
6156 } | |
6157 | |
6158 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
|
6159 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
|
6160 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
|
6161 (process, current_group) |
578 | 6162 Lisp_Object process, current_group; |
6163 { | |
6164 process_send_signal (process, SIGKILL, current_group, 0); | |
6165 return process; | |
6166 } | |
6167 | |
6168 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
|
6169 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
|
6170 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
|
6171 (process, current_group) |
578 | 6172 Lisp_Object process, current_group; |
6173 { | |
6174 process_send_signal (process, SIGQUIT, current_group, 0); | |
6175 return process; | |
6176 } | |
6177 | |
6178 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
|
6179 doc: /* Stop process PROCESS. May be process or name of one. |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6180 See function `interrupt-process' for more details on usage. |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6181 If PROCESS is a network or serial process, inhibit handling of incoming |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6182 traffic. */) |
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
6183 (process, current_group) |
578 | 6184 Lisp_Object process, current_group; |
6185 { | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6186 #ifdef HAVE_SOCKETS |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6187 if (PROCESSP (process) && (NETCONN_P (process) || SERIALCONN_P (process))) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6188 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6189 struct Lisp_Process *p; |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6190 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6191 p = XPROCESS (process); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6192 if (NILP (p->command) |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6193 && p->infd >= 0) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6194 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6195 FD_CLR (p->infd, &input_wait_mask); |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6196 FD_CLR (p->infd, &non_keyboard_wait_mask); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6197 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6198 p->command = Qt; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6199 return process; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6200 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6201 #endif |
578 | 6202 #ifndef SIGTSTP |
63701
9ef43e35d417
(Fstop_process, Fcontinue_process): Follow error conventions.
Juanma Barranquero <lekktu@gmail.com>
parents:
63615
diff
changeset
|
6203 error ("No SIGTSTP support"); |
578 | 6204 #else |
6205 process_send_signal (process, SIGTSTP, current_group, 0); | |
6206 #endif | |
6207 return process; | |
6208 } | |
6209 | |
6210 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
|
6211 doc: /* Continue process PROCESS. May be process or name of one. |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6212 See function `interrupt-process' for more details on usage. |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6213 If PROCESS is a network or serial process, resume handling of incoming |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6214 traffic. */) |
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
6215 (process, current_group) |
578 | 6216 Lisp_Object process, current_group; |
6217 { | |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6218 #ifdef HAVE_SOCKETS |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6219 if (PROCESSP (process) && (NETCONN_P (process) || SERIALCONN_P (process))) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6220 { |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6221 struct Lisp_Process *p; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6222 |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6223 p = XPROCESS (process); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6224 if (EQ (p->command, Qt) |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6225 && p->infd >= 0 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6226 && (!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
|
6227 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6228 FD_SET (p->infd, &input_wait_mask); |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6229 FD_SET (p->infd, &non_keyboard_wait_mask); |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6230 #ifdef WINDOWSNT |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6231 if (fd_info[ p->infd ].flags & FILE_SERIAL) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6232 PurgeComm (fd_info[ p->infd ].hnd, PURGE_RXABORT | PURGE_RXCLEAR); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6233 #endif |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6234 #ifdef HAVE_TERMIOS |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6235 tcflush (p->infd, TCIFLUSH); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6236 #endif |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6237 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6238 p->command = Qnil; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6239 return process; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6240 } |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6241 #endif |
578 | 6242 #ifdef SIGCONT |
6243 process_send_signal (process, SIGCONT, current_group, 0); | |
6244 #else | |
63701
9ef43e35d417
(Fstop_process, Fcontinue_process): Follow error conventions.
Juanma Barranquero <lekktu@gmail.com>
parents:
63615
diff
changeset
|
6245 error ("No SIGCONT support"); |
578 | 6246 #endif |
6247 return process; | |
6248 } | |
6249 | |
6250 DEFUN ("signal-process", Fsignal_process, Ssignal_process, | |
48053
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6251 2, 2, "sProcess (name or number): \nnSignal code: ", |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6252 doc: /* Send PROCESS the signal with code SIGCODE. |
74540
b33acab48a40
(Fsignal_process): Doc fix. Use XFLOAT_DATA to extract the process ID from
Eli Zaretskii <eliz@gnu.org>
parents:
74468
diff
changeset
|
6253 PROCESS may also be a number specifying the process id of the |
48053
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6254 process to signal; in this case, the process need not be a child of |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6255 this Emacs. |
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
6256 SIGCODE may be an integer, or a symbol whose name is a signal name. */) |
48053
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6257 (process, sigcode) |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6258 Lisp_Object process, sigcode; |
578 | 6259 { |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6260 pid_t pid; |
48053
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6261 |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6262 if (INTEGERP (process)) |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6263 { |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6264 pid = XINT (process); |
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6265 goto got_it; |
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6266 } |
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6267 |
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6268 if (FLOATP (process)) |
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6269 { |
74540
b33acab48a40
(Fsignal_process): Doc fix. Use XFLOAT_DATA to extract the process ID from
Eli Zaretskii <eliz@gnu.org>
parents:
74468
diff
changeset
|
6270 pid = (pid_t) XFLOAT_DATA (process); |
48053
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6271 goto got_it; |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6272 } |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6273 |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6274 if (STRINGP (process)) |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6275 { |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6276 Lisp_Object tem; |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6277 if (tem = Fget_process (process), NILP (tem)) |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6278 { |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6279 pid = XINT (Fstring_to_number (process, make_number (10))); |
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6280 if (pid > 0) |
48053
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6281 goto got_it; |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6282 } |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6283 process = tem; |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6284 } |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6285 else |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6286 process = get_process (process); |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6287 |
48053
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6288 if (NILP (process)) |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6289 return process; |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6290 |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6291 CHECK_PROCESS (process); |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6292 pid = XPROCESS (process)->pid; |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6293 if (pid <= 0) |
48053
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6294 error ("Cannot signal process %s", SDATA (XPROCESS (process)->name)); |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6295 |
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6296 got_it: |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6297 |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6298 #define parse_signal(NAME, VALUE) \ |
95216
ad146a8ff5dc
* dispextern.h, xfaces.c (xstrcasecmp): Renamed from xstricmp.
Jason Rumney <jasonr@gnu.org>
parents:
95111
diff
changeset
|
6299 else if (!xstrcasecmp (name, NAME)) \ |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6300 XSETINT (sigcode, VALUE) |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6301 |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6302 if (INTEGERP (sigcode)) |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6303 ; |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6304 else |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6305 { |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6306 unsigned char *name; |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6307 |
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
6308 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
|
6309 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
|
6310 |
74468
7714fd14ce36
(parse_signal): Use xstricmp instead of strcasecmp.
Kim F. Storm <storm@cua.dk>
parents:
74420
diff
changeset
|
6311 if (!strncmp(name, "SIG", 3) || !strncmp(name, "sig", 3)) |
66752
715b819a0ad8
(Fsignal_process): Recognize signal names with and
Kim F. Storm <storm@cua.dk>
parents:
65764
diff
changeset
|
6312 name += 3; |
715b819a0ad8
(Fsignal_process): Recognize signal names with and
Kim F. Storm <storm@cua.dk>
parents:
65764
diff
changeset
|
6313 |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6314 if (0) |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6315 ; |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6316 #ifdef SIGUSR1 |
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6317 parse_signal ("usr1", SIGUSR1); |
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6318 #endif |
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6319 #ifdef SIGUSR2 |
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6320 parse_signal ("usr2", SIGUSR2); |
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6321 #endif |
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6322 #ifdef SIGTERM |
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6323 parse_signal ("term", SIGTERM); |
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6324 #endif |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6325 #ifdef SIGHUP |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6326 parse_signal ("hup", SIGHUP); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6327 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6328 #ifdef SIGINT |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6329 parse_signal ("int", SIGINT); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6330 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6331 #ifdef SIGQUIT |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6332 parse_signal ("quit", SIGQUIT); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6333 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6334 #ifdef SIGILL |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6335 parse_signal ("ill", SIGILL); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6336 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6337 #ifdef SIGABRT |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6338 parse_signal ("abrt", SIGABRT); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6339 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6340 #ifdef SIGEMT |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6341 parse_signal ("emt", SIGEMT); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6342 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6343 #ifdef SIGKILL |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6344 parse_signal ("kill", SIGKILL); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6345 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6346 #ifdef SIGFPE |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6347 parse_signal ("fpe", SIGFPE); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6348 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6349 #ifdef SIGBUS |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6350 parse_signal ("bus", SIGBUS); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6351 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6352 #ifdef SIGSEGV |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6353 parse_signal ("segv", SIGSEGV); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6354 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6355 #ifdef SIGSYS |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6356 parse_signal ("sys", SIGSYS); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6357 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6358 #ifdef SIGPIPE |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6359 parse_signal ("pipe", SIGPIPE); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6360 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6361 #ifdef SIGALRM |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6362 parse_signal ("alrm", SIGALRM); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6363 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6364 #ifdef SIGURG |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6365 parse_signal ("urg", SIGURG); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6366 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6367 #ifdef SIGSTOP |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6368 parse_signal ("stop", SIGSTOP); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6369 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6370 #ifdef SIGTSTP |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6371 parse_signal ("tstp", SIGTSTP); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6372 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6373 #ifdef SIGCONT |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6374 parse_signal ("cont", SIGCONT); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6375 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6376 #ifdef SIGCHLD |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6377 parse_signal ("chld", SIGCHLD); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6378 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6379 #ifdef SIGTTIN |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6380 parse_signal ("ttin", SIGTTIN); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6381 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6382 #ifdef SIGTTOU |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6383 parse_signal ("ttou", SIGTTOU); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6384 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6385 #ifdef SIGIO |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6386 parse_signal ("io", SIGIO); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6387 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6388 #ifdef SIGXCPU |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6389 parse_signal ("xcpu", SIGXCPU); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6390 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6391 #ifdef SIGXFSZ |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6392 parse_signal ("xfsz", SIGXFSZ); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6393 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6394 #ifdef SIGVTALRM |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6395 parse_signal ("vtalrm", SIGVTALRM); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6396 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6397 #ifdef SIGPROF |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6398 parse_signal ("prof", SIGPROF); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6399 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6400 #ifdef SIGWINCH |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6401 parse_signal ("winch", SIGWINCH); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6402 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6403 #ifdef SIGINFO |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6404 parse_signal ("info", SIGINFO); |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6405 #endif |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6406 else |
11148
117b32676686
(Fsignal_process): SIGCODE is a symbol, not a string.
Karl Heuer <kwzh@gnu.org>
parents:
11144
diff
changeset
|
6407 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
|
6408 } |
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6409 |
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6410 #undef parse_signal |
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6411 |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6412 return make_number (kill (pid, XINT (sigcode))); |
578 | 6413 } |
6414 | |
6415 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
|
6416 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
|
6417 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
|
6418 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
|
6419 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
|
6420 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
|
6421 through a pipe (as opposed to a pty), then you cannot send any more |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6422 text to PROCESS after you call this function. |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6423 If PROCESS is a serial process, wait until all output written to the |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6424 process has been transmitted to the serial port. */) |
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
6425 (process) |
578 | 6426 Lisp_Object process; |
6427 { | |
6428 Lisp_Object proc; | |
23879
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
6429 struct coding_system *coding; |
578 | 6430 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6431 if (DATAGRAM_CONN_P (process)) |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6432 return process; |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6433 |
578 | 6434 proc = get_process (process); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6435 coding = proc_encode_coding_system[XPROCESS (proc)->outfd]; |
2221
7edc78402205
(Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents:
2200
diff
changeset
|
6436 |
7edc78402205
(Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents:
2200
diff
changeset
|
6437 /* Make sure the process is really alive. */ |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6438 if (XPROCESS (proc)->raw_status_new) |
2221
7edc78402205
(Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents:
2200
diff
changeset
|
6439 update_status (XPROCESS (proc)); |
7edc78402205
(Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents:
2200
diff
changeset
|
6440 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
|
6441 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
|
6442 |
23879
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
6443 if (CODING_REQUIRE_FLUSHING (coding)) |
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
6444 { |
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
6445 coding->mode |= CODING_MODE_LAST_BLOCK; |
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
6446 send_process (proc, "", 0, Qnil); |
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
6447 } |
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
6448 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6449 if (XPROCESS (proc)->pty_flag) |
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
6450 send_process (proc, "\004", 1, Qnil); |
95900
99342636fa96
(Fserial_process_configure, Fprocess_send_eof):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95884
diff
changeset
|
6451 else if (EQ (XPROCESS (proc)->type, Qserial)) |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6452 { |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6453 #ifdef HAVE_TERMIOS |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6454 if (tcdrain (XPROCESS (proc)->outfd) != 0) |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6455 error ("tcdrain() failed: %s", emacs_strerror (errno)); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6456 #endif |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6457 /* Do nothing on Windows because writes are blocking. */ |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6458 } |
578 | 6459 else |
6460 { | |
22939
572895549f80
(Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents:
22864
diff
changeset
|
6461 int old_outfd, new_outfd; |
572895549f80
(Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents:
22864
diff
changeset
|
6462 |
18329
ddaafa596bf5
(Fprocess_send_eof): Prooperly conditionalize prev. change.
Richard M. Stallman <rms@gnu.org>
parents:
18328
diff
changeset
|
6463 #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
|
6464 /* 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
|
6465 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
|
6466 (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
|
6467 Then we just can't win.) */ |
95900
99342636fa96
(Fserial_process_configure, Fprocess_send_eof):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95884
diff
changeset
|
6468 if (EQ (XPROCESS (proc)->type, Qnetwork) |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6469 || XPROCESS (proc)->outfd == XPROCESS (proc)->infd) |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6470 shutdown (XPROCESS (proc)->outfd, 1); |
18328
0295bbed3c39
(Fprocess_send_eof): Use shutdown, if it's a socket.
Richard M. Stallman <rms@gnu.org>
parents:
18292
diff
changeset
|
6471 /* In case of socketpair, outfd == infd, so don't close it. */ |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6472 if (XPROCESS (proc)->outfd != XPROCESS (proc)->infd) |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6473 emacs_close (XPROCESS (proc)->outfd); |
18329
ddaafa596bf5
(Fprocess_send_eof): Prooperly conditionalize prev. change.
Richard M. Stallman <rms@gnu.org>
parents:
18328
diff
changeset
|
6474 #else /* not HAVE_SHUTDOWN */ |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6475 emacs_close (XPROCESS (proc)->outfd); |
18329
ddaafa596bf5
(Fprocess_send_eof): Prooperly conditionalize prev. change.
Richard M. Stallman <rms@gnu.org>
parents:
18328
diff
changeset
|
6476 #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
|
6477 new_outfd = emacs_open (NULL_DEVICE, O_WRONLY, 0); |
69974
2ecef706d823
(Fprocess_send_eof): Abort if fail to open null device.
Richard M. Stallman <rms@gnu.org>
parents:
69973
diff
changeset
|
6478 if (new_outfd < 0) |
2ecef706d823
(Fprocess_send_eof): Abort if fail to open null device.
Richard M. Stallman <rms@gnu.org>
parents:
69973
diff
changeset
|
6479 abort (); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6480 old_outfd = XPROCESS (proc)->outfd; |
22939
572895549f80
(Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents:
22864
diff
changeset
|
6481 |
572895549f80
(Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents:
22864
diff
changeset
|
6482 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
|
6483 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
|
6484 = (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
|
6485 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
|
6486 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
|
6487 sizeof (struct coding_system)); |
572895549f80
(Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents:
22864
diff
changeset
|
6488 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
|
6489 sizeof (struct coding_system)); |
572895549f80
(Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents:
22864
diff
changeset
|
6490 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6491 XPROCESS (proc)->outfd = new_outfd; |
578 | 6492 } |
6493 return process; | |
6494 } | |
6495 | |
6496 /* 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
|
6497 If `buffer' is nil, kill all processes */ |
578 | 6498 |
20382
dbad9367d232
(create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents:
20225
diff
changeset
|
6499 void |
578 | 6500 kill_buffer_processes (buffer) |
6501 Lisp_Object buffer; | |
6502 { | |
6503 Lisp_Object tail, proc; | |
6504 | |
90970
3371fc48749b
Replace uses of GC_* macros with the non-GC_ versions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
90851
diff
changeset
|
6505 for (tail = Vprocess_alist; CONSP (tail); tail = XCDR (tail)) |
578 | 6506 { |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
6507 proc = XCDR (XCAR (tail)); |
90970
3371fc48749b
Replace uses of GC_* macros with the non-GC_ versions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
90851
diff
changeset
|
6508 if (PROCESSP (proc) |
578 | 6509 && (NILP (buffer) || EQ (XPROCESS (proc)->buffer, buffer))) |
6510 { | |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6511 if (NETCONN_P (proc) || SERIALCONN_P (proc)) |
7764
fad00b057e50
(kill_buffer_processes): For net conn, use Fdelete_process.
Richard M. Stallman <rms@gnu.org>
parents:
7748
diff
changeset
|
6512 Fdelete_process (proc); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6513 else if (XPROCESS (proc)->infd >= 0) |
578 | 6514 process_send_signal (proc, SIGHUP, Qnil, 1); |
6515 } | |
6516 } | |
6517 } | |
6518 | |
39361
2d3bee6a3848
(sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents:
37758
diff
changeset
|
6519 /* 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
|
6520 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
|
6521 are no more. |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6522 |
39361
2d3bee6a3848
(sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents:
37758
diff
changeset
|
6523 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
|
6524 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
|
6525 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
|
6526 |
2d3bee6a3848
(sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents:
37758
diff
changeset
|
6527 ** 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
|
6528 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
|
6529 Lisp objects. |
2d3bee6a3848
(sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents:
37758
diff
changeset
|
6530 |
2d3bee6a3848
(sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents:
37758
diff
changeset
|
6531 ** 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
|
6532 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
|
6533 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
|
6534 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
|
6535 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
|
6536 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
|
6537 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
|
6538 kernel to reexamine the SIGCLD queue. Fred Fish, UniSoft Systems |
53732
0341435e76ce
* process.c (sigchld_handler): Add comment about not calling malloc
Jan Djärv <jan.h.d@swipnet.se>
parents:
53713
diff
changeset
|
6539 Inc. |
0341435e76ce
* process.c (sigchld_handler): Add comment about not calling malloc
Jan Djärv <jan.h.d@swipnet.se>
parents:
53713
diff
changeset
|
6540 |
0341435e76ce
* process.c (sigchld_handler): Add comment about not calling malloc
Jan Djärv <jan.h.d@swipnet.se>
parents:
53713
diff
changeset
|
6541 ** Malloc WARNING: This should never call malloc either directly or |
0341435e76ce
* process.c (sigchld_handler): Add comment about not calling malloc
Jan Djärv <jan.h.d@swipnet.se>
parents:
53713
diff
changeset
|
6542 indirectly; if it does, that is a bug */ |
578 | 6543 |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6544 #ifdef SIGCHLD |
578 | 6545 SIGTYPE |
6546 sigchld_handler (signo) | |
6547 int signo; | |
6548 { | |
6549 int old_errno = errno; | |
6550 Lisp_Object proc; | |
6551 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
|
6552 extern EMACS_TIME *input_available_clear_time; |
578 | 6553 |
58986
59945307b86b
* syssignal.h: Declare main_thread.
Jan Djärv <jan.h.d@swipnet.se>
parents:
58082
diff
changeset
|
6554 SIGNAL_THREAD_CHECK (signo); |
59945307b86b
* syssignal.h: Declare main_thread.
Jan Djärv <jan.h.d@swipnet.se>
parents:
58082
diff
changeset
|
6555 |
578 | 6556 while (1) |
6557 { | |
76493
e5e12c57c640
(sigchld_handler): Change type of pid to pid_t. Scan deleted_pid_list
Chong Yidong <cyd@stupidchicken.com>
parents:
76462
diff
changeset
|
6558 pid_t pid; |
96620
3bea8ede5bd0
* syswait.h: Remove old if 0 code. Do not define WAITTYPE, it was
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96361
diff
changeset
|
6559 int w; |
578 | 6560 Lisp_Object tail; |
6561 | |
6562 #ifdef WNOHANG | |
6563 #ifndef WUNTRACED | |
6564 #define WUNTRACED 0 | |
6565 #endif /* no WUNTRACED */ | |
6566 /* Keep trying to get a status until we get a definitive result. */ | |
76718
217f3f19f471
revert the last patch to the original fix: sleep BEFORE the first wait
Sam Steingold <sds@gnu.org>
parents:
76626
diff
changeset
|
6567 do |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
6568 { |
76494
f0a25b5d3ba0
(Fdelete_process): Properly handle deletion of first element of
Chong Yidong <cyd@stupidchicken.com>
parents:
76493
diff
changeset
|
6569 errno = 0; |
f0a25b5d3ba0
(Fdelete_process): Properly handle deletion of first element of
Chong Yidong <cyd@stupidchicken.com>
parents:
76493
diff
changeset
|
6570 pid = wait3 (&w, WNOHANG | WUNTRACED, 0); |
f0a25b5d3ba0
(Fdelete_process): Properly handle deletion of first element of
Chong Yidong <cyd@stupidchicken.com>
parents:
76493
diff
changeset
|
6571 } |
76718
217f3f19f471
revert the last patch to the original fix: sleep BEFORE the first wait
Sam Steingold <sds@gnu.org>
parents:
76626
diff
changeset
|
6572 while (pid < 0 && errno == EINTR); |
578 | 6573 |
6574 if (pid <= 0) | |
6575 { | |
39361
2d3bee6a3848
(sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents:
37758
diff
changeset
|
6576 /* 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
|
6577 failure. We have done all our job, so return. */ |
578 | 6578 |
6579 /* USG systems forget handlers when they are used; | |
6580 must reestablish each time */ | |
16116
80a67b8f39e9
(create_process_1, sigchld_handler) [POSIX_SIGNALS]:
Richard M. Stallman <rms@gnu.org>
parents:
16076
diff
changeset
|
6581 #if defined (USG) && !defined (POSIX_SIGNALS) |
578 | 6582 signal (signo, sigchld_handler); /* WARNING - must come after wait3() */ |
6583 #endif | |
6584 errno = old_errno; | |
6585 return; | |
6586 } | |
6587 #else | |
6588 pid = wait (&w); | |
6589 #endif /* no WNOHANG */ | |
6590 | |
6591 /* Find the process that signaled us, and record its status. */ | |
6592 | |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6593 /* The process can have been deleted by Fdelete_process. */ |
90970
3371fc48749b
Replace uses of GC_* macros with the non-GC_ versions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
90851
diff
changeset
|
6594 for (tail = deleted_pid_list; CONSP (tail); tail = XCDR (tail)) |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6595 { |
76493
e5e12c57c640
(sigchld_handler): Change type of pid to pid_t. Scan deleted_pid_list
Chong Yidong <cyd@stupidchicken.com>
parents:
76462
diff
changeset
|
6596 Lisp_Object xpid = XCAR (tail); |
90970
3371fc48749b
Replace uses of GC_* macros with the non-GC_ versions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
90851
diff
changeset
|
6597 if ((INTEGERP (xpid) && pid == (pid_t) XINT (xpid)) |
3371fc48749b
Replace uses of GC_* macros with the non-GC_ versions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
90851
diff
changeset
|
6598 || (FLOATP (xpid) && pid == (pid_t) XFLOAT_DATA (xpid))) |
76493
e5e12c57c640
(sigchld_handler): Change type of pid to pid_t. Scan deleted_pid_list
Chong Yidong <cyd@stupidchicken.com>
parents:
76462
diff
changeset
|
6599 { |
e5e12c57c640
(sigchld_handler): Change type of pid to pid_t. Scan deleted_pid_list
Chong Yidong <cyd@stupidchicken.com>
parents:
76462
diff
changeset
|
6600 XSETCAR (tail, Qnil); |
e5e12c57c640
(sigchld_handler): Change type of pid to pid_t. Scan deleted_pid_list
Chong Yidong <cyd@stupidchicken.com>
parents:
76462
diff
changeset
|
6601 goto sigchld_end_of_loop; |
e5e12c57c640
(sigchld_handler): Change type of pid to pid_t. Scan deleted_pid_list
Chong Yidong <cyd@stupidchicken.com>
parents:
76462
diff
changeset
|
6602 } |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6603 } |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6604 |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6605 /* Otherwise, if it is asynchronous, it is in Vprocess_alist. */ |
578 | 6606 p = 0; |
90970
3371fc48749b
Replace uses of GC_* macros with the non-GC_ versions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
90851
diff
changeset
|
6607 for (tail = Vprocess_alist; CONSP (tail); tail = XCDR (tail)) |
578 | 6608 { |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
6609 proc = XCDR (XCAR (tail)); |
578 | 6610 p = XPROCESS (proc); |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6611 if (EQ (p->type, Qreal) && p->pid == pid) |
578 | 6612 break; |
6613 p = 0; | |
6614 } | |
6615 | |
6616 /* Look for an asynchronous process whose pid hasn't been filled | |
6617 in yet. */ | |
6618 if (p == 0) | |
90970
3371fc48749b
Replace uses of GC_* macros with the non-GC_ versions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
90851
diff
changeset
|
6619 for (tail = Vprocess_alist; CONSP (tail); tail = XCDR (tail)) |
578 | 6620 { |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
6621 proc = XCDR (XCAR (tail)); |
578 | 6622 p = XPROCESS (proc); |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6623 if (p->pid == -1) |
578 | 6624 break; |
6625 p = 0; | |
6626 } | |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6627 |
578 | 6628 /* Change the status of the process that was found. */ |
6629 if (p != 0) | |
6630 { | |
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
6631 int clear_desc_flag = 0; |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6632 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6633 p->tick = ++process_tick; |
96620
3bea8ede5bd0
* syswait.h: Remove old if 0 code. Do not define WAITTYPE, it was
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96361
diff
changeset
|
6634 p->raw_status = w; |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6635 p->raw_status_new = 1; |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6636 |
578 | 6637 /* 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
|
6638 if ((WIFSIGNALED (w) || WIFEXITED (w)) |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6639 && p->infd >= 0) |
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
6640 clear_desc_flag = 1; |
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
6641 |
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
6642 /* 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
|
6643 if (clear_desc_flag) |
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
6644 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6645 FD_CLR (p->infd, &input_wait_mask); |
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6646 FD_CLR (p->infd, &non_keyboard_wait_mask); |
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
6647 } |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
6648 |
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
6649 /* Tell wait_reading_process_output that it needs to wake up and |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
6650 look around. */ |
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
6651 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
|
6652 EMACS_SET_SECS_USECS (*input_available_clear_time, 0, 0); |
578 | 6653 } |
6654 | |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6655 /* There was no asynchronous process found for that pid: we have |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6656 a synchronous process. */ |
578 | 6657 else |
6658 { | |
6659 synch_process_alive = 0; | |
6660 | |
6661 /* Report the status of the synchronous process. */ | |
6662 if (WIFEXITED (w)) | |
6663 synch_process_retcode = WRETCODE (w); | |
6664 else if (WIFSIGNALED (w)) | |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
6665 synch_process_termsig = WTERMSIG (w); |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
6666 |
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
6667 /* Tell wait_reading_process_output that it needs to wake up and |
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
6668 look around. */ |
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
6669 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
|
6670 EMACS_SET_SECS_USECS (*input_available_clear_time, 0, 0); |
578 | 6671 } |
6672 | |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6673 sigchld_end_of_loop: |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6674 ; |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6675 |
578 | 6676 /* On some systems, we must return right away. |
6677 If any more processes want to signal us, we will | |
6678 get another signal. | |
6679 Otherwise (on systems that have WNOHANG), loop around | |
6680 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
|
6681 #if (defined WINDOWSNT \ |
41969
e669966d496e
Test GNU_LINUX, not LINUX.
Richard M. Stallman <rms@gnu.org>
parents:
41856
diff
changeset
|
6682 || (defined USG && !defined GNU_LINUX \ |
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
6683 && !(defined HPUX && defined WNOHANG))) |
16116
80a67b8f39e9
(create_process_1, sigchld_handler) [POSIX_SIGNALS]:
Richard M. Stallman <rms@gnu.org>
parents:
16076
diff
changeset
|
6684 #if defined (USG) && ! defined (POSIX_SIGNALS) |
578 | 6685 signal (signo, sigchld_handler); |
6686 #endif | |
6687 errno = old_errno; | |
6688 return; | |
6689 #endif /* USG, but not HPUX with WNOHANG */ | |
6690 } | |
6691 } | |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6692 #endif /* SIGCHLD */ |
578 | 6693 |
6694 | |
6695 static Lisp_Object | |
6696 exec_sentinel_unwind (data) | |
6697 Lisp_Object data; | |
6698 { | |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
6699 XPROCESS (XCAR (data))->sentinel = XCDR (data); |
578 | 6700 return Qnil; |
6701 } | |
6702 | |
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6703 static Lisp_Object |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6704 exec_sentinel_error_handler (error) |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6705 Lisp_Object error; |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6706 { |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6707 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
|
6708 Vinhibit_quit = Qt; |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6709 update_echo_area (); |
11277
d4547e4b0aab
(read_process_output_error_handler)
Richard M. Stallman <rms@gnu.org>
parents:
11235
diff
changeset
|
6710 Fsleep_for (make_number (2), Qnil); |
27558 | 6711 return Qt; |
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6712 } |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6713 |
578 | 6714 static void |
6715 exec_sentinel (proc, reason) | |
6716 Lisp_Object proc, reason; | |
6717 { | |
10914
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
6718 Lisp_Object sentinel, obuffer, odeactivate, okeymap; |
578 | 6719 register struct Lisp_Process *p = XPROCESS (proc); |
46293
1fb8f75062c6
Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents:
45410
diff
changeset
|
6720 int count = SPECPDL_INDEX (); |
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6721 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
|
6722 int waiting = waiting_for_user_input_p; |
578 | 6723 |
72727
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
6724 if (inhibit_sentinels) |
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
6725 return; |
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
6726 |
10914
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
6727 /* 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
|
6728 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
|
6729 odeactivate = Vdeactivate_mark; |
10914
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
6730 XSETBUFFER (obuffer, current_buffer); |
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
6731 okeymap = current_buffer->keymap; |
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
6732 |
578 | 6733 sentinel = p->sentinel; |
6734 if (NILP (sentinel)) | |
6735 return; | |
6736 | |
6737 /* Zilch the sentinel while it's running, to avoid recursive invocations; | |
6738 assure that it gets restored no matter how the sentinel exits. */ | |
6739 p->sentinel = Qnil; | |
6740 record_unwind_protect (exec_sentinel_unwind, Fcons (proc, sentinel)); | |
6741 /* Inhibit quit so that random quits don't screw up a running filter. */ | |
6742 specbind (Qinhibit_quit, Qt); | |
8231
5226ed89c1a6
(Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
8063
diff
changeset
|
6743 specbind (Qlast_nonmenu_event, Qt); |
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6744 |
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6745 /* In case we get recursively called, |
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6746 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
|
6747 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
|
6748 if (outer_running_asynch_code) |
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6749 { |
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6750 Lisp_Object tem; |
63147
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
6751 tem = Fmatch_data (Qnil, Qnil, Qnil); |
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
6752 restore_search_regs (); |
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
6753 record_unwind_save_match_data (); |
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
6754 Fset_match_data (tem, Qt); |
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6755 } |
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6756 |
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6757 /* 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
|
6758 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
|
6759 running_asynch_code = 1; |
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6760 |
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6761 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
|
6762 Fcons (sentinel, |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6763 Fcons (proc, Fcons (reason, Qnil))), |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6764 !NILP (Vdebug_on_error) ? Qnil : Qerror, |
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6765 exec_sentinel_error_handler); |
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6766 |
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6767 /* If we saved the match data nonrecursively, restore it now. */ |
63147
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
6768 restore_search_regs (); |
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6769 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
|
6770 |
8d9e41a175fa
(exec_sentinel): Don't deactivate the mark. Check for asynch buffer switch.
Karl Heuer <kwzh@gnu.org>
parents:
7414
diff
changeset
|
6771 Vdeactivate_mark = odeactivate; |
23460
94f4ba741f22
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
23405
diff
changeset
|
6772 |
94f4ba741f22
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
23405
diff
changeset
|
6773 /* 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
|
6774 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
|
6775 waiting_for_user_input_p = waiting; |
94f4ba741f22
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
23405
diff
changeset
|
6776 |
12808
4db1f387e85f
(read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents:
12749
diff
changeset
|
6777 #if 0 |
10914
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
6778 if (! EQ (Fcurrent_buffer (), obuffer) |
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
6779 || ! EQ (current_buffer->keymap, okeymap)) |
12808
4db1f387e85f
(read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents:
12749
diff
changeset
|
6780 #endif |
13159
2af96ac471bc
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
12808
diff
changeset
|
6781 /* 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
|
6782 Otherwise there's no need to make him wake up, and it could |
71762 | 6783 cause trouble (for example it would make sit_for return). */ |
13159
2af96ac471bc
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
12808
diff
changeset
|
6784 if (waiting_for_user_input_p == -1) |
2af96ac471bc
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
12808
diff
changeset
|
6785 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
|
6786 |
5561
fd7524d61a8d
(read_process_output): Supply second arg to unbind_to.
Richard M. Stallman <rms@gnu.org>
parents:
5548
diff
changeset
|
6787 unbind_to (count, Qnil); |
578 | 6788 } |
6789 | |
6790 /* Report all recent events of a change in process status | |
6791 (either run the sentinel or output a message). | |
44372 | 6792 This is usually done while Emacs is waiting for keyboard input |
6793 but can be done at other times. */ | |
578 | 6794 |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
6795 static void |
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
6796 status_notify (deleting_process) |
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
6797 struct Lisp_Process *deleting_process; |
578 | 6798 { |
6799 register Lisp_Object proc, buffer; | |
6515
df7438605e1e
(status_notify): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6429
diff
changeset
|
6800 Lisp_Object tail, msg; |
578 | 6801 struct gcpro gcpro1, gcpro2; |
6802 | |
6515
df7438605e1e
(status_notify): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6429
diff
changeset
|
6803 tail = Qnil; |
df7438605e1e
(status_notify): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6429
diff
changeset
|
6804 msg = Qnil; |
578 | 6805 /* We need to gcpro tail; if read_process_output calls a filter |
6806 which deletes a process and removes the cons to which tail points | |
6807 from Vprocess_alist, and then causes a GC, tail is an unprotected | |
6808 reference. */ | |
6809 GCPRO2 (tail, msg); | |
6810 | |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6811 /* 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
|
6812 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
|
6813 update_tick = process_tick; |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6814 |
85372
f7d19cfed7da
* xselect.c (x_own_selection, x_handle_selection_clear)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
85362
diff
changeset
|
6815 for (tail = Vprocess_alist; CONSP (tail); tail = XCDR (tail)) |
578 | 6816 { |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6817 Lisp_Object symbol; |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6818 register struct Lisp_Process *p; |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6819 |
85372
f7d19cfed7da
* xselect.c (x_own_selection, x_handle_selection_clear)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
85362
diff
changeset
|
6820 proc = Fcdr (XCAR (tail)); |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6821 p = XPROCESS (proc); |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6822 |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6823 if (p->tick != p->update_tick) |
578 | 6824 { |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6825 p->update_tick = p->tick; |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6826 |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6827 /* 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
|
6828 while (! EQ (p->filter, Qt) |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
6829 && ! EQ (p->status, Qconnect) |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6830 && ! EQ (p->status, Qlisten) |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6831 /* Network or serial process not stopped: */ |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6832 && ! EQ (p->command, Qt) |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6833 && p->infd >= 0 |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
6834 && p != deleting_process |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6835 && read_process_output (proc, p->infd) > 0); |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6836 |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6837 buffer = p->buffer; |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6838 |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6839 /* Get the text to use for the message. */ |
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6840 if (p->raw_status_new) |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6841 update_status (p); |
55962
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
6842 msg = status_message (p); |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6843 |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6844 /* 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
|
6845 symbol = p->status; |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6846 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
|
6847 symbol = XCAR (p->status); |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6848 |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6849 if (EQ (symbol, Qsignal) || EQ (symbol, Qexit) |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6850 || EQ (symbol, Qclosed)) |
578 | 6851 { |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6852 if (delete_exited_processes) |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6853 remove_process (proc); |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6854 else |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6855 deactivate_process (proc); |
578 | 6856 } |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6857 |
16464
c1f19d8e5b80
(status_notify): Update p->tick again
Richard M. Stallman <rms@gnu.org>
parents:
16220
diff
changeset
|
6858 /* 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
|
6859 So set p->update_tick again |
c1f19d8e5b80
(status_notify): Update p->tick again
Richard M. Stallman <rms@gnu.org>
parents:
16220
diff
changeset
|
6860 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
|
6861 this code to be run again. */ |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6862 p->update_tick = p->tick; |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6863 /* Now output the message suitably. */ |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6864 if (!NILP (p->sentinel)) |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6865 exec_sentinel (proc, msg); |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6866 /* 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
|
6867 when a process becomes runnable. */ |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6868 else if (!EQ (symbol, Qrun) && !NILP (buffer)) |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6869 { |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6870 Lisp_Object ro, tem; |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6871 struct buffer *old = current_buffer; |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6872 int opoint, opoint_byte; |
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6873 int before, before_byte; |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6874 |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6875 ro = XBUFFER (buffer)->read_only; |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6876 |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6877 /* Avoid error if buffer is deleted |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6878 (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
|
6879 if (NILP (XBUFFER (buffer)->name)) |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6880 continue; |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6881 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
|
6882 |
16039
855c8d8ba0f0
Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents:
15895
diff
changeset
|
6883 opoint = PT; |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6884 opoint_byte = PT_BYTE; |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6885 /* Insert new output into buffer |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6886 at the current end-of-output marker, |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6887 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
|
6888 if (XMARKER (p->mark)->buffer) |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6889 Fgoto_char (p->mark); |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6890 else |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6891 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
|
6892 |
77b137e2d9a7
(read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents:
17247
diff
changeset
|
6893 before = PT; |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6894 before_byte = PT_BYTE; |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6895 |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6896 tem = current_buffer->read_only; |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6897 current_buffer->read_only = Qnil; |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6898 insert_string ("\nProcess "); |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6899 Finsert (1, &p->name); |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6900 insert_string (" "); |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6901 Finsert (1, &msg); |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6902 current_buffer->read_only = tem; |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6903 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
|
6904 |
17604
77b137e2d9a7
(read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents:
17247
diff
changeset
|
6905 if (opoint >= before) |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6906 SET_PT_BOTH (opoint + (PT - before), |
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6907 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
|
6908 else |
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6909 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
|
6910 |
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6911 set_buffer_internal (old); |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6912 } |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6913 } |
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6914 } /* end for */ |
578 | 6915 |
6916 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
|
6917 redisplay_preserve_echo_area (13); |
578 | 6918 |
6919 UNGCPRO; | |
6920 } | |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6921 |
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6922 |
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6923 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
|
6924 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
|
6925 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
|
6926 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
|
6927 encode subprocess input. */) |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6928 (process, decoding, encoding) |
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6929 register Lisp_Object process, decoding, encoding; |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6930 { |
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6931 register struct Lisp_Process *p; |
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6932 |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6933 CHECK_PROCESS (process); |
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6934 p = XPROCESS (process); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6935 if (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
|
6936 error ("Input file descriptor of %s closed", SDATA (p->name)); |
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6937 if (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
|
6938 error ("Output file descriptor of %s closed", SDATA (p->name)); |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6939 Fcheck_coding_system (decoding); |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6940 Fcheck_coding_system (encoding); |
90392
8b24a6ec5090
(setup_process_coding_systems): Fix synching with
Kenichi Handa <handa@m17n.org>
parents:
90389
diff
changeset
|
6941 encoding = coding_inherit_eol_type (encoding, Qnil); |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6942 p->decode_coding_system = decoding; |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6943 p->encode_coding_system = encoding; |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6944 setup_process_coding_systems (process); |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6945 |
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6946 return Qnil; |
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6947 } |
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6948 |
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6949 DEFUN ("process-coding-system", |
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6950 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
|
6951 doc: /* Return a cons of coding systems for decoding and encoding of PROCESS. */) |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6952 (process) |
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6953 register Lisp_Object process; |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6954 { |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6955 CHECK_PROCESS (process); |
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6956 return Fcons (XPROCESS (process)->decode_coding_system, |
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6957 XPROCESS (process)->encode_coding_system); |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6958 } |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6959 |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6960 DEFUN ("set-process-filter-multibyte", Fset_process_filter_multibyte, |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6961 Sset_process_filter_multibyte, 2, 2, 0, |
49680 | 6962 doc: /* Set multibyteness of the strings given to PROCESS's filter. |
6963 If FLAG is non-nil, the filter is given multibyte strings. | |
6964 If FLAG is nil, the filter is given unibyte strings. In this case, | |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6965 all character code conversion except for end-of-line conversion is |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6966 suppressed. */) |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6967 (process, flag) |
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6968 Lisp_Object process, flag; |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6969 { |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6970 register struct Lisp_Process *p; |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6971 |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6972 CHECK_PROCESS (process); |
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6973 p = XPROCESS (process); |
93201
5dbe361f12c2
* process.h (struct Lisp_Process): Remove filter_multibyte.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92266
diff
changeset
|
6974 if (NILP (flag)) |
5dbe361f12c2
* process.h (struct Lisp_Process): Remove filter_multibyte.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92266
diff
changeset
|
6975 p->decode_coding_system = raw_text_coding_system (p->decode_coding_system); |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6976 setup_process_coding_systems (process); |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6977 |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6978 return Qnil; |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6979 } |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6980 |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6981 DEFUN ("process-filter-multibyte-p", Fprocess_filter_multibyte_p, |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6982 Sprocess_filter_multibyte_p, 1, 1, 0, |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6983 doc: /* Return t if a multibyte string is given to PROCESS's filter.*/) |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6984 (process) |
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6985 Lisp_Object process; |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6986 { |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6987 register struct Lisp_Process *p; |
93201
5dbe361f12c2
* process.h (struct Lisp_Process): Remove filter_multibyte.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92266
diff
changeset
|
6988 struct coding_system *coding; |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6989 |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6990 CHECK_PROCESS (process); |
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6991 p = XPROCESS (process); |
93201
5dbe361f12c2
* process.h (struct Lisp_Process): Remove filter_multibyte.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92266
diff
changeset
|
6992 coding = proc_decode_coding_system[p->infd]; |
5dbe361f12c2
* process.h (struct Lisp_Process): Remove filter_multibyte.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92266
diff
changeset
|
6993 return (CODING_FOR_UNIBYTE (coding) ? Qnil : Qt); |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6994 } |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6995 |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6996 |
578 | 6997 |
83025
c66ebcc29777
Removed %T in mode-line-format. Trivial documentation changes.
Karoly Lorentey <lorentey@elte.hu>
parents:
83019
diff
changeset
|
6998 /* Add DESC to the set of keyboard input descriptors. */ |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
6999 |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7000 void |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7001 add_keyboard_wait_descriptor (desc) |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7002 int desc; |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7003 { |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7004 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
|
7005 FD_SET (desc, &non_process_wait_mask); |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7006 if (desc > max_keyboard_desc) |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7007 max_keyboard_desc = desc; |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7008 } |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7009 |
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7010 static int add_gpm_wait_descriptor_called_flag; |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7011 |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7012 void |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7013 add_gpm_wait_descriptor (desc) |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7014 int desc; |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7015 { |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7016 if (! add_gpm_wait_descriptor_called_flag) |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7017 FD_CLR (0, &input_wait_mask); |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7018 add_gpm_wait_descriptor_called_flag = 1; |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7019 FD_SET (desc, &input_wait_mask); |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7020 FD_SET (desc, &gpm_wait_mask); |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7021 if (desc > max_gpm_desc) |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7022 max_gpm_desc = desc; |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7023 } |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7024 |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7025 /* 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
|
7026 |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7027 void |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7028 delete_keyboard_wait_descriptor (desc) |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7029 int desc; |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7030 { |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7031 int fd; |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7032 int lim = max_keyboard_desc; |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7033 |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7034 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
|
7035 FD_CLR (desc, &non_process_wait_mask); |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7036 |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7037 if (desc == max_keyboard_desc) |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7038 for (fd = 0; fd < lim; fd++) |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7039 if (FD_ISSET (fd, &input_wait_mask) |
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7040 && !FD_ISSET (fd, &non_keyboard_wait_mask) |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7041 && !FD_ISSET (fd, &gpm_wait_mask)) |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7042 max_keyboard_desc = fd; |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7043 } |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7044 |
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7045 void |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7046 delete_gpm_wait_descriptor (desc) |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7047 int desc; |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7048 { |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7049 int fd; |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7050 int lim = max_gpm_desc; |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7051 |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7052 FD_CLR (desc, &input_wait_mask); |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7053 FD_CLR (desc, &non_process_wait_mask); |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7054 |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7055 if (desc == max_gpm_desc) |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7056 for (fd = 0; fd < lim; fd++) |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7057 if (FD_ISSET (fd, &input_wait_mask) |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7058 && !FD_ISSET (fd, &non_keyboard_wait_mask) |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7059 && !FD_ISSET (fd, &non_process_wait_mask)) |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7060 max_gpm_desc = fd; |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7061 } |
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
7062 |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7063 /* Return nonzero if *MASK has a bit set |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7064 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
|
7065 |
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
7066 static int |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7067 keyboard_bit_set (mask) |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7068 SELECT_TYPE *mask; |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7069 { |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7070 int fd; |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7071 |
12541
33a4586124e9
(keyboard_bit_set): Fix one-off in loop end.
Karl Heuer <kwzh@gnu.org>
parents:
12491
diff
changeset
|
7072 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
|
7073 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
|
7074 && !FD_ISSET (fd, &non_keyboard_wait_mask)) |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7075 return 1; |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7076 |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7077 return 0; |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7078 } |
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7079 |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7080 /* Enumeration of and access to system processes a-la ps(1). */ |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7081 |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7082 DEFUN ("list-system-processes", Flist_system_processes, Slist_system_processes, |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7083 0, 0, 0, |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7084 doc: /* Return a list of numerical process IDs of all running processes. |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7085 If this functionality is unsupported, return nil. |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7086 |
102205
0f4ba7f17aa0
Rename `system-process-attributes' to `process-attributes'
Miles Bader <miles@gnu.org>
parents:
101932
diff
changeset
|
7087 See `process-attributes' for getting attributes of a process given its ID. */) |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7088 () |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7089 { |
100565
dcc7f5970d5c
Reorganize implementation of Flist_system_processes and
Dan Nicolaescu <dann@ics.uci.edu>
parents:
100443
diff
changeset
|
7090 return list_system_processes (); |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7091 } |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7092 |
102205
0f4ba7f17aa0
Rename `system-process-attributes' to `process-attributes'
Miles Bader <miles@gnu.org>
parents:
101932
diff
changeset
|
7093 DEFUN ("process-attributes", Fprocess_attributes, |
0f4ba7f17aa0
Rename `system-process-attributes' to `process-attributes'
Miles Bader <miles@gnu.org>
parents:
101932
diff
changeset
|
7094 Sprocess_attributes, 1, 1, 0, |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7095 doc: /* Return attributes of the process given by its PID, a number. |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7096 |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7097 Value is an alist where each element is a cons cell of the form |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7098 |
98062
f2a6b3265c21
(Fsystem_process_attributes): Doc fix.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
97676
diff
changeset
|
7099 \(KEY . VALUE) |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7100 |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7101 If this functionality is unsupported, the value is nil. |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7102 |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7103 See `list-system-processes' for getting a list of all process IDs. |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7104 |
98062
f2a6b3265c21
(Fsystem_process_attributes): Doc fix.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
97676
diff
changeset
|
7105 The KEYs of the attributes that this function may return are listed |
f2a6b3265c21
(Fsystem_process_attributes): Doc fix.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
97676
diff
changeset
|
7106 below, together with the type of the associated VALUE (in parentheses). |
97367
115891550745
(Fsystem_process_attributes): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
97266
diff
changeset
|
7107 Not all platforms support all of these attributes; unsupported |
115891550745
(Fsystem_process_attributes): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
97266
diff
changeset
|
7108 attributes will not appear in the returned alist. |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7109 Unless explicitly indicated otherwise, numbers can have either |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7110 integer or floating point values. |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7111 |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7112 euid -- Effective user User ID of the process (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7113 user -- User name corresponding to euid (string) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7114 egid -- Effective user Group ID of the process (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7115 group -- Group name corresponding to egid (string) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7116 comm -- Command name (executable name only) (string) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7117 state -- Process state code, such as "S", "R", or "T" (string) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7118 ppid -- Parent process ID (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7119 pgrp -- Process group ID (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7120 sess -- Session ID, i.e. process ID of session leader (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7121 ttname -- Controlling tty name (string) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7122 tpgid -- ID of foreground process group on the process's tty (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7123 minflt -- number of minor page faults (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7124 majflt -- number of major page faults (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7125 cminflt -- cumulative number of minor page faults (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7126 cmajflt -- cumulative number of major page faults (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7127 utime -- user time used by the process, in the (HIGH LOW USEC) format |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7128 stime -- system time used by the process, in the (HIGH LOW USEC) format |
100828
0b30d1767fab
(top level) <Qtime, Qctime>: New variables.
Eli Zaretskii <eliz@gnu.org>
parents:
100824
diff
changeset
|
7129 time -- sum of utime and stime, in the (HIGH LOW USEC) format |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7130 cutime -- user time used by the process and its children, (HIGH LOW USEC) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7131 cstime -- system time used by the process and its children, (HIGH LOW USEC) |
100828
0b30d1767fab
(top level) <Qtime, Qctime>: New variables.
Eli Zaretskii <eliz@gnu.org>
parents:
100824
diff
changeset
|
7132 ctime -- sum of cutime and cstime, in the (HIGH LOW USEC) format |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7133 pri -- priority of the process (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7134 nice -- nice value of the process (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7135 thcount -- process thread count (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7136 start -- time the process started, in the (HIGH LOW USEC) format |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7137 vsize -- virtual memory size of the process in KB's (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7138 rss -- resident set size of the process in KB's (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7139 etime -- elapsed time the process is running, in (HIGH LOW USEC) format |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7140 pcpu -- percents of CPU time used by the process (floating-point number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7141 pmem -- percents of total physical memory used by process's resident set |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7142 (floating-point number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7143 args -- command line which invoked the process (string). */) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7144 (pid) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7145 |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7146 Lisp_Object pid; |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7147 { |
100565
dcc7f5970d5c
Reorganize implementation of Flist_system_processes and
Dan Nicolaescu <dann@ics.uci.edu>
parents:
100443
diff
changeset
|
7148 return system_process_attributes (pid); |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7149 } |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7150 |
21514 | 7151 void |
578 | 7152 init_process () |
7153 { | |
7154 register int i; | |
7155 | |
72727
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
7156 inhibit_sentinels = 0; |
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
7157 |
578 | 7158 #ifdef SIGCHLD |
7159 #ifndef CANNOT_DUMP | |
7160 if (! noninteractive || initialized) | |
7161 #endif | |
7162 signal (SIGCHLD, sigchld_handler); | |
7163 #endif | |
7164 | |
7165 FD_ZERO (&input_wait_mask); | |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7166 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
|
7167 FD_ZERO (&non_process_wait_mask); |
7044
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
7168 max_process_desc = 0; |
4682
c4d471244116
(keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
4639
diff
changeset
|
7169 |
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
7170 #ifdef NON_BLOCKING_CONNECT |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
7171 FD_ZERO (&connect_wait_mask); |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
7172 num_pending_connects = 0; |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
7173 #endif |
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
7174 |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7175 #ifdef ADAPTIVE_READ_BUFFERING |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7176 process_output_delay_count = 0; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7177 process_output_skip = 0; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7178 #endif |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7179 |
83013
e77d1a63471b
Don't select on stdin unconditionally.
Karoly Lorentey <lorentey@elte.hu>
parents:
83010
diff
changeset
|
7180 /* Don't do this, it caused infinite select loops. The display |
e77d1a63471b
Don't select on stdin unconditionally.
Karoly Lorentey <lorentey@elte.hu>
parents:
83010
diff
changeset
|
7181 method should call add_keyboard_wait_descriptor on stdin if it |
e77d1a63471b
Don't select on stdin unconditionally.
Karoly Lorentey <lorentey@elte.hu>
parents:
83010
diff
changeset
|
7182 needs that. */ |
e77d1a63471b
Don't select on stdin unconditionally.
Karoly Lorentey <lorentey@elte.hu>
parents:
83010
diff
changeset
|
7183 #if 0 |
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
7184 FD_SET (0, &input_wait_mask); |
83013
e77d1a63471b
Don't select on stdin unconditionally.
Karoly Lorentey <lorentey@elte.hu>
parents:
83010
diff
changeset
|
7185 #endif |
4682
c4d471244116
(keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
4639
diff
changeset
|
7186 |
578 | 7187 Vprocess_alist = Qnil; |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
7188 #ifdef SIGCHLD |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
7189 deleted_pid_list = Qnil; |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
7190 #endif |
578 | 7191 for (i = 0; i < MAXDESC; i++) |
7192 { | |
7193 chan_process[i] = Qnil; | |
7194 proc_buffered_char[i] = -1; | |
7195 } | |
17110
3a348cbb354f
(Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents:
17041
diff
changeset
|
7196 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
|
7197 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
|
7198 #ifdef DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7199 bzero (datagram_address, sizeof datagram_address); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7200 #endif |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7201 |
44073
9984126a7008
(init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents:
44067
diff
changeset
|
7202 #ifdef HAVE_SOCKETS |
9984126a7008
(init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents:
44067
diff
changeset
|
7203 { |
9984126a7008
(init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents:
44067
diff
changeset
|
7204 Lisp_Object subfeatures = Qnil; |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
7205 struct socket_options *sopt; |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
7206 |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7207 #define ADD_SUBFEATURE(key, val) \ |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7208 subfeatures = Fcons (Fcons (key, Fcons (val, Qnil)), subfeatures) |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7209 |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7210 #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
|
7211 ADD_SUBFEATURE (QCnowait, Qt); |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7212 #endif |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7213 #ifdef DATAGRAM_SOCKETS |
44073
9984126a7008
(init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents:
44067
diff
changeset
|
7214 ADD_SUBFEATURE (QCtype, Qdatagram); |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7215 #endif |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7216 #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
|
7217 ADD_SUBFEATURE (QCfamily, Qlocal); |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7218 #endif |
68008 | 7219 ADD_SUBFEATURE (QCfamily, Qipv4); |
7220 #ifdef AF_INET6 | |
7221 ADD_SUBFEATURE (QCfamily, Qipv6); | |
7222 #endif | |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7223 #ifdef HAVE_GETSOCKNAME |
44073
9984126a7008
(init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents:
44067
diff
changeset
|
7224 ADD_SUBFEATURE (QCservice, Qt); |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7225 #endif |
96732
1e0b67e40d48
* systty.h: Remove code for Aix on 386, unsupported platform.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96675
diff
changeset
|
7226 #if 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
|
7227 ADD_SUBFEATURE (QCserver, Qt); |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7228 #endif |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
7229 |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
7230 for (sopt = socket_options; sopt->name; sopt++) |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
7231 subfeatures = Fcons (intern (sopt->name), subfeatures); |
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
7232 |
44073
9984126a7008
(init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents:
44067
diff
changeset
|
7233 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
|
7234 } |
9984126a7008
(init_process): Only provide make-network-process feature and
Kim F. Storm <storm@cua.dk>
parents:
44067
diff
changeset
|
7235 #endif /* HAVE_SOCKETS */ |
59689
007a1a6d92de
* s/darwin.h: Removed PTY_ITERATION from here.
Steven Tamm <steventamm@mac.com>
parents:
59113
diff
changeset
|
7236 |
97266
80acedef7417
cleanup in s/darwin.h, define DARWIN_OS and use it instead of DARWIN and/or MAC_OSX; also, nsterm.m: small unrelated cleanups
Adrian Robert <Adrian.B.Robert@gmail.com>
parents:
97227
diff
changeset
|
7237 #if defined (DARWIN_OS) |
63114
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
7238 /* PTYs are broken on Darwin < 6, but are sometimes useful for interactive |
59689
007a1a6d92de
* s/darwin.h: Removed PTY_ITERATION from here.
Steven Tamm <steventamm@mac.com>
parents:
59113
diff
changeset
|
7239 processes. As such, we only change the default value. */ |
007a1a6d92de
* s/darwin.h: Removed PTY_ITERATION from here.
Steven Tamm <steventamm@mac.com>
parents:
59113
diff
changeset
|
7240 if (initialized) |
007a1a6d92de
* s/darwin.h: Removed PTY_ITERATION from here.
Steven Tamm <steventamm@mac.com>
parents:
59113
diff
changeset
|
7241 { |
007a1a6d92de
* s/darwin.h: Removed PTY_ITERATION from here.
Steven Tamm <steventamm@mac.com>
parents:
59113
diff
changeset
|
7242 char *release = get_operating_system_release(); |
007a1a6d92de
* s/darwin.h: Removed PTY_ITERATION from here.
Steven Tamm <steventamm@mac.com>
parents:
59113
diff
changeset
|
7243 if (!release || !release[0] || (release[0] < MIN_PTY_KERNEL_VERSION |
007a1a6d92de
* s/darwin.h: Removed PTY_ITERATION from here.
Steven Tamm <steventamm@mac.com>
parents:
59113
diff
changeset
|
7244 && release[1] == '.')) { |
007a1a6d92de
* s/darwin.h: Removed PTY_ITERATION from here.
Steven Tamm <steventamm@mac.com>
parents:
59113
diff
changeset
|
7245 Vprocess_connection_type = Qnil; |
007a1a6d92de
* s/darwin.h: Removed PTY_ITERATION from here.
Steven Tamm <steventamm@mac.com>
parents:
59113
diff
changeset
|
7246 } |
007a1a6d92de
* s/darwin.h: Removed PTY_ITERATION from here.
Steven Tamm <steventamm@mac.com>
parents:
59113
diff
changeset
|
7247 } |
007a1a6d92de
* s/darwin.h: Removed PTY_ITERATION from here.
Steven Tamm <steventamm@mac.com>
parents:
59113
diff
changeset
|
7248 #endif |
578 | 7249 } |
4231
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
7250 |
21514 | 7251 void |
578 | 7252 syms_of_process () |
7253 { | |
7254 Qprocessp = intern ("processp"); | |
7255 staticpro (&Qprocessp); | |
7256 Qrun = intern ("run"); | |
7257 staticpro (&Qrun); | |
7258 Qstop = intern ("stop"); | |
7259 staticpro (&Qstop); | |
74749 | 7260 Qsignal = intern ("signal"); |
7261 staticpro (&Qsignal); | |
578 | 7262 |
7263 /* Qexit is already staticpro'd by syms_of_eval; don't staticpro it | |
7264 here again. | |
7265 | |
7266 Qexit = intern ("exit"); | |
7267 staticpro (&Qexit); */ | |
7268 | |
7269 Qopen = intern ("open"); | |
7270 staticpro (&Qopen); | |
7271 Qclosed = intern ("closed"); | |
7272 staticpro (&Qclosed); | |
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
7273 Qconnect = intern ("connect"); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
7274 staticpro (&Qconnect); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
7275 Qfailed = intern ("failed"); |
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
7276 staticpro (&Qfailed); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7277 Qlisten = intern ("listen"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7278 staticpro (&Qlisten); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7279 Qlocal = intern ("local"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7280 staticpro (&Qlocal); |
68008 | 7281 Qipv4 = intern ("ipv4"); |
7282 staticpro (&Qipv4); | |
7283 #ifdef AF_INET6 | |
7284 Qipv6 = intern ("ipv6"); | |
7285 staticpro (&Qipv6); | |
7286 #endif | |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7287 Qdatagram = intern ("datagram"); |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7288 staticpro (&Qdatagram); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7289 |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7290 QCport = intern (":port"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7291 staticpro (&QCport); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7292 QCspeed = intern (":speed"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7293 staticpro (&QCspeed); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7294 QCprocess = intern (":process"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7295 staticpro (&QCprocess); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7296 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7297 QCbytesize = intern (":bytesize"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7298 staticpro (&QCbytesize); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7299 QCstopbits = intern (":stopbits"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7300 staticpro (&QCstopbits); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7301 QCparity = intern (":parity"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7302 staticpro (&QCparity); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7303 Qodd = intern ("odd"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7304 staticpro (&Qodd); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7305 Qeven = intern ("even"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7306 staticpro (&Qeven); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7307 QCflowcontrol = intern (":flowcontrol"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7308 staticpro (&QCflowcontrol); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7309 Qhw = intern ("hw"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7310 staticpro (&Qhw); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7311 Qsw = intern ("sw"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7312 staticpro (&Qsw); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7313 QCsummary = intern (":summary"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7314 staticpro (&QCsummary); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7315 |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7316 Qreal = intern ("real"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7317 staticpro (&Qreal); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7318 Qnetwork = intern ("network"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7319 staticpro (&Qnetwork); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7320 Qserial = intern ("serial"); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7321 staticpro (&Qserial); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7322 |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7323 QCname = intern (":name"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7324 staticpro (&QCname); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7325 QCbuffer = intern (":buffer"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7326 staticpro (&QCbuffer); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7327 QChost = intern (":host"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7328 staticpro (&QChost); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7329 QCservice = intern (":service"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7330 staticpro (&QCservice); |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7331 QCtype = intern (":type"); |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7332 staticpro (&QCtype); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7333 QClocal = intern (":local"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7334 staticpro (&QClocal); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7335 QCremote = intern (":remote"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7336 staticpro (&QCremote); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7337 QCcoding = intern (":coding"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7338 staticpro (&QCcoding); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7339 QCserver = intern (":server"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7340 staticpro (&QCserver); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7341 QCnowait = intern (":nowait"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7342 staticpro (&QCnowait); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7343 QCsentinel = intern (":sentinel"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7344 staticpro (&QCsentinel); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7345 QClog = intern (":log"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7346 staticpro (&QClog); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7347 QCnoquery = intern (":noquery"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7348 staticpro (&QCnoquery); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7349 QCstop = intern (":stop"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7350 staticpro (&QCstop); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7351 QCoptions = intern (":options"); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7352 staticpro (&QCoptions); |
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
7353 QCplist = intern (":plist"); |
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
7354 staticpro (&QCplist); |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
7355 |
8231
5226ed89c1a6
(Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
8063
diff
changeset
|
7356 Qlast_nonmenu_event = intern ("last-nonmenu-event"); |
5226ed89c1a6
(Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
8063
diff
changeset
|
7357 staticpro (&Qlast_nonmenu_event); |
5226ed89c1a6
(Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
8063
diff
changeset
|
7358 |
578 | 7359 staticpro (&Vprocess_alist); |
71140
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
7360 #ifdef SIGCHLD |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
7361 staticpro (&deleted_pid_list); |
80310801887e
2006-06-01 Micha«³l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
7362 #endif |
578 | 7363 |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7364 Qeuid = intern ("euid"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7365 staticpro (&Qeuid); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7366 Qegid = intern ("egid"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7367 staticpro (&Qegid); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7368 Quser = intern ("user"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7369 staticpro (&Quser); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7370 Qgroup = intern ("group"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7371 staticpro (&Qgroup); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7372 Qcomm = intern ("comm"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7373 staticpro (&Qcomm); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7374 Qstate = intern ("state"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7375 staticpro (&Qstate); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7376 Qppid = intern ("ppid"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7377 staticpro (&Qppid); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7378 Qpgrp = intern ("pgrp"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7379 staticpro (&Qpgrp); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7380 Qsess = intern ("sess"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7381 staticpro (&Qsess); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7382 Qttname = intern ("ttname"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7383 staticpro (&Qttname); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7384 Qtpgid = intern ("tpgid"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7385 staticpro (&Qtpgid); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7386 Qminflt = intern ("minflt"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7387 staticpro (&Qminflt); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7388 Qmajflt = intern ("majflt"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7389 staticpro (&Qmajflt); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7390 Qcminflt = intern ("cminflt"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7391 staticpro (&Qcminflt); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7392 Qcmajflt = intern ("cmajflt"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7393 staticpro (&Qcmajflt); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7394 Qutime = intern ("utime"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7395 staticpro (&Qutime); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7396 Qstime = intern ("stime"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7397 staticpro (&Qstime); |
100828
0b30d1767fab
(top level) <Qtime, Qctime>: New variables.
Eli Zaretskii <eliz@gnu.org>
parents:
100824
diff
changeset
|
7398 Qtime = intern ("time"); |
0b30d1767fab
(top level) <Qtime, Qctime>: New variables.
Eli Zaretskii <eliz@gnu.org>
parents:
100824
diff
changeset
|
7399 staticpro (&Qtime); |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7400 Qcutime = intern ("cutime"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7401 staticpro (&Qcutime); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7402 Qcstime = intern ("cstime"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7403 staticpro (&Qcstime); |
100828
0b30d1767fab
(top level) <Qtime, Qctime>: New variables.
Eli Zaretskii <eliz@gnu.org>
parents:
100824
diff
changeset
|
7404 Qctime = intern ("ctime"); |
0b30d1767fab
(top level) <Qtime, Qctime>: New variables.
Eli Zaretskii <eliz@gnu.org>
parents:
100824
diff
changeset
|
7405 staticpro (&Qctime); |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7406 Qpri = intern ("pri"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7407 staticpro (&Qpri); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7408 Qnice = intern ("nice"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7409 staticpro (&Qnice); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7410 Qthcount = intern ("thcount"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7411 staticpro (&Qthcount); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7412 Qstart = intern ("start"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7413 staticpro (&Qstart); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7414 Qvsize = intern ("vsize"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7415 staticpro (&Qvsize); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7416 Qrss = intern ("rss"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7417 staticpro (&Qrss); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7418 Qetime = intern ("etime"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7419 staticpro (&Qetime); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7420 Qpcpu = intern ("pcpu"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7421 staticpro (&Qpcpu); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7422 Qpmem = intern ("pmem"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7423 staticpro (&Qpmem); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7424 Qargs = intern ("args"); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7425 staticpro (&Qargs); |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7426 |
578 | 7427 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
|
7428 doc: /* *Non-nil means delete processes immediately when they exit. |
73951
182d429ba6f9
(syms_of_process) <delete-exited-processes>: Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents:
73225
diff
changeset
|
7429 A value of nil means don't delete them until `list-processes' is run. */); |
578 | 7430 |
7431 delete_exited_processes = 1; | |
7432 | |
7433 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
|
7434 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
|
7435 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
|
7436 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
|
7437 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
|
7438 The value takes effect when `start-process' is called. */); |
578 | 7439 Vprocess_connection_type = Qt; |
7440 | |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7441 #ifdef ADAPTIVE_READ_BUFFERING |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7442 DEFVAR_LISP ("process-adaptive-read-buffering", &Vprocess_adaptive_read_buffering, |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7443 doc: /* If non-nil, improve receive buffering by delaying after short reads. |
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
7444 On some systems, when Emacs reads the output from a subprocess, the output data |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7445 is read in very small blocks, potentially resulting in very poor performance. |
63278
d826c3c6df3f
(syms_of_process) [ADAPTIVE_READ_BUFFERING]: Fix spellings in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
63147
diff
changeset
|
7446 This behavior can be remedied to some extent by setting this variable to a |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7447 non-nil value, as it will automatically delay reading from such processes, to |
69376
921341a03d5b
(Vprocess_adaptive_read_buffering): Doc fix.
Romain Francoise <romain@orebokech.com>
parents:
69151
diff
changeset
|
7448 allow them to produce more output before Emacs tries to read it. |
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7449 If the value is t, the delay is reset after each write to the process; any other |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7450 non-nil value means that the delay is not reset on write. |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7451 The variable takes effect when `start-process' is called. */); |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7452 Vprocess_adaptive_read_buffering = Qt; |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7453 #endif |
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
7454 |
578 | 7455 defsubr (&Sprocessp); |
7456 defsubr (&Sget_process); | |
7457 defsubr (&Sget_buffer_process); | |
7458 defsubr (&Sdelete_process); | |
7459 defsubr (&Sprocess_status); | |
7460 defsubr (&Sprocess_exit_status); | |
7461 defsubr (&Sprocess_id); | |
7462 defsubr (&Sprocess_name); | |
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
7463 defsubr (&Sprocess_tty_name); |
578 | 7464 defsubr (&Sprocess_command); |
7465 defsubr (&Sset_process_buffer); | |
7466 defsubr (&Sprocess_buffer); | |
7467 defsubr (&Sprocess_mark); | |
7468 defsubr (&Sset_process_filter); | |
7469 defsubr (&Sprocess_filter); | |
7470 defsubr (&Sset_process_sentinel); | |
16058
924aeb9ed7c3
(Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16053
diff
changeset
|
7471 defsubr (&Sprocess_sentinel); |
6830
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
7472 defsubr (&Sset_process_window_size); |
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7473 defsubr (&Sset_process_inherit_coding_system_flag); |
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7474 defsubr (&Sprocess_inherit_coding_system_flag); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7475 defsubr (&Sset_process_query_on_exit_flag); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7476 defsubr (&Sprocess_query_on_exit_flag); |
16058
924aeb9ed7c3
(Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16053
diff
changeset
|
7477 defsubr (&Sprocess_contact); |
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
7478 defsubr (&Sprocess_plist); |
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
7479 defsubr (&Sset_process_plist); |
578 | 7480 defsubr (&Slist_processes); |
7481 defsubr (&Sprocess_list); | |
7482 defsubr (&Sstart_process); | |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7483 #ifdef HAVE_SERIAL |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7484 defsubr (&Sserial_process_configure); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7485 defsubr (&Smake_serial_process); |
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7486 #endif /* HAVE_SERIAL */ |
578 | 7487 #ifdef HAVE_SOCKETS |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
7488 defsubr (&Sset_network_process_option); |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7489 defsubr (&Smake_network_process); |
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
7490 defsubr (&Sformat_network_address); |
52525
fd2be6cea0e7
(Fnetwork_interface_list, Fnetwork_interface_info):
Kim F. Storm <storm@cua.dk>
parents:
52516
diff
changeset
|
7491 #endif /* HAVE_SOCKETS */ |
fd2be6cea0e7
(Fnetwork_interface_list, Fnetwork_interface_info):
Kim F. Storm <storm@cua.dk>
parents:
52516
diff
changeset
|
7492 #if defined(HAVE_SOCKETS) && defined(HAVE_NET_IF_H) && defined(HAVE_SYS_IOCTL_H) |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
7493 #ifdef SIOCGIFCONF |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
7494 defsubr (&Snetwork_interface_list); |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
7495 #endif |
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
7496 #if defined(SIOCGIFADDR) || defined(SIOCGIFHWADDR) || defined(SIOCGIFFLAGS) |
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
7497 defsubr (&Snetwork_interface_info); |
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
7498 #endif |
52525
fd2be6cea0e7
(Fnetwork_interface_list, Fnetwork_interface_info):
Kim F. Storm <storm@cua.dk>
parents:
52516
diff
changeset
|
7499 #endif /* HAVE_SOCKETS ... */ |
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7500 #ifdef DATAGRAM_SOCKETS |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7501 defsubr (&Sprocess_datagram_address); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7502 defsubr (&Sset_process_datagram_address); |
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
7503 #endif |
578 | 7504 defsubr (&Saccept_process_output); |
7505 defsubr (&Sprocess_send_region); | |
7506 defsubr (&Sprocess_send_string); | |
7507 defsubr (&Sinterrupt_process); | |
7508 defsubr (&Skill_process); | |
7509 defsubr (&Squit_process); | |
7510 defsubr (&Sstop_process); | |
7511 defsubr (&Scontinue_process); | |
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
7512 defsubr (&Sprocess_running_child_p); |
578 | 7513 defsubr (&Sprocess_send_eof); |
7514 defsubr (&Ssignal_process); | |
7515 defsubr (&Swaiting_for_user_input_p); | |
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
7516 defsubr (&Sprocess_type); |
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
7517 defsubr (&Sset_process_coding_system); |
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
7518 defsubr (&Sprocess_coding_system); |
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
7519 defsubr (&Sset_process_filter_multibyte); |
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
7520 defsubr (&Sprocess_filter_multibyte_p); |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7521 defsubr (&Slist_system_processes); |
102205
0f4ba7f17aa0
Rename `system-process-attributes' to `process-attributes'
Miles Bader <miles@gnu.org>
parents:
101932
diff
changeset
|
7522 defsubr (&Sprocess_attributes); |
578 | 7523 } |
7524 | |
588 | 7525 |
7526 #else /* not subprocesses */ | |
7527 | |
7528 #include <sys/types.h> | |
7529 #include <errno.h> | |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7530 #include <sys/stat.h> |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7531 #include <stdlib.h> |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7532 #include <fcntl.h> |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7533 #ifdef HAVE_UNISTD_H |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7534 #include <unistd.h> |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7535 #endif |
588 | 7536 |
7537 #include "lisp.h" | |
7538 #include "systime.h" | |
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
7539 #include "character.h" |
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7540 #include "coding.h" |
588 | 7541 #include "termopts.h" |
12132
017f32786ed3
[!subprocesses]: Include sysselect.h.
Karl Heuer <kwzh@gnu.org>
parents:
11926
diff
changeset
|
7542 #include "sysselect.h" |
588 | 7543 |
765 | 7544 extern int frame_garbaged; |
588 | 7545 |
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7546 extern EMACS_TIME timer_check (); |
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7547 extern int timers_run; |
588 | 7548 |
97650
8b1a761cfe61
[!subprocesses]: Define QCname.
Eli Zaretskii <eliz@gnu.org>
parents:
97498
diff
changeset
|
7549 Lisp_Object QCtype, QCname; |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7550 |
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7551 Lisp_Object Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess, Qttname, Qtpgid; |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7552 Lisp_Object Qminflt, Qmajflt, Qcminflt, Qcmajflt, Qutime, Qstime, Qcstime; |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7553 Lisp_Object Qcutime, Qpri, Qnice, Qthcount, Qstart, Qvsize, Qrss, Qargs; |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7554 Lisp_Object Quser, Qgroup, Qetime, Qpcpu, Qpmem, Qtime, Qctime; |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7555 |
588 | 7556 /* As described above, except assuming that there are no subprocesses: |
7557 | |
7558 Wait for timeout to elapse and/or keyboard input to be available. | |
7559 | |
7560 time_limit is: | |
7561 timeout in seconds, or | |
7562 zero for no limit, or | |
7563 -1 means gobble data immediately available but don't wait for any. | |
7564 | |
650 | 7565 read_kbd is a Lisp_Object: |
588 | 7566 0 to ignore keyboard input, or |
7567 1 to return when input is available, or | |
7568 -1 means caller will actually read the input, so don't throw to | |
7569 the quit handler. | |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7570 |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7571 see full version for other parameters. We know that wait_proc will |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7572 always be NULL, since `subprocesses' isn't defined. |
588 | 7573 |
7574 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
|
7575 output that arrives. |
588 | 7576 |
78501 | 7577 Return true if we received input from any process. */ |
588 | 7578 |
7579 int | |
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
7580 wait_reading_process_output (time_limit, microsecs, read_kbd, do_display, |
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
7581 wait_for_cell, wait_proc, just_wait_proc) |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7582 int time_limit, microsecs, read_kbd, do_display; |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7583 Lisp_Object wait_for_cell; |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7584 struct Lisp_Process *wait_proc; |
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7585 int just_wait_proc; |
588 | 7586 { |
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7587 register int nfds; |
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7588 EMACS_TIME end_time, timeout; |
14278
3562c5f43780
(wait_reading_process_input) [not subprocesses]: Do
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
7589 SELECT_TYPE waitchannels; |
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7590 int xerrno; |
588 | 7591 |
7592 /* What does time_limit really mean? */ | |
7593 if (time_limit || microsecs) | |
7594 { | |
7595 EMACS_GET_TIME (end_time); | |
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7596 EMACS_SET_SECS_USECS (timeout, time_limit, microsecs); |
588 | 7597 EMACS_ADD_TIME (end_time, end_time, timeout); |
7598 } | |
7599 | |
7600 /* 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
|
7601 and then turn off any other atimers, |
588 | 7602 because the select emulator uses alarms. */ |
47431
8871e67384e4
(wait_reading_process_input, both versions):
Richard M. Stallman <rms@gnu.org>
parents:
47020
diff
changeset
|
7603 stop_polling (); |
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
7604 turn_on_atimers (0); |
588 | 7605 |
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7606 while (1) |
588 | 7607 { |
14802
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7608 int timeout_reduced_for_timers = 0; |
588 | 7609 |
7610 /* If calling from keyboard input, do not quit | |
7611 since we want to return C-g as an input character. | |
7612 Otherwise, do pending quit if requested. */ | |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7613 if (read_kbd >= 0) |
588 | 7614 QUIT; |
7615 | |
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7616 /* 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
|
7617 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
|
7618 break; |
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7619 |
14802
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7620 /* 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
|
7621 /* Exit if already run out */ |
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7622 if (time_limit == -1) |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7623 { |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7624 /* -1 specified for timeout means |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7625 gobble output available now |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7626 but don't wait at all. */ |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7627 |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7628 EMACS_SET_SECS_USECS (timeout, 0, 0); |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7629 } |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7630 else if (time_limit || microsecs) |
588 | 7631 { |
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7632 EMACS_GET_TIME (timeout); |
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7633 EMACS_SUB_TIME (timeout, end_time, timeout); |
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7634 if (EMACS_TIME_NEG_P (timeout)) |
588 | 7635 break; |
7636 } | |
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7637 else |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7638 { |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7639 EMACS_SET_SECS_USECS (timeout, 100000, 0); |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7640 } |
588 | 7641 |
14802
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7642 /* 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
|
7643 run timer events directly. |
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7644 (Callers that will immediately read keyboard events |
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7645 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
|
7646 if (NILP (wait_for_cell)) |
14802
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7647 { |
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7648 EMACS_TIME timer_delay; |
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
7649 |
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
7650 do |
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7651 { |
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
7652 int old_timers_run = timers_run; |
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
7653 timer_delay = timer_check (1); |
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
7654 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
|
7655 /* 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
|
7656 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
|
7657 redisplay_preserve_echo_area (14); |
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
7658 else |
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
7659 break; |
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7660 } |
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
7661 while (!detect_input_pending ()); |
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7662 |
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7663 /* If there is unread keyboard input, also return. */ |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7664 if (read_kbd != 0 |
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7665 && requeued_events_pending_p ()) |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7666 break; |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7667 |
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7668 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
|
7669 { |
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7670 EMACS_TIME difference; |
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7671 EMACS_SUB_TIME (difference, timer_delay, timeout); |
14802
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7672 if (EMACS_TIME_NEG_P (difference)) |
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7673 { |
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7674 timeout = timer_delay; |
14802
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7675 timeout_reduced_for_timers = 1; |
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7676 } |
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7677 } |
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7678 } |
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
7679 |
588 | 7680 /* Cause C-g and alarm signals to take immediate action, |
7681 and cause input available signals to zero out timeout. */ | |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7682 if (read_kbd < 0) |
588 | 7683 set_waiting_for_input (&timeout); |
7684 | |
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7685 /* Wait till there is something to do. */ |
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7686 |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7687 if (! read_kbd && NILP (wait_for_cell)) |
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7688 FD_ZERO (&waitchannels); |
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7689 else |
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7690 FD_SET (0, &waitchannels); |
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7691 |
765 | 7692 /* If a frame has been newly mapped and needs updating, |
588 | 7693 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
|
7694 if (frame_garbaged && do_display) |
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7695 { |
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7696 clear_waiting_for_input (); |
35336
002c02db42d3
Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents:
34660
diff
changeset
|
7697 redisplay_preserve_echo_area (15); |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7698 if (read_kbd < 0) |
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7699 set_waiting_for_input (&timeout); |
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7700 } |
588 | 7701 |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7702 if (read_kbd && detect_input_pending ()) |
15025
e5f54fd1c352
(wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents:
15021
diff
changeset
|
7703 { |
e5f54fd1c352
(wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents:
15021
diff
changeset
|
7704 nfds = 0; |
e5f54fd1c352
(wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents:
15021
diff
changeset
|
7705 FD_ZERO (&waitchannels); |
e5f54fd1c352
(wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents:
15021
diff
changeset
|
7706 } |
e5f54fd1c352
(wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents:
15021
diff
changeset
|
7707 else |
e5f54fd1c352
(wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents:
15021
diff
changeset
|
7708 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
|
7709 &timeout); |
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7710 |
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7711 xerrno = errno; |
588 | 7712 |
7713 /* Make C-g and alarm signals set flags again */ | |
7714 clear_waiting_for_input (); | |
7715 | |
7716 /* 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
|
7717 do_pending_window_change (0); |
588 | 7718 |
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7719 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
|
7720 /* 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
|
7721 break; |
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7722 |
588 | 7723 if (nfds == -1) |
7724 { | |
7725 /* If the system call was interrupted, then go around the | |
7726 loop again. */ | |
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7727 if (xerrno == EINTR) |
14278
3562c5f43780
(wait_reading_process_input) [not subprocesses]: Do
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
7728 FD_ZERO (&waitchannels); |
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7729 else |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
7730 error ("select error: %s", emacs_strerror (xerrno)); |
588 | 7731 } |
96833
c06568fd3844
* s/usg5-4.h (LIBS_SYSTEM): Remove, system for which this was
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96774
diff
changeset
|
7732 #ifdef SOLARIS2 |
588 | 7733 else if (nfds > 0 && (waitchannels & 1) && interrupt_input) |
7734 /* System sometimes fails to deliver SIGIO. */ | |
7735 kill (getpid (), SIGIO); | |
7736 #endif | |
3915
55ed7a65746e
(wait_reading_process_input): Use SIGIO only if defined.
Richard M. Stallman <rms@gnu.org>
parents:
3826
diff
changeset
|
7737 #ifdef SIGIO |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7738 if (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
|
7739 kill (getpid (), SIGIO); |
3915
55ed7a65746e
(wait_reading_process_input): Use SIGIO only if defined.
Richard M. Stallman <rms@gnu.org>
parents:
3826
diff
changeset
|
7740 #endif |
588 | 7741 |
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7742 /* Check for keyboard input */ |
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7743 |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7744 if (read_kbd |
37413
49147b9fe206
(wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents:
37398
diff
changeset
|
7745 && detect_input_pending_run_timers (do_display)) |
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7746 { |
37413
49147b9fe206
(wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents:
37398
diff
changeset
|
7747 swallow_events (do_display); |
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7748 if (detect_input_pending_run_timers (do_display)) |
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7749 break; |
37413
49147b9fe206
(wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents:
37398
diff
changeset
|
7750 } |
49147b9fe206
(wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents:
37398
diff
changeset
|
7751 |
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7752 /* If there is unread keyboard input, also return. */ |
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7753 if (read_kbd |
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7754 && requeued_events_pending_p ()) |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7755 break; |
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7756 |
15064
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7757 /* 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
|
7758 but don't run any timers. |
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7759 ??? (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
|
7760 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
|
7761 has been this way since July 1994. |
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7762 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
|
7763 if (! NILP (wait_for_cell) |
15064
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7764 && detect_input_pending ()) |
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7765 { |
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7766 swallow_events (do_display); |
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7767 if (detect_input_pending ()) |
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7768 break; |
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7769 } |
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7770 |
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7771 /* 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
|
7772 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
|
7773 break; |
588 | 7774 } |
7775 | |
2120
fc3cdca22f8d
* process.c (process_send_signal): In the TERMIOS code for sending
Jim Blandy <jimb@redhat.com>
parents:
1925
diff
changeset
|
7776 start_polling (); |
fc3cdca22f8d
* process.c (process_send_signal): In the TERMIOS code for sending
Jim Blandy <jimb@redhat.com>
parents:
1925
diff
changeset
|
7777 |
588 | 7778 return 0; |
7779 } | |
7780 | |
7781 | |
39964
4ca5cbe5610d
(process-inherit-coding-system-flag, get-buffer-process): Do not confuse
Pavel Janík <Pavel@Janik.cz>
parents:
39812
diff
changeset
|
7782 /* 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
|
7783 make-docfile does not pay attention to #if, for good reason! */ |
588 | 7784 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
|
7785 0) |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
7786 (name) |
588 | 7787 register Lisp_Object name; |
7788 { | |
7789 return Qnil; | |
7790 } | |
7791 | |
39964
4ca5cbe5610d
(process-inherit-coding-system-flag, get-buffer-process): Do not confuse
Pavel Janík <Pavel@Janik.cz>
parents:
39812
diff
changeset
|
7792 /* 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
|
7793 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
|
7794 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
|
7795 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
|
7796 1, 1, 0, |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
7797 0) |
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
7798 (process) |
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7799 register Lisp_Object process; |
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7800 { |
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7801 /* Ignore the argument and return the value of |
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7802 inherit-process-coding-system. */ |
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7803 return inherit_process_coding_system ? Qt : Qnil; |
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7804 } |
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7805 |
588 | 7806 /* Kill all processes associated with `buffer'. |
7807 If `buffer' is nil, kill all processes. | |
7808 Since we have no subprocesses, this does nothing. */ | |
7809 | |
21414
aac7354edaed
(kill_buffer_processes): Make consistent with
Karl Heuer <kwzh@gnu.org>
parents:
21281
diff
changeset
|
7810 void |
588 | 7811 kill_buffer_processes (buffer) |
7812 Lisp_Object buffer; | |
7813 { | |
7814 } | |
7815 | |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7816 DEFUN ("list-system-processes", Flist_system_processes, Slist_system_processes, |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7817 0, 0, 0, |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7818 doc: /* Return a list of numerical process IDs of all running processes. |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7819 If this functionality is unsupported, return nil. |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7820 |
102205
0f4ba7f17aa0
Rename `system-process-attributes' to `process-attributes'
Miles Bader <miles@gnu.org>
parents:
101932
diff
changeset
|
7821 See `process-attributes' for getting attributes of a process given its ID. */) |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7822 () |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7823 { |
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7824 return list_system_processes (); |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7825 } |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7826 |
102205
0f4ba7f17aa0
Rename `system-process-attributes' to `process-attributes'
Miles Bader <miles@gnu.org>
parents:
101932
diff
changeset
|
7827 DEFUN ("process-attributes", Fprocess_attributes, |
0f4ba7f17aa0
Rename `system-process-attributes' to `process-attributes'
Miles Bader <miles@gnu.org>
parents:
101932
diff
changeset
|
7828 Sprocess_attributes, 1, 1, 0, |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7829 doc: /* Return attributes of the process given by its PID, a number. |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7830 |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7831 Value is an alist where each element is a cons cell of the form |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7832 |
98084
cdd80926d2ea
(Fsystem_process_attributes): Doc fix.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
98062
diff
changeset
|
7833 \(KEY . VALUE) |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7834 |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7835 If this functionality is unsupported, the value is nil. |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7836 |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7837 See `list-system-processes' for getting a list of all process IDs. |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7838 |
98084
cdd80926d2ea
(Fsystem_process_attributes): Doc fix.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
98062
diff
changeset
|
7839 The KEYs of the attributes that this function may return are listed |
cdd80926d2ea
(Fsystem_process_attributes): Doc fix.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
98062
diff
changeset
|
7840 below, together with the type of the associated VALUE (in parentheses). |
97367
115891550745
(Fsystem_process_attributes): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
97266
diff
changeset
|
7841 Not all platforms support all of these attributes; unsupported |
115891550745
(Fsystem_process_attributes): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
97266
diff
changeset
|
7842 attributes will not appear in the returned alist. |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7843 Unless explicitly indicated otherwise, numbers can have either |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7844 integer or floating point values. |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7845 |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7846 euid -- Effective user User ID of the process (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7847 user -- User name corresponding to euid (string) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7848 egid -- Effective user Group ID of the process (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7849 group -- Group name corresponding to egid (string) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7850 comm -- Command name (executable name only) (string) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7851 state -- Process state code, such as "S", "R", or "T" (string) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7852 ppid -- Parent process ID (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7853 pgrp -- Process group ID (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7854 sess -- Session ID, i.e. process ID of session leader (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7855 ttname -- Controlling tty name (string) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7856 tpgid -- ID of foreground process group on the process's tty (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7857 minflt -- number of minor page faults (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7858 majflt -- number of major page faults (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7859 cminflt -- cumulative number of minor page faults (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7860 cmajflt -- cumulative number of major page faults (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7861 utime -- user time used by the process, in the (HIGH LOW USEC) format |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7862 stime -- system time used by the process, in the (HIGH LOW USEC) format |
100828
0b30d1767fab
(top level) <Qtime, Qctime>: New variables.
Eli Zaretskii <eliz@gnu.org>
parents:
100824
diff
changeset
|
7863 time -- sum of utime and stime, in the (HIGH LOW USEC) format |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7864 cutime -- user time used by the process and its children, (HIGH LOW USEC) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7865 cstime -- system time used by the process and its children, (HIGH LOW USEC) |
100828
0b30d1767fab
(top level) <Qtime, Qctime>: New variables.
Eli Zaretskii <eliz@gnu.org>
parents:
100824
diff
changeset
|
7866 ctime -- sum of cutime and cstime, in the (HIGH LOW USEC) format |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7867 pri -- priority of the process (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7868 nice -- nice value of the process (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7869 thcount -- process thread count (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7870 start -- time the process started, in the (HIGH LOW USEC) format |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7871 vsize -- virtual memory size of the process in KB's (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7872 rss -- resident set size of the process in KB's (number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7873 etime -- elapsed time the process is running, in (HIGH LOW USEC) format |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7874 pcpu -- percents of CPU time used by the process (floating-point number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7875 pmem -- percents of total physical memory used by process's resident set |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7876 (floating-point number) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7877 args -- command line which invoked the process (string). */) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7878 (pid) |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7879 |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7880 Lisp_Object pid; |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7881 { |
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7882 return system_process_attributes (pid); |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7883 } |
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7884 |
21978
ba8852d809f6
(init_process, syms_of_process): Make definition consistent with
Eli Zaretskii <eliz@gnu.org>
parents:
21950
diff
changeset
|
7885 void |
588 | 7886 init_process () |
7887 { | |
7888 } | |
7889 | |
21978
ba8852d809f6
(init_process, syms_of_process): Make definition consistent with
Eli Zaretskii <eliz@gnu.org>
parents:
21950
diff
changeset
|
7890 void |
588 | 7891 syms_of_process () |
7892 { | |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7893 QCtype = intern (":type"); |
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7894 staticpro (&QCtype); |
97650
8b1a761cfe61
[!subprocesses]: Define QCname.
Eli Zaretskii <eliz@gnu.org>
parents:
97498
diff
changeset
|
7895 QCname = intern (":name"); |
8b1a761cfe61
[!subprocesses]: Define QCname.
Eli Zaretskii <eliz@gnu.org>
parents:
97498
diff
changeset
|
7896 staticpro (&QCname); |
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7897 QCtype = intern (":type"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7898 staticpro (&QCtype); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7899 QCname = intern (":name"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7900 staticpro (&QCname); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7901 Qeuid = intern ("euid"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7902 staticpro (&Qeuid); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7903 Qegid = intern ("egid"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7904 staticpro (&Qegid); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7905 Quser = intern ("user"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7906 staticpro (&Quser); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7907 Qgroup = intern ("group"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7908 staticpro (&Qgroup); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7909 Qcomm = intern ("comm"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7910 staticpro (&Qcomm); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7911 Qstate = intern ("state"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7912 staticpro (&Qstate); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7913 Qppid = intern ("ppid"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7914 staticpro (&Qppid); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7915 Qpgrp = intern ("pgrp"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7916 staticpro (&Qpgrp); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7917 Qsess = intern ("sess"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7918 staticpro (&Qsess); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7919 Qttname = intern ("ttname"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7920 staticpro (&Qttname); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7921 Qtpgid = intern ("tpgid"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7922 staticpro (&Qtpgid); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7923 Qminflt = intern ("minflt"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7924 staticpro (&Qminflt); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7925 Qmajflt = intern ("majflt"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7926 staticpro (&Qmajflt); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7927 Qcminflt = intern ("cminflt"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7928 staticpro (&Qcminflt); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7929 Qcmajflt = intern ("cmajflt"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7930 staticpro (&Qcmajflt); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7931 Qutime = intern ("utime"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7932 staticpro (&Qutime); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7933 Qstime = intern ("stime"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7934 staticpro (&Qstime); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7935 Qtime = intern ("time"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7936 staticpro (&Qtime); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7937 Qcutime = intern ("cutime"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7938 staticpro (&Qcutime); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7939 Qcstime = intern ("cstime"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7940 staticpro (&Qcstime); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7941 Qctime = intern ("ctime"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7942 staticpro (&Qctime); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7943 Qpri = intern ("pri"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7944 staticpro (&Qpri); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7945 Qnice = intern ("nice"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7946 staticpro (&Qnice); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7947 Qthcount = intern ("thcount"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7948 staticpro (&Qthcount); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7949 Qstart = intern ("start"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7950 staticpro (&Qstart); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7951 Qvsize = intern ("vsize"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7952 staticpro (&Qvsize); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7953 Qrss = intern ("rss"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7954 staticpro (&Qrss); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7955 Qetime = intern ("etime"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7956 staticpro (&Qetime); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7957 Qpcpu = intern ("pcpu"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7958 staticpro (&Qpcpu); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7959 Qpmem = intern ("pmem"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7960 staticpro (&Qpmem); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7961 Qargs = intern ("args"); |
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7962 staticpro (&Qargs); |
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7963 |
588 | 7964 defsubr (&Sget_buffer_process); |
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7965 defsubr (&Sprocess_inherit_coding_system_flag); |
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7966 defsubr (&Slist_system_processes); |
102205
0f4ba7f17aa0
Rename `system-process-attributes' to `process-attributes'
Miles Bader <miles@gnu.org>
parents:
101932
diff
changeset
|
7967 defsubr (&Sprocess_attributes); |
588 | 7968 } |
7969 | |
7970 | |
7971 #endif /* not subprocesses */ | |
52401 | 7972 |
7973 /* arch-tag: 3706c011-7b9a-4117-bd4f-59e7f701a4c4 | |
7974 (do not change this comment) */ |