Mercurial > emacs
annotate src/process.c @ 111210:4c19a062df30
* lisp/progmodes/compile.el (compilation-mode-font-lock-keywords):
Don't confuse -omega as "-o mega".
| author | Stefan Monnier <monnier@iro.umontreal.ca> |
|---|---|
| date | Wed, 27 Oct 2010 21:10:22 -0400 |
| parents | bec49af30c2f |
| children | 32e6d2b445ce |
| 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, |
| 106815 | 4 2005, 2006, 2007, 2008, 2009, 2010 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 #include <stdio.h> | |
| 25 #include <errno.h> | |
| 26 #include <setjmp.h> | |
| 27 #include <sys/types.h> /* some typedefs are used in sys/file.h */ | |
| 28 #include <sys/file.h> | |
| 29 #include <sys/stat.h> | |
|
105669
68dd71358159
* alloc.c: Do not define struct catchtag.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105577
diff
changeset
|
30 #include <setjmp.h> |
|
68146
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
31 #ifdef HAVE_INTTYPES_H |
|
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
32 #include <inttypes.h> |
|
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
33 #endif |
|
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
34 |
| 6158 | 35 #ifdef HAVE_UNISTD_H |
| 36 #include <unistd.h> | |
| 37 #endif | |
|
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
38 #include <fcntl.h> |
|
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
39 |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
40 /* Only MS-DOS does not define `subprocesses'. */ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
41 #ifdef subprocesses |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
42 |
| 578 | 43 #include <sys/socket.h> |
| 44 #include <netdb.h> | |
| 45 #include <netinet/in.h> | |
| 46 #include <arpa/inet.h> | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
47 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
48 /* 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
|
49 #if defined (HAVE_SYS_UN_H) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
50 #if !defined (AF_LOCAL) && defined (AF_UNIX) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
51 #define AF_LOCAL AF_UNIX |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
52 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
53 #ifdef AF_LOCAL |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
54 #define HAVE_LOCAL_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
55 #include <sys/un.h> |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
56 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
57 #endif |
| 578 | 58 |
|
107722
98f7a4103e8e
Clean up BSD_SYSTEM use.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107546
diff
changeset
|
59 #if defined(HAVE_SYS_IOCTL_H) |
| 578 | 60 #include <sys/ioctl.h> |
|
109672
bd826f80a765
* src/process.c: Simplify include logic.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109668
diff
changeset
|
61 #if defined(HAVE_NET_IF_H) |
|
bd826f80a765
* src/process.c: Simplify include logic.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109668
diff
changeset
|
62 #include <net/if.h> |
|
bd826f80a765
* src/process.c: Simplify include logic.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109668
diff
changeset
|
63 #endif /* HAVE_NET_IF_H */ |
|
107722
98f7a4103e8e
Clean up BSD_SYSTEM use.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
107546
diff
changeset
|
64 #endif /* HAVE_SYS_IOCTL_H */ |
|
5240
eed870591987
(Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents:
5239
diff
changeset
|
65 |
| 578 | 66 #ifdef NEED_BSDTTY |
| 67 #include <bsdtty.h> | |
| 68 #endif | |
| 69 | |
|
85362
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
70 #ifdef HAVE_RES_INIT |
|
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
71 #include <netinet/in.h> |
|
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
72 #include <arpa/nameser.h> |
|
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
73 #include <resolv.h> |
|
68022
e213d76ca446
[WINDOWSNT]: Undef AF_INET6 to disable IPv6 support for w32.
Eli Zaretskii <eliz@gnu.org>
parents:
68008
diff
changeset
|
74 #endif |
|
e213d76ca446
[WINDOWSNT]: Undef AF_INET6 to disable IPv6 support for w32.
Eli Zaretskii <eliz@gnu.org>
parents:
68008
diff
changeset
|
75 |
|
109653
9cfca8c9fb07
Fix missing prototypes for HAVE_NS (caused crash) and vrious warnings.
Jan D <jan.h.d@swipnet.se>
parents:
109640
diff
changeset
|
76 #ifdef HAVE_UTIL_H |
|
9cfca8c9fb07
Fix missing prototypes for HAVE_NS (caused crash) and vrious warnings.
Jan D <jan.h.d@swipnet.se>
parents:
109640
diff
changeset
|
77 #include <util.h> |
|
9cfca8c9fb07
Fix missing prototypes for HAVE_NS (caused crash) and vrious warnings.
Jan D <jan.h.d@swipnet.se>
parents:
109640
diff
changeset
|
78 #endif |
|
9cfca8c9fb07
Fix missing prototypes for HAVE_NS (caused crash) and vrious warnings.
Jan D <jan.h.d@swipnet.se>
parents:
109640
diff
changeset
|
79 |
|
110680
3bc79f337a57
Small process.c cleanups.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
110648
diff
changeset
|
80 #ifdef HAVE_PTY_H |
|
3bc79f337a57
Small process.c cleanups.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
110648
diff
changeset
|
81 #include <pty.h> |
|
3bc79f337a57
Small process.c cleanups.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
110648
diff
changeset
|
82 #endif |
|
3bc79f337a57
Small process.c cleanups.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
110648
diff
changeset
|
83 |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
84 #endif /* subprocesses */ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
85 |
|
65764
375ab086d366
* image.c (slurp_file, xbm_read_bitmap_data): Cast to the correct
Dan Nicolaescu <dann@ics.uci.edu>
parents:
65713
diff
changeset
|
86 #include "lisp.h" |
| 578 | 87 #include "systime.h" |
|
1047
1ab1ed32e82a
* process.c: Include "systty.h", not "systerm.h".
Jim Blandy <jimb@redhat.com>
parents:
1030
diff
changeset
|
88 #include "systty.h" |
| 578 | 89 |
| 90 #include "window.h" | |
| 91 #include "buffer.h" | |
|
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
92 #include "character.h" |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
93 #include "coding.h" |
| 578 | 94 #include "process.h" |
|
83004
7900111db01c
Converted display hooks to be display-local. Plus many bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents:
82993
diff
changeset
|
95 #include "frame.h" |
| 578 | 96 #include "termhooks.h" |
| 97 #include "termopts.h" | |
| 98 #include "commands.h" | |
|
31099
0fe5afca71e4
Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents:
30582
diff
changeset
|
99 #include "keyboard.h" |
| 16780 | 100 #include "blockinput.h" |
| 21514 | 101 #include "dispextern.h" |
| 26868 | 102 #include "composite.h" |
|
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
103 #include "atimer.h" |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
104 #include "sysselect.h" |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
105 #include "syssignal.h" |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
106 #include "syswait.h" |
| 110584 | 107 #ifdef HAVE_GNUTLS |
| 108 #include "gnutls.h" | |
| 109 #endif | |
| 578 | 110 |
|
106186
9b6f45dd8386
Use a select wrapper around the GLib event loop, thus taking into account GLib
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
106185
diff
changeset
|
111 #if defined (USE_GTK) || defined (HAVE_GCONF) |
|
9b6f45dd8386
Use a select wrapper around the GLib event loop, thus taking into account GLib
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
106185
diff
changeset
|
112 #include "xgselect.h" |
|
9b6f45dd8386
Use a select wrapper around the GLib event loop, thus taking into account GLib
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
106185
diff
changeset
|
113 #endif /* defined (USE_GTK) || defined (HAVE_GCONF) */ |
|
109653
9cfca8c9fb07
Fix missing prototypes for HAVE_NS (caused crash) and vrious warnings.
Jan D <jan.h.d@swipnet.se>
parents:
109640
diff
changeset
|
114 #ifdef HAVE_NS |
|
9cfca8c9fb07
Fix missing prototypes for HAVE_NS (caused crash) and vrious warnings.
Jan D <jan.h.d@swipnet.se>
parents:
109640
diff
changeset
|
115 #include "nsterm.h" |
|
9cfca8c9fb07
Fix missing prototypes for HAVE_NS (caused crash) and vrious warnings.
Jan D <jan.h.d@swipnet.se>
parents:
109640
diff
changeset
|
116 #endif |
| 110730 | 117 |
|
109556
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
118 extern int timers_run; |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
119 |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
120 Lisp_Object Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess, Qttname, Qtpgid; |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
121 Lisp_Object Qminflt, Qmajflt, Qcminflt, Qcmajflt, Qutime, Qstime, Qcstime; |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
122 Lisp_Object Qcutime, Qpri, Qnice, Qthcount, Qstart, Qvsize, Qrss, Qargs; |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
123 Lisp_Object Quser, Qgroup, Qetime, Qpcpu, Qpmem, Qtime, Qctime; |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
124 Lisp_Object QCname, QCtype; |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
125 |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
126 /* Non-zero if keyboard input is on hold, zero otherwise. */ |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
127 |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
128 static int kbd_is_on_hold; |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
129 |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
130 /* Nonzero means delete a process right away if it exits. */ |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
131 static int delete_exited_processes; |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
132 |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
133 /* Nonzero means don't run process sentinels. This is used |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
134 when exiting. */ |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
135 int inhibit_sentinels; |
|
039143f82441
* src/process.c: Move definitions earlier to minimize #ifdefs.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109378
diff
changeset
|
136 |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
137 #ifdef subprocesses |
|
106186
9b6f45dd8386
Use a select wrapper around the GLib event loop, thus taking into account GLib
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
106185
diff
changeset
|
138 |
|
4682
c4d471244116
(keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
4639
diff
changeset
|
139 Lisp_Object Qprocessp; |
| 74749 | 140 Lisp_Object Qrun, Qstop, Qsignal; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
141 Lisp_Object Qopen, Qclosed, Qconnect, Qfailed, Qlisten; |
|
106397
210af1fb2669
(Qseqpacket): New symbol.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106186
diff
changeset
|
142 Lisp_Object Qlocal, Qipv4, Qdatagram, Qseqpacket; |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
143 Lisp_Object Qreal, Qnetwork, Qserial; |
| 68008 | 144 #ifdef AF_INET6 |
| 145 Lisp_Object Qipv6; | |
| 146 #endif | |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
147 Lisp_Object QCport, QCspeed, QCprocess; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
148 Lisp_Object QCbytesize, QCstopbits, QCparity, Qodd, Qeven; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
149 Lisp_Object QCflowcontrol, Qhw, Qsw, QCsummary; |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
150 Lisp_Object QCbuffer, QChost, QCservice; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
151 Lisp_Object QClocal, QCremote, QCcoding; |
|
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
152 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
|
153 Lisp_Object QCsentinel, QClog, QCoptions, QCplist; |
|
8231
5226ed89c1a6
(Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
8063
diff
changeset
|
154 Lisp_Object Qlast_nonmenu_event; |
|
44041
134644f94850
(QCfamily, QCfiler): Remove duplicate declaration and initialization.
Jason Rumney <jasonr@gnu.org>
parents:
44038
diff
changeset
|
155 /* 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
|
156 QCfilter in keyboard.c. */ |
|
134644f94850
(QCfamily, QCfiler): Remove duplicate declaration and initialization.
Jason Rumney <jasonr@gnu.org>
parents:
44038
diff
changeset
|
157 extern Lisp_Object QCfamily, QCfilter; |
|
134644f94850
(QCfamily, QCfiler): Remove duplicate declaration and initialization.
Jason Rumney <jasonr@gnu.org>
parents:
44038
diff
changeset
|
158 |
| 578 | 159 /* Qexit is declared and initialized in eval.c. */ |
| 160 | |
|
44890
01b93e5e53a7
Patch for building Emacs on Mac OS X. April 26, 2002. See ChangeLog,
Andrew Choi <akochoi@shaw.ca>
parents:
44372
diff
changeset
|
161 /* 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
|
162 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
|
163 /* 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
|
164 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
|
165 |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
166 #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
|
167 #define NETCONN1_P(p) (EQ ((p)->type, Qnetwork)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
168 #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
|
169 #define SERIALCONN1_P(p) (EQ ((p)->type, Qserial)) |
| 578 | 170 |
| 171 /* Define first descriptor number available for subprocesses. */ | |
| 172 #define FIRST_PROC_DESC 3 | |
| 173 | |
|
109726
64732fa6188a
Use const char* instead of char*.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109672
diff
changeset
|
174 extern const char *get_operating_system_release (void); |
|
25770
3a44b5298cd5
(list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents:
25760
diff
changeset
|
175 |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
176 /* From sysdep.c or w32.c */ |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
177 extern int serial_open (char *port); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
178 extern void serial_configure (struct Lisp_Process *p, Lisp_Object contact); |
| 578 | 179 |
|
8331
14ddb4c66461
[!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents:
8287
diff
changeset
|
180 #ifndef HAVE_H_ERRNO |
|
14ddb4c66461
[!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents:
8287
diff
changeset
|
181 extern int h_errno; |
|
14ddb4c66461
[!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents:
8287
diff
changeset
|
182 #endif |
|
14ddb4c66461
[!HAVE_H_ERRNO]: Declare h_errno.
Richard M. Stallman <rms@gnu.org>
parents:
8287
diff
changeset
|
183 |
| 578 | 184 /* t means use pty, nil means use a pipe, |
| 185 maybe other values to come. */ | |
|
4682
c4d471244116
(keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
4639
diff
changeset
|
186 static Lisp_Object Vprocess_connection_type; |
| 578 | 187 |
|
10548
dcae4394587d
(process_tick, update_tick): Make non-static.
Karl Heuer <kwzh@gnu.org>
parents:
10527
diff
changeset
|
188 /* These next two vars are non-static since sysdep.c uses them in the |
|
dcae4394587d
(process_tick, update_tick): Make non-static.
Karl Heuer <kwzh@gnu.org>
parents:
10527
diff
changeset
|
189 emulation of `select'. */ |
| 578 | 190 /* Number of events of change of status of a process. */ |
|
10548
dcae4394587d
(process_tick, update_tick): Make non-static.
Karl Heuer <kwzh@gnu.org>
parents:
10527
diff
changeset
|
191 int process_tick; |
| 578 | 192 /* Number of events for which the user or sentinel has been notified. */ |
|
10548
dcae4394587d
(process_tick, update_tick): Make non-static.
Karl Heuer <kwzh@gnu.org>
parents:
10527
diff
changeset
|
193 int update_tick; |
| 578 | 194 |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
195 /* Define NON_BLOCKING_CONNECT if we can support non-blocking connects. */ |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
196 |
|
110594
76b6c21279ec
Don?t give write_mask to select for W32.
Jan D <jan.h.d@swipnet.se>
parents:
110593
diff
changeset
|
197 /* Only W32 has this, it really means that select can't take write mask. */ |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
198 #ifdef BROKEN_NON_BLOCKING_CONNECT |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
199 #undef NON_BLOCKING_CONNECT |
|
110594
76b6c21279ec
Don?t give write_mask to select for W32.
Jan D <jan.h.d@swipnet.se>
parents:
110593
diff
changeset
|
200 #define SELECT_CANT_DO_WRITE_MASK |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
201 #else |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
202 #ifndef NON_BLOCKING_CONNECT |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
203 #ifdef HAVE_SELECT |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
204 #if defined (HAVE_GETPEERNAME) || defined (GNU_LINUX) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
205 #if defined (O_NONBLOCK) || defined (O_NDELAY) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
206 #if defined (EWOULDBLOCK) || defined (EINPROGRESS) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
207 #define NON_BLOCKING_CONNECT |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
208 #endif /* EWOULDBLOCK || EINPROGRESS */ |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
209 #endif /* O_NONBLOCK || O_NDELAY */ |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
210 #endif /* HAVE_GETPEERNAME || GNU_LINUX */ |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
211 #endif /* HAVE_SELECT */ |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
212 #endif /* NON_BLOCKING_CONNECT */ |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
213 #endif /* BROKEN_NON_BLOCKING_CONNECT */ |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
214 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
215 /* Define DATAGRAM_SOCKETS if datagrams can be used safely on |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
216 this system. We need to read full packets, so we need a |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
217 "non-destructive" select. So we require either native select, |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
218 or emulation of select using FIONREAD. */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
219 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
220 #ifdef BROKEN_DATAGRAM_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
221 #undef DATAGRAM_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
222 #else |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
223 #ifndef DATAGRAM_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
224 #if defined (HAVE_SELECT) || defined (FIONREAD) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
225 #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
|
226 #define DATAGRAM_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
227 #endif /* HAVE_SENDTO && HAVE_RECVFROM && EMSGSIZE */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
228 #endif /* HAVE_SELECT || FIONREAD */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
229 #endif /* DATAGRAM_SOCKETS */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
230 #endif /* BROKEN_DATAGRAM_SOCKETS */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
231 |
|
106397
210af1fb2669
(Qseqpacket): New symbol.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106186
diff
changeset
|
232 #if defined HAVE_LOCAL_SOCKETS && defined DATAGRAM_SOCKETS |
|
210af1fb2669
(Qseqpacket): New symbol.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106186
diff
changeset
|
233 # define HAVE_SEQPACKET |
|
210af1fb2669
(Qseqpacket): New symbol.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106186
diff
changeset
|
234 #endif |
|
210af1fb2669
(Qseqpacket): New symbol.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106186
diff
changeset
|
235 |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
236 #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
|
237 #ifdef EMACS_HAS_USECS |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
238 #define ADAPTIVE_READ_BUFFERING |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
239 #endif |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
240 #endif |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
241 |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
242 #ifdef ADAPTIVE_READ_BUFFERING |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
243 #define READ_OUTPUT_DELAY_INCREMENT 10000 |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
244 #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
|
245 #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
|
246 |
|
63114
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
247 /* 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
|
248 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
|
249 |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
250 static int process_output_delay_count; |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
251 |
|
63114
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
252 /* 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
|
253 |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
254 static int process_output_skip; |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
255 |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
256 /* 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
|
257 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
|
258 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
|
259 adaptive read buffering completely. */ |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
260 static Lisp_Object Vprocess_adaptive_read_buffering; |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
261 #else |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
262 #define process_output_delay_count 0 |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
263 #endif |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
264 |
|
109100
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
109087
diff
changeset
|
265 static int keyboard_bit_set (SELECT_TYPE *); |
|
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
109087
diff
changeset
|
266 static void deactivate_process (Lisp_Object); |
|
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
109087
diff
changeset
|
267 static void status_notify (struct Lisp_Process *); |
|
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
109087
diff
changeset
|
268 static int read_process_output (Lisp_Object, int); |
|
2bc9a0c04c87
Remove __P and P_ from .c and .m files and definition of P_
Jan D <jan.h.d@swipnet.se>
parents:
109087
diff
changeset
|
269 static void create_pty (Lisp_Object); |
|
25770
3a44b5298cd5
(list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents:
25760
diff
changeset
|
270 |
|
13414
b035c6e41457
[HAVE_NTGUI] (POLL_FOR_INPUT): Define macro.
Geoff Voelker <voelker@cs.washington.edu>
parents:
13159
diff
changeset
|
271 /* 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
|
272 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
|
273 #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
|
274 #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
|
275 #endif |
|
cfe4840ffde9
(Fopen_network_stream): Call bind_polling_period; later unbind the binding.
Richard M. Stallman <rms@gnu.org>
parents:
7454
diff
changeset
|
276 |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
277 static Lisp_Object get_process (register Lisp_Object name); |
|
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
278 static void exec_sentinel (Lisp_Object proc, Lisp_Object reason); |
|
72727
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
279 |
|
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
280 /* Mask of bits indicating the descriptors that we wait for input on. */ |
| 578 | 281 |
|
4682
c4d471244116
(keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
4639
diff
changeset
|
282 static SELECT_TYPE input_wait_mask; |
|
c4d471244116
(keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
4639
diff
changeset
|
283 |
|
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
284 /* Mask that excludes keyboard input descriptor(s). */ |
|
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
285 |
|
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
286 static SELECT_TYPE non_keyboard_wait_mask; |
|
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
287 |
|
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
288 /* 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
|
289 |
|
dd2545e79add
(wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents:
17110
diff
changeset
|
290 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
|
291 |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
292 /* Mask for selecting for write. */ |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
293 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
294 static SELECT_TYPE write_mask; |
|
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
295 |
|
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
296 #ifdef NON_BLOCKING_CONNECT |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
297 /* 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
|
298 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
|
299 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
|
300 |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
301 static SELECT_TYPE connect_wait_mask; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
302 |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
303 /* Number of bits set in connect_wait_mask. */ |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
304 static int num_pending_connects; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
305 |
|
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
306 #define IF_NON_BLOCKING_CONNECT(s) s |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
307 #else /* NON_BLOCKING_CONNECT */ |
|
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
308 #define IF_NON_BLOCKING_CONNECT(s) |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
309 #endif /* NON_BLOCKING_CONNECT */ |
|
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
310 |
|
7044
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
311 /* 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
|
312 static int max_process_desc; |
|
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
313 |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
314 /* The largest descriptor currently in use for input. */ |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
315 static int max_input_desc; |
| 578 | 316 |
| 317 /* 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
|
318 Lisp_Object chan_process[MAXDESC]; |
| 578 | 319 |
| 320 /* Alist of elements (NAME . PROCESS) */ | |
|
6164
d047d5a48e0e
(chan_process, Vprocess_alist): No longer static.
Richard M. Stallman <rms@gnu.org>
parents:
6158
diff
changeset
|
321 Lisp_Object Vprocess_alist; |
| 578 | 322 |
| 323 /* Buffered-ahead input char from process, indexed by channel. | |
| 324 -1 means empty (no char is buffered). | |
| 325 Used on sys V where the only way to tell if there is any | |
| 326 output from the process is to read at least one char. | |
| 327 Always -1 on systems that support FIONREAD. */ | |
| 328 | |
|
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
329 /* 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
|
330 int proc_buffered_char[MAXDESC]; |
|
4682
c4d471244116
(keyboard_descriptor): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
4639
diff
changeset
|
331 |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
332 /* 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
|
333 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
|
334 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
|
335 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
336 #ifdef DATAGRAM_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
337 /* Table of `partner address' for datagram sockets. */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
338 struct sockaddr_and_len { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
339 struct sockaddr *sa; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
340 int len; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
341 } datagram_address[MAXDESC]; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
342 #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
|
343 #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
|
344 #else |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
345 #define DATAGRAM_CHAN_P(chan) (0) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
346 #define DATAGRAM_CONN_P(proc) (0) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
347 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
348 |
| 6158 | 349 /* Maximum number of bytes to send to a pty without an eof. */ |
| 350 static int pty_max_bytes; | |
|
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
351 |
| 578 | 352 |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
353 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
354 struct fd_callback_data |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
355 { |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
356 fd_callback func; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
357 void *data; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
358 #define FOR_READ 1 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
359 #define FOR_WRITE 2 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
360 int condition; /* mask of the defines above. */ |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
361 } fd_callback_info[MAXDESC]; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
362 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
363 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
364 /* Add a file descriptor FD to be monitored for when read is possible. |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
365 When read is possible, call FUNC with argument DATA. */ |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
366 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
367 void |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
368 add_read_fd (int fd, fd_callback func, void *data) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
369 { |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
370 xassert (fd < MAXDESC); |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
371 add_keyboard_wait_descriptor (fd); |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
372 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
373 fd_callback_info[fd].func = func; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
374 fd_callback_info[fd].data = data; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
375 fd_callback_info[fd].condition |= FOR_READ; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
376 } |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
377 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
378 /* Stop monitoring file descriptor FD for when read is possible. */ |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
379 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
380 void |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
381 delete_read_fd (int fd) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
382 { |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
383 xassert (fd < MAXDESC); |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
384 delete_keyboard_wait_descriptor (fd); |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
385 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
386 fd_callback_info[fd].condition &= ~FOR_READ; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
387 if (fd_callback_info[fd].condition == 0) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
388 { |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
389 fd_callback_info[fd].func = 0; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
390 fd_callback_info[fd].data = 0; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
391 } |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
392 } |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
393 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
394 /* Add a file descriptor FD to be monitored for when write is possible. |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
395 When write is possible, call FUNC with argument DATA. */ |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
396 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
397 void |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
398 add_write_fd (int fd, fd_callback func, void *data) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
399 { |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
400 xassert (fd < MAXDESC); |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
401 FD_SET (fd, &write_mask); |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
402 if (fd > max_input_desc) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
403 max_input_desc = fd; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
404 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
405 fd_callback_info[fd].func = func; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
406 fd_callback_info[fd].data = data; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
407 fd_callback_info[fd].condition |= FOR_WRITE; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
408 } |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
409 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
410 /* Stop monitoring file descriptor FD for when write is possible. */ |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
411 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
412 void |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
413 delete_write_fd (int fd) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
414 { |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
415 int lim = max_input_desc; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
416 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
417 xassert (fd < MAXDESC); |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
418 FD_CLR (fd, &write_mask); |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
419 fd_callback_info[fd].condition &= ~FOR_WRITE; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
420 if (fd_callback_info[fd].condition == 0) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
421 { |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
422 fd_callback_info[fd].func = 0; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
423 fd_callback_info[fd].data = 0; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
424 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
425 if (fd == max_input_desc) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
426 for (fd = lim; fd >= 0; fd--) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
427 if (FD_ISSET (fd, &input_wait_mask) || FD_ISSET (fd, &write_mask)) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
428 { |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
429 max_input_desc = fd; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
430 break; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
431 } |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
432 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
433 } |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
434 } |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
435 |
| 578 | 436 |
| 437 /* Compute the Lisp form of the process status, p->status, from | |
| 438 the numeric status that was returned by `wait'. */ | |
| 439 | |
|
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
|
440 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
|
441 |
|
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
442 static void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
443 update_status (struct Lisp_Process *p) |
| 578 | 444 { |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
445 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
|
446 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
|
447 p->raw_status_new = 0; |
| 578 | 448 } |
| 449 | |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
450 /* Convert a process status word in Unix format to |
| 578 | 451 the list that we use internally. */ |
| 452 | |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
453 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
|
454 status_convert (int w) |
| 578 | 455 { |
| 456 if (WIFSTOPPED (w)) | |
| 457 return Fcons (Qstop, Fcons (make_number (WSTOPSIG (w)), Qnil)); | |
| 458 else if (WIFEXITED (w)) | |
| 459 return Fcons (Qexit, Fcons (make_number (WRETCODE (w)), | |
| 460 WCOREDUMP (w) ? Qt : Qnil)); | |
| 461 else if (WIFSIGNALED (w)) | |
| 462 return Fcons (Qsignal, Fcons (make_number (WTERMSIG (w)), | |
| 463 WCOREDUMP (w) ? Qt : Qnil)); | |
| 464 else | |
| 465 return Qrun; | |
| 466 } | |
| 467 | |
| 468 /* Given a status-list, extract the three pieces of information | |
| 469 and store them individually through the three pointers. */ | |
| 470 | |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
471 static void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
472 decode_status (Lisp_Object l, Lisp_Object *symbol, int *code, int *coredump) |
| 578 | 473 { |
| 474 Lisp_Object tem; | |
| 475 | |
|
9115
59bc2d010b5f
(decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents:
9034
diff
changeset
|
476 if (SYMBOLP (l)) |
| 578 | 477 { |
| 478 *symbol = l; | |
| 479 *code = 0; | |
| 480 *coredump = 0; | |
| 481 } | |
| 482 else | |
| 483 { | |
|
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
484 *symbol = XCAR (l); |
|
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
485 tem = XCDR (l); |
|
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
486 *code = XFASTINT (XCAR (tem)); |
|
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
487 tem = XCDR (tem); |
| 578 | 488 *coredump = !NILP (tem); |
| 489 } | |
| 490 } | |
| 491 | |
| 492 /* Return a string describing a process status list. */ | |
| 493 | |
|
55962
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
494 static Lisp_Object |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
495 status_message (struct Lisp_Process *p) |
| 578 | 496 { |
|
55962
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
497 Lisp_Object status = p->status; |
| 578 | 498 Lisp_Object symbol; |
| 499 int code, coredump; | |
| 500 Lisp_Object string, string2; | |
| 501 | |
| 502 decode_status (status, &symbol, &code, &coredump); | |
| 503 | |
| 504 if (EQ (symbol, Qsignal) || EQ (symbol, Qstop)) | |
| 505 { | |
|
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
506 char *signame; |
|
26526
b7438760079b
* callproc.c (strerror): Remove decl.
Paul Eggert <eggert@twinsun.com>
parents:
26313
diff
changeset
|
507 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
|
508 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
|
509 if (signame == 0) |
|
103432
c849cd055fab
(status_message): Fix previous change. Be sure to
Kenichi Handa <handa@m17n.org>
parents:
103363
diff
changeset
|
510 string = build_string ("unknown"); |
|
c849cd055fab
(status_message): Fix previous change. Be sure to
Kenichi Handa <handa@m17n.org>
parents:
103363
diff
changeset
|
511 else |
|
c849cd055fab
(status_message): Fix previous change. Be sure to
Kenichi Handa <handa@m17n.org>
parents:
103363
diff
changeset
|
512 { |
|
c849cd055fab
(status_message): Fix previous change. Be sure to
Kenichi Handa <handa@m17n.org>
parents:
103363
diff
changeset
|
513 int c1, c2; |
|
c849cd055fab
(status_message): Fix previous change. Be sure to
Kenichi Handa <handa@m17n.org>
parents:
103363
diff
changeset
|
514 |
|
c849cd055fab
(status_message): Fix previous change. Be sure to
Kenichi Handa <handa@m17n.org>
parents:
103363
diff
changeset
|
515 string = make_unibyte_string (signame, strlen (signame)); |
|
c849cd055fab
(status_message): Fix previous change. Be sure to
Kenichi Handa <handa@m17n.org>
parents:
103363
diff
changeset
|
516 if (! NILP (Vlocale_coding_system)) |
|
c849cd055fab
(status_message): Fix previous change. Be sure to
Kenichi Handa <handa@m17n.org>
parents:
103363
diff
changeset
|
517 string = (code_convert_string_norecord |
|
c849cd055fab
(status_message): Fix previous change. Be sure to
Kenichi Handa <handa@m17n.org>
parents:
103363
diff
changeset
|
518 (string, Vlocale_coding_system, 0)); |
|
106185
f2cea199b0c4
* character.h (STRING_CHAR, STRING_CHAR_AND_LENGTH): Remove
Andreas Schwab <schwab@linux-m68k.org>
parents:
105959
diff
changeset
|
519 c1 = STRING_CHAR ((char *) SDATA (string)); |
|
103432
c849cd055fab
(status_message): Fix previous change. Be sure to
Kenichi Handa <handa@m17n.org>
parents:
103363
diff
changeset
|
520 c2 = DOWNCASE (c1); |
|
c849cd055fab
(status_message): Fix previous change. Be sure to
Kenichi Handa <handa@m17n.org>
parents:
103363
diff
changeset
|
521 if (c1 != c2) |
|
103496
e13621e7689e
(status_message): Pass Faset index argument as a lisp object, so as to work
Ken Raeburn <raeburn@raeburn.org>
parents:
103432
diff
changeset
|
522 Faset (string, make_number (0), make_number (c2)); |
|
103432
c849cd055fab
(status_message): Fix previous change. Be sure to
Kenichi Handa <handa@m17n.org>
parents:
103363
diff
changeset
|
523 } |
| 578 | 524 string2 = build_string (coredump ? " (core dumped)\n" : "\n"); |
| 525 return concat2 (string, string2); | |
| 526 } | |
| 527 else if (EQ (symbol, Qexit)) | |
| 528 { | |
|
55962
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
529 if (NETCONN1_P (p)) |
|
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
530 return build_string (code == 0 ? "deleted\n" : "connection broken by remote peer\n"); |
| 578 | 531 if (code == 0) |
| 532 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
|
533 string = Fnumber_to_string (make_number (code)); |
| 578 | 534 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
|
535 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
|
536 string, string2); |
| 578 | 537 } |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
538 else if (EQ (symbol, Qfailed)) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
539 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
540 string = Fnumber_to_string (make_number (code)); |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
541 string2 = build_string ("\n"); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
542 return concat3 (build_string ("failed with code "), |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
543 string, string2); |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
544 } |
| 578 | 545 else |
| 546 return Fcopy_sequence (Fsymbol_name (symbol)); | |
| 547 } | |
| 548 | |
| 549 #ifdef HAVE_PTYS | |
| 550 | |
|
110680
3bc79f337a57
Small process.c cleanups.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
110648
diff
changeset
|
551 /* The file name of the pty opened by allocate_pty. */ |
|
3bc79f337a57
Small process.c cleanups.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
110648
diff
changeset
|
552 static char pty_name[24]; |
|
3bc79f337a57
Small process.c cleanups.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
110648
diff
changeset
|
553 |
|
11609
3b2dacb1bfe9
(create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents:
11514
diff
changeset
|
554 /* 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
|
555 Return -1 on failure. |
|
3b2dacb1bfe9
(create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents:
11514
diff
changeset
|
556 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
|
557 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
|
558 |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
559 static int |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
560 allocate_pty (void) |
| 578 | 561 { |
| 21514 | 562 register int c, i; |
| 578 | 563 int fd; |
| 564 | |
| 565 #ifdef PTY_ITERATION | |
| 566 PTY_ITERATION | |
| 567 #else | |
| 568 for (c = FIRST_PTY_LETTER; c <= 'z'; c++) | |
| 569 for (i = 0; i < 16; i++) | |
| 570 #endif | |
| 571 { | |
|
51473
58061223557c
(allocate_pty): Revert part of the previous patch.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51233
diff
changeset
|
572 struct stat stb; /* Used in some PTY_OPEN. */ |
| 578 | 573 #ifdef PTY_NAME_SPRINTF |
| 574 PTY_NAME_SPRINTF | |
| 575 #else | |
| 576 sprintf (pty_name, "/dev/pty%c%x", c, i); | |
| 577 #endif /* no PTY_NAME_SPRINTF */ | |
| 578 | |
|
822
c6e94e13926c
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
579 #ifdef PTY_OPEN |
|
c6e94e13926c
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
580 PTY_OPEN; |
|
c6e94e13926c
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
581 #else /* no PTY_OPEN */ |
|
51233
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
582 { |
|
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
583 { /* 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
|
584 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
|
585 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
|
586 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
|
587 end of the ptys. */ |
|
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
588 int failed_count = 0; |
|
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
589 |
|
51233
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
590 if (stat (pty_name, &stb) < 0) |
|
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
591 { |
|
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
592 failed_count++; |
|
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
593 if (failed_count >= 3) |
|
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
594 return -1; |
|
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
595 } |
|
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
596 else |
|
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
597 failed_count = 0; |
| 624 | 598 } |
|
51233
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
599 # ifdef O_NONBLOCK |
|
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
600 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
|
601 # else |
|
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
602 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
|
603 # endif |
|
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
604 } |
|
822
c6e94e13926c
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
605 #endif /* no PTY_OPEN */ |
| 578 | 606 |
| 607 if (fd >= 0) | |
| 608 { | |
| 609 /* check to make certain that both sides are available | |
| 610 this avoids a nasty yet stupid bug in rlogins */ | |
| 611 #ifdef PTY_TTY_NAME_SPRINTF | |
| 612 PTY_TTY_NAME_SPRINTF | |
| 613 #else | |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
614 sprintf (pty_name, "/dev/tty%c%x", c, i); |
| 578 | 615 #endif /* no PTY_TTY_NAME_SPRINTF */ |
| 616 if (access (pty_name, 6) != 0) | |
| 617 { | |
|
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
618 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
|
619 # ifndef __sgi |
| 578 | 620 continue; |
|
51233
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
621 # else |
| 578 | 622 return -1; |
|
96732
1e0b67e40d48
* systty.h: Remove code for Aix on 386, unsupported platform.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96675
diff
changeset
|
623 # endif /* __sgi */ |
| 578 | 624 } |
| 625 setup_pty (fd); | |
| 626 return fd; | |
| 627 } | |
| 628 } | |
| 629 return -1; | |
| 630 } | |
| 631 #endif /* HAVE_PTYS */ | |
| 632 | |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
633 static Lisp_Object |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
634 make_process (Lisp_Object name) |
| 578 | 635 { |
| 636 register Lisp_Object val, tem, name1; | |
| 637 register struct Lisp_Process *p; | |
| 638 char suffix[10]; | |
| 639 register int i; | |
| 640 | |
|
36434
40cfe4976f04
(make_process): Use allocate_process.
Gerd Moellmann <gerd@gnu.org>
parents:
35336
diff
changeset
|
641 p = allocate_process (); |
|
9969
007d93b04e1f
(make_process): Use allocate_vectorlike and VECSIZE.
Karl Heuer <kwzh@gnu.org>
parents:
9952
diff
changeset
|
642 |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
643 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
|
644 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
|
645 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
|
646 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
|
647 p->pid = 0; |
| 87470 | 648 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
|
649 p->raw_status_new = 0; |
| 578 | 650 p->status = Qrun; |
| 651 p->mark = Fmake_marker (); | |
|
97498
e4a1b306a650
(make_process): Initialize kill_without_query struct member.
Chong Yidong <cyd@stupidchicken.com>
parents:
97405
diff
changeset
|
652 p->kill_without_query = 0; |
| 578 | 653 |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
654 #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
|
655 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
|
656 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
|
657 p->read_output_skip = 0; |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
658 #endif |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
659 |
| 110584 | 660 #ifdef HAVE_GNUTLS |
| 661 p->gnutls_initstage = GNUTLS_STAGE_EMPTY; | |
|
110611
6c735824d0c1
Add gnutls logging and clean up various gnutls bits.
Lars Magne Ingebrigtsen <larsi@gnus.org>
parents:
110594
diff
changeset
|
662 p->gnutls_log_level = 0; |
|
110648
256dd50b2a63
Make sure all reads/writes to gnutls streams go via the gnutls functions.
Lars Magne Ingebrigtsen <larsi@gnus.org>
parents:
110613
diff
changeset
|
663 p->gnutls_p = 0; |
| 110584 | 664 #endif |
| 665 | |
| 578 | 666 /* If name is already in use, modify it until it is unused. */ |
| 667 | |
| 668 name1 = name; | |
| 669 for (i = 1; ; i++) | |
| 670 { | |
| 671 tem = Fget_process (name1); | |
| 672 if (NILP (tem)) break; | |
| 673 sprintf (suffix, "<%d>", i); | |
| 674 name1 = concat2 (name, build_string (suffix)); | |
| 675 } | |
| 676 name = name1; | |
| 677 p->name = name; | |
|
9969
007d93b04e1f
(make_process): Use allocate_vectorlike and VECSIZE.
Karl Heuer <kwzh@gnu.org>
parents:
9952
diff
changeset
|
678 XSETPROCESS (val, p); |
| 578 | 679 Vprocess_alist = Fcons (Fcons (name, val), Vprocess_alist); |
| 680 return val; | |
| 681 } | |
| 682 | |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
683 static void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
684 remove_process (register Lisp_Object proc) |
| 578 | 685 { |
| 686 register Lisp_Object pair; | |
| 687 | |
| 688 pair = Frassq (proc, Vprocess_alist); | |
| 689 Vprocess_alist = Fdelq (pair, Vprocess_alist); | |
| 690 | |
| 691 deactivate_process (proc); | |
| 692 } | |
|
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
693 |
| 578 | 694 |
| 695 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
|
696 doc: /* Return t if OBJECT is a process. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
697 (Lisp_Object object) |
| 578 | 698 { |
|
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
699 return PROCESSP (object) ? Qt : Qnil; |
| 578 | 700 } |
| 701 | |
| 702 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
|
703 doc: /* Return the process named NAME, or nil if there is none. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
704 (register Lisp_Object name) |
| 578 | 705 { |
|
9115
59bc2d010b5f
(decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents:
9034
diff
changeset
|
706 if (PROCESSP (name)) |
| 578 | 707 return name; |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
708 CHECK_STRING (name); |
| 578 | 709 return Fcdr (Fassoc (name, Vprocess_alist)); |
| 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 |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
718 get_process (register Lisp_Object name) |
| 578 | 719 { |
|
6313
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
720 register Lisp_Object proc, obj; |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
721 if (STRINGP (name)) |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
722 { |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
723 obj = Fget_process (name); |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
724 if (NILP (obj)) |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
725 obj = Fget_buffer (name); |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
726 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
|
727 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
|
728 } |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
729 else if (NILP (name)) |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
730 obj = Fcurrent_buffer (); |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
731 else |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
732 obj = name; |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
733 |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
734 /* 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
|
735 */ |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
736 if (BUFFERP (obj)) |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
737 { |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
738 proc = Fget_buffer_process (obj); |
|
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
739 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
|
740 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
|
741 } |
| 578 | 742 else |
| 743 { | |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
744 CHECK_PROCESS (obj); |
|
6313
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
745 proc = obj; |
| 578 | 746 } |
|
6313
9a6531e6de5d
(get_process): Allow arg to be a buffer object.
Karl Heuer <kwzh@gnu.org>
parents:
6253
diff
changeset
|
747 return proc; |
| 578 | 748 } |
| 749 | |
|
71140
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
750 |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
751 #ifdef SIGCHLD |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
752 /* 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
|
753 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
|
754 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
|
755 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
|
756 dead. */ |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
757 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
|
758 #endif |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
759 |
| 578 | 760 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
|
761 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
|
762 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
|
763 nil, indicating the current buffer's process. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
764 (register Lisp_Object process) |
| 578 | 765 { |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
766 register struct Lisp_Process *p; |
|
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
767 |
|
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
768 process = get_process (process); |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
769 p = XPROCESS (process); |
|
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
770 |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
771 p->raw_status_new = 0; |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
772 if (NETCONN1_P (p) || SERIALCONN1_P (p)) |
| 578 | 773 { |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
774 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
|
775 p->tick = ++process_tick; |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
776 status_notify (p); |
|
104316
bb8ce3c842e7
* process.c (status_notify): Don't perform redisplay.
Chong Yidong <cyd@stupidchicken.com>
parents:
104265
diff
changeset
|
777 redisplay_preserve_echo_area (13); |
| 578 | 778 } |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
779 else if (p->infd >= 0) |
| 578 | 780 { |
|
71140
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
781 #ifdef SIGCHLD |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
782 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
|
783 /* 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
|
784 of data type. */ |
|
76494
f0a25b5d3ba0
(Fdelete_process): Properly handle deletion of first element of
Chong Yidong <cyd@stupidchicken.com>
parents:
76493
diff
changeset
|
785 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
|
786 |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
787 /* 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
|
788 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
|
789 /* 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
|
790 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
|
791 /* 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
|
792 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
|
793 update_status (p); |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
794 symbol = p->status; |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
795 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
|
796 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
|
797 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
|
798 deleted_pid_list |
|
f0a25b5d3ba0
(Fdelete_process): Properly handle deletion of first element of
Chong Yidong <cyd@stupidchicken.com>
parents:
76493
diff
changeset
|
799 = 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
|
800 else |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
801 #endif |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
802 { |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
803 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
|
804 /* 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
|
805 p->status |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
806 = 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
|
807 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
|
808 status_notify (p); |
|
104316
bb8ce3c842e7
* process.c (status_notify): Don't perform redisplay.
Chong Yidong <cyd@stupidchicken.com>
parents:
104265
diff
changeset
|
809 redisplay_preserve_echo_area (13); |
|
71140
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. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
831 (register Lisp_Object process) |
| 578 | 832 { |
| 833 register struct Lisp_Process *p; | |
| 834 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
|
835 |
|
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
836 if (STRINGP (process)) |
|
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
837 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
|
838 else |
|
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
839 process = get_process (process); |
|
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
840 |
|
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
841 if (NILP (process)) |
|
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
842 return process; |
|
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
843 |
|
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
844 p = XPROCESS (process); |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
845 if (p->raw_status_new) |
| 578 | 846 update_status (p); |
| 847 status = p->status; | |
|
9115
59bc2d010b5f
(decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents:
9034
diff
changeset
|
848 if (CONSP (status)) |
|
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
849 status = XCAR (status); |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
850 if (NETCONN1_P (p) || SERIALCONN1_P (p)) |
| 578 | 851 { |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
852 if (EQ (status, Qexit)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
853 status = Qclosed; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
854 else if (EQ (p->command, Qt)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
855 status = Qstop; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
856 else if (EQ (status, Qrun)) |
| 578 | 857 status = Qopen; |
| 858 } | |
| 859 return status; | |
| 860 } | |
| 861 | |
| 862 DEFUN ("process-exit-status", Fprocess_exit_status, Sprocess_exit_status, | |
| 863 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
|
864 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
|
865 If PROCESS has not yet exited or died, return 0. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
866 (register Lisp_Object process) |
| 578 | 867 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
868 CHECK_PROCESS (process); |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
869 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
|
870 update_status (XPROCESS (process)); |
|
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
871 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
|
872 return XCAR (XCDR (XPROCESS (process)->status)); |
| 578 | 873 return make_number (0); |
| 874 } | |
| 875 | |
| 876 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
|
877 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
|
878 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
|
879 For a network connection, this value is nil. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
880 (register Lisp_Object process) |
| 578 | 881 { |
|
75220
1b003fe28dfe
(Fdelete_process, Fprocess_id, sigchld_handler): Copy PID into EMACS_INT
Eli Zaretskii <eliz@gnu.org>
parents:
74946
diff
changeset
|
882 /* 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
|
883 data type. */ |
|
1b003fe28dfe
(Fdelete_process, Fprocess_id, sigchld_handler): Copy PID into EMACS_INT
Eli Zaretskii <eliz@gnu.org>
parents:
74946
diff
changeset
|
884 EMACS_INT pid; |
|
1b003fe28dfe
(Fdelete_process, Fprocess_id, sigchld_handler): Copy PID into EMACS_INT
Eli Zaretskii <eliz@gnu.org>
parents:
74946
diff
changeset
|
885 |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
886 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
|
887 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
|
888 return (pid ? make_fixnum_or_float (pid) : Qnil); |
| 578 | 889 } |
| 890 | |
| 891 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
|
892 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
|
893 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
|
894 possibly modified to make it unique among process names. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
895 (register Lisp_Object process) |
| 578 | 896 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
897 CHECK_PROCESS (process); |
|
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
898 return XPROCESS (process)->name; |
| 578 | 899 } |
| 900 | |
| 901 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
|
902 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
|
903 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
|
904 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
|
905 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
|
906 \(process is stopped). */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
907 (register Lisp_Object process) |
| 578 | 908 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
909 CHECK_PROCESS (process); |
|
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
910 return XPROCESS (process)->command; |
| 578 | 911 } |
| 912 | |
|
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
913 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
|
914 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
|
915 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
|
916 not the name of the pty that Emacs uses to talk with that terminal. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
917 (register Lisp_Object process) |
|
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
918 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
919 CHECK_PROCESS (process); |
|
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
920 return XPROCESS (process)->tty_name; |
|
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
921 } |
|
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
922 |
| 578 | 923 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
|
924 2, 2, 0, |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
925 doc: /* Set buffer associated with PROCESS to BUFFER (a buffer, or nil). */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
926 (register Lisp_Object process, Lisp_Object buffer) |
| 578 | 927 { |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
928 struct Lisp_Process *p; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
929 |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
930 CHECK_PROCESS (process); |
| 578 | 931 if (!NILP (buffer)) |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
932 CHECK_BUFFER (buffer); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
933 p = XPROCESS (process); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
934 p->buffer = buffer; |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
935 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
|
936 p->childp = Fplist_put (p->childp, QCbuffer, buffer); |
|
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
937 setup_process_coding_systems (process); |
| 578 | 938 return buffer; |
| 939 } | |
| 940 | |
| 941 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
|
942 1, 1, 0, |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
943 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
|
944 Output from PROCESS is inserted in this buffer unless PROCESS has a filter. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
945 (register Lisp_Object process) |
| 578 | 946 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
947 CHECK_PROCESS (process); |
|
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
948 return XPROCESS (process)->buffer; |
| 578 | 949 } |
| 950 | |
| 951 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
|
952 1, 1, 0, |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
953 doc: /* Return the marker for the end of the last output from PROCESS. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
954 (register Lisp_Object process) |
| 578 | 955 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
956 CHECK_PROCESS (process); |
|
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
957 return XPROCESS (process)->mark; |
| 578 | 958 } |
| 959 | |
| 960 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
|
961 2, 2, 0, |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
962 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
|
963 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
|
964 |
|
f9e4999d3025
(set-process-filter): Document unibyte/multibyte-ness of string argument.
Kim F. Storm <storm@cua.dk>
parents:
49229
diff
changeset
|
965 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
|
966 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
|
967 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
|
968 |
|
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
969 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
|
970 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
|
971 - 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
|
972 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
|
973 - 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
|
974 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
|
975 string to unibyte with `string-make-unibyte'). */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
976 (register Lisp_Object process, Lisp_Object filter) |
| 578 | 977 { |
|
36623
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
978 struct Lisp_Process *p; |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
979 |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
980 CHECK_PROCESS (process); |
|
36623
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
981 p = XPROCESS (process); |
|
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
982 |
|
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
983 /* 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
|
984 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
|
985 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
|
986 |
|
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
987 (setq process (start-process ...)) |
|
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
988 (debug) |
|
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
989 (set-process-filter process ...) */ |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
990 |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
991 if (p->infd >= 0) |
|
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
992 { |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
993 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
|
994 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
995 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
|
996 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
|
997 } |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
998 else if (EQ (p->filter, Qt) |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
999 /* Network or serial process not stopped: */ |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1000 && !EQ (p->command, Qt)) |
|
36623
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
1001 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1002 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
|
1003 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
|
1004 } |
|
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
1005 } |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
1006 |
|
36623
9fde2182c68a
(Fset_process_filter): Don't crash if the input
Gerd Moellmann <gerd@gnu.org>
parents:
36434
diff
changeset
|
1007 p->filter = filter; |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1008 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
|
1009 p->childp = Fplist_put (p->childp, QCfilter, filter); |
|
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
1010 setup_process_coding_systems (process); |
| 578 | 1011 return filter; |
| 1012 } | |
| 1013 | |
| 1014 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
|
1015 1, 1, 0, |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1016 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
|
1017 See `set-process-filter' for more info on filter functions. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1018 (register Lisp_Object process) |
| 578 | 1019 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1020 CHECK_PROCESS (process); |
|
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1021 return XPROCESS (process)->filter; |
| 578 | 1022 } |
| 1023 | |
| 1024 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
|
1025 2, 2, 0, |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1026 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
|
1027 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
|
1028 It gets two arguments: the process, and a string describing the change. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1029 (register Lisp_Object process, Lisp_Object sentinel) |
| 578 | 1030 { |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
1031 struct Lisp_Process *p; |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
1032 |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1033 CHECK_PROCESS (process); |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
1034 p = XPROCESS (process); |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
1035 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
1036 p->sentinel = sentinel; |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1037 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
|
1038 p->childp = Fplist_put (p->childp, QCsentinel, sentinel); |
| 578 | 1039 return sentinel; |
| 1040 } | |
| 1041 | |
| 1042 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
|
1043 1, 1, 0, |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1044 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
|
1045 See `set-process-sentinel' for more info on sentinels. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1046 (register Lisp_Object process) |
| 578 | 1047 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1048 CHECK_PROCESS (process); |
|
14085
85ce7bab31dc
(Fprocessp, Fget_buffer_process, Fdelete_process, Fprocess_status,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1049 return XPROCESS (process)->sentinel; |
| 578 | 1050 } |
| 1051 | |
|
6830
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
1052 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
|
1053 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
|
1054 doc: /* Tell PROCESS that it has logical window size HEIGHT and WIDTH. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1055 (register Lisp_Object process, Lisp_Object height, Lisp_Object width) |
|
6830
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
1056 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1057 CHECK_PROCESS (process); |
|
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1058 CHECK_NATNUM (height); |
|
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1059 CHECK_NATNUM (width); |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
1060 |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1061 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
|
1062 || 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
|
1063 XINT (height), XINT (width)) <= 0) |
|
6830
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
1064 return Qnil; |
|
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
1065 else |
|
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
1066 return Qt; |
|
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
1067 } |
|
bcaddbe53068
(Fset_process_window_size): New function.
Richard M. Stallman <rms@gnu.org>
parents:
6823
diff
changeset
|
1068 |
|
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1069 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
|
1070 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
|
1071 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
|
1072 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
|
1073 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
|
1074 `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
|
1075 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
|
1076 the process output. |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1077 |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1078 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
|
1079 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
|
1080 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
|
1081 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
|
1082 |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
1083 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
|
1084 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
|
1085 for the process which will run. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1086 (register Lisp_Object process, Lisp_Object flag) |
|
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1087 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1088 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
|
1089 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
|
1090 return flag; |
|
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1091 } |
|
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1092 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1093 DEFUN ("set-process-query-on-exit-flag", |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1094 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
|
1095 2, 2, 0, |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1096 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
|
1097 If the second argument FLAG is non-nil, Emacs will query the user before |
|
103972
2e99121a6895
(Fset_process_query_on_exit_flag): Mention killing
Juri Linkov <juri@jurta.org>
parents:
103621
diff
changeset
|
1098 exiting or killing a buffer if PROCESS is running. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1099 (register Lisp_Object process, Lisp_Object flag) |
| 578 | 1100 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1101 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
|
1102 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
|
1103 return flag; |
| 578 | 1104 } |
|
4231
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1105 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1106 DEFUN ("process-query-on-exit-flag", |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1107 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
|
1108 1, 1, 0, |
|
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
1109 doc: /* Return the current value of query-on-exit flag for PROCESS. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1110 (register Lisp_Object process) |
|
16058
924aeb9ed7c3
(Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16053
diff
changeset
|
1111 { |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1112 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
|
1113 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
|
1114 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1115 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1116 #ifdef DATAGRAM_SOCKETS |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
1117 Lisp_Object Fprocess_datagram_address (Lisp_Object process); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1118 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1119 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1120 DEFUN ("process-contact", Fprocess_contact, Sprocess_contact, |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1121 1, 2, 0, |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1122 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
|
1123 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
|
1124 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
|
1125 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
|
1126 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
|
1127 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
|
1128 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
|
1129 list of keywords. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1130 (register Lisp_Object process, Lisp_Object key) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1131 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1132 Lisp_Object contact; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1133 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1134 CHECK_PROCESS (process); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1135 contact = XPROCESS (process)->childp; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1136 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1137 #ifdef DATAGRAM_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1138 if (DATAGRAM_CONN_P (process) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1139 && (EQ (key, Qt) || EQ (key, QCremote))) |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
1140 contact = Fplist_put (contact, QCremote, |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1141 Fprocess_datagram_address (process)); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1142 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1143 |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1144 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
|
1145 return contact; |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1146 if (NILP (key) && NETCONN_P (process)) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1147 return Fcons (Fplist_get (contact, QChost), |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1148 Fcons (Fplist_get (contact, QCservice), Qnil)); |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1149 if (NILP (key) && SERIALCONN_P (process)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1150 return Fcons (Fplist_get (contact, QCport), |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1151 Fcons (Fplist_get (contact, QCspeed), Qnil)); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1152 return Fplist_get (contact, key); |
|
16058
924aeb9ed7c3
(Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16053
diff
changeset
|
1153 } |
|
924aeb9ed7c3
(Fprocess_contact): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16053
diff
changeset
|
1154 |
|
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1155 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
|
1156 1, 1, 0, |
|
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1157 doc: /* Return the plist of PROCESS. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1158 (register Lisp_Object process) |
| 49164 | 1159 { |
| 1160 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
|
1161 return XPROCESS (process)->plist; |
| 49164 | 1162 } |
| 1163 | |
|
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1164 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
|
1165 2, 2, 0, |
|
49229
a3af03912e6f
(Fset_process_plist): Fixed return value.
Kim F. Storm <storm@cua.dk>
parents:
49223
diff
changeset
|
1166 doc: /* Replace the plist of PROCESS with PLIST. Returns PLIST. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1167 (register Lisp_Object process, Lisp_Object plist) |
|
49142
8dca38bc0261
(Fset_process_contact): New function.
Kim F. Storm <storm@cua.dk>
parents:
49119
diff
changeset
|
1168 { |
|
8dca38bc0261
(Fset_process_contact): New function.
Kim F. Storm <storm@cua.dk>
parents:
49119
diff
changeset
|
1169 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
|
1170 CHECK_LIST (plist); |
|
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1171 |
|
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
1172 XPROCESS (process)->plist = plist; |
|
49229
a3af03912e6f
(Fset_process_plist): Fixed return value.
Kim F. Storm <storm@cua.dk>
parents:
49223
diff
changeset
|
1173 return plist; |
|
49142
8dca38bc0261
(Fset_process_contact): New function.
Kim F. Storm <storm@cua.dk>
parents:
49119
diff
changeset
|
1174 } |
|
8dca38bc0261
(Fset_process_contact): New function.
Kim F. Storm <storm@cua.dk>
parents:
49119
diff
changeset
|
1175 |
|
4231
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1176 #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
|
1177 in the process. Perhaps add it. */ |
|
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1178 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
|
1179 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
|
1180 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
|
1181 a socket connection. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1182 (Lisp_Object process) |
|
4231
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1183 { |
|
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1184 return XPROCESS (process)->type; |
|
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1185 } |
|
91a883c56382
(Fget_buffer_process): Delete doc string from
Richard M. Stallman <rms@gnu.org>
parents:
4057
diff
changeset
|
1186 #endif |
|
98456
a68b7a895cb6
(Faccept_process_output): Fix doc-string.
Martin Rudalics <rudalics@gmx.at>
parents:
98248
diff
changeset
|
1187 |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1188 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
|
1189 doc: /* Return the connection type of PROCESS. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1190 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
|
1191 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
|
1192 nil, indicating the current buffer's process. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1193 (Lisp_Object process) |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1194 { |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1195 Lisp_Object proc; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1196 proc = get_process (process); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1197 return XPROCESS (proc)->type; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1198 } |
|
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1199 |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1200 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
|
1201 1, 2, 0, |
|
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1202 doc: /* Convert network ADDRESS from internal format to a string. |
| 68008 | 1203 A 4 or 5 element vector represents an IPv4 address (with port number). |
| 1204 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
|
1205 If optional second argument OMIT-PORT is non-nil, don't include a port |
| 68008 | 1206 number in the string, even when present in ADDRESS. |
| 1207 Returns nil if format of ADDRESS is invalid. */) | |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1208 (Lisp_Object address, Lisp_Object omit_port) |
|
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1209 { |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1210 if (NILP (address)) |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1211 return Qnil; |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1212 |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1213 if (STRINGP (address)) /* AF_LOCAL */ |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1214 return address; |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1215 |
| 68008 | 1216 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
|
1217 { |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1218 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
|
1219 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
|
1220 int nargs, i; |
|
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1221 |
| 68008 | 1222 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
|
1223 { |
|
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1224 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
|
1225 nargs = 4; |
|
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1226 } |
|
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1227 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
|
1228 { |
|
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1229 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
|
1230 nargs = 5; |
|
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1231 } |
| 68008 | 1232 else if (p->size == 8 || (p->size == 9 && !NILP (omit_port))) |
| 1233 { | |
| 1234 args[0] = build_string ("%x:%x:%x:%x:%x:%x:%x:%x"); | |
| 1235 nargs = 8; | |
| 1236 } | |
| 1237 else if (p->size == 9) | |
| 1238 { | |
| 1239 args[0] = build_string ("[%x:%x:%x:%x:%x:%x:%x:%x]:%d"); | |
| 1240 nargs = 9; | |
| 1241 } | |
|
49114
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1242 else |
|
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1243 return Qnil; |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1244 |
|
49114
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1245 for (i = 0; i < nargs; i++) |
|
76789
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1246 { |
|
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1247 EMACS_INT element = XINT (p->contents[i]); |
|
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1248 |
|
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1249 if (element < 0 || element > 65535) |
|
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1250 return Qnil; |
|
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1251 |
|
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1252 if (nargs <= 5 /* IPv4 */ |
|
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1253 && i < 4 /* host, not port */ |
|
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1254 && element > 255) |
|
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1255 return Qnil; |
|
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1256 |
|
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1257 args[i+1] = p->contents[i]; |
|
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1258 } |
|
e3f8914e3f5e
(Fformat_network_address): Return nil when the
Juanma Barranquero <lekktu@gmail.com>
parents:
76760
diff
changeset
|
1259 |
|
49114
c87af62cc6b4
(format-network-address): Added optional OMIT-PORT arg. Callers changed.
Kim F. Storm <storm@cua.dk>
parents:
49111
diff
changeset
|
1260 return Fformat (nargs+1, args); |
|
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1261 } |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1262 |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1263 if (CONSP (address)) |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1264 { |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1265 Lisp_Object args[2]; |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1266 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
|
1267 args[1] = Fcar (address); |
|
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1268 return Fformat (2, args); |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1269 } |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1270 |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1271 return Qnil; |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1272 } |
| 578 | 1273 |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
1274 static Lisp_Object |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
1275 list_processes_1 (Lisp_Object query_only) |
| 578 | 1276 { |
| 1277 register Lisp_Object tail, tem; | |
| 1278 Lisp_Object proc, minspace, tem1; | |
| 1279 register struct Lisp_Process *p; | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1280 char tembuf[300]; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1281 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
|
1282 int exited = 0; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1283 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
|
1284 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1285 w_proc = 4; /* Proc */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1286 w_buffer = 6; /* Buffer */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1287 w_tty = 0; /* Omit if no ttys */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1288 |
|
85372
f7d19cfed7da
* xselect.c (x_own_selection, x_handle_selection_clear)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
85362
diff
changeset
|
1289 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
|
1290 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1291 int i; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1292 |
|
85372
f7d19cfed7da
* xselect.c (x_own_selection, x_handle_selection_clear)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
85362
diff
changeset
|
1293 proc = Fcdr (XCAR (tail)); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1294 p = XPROCESS (proc); |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1295 if (NILP (p->type)) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1296 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
|
1297 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
|
1298 continue; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1299 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
|
1300 && ( 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
|
1301 w_proc = i; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1302 if (!NILP (p->buffer)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1303 { |
|
87849
8f7e97005eef
(list_processes_1): Don't use SCHARS on a nil buffer name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
87730
diff
changeset
|
1304 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
|
1305 { |
|
8f7e97005eef
(list_processes_1): Don't use SCHARS on a nil buffer name.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
87730
diff
changeset
|
1306 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
|
1307 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
|
1308 } |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46314
diff
changeset
|
1309 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
|
1310 w_buffer = i; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1311 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1312 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
|
1313 && (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
|
1314 w_tty = i; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1315 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1316 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1317 XSETFASTINT (i_status, w_proc + 1); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1318 XSETFASTINT (i_buffer, XFASTINT (i_status) + 9); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1319 if (w_tty) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1320 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1321 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
|
1322 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
|
1323 } |
|
c2586e2e84d3
(list_processes_1): Fix indentation level of the
Andreas Schwab <schwab@suse.de>
parents:
79147
diff
changeset
|
1324 else |
|
c2586e2e84d3
(list_processes_1): Fix indentation level of the
Andreas Schwab <schwab@suse.de>
parents:
79147
diff
changeset
|
1325 { |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1326 i_tty = Qnil; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1327 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
|
1328 } |
| 578 | 1329 |
|
9318
a14cc1712337
(make_process, list_processes_1, create_process, Faccept_process_output,
Karl Heuer <kwzh@gnu.org>
parents:
9277
diff
changeset
|
1330 XSETFASTINT (minspace, 1); |
| 578 | 1331 |
| 1332 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
|
1333 current_buffer->undo_list = Qt; |
| 578 | 1334 |
| 1335 current_buffer->truncate_lines = Qt; | |
| 1336 | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1337 write_string ("Proc", -1); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1338 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
|
1339 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
|
1340 if (!NILP (i_tty)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1341 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1342 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
|
1343 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1344 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
|
1345 write_string ("\n", -1); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1346 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1347 write_string ("----", -1); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1348 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
|
1349 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
|
1350 if (!NILP (i_tty)) |
|
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 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
|
1353 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1354 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
|
1355 write_string ("\n", -1); |
| 578 | 1356 |
|
85372
f7d19cfed7da
* xselect.c (x_own_selection, x_handle_selection_clear)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
85362
diff
changeset
|
1357 for (tail = Vprocess_alist; CONSP (tail); tail = XCDR (tail)) |
| 578 | 1358 { |
| 1359 Lisp_Object symbol; | |
| 1360 | |
|
85372
f7d19cfed7da
* xselect.c (x_own_selection, x_handle_selection_clear)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
85362
diff
changeset
|
1361 proc = Fcdr (XCAR (tail)); |
| 578 | 1362 p = XPROCESS (proc); |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1363 if (NILP (p->type)) |
| 578 | 1364 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
|
1365 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
|
1366 continue; |
| 578 | 1367 |
| 1368 Finsert (1, &p->name); | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1369 Findent_to (i_status, minspace); |
| 578 | 1370 |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
1371 if (p->raw_status_new) |
| 578 | 1372 update_status (p); |
| 1373 symbol = p->status; | |
|
9115
59bc2d010b5f
(decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents:
9034
diff
changeset
|
1374 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
|
1375 symbol = XCAR (p->status); |
| 578 | 1376 |
| 1377 if (EQ (symbol, Qsignal)) | |
| 1378 { | |
| 1379 Lisp_Object tem; | |
| 1380 tem = Fcar (Fcdr (p->status)); | |
| 97142 | 1381 Fprinc (symbol, Qnil); |
| 578 | 1382 } |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1383 else if (NETCONN1_P (p) || SERIALCONN1_P (p)) |
| 578 | 1384 { |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1385 if (EQ (symbol, Qexit)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1386 write_string ("closed", -1); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1387 else if (EQ (p->command, Qt)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1388 write_string ("stopped", -1); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1389 else if (EQ (symbol, Qrun)) |
| 578 | 1390 write_string ("open", -1); |
| 1391 else | |
| 1392 Fprinc (symbol, Qnil); | |
| 1393 } | |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1394 else if (SERIALCONN1_P (p)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1395 { |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1396 write_string ("running", -1); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1397 } |
| 578 | 1398 else |
| 1399 Fprinc (symbol, Qnil); | |
| 1400 | |
| 1401 if (EQ (symbol, Qexit)) | |
| 1402 { | |
| 1403 Lisp_Object tem; | |
| 1404 tem = Fcar (Fcdr (p->status)); | |
| 1405 if (XFASTINT (tem)) | |
| 1406 { | |
|
11695
0f9b9c375416
(list_processes_1): Cast XFASTINT for passing to sprintf.
Richard M. Stallman <rms@gnu.org>
parents:
11609
diff
changeset
|
1407 sprintf (tembuf, " %d", (int) XFASTINT (tem)); |
| 578 | 1408 write_string (tembuf, -1); |
| 1409 } | |
| 1410 } | |
| 1411 | |
|
73225
ff880e40efba
(list_processes_1): Run sentinels before removing dead
Kim F. Storm <storm@cua.dk>
parents:
72727
diff
changeset
|
1412 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
|
1413 exited++; |
| 578 | 1414 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1415 Findent_to (i_buffer, minspace); |
| 578 | 1416 if (NILP (p->buffer)) |
| 1417 insert_string ("(none)"); | |
| 1418 else if (NILP (XBUFFER (p->buffer)->name)) | |
| 1419 insert_string ("(Killed)"); | |
| 1420 else | |
| 1421 Finsert (1, &XBUFFER (p->buffer)->name); | |
| 1422 | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1423 if (!NILP (i_tty)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1424 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1425 Findent_to (i_tty, minspace); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1426 if (STRINGP (p->tty_name)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1427 Finsert (1, &p->tty_name); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1428 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1429 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1430 Findent_to (i_command, minspace); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1431 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1432 if (EQ (p->status, Qlisten)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1433 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1434 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
|
1435 if (INTEGERP (port)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1436 port = Fnumber_to_string (port); |
|
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1437 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
|
1438 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
|
1439 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
|
1440 (DATAGRAM_CHAN_P (p->infd) ? "datagram" : "stream"), |
|
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1441 (STRINGP (port) ? (char *)SDATA (port) : "?")); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1442 insert_string (tembuf); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1443 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1444 else if (NETCONN1_P (p)) |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
1445 { |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1446 /* 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
|
1447 so display service instead. */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1448 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
|
1449 if (!STRINGP (host)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1450 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1451 host = Fplist_get (p->childp, QCservice); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1452 if (INTEGERP (host)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1453 host = Fnumber_to_string (host); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1454 } |
|
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1455 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
|
1456 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
|
1457 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
|
1458 (DATAGRAM_CHAN_P (p->infd) ? "datagram" : "stream"), |
|
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
1459 (STRINGP (host) ? (char *)SDATA (host) : "?")); |
| 578 | 1460 insert_string (tembuf); |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
1461 } |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1462 else if (SERIALCONN1_P (p)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1463 { |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1464 Lisp_Object port = Fplist_get (p->childp, QCport); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1465 Lisp_Object speed = Fplist_get (p->childp, QCspeed); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1466 insert_string ("(serial port "); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1467 if (STRINGP (port)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1468 insert_string (SDATA (port)); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1469 else |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1470 insert_string ("?"); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1471 if (INTEGERP (speed)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1472 { |
|
105577
d6307924111b
(list_processes_1): Use long format in printf, and cast argument.
Adrian Robert <Adrian.B.Robert@gmail.com>
parents:
104724
diff
changeset
|
1473 sprintf (tembuf, " at %ld b/s", (long) XINT (speed)); |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1474 insert_string (tembuf); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1475 } |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1476 insert_string (")\n"); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1477 } |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
1478 else |
| 578 | 1479 { |
| 1480 tem = p->command; | |
| 1481 while (1) | |
| 1482 { | |
| 1483 tem1 = Fcar (tem); | |
|
104257
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1484 if (NILP (tem1)) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1485 break; |
| 578 | 1486 Finsert (1, &tem1); |
| 1487 tem = Fcdr (tem); | |
| 1488 if (NILP (tem)) | |
| 1489 break; | |
| 1490 insert_string (" "); | |
| 1491 } | |
| 1492 insert_string ("\n"); | |
| 1493 } | |
| 1494 } | |
|
73225
ff880e40efba
(list_processes_1): Run sentinels before removing dead
Kim F. Storm <storm@cua.dk>
parents:
72727
diff
changeset
|
1495 if (exited) |
|
104316
bb8ce3c842e7
* process.c (status_notify): Don't perform redisplay.
Chong Yidong <cyd@stupidchicken.com>
parents:
104265
diff
changeset
|
1496 { |
|
bb8ce3c842e7
* process.c (status_notify): Don't perform redisplay.
Chong Yidong <cyd@stupidchicken.com>
parents:
104265
diff
changeset
|
1497 status_notify (NULL); |
|
bb8ce3c842e7
* process.c (status_notify): Don't perform redisplay.
Chong Yidong <cyd@stupidchicken.com>
parents:
104265
diff
changeset
|
1498 redisplay_preserve_echo_area (13); |
|
bb8ce3c842e7
* process.c (status_notify): Don't perform redisplay.
Chong Yidong <cyd@stupidchicken.com>
parents:
104265
diff
changeset
|
1499 } |
| 578 | 1500 return Qnil; |
| 1501 } | |
| 1502 | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
1503 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
|
1504 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
|
1505 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
|
1506 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
|
1507 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
|
1508 after the listing is made. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1509 (Lisp_Object query_only) |
| 578 | 1510 { |
| 1511 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
|
1512 list_processes_1, query_only); |
| 578 | 1513 return Qnil; |
| 1514 } | |
| 1515 | |
| 1516 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
|
1517 doc: /* Return a list of all processes. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1518 (void) |
| 578 | 1519 { |
| 1520 return Fmapcar (Qcdr, Vprocess_alist); | |
| 1521 } | |
| 1522 | |
|
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1523 /* 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
|
1524 |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
1525 static Lisp_Object start_process_unwind (Lisp_Object proc); |
|
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1526 |
| 578 | 1527 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
|
1528 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
|
1529 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
|
1530 BUFFER is the buffer (or buffer name) to associate with the process. |
| 77440 | 1531 |
| 1532 Process output (both standard output and standard error streams) goes | |
| 1533 at end of BUFFER, unless you specify an output stream or filter | |
| 1534 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
|
1535 this process is not associated with any buffer. |
|
4f679f6070a0
(Fstart_process): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
77440
diff
changeset
|
1536 |
|
104257
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1537 PROGRAM is the program file name. It is searched for in PATH. If |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1538 nil, just associate a pty with the buffer. Remaining arguments are |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1539 strings to give program as arguments. |
| 77440 | 1540 |
| 1541 If you want to separate standard output from standard error, invoke | |
| 1542 the command through a shell and redirect one of them using the shell | |
| 1543 syntax. | |
|
44170
888d736c0e91
(set-network-process-options): Add usage.
Pavel Jan?k <Pavel@Janik.cz>
parents:
44073
diff
changeset
|
1544 |
|
40641
d94fc1022312
(Fstart_process): Add usage to doc-string.
Pavel Jan?k <Pavel@Janik.cz>
parents:
40231
diff
changeset
|
1545 usage: (start-process NAME BUFFER PROGRAM &rest PROGRAM-ARGS) */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
1546 (int nargs, register Lisp_Object *args) |
| 578 | 1547 { |
|
1683
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1548 Lisp_Object buffer, name, program, proc, current_dir, tem; |
| 578 | 1549 register unsigned char **new_argv; |
| 1550 register int i; | |
|
46293
1fb8f75062c6
Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents:
45410
diff
changeset
|
1551 int count = SPECPDL_INDEX (); |
| 578 | 1552 |
| 1553 buffer = args[1]; | |
| 1554 if (!NILP (buffer)) | |
| 1555 buffer = Fget_buffer_create (buffer); | |
| 1556 | |
|
1683
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1557 /* 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
|
1558 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
|
1559 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
|
1560 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
|
1561 |
|
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1562 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
|
1563 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
|
1564 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
|
1565 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
|
1566 { |
|
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1567 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
|
1568 |
|
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1569 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
|
1570 |
|
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1571 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
|
1572 |
|
91551
f14242124fd7
* process.c (Fstart_process):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91367
diff
changeset
|
1573 current_dir = Funhandled_file_name_directory (current_dir); |
|
f14242124fd7
* process.c (Fstart_process):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91367
diff
changeset
|
1574 if (NILP (current_dir)) |
|
f14242124fd7
* process.c (Fstart_process):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91367
diff
changeset
|
1575 /* 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
|
1576 a sensible default. */ |
|
f14242124fd7
* process.c (Fstart_process):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91367
diff
changeset
|
1577 current_dir = build_string ("~/"); |
|
f14242124fd7
* process.c (Fstart_process):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91367
diff
changeset
|
1578 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
|
1579 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
|
1580 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
|
1581 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
|
1582 |
|
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1583 UNGCPRO; |
|
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1584 } |
|
a0a41de51400
Give subprocess creation a way to find a valid current directory
Jim Blandy <jimb@redhat.com>
parents:
1655
diff
changeset
|
1585 |
| 578 | 1586 name = args[0]; |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
1587 CHECK_STRING (name); |
| 578 | 1588 |
| 1589 program = args[2]; | |
| 1590 | |
|
104257
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1591 if (!NILP (program)) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1592 CHECK_STRING (program); |
| 578 | 1593 |
|
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1594 proc = make_process (name); |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1595 /* 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
|
1596 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
|
1597 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
|
1598 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
|
1599 record_unwind_protect (start_process_unwind, proc); |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1600 |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1601 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
|
1602 XPROCESS (proc)->plist = Qnil; |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
1603 XPROCESS (proc)->type = Qreal; |
|
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1604 XPROCESS (proc)->buffer = buffer; |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1605 XPROCESS (proc)->sentinel = Qnil; |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1606 XPROCESS (proc)->filter = Qnil; |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1607 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
|
1608 |
| 110584 | 1609 #ifdef HAVE_GNUTLS |
| 1610 /* AKA GNUTLS_INITSTAGE(proc). */ | |
| 1611 XPROCESS (proc)->gnutls_initstage = GNUTLS_STAGE_EMPTY; | |
| 1612 XPROCESS (proc)->gnutls_cred_type = Qnil; | |
| 1613 #endif | |
| 1614 | |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
1615 #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
|
1616 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
|
1617 = (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
|
1618 : 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
|
1619 #endif |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
1620 |
|
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1621 /* 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
|
1622 if (BUFFERP (buffer)) |
|
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1623 set_marker_both (XPROCESS (proc)->mark, buffer, |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1624 BUF_ZV (XBUFFER (buffer)), |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1625 BUF_ZV_BYTE (XBUFFER (buffer))); |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1626 |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1627 { |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1628 /* 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
|
1629 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
|
1630 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
|
1631 |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1632 /* 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
|
1633 Lisp_Object coding_systems = Qt; |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1634 Lisp_Object val, *args2; |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1635 struct gcpro gcpro1, gcpro2; |
|
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 val = Vcoding_system_for_read; |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1638 if (NILP (val)) |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1639 { |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1640 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
|
1641 args2[0] = Qstart_process; |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1642 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
|
1643 GCPRO2 (proc, current_dir); |
|
104257
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1644 if (!NILP (program)) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1645 coding_systems = Ffind_operation_coding_system (nargs + 1, args2); |
|
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1646 UNGCPRO; |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1647 if (CONSP (coding_systems)) |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1648 val = XCAR (coding_systems); |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1649 else if (CONSP (Vdefault_process_coding_system)) |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1650 val = XCAR (Vdefault_process_coding_system); |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1651 } |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1652 XPROCESS (proc)->decode_coding_system = val; |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1653 |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1654 val = Vcoding_system_for_write; |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1655 if (NILP (val)) |
|
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 if (EQ (coding_systems, Qt)) |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1658 { |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1659 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
|
1660 args2[0] = Qstart_process; |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1661 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
|
1662 GCPRO2 (proc, current_dir); |
|
104257
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1663 if (!NILP (program)) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1664 coding_systems = Ffind_operation_coding_system (nargs + 1, args2); |
|
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1665 UNGCPRO; |
|
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 if (CONSP (coding_systems)) |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1668 val = XCDR (coding_systems); |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1669 else if (CONSP (Vdefault_process_coding_system)) |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1670 val = XCDR (Vdefault_process_coding_system); |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1671 } |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1672 XPROCESS (proc)->encode_coding_system = val; |
|
110829
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
1673 /* Note: At this momemnt, the above coding system may leave |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
1674 text-conversion or eol-conversion unspecified. They will be |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
1675 decided after we read output from the process and decode it by |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
1676 some coding system, or just before we actually send a text to |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
1677 the process. */ |
|
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1678 } |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
1679 |
| 578 | 1680 |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
1681 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
|
1682 XPROCESS (proc)->decoding_carryover = 0; |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
1683 XPROCESS (proc)->encoding_buf = make_uninit_string (0); |
|
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
1684 |
|
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1685 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
|
1686 = !(NILP (buffer) || !inherit_process_coding_system); |
|
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
1687 |
|
104257
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1688 if (!NILP (program)) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1689 { |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1690 /* If program file name is not absolute, search our path for it. |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1691 Put the name we will really use in TEM. */ |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1692 if (!IS_DIRECTORY_SEP (SREF (program, 0)) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1693 && !(SCHARS (program) > 1 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1694 && IS_DEVICE_SEP (SREF (program, 1)))) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1695 { |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1696 struct gcpro gcpro1, gcpro2, gcpro3, gcpro4; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1697 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1698 tem = Qnil; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1699 GCPRO4 (name, program, buffer, current_dir); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1700 openp (Vexec_path, program, Vexec_suffixes, &tem, make_number (X_OK)); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1701 UNGCPRO; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1702 if (NILP (tem)) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1703 report_file_error ("Searching for program", Fcons (program, Qnil)); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1704 tem = Fexpand_file_name (tem, Qnil); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1705 } |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1706 else |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1707 { |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1708 if (!NILP (Ffile_directory_p (program))) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1709 error ("Specified program for new process is a directory"); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1710 tem = program; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1711 } |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1712 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1713 /* If program file name starts with /: for quoting a magic name, |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1714 discard that. */ |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1715 if (SBYTES (tem) > 2 && SREF (tem, 0) == '/' |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1716 && SREF (tem, 1) == ':') |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1717 tem = Fsubstring (tem, make_number (2), Qnil); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1718 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1719 { |
|
110829
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
1720 Lisp_Object arg_encoding = Qnil; |
|
104257
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1721 struct gcpro gcpro1; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1722 GCPRO1 (tem); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1723 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1724 /* Encode the file name and put it in NEW_ARGV. |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1725 That's where the child will use it to execute the program. */ |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1726 tem = Fcons (ENCODE_FILE (tem), Qnil); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1727 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1728 /* Here we encode arguments by the coding system used for sending |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1729 data to the process. We don't support using different coding |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1730 systems for encoding arguments and for encoding data sent to the |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1731 process. */ |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1732 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1733 for (i = 3; i < nargs; i++) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1734 { |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1735 tem = Fcons (args[i], tem); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1736 CHECK_STRING (XCAR (tem)); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1737 if (STRING_MULTIBYTE (XCAR (tem))) |
|
110829
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
1738 { |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
1739 if (NILP (arg_encoding)) |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
1740 arg_encoding = (complement_process_encoding_system |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
1741 (XPROCESS (proc)->encode_coding_system)); |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
1742 XSETCAR (tem, |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
1743 code_convert_string_norecord |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
1744 (XCAR (tem), arg_encoding, 1)); |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
1745 } |
|
104257
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1746 } |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1747 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1748 UNGCPRO; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1749 } |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1750 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1751 /* Now that everything is encoded we can collect the strings into |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1752 NEW_ARGV. */ |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1753 new_argv = (unsigned char **) alloca ((nargs - 1) * sizeof (char *)); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1754 new_argv[nargs - 2] = 0; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1755 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1756 for (i = nargs - 3; i >= 0; i--) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1757 { |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1758 new_argv[i] = SDATA (XCAR (tem)); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1759 tem = XCDR (tem); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1760 } |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1761 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1762 create_process (proc, (char **) new_argv, current_dir); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1763 } |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1764 else |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1765 create_pty (proc); |
| 578 | 1766 |
|
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1767 return unbind_to (count, proc); |
| 578 | 1768 } |
| 1769 | |
|
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1770 /* This function is the unwind_protect form for Fstart_process. If |
| 14036 | 1771 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
|
1772 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
|
1773 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
|
1774 static Lisp_Object |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
1775 start_process_unwind (Lisp_Object proc) |
|
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1776 { |
|
9115
59bc2d010b5f
(decode_status, Fprocessp, Fget_process, Fget_buffer_process, Fprocess_status,
Karl Heuer <kwzh@gnu.org>
parents:
9034
diff
changeset
|
1777 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
|
1778 abort (); |
|
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1779 |
|
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1780 /* Was PROC started successfully? */ |
|
104257
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
1781 if (XPROCESS (proc)->pid == -1) |
|
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1782 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
|
1783 |
|
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1784 return Qnil; |
|
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1785 } |
|
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
1786 |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
1787 static void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
1788 create_process_1 (struct atimer *timer) |
| 578 | 1789 { |
|
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
1790 /* Nothing to do. */ |
| 578 | 1791 } |
| 1792 | |
|
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
1793 |
|
20382
dbad9367d232
(create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents:
20225
diff
changeset
|
1794 void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
1795 create_process (Lisp_Object process, char **new_argv, Lisp_Object current_dir) |
| 578 | 1796 { |
|
76494
f0a25b5d3ba0
(Fdelete_process): Properly handle deletion of first element of
Chong Yidong <cyd@stupidchicken.com>
parents:
76493
diff
changeset
|
1797 int inchannel, outchannel; |
|
f0a25b5d3ba0
(Fdelete_process): Properly handle deletion of first element of
Chong Yidong <cyd@stupidchicken.com>
parents:
76493
diff
changeset
|
1798 pid_t pid; |
| 578 | 1799 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
|
1800 #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
|
1801 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
|
1802 #endif |
|
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1803 sigset_t procmask; |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1804 sigset_t blocked; |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1805 struct sigaction sigint_action; |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1806 struct sigaction sigquit_action; |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1807 #ifdef AIX |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1808 struct sigaction sighup_action; |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1809 #endif |
|
11926
40d7e6f04ebe
(create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents:
11845
diff
changeset
|
1810 /* 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
|
1811 volatile int forkin, forkout; |
|
40d7e6f04ebe
(create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents:
11845
diff
changeset
|
1812 volatile int pty_flag = 0; |
|
31099
0fe5afca71e4
Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents:
30582
diff
changeset
|
1813 #ifndef USE_CRT_DLL |
| 578 | 1814 extern char **environ; |
|
31099
0fe5afca71e4
Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents:
30582
diff
changeset
|
1815 #endif |
| 578 | 1816 |
| 1817 inchannel = outchannel = -1; | |
| 1818 | |
| 1819 #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
|
1820 if (!NILP (Vprocess_connection_type)) |
| 578 | 1821 outchannel = inchannel = allocate_pty (); |
| 1822 | |
| 1823 if (inchannel >= 0) | |
| 1824 { | |
|
46411
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
1825 #if ! defined (USG) || defined (USG_SUBTTY_WORKS) |
|
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
1826 /* 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
|
1827 then close it and reopen it in the child. */ |
| 578 | 1828 #ifdef O_NOCTTY |
| 1829 /* Don't let this terminal become our controlling terminal | |
| 1830 (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
|
1831 forkout = forkin = emacs_open (pty_name, O_RDWR | O_NOCTTY, 0); |
| 578 | 1832 #else |
|
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
1833 forkout = forkin = emacs_open (pty_name, O_RDWR, 0); |
| 578 | 1834 #endif |
| 1835 if (forkin < 0) | |
| 1836 report_file_error ("Opening pty", Qnil); | |
| 1837 #else | |
| 1838 forkin = forkout = -1; | |
|
46411
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
1839 #endif /* not USG, or USG_SUBTTY_WORKS */ |
| 578 | 1840 pty_flag = 1; |
| 1841 } | |
| 1842 else | |
| 1843 #endif /* HAVE_PTYS */ | |
| 1844 { | |
|
25129
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1845 int tem; |
|
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1846 tem = pipe (sv); |
|
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1847 if (tem < 0) |
|
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1848 report_file_error ("Creating pipe", Qnil); |
| 578 | 1849 inchannel = sv[0]; |
| 1850 forkout = sv[1]; | |
|
25129
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1851 tem = pipe (sv); |
|
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1852 if (tem < 0) |
|
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1853 { |
|
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
1854 emacs_close (inchannel); |
|
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
1855 emacs_close (forkout); |
|
25129
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1856 report_file_error ("Creating pipe", Qnil); |
|
4f3c8f1cec96
(create_process): Detect failure of `pipe'.
Karl Heuer <kwzh@gnu.org>
parents:
25009
diff
changeset
|
1857 } |
| 578 | 1858 outchannel = sv[1]; |
| 1859 forkin = sv[0]; | |
| 1860 } | |
| 1861 | |
|
80610
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1862 #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
|
1863 { |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1864 int tem; |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1865 |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1866 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
|
1867 if (tem < 0) |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1868 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
|
1869 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
|
1870 if (tem >= 0) |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1871 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
|
1872 if (tem < 0) |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1873 { |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1874 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
|
1875 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
|
1876 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
|
1877 } |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1878 } |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1879 #endif |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
1880 |
| 578 | 1881 #ifdef O_NONBLOCK |
| 1882 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
|
1883 fcntl (outchannel, F_SETFL, O_NONBLOCK); |
| 578 | 1884 #else |
| 1885 #ifdef O_NDELAY | |
| 1886 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
|
1887 fcntl (outchannel, F_SETFL, O_NDELAY); |
| 578 | 1888 #endif |
| 1889 #endif | |
| 1890 | |
| 1891 /* Record this as an active process, with its channels. | |
| 1892 As a result, child_setup will close Emacs's side of the pipes. */ | |
| 1893 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
|
1894 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
|
1895 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
|
1896 |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
1897 /* 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
|
1898 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
|
1899 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
|
1900 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
|
1901 |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
1902 XPROCESS (process)->pty_flag = pty_flag; |
| 578 | 1903 XPROCESS (process)->status = Qrun; |
|
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
1904 setup_process_coding_systems (process); |
| 578 | 1905 |
| 1906 /* Delay interrupts until we have a chance to store | |
| 1907 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
|
1908 sigemptyset (&blocked); |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1909 #ifdef SIGCHLD |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1910 sigaddset (&blocked, SIGCHLD); |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1911 #endif |
|
41856
0028402ed7d1
(create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents:
40656
diff
changeset
|
1912 #ifdef HAVE_WORKING_VFORK |
|
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1913 /* 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
|
1914 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
|
1915 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
|
1916 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
|
1917 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
|
1918 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
|
1919 #ifdef AIX |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1920 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
|
1921 #endif |
|
41856
0028402ed7d1
(create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents:
40656
diff
changeset
|
1922 #endif /* HAVE_WORKING_VFORK */ |
|
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
1923 sigprocmask (SIG_BLOCK, &blocked, &procmask); |
| 578 | 1924 |
|
7893
e54617027a47
(create_process): Set input_wait_mask before forking.
Karl Heuer <kwzh@gnu.org>
parents:
7884
diff
changeset
|
1925 FD_SET (inchannel, &input_wait_mask); |
|
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
1926 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
|
1927 if (inchannel > max_process_desc) |
|
e54617027a47
(create_process): Set input_wait_mask before forking.
Karl Heuer <kwzh@gnu.org>
parents:
7884
diff
changeset
|
1928 max_process_desc = inchannel; |
|
e54617027a47
(create_process): Set input_wait_mask before forking.
Karl Heuer <kwzh@gnu.org>
parents:
7884
diff
changeset
|
1929 |
| 578 | 1930 /* Until we store the proper pid, enable sigchld_handler |
| 1931 to recognize an unknown pid as standing for this process. | |
| 1932 It is very important not to let this `marker' value stay | |
| 1933 in the table after this function has returned; if it does | |
| 1934 it might cause call-process to hang and subsequent asynchronous | |
| 1935 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
|
1936 XPROCESS (process)->pid = -1; |
| 578 | 1937 |
| 16780 | 1938 BLOCK_INPUT; |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
1939 |
| 578 | 1940 { |
| 1941 /* child_setup must clobber environ on systems with true vfork. | |
| 1942 Protect it from permanent change. */ | |
| 1943 char **save_environ = environ; | |
| 1944 | |
|
21049
01e626b0a624
(Vdefault_file_name_coding_system): Extern it.
Kenichi Handa <handa@m17n.org>
parents:
20715
diff
changeset
|
1945 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
|
1946 |
|
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
1947 #ifndef WINDOWSNT |
| 578 | 1948 pid = vfork (); |
| 1949 if (pid == 0) | |
|
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
1950 #endif /* not WINDOWSNT */ |
| 578 | 1951 { |
| 1952 int xforkin = forkin; | |
| 1953 int xforkout = forkout; | |
| 1954 | |
| 1955 #if 0 /* This was probably a mistake--it duplicates code later on, | |
| 1956 but fails to handle all the cases. */ | |
| 1957 /* Make sure SIGCHLD is not blocked in the child. */ | |
| 1958 sigsetmask (SIGEMPTYMASK); | |
| 1959 #endif | |
| 1960 | |
| 1961 /* Make the pty be the controlling terminal of the process. */ | |
| 1962 #ifdef HAVE_PTYS | |
| 1963 /* First, disconnect its current controlling terminal. */ | |
| 1964 #ifdef HAVE_SETSID | |
|
7266
f87808bd90e9
(create_process): Undo April 19 setsid change.
Richard M. Stallman <rms@gnu.org>
parents:
7238
diff
changeset
|
1965 /* 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
|
1966 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
|
1967 setsid (); |
|
1030
9934251d8219
(WCOREDUMP): Define only if not defined.
Richard M. Stallman <rms@gnu.org>
parents:
1012
diff
changeset
|
1968 /* Make the pty's terminal the controlling terminal. */ |
|
109087
a089fae47976
Avoid erroneous syscalls
Andreas Schwab <schwab@linux-m68k.org>
parents:
108946
diff
changeset
|
1969 if (pty_flag && xforkin >= 0) |
|
6975
b7411e378b65
(create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
6947
diff
changeset
|
1970 { |
|
b7411e378b65
(create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
6947
diff
changeset
|
1971 #ifdef TIOCSCTTY |
|
b7411e378b65
(create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
6947
diff
changeset
|
1972 /* We ignore the return value |
|
b7411e378b65
(create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
6947
diff
changeset
|
1973 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
|
1974 ioctl (xforkin, TIOCSCTTY, 0); |
|
1030
9934251d8219
(WCOREDUMP): Define only if not defined.
Richard M. Stallman <rms@gnu.org>
parents:
1012
diff
changeset
|
1975 #endif |
|
6975
b7411e378b65
(create_process): Call setsid only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
6947
diff
changeset
|
1976 } |
| 578 | 1977 #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
|
1978 #ifdef USG |
|
5347
21bffe027a7d
(create_process) [NTTYDISC]: Set the tty line discipline.
Richard M. Stallman <rms@gnu.org>
parents:
5332
diff
changeset
|
1979 /* It's very important to call setpgrp here and no time |
| 578 | 1980 afterwards. Otherwise, we lose our controlling tty which |
| 1981 is set when we open the pty. */ | |
| 1982 setpgrp (); | |
| 1983 #endif /* USG */ | |
| 1984 #endif /* not HAVE_SETSID */ | |
| 109949 | 1985 #if defined (LDISC1) |
|
7116
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
1986 if (pty_flag && xforkin >= 0) |
|
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
1987 { |
|
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
1988 struct termios t; |
|
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
1989 tcgetattr (xforkin, &t); |
|
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
1990 t.c_lflag = LDISC1; |
|
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
1991 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
|
1992 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
|
1993 } |
|
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
1994 #else |
|
6947
c5f990fad6bb
(create_process): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents:
6928
diff
changeset
|
1995 #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
|
1996 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
|
1997 { |
|
36d2fd17f833
(create_process): Set line discipline only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
5543
diff
changeset
|
1998 /* Use new line discipline. */ |
|
36d2fd17f833
(create_process): Set line discipline only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
5543
diff
changeset
|
1999 int ldisc = NTTYDISC; |
|
7605
53186c2698e5
(create_process): Don't complain about error from TIOCSETD.
Richard M. Stallman <rms@gnu.org>
parents:
7486
diff
changeset
|
2000 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
|
2001 } |
|
5347
21bffe027a7d
(create_process) [NTTYDISC]: Set the tty line discipline.
Richard M. Stallman <rms@gnu.org>
parents:
5332
diff
changeset
|
2002 #endif |
|
7116
d35b11eed89f
(create_process) [HAVE_TERMIOS && LDISC1]: Use tcsetattr.
Karl Heuer <kwzh@gnu.org>
parents:
7059
diff
changeset
|
2003 #endif |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2004 #ifdef TIOCNOTTY |
| 578 | 2005 /* In 4.3BSD, the TIOCSPGRP bug has been fixed, and now you |
| 2006 can do TIOCSPGRP only to the process's controlling tty. */ | |
| 2007 if (pty_flag) | |
| 2008 { | |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2009 /* I wonder: would just ioctl (0, TIOCNOTTY, 0) work here? |
| 578 | 2010 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
|
2011 int j = emacs_open ("/dev/tty", O_RDWR, 0); |
|
109087
a089fae47976
Avoid erroneous syscalls
Andreas Schwab <schwab@linux-m68k.org>
parents:
108946
diff
changeset
|
2012 if (j >= 0) |
|
a089fae47976
Avoid erroneous syscalls
Andreas Schwab <schwab@linux-m68k.org>
parents:
108946
diff
changeset
|
2013 { |
|
a089fae47976
Avoid erroneous syscalls
Andreas Schwab <schwab@linux-m68k.org>
parents:
108946
diff
changeset
|
2014 ioctl (j, TIOCNOTTY, 0); |
|
a089fae47976
Avoid erroneous syscalls
Andreas Schwab <schwab@linux-m68k.org>
parents:
108946
diff
changeset
|
2015 emacs_close (j); |
|
a089fae47976
Avoid erroneous syscalls
Andreas Schwab <schwab@linux-m68k.org>
parents:
108946
diff
changeset
|
2016 } |
|
3826
647bef18618f
Changes for Irix 4.0, tested this time:
Jim Blandy <jimb@redhat.com>
parents:
3810
diff
changeset
|
2017 #ifndef USG |
| 578 | 2018 /* In order to get a controlling terminal on some versions |
| 2019 of BSD, it is necessary to put the process in pgrp 0 | |
| 2020 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
|
2021 #ifdef HAVE_SETPGID |
|
9882
ccc5562a7194
(create_process) [OSF1]: Use setpgid, not setpgrp.
Richard M. Stallman <rms@gnu.org>
parents:
9793
diff
changeset
|
2022 setpgid (0, 0); |
|
ccc5562a7194
(create_process) [OSF1]: Use setpgid, not setpgrp.
Richard M. Stallman <rms@gnu.org>
parents:
9793
diff
changeset
|
2023 #else |
| 578 | 2024 setpgrp (0, 0); |
| 2025 #endif | |
|
9882
ccc5562a7194
(create_process) [OSF1]: Use setpgid, not setpgrp.
Richard M. Stallman <rms@gnu.org>
parents:
9793
diff
changeset
|
2026 #endif |
| 578 | 2027 } |
| 2028 #endif /* TIOCNOTTY */ | |
| 2029 | |
| 87730 | 2030 #if !defined (DONT_REOPEN_PTY) |
| 578 | 2031 /*** 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
|
2032 conditional on TIOCSPGRP, |
|
5d1e0290bbd0
(create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents:
16058
diff
changeset
|
2033 or !(defined (HAVE_SETSID) && defined (TIOCSCTTY)). |
|
5d1e0290bbd0
(create_process): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents:
16058
diff
changeset
|
2034 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
|
2035 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
|
2036 both HAVE_SETSID and TIOCSCTTY are defined. */ |
| 578 | 2037 /* Now close the pty (if we had it open) and reopen it. |
| 2038 This makes the pty the controlling terminal of the subprocess. */ | |
| 2039 if (pty_flag) | |
| 2040 { | |
|
5240
eed870591987
(Fprocess_status): Use get_process, not Fget_process.
Richard M. Stallman <rms@gnu.org>
parents:
5239
diff
changeset
|
2041 |
|
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
2042 /* 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
|
2043 would work? */ |
| 578 | 2044 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
|
2045 emacs_close (xforkin); |
|
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
2046 xforkout = xforkin = emacs_open (pty_name, O_RDWR, 0); |
| 578 | 2047 |
|
11514
321726163a65
(create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents:
11376
diff
changeset
|
2048 if (xforkin < 0) |
|
321726163a65
(create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents:
11376
diff
changeset
|
2049 { |
|
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
2050 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
|
2051 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
|
2052 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
|
2053 _exit (1); |
|
321726163a65
(create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents:
11376
diff
changeset
|
2054 } |
|
321726163a65
(create_process): Don't abort if can't reopen
Richard M. Stallman <rms@gnu.org>
parents:
11376
diff
changeset
|
2055 |
| 578 | 2056 } |
| 87730 | 2057 #endif /* not DONT_REOPEN_PTY */ |
|
15368
6229fb866493
(create_process): Add DONT_OPEN_PTY conditional.
Richard M. Stallman <rms@gnu.org>
parents:
15355
diff
changeset
|
2058 |
| 578 | 2059 #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
|
2060 if (pty_flag) |
|
1855e568a9b8
(create_process): Use SETUP_SLAVE_PTY only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
7044
diff
changeset
|
2061 { |
|
1855e568a9b8
(create_process): Use SETUP_SLAVE_PTY only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
7044
diff
changeset
|
2062 SETUP_SLAVE_PTY; |
|
1855e568a9b8
(create_process): Use SETUP_SLAVE_PTY only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
7044
diff
changeset
|
2063 } |
| 578 | 2064 #endif /* SETUP_SLAVE_PTY */ |
| 2065 #ifdef AIX | |
| 2066 /* On AIX, we've disabled SIGHUP above once we start a child on a pty. | |
| 2067 Now reenable it in the child, so it will die when we want it to. */ | |
| 2068 if (pty_flag) | |
| 2069 signal (SIGHUP, SIG_DFL); | |
| 2070 #endif | |
| 2071 #endif /* HAVE_PTYS */ | |
| 2072 | |
|
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2073 signal (SIGINT, SIG_DFL); |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2074 signal (SIGQUIT, SIG_DFL); |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2075 |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2076 /* Stop blocking signals in the child. */ |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2077 sigprocmask (SIG_SETMASK, &procmask, 0); |
|
8390
ee13e8728666
(create_process): Set default handling for SIGINT, etc.
Richard M. Stallman <rms@gnu.org>
parents:
8354
diff
changeset
|
2078 |
|
7059
6a55de48ade5
(create_process): Use child_setup_tty only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
7058
diff
changeset
|
2079 if (pty_flag) |
|
6a55de48ade5
(create_process): Use child_setup_tty only if pty_flag.
Richard M. Stallman <rms@gnu.org>
parents:
7058
diff
changeset
|
2080 child_setup_tty (xforkout); |
|
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
2081 #ifdef WINDOWSNT |
|
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
2082 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
|
2083 new_argv, 1, current_dir); |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2084 #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
|
2085 #ifdef FD_CLOEXEC |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2086 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
|
2087 #endif |
| 578 | 2088 child_setup (xforkin, xforkout, xforkout, |
| 638 | 2089 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
|
2090 #endif /* not WINDOWSNT */ |
| 578 | 2091 } |
| 2092 environ = save_environ; | |
| 2093 } | |
| 2094 | |
| 16780 | 2095 UNBLOCK_INPUT; |
| 2096 | |
|
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2097 /* This runs in the Emacs process. */ |
| 578 | 2098 if (pid < 0) |
|
7157
3f4fc9d682b4
(create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents:
7116
diff
changeset
|
2099 { |
|
3f4fc9d682b4
(create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents:
7116
diff
changeset
|
2100 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
|
2101 emacs_close (forkin); |
|
7157
3f4fc9d682b4
(create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents:
7116
diff
changeset
|
2102 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
|
2103 emacs_close (forkout); |
|
7157
3f4fc9d682b4
(create_process): If vfork fails, close forkin and forkout.
Richard M. Stallman <rms@gnu.org>
parents:
7116
diff
changeset
|
2104 } |
|
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2105 else |
|
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2106 { |
|
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2107 /* vfork succeeded. */ |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
2108 XPROCESS (process)->pid = pid; |
| 578 | 2109 |
|
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
2110 #ifdef WINDOWSNT |
|
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2111 register_child (pid, inchannel); |
|
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
2112 #endif /* WINDOWSNT */ |
|
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
2113 |
|
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2114 /* If the subfork execv fails, and it exits, |
|
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2115 this close hangs. I don't know why. |
|
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2116 So have an interrupt jar it loose. */ |
|
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2117 { |
|
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2118 struct atimer *timer; |
|
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2119 EMACS_TIME offset; |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2120 |
|
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2121 stop_polling (); |
|
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2122 EMACS_SET_SECS_USECS (offset, 1, 0); |
|
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2123 timer = start_atimer (ATIMER_RELATIVE, offset, create_process_1, 0); |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2124 |
|
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2125 if (forkin >= 0) |
|
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2126 emacs_close (forkin); |
|
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2127 |
|
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2128 cancel_atimer (timer); |
|
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2129 start_polling (); |
|
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
2130 } |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2131 |
|
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2132 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
|
2133 emacs_close (forkout); |
| 578 | 2134 |
|
11609
3b2dacb1bfe9
(create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents:
11514
diff
changeset
|
2135 #ifdef HAVE_PTYS |
|
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2136 if (pty_flag) |
|
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2137 XPROCESS (process)->tty_name = build_string (pty_name); |
|
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2138 else |
|
11609
3b2dacb1bfe9
(create_process): Don't reference pty_name if !HAVE_PTYS.
Karl Heuer <kwzh@gnu.org>
parents:
11514
diff
changeset
|
2139 #endif |
|
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2140 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
|
2141 |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2142 #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
|
2143 /* 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
|
2144 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
|
2145 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
|
2146 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
|
2147 { |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2148 char dummy; |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2149 |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2150 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
|
2151 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
|
2152 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
|
2153 } |
|
a6adb4611f10
(create_process) [!WINDOWSNT && FD_CLOEXEC]: Wait for
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
80225
diff
changeset
|
2154 #endif |
|
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2155 } |
|
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2156 |
|
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2157 /* 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
|
2158 (We will signal an error, below, if it failed.) */ |
|
41856
0028402ed7d1
(create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents:
40656
diff
changeset
|
2159 #ifdef HAVE_WORKING_VFORK |
|
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2160 /* Restore the parent's signal handlers. */ |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2161 sigaction (SIGINT, &sigint_action, 0); |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2162 sigaction (SIGQUIT, &sigquit_action, 0); |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2163 #ifdef AIX |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2164 sigaction (SIGHUP, &sighup_action, 0); |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2165 #endif |
|
41856
0028402ed7d1
(create_process): Use HAVE_WORKING_VFORK, not HAVE_VFORK.
Paul Eggert <eggert@twinsun.com>
parents:
40656
diff
changeset
|
2166 #endif /* HAVE_WORKING_VFORK */ |
|
13709
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2167 /* Stop blocking signals in the parent. */ |
|
d16f31ae8adf
(create_process): Use Posix signal handling to
Karl Heuer <kwzh@gnu.org>
parents:
13414
diff
changeset
|
2168 sigprocmask (SIG_SETMASK, &procmask, 0); |
|
14131
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2169 |
|
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2170 /* Now generate the error if vfork failed. */ |
|
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2171 if (pid < 0) |
|
7717b68abd2e
(create_process): Restore the signal state
Karl Heuer <kwzh@gnu.org>
parents:
14085
diff
changeset
|
2172 report_file_error ("Doing vfork", Qnil); |
| 578 | 2173 } |
| 2174 | |
|
104257
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2175 void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
2176 create_pty (Lisp_Object process) |
|
104257
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2177 { |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2178 int inchannel, outchannel; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2179 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2180 /* Use volatile to protect variables from being clobbered by longjmp. */ |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2181 volatile int forkin, forkout; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2182 volatile int pty_flag = 0; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2183 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2184 inchannel = outchannel = -1; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2185 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2186 #ifdef HAVE_PTYS |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2187 if (!NILP (Vprocess_connection_type)) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2188 outchannel = inchannel = allocate_pty (); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2189 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2190 if (inchannel >= 0) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2191 { |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2192 #if ! defined (USG) || defined (USG_SUBTTY_WORKS) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2193 /* On most USG systems it does not work to open the pty's tty here, |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2194 then close it and reopen it in the child. */ |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2195 #ifdef O_NOCTTY |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2196 /* Don't let this terminal become our controlling terminal |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2197 (in case we don't have one). */ |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2198 forkout = forkin = emacs_open (pty_name, O_RDWR | O_NOCTTY, 0); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2199 #else |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2200 forkout = forkin = emacs_open (pty_name, O_RDWR, 0); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2201 #endif |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2202 if (forkin < 0) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2203 report_file_error ("Opening pty", Qnil); |
|
105672
715324003204
* process.c (create_pty): Remove conditionals for no longer
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
2204 #if defined (DONT_REOPEN_PTY) |
|
104257
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2205 /* In the case that vfork is defined as fork, the parent process |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2206 (Emacs) may send some data before the child process completes |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2207 tty options setup. So we setup tty before forking. */ |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2208 child_setup_tty (forkout); |
|
105672
715324003204
* process.c (create_pty): Remove conditionals for no longer
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105669
diff
changeset
|
2209 #endif /* DONT_REOPEN_PTY */ |
|
104257
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2210 #else |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2211 forkin = forkout = -1; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2212 #endif /* not USG, or USG_SUBTTY_WORKS */ |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2213 pty_flag = 1; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2214 } |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2215 #endif /* HAVE_PTYS */ |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2216 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2217 #ifdef O_NONBLOCK |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2218 fcntl (inchannel, F_SETFL, O_NONBLOCK); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2219 fcntl (outchannel, F_SETFL, O_NONBLOCK); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2220 #else |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2221 #ifdef O_NDELAY |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2222 fcntl (inchannel, F_SETFL, O_NDELAY); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2223 fcntl (outchannel, F_SETFL, O_NDELAY); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2224 #endif |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2225 #endif |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2226 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2227 /* Record this as an active process, with its channels. |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2228 As a result, child_setup will close Emacs's side of the pipes. */ |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2229 chan_process[inchannel] = process; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2230 XPROCESS (process)->infd = inchannel; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2231 XPROCESS (process)->outfd = outchannel; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2232 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2233 /* Previously we recorded the tty descriptor used in the subprocess. |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2234 It was only used for getting the foreground tty process, so now |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2235 we just reopen the device (see emacs_get_tty_pgrp) as this is |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2236 more portable (see USG_SUBTTY_WORKS above). */ |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2237 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2238 XPROCESS (process)->pty_flag = pty_flag; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2239 XPROCESS (process)->status = Qrun; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2240 setup_process_coding_systems (process); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2241 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2242 FD_SET (inchannel, &input_wait_mask); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2243 FD_SET (inchannel, &non_keyboard_wait_mask); |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2244 if (inchannel > max_process_desc) |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2245 max_process_desc = inchannel; |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2246 |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2247 XPROCESS (process)->pid = -2; |
|
104265
a812c049e63c
(create_pty): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents:
104257
diff
changeset
|
2248 #ifdef HAVE_PTYS |
|
a812c049e63c
(create_pty): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents:
104257
diff
changeset
|
2249 if (pty_flag) |
|
a812c049e63c
(create_pty): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents:
104257
diff
changeset
|
2250 XPROCESS (process)->tty_name = build_string (pty_name); |
|
a812c049e63c
(create_pty): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents:
104257
diff
changeset
|
2251 else |
|
a812c049e63c
(create_pty): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents:
104257
diff
changeset
|
2252 #endif |
|
a812c049e63c
(create_pty): Fix last change.
Eli Zaretskii <eliz@gnu.org>
parents:
104257
diff
changeset
|
2253 XPROCESS (process)->tty_name = Qnil; |
|
104257
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2254 } |
|
a577041a0370
(create_pty): New function.
Nick Roberts <nickrob@snap.net.nz>
parents:
103972
diff
changeset
|
2255 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2256 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2257 /* 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
|
2258 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
|
2259 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2260 static Lisp_Object |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
2261 conv_sockaddr_to_lisp (struct sockaddr *sa, int len) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2262 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2263 Lisp_Object address; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2264 int i; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2265 unsigned char *cp; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2266 register struct Lisp_Vector *p; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2267 |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
2268 /* 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
|
2269 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
|
2270 a zero length name. */ |
|
109320
a0d2db31314d
Use offsetof instead of own definition
Andreas Schwab <schwab@linux-m68k.org>
parents:
109319
diff
changeset
|
2271 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
|
2272 return empty_unibyte_string; |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
2273 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2274 switch (sa->sa_family) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2275 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2276 case AF_INET: |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2277 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2278 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
|
2279 len = sizeof (sin->sin_addr) + 1; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2280 address = Fmake_vector (make_number (len), Qnil); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2281 p = XVECTOR (address); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2282 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
|
2283 cp = (unsigned char *) &sin->sin_addr; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2284 break; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2285 } |
| 68008 | 2286 #ifdef AF_INET6 |
| 2287 case AF_INET6: | |
| 2288 { | |
| 2289 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
|
2290 uint16_t *ip6 = (uint16_t *) &sin6->sin6_addr; |
| 68008 | 2291 len = sizeof (sin6->sin6_addr)/2 + 1; |
| 2292 address = Fmake_vector (make_number (len), Qnil); | |
| 2293 p = XVECTOR (address); | |
| 2294 p->contents[--len] = make_number (ntohs (sin6->sin6_port)); | |
| 2295 for (i = 0; i < len; i++) | |
| 2296 p->contents[i] = make_number (ntohs (ip6[i])); | |
| 2297 return address; | |
| 2298 } | |
| 2299 #endif | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2300 #ifdef HAVE_LOCAL_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2301 case AF_LOCAL: |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2302 { |
|
44038
e2339254ba48
(conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents:
44013
diff
changeset
|
2303 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
|
2304 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
|
2305 if (sockun->sun_path[i] == 0) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2306 break; |
|
44038
e2339254ba48
(conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents:
44013
diff
changeset
|
2307 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
|
2308 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2309 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2310 default: |
|
109320
a0d2db31314d
Use offsetof instead of own definition
Andreas Schwab <schwab@linux-m68k.org>
parents:
109319
diff
changeset
|
2311 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
|
2312 address = Fcons (make_number (sa->sa_family), |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2313 Fmake_vector (make_number (len), Qnil)); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2314 p = XVECTOR (XCDR (address)); |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
2315 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
|
2316 break; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2317 } |
|
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 i = 0; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2320 while (i < len) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2321 p->contents[i++] = make_number (*cp++); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2322 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2323 return address; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2324 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2325 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2326 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2327 /* 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
|
2328 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2329 static int |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
2330 get_lisp_to_sockaddr_size (Lisp_Object address, int *familyp) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2331 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2332 register struct Lisp_Vector *p; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2333 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2334 if (VECTORP (address)) |
|
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 p = XVECTOR (address); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2337 if (p->size == 5) |
|
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 *familyp = AF_INET; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2340 return sizeof (struct sockaddr_in); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2341 } |
| 68008 | 2342 #ifdef AF_INET6 |
| 2343 else if (p->size == 9) | |
| 2344 { | |
| 2345 *familyp = AF_INET6; | |
| 2346 return sizeof (struct sockaddr_in6); | |
| 2347 } | |
| 2348 #endif | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2349 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2350 #ifdef HAVE_LOCAL_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2351 else if (STRINGP (address)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2352 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2353 *familyp = AF_LOCAL; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2354 return sizeof (struct sockaddr_un); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2355 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2356 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2357 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
|
2358 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2359 struct sockaddr *sa; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2360 *familyp = XINT (XCAR (address)); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2361 p = XVECTOR (XCDR (address)); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2362 return p->size + sizeof (sa->sa_family); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2363 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2364 return 0; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2365 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2366 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2367 /* 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
|
2368 |
|
9fb9e33ecf2d
(conv_lisp_to_sockaddr): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents:
69974
diff
changeset
|
2369 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
|
2370 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
|
2371 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
|
2372 we return after zeroing *SA. */ |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2373 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2374 static void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
2375 conv_lisp_to_sockaddr (int family, Lisp_Object address, struct sockaddr *sa, int len) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2376 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2377 register struct Lisp_Vector *p; |
|
51233
41ed31a0fd49
(allocate_pty): Remove `unused var stb' and
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51046
diff
changeset
|
2378 register unsigned char *cp = NULL; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2379 register int i; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2380 |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
2381 memset (sa, 0, len); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2382 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2383 if (VECTORP (address)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2384 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2385 p = XVECTOR (address); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2386 if (family == AF_INET) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2387 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2388 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
|
2389 len = sizeof (sin->sin_addr) + 1; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2390 i = XINT (p->contents[--len]); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2391 sin->sin_port = htons (i); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2392 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
|
2393 sa->sa_family = family; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2394 } |
| 68008 | 2395 #ifdef AF_INET6 |
| 2396 else if (family == AF_INET6) | |
| 2397 { | |
| 2398 struct sockaddr_in6 *sin6 = (struct sockaddr_in6 *) sa; | |
| 2399 uint16_t *ip6 = (uint16_t *)&sin6->sin6_addr; | |
| 2400 len = sizeof (sin6->sin6_addr) + 1; | |
| 2401 i = XINT (p->contents[--len]); | |
| 2402 sin6->sin6_port = htons (i); | |
| 2403 for (i = 0; i < len; i++) | |
| 2404 if (INTEGERP (p->contents[i])) | |
| 2405 { | |
| 2406 int j = XFASTINT (p->contents[i]) & 0xffff; | |
| 2407 ip6[i] = ntohs (j); | |
| 2408 } | |
|
69981
9fb9e33ecf2d
(conv_lisp_to_sockaddr): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents:
69974
diff
changeset
|
2409 sa->sa_family = family; |
|
108935
44a0c766b765
* process.c (conv_lisp_to_sockaddr): Fix conversion of IPv4
Andreas Schwab <schwab@linux-m68k.org>
parents:
106815
diff
changeset
|
2410 return; |
| 68008 | 2411 } |
| 2412 #endif | |
|
108935
44a0c766b765
* process.c (conv_lisp_to_sockaddr): Fix conversion of IPv4
Andreas Schwab <schwab@linux-m68k.org>
parents:
106815
diff
changeset
|
2413 else |
|
44a0c766b765
* process.c (conv_lisp_to_sockaddr): Fix conversion of IPv4
Andreas Schwab <schwab@linux-m68k.org>
parents:
106815
diff
changeset
|
2414 return; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2415 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2416 else if (STRINGP (address)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2417 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2418 #ifdef HAVE_LOCAL_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2419 if (family == AF_LOCAL) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2420 { |
|
44038
e2339254ba48
(conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents:
44013
diff
changeset
|
2421 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
|
2422 cp = SDATA (address); |
|
44038
e2339254ba48
(conv_sockaddr_to_lisp, conv_lisp_to_sockaddr): Don't
Eli Zaretskii <eliz@gnu.org>
parents:
44013
diff
changeset
|
2423 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
|
2424 sockun->sun_path[i] = *cp++; |
|
69981
9fb9e33ecf2d
(conv_lisp_to_sockaddr): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents:
69974
diff
changeset
|
2425 sa->sa_family = family; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2426 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2427 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2428 return; |
|
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 |
|
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 p = XVECTOR (XCDR (address)); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2433 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
|
2434 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2435 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2436 for (i = 0; i < len; i++) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2437 if (INTEGERP (p->contents[i])) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2438 *cp++ = XFASTINT (p->contents[i]) & 0xff; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2439 } |
|
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 #ifdef DATAGRAM_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2442 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
|
2443 1, 1, 0, |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2444 doc: /* Get the current datagram address associated with PROCESS. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
2445 (Lisp_Object process) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2446 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2447 int channel; |
|
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 CHECK_PROCESS (process); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2450 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2451 if (!DATAGRAM_CONN_P (process)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2452 return Qnil; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2453 |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
2454 channel = XPROCESS (process)->infd; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2455 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
|
2456 datagram_address[channel].len); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2457 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2458 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2459 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
|
2460 2, 2, 0, |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2461 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
|
2462 Returns nil upon error setting address, ADDRESS otherwise. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
2463 (Lisp_Object process, Lisp_Object address) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2464 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2465 int channel; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2466 int family, len; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2467 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2468 CHECK_PROCESS (process); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2469 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2470 if (!DATAGRAM_CONN_P (process)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2471 return Qnil; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2472 |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
2473 channel = XPROCESS (process)->infd; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2474 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2475 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
|
2476 if (datagram_address[channel].len != len) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2477 return Qnil; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2478 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
|
2479 return 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 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2482 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2483 |
|
105872
89183b6f6e9d
* process.c (socket_options): Make it const.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105672
diff
changeset
|
2484 static const struct socket_options { |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2485 /* 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
|
2486 name without SO_ prefix. */ |
| 109640 | 2487 const char *name; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2488 /* Option level SOL_... */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2489 int optlevel; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2490 /* Option number SO_... */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2491 int optnum; |
|
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2492 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
|
2493 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
|
2494 } socket_options[] = |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2495 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2496 #ifdef SO_BINDTODEVICE |
|
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2497 { ":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
|
2498 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2499 #ifdef SO_BROADCAST |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2500 { ":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
|
2501 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2502 #ifdef SO_DONTROUTE |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2503 { ":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
|
2504 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2505 #ifdef SO_KEEPALIVE |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2506 { ":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
|
2507 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2508 #ifdef SO_LINGER |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2509 { ":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
|
2510 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2511 #ifdef SO_OOBINLINE |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2512 { ":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
|
2513 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2514 #ifdef SO_PRIORITY |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2515 { ":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
|
2516 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2517 #ifdef SO_REUSEADDR |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2518 { ":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
|
2519 #endif |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2520 { 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
|
2521 }; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2522 |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2523 /* 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
|
2524 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2525 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
|
2526 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
|
2527 */ |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2528 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2529 static int |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
2530 set_socket_option (int s, Lisp_Object opt, Lisp_Object val) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2531 { |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2532 char *name; |
|
105872
89183b6f6e9d
* process.c (socket_options): Make it const.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105672
diff
changeset
|
2533 const struct socket_options *sopt; |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2534 int ret = 0; |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2535 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2536 CHECK_SYMBOL (opt); |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2537 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2538 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
|
2539 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
|
2540 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
|
2541 break; |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2542 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2543 switch (sopt->opttype) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2544 { |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2545 case SOPT_BOOL: |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2546 { |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2547 int optval; |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2548 optval = NILP (val) ? 0 : 1; |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2549 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
|
2550 &optval, sizeof (optval)); |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2551 break; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2552 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2553 |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2554 case SOPT_INT: |
|
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 int optval; |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2557 if (INTEGERP (val)) |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2558 optval = XINT (val); |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2559 else |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2560 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
|
2561 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
|
2562 &optval, sizeof (optval)); |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2563 break; |
|
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 |
|
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2566 #ifdef SO_BINDTODEVICE |
|
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2567 case SOPT_IFNAME: |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2568 { |
|
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2569 char devname[IFNAMSIZ+1]; |
|
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2570 |
|
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2571 /* 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
|
2572 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
|
2573 This should work on all systems. KFS. 2003-09-23. */ |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
2574 memset (devname, 0, sizeof devname); |
|
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2575 if (STRINGP (val)) |
|
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2576 { |
|
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2577 char *arg = (char *) SDATA (val); |
|
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2578 int len = min (strlen (arg), IFNAMSIZ); |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
2579 memcpy (devname, arg, len); |
|
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2580 } |
|
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2581 else if (!NILP (val)) |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2582 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
|
2583 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
|
2584 devname, IFNAMSIZ); |
|
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2585 break; |
|
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 #endif |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2588 |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2589 #ifdef SO_LINGER |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2590 case SOPT_LINGER: |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2591 { |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2592 struct linger linger; |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2593 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2594 linger.l_onoff = 1; |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2595 linger.l_linger = 0; |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2596 if (INTEGERP (val)) |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2597 linger.l_linger = XINT (val); |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2598 else |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2599 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
|
2600 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
|
2601 &linger, sizeof (linger)); |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2602 break; |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2603 } |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2604 #endif |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2605 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2606 default: |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2607 return 0; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2608 } |
|
52516
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 if (ret < 0) |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2611 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
|
2612 Fcons (opt, Fcons (val, Qnil))); |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2613 return (1 << sopt->optbit); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2614 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2615 |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2616 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2617 DEFUN ("set-network-process-option", |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2618 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
|
2619 3, 4, 0, |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2620 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
|
2621 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
|
2622 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
|
2623 OPTION is not a supported option, return nil instead; otherwise return t. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
2624 (Lisp_Object process, Lisp_Object option, Lisp_Object value, Lisp_Object no_error) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2625 { |
|
52527
3ea59ac8dfa5
(Fnetwork_interface_info): Fix type error.
Dave Love <fx@gnu.org>
parents:
52525
diff
changeset
|
2626 int s; |
|
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2627 struct Lisp_Process *p; |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2628 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2629 CHECK_PROCESS (process); |
|
52594
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2630 p = XPROCESS (process); |
|
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2631 if (!NETCONN1_P (p)) |
|
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2632 error ("Process is not a network process"); |
|
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2633 |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
2634 s = p->infd; |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2635 if (s < 0) |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2636 error ("Process is not running"); |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2637 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2638 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
|
2639 { |
|
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2640 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
|
2641 return Qt; |
|
d03629d1d293
(set_socket_option): Fix :bindtodevice option.
Kim F. Storm <storm@cua.dk>
parents:
52591
diff
changeset
|
2642 } |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2643 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2644 if (NILP (no_error)) |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2645 error ("Unknown or unsupported option"); |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2646 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2647 return Qnil; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2648 } |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
2649 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2650 |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2651 DEFUN ("serial-process-configure", |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2652 Fserial_process_configure, |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2653 Sserial_process_configure, |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2654 0, MANY, 0, |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2655 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
|
2656 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2657 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
|
2658 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
|
2659 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
|
2660 reasonable default values. The following arguments are defined: |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2661 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2662 :process PROCESS |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2663 :name NAME |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2664 :buffer BUFFER |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2665 :port PORT |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2666 -- 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
|
2667 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
|
2668 buffer's process is used. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2669 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2670 :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
|
2671 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
|
2672 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
|
2673 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
|
2674 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
|
2675 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
|
2676 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
|
2677 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
|
2678 through `make-serial-process' or `serial-term'. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2679 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2680 :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
|
2681 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
|
2682 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2683 :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
|
2684 `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
|
2685 PARITY is not given, no parity is used. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2686 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2687 :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
|
2688 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
|
2689 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
|
2690 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2691 :flowcontrol FLOWCONTROL -- FLOWCONTROL determines the type of |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2692 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
|
2693 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
|
2694 \(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
|
2695 flowcontrol is used. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2696 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2697 `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
|
2698 initial configuration of the serial port. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2699 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2700 Examples: |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2701 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2702 \(serial-process-configure :process "/dev/ttyS0" :speed 1200) |
|
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 \(serial-process-configure |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2705 :buffer "COM1" :stopbits 1 :parity 'odd :flowcontrol 'hw) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2706 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2707 \(serial-process-configure :port "\\\\.\\COM13" :bytesize 7) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2708 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2709 usage: (serial-process-configure &rest ARGS) */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
2710 (int nargs, Lisp_Object *args) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2711 { |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2712 struct Lisp_Process *p; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2713 Lisp_Object contact = Qnil; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2714 Lisp_Object proc = Qnil; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2715 struct gcpro gcpro1; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2716 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2717 contact = Flist (nargs, args); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2718 GCPRO1 (contact); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2719 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2720 proc = Fplist_get (contact, QCprocess); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2721 if (NILP (proc)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2722 proc = Fplist_get (contact, QCname); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2723 if (NILP (proc)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2724 proc = Fplist_get (contact, QCbuffer); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2725 if (NILP (proc)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2726 proc = Fplist_get (contact, QCport); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2727 proc = get_process (proc); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2728 p = XPROCESS (proc); |
|
95900
99342636fa96
(Fserial_process_configure, Fprocess_send_eof):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95884
diff
changeset
|
2729 if (!EQ (p->type, Qserial)) |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2730 error ("Not a serial process"); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2731 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2732 if (NILP (Fplist_get (p->childp, QCspeed))) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2733 { |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2734 UNGCPRO; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2735 return Qnil; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2736 } |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2737 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2738 serial_configure (p, contact); |
|
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 UNGCPRO; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2741 return Qnil; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2742 } |
|
96833
c06568fd3844
* s/usg5-4.h (LIBS_SYSTEM): Remove, system for which this was
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96774
diff
changeset
|
2743 |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2744 /* 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
|
2745 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
|
2746 { |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2747 if (!PROCESSP (proc)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2748 abort (); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2749 remove_process (proc); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2750 return Qnil; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2751 } |
|
96833
c06568fd3844
* s/usg5-4.h (LIBS_SYSTEM): Remove, system for which this was
Dan Nicolaescu <dann@ics.uci.edu>
parents:
96774
diff
changeset
|
2752 |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2753 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
|
2754 0, MANY, 0, |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2755 doc: /* Create and return a serial port process. |
|
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 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
|
2758 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
|
2759 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
|
2760 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
|
2761 from normal processes. |
|
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 `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
|
2764 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
|
2765 an interactive terminal. See below for examples. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2766 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2767 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
|
2768 arguments are defined: |
|
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 :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
|
2771 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
|
2772 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
|
2773 the backslashes in strings). |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2774 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2775 :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
|
2776 which is called by `make-serial-process'. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2777 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2778 :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
|
2779 the value of PORT is used. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2780 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2781 :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
|
2782 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
|
2783 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
|
2784 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
|
2785 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2786 :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
|
2787 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
|
2788 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
|
2789 ENCODING is used for writing. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2790 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2791 :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
|
2792 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
|
2793 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2794 :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
|
2795 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
|
2796 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
|
2797 `continue-process' and set by `stop-process'. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2798 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2799 :filter FILTER -- Install FILTER as the process filter. |
|
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 :sentinel SENTINEL -- Install SENTINEL as the process sentinel. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2802 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2803 :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
|
2804 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2805 :speed |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2806 :bytesize |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2807 :parity |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2808 :stopbits |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2809 :flowcontrol |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2810 -- 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
|
2811 called by `make-serial-process'. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2812 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2813 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
|
2814 is available via the function `process-contact'. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2815 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2816 Examples: |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2817 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2818 \(make-serial-process :port "/dev/ttyS0" :speed 9600) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2819 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2820 \(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
|
2821 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2822 \(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
|
2823 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2824 \(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
|
2825 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2826 usage: (make-serial-process &rest ARGS) */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
2827 (int nargs, Lisp_Object *args) |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2828 { |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2829 int fd = -1; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2830 Lisp_Object proc, contact, port; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2831 struct Lisp_Process *p; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2832 struct gcpro gcpro1; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2833 Lisp_Object name, buffer; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2834 Lisp_Object tem, val; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2835 int specpdl_count = -1; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2836 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2837 if (nargs == 0) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2838 return Qnil; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2839 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2840 contact = Flist (nargs, args); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2841 GCPRO1 (contact); |
|
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 port = Fplist_get (contact, QCport); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2844 if (NILP (port)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2845 error ("No port specified"); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2846 CHECK_STRING (port); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2847 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2848 if (NILP (Fplist_member (contact, QCspeed))) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2849 error (":speed not specified"); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2850 if (!NILP (Fplist_get (contact, QCspeed))) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2851 CHECK_NUMBER (Fplist_get (contact, QCspeed)); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2852 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2853 name = Fplist_get (contact, QCname); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2854 if (NILP (name)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2855 name = port; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2856 CHECK_STRING (name); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2857 proc = make_process (name); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2858 specpdl_count = SPECPDL_INDEX (); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2859 record_unwind_protect (make_serial_process_unwind, proc); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2860 p = XPROCESS (proc); |
|
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 fd = serial_open ((char*) SDATA (port)); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2863 p->infd = fd; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2864 p->outfd = fd; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2865 if (fd > max_process_desc) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2866 max_process_desc = fd; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2867 chan_process[fd] = proc; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2868 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2869 buffer = Fplist_get (contact, QCbuffer); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2870 if (NILP (buffer)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2871 buffer = name; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2872 buffer = Fget_buffer_create (buffer); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2873 p->buffer = buffer; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2874 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2875 p->childp = contact; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2876 p->plist = Fcopy_sequence (Fplist_get (contact, QCplist)); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2877 p->type = Qserial; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2878 p->sentinel = Fplist_get (contact, QCsentinel); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2879 p->filter = Fplist_get (contact, QCfilter); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2880 p->log = Qnil; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2881 if (tem = Fplist_get (contact, QCnoquery), !NILP (tem)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2882 p->kill_without_query = 1; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2883 if (tem = Fplist_get (contact, QCstop), !NILP (tem)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2884 p->command = Qt; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2885 p->pty_flag = 0; |
|
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 if (!EQ (p->command, Qt)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2888 { |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2889 FD_SET (fd, &input_wait_mask); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2890 FD_SET (fd, &non_keyboard_wait_mask); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2891 } |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2892 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2893 if (BUFFERP (buffer)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2894 { |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2895 set_marker_both (p->mark, buffer, |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2896 BUF_ZV (XBUFFER (buffer)), |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2897 BUF_ZV_BYTE (XBUFFER (buffer))); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2898 } |
|
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 tem = Fplist_member (contact, QCcoding); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2901 if (!NILP (tem) && (!CONSP (tem) || !CONSP (XCDR (tem)))) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2902 tem = Qnil; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2903 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2904 val = Qnil; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2905 if (!NILP (tem)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2906 { |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2907 val = XCAR (XCDR (tem)); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2908 if (CONSP (val)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2909 val = XCAR (val); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2910 } |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2911 else if (!NILP (Vcoding_system_for_read)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2912 val = Vcoding_system_for_read; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2913 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
|
2914 || (NILP (buffer) && NILP (buffer_defaults.enable_multibyte_characters))) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2915 val = Qnil; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2916 p->decode_coding_system = val; |
|
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 val = Qnil; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2919 if (!NILP (tem)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2920 { |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2921 val = XCAR (XCDR (tem)); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2922 if (CONSP (val)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2923 val = XCDR (val); |
|
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 else if (!NILP (Vcoding_system_for_write)) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2926 val = Vcoding_system_for_write; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2927 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
|
2928 || (NILP (buffer) && NILP (buffer_defaults.enable_multibyte_characters))) |
|
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 p->encode_coding_system = val; |
|
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 setup_process_coding_systems (proc); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2933 p->decoding_buf = make_uninit_string (0); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2934 p->decoding_carryover = 0; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2935 p->encoding_buf = make_uninit_string (0); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2936 p->inherit_coding_system_flag |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2937 = !(!NILP (tem) || NILP (buffer) || !inherit_process_coding_system); |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2938 |
|
109160
f8660b83cdbf
Fix whitespace to follow coding guidelines.
Juanma Barranquero <lekktu@gmail.com>
parents:
109145
diff
changeset
|
2939 Fserial_process_configure (nargs, args); |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2940 |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2941 specpdl_ptr = specpdl + specpdl_count; |
|
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 UNGCPRO; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2944 return proc; |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
2945 } |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2946 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2947 /* 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
|
2948 exactly like a normal process when reading and writing. Primary |
| 578 | 2949 differences are in status display and process deletion. A network |
| 2950 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
|
2951 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
|
2952 |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2953 DEFUN ("make-network-process", Fmake_network_process, Smake_network_process, |
|
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
2954 0, MANY, 0, |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2955 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
|
2956 |
|
43995
110955214222
(Fmake_network_process): Remove unused variable `sa'.
Pavel Jan?k <Pavel@Janik.cz>
parents:
43968
diff
changeset
|
2957 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
|
2958 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
|
2959 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
|
2960 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
|
2961 processes. |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2962 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2963 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
|
2964 arguments are defined: |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2965 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2966 :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
|
2967 to make it unique. |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2968 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2969 :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
|
2970 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
|
2971 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
|
2972 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
|
2973 with any buffer. |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2974 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2975 :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
|
2976 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
|
2977 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
|
2978 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
|
2979 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2980 :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
|
2981 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
|
2982 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
|
2983 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
|
2984 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
|
2985 |
|
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
2986 :type TYPE -- TYPE is the type of connection. The default (nil) is a |
|
106397
210af1fb2669
(Qseqpacket): New symbol.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106186
diff
changeset
|
2987 stream type connection, `datagram' creates a datagram type connection, |
|
210af1fb2669
(Qseqpacket): New symbol.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106186
diff
changeset
|
2988 `seqpacket' creates a reliable datagram connection. |
|
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
2989 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2990 :family FAMILY -- FAMILY is the address (and protocol) family for the |
| 68008 | 2991 service specified by HOST and SERVICE. The default (nil) is to use |
| 2992 whatever address family (IPv4 or IPv6) that is defined for the host | |
| 2993 and port number specified by HOST and SERVICE. Other address families | |
| 2994 supported are: | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2995 local -- for a local (i.e. UNIX) address specified by SERVICE. |
| 68008 | 2996 ipv4 -- use IPv4 address family only. |
| 2997 ipv6 -- use IPv6 address family only. | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2998 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
2999 :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
|
3000 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
|
3001 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
|
3002 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3003 :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
|
3004 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
|
3005 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
|
3006 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
|
3007 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
|
3008 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3009 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
|
3010 - 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
|
3011 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
|
3012 - 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
|
3013 local address space. |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3014 - 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
|
3015 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
|
3016 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
|
3017 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
|
3018 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
|
3019 |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3020 :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
|
3021 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
|
3022 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
|
3023 ENCODING is used for writing. |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3024 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3025 :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
|
3026 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
|
3027 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
|
3028 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
|
3029 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
|
3030 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3031 :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
|
3032 running when Emacs is exited. |
|
43968
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 :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
|
3035 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
|
3036 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
|
3037 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
|
3038 `stop-process'. |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3039 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3040 :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
|
3041 |
| 49680 | 3042 :filter-multibyte BOOL -- If BOOL is non-nil, strings given to the |
| 3043 process filter are multibyte, otherwise they are unibyte. | |
| 78501 | 3044 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
|
3045 `default-enable-multibyte-characters' is non-nil. |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
3046 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3047 :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
|
3048 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3049 :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
|
3050 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
|
3051 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
|
3052 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
|
3053 and MESSAGE is a string. |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3054 |
|
49223
26622fa0d099
Reworked 2003-01-12 change -- call a plist a plist!
Kim F. Storm <storm@cua.dk>
parents:
49164
diff
changeset
|
3055 :plist PLIST -- Install PLIST as the new process' initial plist. |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3056 |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3057 :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
|
3058 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
|
3059 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
|
3060 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
|
3061 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
|
3062 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3063 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
|
3064 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3065 :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
|
3066 :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
|
3067 :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
|
3068 :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
|
3069 :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
|
3070 :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
|
3071 :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
|
3072 (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
|
3073 :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
|
3074 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
|
3075 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3076 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
|
3077 information on using these options. |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3078 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3079 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3080 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
|
3081 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
|
3082 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
|
3083 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3084 - 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
|
3085 process' NAME and a client identification string. |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3086 - 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
|
3087 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
|
3088 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
|
3089 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
|
3090 - 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
|
3091 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
|
3092 - 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
|
3093 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
|
3094 - 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
|
3095 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3096 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
|
3097 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
|
3098 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
|
3099 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
|
3100 |
|
49142
8dca38bc0261
(Fset_process_contact): New function.
Kim F. Storm <storm@cua.dk>
parents:
49119
diff
changeset
|
3101 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
|
3102 information, is available via the `process-contact' function. |
|
8dca38bc0261
(Fset_process_contact): New function.
Kim F. Storm <storm@cua.dk>
parents:
49119
diff
changeset
|
3103 |
|
43995
110955214222
(Fmake_network_process): Remove unused variable `sa'.
Pavel Jan?k <Pavel@Janik.cz>
parents:
43968
diff
changeset
|
3104 usage: (make-network-process &rest ARGS) */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
3105 (int nargs, Lisp_Object *args) |
| 578 | 3106 { |
| 3107 Lisp_Object proc; | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3108 Lisp_Object contact; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3109 struct Lisp_Process *p; |
|
32032
633b826a56f3
(Fopen_network_stream) [HAVE_GETADDRINFO]: Use
Gerd Moellmann <gerd@gnu.org>
parents:
31806
diff
changeset
|
3110 #ifdef HAVE_GETADDRINFO |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3111 struct addrinfo ai, *res, *lres; |
| 68008 | 3112 struct addrinfo hints; |
|
109726
64732fa6188a
Use const char* instead of char*.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109672
diff
changeset
|
3113 const char *portstring; |
|
64732fa6188a
Use const char* instead of char*.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109672
diff
changeset
|
3114 char portbuf[128]; |
|
32032
633b826a56f3
(Fopen_network_stream) [HAVE_GETADDRINFO]: Use
Gerd Moellmann <gerd@gnu.org>
parents:
31806
diff
changeset
|
3115 #else /* HAVE_GETADDRINFO */ |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3116 struct _emacs_addrinfo |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3117 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3118 int ai_family; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3119 int ai_socktype; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3120 int ai_protocol; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3121 int ai_addrlen; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3122 struct sockaddr *ai_addr; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3123 struct _emacs_addrinfo *ai_next; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3124 } ai, *res, *lres; |
|
25262
ccf83ed7326a
(Fopen_network_stream): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents:
25248
diff
changeset
|
3125 #endif /* HAVE_GETADDRINFO */ |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3126 struct sockaddr_in address_in; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3127 #ifdef HAVE_LOCAL_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3128 struct sockaddr_un address_un; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3129 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3130 int port; |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3131 int ret = 0; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3132 int xerrno = 0; |
|
25262
ccf83ed7326a
(Fopen_network_stream): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents:
25248
diff
changeset
|
3133 int s = -1, outch, inch; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3134 struct gcpro gcpro1; |
|
46293
1fb8f75062c6
Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents:
45410
diff
changeset
|
3135 int count = SPECPDL_INDEX (); |
|
25705
1f109108fa7e
(Fopen_network_stream): Avoid socket decriptor leak.
Andreas Schwab <schwab@suse.de>
parents:
25645
diff
changeset
|
3136 int count1; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3137 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
|
3138 Lisp_Object tem; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3139 Lisp_Object name, buffer, host, service, address; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3140 Lisp_Object filter, sentinel; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3141 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
|
3142 int is_server = 0, backlog = 5; |
|
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3143 int socktype; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3144 int family = -1; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3145 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3146 if (nargs == 0) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3147 return Qnil; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3148 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3149 /* 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
|
3150 contact = Flist (nargs, args); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3151 GCPRO1 (contact); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3152 |
|
15355
6bb377ef707f
(Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents:
15092
diff
changeset
|
3153 #ifdef WINDOWSNT |
|
6bb377ef707f
(Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents:
15092
diff
changeset
|
3154 /* Ensure socket support is loaded if available. */ |
|
6bb377ef707f
(Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents:
15092
diff
changeset
|
3155 init_winsock (TRUE); |
|
6bb377ef707f
(Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents:
15092
diff
changeset
|
3156 #endif |
|
6bb377ef707f
(Fopen_network_stream)[WINDOWSNT]: Ensure Windows
Richard M. Stallman <rms@gnu.org>
parents:
15092
diff
changeset
|
3157 |
|
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3158 /* :type TYPE (nil: stream, datagram */ |
|
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3159 tem = Fplist_get (contact, QCtype); |
|
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3160 if (NILP (tem)) |
|
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3161 socktype = SOCK_STREAM; |
|
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3162 #ifdef DATAGRAM_SOCKETS |
|
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3163 else if (EQ (tem, Qdatagram)) |
|
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3164 socktype = SOCK_DGRAM; |
|
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3165 #endif |
|
106397
210af1fb2669
(Qseqpacket): New symbol.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106186
diff
changeset
|
3166 #ifdef HAVE_SEQPACKET |
|
210af1fb2669
(Qseqpacket): New symbol.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106186
diff
changeset
|
3167 else if (EQ (tem, Qseqpacket)) |
|
210af1fb2669
(Qseqpacket): New symbol.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106186
diff
changeset
|
3168 socktype = SOCK_SEQPACKET; |
|
210af1fb2669
(Qseqpacket): New symbol.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106186
diff
changeset
|
3169 #endif |
|
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3170 else |
|
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
3171 error ("Unsupported connection type"); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3172 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3173 /* :server BOOL */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3174 tem = Fplist_get (contact, QCserver); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3175 if (!NILP (tem)) |
|
25248
f0fc8443bdbb
(Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents:
25129
diff
changeset
|
3176 { |
|
45099
8a33d836b6fb
(Fmake_network_process): Only support server sockets
Jason Rumney <jasonr@gnu.org>
parents:
45005
diff
changeset
|
3177 /* 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
|
3178 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
|
3179 #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
|
3180 error ("Network servers not supported"); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3181 #else |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3182 is_server = 1; |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3183 if (INTEGERP (tem)) |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3184 backlog = XINT (tem); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3185 #endif |
|
25248
f0fc8443bdbb
(Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents:
25129
diff
changeset
|
3186 } |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3187 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3188 /* 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
|
3189 QCaddress = is_server ? QClocal : QCremote; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3190 |
| 74946 | 3191 /* :nowait BOOL */ |
|
106398
31424b91531a
(Fmake_network_process): Fix up the tests for
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106397
diff
changeset
|
3192 if (!is_server && socktype != SOCK_DGRAM |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3193 && (tem = Fplist_get (contact, QCnowait), !NILP (tem))) |
|
25248
f0fc8443bdbb
(Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents:
25129
diff
changeset
|
3194 { |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3195 #ifndef NON_BLOCKING_CONNECT |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3196 error ("Non-blocking connect not supported"); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3197 #else |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3198 is_non_blocking_client = 1; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3199 #endif |
|
25248
f0fc8443bdbb
(Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents:
25129
diff
changeset
|
3200 } |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3201 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3202 name = Fplist_get (contact, QCname); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3203 buffer = Fplist_get (contact, QCbuffer); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3204 filter = Fplist_get (contact, QCfilter); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3205 sentinel = Fplist_get (contact, QCsentinel); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3206 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3207 CHECK_STRING (name); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3208 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3209 /* 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
|
3210 ai.ai_socktype = socktype; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3211 ai.ai_protocol = 0; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3212 ai.ai_next = NULL; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3213 res = &ai; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3214 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3215 /* :local ADDRESS or :remote ADDRESS */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3216 address = Fplist_get (contact, QCaddress); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3217 if (!NILP (address)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3218 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3219 host = service = Qnil; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3220 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3221 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
|
3222 error ("Malformed :address"); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3223 ai.ai_family = family; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3224 ai.ai_addr = alloca (ai.ai_addrlen); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3225 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
|
3226 goto open_socket; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3227 } |
|
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 /* :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
|
3230 tem = Fplist_get (contact, QCfamily); |
| 68008 | 3231 if (NILP (tem)) |
| 3232 { | |
|
68041
b7409cbd6d99
(Fmake_network_process): Use AF_INET instead of
Kim F. Storm <storm@cua.dk>
parents:
68022
diff
changeset
|
3233 #if defined(HAVE_GETADDRINFO) && defined(AF_INET6) |
| 68008 | 3234 family = AF_UNSPEC; |
| 3235 #else | |
| 3236 family = AF_INET; | |
| 3237 #endif | |
| 3238 } | |
| 3239 #ifdef HAVE_LOCAL_SOCKETS | |
| 3240 else if (EQ (tem, Qlocal)) | |
| 3241 family = AF_LOCAL; | |
| 3242 #endif | |
| 3243 #ifdef AF_INET6 | |
| 3244 else if (EQ (tem, Qipv6)) | |
| 3245 family = AF_INET6; | |
| 3246 #endif | |
| 3247 else if (EQ (tem, Qipv4)) | |
| 3248 family = AF_INET; | |
| 3249 else if (INTEGERP (tem)) | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3250 family = XINT (tem); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3251 else |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3252 error ("Unknown address family"); |
| 68008 | 3253 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3254 ai.ai_family = family; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3255 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3256 /* :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
|
3257 service = Fplist_get (contact, QCservice); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3258 |
|
108754
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3259 /* :host HOST -- hostname, ip address, or 'local for localhost. */ |
|
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3260 host = Fplist_get (contact, QChost); |
|
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3261 if (!NILP (host)) |
|
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3262 { |
|
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3263 if (EQ (host, Qlocal)) |
|
110556
310fef3bdbbb
Fix bug#6781: Use 127.0.0.1 for local hosts, not "localhost".
Juanma Barranquero <lekktu@gmail.com>
parents:
110398
diff
changeset
|
3264 /* Depending on setup, "localhost" may map to different IPv4 and/or |
|
310fef3bdbbb
Fix bug#6781: Use 127.0.0.1 for local hosts, not "localhost".
Juanma Barranquero <lekktu@gmail.com>
parents:
110398
diff
changeset
|
3265 IPv6 addresses, so it's better to be explicit. (Bug#6781) */ |
|
310fef3bdbbb
Fix bug#6781: Use 127.0.0.1 for local hosts, not "localhost".
Juanma Barranquero <lekktu@gmail.com>
parents:
110398
diff
changeset
|
3266 host = build_string ("127.0.0.1"); |
|
108754
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3267 CHECK_STRING (host); |
|
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3268 } |
|
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3269 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3270 #ifdef HAVE_LOCAL_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3271 if (family == AF_LOCAL) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3272 { |
|
108754
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3273 if (!NILP (host)) |
|
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3274 { |
|
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3275 message (":family local ignores the :host \"%s\" property", |
|
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3276 SDATA (host)); |
|
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3277 contact = Fplist_put (contact, QChost, Qnil); |
|
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3278 host = Qnil; |
|
728449765ab0
* process.c (Fmake_network_process): Set :host to nil if it's not used.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
108234
diff
changeset
|
3279 } |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3280 CHECK_STRING (service); |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
3281 memset (&address_un, 0, sizeof address_un); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3282 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
|
3283 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
|
3284 ai.ai_addr = (struct sockaddr *) &address_un; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3285 ai.ai_addrlen = sizeof address_un; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3286 goto open_socket; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3287 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3288 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3289 |
|
13777
5e0cbd5fcb46
(Fopen_network_stream): Call bind_polling_period earlier.
Karl Heuer <kwzh@gnu.org>
parents:
13709
diff
changeset
|
3290 /* 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
|
3291 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
|
3292 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
|
3293 #ifdef POLL_FOR_INPUT |
|
106398
31424b91531a
(Fmake_network_process): Fix up the tests for
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106397
diff
changeset
|
3294 if (socktype != SOCK_DGRAM) |
|
43968
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 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
|
3297 bind_polling_period (10); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3298 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3299 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3300 |
|
25248
f0fc8443bdbb
(Fopen_network_stream): Use getaddrinfo.
Karl Heuer <kwzh@gnu.org>
parents:
25129
diff
changeset
|
3301 #ifdef HAVE_GETADDRINFO |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3302 /* 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
|
3303 Otherwise, use getservbyname to lookup the service. */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3304 if (!NILP (host)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3305 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3306 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3307 /* 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
|
3308 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
|
3309 if (EQ (service, Qt)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3310 portstring = "0"; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3311 else if (INTEGERP (service)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3312 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3313 sprintf (portbuf, "%ld", (long) XINT (service)); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3314 portstring = portbuf; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3315 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3316 else |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3317 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3318 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
|
3319 portstring = SDATA (service); |
|
43968
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 immediate_quit = 1; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3323 QUIT; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3324 memset (&hints, 0, sizeof (hints)); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3325 hints.ai_flags = 0; |
| 68008 | 3326 hints.ai_family = family; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3327 hints.ai_socktype = socktype; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3328 hints.ai_protocol = 0; |
|
85362
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3329 |
|
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3330 #ifdef HAVE_RES_INIT |
|
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3331 res_init (); |
|
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3332 #endif |
|
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3333 |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46314
diff
changeset
|
3334 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
|
3335 if (ret) |
|
32074
a889f9fc59a7
(Fopen_network_stream): Use HAVE_GAI_STRERROR.
Dave Love <fx@gnu.org>
parents:
32032
diff
changeset
|
3336 #ifdef HAVE_GAI_STRERROR |
|
109160
f8660b83cdbf
Fix whitespace to follow coding guidelines.
Juanma Barranquero <lekktu@gmail.com>
parents:
109145
diff
changeset
|
3337 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
|
3338 #else |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
3339 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
|
3340 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3341 immediate_quit = 0; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3342 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3343 goto open_socket; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3344 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3345 #endif /* HAVE_GETADDRINFO */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3346 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3347 /* 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
|
3348 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
|
3349 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3350 if (EQ (service, Qt)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3351 port = 0; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3352 else if (INTEGERP (service)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3353 port = htons ((unsigned short) XINT (service)); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3354 else |
|
8287
97c2535b7f37
(Fopen_network_stream): Retry gethostbyname after TRY_AGAIN failure.
Richard M. Stallman <rms@gnu.org>
parents:
8231
diff
changeset
|
3355 { |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3356 struct servent *svc_info; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3357 CHECK_STRING (service); |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3358 svc_info = getservbyname (SDATA (service), |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3359 (socktype == SOCK_DGRAM ? "udp" : "tcp")); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3360 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
|
3361 error ("Unknown service: %s", SDATA (service)); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3362 port = svc_info->s_port; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3363 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3364 |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
3365 memset (&address_in, 0, sizeof address_in); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3366 address_in.sin_family = family; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3367 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
|
3368 address_in.sin_port = port; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3369 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3370 #ifndef HAVE_GETADDRINFO |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3371 if (!NILP (host)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3372 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3373 struct hostent *host_info_ptr; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3374 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3375 /* 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
|
3376 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
|
3377 immediate_quit = 1; |
|
849458c13c0c
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14736
diff
changeset
|
3378 QUIT; |
|
85362
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3379 |
|
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3380 #ifdef HAVE_RES_INIT |
|
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3381 res_init (); |
|
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3382 #endif |
|
b949ffc47cba
Link to libs for calling res_init() if available.
Chong Yidong <cyd@stupidchicken.com>
parents:
84668
diff
changeset
|
3383 |
|
46370
40db0673e6f0
Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents:
46314
diff
changeset
|
3384 host_info_ptr = gethostbyname (SDATA (host)); |
|
14758
849458c13c0c
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14736
diff
changeset
|
3385 immediate_quit = 0; |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3386 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3387 if (host_info_ptr) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3388 { |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
3389 memcpy (&address_in.sin_addr, host_info_ptr->h_addr, |
|
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
3390 host_info_ptr->h_length); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3391 family = host_info_ptr->h_addrtype; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3392 address_in.sin_family = family; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3393 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3394 else |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3395 /* 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
|
3396 { |
|
91702
b7a5a89054dc
* configure.in (LIBX11_MACHINE, HAVE_XFREE386): Remove code
Dan Nicolaescu <dann@ics.uci.edu>
parents:
91551
diff
changeset
|
3397 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
|
3398 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
|
3399 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
|
3400 error ("Unknown host \"%s\"", SDATA (host)); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3401 |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
3402 memcpy (&address_in.sin_addr, &numeric_addr, |
|
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
3403 sizeof (address_in.sin_addr)); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3404 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3405 |
|
8287
97c2535b7f37
(Fopen_network_stream): Retry gethostbyname after TRY_AGAIN failure.
Richard M. Stallman <rms@gnu.org>
parents:
8231
diff
changeset
|
3406 } |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3407 #endif /* not HAVE_GETADDRINFO */ |
|
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 ai.ai_family = family; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3410 ai.ai_addr = (struct sockaddr *) &address_in; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3411 ai.ai_addrlen = sizeof address_in; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3412 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3413 open_socket: |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3414 |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3415 /* 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
|
3416 count1 = SPECPDL_INDEX (); |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3417 s = -1; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3418 |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3419 for (lres = res; lres; lres = lres->ai_next) |
| 578 | 3420 { |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3421 int optn, optbits; |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3422 |
|
58072
4ebc52bf6429
(Fmake_network_process): Remove kludge for interrupted
Kim F. Storm <storm@cua.dk>
parents:
57840
diff
changeset
|
3423 retry_connect: |
|
4ebc52bf6429
(Fmake_network_process): Remove kludge for interrupted
Kim F. Storm <storm@cua.dk>
parents:
57840
diff
changeset
|
3424 |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3425 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
|
3426 if (s < 0) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3427 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3428 xerrno = errno; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3429 continue; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3430 } |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3431 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3432 #ifdef DATAGRAM_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3433 if (!is_server && socktype == SOCK_DGRAM) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3434 break; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3435 #endif /* DATAGRAM_SOCKETS */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3436 |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3437 #ifdef NON_BLOCKING_CONNECT |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3438 if (is_non_blocking_client) |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3439 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3440 #ifdef O_NONBLOCK |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3441 ret = fcntl (s, F_SETFL, O_NONBLOCK); |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3442 #else |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3443 ret = fcntl (s, F_SETFL, O_NDELAY); |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3444 #endif |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3445 if (ret < 0) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3446 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3447 xerrno = errno; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3448 emacs_close (s); |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3449 s = -1; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3450 continue; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3451 } |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3452 } |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3453 #endif |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3454 |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3455 /* Make us close S if quit. */ |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3456 record_unwind_protect (close_file_unwind, make_number (s)); |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3457 |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3458 /* 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
|
3459 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
|
3460 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
|
3461 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
|
3462 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
|
3463 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3464 if (is_server) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3465 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3466 /* 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
|
3467 |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3468 /* 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
|
3469 explicit :reuseaddr key to override this. */ |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3470 #ifdef HAVE_LOCAL_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3471 if (family != AF_LOCAL) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3472 #endif |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3473 if (!(optbits & (1 << OPIX_REUSEADDR))) |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3474 { |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3475 int optval = 1; |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3476 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
|
3477 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
|
3478 } |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3479 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3480 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
|
3481 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
|
3482 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3483 #ifdef HAVE_GETSOCKNAME |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3484 if (EQ (service, Qt)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3485 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3486 struct sockaddr_in sa1; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3487 int len1 = sizeof (sa1); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3488 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
|
3489 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3490 ((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
|
3491 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
|
3492 contact = Fplist_put (contact, QCservice, service); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3493 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3494 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3495 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3496 |
|
106398
31424b91531a
(Fmake_network_process): Fix up the tests for
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106397
diff
changeset
|
3497 if (socktype != SOCK_DGRAM && listen (s, backlog)) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3498 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
|
3499 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3500 break; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3501 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3502 |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3503 immediate_quit = 1; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3504 QUIT; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3505 |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3506 ret = connect (s, lres->ai_addr, lres->ai_addrlen); |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3507 xerrno = errno; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3508 |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3509 if (ret == 0 || xerrno == EISCONN) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3510 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3511 /* The unwind-protect will be discarded afterwards. |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3512 Likewise for immediate_quit. */ |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3513 break; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3514 } |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3515 |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3516 #ifdef NON_BLOCKING_CONNECT |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3517 #ifdef EINPROGRESS |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3518 if (is_non_blocking_client && xerrno == EINPROGRESS) |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3519 break; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3520 #else |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3521 #ifdef EWOULDBLOCK |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3522 if (is_non_blocking_client && xerrno == EWOULDBLOCK) |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3523 break; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3524 #endif |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3525 #endif |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3526 #endif |
|
7220
a33eb16cab9d
(Fopen_network_stream): Retry the connect if EADDRINUSE. Ignore EISCONN.
Richard M. Stallman <rms@gnu.org>
parents:
7157
diff
changeset
|
3527 |
|
107546
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3528 #ifndef WINDOWSNT |
|
107544
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3529 if (xerrno == EINTR) |
|
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3530 { |
|
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3531 /* Unlike most other syscalls connect() cannot be called |
|
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3532 again. (That would return EALREADY.) The proper way to |
|
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3533 wait for completion is select(). */ |
|
107546
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3534 int sc, len; |
|
107544
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3535 SELECT_TYPE fdset; |
|
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3536 retry_select: |
|
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3537 FD_ZERO (&fdset); |
|
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3538 FD_SET (s, &fdset); |
|
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3539 QUIT; |
|
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3540 sc = select (s + 1, (SELECT_TYPE *)0, &fdset, (SELECT_TYPE *)0, |
|
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3541 (EMACS_TIME *)0); |
|
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3542 if (sc == -1) |
|
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3543 { |
|
107546
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3544 if (errno == EINTR) |
|
107544
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3545 goto retry_select; |
|
107546
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3546 else |
|
107544
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3547 report_file_error ("select failed", Qnil); |
|
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3548 } |
|
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3549 eassert (sc > 0); |
|
107546
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3550 |
|
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3551 len = sizeof xerrno; |
|
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3552 eassert (FD_ISSET (s, &fdset)); |
|
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3553 if (getsockopt (s, SOL_SOCKET, SO_ERROR, &xerrno, &len) == -1) |
|
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3554 report_file_error ("getsockopt failed", Qnil); |
|
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3555 if (xerrno) |
|
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3556 errno = xerrno, report_file_error ("error during connect", Qnil); |
|
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3557 else |
|
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3558 break; |
|
107544
afbf4ad814c7
Call `select' for interrupted `connect' rather than creating new socket (Bug#5173).
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
107460
diff
changeset
|
3559 } |
|
107546
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3560 #endif /* !WINDOWSNT */ |
|
7220
a33eb16cab9d
(Fopen_network_stream): Retry the connect if EADDRINUSE. Ignore EISCONN.
Richard M. Stallman <rms@gnu.org>
parents:
7157
diff
changeset
|
3561 |
|
14671
0493e857a13b
(Fopen_network_stream): Set immediate_quit for the connect.
Richard M. Stallman <rms@gnu.org>
parents:
14613
diff
changeset
|
3562 immediate_quit = 0; |
|
0493e857a13b
(Fopen_network_stream): Set immediate_quit for the connect.
Richard M. Stallman <rms@gnu.org>
parents:
14613
diff
changeset
|
3563 |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3564 /* Discard the unwind protect closing S. */ |
|
25705
1f109108fa7e
(Fopen_network_stream): Avoid socket decriptor leak.
Andreas Schwab <schwab@suse.de>
parents:
25645
diff
changeset
|
3565 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
|
3566 emacs_close (s); |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3567 s = -1; |
|
58072
4ebc52bf6429
(Fmake_network_process): Remove kludge for interrupted
Kim F. Storm <storm@cua.dk>
parents:
57840
diff
changeset
|
3568 |
|
107546
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3569 #ifdef WINDOWSNT |
|
58072
4ebc52bf6429
(Fmake_network_process): Remove kludge for interrupted
Kim F. Storm <storm@cua.dk>
parents:
57840
diff
changeset
|
3570 if (xerrno == EINTR) |
|
4ebc52bf6429
(Fmake_network_process): Remove kludge for interrupted
Kim F. Storm <storm@cua.dk>
parents:
57840
diff
changeset
|
3571 goto retry_connect; |
|
107546
59e2de1eaab1
* process.c (Fmake_network_process): Don't apply Bug#5173 fix for Windows.
Chong Yidong <cyd@stupidchicken.com>
parents:
107545
diff
changeset
|
3572 #endif |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3573 } |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3574 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3575 if (s >= 0) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3576 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3577 #ifdef DATAGRAM_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3578 if (socktype == SOCK_DGRAM) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3579 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3580 if (datagram_address[s].sa) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3581 abort (); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3582 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
|
3583 datagram_address[s].len = lres->ai_addrlen; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3584 if (is_server) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3585 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3586 Lisp_Object remote; |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
3587 memset (datagram_address[s].sa, 0, lres->ai_addrlen); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3588 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
|
3589 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3590 int rfamily, rlen; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3591 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
|
3592 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
|
3593 conv_lisp_to_sockaddr (rfamily, remote, |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3594 datagram_address[s].sa, rlen); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3595 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3596 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3597 else |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
3598 memcpy (datagram_address[s].sa, lres->ai_addr, lres->ai_addrlen); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3599 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3600 #endif |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3601 contact = Fplist_put (contact, QCaddress, |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3602 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
|
3603 #ifdef HAVE_GETSOCKNAME |
|
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3604 if (!is_server) |
|
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3605 { |
|
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3606 struct sockaddr_in sa1; |
|
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3607 int len1 = sizeof (sa1); |
|
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3608 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
|
3609 contact = Fplist_put (contact, QClocal, |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
3610 conv_sockaddr_to_lisp ((struct sockaddr *)&sa1, len1)); |
|
49111
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3611 } |
|
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
3612 #endif |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3613 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3614 |
|
76626
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3615 immediate_quit = 0; |
|
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3616 |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3617 #ifdef HAVE_GETADDRINFO |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3618 if (res != &ai) |
|
76626
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3619 { |
|
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3620 BLOCK_INPUT; |
|
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3621 freeaddrinfo (res); |
|
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3622 UNBLOCK_INPUT; |
|
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3623 } |
|
2fb8fb4a9bab
(Fmake_network_process) [HAVE_GETADDRINFO]: Clear
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
76494
diff
changeset
|
3624 #endif |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3625 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3626 /* 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
|
3627 specpdl_ptr = specpdl + count1; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3628 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3629 /* Unwind bind_polling_period and request_sigio. */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3630 unbind_to (count, Qnil); |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3631 |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3632 if (s < 0) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3633 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3634 /* 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
|
3635 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
|
3636 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
|
3637 better. */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3638 if (is_non_blocking_client) |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3639 return Qnil; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3640 |
| 578 | 3641 errno = xerrno; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3642 if (is_server) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3643 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
|
3644 else |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3645 report_file_error ("make client process failed", contact); |
| 578 | 3646 } |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3647 |
| 578 | 3648 inch = s; |
|
17247
351006378b51
(Fopen_network_stream): Use same socket for in and out.
Richard M. Stallman <rms@gnu.org>
parents:
17224
diff
changeset
|
3649 outch = s; |
| 578 | 3650 |
| 3651 if (!NILP (buffer)) | |
| 3652 buffer = Fget_buffer_create (buffer); | |
| 3653 proc = make_process (name); | |
| 3654 | |
| 3655 chan_process[inch] = proc; | |
| 3656 | |
| 3657 #ifdef O_NONBLOCK | |
| 3658 fcntl (inch, F_SETFL, O_NONBLOCK); | |
| 3659 #else | |
| 3660 #ifdef O_NDELAY | |
| 3661 fcntl (inch, F_SETFL, O_NDELAY); | |
| 3662 #endif | |
| 3663 #endif | |
| 3664 | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3665 p = XPROCESS (proc); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3666 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3667 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
|
3668 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
|
3669 p->type = Qnetwork; |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
3670 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3671 p->buffer = buffer; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3672 p->sentinel = sentinel; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3673 p->filter = filter; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3674 p->log = Fplist_get (contact, QClog); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3675 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
|
3676 p->kill_without_query = 1; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3677 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
|
3678 p->command = Qt; |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
3679 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
|
3680 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
|
3681 p->outfd = outch; |
|
106398
31424b91531a
(Fmake_network_process): Fix up the tests for
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106397
diff
changeset
|
3682 if (is_server && socktype != SOCK_DGRAM) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3683 p->status = Qlisten; |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3684 |
|
69151
08c9c1760e1c
(Fmake_network_process): Init the process's mark.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68651
diff
changeset
|
3685 /* 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
|
3686 if (BUFFERP (buffer)) |
|
08c9c1760e1c
(Fmake_network_process): Init the process's mark.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68651
diff
changeset
|
3687 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
|
3688 BUF_ZV (XBUFFER (buffer)), |
|
08c9c1760e1c
(Fmake_network_process): Init the process's mark.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68651
diff
changeset
|
3689 BUF_ZV_BYTE (XBUFFER (buffer))); |
|
08c9c1760e1c
(Fmake_network_process): Init the process's mark.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
68651
diff
changeset
|
3690 |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3691 #ifdef NON_BLOCKING_CONNECT |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3692 if (is_non_blocking_client) |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3693 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3694 /* 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
|
3695 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
|
3696 connection. */ |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3697 p->status = Qconnect; |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3698 if (!FD_ISSET (inch, &connect_wait_mask)) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3699 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3700 FD_SET (inch, &connect_wait_mask); |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
3701 FD_SET (inch, &write_mask); |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3702 num_pending_connects++; |
|
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 } |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3705 else |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3706 #endif |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3707 /* 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
|
3708 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
|
3709 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
|
3710 || (EQ (p->status, Qlisten) && NILP (p->command))) |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3711 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3712 FD_SET (inch, &input_wait_mask); |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3713 FD_SET (inch, &non_keyboard_wait_mask); |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3714 } |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
3715 |
|
7044
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
3716 if (inch > max_process_desc) |
|
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
3717 max_process_desc = inch; |
| 578 | 3718 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3719 tem = Fplist_member (contact, QCcoding); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3720 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
|
3721 tem = Qnil; /* No error message (too late!). */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3722 |
|
22019
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3723 { |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3724 /* 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
|
3725 struct gcpro gcpro1; |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3726 /* 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
|
3727 Lisp_Object coding_systems = Qt; |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3728 Lisp_Object args[5], val; |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3729 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3730 if (!NILP (tem)) |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3731 { |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3732 val = XCAR (XCDR (tem)); |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3733 if (CONSP (val)) |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3734 val = XCAR (val); |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3735 } |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3736 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
|
3737 val = Vcoding_system_for_read; |
|
25770
3a44b5298cd5
(list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents:
25760
diff
changeset
|
3738 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
|
3739 || (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
|
3740 /* 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
|
3741 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
|
3742 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
|
3743 CR LF. */ |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3744 val = Qnil; |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3745 else |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3746 { |
|
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3747 if (NILP (host) || NILP (service)) |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3748 coding_systems = Qnil; |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3749 else |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3750 { |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3751 args[0] = Qopen_network_stream, args[1] = name, |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3752 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
|
3753 GCPRO1 (proc); |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3754 coding_systems = Ffind_operation_coding_system (5, args); |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3755 UNGCPRO; |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3756 } |
|
22019
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3757 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
|
3758 val = XCAR (coding_systems); |
|
22019
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3759 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
|
3760 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
|
3761 else |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3762 val = Qnil; |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3763 } |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3764 p->decode_coding_system = val; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3765 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3766 if (!NILP (tem)) |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3767 { |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3768 val = XCAR (XCDR (tem)); |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3769 if (CONSP (val)) |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3770 val = XCDR (val); |
|
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3771 } |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3772 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
|
3773 val = Vcoding_system_for_write; |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3774 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
|
3775 val = Qnil; |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3776 else |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3777 { |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3778 if (EQ (coding_systems, Qt)) |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3779 { |
|
47987
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3780 if (NILP (host) || NILP (service)) |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3781 coding_systems = Qnil; |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3782 else |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3783 { |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3784 args[0] = Qopen_network_stream, args[1] = name, |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3785 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
|
3786 GCPRO1 (proc); |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3787 coding_systems = Ffind_operation_coding_system (5, args); |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3788 UNGCPRO; |
|
b30942bd85f3
(Fformat_network_address): New function.
Kim F. Storm <storm@cua.dk>
parents:
47542
diff
changeset
|
3789 } |
|
22019
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3790 } |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3791 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
|
3792 val = XCDR (coding_systems); |
|
22019
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3793 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
|
3794 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
|
3795 else |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3796 val = Qnil; |
|
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3797 } |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3798 p->encode_coding_system = val; |
|
22019
bb9dd4758e7e
(Fstart_process): Remove the special case for
Richard M. Stallman <rms@gnu.org>
parents:
21978
diff
changeset
|
3799 } |
|
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
3800 setup_process_coding_systems (proc); |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
3801 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3802 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
|
3803 p->decoding_carryover = 0; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3804 p->encoding_buf = make_uninit_string (0); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3805 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
3806 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
|
3807 = !(!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
|
3808 |
| 578 | 3809 UNGCPRO; |
| 3810 return proc; | |
| 3811 } | |
| 3812 | |
|
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3813 |
| 109640 | 3814 #if 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
|
3815 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3816 #ifdef SIOCGIFCONF |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3817 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
|
3818 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
|
3819 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
|
3820 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
|
3821 format; see the description of ADDRESS in `make-network-process'. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
3822 (void) |
|
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3823 { |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3824 struct ifconf ifconf; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3825 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
|
3826 int ifaces = 0; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3827 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
|
3828 Lisp_Object res; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3829 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3830 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
|
3831 if (s < 0) |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3832 return Qnil; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3833 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3834 again: |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3835 ifaces += 25; |
|
109160
f8660b83cdbf
Fix whitespace to follow coding guidelines.
Juanma Barranquero <lekktu@gmail.com>
parents:
109145
diff
changeset
|
3836 buf_size = ifaces * sizeof (ifreqs[0]); |
|
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3837 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
|
3838 if (!ifreqs) |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3839 { |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3840 close (s); |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3841 return Qnil; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3842 } |
|
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 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
|
3845 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
|
3846 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
|
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 return Qnil; |
|
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 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3852 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
|
3853 goto again; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3854 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3855 close (s); |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3856 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
|
3857 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3858 res = Qnil; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3859 while (--ifaces >= 0) |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3860 { |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3861 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
|
3862 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
|
3863 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
|
3864 continue; |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
3865 memcpy (namebuf, ifq->ifr_name, sizeof (ifq->ifr_name)); |
|
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3866 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
|
3867 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
|
3868 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
|
3869 sizeof (struct sockaddr))), |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3870 res); |
|
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 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3873 return res; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3874 } |
|
52525
fd2be6cea0e7
(Fnetwork_interface_list, Fnetwork_interface_info):
Kim F. Storm <storm@cua.dk>
parents:
52516
diff
changeset
|
3875 #endif /* SIOCGIFCONF */ |
|
52503
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 #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
|
3878 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3879 struct ifflag_def { |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3880 int flag_bit; |
|
105959
ba3ffbd9c422
* process.c (ifflag_def): Make flag_sym constant.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105936
diff
changeset
|
3881 const char *flag_sym; |
|
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3882 }; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3883 |
|
105959
ba3ffbd9c422
* process.c (ifflag_def): Make flag_sym constant.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105936
diff
changeset
|
3884 static const struct ifflag_def ifflag_table[] = { |
|
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3885 #ifdef IFF_UP |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3886 { IFF_UP, "up" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3887 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3888 #ifdef IFF_BROADCAST |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3889 { IFF_BROADCAST, "broadcast" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3890 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3891 #ifdef IFF_DEBUG |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3892 { IFF_DEBUG, "debug" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3893 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3894 #ifdef IFF_LOOPBACK |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3895 { IFF_LOOPBACK, "loopback" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3896 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3897 #ifdef IFF_POINTOPOINT |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3898 { IFF_POINTOPOINT, "pointopoint" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3899 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3900 #ifdef IFF_RUNNING |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3901 { IFF_RUNNING, "running" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3902 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3903 #ifdef IFF_NOARP |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3904 { IFF_NOARP, "noarp" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3905 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3906 #ifdef IFF_PROMISC |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3907 { IFF_PROMISC, "promisc" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3908 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3909 #ifdef IFF_NOTRAILERS |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3910 { IFF_NOTRAILERS, "notrailers" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3911 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3912 #ifdef IFF_ALLMULTI |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3913 { IFF_ALLMULTI, "allmulti" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3914 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3915 #ifdef IFF_MASTER |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3916 { IFF_MASTER, "master" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3917 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3918 #ifdef IFF_SLAVE |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3919 { IFF_SLAVE, "slave" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3920 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3921 #ifdef IFF_MULTICAST |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3922 { IFF_MULTICAST, "multicast" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3923 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3924 #ifdef IFF_PORTSEL |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3925 { IFF_PORTSEL, "portsel" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3926 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3927 #ifdef IFF_AUTOMEDIA |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3928 { IFF_AUTOMEDIA, "automedia" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3929 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3930 #ifdef IFF_DYNAMIC |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3931 { IFF_DYNAMIC, "dynamic" }, |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3932 #endif |
|
68146
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
3933 #ifdef IFF_OACTIVE |
|
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
3934 { IFF_OACTIVE, "oactive" }, /* OpenBSD: transmission in progress */ |
| 68008 | 3935 #endif |
| 3936 #ifdef IFF_SIMPLEX | |
| 3937 { IFF_SIMPLEX, "simplex" }, /* OpenBSD: can't hear own transmissions */ | |
| 3938 #endif | |
| 3939 #ifdef IFF_LINK0 | |
| 3940 { IFF_LINK0, "link0" }, /* OpenBSD: per link layer defined bit */ | |
| 3941 #endif | |
| 3942 #ifdef IFF_LINK1 | |
| 3943 { IFF_LINK1, "link1" }, /* OpenBSD: per link layer defined bit */ | |
| 3944 #endif | |
| 3945 #ifdef IFF_LINK2 | |
| 3946 { IFF_LINK2, "link2" }, /* OpenBSD: per link layer defined bit */ | |
| 3947 #endif | |
|
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3948 { 0, 0 } |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3949 }; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3950 |
|
52516
0ca23eb697b9
(Fset_process_sentinel): Add sentinel to childp plist
Kim F. Storm <storm@cua.dk>
parents:
52503
diff
changeset
|
3951 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
|
3952 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
|
3953 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
|
3954 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
|
3955 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
|
3956 FLAGS is the current flags of the interface. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
3957 (Lisp_Object ifname) |
|
52503
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 struct ifreq rq; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3960 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
|
3961 Lisp_Object elt; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3962 int s; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3963 int any = 0; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3964 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3965 CHECK_STRING (ifname); |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3966 |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
3967 memset (rq.ifr_name, 0, sizeof rq.ifr_name); |
|
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3968 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
|
3969 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3970 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
|
3971 if (s < 0) |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3972 return Qnil; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3973 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3974 elt = Qnil; |
| 52591 | 3975 #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
|
3976 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
|
3977 { |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3978 int flags = rq.ifr_flags; |
|
105959
ba3ffbd9c422
* process.c (ifflag_def): Make flag_sym constant.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105936
diff
changeset
|
3979 const struct ifflag_def *fp; |
|
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3980 int fnum; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3981 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3982 any++; |
|
67920
8f3c10fea90b
(Fnetwork_interface_info): Correctly terminate the
Andreas Schwab <schwab@suse.de>
parents:
66752
diff
changeset
|
3983 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
|
3984 { |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3985 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
|
3986 { |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3987 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
|
3988 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
|
3989 } |
|
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 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
|
3992 { |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3993 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
|
3994 { |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3995 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
|
3996 } |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3997 } |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3998 } |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
3999 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4000 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
|
4001 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4002 elt = Qnil; |
| 52591 | 4003 #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
|
4004 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
|
4005 { |
|
52525
fd2be6cea0e7
(Fnetwork_interface_list, Fnetwork_interface_info):
Kim F. Storm <storm@cua.dk>
parents:
52516
diff
changeset
|
4006 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
|
4007 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
|
4008 int n; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4009 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4010 any++; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4011 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
|
4012 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
|
4013 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
|
4014 } |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4015 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4016 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
|
4017 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4018 elt = Qnil; |
|
68146
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
4019 #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
|
4020 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
|
4021 { |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4022 any++; |
|
68146
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
4023 #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
|
4024 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
|
4025 #else |
|
e5c85a134e67
[HAVE_INTTYPES_H]: Include inttypes.h.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
68041
diff
changeset
|
4026 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
|
4027 #endif |
|
52503
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4028 } |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4029 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4030 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
|
4031 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4032 elt = Qnil; |
| 52591 | 4033 #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
|
4034 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
|
4035 { |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4036 any++; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4037 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
|
4038 } |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4039 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4040 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
|
4041 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4042 elt = Qnil; |
| 52591 | 4043 #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
|
4044 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
|
4045 { |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4046 any++; |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4047 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
|
4048 } |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4049 #endif |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4050 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
|
4051 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4052 close (s); |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4053 |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4054 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
|
4055 } |
|
256a27a47af1
[HAVE_SOCKETS]: Include sys/ioctl.h and net/if.h.
Kim F. Storm <storm@cua.dk>
parents:
52401
diff
changeset
|
4056 #endif |
| 109640 | 4057 #endif /* 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
|
4058 |
| 56092 | 4059 /* Turn off input and output for process PROC. */ |
| 4060 | |
|
20382
dbad9367d232
(create_process, deactivate_process, close_process_descs):
Andreas Schwab <schwab@suse.de>
parents:
20225
diff
changeset
|
4061 void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
4062 deactivate_process (Lisp_Object proc) |
| 578 | 4063 { |
| 4064 register int inchannel, outchannel; | |
| 4065 register struct Lisp_Process *p = XPROCESS (proc); | |
| 4066 | |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4067 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
|
4068 outchannel = p->outfd; |
|
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4069 |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4070 #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
|
4071 if (p->read_output_delay > 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 if (--process_output_delay_count < 0) |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4074 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
|
4075 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
|
4076 p->read_output_skip = 0; |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4077 } |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4078 #endif |
|
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
4079 |
|
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4080 if (inchannel >= 0) |
| 578 | 4081 { |
| 4082 /* Beware SIGCHLD hereabouts. */ | |
| 4083 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
|
4084 emacs_close (inchannel); |
|
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4085 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
|
4086 emacs_close (outchannel); |
| 578 | 4087 |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4088 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
|
4089 p->outfd = -1; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4090 #ifdef DATAGRAM_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4091 if (DATAGRAM_CHAN_P (inchannel)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4092 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4093 xfree (datagram_address[inchannel].sa); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4094 datagram_address[inchannel].sa = 0; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4095 datagram_address[inchannel].len = 0; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4096 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4097 #endif |
| 578 | 4098 chan_process[inchannel] = Qnil; |
| 4099 FD_CLR (inchannel, &input_wait_mask); | |
|
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
4100 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
|
4101 #ifdef NON_BLOCKING_CONNECT |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4102 if (FD_ISSET (inchannel, &connect_wait_mask)) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4103 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4104 FD_CLR (inchannel, &connect_wait_mask); |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4105 FD_CLR (inchannel, &write_mask); |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4106 if (--num_pending_connects < 0) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4107 abort (); |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4108 } |
|
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4109 #endif |
|
7044
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4110 if (inchannel == max_process_desc) |
|
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4111 { |
|
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4112 int i; |
|
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4113 /* 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
|
4114 so recompute the highest-numbered one now. */ |
|
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4115 max_process_desc = 0; |
|
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4116 for (i = 0; i < MAXDESC; i++) |
|
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4117 if (!NILP (chan_process[i])) |
|
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4118 max_process_desc = i; |
|
7032d07f5ad9
(max_process_desc): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
7013
diff
changeset
|
4119 } |
| 578 | 4120 } |
| 4121 } | |
| 4122 | |
| 4123 | |
| 4124 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
|
4125 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
|
4126 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
|
4127 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
|
4128 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
|
4129 from PROCESS. |
|
69634
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4130 |
|
98456
a68b7a895cb6
(Faccept_process_output): Fix doc-string.
Martin Rudalics <rudalics@gmx.at>
parents:
98248
diff
changeset
|
4131 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
|
4132 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
|
4133 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
|
4134 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
|
4135 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
|
4136 |
|
56701
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4137 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
|
4138 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
|
4139 If JUST-THIS-ONE is an integer, don't run any timers either. |
| 78501 | 4140 Return non-nil if we received any output before the timeout expired. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
4141 (register Lisp_Object process, Lisp_Object seconds, Lisp_Object millisec, Lisp_Object just_this_one) |
| 578 | 4142 { |
|
69634
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4143 int secs, usecs = 0; |
| 578 | 4144 |
|
24598
078d53377010
(Faccept_process_output): Check validity of PROCESS.
Richard M. Stallman <rms@gnu.org>
parents:
24352
diff
changeset
|
4145 if (! NILP (process)) |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
4146 CHECK_PROCESS (process); |
|
56701
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4147 else |
|
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4148 just_this_one = Qnil; |
|
24598
078d53377010
(Faccept_process_output): Check validity of PROCESS.
Richard M. Stallman <rms@gnu.org>
parents:
24352
diff
changeset
|
4149 |
|
95387
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4150 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
|
4151 { /* 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
|
4152 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
|
4153 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
|
4154 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
|
4155 else |
|
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4156 { |
|
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4157 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
|
4158 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
|
4159 } |
|
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4160 } |
|
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4161 |
|
69634
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4162 if (!NILP (seconds)) |
| 578 | 4163 { |
|
69634
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4164 if (INTEGERP (seconds)) |
|
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4165 secs = XINT (seconds); |
|
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4166 else if (FLOATP (seconds)) |
|
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4167 { |
|
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4168 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
|
4169 secs = (int) timeout; |
|
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4170 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
|
4171 } |
|
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4172 else |
|
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4173 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
|
4174 |
|
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4175 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
|
4176 secs = -1, usecs = 0; |
| 578 | 4177 } |
|
1180
9bf82484415d
(Faccept_process_output): Initialize useconds.
Richard M. Stallman <rms@gnu.org>
parents:
1047
diff
changeset
|
4178 else |
|
69634
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4179 secs = NILP (process) ? -1 : 0; |
| 578 | 4180 |
| 4181 return | |
|
69634
5633a1931272
(Faccept_process_output): Fix to comply with lisp reference.
Kim F. Storm <storm@cua.dk>
parents:
69376
diff
changeset
|
4182 (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
|
4183 Qnil, |
|
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
4184 !NILP (process) ? XPROCESS (process) : NULL, |
|
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
4185 NILP (just_this_one) ? 0 : |
|
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
4186 !INTEGERP (just_this_one) ? 1 : -1) |
| 578 | 4187 ? Qt : Qnil); |
| 4188 } | |
| 4189 | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4190 /* 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
|
4191 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4192 static int connect_counter = 0; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4193 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4194 static void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
4195 server_accept_connection (Lisp_Object server, int channel) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4196 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4197 Lisp_Object proc, caller, name, buffer; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4198 Lisp_Object contact, host, service; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4199 struct Lisp_Process *ps= XPROCESS (server); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4200 struct Lisp_Process *p; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4201 int s; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4202 union u_sockaddr { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4203 struct sockaddr sa; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4204 struct sockaddr_in in; |
| 68008 | 4205 #ifdef AF_INET6 |
| 4206 struct sockaddr_in6 in6; | |
| 4207 #endif | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4208 #ifdef HAVE_LOCAL_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4209 struct sockaddr_un un; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4210 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4211 } saddr; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4212 int len = sizeof saddr; |
|
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 s = accept (channel, &saddr.sa, &len); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4215 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4216 if (s < 0) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4217 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4218 int code = errno; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4219 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4220 if (code == EAGAIN) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4221 return; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4222 #ifdef EWOULDBLOCK |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4223 if (code == EWOULDBLOCK) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4224 return; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4225 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4226 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4227 if (!NILP (ps->log)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4228 call3 (ps->log, server, Qnil, |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4229 concat3 (build_string ("accept failed with code"), |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4230 Fnumber_to_string (make_number (code)), |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4231 build_string ("\n"))); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4232 return; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4233 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4234 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4235 connect_counter++; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4236 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4237 /* 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
|
4238 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4239 /* 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
|
4240 information for this process. */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4241 host = Qt; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4242 service = Qnil; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4243 switch (saddr.sa.sa_family) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4244 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4245 case AF_INET: |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4246 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4247 Lisp_Object args[5]; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4248 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
|
4249 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
|
4250 args[1] = make_number (*ip++); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4251 args[2] = make_number (*ip++); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4252 args[3] = make_number (*ip++); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4253 args[4] = make_number (*ip++); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4254 host = Fformat (5, args); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4255 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
|
4256 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4257 args[0] = build_string (" <%s:%d>"); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4258 args[1] = host; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4259 args[2] = service; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4260 caller = Fformat (3, args); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4261 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4262 break; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4263 |
| 68008 | 4264 #ifdef AF_INET6 |
| 4265 case AF_INET6: | |
| 4266 { | |
| 4267 Lisp_Object args[9]; | |
| 4268 uint16_t *ip6 = (uint16_t *)&saddr.in6.sin6_addr; | |
| 4269 int i; | |
| 4270 args[0] = build_string ("%x:%x:%x:%x:%x:%x:%x:%x"); | |
| 4271 for (i = 0; i < 8; i++) | |
|
109160
f8660b83cdbf
Fix whitespace to follow coding guidelines.
Juanma Barranquero <lekktu@gmail.com>
parents:
109145
diff
changeset
|
4272 args[i+1] = make_number (ntohs (ip6[i])); |
| 68008 | 4273 host = Fformat (9, args); |
| 4274 service = make_number (ntohs (saddr.in.sin_port)); | |
| 4275 | |
| 4276 args[0] = build_string (" <[%s]:%d>"); | |
| 4277 args[1] = host; | |
| 4278 args[2] = service; | |
| 4279 caller = Fformat (3, args); | |
| 4280 } | |
| 4281 break; | |
| 4282 #endif | |
| 4283 | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4284 #ifdef HAVE_LOCAL_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4285 case AF_LOCAL: |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4286 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4287 default: |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4288 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
|
4289 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
|
4290 break; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4291 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4292 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4293 /* 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
|
4294 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
|
4295 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
|
4296 identification. */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4297 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4298 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
|
4299 buffer = Qnil; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4300 else |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4301 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4302 buffer = ps->buffer; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4303 if (!NILP (buffer)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4304 buffer = Fbuffer_name (buffer); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4305 else |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4306 buffer = ps->name; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4307 if (!NILP (buffer)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4308 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4309 buffer = concat2 (buffer, caller); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4310 buffer = Fget_buffer_create (buffer); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4311 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4312 } |
|
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 /* 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
|
4315 server process name with the caller identification. */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4316 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4317 name = concat2 (ps->name, caller); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4318 proc = make_process (name); |
|
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 chan_process[s] = proc; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4321 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4322 #ifdef O_NONBLOCK |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4323 fcntl (s, F_SETFL, O_NONBLOCK); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4324 #else |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4325 #ifdef O_NDELAY |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4326 fcntl (s, F_SETFL, O_NDELAY); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4327 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4328 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4329 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4330 p = XPROCESS (proc); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4331 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4332 /* Build new contact information for this setup. */ |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4333 contact = Fcopy_sequence (ps->childp); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4334 contact = Fplist_put (contact, QCserver, Qnil); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4335 contact = Fplist_put (contact, QChost, host); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4336 if (!NILP (service)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4337 contact = Fplist_put (contact, QCservice, service); |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4338 contact = Fplist_put (contact, QCremote, |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4339 conv_sockaddr_to_lisp (&saddr.sa, len)); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4340 #ifdef HAVE_GETSOCKNAME |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4341 len = sizeof saddr; |
|
49111
32c767302a23
(server_accept_connection): Fixed recording of new
Kim F. Storm <storm@cua.dk>
parents:
48424
diff
changeset
|
4342 if (getsockname (s, &saddr.sa, &len) == 0) |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4343 contact = Fplist_put (contact, QClocal, |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4344 conv_sockaddr_to_lisp (&saddr.sa, len)); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4345 #endif |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4346 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4347 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
|
4348 p->plist = Fcopy_sequence (ps->plist); |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
4349 p->type = Qnetwork; |
| 49164 | 4350 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4351 p->buffer = buffer; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4352 p->sentinel = ps->sentinel; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4353 p->filter = ps->filter; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4354 p->command = Qnil; |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
4355 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
|
4356 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
|
4357 p->outfd = s; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4358 p->status = Qrun; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4359 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4360 /* 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
|
4361 if (!EQ (p->filter, Qt)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4362 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4363 FD_SET (s, &input_wait_mask); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4364 FD_SET (s, &non_keyboard_wait_mask); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4365 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4366 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4367 if (s > max_process_desc) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4368 max_process_desc = s; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4369 |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4370 /* 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
|
4371 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
|
4372 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
|
4373 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
|
4374 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4375 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
|
4376 p->encode_coding_system = ps->encode_coding_system; |
|
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
4377 setup_process_coding_systems (proc); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4378 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4379 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
|
4380 p->decoding_carryover = 0; |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4381 p->encoding_buf = make_uninit_string (0); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4382 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4383 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
|
4384 = (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
|
4385 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4386 if (!NILP (ps->log)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4387 call3 (ps->log, server, proc, |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4388 concat3 (build_string ("accept from "), |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4389 (STRINGP (host) ? host : build_string ("-")), |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4390 build_string ("\n"))); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4391 |
|
44314
f76a1425eb34
(DATAGRAM_CONN_P, list_processes_1)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44194
diff
changeset
|
4392 if (!NILP (p->sentinel)) |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4393 exec_sentinel (proc, |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4394 concat3 (build_string ("open from "), |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4395 (STRINGP (host) ? host : build_string ("-")), |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4396 build_string ("\n"))); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4397 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4398 |
| 578 | 4399 /* This variable is different from waiting_for_input in keyboard.c. |
| 4400 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
|
4401 function Fwaiting_for_user_input_p below) whether Emacs was waiting |
| 578 | 4402 for user-input when that process-filter was called. |
| 4403 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
|
4404 lisp code is being evalled. |
|
dd3dfde8f973
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
8390
diff
changeset
|
4405 This is also used in record_asynch_buffer_change. |
|
dd3dfde8f973
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
8390
diff
changeset
|
4406 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
|
4407 when not inside wait_reading_process_output. */ |
| 578 | 4408 static int waiting_for_user_input_p; |
| 4409 | |
|
72277
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4410 static Lisp_Object |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
4411 wait_reading_process_output_unwind (Lisp_Object data) |
|
72277
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4412 { |
|
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4413 waiting_for_user_input_p = XINT (data); |
|
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4414 return Qnil; |
|
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4415 } |
|
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4416 |
|
14890
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4417 /* This is here so breakpoints can be put on it. */ |
| 21514 | 4418 static void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
4419 wait_reading_process_output_1 (void) |
|
14890
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4420 { |
|
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4421 } |
|
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4422 |
|
71109
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4423 /* Use a wrapper around select to work around a bug in gdb 5.3. |
|
106675
72ee8229ccc7
process.c: Fix typo in comment.
Juanma Barranquero <lekktu@gmail.com>
parents:
106398
diff
changeset
|
4424 Normally, the wrapper is optimized away by inlining. |
|
71109
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4425 |
|
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4426 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
|
4427 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
|
4428 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
|
4429 |
|
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4430 #ifndef select |
|
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4431 static INLINE int |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
4432 select_wrapper (int n, fd_set *rfd, fd_set *wfd, fd_set *xfd, struct timeval *tmo) |
|
71109
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4433 { |
|
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4434 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
|
4435 } |
|
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4436 #define select select_wrapper |
|
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4437 #endif |
|
8e0e27268c74
(select_wrapper): Add wrapper around select to work around
Kim F. Storm <storm@cua.dk>
parents:
70517
diff
changeset
|
4438 |
| 578 | 4439 /* Read and dispose of subprocess output while waiting for timeout to |
| 4440 elapse and/or keyboard input to be available. | |
| 4441 | |
|
3953
d0c23febc08c
(wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents:
3915
diff
changeset
|
4442 TIME_LIMIT is: |
| 578 | 4443 timeout in seconds, or |
| 4444 zero for no limit, or | |
| 4445 -1 means gobble data immediately available but don't wait for any. | |
| 4446 | |
|
3953
d0c23febc08c
(wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents:
3915
diff
changeset
|
4447 MICROSECS is: |
|
d0c23febc08c
(wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents:
3915
diff
changeset
|
4448 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
|
4449 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
|
4450 consists of MICROSECS only. |
|
d0c23febc08c
(wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents:
3915
diff
changeset
|
4451 |
|
d0c23febc08c
(wait_reading_process_input): Do include the keyboard
Richard M. Stallman <rms@gnu.org>
parents:
3915
diff
changeset
|
4452 READ_KBD is a lisp value: |
| 578 | 4453 0 to ignore keyboard input, or |
| 4454 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
|
4455 -1 meaning caller will actually read the input, so don't throw to |
| 578 | 4456 the quit handler, or |
|
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4457 |
|
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4458 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
|
4459 output that arrives. |
| 578 | 4460 |
|
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4461 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
|
4462 (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
|
4463 |
|
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4464 If WAIT_PROC is specified, wait until something arrives from that |
| 78501 | 4465 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
|
4466 that process. |
|
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4467 |
|
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4468 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
|
4469 (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
|
4470 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
|
4471 |
| 78501 | 4472 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
|
4473 received input from that process before the timeout elapsed. |
| 78501 | 4474 Otherwise, return true if we received input from any process. */ |
| 578 | 4475 |
| 21514 | 4476 int |
|
109364
89a16701cde1
Convert old-style definitions
Andreas Schwab <schwab@linux-m68k.org>
parents:
109362
diff
changeset
|
4477 wait_reading_process_output (int time_limit, int microsecs, int read_kbd, |
|
89a16701cde1
Convert old-style definitions
Andreas Schwab <schwab@linux-m68k.org>
parents:
109362
diff
changeset
|
4478 int do_display, |
|
89a16701cde1
Convert old-style definitions
Andreas Schwab <schwab@linux-m68k.org>
parents:
109362
diff
changeset
|
4479 Lisp_Object wait_for_cell, |
|
89a16701cde1
Convert old-style definitions
Andreas Schwab <schwab@linux-m68k.org>
parents:
109362
diff
changeset
|
4480 struct Lisp_Process *wait_proc, int just_wait_proc) |
| 578 | 4481 { |
|
25770
3a44b5298cd5
(list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents:
25760
diff
changeset
|
4482 register int channel, nfds; |
|
55579
234873044c2a
(wait_reading_process_input): Make reentrant.
Kim F. Storm <storm@cua.dk>
parents:
55534
diff
changeset
|
4483 SELECT_TYPE Available; |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4484 SELECT_TYPE Writeok; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4485 int check_write; |
|
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4486 int check_delay, no_avail; |
| 578 | 4487 int xerrno; |
| 4488 Lisp_Object proc; | |
|
25770
3a44b5298cd5
(list_processes_1): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents:
25760
diff
changeset
|
4489 EMACS_TIME timeout, end_time; |
|
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4490 int wait_channel = -1; |
| 578 | 4491 int got_some_input = 0; |
|
72277
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4492 int count = SPECPDL_INDEX (); |
| 578 | 4493 |
| 4494 FD_ZERO (&Available); | |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4495 FD_ZERO (&Writeok); |
| 578 | 4496 |
|
110398
015a63c2574f
* process.c (wait_reading_process_output): Don't message about
Lars Magne Ingebrigtsen <larsi@gnus.org>
parents:
109949
diff
changeset
|
4497 if (time_limit == 0 && microsecs == 0 && wait_proc && !NILP (Vinhibit_quit) |
|
107846
e8ea73860300
Try to solve the problem of spurious EOF chars in long lines of text
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107842
diff
changeset
|
4498 && !(CONSP (wait_proc->status) && EQ (XCAR (wait_proc->status), Qexit))) |
|
e8ea73860300
Try to solve the problem of spurious EOF chars in long lines of text
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107842
diff
changeset
|
4499 message ("Blocking call to accept-process-output with quit inhibited!!"); |
| 578 | 4500 |
|
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4501 /* 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
|
4502 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
|
4503 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
|
4504 |
|
72277
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
4505 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
|
4506 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
|
4507 waiting_for_user_input_p = read_kbd; |
| 578 | 4508 |
| 4509 /* Since we may need to wait several times, | |
| 4510 compute the absolute time to return at. */ | |
| 4511 if (time_limit || microsecs) | |
| 4512 { | |
| 4513 EMACS_GET_TIME (end_time); | |
| 4514 EMACS_SET_SECS_USECS (timeout, time_limit, microsecs); | |
| 4515 EMACS_ADD_TIME (end_time, end_time, timeout); | |
| 4516 } | |
| 4517 | |
| 4518 while (1) | |
| 4519 { | |
|
14458
2bb4652305c1
(wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents:
14405
diff
changeset
|
4520 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
|
4521 |
| 578 | 4522 /* If calling from keyboard input, do not quit |
| 4523 since we want to return C-g as an input character. | |
| 4524 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
|
4525 if (read_kbd >= 0) |
| 578 | 4526 QUIT; |
|
53659
291acfb4bf40
(wait_reading_process_input) [SYNC_INPUT]: Check interrupt_input_pending.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53637
diff
changeset
|
4527 #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
|
4528 else |
|
101649
bd66da73ef9f
(wait_reading_process_output): Use process_pending_signals.
Chong Yidong <cyd@stupidchicken.com>
parents:
101276
diff
changeset
|
4529 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
|
4530 #endif |
| 578 | 4531 |
| 4639 | 4532 /* 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
|
4533 if (! NILP (wait_for_cell) && ! NILP (XCAR (wait_for_cell))) |
| 4639 | 4534 break; |
| 4535 | |
| 578 | 4536 /* Compute time from now till when time limit is up */ |
| 4537 /* Exit if already run out */ | |
| 4538 if (time_limit == -1) | |
| 4539 { | |
| 4540 /* -1 specified for timeout means | |
| 4541 gobble output available now | |
| 4542 but don't wait at all. */ | |
| 4543 | |
| 4544 EMACS_SET_SECS_USECS (timeout, 0, 0); | |
| 4545 } | |
| 4546 else if (time_limit || microsecs) | |
| 4547 { | |
| 4548 EMACS_GET_TIME (timeout); | |
| 4549 EMACS_SUB_TIME (timeout, end_time, timeout); | |
| 4550 if (EMACS_TIME_NEG_P (timeout)) | |
| 4551 break; | |
| 4552 } | |
| 4553 else | |
| 4554 { | |
| 4555 EMACS_SET_SECS_USECS (timeout, 100000, 0); | |
| 4556 } | |
| 4557 | |
|
15064
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4558 /* Normally we run timers here. |
|
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4559 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
|
4560 the wait is supposed to be short, |
|
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4561 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
|
4562 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
|
4563 && just_wait_proc >= 0) |
|
14404
cba05f90ee57
(wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents:
14278
diff
changeset
|
4564 { |
|
14458
2bb4652305c1
(wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents:
14405
diff
changeset
|
4565 EMACS_TIME timer_delay; |
|
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4566 |
|
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4567 do |
|
14890
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4568 { |
|
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4569 int old_timers_run = timers_run; |
|
37465
f790d83ea743
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
37413
diff
changeset
|
4570 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
|
4571 Lisp_Object old_window = selected_window; |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4572 |
|
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4573 timer_delay = timer_check (1); |
|
37398
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4574 |
|
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4575 /* 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
|
4576 an alike. Make read_key_sequence aware of that. */ |
|
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4577 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
|
4578 && (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
|
4579 || !EQ (old_window, selected_window)) |
|
37398
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4580 && waiting_for_user_input_p == -1) |
|
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4581 record_asynch_buffer_change (); |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4582 |
|
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4583 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
|
4584 /* 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
|
4585 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
|
4586 redisplay_preserve_echo_area (9); |
|
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4587 else |
|
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4588 break; |
|
14890
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4589 } |
|
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
4590 while (!detect_input_pending ()); |
|
14890
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4591 |
|
18230
2f1f942f25ca
(wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents:
18183
diff
changeset
|
4592 /* 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
|
4593 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
|
4594 && requeued_events_pending_p ()) |
|
2f1f942f25ca
(wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents:
18183
diff
changeset
|
4595 break; |
|
2f1f942f25ca
(wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents:
18183
diff
changeset
|
4596 |
|
14458
2bb4652305c1
(wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents:
14405
diff
changeset
|
4597 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
|
4598 { |
|
cba05f90ee57
(wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents:
14278
diff
changeset
|
4599 EMACS_TIME difference; |
|
cba05f90ee57
(wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents:
14278
diff
changeset
|
4600 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
|
4601 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
|
4602 { |
|
2bb4652305c1
(wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents:
14405
diff
changeset
|
4603 timeout = timer_delay; |
|
2bb4652305c1
(wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents:
14405
diff
changeset
|
4604 timeout_reduced_for_timers = 1; |
|
2bb4652305c1
(wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents:
14405
diff
changeset
|
4605 } |
|
14404
cba05f90ee57
(wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents:
14278
diff
changeset
|
4606 } |
|
14935
3e0dc64a5cb8
(wait_reading_process_input): Don't call
Richard M. Stallman <rms@gnu.org>
parents:
14890
diff
changeset
|
4607 /* 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
|
4608 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
|
4609 { |
|
71c2cf461805
(wait_reading_process_input_1): New (empty) function.
Richard M. Stallman <rms@gnu.org>
parents:
14863
diff
changeset
|
4610 /* 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
|
4611 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
|
4612 } |
|
14404
cba05f90ee57
(wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents:
14278
diff
changeset
|
4613 } |
|
cba05f90ee57
(wait_reading_process_input): Call timer_check
Richard M. Stallman <rms@gnu.org>
parents:
14278
diff
changeset
|
4614 |
|
2894
646c5beae647
* process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents:
2893
diff
changeset
|
4615 /* 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
|
4616 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
|
4617 |
|
646c5beae647
* process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents:
2893
diff
changeset
|
4618 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
|
4619 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
|
4620 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
|
4621 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
|
4622 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
|
4623 |
|
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
4624 /* 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
|
4625 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
|
4626 this explicit check, we'll let the SIGCHLD handler zap |
|
104316
bb8ce3c842e7
* process.c (status_notify): Don't perform redisplay.
Chong Yidong <cyd@stupidchicken.com>
parents:
104265
diff
changeset
|
4627 timeout to get our attention. */ |
|
bb8ce3c842e7
* process.c (status_notify): Don't perform redisplay.
Chong Yidong <cyd@stupidchicken.com>
parents:
104265
diff
changeset
|
4628 if (update_tick != process_tick) |
|
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
4629 { |
|
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4630 SELECT_TYPE Atemp; |
|
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4631 SELECT_TYPE Ctemp; |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4632 |
|
109164
a7b09b567d58
If kbd_buffer is becoming full, stop reading until it drains (Bug#6571).
Jan D <jan.h.d@swipnet.se>
parents:
109160
diff
changeset
|
4633 if (kbd_on_hold_p ()) |
|
a7b09b567d58
If kbd_buffer is becoming full, stop reading until it drains (Bug#6571).
Jan D <jan.h.d@swipnet.se>
parents:
109160
diff
changeset
|
4634 FD_ZERO (&Atemp); |
|
a7b09b567d58
If kbd_buffer is becoming full, stop reading until it drains (Bug#6571).
Jan D <jan.h.d@swipnet.se>
parents:
109160
diff
changeset
|
4635 else |
|
a7b09b567d58
If kbd_buffer is becoming full, stop reading until it drains (Bug#6571).
Jan D <jan.h.d@swipnet.se>
parents:
109160
diff
changeset
|
4636 Atemp = input_wait_mask; |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4637 Ctemp = write_mask; |
|
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4638 |
|
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
4639 EMACS_SET_SECS_USECS (timeout, 0, 0); |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4640 if ((select (max (max_process_desc, max_input_desc) + 1, |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4641 &Atemp, |
|
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4642 #ifdef NON_BLOCKING_CONNECT |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4643 (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
|
4644 #else |
|
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4645 (SELECT_TYPE *)0, |
|
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4646 #endif |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4647 (SELECT_TYPE *)0, &timeout) |
|
11926
40d7e6f04ebe
(create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents:
11845
diff
changeset
|
4648 <= 0)) |
|
2894
646c5beae647
* process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents:
2893
diff
changeset
|
4649 { |
|
646c5beae647
* process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents:
2893
diff
changeset
|
4650 /* It's okay for us to do this and then continue with |
| 5534 | 4651 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
|
4652 clear_waiting_for_input (); |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
4653 status_notify (NULL); |
|
104316
bb8ce3c842e7
* process.c (status_notify): Don't perform redisplay.
Chong Yidong <cyd@stupidchicken.com>
parents:
104265
diff
changeset
|
4654 if (do_display) redisplay_preserve_echo_area (13); |
|
2894
646c5beae647
* process.c (wait_reading_process_input): Undo change of April
Jim Blandy <jimb@redhat.com>
parents:
2893
diff
changeset
|
4655 } |
|
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
4656 } |
|
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
4657 |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4658 /* 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
|
4659 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
|
4660 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
|
4661 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
|
4662 if (wait_proc |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4663 && ! EQ (wait_proc->status, Qrun) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4664 && ! 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
|
4665 { |
|
18946
84b78d90cd45
(wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents:
18739
diff
changeset
|
4666 int nread, total_nread = 0; |
|
18267
29c37882ee1f
(wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents:
18230
diff
changeset
|
4667 |
|
2893
4df57953d5d0
* process.c (wait_reading_process_input): Don't forget to call
Jim Blandy <jimb@redhat.com>
parents:
2887
diff
changeset
|
4668 clear_waiting_for_input (); |
|
18267
29c37882ee1f
(wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents:
18230
diff
changeset
|
4669 XSETPROCESS (proc, wait_proc); |
|
29c37882ee1f
(wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents:
18230
diff
changeset
|
4670 |
|
29c37882ee1f
(wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents:
18230
diff
changeset
|
4671 /* 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
|
4672 while (wait_proc->infd >= 0) |
|
18946
84b78d90cd45
(wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents:
18739
diff
changeset
|
4673 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4674 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
|
4675 |
|
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4676 if (nread == 0) |
|
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4677 break; |
|
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4678 |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4679 if (0 < nread) |
|
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4680 { |
|
95387
be7d86474ead
(Faccept_process_output): If `millisec' is non-nil, `seconds' default to 0.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95216
diff
changeset
|
4681 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
|
4682 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
|
4683 } |
|
18946
84b78d90cd45
(wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents:
18739
diff
changeset
|
4684 #ifdef EIO |
|
84b78d90cd45
(wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents:
18739
diff
changeset
|
4685 else if (nread == -1 && EIO == errno) |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4686 break; |
|
18946
84b78d90cd45
(wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents:
18739
diff
changeset
|
4687 #endif |
|
25894
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4688 #ifdef EAGAIN |
|
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4689 else if (nread == -1 && EAGAIN == errno) |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4690 break; |
|
25894
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4691 #endif |
|
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4692 #ifdef EWOULDBLOCK |
|
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4693 else if (nread == -1 && EWOULDBLOCK == errno) |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4694 break; |
|
25894
8bd3e6fbf42f
(wait_reading_process_input): When trying to suck
Gerd Moellmann <gerd@gnu.org>
parents:
25770
diff
changeset
|
4695 #endif |
|
18946
84b78d90cd45
(wait_reading_process_input): Initialize total_read.
Richard M. Stallman <rms@gnu.org>
parents:
18739
diff
changeset
|
4696 } |
|
18267
29c37882ee1f
(wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents:
18230
diff
changeset
|
4697 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
|
4698 redisplay_preserve_echo_area (10); |
|
18267
29c37882ee1f
(wait_reading_process_input): When exiting because
Richard M. Stallman <rms@gnu.org>
parents:
18230
diff
changeset
|
4699 |
|
2893
4df57953d5d0
* process.c (wait_reading_process_input): Don't forget to call
Jim Blandy <jimb@redhat.com>
parents:
2887
diff
changeset
|
4700 break; |
|
4df57953d5d0
* process.c (wait_reading_process_input): Don't forget to call
Jim Blandy <jimb@redhat.com>
parents:
2887
diff
changeset
|
4701 } |
|
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
4702 |
| 578 | 4703 /* Wait till there is something to do */ |
| 4704 | |
|
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4705 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
|
4706 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
4707 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
|
4708 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
|
4709 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
|
4710 check_delay = 0; |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4711 check_write = 0; |
|
56701
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4712 } |
|
e327231e4361
(Faccept_process_output): Add arg JUST-THIS-ONE;
Kim F. Storm <storm@cua.dk>
parents:
56700
diff
changeset
|
4713 else if (!NILP (wait_for_cell)) |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4714 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4715 Available = non_process_wait_mask; |
|
57840
8abbe69dfdb2
(connect_wait_mask, num_pending_connects): Only
Kim F. Storm <storm@cua.dk>
parents:
57287
diff
changeset
|
4716 check_delay = 0; |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4717 check_write = 0; |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4718 } |
|
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
4719 else |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4720 { |
|
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4721 if (! read_kbd) |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4722 Available = non_keyboard_wait_mask; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4723 else |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4724 Available = input_wait_mask; |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4725 Writeok = write_mask; |
|
110594
76b6c21279ec
Don?t give write_mask to select for W32.
Jan D <jan.h.d@swipnet.se>
parents:
110593
diff
changeset
|
4726 #ifdef SELECT_CANT_DO_WRITE_MASK |
|
76b6c21279ec
Don?t give write_mask to select for W32.
Jan D <jan.h.d@swipnet.se>
parents:
110593
diff
changeset
|
4727 check_write = 0; |
|
76b6c21279ec
Don?t give write_mask to select for W32.
Jan D <jan.h.d@swipnet.se>
parents:
110593
diff
changeset
|
4728 #else |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4729 check_write = 1; |
|
110594
76b6c21279ec
Don?t give write_mask to select for W32.
Jan D <jan.h.d@swipnet.se>
parents:
110593
diff
changeset
|
4730 #endif |
|
53835
ad9da392f358
(wait_reading_process_input): Don't do adaptive read
Kim F. Storm <storm@cua.dk>
parents:
53732
diff
changeset
|
4731 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
|
4732 } |
| 578 | 4733 |
| 765 | 4734 /* If frame size has changed or the window is newly mapped, |
| 648 | 4735 redisplay now, before we start to wait. There is a race |
| 4736 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
|
4737 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
|
4738 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
|
4739 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
|
4740 { |
|
affed1766d34
(wait_reading_process_input): Don't call prepare_menu_bars.
Richard M. Stallman <rms@gnu.org>
parents:
11695
diff
changeset
|
4741 clear_waiting_for_input (); |
|
35336
002c02db42d3
Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents:
34660
diff
changeset
|
4742 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
|
4743 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
|
4744 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
|
4745 } |
| 648 | 4746 |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4747 no_avail = 0; |
|
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4748 if (read_kbd && detect_input_pending ()) |
|
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
4749 { |
|
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
4750 nfds = 0; |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4751 no_avail = 1; |
|
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
4752 } |
|
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
4753 else |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4754 { |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4755 |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4756 #ifdef ADAPTIVE_READ_BUFFERING |
|
63114
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
4757 /* 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
|
4758 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
|
4759 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
|
4760 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
|
4761 Vprocess_adaptive_read_buffering is nil. */ |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4762 if (process_output_skip && check_delay > 0) |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4763 { |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4764 int usecs = EMACS_USECS (timeout); |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4765 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
|
4766 usecs = READ_OUTPUT_DELAY_MAX; |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4767 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
|
4768 { |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4769 proc = chan_process[channel]; |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4770 if (NILP (proc)) |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4771 continue; |
|
63114
6ef9e44e50d7
Improve commentary for adaptive read buffering.
Kim F. Storm <storm@cua.dk>
parents:
62604
diff
changeset
|
4772 /* 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
|
4773 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
|
4774 if (XPROCESS (proc)->read_output_delay > 0) |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4775 { |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4776 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
|
4777 if (!XPROCESS (proc)->read_output_skip) |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4778 continue; |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4779 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
|
4780 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
|
4781 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
|
4782 usecs = XPROCESS (proc)->read_output_delay; |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4783 } |
|
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 EMACS_SET_SECS_USECS (timeout, 0, usecs); |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4786 process_output_skip = 0; |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4787 } |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
4788 #endif |
|
106186
9b6f45dd8386
Use a select wrapper around the GLib event loop, thus taking into account GLib
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
106185
diff
changeset
|
4789 #if defined (USE_GTK) || defined (HAVE_GCONF) |
|
9b6f45dd8386
Use a select wrapper around the GLib event loop, thus taking into account GLib
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
106185
diff
changeset
|
4790 nfds = xg_select |
|
9b6f45dd8386
Use a select wrapper around the GLib event loop, thus taking into account GLib
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
106185
diff
changeset
|
4791 #elif defined (HAVE_NS) |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4792 nfds = ns_select |
|
96675
d45acf0c8d23
merging Emacs.app (NeXTstep port)
Adrian Robert <Adrian.B.Robert@gmail.com>
parents:
96620
diff
changeset
|
4793 #else |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4794 nfds = select |
|
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
4795 #endif |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4796 (max (max_process_desc, max_input_desc) + 1, |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4797 &Available, |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4798 (check_write ? &Writeok : (SELECT_TYPE *)0), |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4799 (SELECT_TYPE *)0, &timeout); |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4800 } |
| 588 | 4801 |
| 578 | 4802 xerrno = errno; |
| 4803 | |
| 4804 /* Make C-g and alarm signals set flags again */ | |
| 4805 clear_waiting_for_input (); | |
| 4806 | |
| 4807 /* 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
|
4808 do_pending_window_change (0); |
| 578 | 4809 |
|
14458
2bb4652305c1
(wait_reading_process_input): If select times out,
Richard M. Stallman <rms@gnu.org>
parents:
14405
diff
changeset
|
4810 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
|
4811 /* We wanted the full specified time, so return now. */ |
| 578 | 4812 break; |
| 4813 if (nfds < 0) | |
| 4814 { | |
| 4815 if (xerrno == EINTR) | |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4816 no_avail = 1; |
| 578 | 4817 else if (xerrno == EBADF) |
| 4818 { | |
| 4819 #ifdef AIX | |
| 4820 /* AIX doesn't handle PTY closure the same way BSD does. On AIX, | |
| 4821 the child's closure of the pts gives the parent a SIGHUP, and | |
| 4822 the ptc file descriptor is automatically closed, | |
| 4823 yielding EBADF here or at select() call above. | |
| 4824 So, SIGHUP is ignored (see def of PTY_TTY_NAME_SPRINTF | |
| 5534 | 4825 in m/ibmrt-aix.h), and here we just ignore the select error. |
| 578 | 4826 Cleanup occurs c/o status_notify after SIGCLD. */ |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4827 no_avail = 1; /* Cannot depend on values returned */ |
| 578 | 4828 #else |
| 4829 abort (); | |
| 4830 #endif | |
| 4831 } | |
| 4832 else | |
|
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
4833 error ("select error: %s", emacs_strerror (xerrno)); |
| 578 | 4834 } |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4835 |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4836 if (no_avail) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4837 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4838 FD_ZERO (&Available); |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4839 check_write = 0; |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4840 } |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4841 |
|
18378
22cd8d7dd5aa
(wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents:
18329
diff
changeset
|
4842 #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
|
4843 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
|
4844 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
|
4845 /* 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
|
4846 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
|
4847 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
|
4848 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
|
4849 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
|
4850 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
|
4851 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
|
4852 && keyboard_bit_set (&Available) |
|
22cd8d7dd5aa
(wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents:
18329
diff
changeset
|
4853 && input_polling_used ()) |
|
22cd8d7dd5aa
(wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents:
18329
diff
changeset
|
4854 kill (getpid (), SIGALRM); |
|
22cd8d7dd5aa
(wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents:
18329
diff
changeset
|
4855 #endif |
|
22cd8d7dd5aa
(wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents:
18329
diff
changeset
|
4856 |
| 578 | 4857 /* Check for keyboard input */ |
| 4858 /* If there is any, return immediately | |
| 4859 to give it higher priority than subprocesses */ | |
| 4860 | |
|
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4861 if (read_kbd != 0) |
| 14613 | 4862 { |
|
37398
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4863 int old_timers_run = timers_run; |
|
37465
f790d83ea743
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
37413
diff
changeset
|
4864 struct buffer *old_buffer = current_buffer; |
|
79807
6292ea8947eb
Chong Yidong <cyd at stupidchicken.com>
Glenn Morris <rgm@gnu.org>
parents:
79759
diff
changeset
|
4865 Lisp_Object old_window = selected_window; |
|
37398
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4866 int leave = 0; |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4867 |
|
14758
849458c13c0c
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14736
diff
changeset
|
4868 if (detect_input_pending_run_timers (do_display)) |
|
37398
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4869 { |
|
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4870 swallow_events (do_display); |
|
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4871 if (detect_input_pending_run_timers (do_display)) |
|
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4872 leave = 1; |
|
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4873 } |
|
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4874 |
|
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4875 /* 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
|
4876 an alike. Make read_key_sequence aware of that. */ |
|
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4877 if (timers_run != old_timers_run |
|
37465
f790d83ea743
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
37413
diff
changeset
|
4878 && waiting_for_user_input_p == -1 |
|
79807
6292ea8947eb
Chong Yidong <cyd at stupidchicken.com>
Glenn Morris <rgm@gnu.org>
parents:
79759
diff
changeset
|
4879 && (old_buffer != current_buffer |
|
6292ea8947eb
Chong Yidong <cyd at stupidchicken.com>
Glenn Morris <rgm@gnu.org>
parents:
79759
diff
changeset
|
4880 || !EQ (old_window, selected_window))) |
|
37398
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4881 record_asynch_buffer_change (); |
|
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4882 |
|
756d2f4e4058
(wait_reading_process_input): Call
Gerd Moellmann <gerd@gnu.org>
parents:
36659
diff
changeset
|
4883 if (leave) |
| 14613 | 4884 break; |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4885 } |
|
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
4886 |
|
18230
2f1f942f25ca
(wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents:
18183
diff
changeset
|
4887 /* 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
|
4888 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
|
4889 && requeued_events_pending_p ()) |
|
2f1f942f25ca
(wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents:
18183
diff
changeset
|
4890 break; |
|
2f1f942f25ca
(wait_reading_process_input): Return if unread events appear.
Richard M. Stallman <rms@gnu.org>
parents:
18183
diff
changeset
|
4891 |
|
19053
7b5642657857
(read_process_output): Don't call setup_coding_system
Richard M. Stallman <rms@gnu.org>
parents:
18974
diff
changeset
|
4892 /* 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
|
4893 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
|
4894 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
|
4895 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
|
4896 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
|
4897 |
|
7b5642657857
(read_process_output): Don't call setup_coding_system
Richard M. Stallman <rms@gnu.org>
parents:
18974
diff
changeset
|
4898 (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
|
4899 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
|
4900 { |
|
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4901 swallow_events (do_display); |
|
18492
668304de6f92
(wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents:
18378
diff
changeset
|
4902 #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
|
4903 if (detect_input_pending ()) |
|
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4904 break; |
|
18492
668304de6f92
(wait_reading_process_input): If wait_for_cell,
Richard M. Stallman <rms@gnu.org>
parents:
18378
diff
changeset
|
4905 #endif |
|
15064
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4906 } |
|
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
4907 |
|
2200
5e58643bb169
(wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents:
2120
diff
changeset
|
4908 /* 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
|
4909 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
|
4910 break; |
|
5e58643bb169
(wait_reading_process_input): New option to wait
Richard M. Stallman <rms@gnu.org>
parents:
2120
diff
changeset
|
4911 |
| 621 | 4912 #ifdef SIGIO |
|
18378
22cd8d7dd5aa
(wait_reading_process_input): Don't check for
Richard M. Stallman <rms@gnu.org>
parents:
18329
diff
changeset
|
4913 /* If we think we have keyboard input waiting, but didn't get SIGIO, |
| 578 | 4914 go read it. This can happen with X on BSD after logging out. |
| 4915 In that case, there really is no input and no SIGIO, | |
| 4916 but select says there is input. */ | |
| 4917 | |
|
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
4918 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
|
4919 && 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
|
4920 kill (getpid (), SIGIO); |
| 621 | 4921 #endif |
| 578 | 4922 |
| 4923 if (! wait_proc) | |
| 4924 got_some_input |= nfds > 0; | |
| 4925 | |
| 624 | 4926 /* If checking input just got us a size-change event from X, |
| 4927 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
|
4928 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
|
4929 do_pending_window_change (0); |
| 624 | 4930 |
|
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4931 /* Check for data from a process. */ |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4932 if (no_avail || nfds == 0) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4933 continue; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
4934 |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4935 for (channel = 0; channel <= max_input_desc; ++channel) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4936 { |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4937 struct fd_callback_data *d = &fd_callback_info[channel]; |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4938 if (FD_ISSET (channel, &Available) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4939 && d->func != 0 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4940 && (d->condition & FOR_READ) != 0) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4941 d->func (channel, d->data, 1); |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4942 if (FD_ISSET (channel, &write_mask) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4943 && d->func != 0 |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4944 && (d->condition & FOR_WRITE) != 0) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4945 d->func (channel, d->data, 0); |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4946 } |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4947 |
|
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4948 /* Really FIRST_PROC_DESC should be 0 on Unix, |
|
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4949 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
|
4950 for (channel = 0; channel <= max_process_desc; channel++) |
| 578 | 4951 { |
|
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
4952 if (FD_ISSET (channel, &Available) |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4953 && FD_ISSET (channel, &non_keyboard_wait_mask) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
4954 && !FD_ISSET (channel, &non_process_wait_mask)) |
| 578 | 4955 { |
| 4956 int nread; | |
| 4957 | |
| 4958 /* If waiting for this channel, arrange to return as | |
| 4959 soon as no more input to be processed. No more | |
| 4960 waiting. */ | |
| 4961 if (wait_channel == channel) | |
| 4962 { | |
|
5134
0a4e46e15304
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
4998
diff
changeset
|
4963 wait_channel = -1; |
| 578 | 4964 time_limit = -1; |
| 4965 got_some_input = 1; | |
| 4966 } | |
| 4967 proc = chan_process[channel]; | |
| 4968 if (NILP (proc)) | |
| 4969 continue; | |
| 4970 | |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4971 /* 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
|
4972 if (EQ (XPROCESS (proc)->status, Qlisten)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4973 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4974 server_accept_connection (proc, channel); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4975 continue; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4976 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
4977 |
| 578 | 4978 /* Read data from the process, starting with our |
| 4979 buffered-ahead character if we have one. */ | |
| 4980 | |
| 4981 nread = read_process_output (proc, channel); | |
| 4982 if (nread > 0) | |
| 4983 { | |
| 4984 /* Since read_process_output can run a filter, | |
| 4985 which can call accept-process-output, | |
| 4986 don't try to read from any other processes | |
| 4987 before doing the select again. */ | |
| 4988 FD_ZERO (&Available); | |
| 4989 | |
| 4990 if (do_display) | |
|
35336
002c02db42d3
Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents:
34660
diff
changeset
|
4991 redisplay_preserve_echo_area (12); |
| 578 | 4992 } |
| 4993 #ifdef EWOULDBLOCK | |
| 4994 else if (nread == -1 && errno == EWOULDBLOCK) | |
| 4995 ; | |
|
15405
c27bb6e69e2d
(wait_reading_process_input): Move the O_NONBLOCK and
Richard M. Stallman <rms@gnu.org>
parents:
15368
diff
changeset
|
4996 #endif |
| 15406 | 4997 /* ISC 4.1 defines both EWOULDBLOCK and O_NONBLOCK, |
| 4998 and Emacs uses O_NONBLOCK, so what we get is EAGAIN. */ | |
| 578 | 4999 #ifdef O_NONBLOCK |
| 5000 else if (nread == -1 && errno == EAGAIN) | |
| 5001 ; | |
| 5002 #else | |
| 5003 #ifdef O_NDELAY | |
| 5004 else if (nread == -1 && errno == EAGAIN) | |
| 5005 ; | |
| 5006 /* Note that we cannot distinguish between no input | |
| 5007 available now and a closed pipe. | |
| 5008 With luck, a closed pipe will be accompanied by | |
| 5009 subprocess termination and SIGCHLD. */ | |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
5010 else if (nread == 0 && !NETCONN_P (proc) && !SERIALCONN_P (proc)) |
| 578 | 5011 ; |
|
76794
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5012 #endif /* O_NDELAY */ |
|
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5013 #endif /* O_NONBLOCK */ |
| 578 | 5014 #ifdef HAVE_PTYS |
| 5015 /* On some OSs with ptys, when the process on one end of | |
| 5016 a pty exits, the other end gets an error reading with | |
| 5017 errno = EIO instead of getting an EOF (0 bytes read). | |
| 5018 Therefore, if we get an error reading and errno = | |
| 5019 EIO, just continue, because the child process has | |
| 5020 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
|
5021 get a SIGCHLD). |
|
8d68b82a4d8c
(wait_reading_process_input): If a pty gives EIO,
Richard M. Stallman <rms@gnu.org>
parents:
22939
diff
changeset
|
5022 |
|
8d68b82a4d8c
(wait_reading_process_input): If a pty gives EIO,
Richard M. Stallman <rms@gnu.org>
parents:
22939
diff
changeset
|
5023 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
|
5024 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
|
5025 It can't hurt. */ |
| 578 | 5026 else if (nread == -1 && errno == EIO) |
|
76794
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5027 { |
|
104723
1eb83f01c48d
(wait_reading_process_output): Keep the descriptor
Nick Roberts <nickrob@snap.net.nz>
parents:
104638
diff
changeset
|
5028 /* Clear the descriptor now, so we only raise the |
|
104724
8bd22a0db033
*** empty log message ***
Nick Roberts <nickrob@snap.net.nz>
parents:
104723
diff
changeset
|
5029 signal once. Don't do this if `process' is only |
|
104723
1eb83f01c48d
(wait_reading_process_output): Keep the descriptor
Nick Roberts <nickrob@snap.net.nz>
parents:
104638
diff
changeset
|
5030 a pty. */ |
|
1eb83f01c48d
(wait_reading_process_output): Keep the descriptor
Nick Roberts <nickrob@snap.net.nz>
parents:
104638
diff
changeset
|
5031 if (XPROCESS (proc)->pid != -2) |
|
1eb83f01c48d
(wait_reading_process_output): Keep the descriptor
Nick Roberts <nickrob@snap.net.nz>
parents:
104638
diff
changeset
|
5032 { |
|
1eb83f01c48d
(wait_reading_process_output): Keep the descriptor
Nick Roberts <nickrob@snap.net.nz>
parents:
104638
diff
changeset
|
5033 FD_CLR (channel, &input_wait_mask); |
|
1eb83f01c48d
(wait_reading_process_output): Keep the descriptor
Nick Roberts <nickrob@snap.net.nz>
parents:
104638
diff
changeset
|
5034 FD_CLR (channel, &non_keyboard_wait_mask); |
|
1eb83f01c48d
(wait_reading_process_output): Keep the descriptor
Nick Roberts <nickrob@snap.net.nz>
parents:
104638
diff
changeset
|
5035 |
|
1eb83f01c48d
(wait_reading_process_output): Keep the descriptor
Nick Roberts <nickrob@snap.net.nz>
parents:
104638
diff
changeset
|
5036 kill (getpid (), SIGCHLD); |
|
1eb83f01c48d
(wait_reading_process_output): Keep the descriptor
Nick Roberts <nickrob@snap.net.nz>
parents:
104638
diff
changeset
|
5037 } |
|
76794
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5038 } |
|
fbe60d04cec2
(wait_reading_process_output) [HAVE_PTYS]:
Kim F. Storm <storm@cua.dk>
parents:
76789
diff
changeset
|
5039 #endif /* HAVE_PTYS */ |
| 648 | 5040 /* If we can detect process termination, don't consider the process |
| 5041 gone just because its pipe is closed. */ | |
| 578 | 5042 #ifdef SIGCHLD |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
5043 else if (nread == 0 && !NETCONN_P (proc) && !SERIALCONN_P (proc)) |
| 578 | 5044 ; |
| 5045 #endif | |
| 5046 else | |
| 5047 { | |
| 5048 /* 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
|
5049 XPROCESS (proc)->tick = ++process_tick; |
| 578 | 5050 deactivate_process (proc); |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
5051 if (XPROCESS (proc)->raw_status_new) |
| 578 | 5052 update_status (XPROCESS (proc)); |
| 5053 if (EQ (XPROCESS (proc)->status, Qrun)) | |
| 5054 XPROCESS (proc)->status | |
| 5055 = Fcons (Qexit, Fcons (make_number (256), Qnil)); | |
| 5056 } | |
| 5057 } | |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
5058 #ifdef NON_BLOCKING_CONNECT |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
5059 if (FD_ISSET (channel, &Writeok) |
|
55766
d5fe47c900ee
(wait_reading_process_input): Check connect_wait_mask
Kim F. Storm <storm@cua.dk>
parents:
55579
diff
changeset
|
5060 && FD_ISSET (channel, &connect_wait_mask)) |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5061 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5062 struct Lisp_Process *p; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5063 |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5064 FD_CLR (channel, &connect_wait_mask); |
|
110613
ddf04bc5ad27
* process.c (wait_reading_process_output): Add missing FD_CLR
Jan D <jan.h.d@swipnet.se>
parents:
110611
diff
changeset
|
5065 FD_CLR (channel, &write_mask); |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5066 if (--num_pending_connects < 0) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5067 abort (); |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5068 |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5069 proc = chan_process[channel]; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5070 if (NILP (proc)) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5071 continue; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5072 |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5073 p = XPROCESS (proc); |
|
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 #ifdef GNU_LINUX |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5076 /* 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
|
5077 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
|
5078 { |
|
109160
f8660b83cdbf
Fix whitespace to follow coding guidelines.
Juanma Barranquero <lekktu@gmail.com>
parents:
109145
diff
changeset
|
5079 int xlen = sizeof (xerrno); |
|
f8660b83cdbf
Fix whitespace to follow coding guidelines.
Juanma Barranquero <lekktu@gmail.com>
parents:
109145
diff
changeset
|
5080 if (getsockopt (channel, SOL_SOCKET, SO_ERROR, &xerrno, &xlen)) |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5081 xerrno = errno; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5082 } |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5083 #else |
|
44013
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Jan?k <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5084 { |
|
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Jan?k <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5085 struct sockaddr pname; |
|
109160
f8660b83cdbf
Fix whitespace to follow coding guidelines.
Juanma Barranquero <lekktu@gmail.com>
parents:
109145
diff
changeset
|
5086 int pnamelen = sizeof (pname); |
|
44013
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Jan?k <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5087 |
|
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Jan?k <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5088 /* 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
|
5089 xerrno = 0; |
|
109160
f8660b83cdbf
Fix whitespace to follow coding guidelines.
Juanma Barranquero <lekktu@gmail.com>
parents:
109145
diff
changeset
|
5090 if (getpeername (channel, &pname, &pnamelen) < 0) |
|
44013
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Jan?k <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5091 { |
|
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Jan?k <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5092 /* 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
|
5093 char dummy; |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5094 xerrno = errno; |
|
109160
f8660b83cdbf
Fix whitespace to follow coding guidelines.
Juanma Barranquero <lekktu@gmail.com>
parents:
109145
diff
changeset
|
5095 if (errno == ENOTCONN && read (channel, &dummy, 1) < 0) |
|
44013
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Jan?k <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5096 xerrno = errno; |
|
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Jan?k <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5097 } |
|
da239fc7bb6c
(wait_reading_process_input): Move variables `pname' and `pnamelen' down
Pavel Jan?k <Pavel@Janik.cz>
parents:
43999
diff
changeset
|
5098 } |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5099 #endif |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5100 if (xerrno) |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5101 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5102 p->tick = ++process_tick; |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5103 p->status = Fcons (Qfailed, Fcons (make_number (xerrno), Qnil)); |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5104 deactivate_process (proc); |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5105 } |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5106 else |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5107 { |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5108 p->status = Qrun; |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5109 /* Execute the sentinel here. If we had relied on |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5110 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
|
5111 from the process before calling the sentinel. */ |
|
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
5112 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
|
5113 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
|
5114 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5115 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
|
5116 FD_SET (p->infd, &non_keyboard_wait_mask); |
|
43598
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 } |
|
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 #endif /* NON_BLOCKING_CONNECT */ |
| 648 | 5121 } /* end for each file descriptor */ |
| 5122 } /* end while exit conditions not met */ | |
| 5123 | |
|
72277
a6b9ee835f88
* process.c: Reapply 2006-08-01 change.
Chong Yidong <cyd@stupidchicken.com>
parents:
72255
diff
changeset
|
5124 unbind_to (count, Qnil); |
|
8570
dd3dfde8f973
(wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
8390
diff
changeset
|
5125 |
| 648 | 5126 /* If calling from keyboard input, do not quit |
| 5127 since we want to return C-g as an input character. | |
| 5128 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
|
5129 if (read_kbd >= 0) |
| 648 | 5130 { |
| 5131 /* Prevent input_pending from remaining set if we quit. */ | |
| 5132 clear_input_pending (); | |
| 5133 QUIT; | |
| 5134 } | |
|
25009
5733af0b62ce
(wait_reading_process_input): Show and hide busy
Gerd Moellmann <gerd@gnu.org>
parents:
24933
diff
changeset
|
5135 |
| 578 | 5136 return got_some_input; |
| 5137 } | |
| 5138 | |
|
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5139 /* 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
|
5140 |
|
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5141 static Lisp_Object |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
5142 read_process_output_call (Lisp_Object fun_and_args) |
|
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5143 { |
|
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
5144 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
|
5145 } |
|
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5146 |
|
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5147 static Lisp_Object |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
5148 read_process_output_error_handler (Lisp_Object error) |
|
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5149 { |
|
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5150 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
|
5151 Vinhibit_quit = Qt; |
|
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5152 update_echo_area (); |
|
11277
d4547e4b0aab
(read_process_output_error_handler)
Richard M. Stallman <rms@gnu.org>
parents:
11235
diff
changeset
|
5153 Fsleep_for (make_number (2), Qnil); |
| 27558 | 5154 return Qt; |
|
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5155 } |
|
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5156 |
| 578 | 5157 /* Read pending output from the process channel, |
| 5158 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
|
5159 Yield number of decoded characters read. |
| 578 | 5160 |
|
55962
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
5161 This function reads at most 4096 characters. |
| 578 | 5162 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
|
5163 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
|
5164 |
|
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5165 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
|
5166 for decoding. */ |
| 578 | 5167 |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
5168 static int |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
5169 read_process_output (Lisp_Object proc, register int channel) |
| 578 | 5170 { |
|
52527
3ea59ac8dfa5
(Fnetwork_interface_info): Fix type error.
Dave Love <fx@gnu.org>
parents:
52525
diff
changeset
|
5171 register int nbytes; |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5172 char *chars; |
| 578 | 5173 register Lisp_Object outstream; |
| 5174 register struct Lisp_Process *p = XPROCESS (proc); | |
|
110562
ea50a897140e
Fix int/EMACS_INT use in process.c and term.c.
Eli Zaretskii <eliz@gnu.org>
parents:
110556
diff
changeset
|
5175 register EMACS_INT opoint; |
|
17110
3a348cbb354f
(Fstart_process, Fopen_network_stream): Do not perform
Kenichi Handa <handa@m17n.org>
parents:
17041
diff
changeset
|
5176 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
|
5177 int carryover = p->decoding_carryover; |
|
55962
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
5178 int readmax = 4096; |
|
107825
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5179 int count = SPECPDL_INDEX (); |
|
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5180 Lisp_Object odeactivate; |
| 578 | 5181 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5182 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
|
5183 if (carryover) |
|
5e983ddb85c9
(Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
5184 /* See the comment above. */ |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
5185 memcpy (chars, SDATA (p->decoding_buf), carryover); |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5186 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5187 #ifdef DATAGRAM_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5188 /* 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
|
5189 if (DATAGRAM_CHAN_P (channel)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5190 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5191 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
|
5192 nbytes = recvfrom (channel, chars + carryover, readmax, |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5193 0, datagram_address[channel].sa, &len); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5194 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5195 else |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5196 #endif |
| 578 | 5197 if (proc_buffered_char[channel] < 0) |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5198 { |
| 110584 | 5199 #ifdef HAVE_GNUTLS |
|
110648
256dd50b2a63
Make sure all reads/writes to gnutls streams go via the gnutls functions.
Lars Magne Ingebrigtsen <larsi@gnus.org>
parents:
110613
diff
changeset
|
5200 if (XPROCESS (proc)->gnutls_p) |
|
256dd50b2a63
Make sure all reads/writes to gnutls streams go via the gnutls functions.
Lars Magne Ingebrigtsen <larsi@gnus.org>
parents:
110613
diff
changeset
|
5201 nbytes = emacs_gnutls_read (channel, XPROCESS (proc), |
| 110584 | 5202 chars + carryover, readmax); |
| 5203 else | |
| 5204 #endif | |
| 5205 nbytes = emacs_read (channel, chars + carryover, readmax); | |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5206 #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
|
5207 if (nbytes > 0 && p->adaptive_read_buffering) |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5208 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5209 int delay = p->read_output_delay; |
|
53520
2a54a8df1973
(read_process_output): Only activate adaptive
Kim F. Storm <storm@cua.dk>
parents:
53472
diff
changeset
|
5210 if (nbytes < 256) |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5211 { |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5212 if (delay < READ_OUTPUT_DELAY_MAX_MAX) |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5213 { |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5214 if (delay == 0) |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5215 process_output_delay_count++; |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5216 delay += READ_OUTPUT_DELAY_INCREMENT * 2; |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5217 } |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5218 } |
|
56583
64ae47cb68ff
(read_process_output): Use whole read buffer.
Kim F. Storm <storm@cua.dk>
parents:
56477
diff
changeset
|
5219 else if (delay > 0 && (nbytes == readmax)) |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5220 { |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5221 delay -= READ_OUTPUT_DELAY_INCREMENT; |
|
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 } |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5225 p->read_output_delay = delay; |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5226 if (delay) |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5227 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5228 p->read_output_skip = 1; |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5229 process_output_skip = 1; |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5230 } |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5231 } |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5232 #endif |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5233 } |
| 578 | 5234 else |
| 5235 { | |
|
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5236 chars[carryover] = proc_buffered_char[channel]; |
| 578 | 5237 proc_buffered_char[channel] = -1; |
| 110584 | 5238 #ifdef HAVE_GNUTLS |
|
110648
256dd50b2a63
Make sure all reads/writes to gnutls streams go via the gnutls functions.
Lars Magne Ingebrigtsen <larsi@gnus.org>
parents:
110613
diff
changeset
|
5239 if (XPROCESS (proc)->gnutls_p) |
|
256dd50b2a63
Make sure all reads/writes to gnutls streams go via the gnutls functions.
Lars Magne Ingebrigtsen <larsi@gnus.org>
parents:
110613
diff
changeset
|
5240 nbytes = emacs_gnutls_read (channel, XPROCESS (proc), |
| 110584 | 5241 chars + carryover + 1, readmax - 1); |
| 5242 else | |
| 5243 #endif | |
| 5244 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
|
5245 if (nbytes < 0) |
|
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5246 nbytes = 1; |
| 578 | 5247 else |
|
20594
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5248 nbytes = nbytes + 1; |
| 578 | 5249 } |
| 5250 | |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5251 p->decoding_carryover = 0; |
|
22523
b02a5ea8cf93
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
22019
diff
changeset
|
5252 |
|
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5253 /* 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
|
5254 (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
|
5255 if (nbytes <= 0) |
|
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
5256 { |
|
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
5257 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
|
5258 return nbytes; |
|
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
5259 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 } |
|
20594
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5261 |
|
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5262 /* 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
|
5263 nbytes += carryover; |
|
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
5264 |
|
107825
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5265 odeactivate = Vdeactivate_mark; |
|
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5266 /* There's no good reason to let process filters change the current |
|
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5267 buffer, and many callers of accept-process-output, sit-for, and |
|
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5268 friends don't expect current-buffer to be changed from under them. */ |
|
108164
745e12b5af4a
Don't burp if process sentinel/filter kills the current buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107846
diff
changeset
|
5269 record_unwind_protect (set_buffer_if_live, Fcurrent_buffer ()); |
|
107825
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5270 |
|
20594
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5271 /* Read and dispose of the process output. */ |
| 578 | 5272 outstream = p->filter; |
| 5273 if (!NILP (outstream)) | |
| 5274 { | |
|
10914
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
5275 Lisp_Object obuffer, okeymap; |
|
20594
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5276 Lisp_Object text; |
|
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5277 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
|
5278 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
|
5279 |
|
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
5280 /* 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
|
5281 is test them for EQness, and none of them should be a string. */ |
|
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
5282 XSETBUFFER (obuffer, current_buffer); |
|
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
5283 okeymap = current_buffer->keymap; |
|
3510
b4a552ca4e99
(read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents:
3238
diff
changeset
|
5284 |
|
107825
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5285 /* We inhibit quit here instead of just catching it so that |
|
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5286 hitting ^G when a filter happens to be running won't screw |
|
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5287 it up. */ |
| 578 | 5288 specbind (Qinhibit_quit, Qt); |
|
8231
5226ed89c1a6
(Qlast_nonmenu_event): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
8063
diff
changeset
|
5289 specbind (Qlast_nonmenu_event, Qt); |
|
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
5290 |
|
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5291 /* In case we get recursively called, |
|
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5292 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
|
5293 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
|
5294 if (outer_running_asynch_code) |
|
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5295 { |
|
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5296 Lisp_Object tem; |
|
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5297 /* 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
|
5298 tem = Fmatch_data (Qnil, Qnil, Qnil); |
|
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
5299 restore_search_regs (); |
|
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
5300 record_unwind_save_match_data (); |
|
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
5301 Fset_match_data (tem, Qt); |
|
16644
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 |
|
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5304 /* 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
|
5305 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
|
5306 running_asynch_code = 1; |
|
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5307 |
|
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5308 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
|
5309 text = coding->dst_object; |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5310 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
|
5311 /* 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
|
5312 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
|
5313 { |
|
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5314 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
|
5315 |
|
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5316 /* Don't call setup_coding_system for |
|
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5317 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
|
5318 detect_coding called via decode_coding above. */ |
|
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5319 |
|
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5320 /* 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
|
5321 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
|
5322 |
|
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5323 But, before doing that we must check if |
|
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5324 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
|
5325 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
|
5326 sent to the process. */ |
|
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5327 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
|
5328 && proc_encode_coding_system[p->outfd]) |
|
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5329 { |
|
90392
8b24a6ec5090
(setup_process_coding_systems): Fix synching with
Kenichi Handa <handa@m17n.org>
parents:
90389
diff
changeset
|
5330 p->encode_coding_system |
|
8b24a6ec5090
(setup_process_coding_systems): Fix synching with
Kenichi Handa <handa@m17n.org>
parents:
90389
diff
changeset
|
5331 = 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
|
5332 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
|
5333 proc_encode_coding_system[p->outfd]); |
|
30580
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 } |
|
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5336 |
|
89459
3e4c75be8383
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
88554
diff
changeset
|
5337 if (coding->carryover_bytes > 0) |
|
3e4c75be8383
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
88554
diff
changeset
|
5338 { |
|
89938
ab6b6e8cffe6
(read_process_output): Grow decoding_buf when needed;
Kenichi Handa <handa@m17n.org>
parents:
89909
diff
changeset
|
5339 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
|
5340 p->decoding_buf = make_uninit_string (coding->carryover_bytes); |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
5341 memcpy (SDATA (p->decoding_buf), coding->carryover, |
|
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
5342 coding->carryover_bytes); |
| 90982 | 5343 p->decoding_carryover = coding->carryover_bytes; |
|
89459
3e4c75be8383
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
88554
diff
changeset
|
5344 } |
|
52093
25ad7be098ba
(read_process_output): Return the actually read bytes
Kenichi Handa <handa@m17n.org>
parents:
51637
diff
changeset
|
5345 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
|
5346 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
|
5347 Fcons (outstream, |
|
1898b3c996ff
(read_process_output): Don't run a filter if the code
Kenichi Handa <handa@m17n.org>
parents:
34352
diff
changeset
|
5348 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
|
5349 !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
|
5350 read_process_output_error_handler); |
|
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5351 |
|
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5352 /* 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
|
5353 restore_search_regs (); |
|
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
5354 running_asynch_code = outer_running_asynch_code; |
| 578 | 5355 |
|
23460
94f4ba741f22
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
23405
diff
changeset
|
5356 /* 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
|
5357 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
|
5358 waiting_for_user_input_p = waiting; |
|
94f4ba741f22
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
23405
diff
changeset
|
5359 |
|
12808
4db1f387e85f
(read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents:
12749
diff
changeset
|
5360 #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
|
5361 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
|
5362 that affect key bindings. */ |
|
10914
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
5363 if (! EQ (Fcurrent_buffer (), obuffer) |
|
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
5364 || ! EQ (current_buffer->keymap, okeymap)) |
|
12808
4db1f387e85f
(read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents:
12749
diff
changeset
|
5365 #endif |
|
13159
2af96ac471bc
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
12808
diff
changeset
|
5366 /* 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
|
5367 Otherwise there's no need to make him wake up, and it could |
| 71762 | 5368 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
|
5369 if (waiting_for_user_input_p == -1) |
|
2af96ac471bc
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
12808
diff
changeset
|
5370 record_asynch_buffer_change (); |
| 578 | 5371 } |
| 5372 | |
| 5373 /* If no filter, write into buffer if it isn't dead. */ | |
|
107825
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5374 else if (!NILP (p->buffer) && !NILP (XBUFFER (p->buffer)->name)) |
| 578 | 5375 { |
|
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5376 Lisp_Object old_read_only; |
|
110562
ea50a897140e
Fix int/EMACS_INT use in process.c and term.c.
Eli Zaretskii <eliz@gnu.org>
parents:
110556
diff
changeset
|
5377 EMACS_INT old_begv, old_zv; |
|
ea50a897140e
Fix int/EMACS_INT use in process.c and term.c.
Eli Zaretskii <eliz@gnu.org>
parents:
110556
diff
changeset
|
5378 EMACS_INT old_begv_byte, old_zv_byte; |
|
ea50a897140e
Fix int/EMACS_INT use in process.c and term.c.
Eli Zaretskii <eliz@gnu.org>
parents:
110556
diff
changeset
|
5379 EMACS_INT before, before_byte; |
|
ea50a897140e
Fix int/EMACS_INT use in process.c and term.c.
Eli Zaretskii <eliz@gnu.org>
parents:
110556
diff
changeset
|
5380 EMACS_INT opoint_byte; |
|
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5381 Lisp_Object text; |
|
34352
642fb6c53a10
(read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents:
32864
diff
changeset
|
5382 struct buffer *b; |
|
107825
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5383 |
| 578 | 5384 Fset_buffer (p->buffer); |
|
16039
855c8d8ba0f0
Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents:
15895
diff
changeset
|
5385 opoint = PT; |
|
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5386 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
|
5387 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
|
5388 old_begv = BEGV; |
|
77b137e2d9a7
(read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents:
17247
diff
changeset
|
5389 old_zv = ZV; |
|
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5390 old_begv_byte = BEGV_BYTE; |
|
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5391 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
|
5392 |
|
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5393 current_buffer->read_only = Qnil; |
| 578 | 5394 |
| 5395 /* Insert new output into buffer | |
| 5396 at the current end-of-output marker, | |
| 5397 thus preserving logical ordering of input and output. */ | |
| 5398 if (XMARKER (p->mark)->buffer) | |
|
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5399 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
|
5400 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
|
5401 ZV_BYTE)); |
| 578 | 5402 else |
|
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5403 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
|
5404 before = PT; |
|
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5405 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
|
5406 |
|
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5407 /* 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
|
5408 the restriction and widen. */ |
|
16039
855c8d8ba0f0
Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents:
15895
diff
changeset
|
5409 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
|
5410 Fwiden (); |
|
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5411 |
|
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5412 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
|
5413 text = coding->dst_object; |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5414 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
|
5415 /* 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
|
5416 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
|
5417 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
|
5418 { |
|
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5419 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
|
5420 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
|
5421 && proc_encode_coding_system[p->outfd]) |
|
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5422 { |
|
90392
8b24a6ec5090
(setup_process_coding_systems): Fix synching with
Kenichi Handa <handa@m17n.org>
parents:
90389
diff
changeset
|
5423 p->encode_coding_system |
|
8b24a6ec5090
(setup_process_coding_systems): Fix synching with
Kenichi Handa <handa@m17n.org>
parents:
90389
diff
changeset
|
5424 = 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
|
5425 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
|
5426 proc_encode_coding_system[p->outfd]); |
|
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5427 } |
|
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5428 } |
|
89459
3e4c75be8383
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
88554
diff
changeset
|
5429 if (coding->carryover_bytes > 0) |
|
3e4c75be8383
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
88554
diff
changeset
|
5430 { |
|
89938
ab6b6e8cffe6
(read_process_output): Grow decoding_buf when needed;
Kenichi Handa <handa@m17n.org>
parents:
89909
diff
changeset
|
5431 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
|
5432 p->decoding_buf = make_uninit_string (coding->carryover_bytes); |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
5433 memcpy (SDATA (p->decoding_buf), coding->carryover, |
|
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
5434 coding->carryover_bytes); |
| 90982 | 5435 p->decoding_carryover = coding->carryover_bytes; |
|
89459
3e4c75be8383
(read_process_output): Handle carryover correctly.
Kenichi Handa <handa@m17n.org>
parents:
88554
diff
changeset
|
5436 } |
|
31419
bd258f4dc0fa
(read_process_output): Before inserting the decoded
Kenichi Handa <handa@m17n.org>
parents:
31136
diff
changeset
|
5437 /* 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
|
5438 if (NILP (current_buffer->enable_multibyte_characters) |
|
bd258f4dc0fa
(read_process_output): Before inserting the decoded
Kenichi Handa <handa@m17n.org>
parents:
31136
diff
changeset
|
5439 != ! STRING_MULTIBYTE (text)) |
|
bd258f4dc0fa
(read_process_output): Before inserting the decoded
Kenichi Handa <handa@m17n.org>
parents:
31136
diff
changeset
|
5440 text = (STRING_MULTIBYTE (text) |
|
32395
11b8c07e5fed
(read_process_output): Cancel previous change.
Kenichi Handa <handa@m17n.org>
parents:
32371
diff
changeset
|
5441 ? Fstring_as_unibyte (text) |
|
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
5442 : Fstring_to_multibyte (text)); |
|
32395
11b8c07e5fed
(read_process_output): Cancel previous change.
Kenichi Handa <handa@m17n.org>
parents:
32371
diff
changeset
|
5443 /* 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
|
5444 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
|
5445 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
|
5446 SCHARS (text), SBYTES (text), 0); |
|
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
5447 |
|
34352
642fb6c53a10
(read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents:
32864
diff
changeset
|
5448 /* 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
|
5449 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
|
5450 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
|
5451 if (BUFFERP (p->buffer) |
|
642fb6c53a10
(read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents:
32864
diff
changeset
|
5452 && (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
|
5453 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
|
5454 else |
|
642fb6c53a10
(read_process_output): Make sure the process marker's
Gerd Moellmann <gerd@gnu.org>
parents:
32864
diff
changeset
|
5455 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
|
5456 |
| 578 | 5457 update_mode_lines++; |
| 5458 | |
|
17604
77b137e2d9a7
(read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents:
17247
diff
changeset
|
5459 /* 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
|
5460 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
|
5461 if (opoint >= before) |
|
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5462 { |
|
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5463 opoint += PT - before; |
|
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5464 opoint_byte += PT_BYTE - before_byte; |
|
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5465 } |
|
17604
77b137e2d9a7
(read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents:
17247
diff
changeset
|
5466 if (old_begv > before) |
|
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5467 { |
|
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5468 old_begv += PT - before; |
|
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5469 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
|
5470 } |
|
17604
77b137e2d9a7
(read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents:
17247
diff
changeset
|
5471 if (old_zv >= 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 old_zv += PT - before; |
|
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
5474 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
|
5475 } |
|
17604
77b137e2d9a7
(read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents:
17247
diff
changeset
|
5476 |
|
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5477 /* 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
|
5478 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
|
5479 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
|
5480 |
|
3510
b4a552ca4e99
(read_process_output): Deactivate the mark.
Richard M. Stallman <rms@gnu.org>
parents:
3238
diff
changeset
|
5481 |
|
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5482 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
|
5483 SET_PT_BOTH (opoint, opoint_byte); |
| 578 | 5484 } |
|
107825
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5485 /* Handling the process output should not deactivate the mark. */ |
|
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5486 Vdeactivate_mark = odeactivate; |
|
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5487 |
|
57e2e94dbe55
(read_process_output): Move the save-current-buffer to
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107737
diff
changeset
|
5488 unbind_to (count, Qnil); |
|
20594
6e5a5afbe628
(read_process_output): Use insert_1_both.
Richard M. Stallman <rms@gnu.org>
parents:
20551
diff
changeset
|
5489 return nbytes; |
| 578 | 5490 } |
| 5491 | |
| 5492 /* Sending data to subprocess */ | |
| 5493 | |
| 5494 jmp_buf send_process_frame; | |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5495 Lisp_Object process_sent_to; |
| 578 | 5496 |
| 5497 SIGTYPE | |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
5498 send_process_trap (int ignore) |
| 578 | 5499 { |
|
58986
59945307b86b
* syssignal.h: Declare main_thread.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
58082
diff
changeset
|
5500 SIGNAL_THREAD_CHECK (SIGPIPE); |
|
62334
f9dc4e8a41fe
(send_process_trap): Unblock SIGPIPE.
Richard M. Stallman <rms@gnu.org>
parents:
60892
diff
changeset
|
5501 sigunblock (sigmask (SIGPIPE)); |
| 578 | 5502 longjmp (send_process_frame, 1); |
| 5503 } | |
| 5504 | |
|
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5505 /* Send some data to process PROC. |
|
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5506 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
|
5507 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
|
5508 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
|
5509 |
|
21acd0c60f5d
(send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents:
32395
diff
changeset
|
5510 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
|
5511 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
|
5512 |
|
336858b2b11a
(send_process): Add a hint that the function
Gerd Moellmann <gerd@gnu.org>
parents:
28012
diff
changeset
|
5513 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
|
5514 |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
5515 static void |
|
109726
64732fa6188a
Use const char* instead of char*.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109672
diff
changeset
|
5516 send_process (volatile Lisp_Object proc, const unsigned char *volatile buf, |
|
110562
ea50a897140e
Fix int/EMACS_INT use in process.c and term.c.
Eli Zaretskii <eliz@gnu.org>
parents:
110556
diff
changeset
|
5517 volatile EMACS_INT len, volatile Lisp_Object object) |
| 578 | 5518 { |
|
11926
40d7e6f04ebe
(create_process, send_process): Add volatile qualifiers.
Karl Heuer <kwzh@gnu.org>
parents:
11845
diff
changeset
|
5519 /* 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
|
5520 struct Lisp_Process *p = XPROCESS (proc); |
|
110562
ea50a897140e
Fix int/EMACS_INT use in process.c and term.c.
Eli Zaretskii <eliz@gnu.org>
parents:
110556
diff
changeset
|
5521 EMACS_INT rv; |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5522 struct coding_system *coding; |
|
103621
444861df76cd
Simplify last change.
Andreas Schwab <schwab@linux-m68k.org>
parents:
103620
diff
changeset
|
5523 struct gcpro gcpro1; |
|
109145
d0090a8b66c3
Convert function definitions and declarations to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109144
diff
changeset
|
5524 SIGTYPE (*volatile old_sigpipe) (int); |
|
103621
444861df76cd
Simplify last change.
Andreas Schwab <schwab@linux-m68k.org>
parents:
103620
diff
changeset
|
5525 |
|
444861df76cd
Simplify last change.
Andreas Schwab <schwab@linux-m68k.org>
parents:
103620
diff
changeset
|
5526 GCPRO1 (object); |
| 578 | 5527 |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
5528 if (p->raw_status_new) |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5529 update_status (p); |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5530 if (! EQ (p->status, Qrun)) |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5531 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
|
5532 if (p->outfd < 0) |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5533 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
|
5534 |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5535 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
|
5536 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
|
5537 |
|
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5538 if ((STRINGP (object) && STRING_MULTIBYTE (object)) |
|
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5539 || (BUFFERP (object) |
|
32864
21acd0c60f5d
(send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents:
32395
diff
changeset
|
5540 && !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
|
5541 || EQ (object, Qt)) |
|
31136
d1344c992a9a
(create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents:
31099
diff
changeset
|
5542 { |
|
110829
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
5543 p->encode_coding_system |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
5544 = complement_process_encoding_system (p->encode_coding_system); |
| 89909 | 5545 if (!EQ (Vlast_coding_system_used, p->encode_coding_system)) |
|
110829
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
5546 { |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
5547 /* The coding system for encoding was changed to raw-text |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
5548 because we sent a unibyte text previously. Now we are |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
5549 sending a multibyte text, thus we must encode it by the |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
5550 original coding system specified for the current process. |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
5551 |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
5552 Another reason we comming here is that the coding system |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
5553 was just complemented and new one was returned by |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
5554 complement_process_encoding_system. */ |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
5555 setup_coding_system (p->encode_coding_system, coding); |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
5556 Vlast_coding_system_used = p->encode_coding_system; |
|
4d672e9d91bf
Complement a coding system for encoding arguments and input to a process.
Kenichi Handa <handa@m17n.org>
parents:
108935
diff
changeset
|
5557 } |
|
42600
93254645e03b
(send_process): Set src_multibyte to 1 after the call
Eli Zaretskii <eliz@gnu.org>
parents:
41969
diff
changeset
|
5558 coding->src_multibyte = 1; |
|
31136
d1344c992a9a
(create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents:
31099
diff
changeset
|
5559 } |
|
d1344c992a9a
(create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents:
31099
diff
changeset
|
5560 else |
|
d1344c992a9a
(create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents:
31099
diff
changeset
|
5561 { |
|
32864
21acd0c60f5d
(send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents:
32395
diff
changeset
|
5562 /* 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
|
5563 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
|
5564 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
|
5565 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
|
5566 { |
|
21acd0c60f5d
(send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents:
32395
diff
changeset
|
5567 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
|
5568 { |
|
21acd0c60f5d
(send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents:
32395
diff
changeset
|
5569 /* 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
|
5570 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
|
5571 send_process (proc, "", 0, Qt); |
| 89483 | 5572 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
|
5573 } |
|
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5574 setup_coding_system (raw_text_coding_system |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5575 (Vlast_coding_system_used), |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5576 coding); |
|
32864
21acd0c60f5d
(send_process): If OBJECT is t, it means that the data
Kenichi Handa <handa@m17n.org>
parents:
32395
diff
changeset
|
5577 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
|
5578 } |
|
31136
d1344c992a9a
(create_process): Don't setup raw-text coding here.
Kenichi Handa <handa@m17n.org>
parents:
31099
diff
changeset
|
5579 } |
|
29017
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
5580 coding->dst_multibyte = 0; |
|
8f10362eb5ff
(Fstart_process): GCPRO current_dir before calling
Kenichi Handa <handa@m17n.org>
parents:
28157
diff
changeset
|
5581 |
|
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5582 if (CODING_REQUIRE_ENCODING (coding)) |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5583 { |
|
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5584 coding->dst_object = Qt; |
|
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5585 if (BUFFERP (object)) |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5586 { |
|
110562
ea50a897140e
Fix int/EMACS_INT use in process.c and term.c.
Eli Zaretskii <eliz@gnu.org>
parents:
110556
diff
changeset
|
5587 EMACS_INT from_byte, from, to; |
|
ea50a897140e
Fix int/EMACS_INT use in process.c and term.c.
Eli Zaretskii <eliz@gnu.org>
parents:
110556
diff
changeset
|
5588 EMACS_INT save_pt, save_pt_byte; |
|
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5589 struct buffer *cur = current_buffer; |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5590 |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5591 set_buffer_internal (XBUFFER (object)); |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5592 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
|
5593 |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5594 from_byte = PTR_BYTE_POS (buf); |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5595 from = BYTE_TO_CHAR (from_byte); |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5596 to = BYTE_TO_CHAR (from_byte + len); |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5597 TEMP_SET_PT_BOTH (from, from_byte); |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5598 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
|
5599 to, from_byte + len, Qt); |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5600 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
|
5601 set_buffer_internal (cur); |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5602 } |
|
30580
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5603 else if (STRINGP (object)) |
|
5d92193ed196
(read_process_output): Big simplification. Handle
Kenichi Handa <handa@m17n.org>
parents:
29921
diff
changeset
|
5604 { |
|
104638
fec993ec6e85
(send_process): Use encode_coding_object instead of
Kenichi Handa <handa@m17n.org>
parents:
104316
diff
changeset
|
5605 encode_coding_object (coding, object, 0, 0, SCHARS (object), |
|
fec993ec6e85
(send_process): Use encode_coding_object instead of
Kenichi Handa <handa@m17n.org>
parents:
104316
diff
changeset
|
5606 SBYTES (object), Qt); |
|
39429
9de129194439
(send_process): Disable composition if from_byte < 0.
Gerd Moellmann <gerd@gnu.org>
parents:
39406
diff
changeset
|
5607 } |
|
88385
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5608 else |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5609 { |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5610 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
|
5611 coding->produced = len; |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5612 } |
|
c60e206fcf58
Include "character.h" instead of "charset.h".
Kenichi Handa <handa@m17n.org>
parents:
42600
diff
changeset
|
5613 |
|
20715
5e983ddb85c9
(Fstart_process): Use raw-text instead of emacs-mule
Kenichi Handa <handa@m17n.org>
parents:
20708
diff
changeset
|
5614 len = coding->produced; |
|
103621
444861df76cd
Simplify last change.
Andreas Schwab <schwab@linux-m68k.org>
parents:
103620
diff
changeset
|
5615 object = coding->dst_object; |
|
444861df76cd
Simplify last change.
Andreas Schwab <schwab@linux-m68k.org>
parents:
103620
diff
changeset
|
5616 buf = SDATA (object); |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
5617 } |
| 578 | 5618 |
|
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5619 if (pty_max_bytes == 0) |
|
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5620 { |
|
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5621 #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
|
5622 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
|
5623 if (pty_max_bytes < 0) |
|
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5624 pty_max_bytes = 250; |
|
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5625 #else |
|
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5626 pty_max_bytes = 250; |
|
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5627 #endif |
|
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5628 /* Deduct one, to leave space for the eof. */ |
|
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5629 pty_max_bytes--; |
|
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 |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5632 /* 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
|
5633 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
|
5634 when returning with longjmp despite being declared volatile. */ |
| 578 | 5635 if (!setjmp (send_process_frame)) |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5636 { |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5637 process_sent_to = proc; |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5638 while (len > 0) |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5639 { |
|
110562
ea50a897140e
Fix int/EMACS_INT use in process.c and term.c.
Eli Zaretskii <eliz@gnu.org>
parents:
110556
diff
changeset
|
5640 EMACS_INT this = len; |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5641 |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5642 /* Send this batch, using one or more write calls. */ |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5643 while (this > 0) |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5644 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5645 int outfd = p->outfd; |
|
109145
d0090a8b66c3
Convert function definitions and declarations to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109144
diff
changeset
|
5646 old_sigpipe = (SIGTYPE (*) (int)) signal (SIGPIPE, send_process_trap); |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5647 #ifdef DATAGRAM_SOCKETS |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5648 if (DATAGRAM_CHAN_P (outfd)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5649 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5650 rv = sendto (outfd, (char *) buf, this, |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5651 0, datagram_address[outfd].sa, |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5652 datagram_address[outfd].len); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5653 if (rv < 0 && errno == EMSGSIZE) |
|
62334
f9dc4e8a41fe
(send_process_trap): Unblock SIGPIPE.
Richard M. Stallman <rms@gnu.org>
parents:
60892
diff
changeset
|
5654 { |
|
f9dc4e8a41fe
(send_process_trap): Unblock SIGPIPE.
Richard M. Stallman <rms@gnu.org>
parents:
60892
diff
changeset
|
5655 signal (SIGPIPE, old_sigpipe); |
|
f9dc4e8a41fe
(send_process_trap): Unblock SIGPIPE.
Richard M. Stallman <rms@gnu.org>
parents:
60892
diff
changeset
|
5656 report_file_error ("sending datagram", |
|
f9dc4e8a41fe
(send_process_trap): Unblock SIGPIPE.
Richard M. Stallman <rms@gnu.org>
parents:
60892
diff
changeset
|
5657 Fcons (proc, Qnil)); |
|
f9dc4e8a41fe
(send_process_trap): Unblock SIGPIPE.
Richard M. Stallman <rms@gnu.org>
parents:
60892
diff
changeset
|
5658 } |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5659 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5660 else |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
5661 #endif |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5662 { |
| 110584 | 5663 #ifdef HAVE_GNUTLS |
|
110648
256dd50b2a63
Make sure all reads/writes to gnutls streams go via the gnutls functions.
Lars Magne Ingebrigtsen <larsi@gnus.org>
parents:
110613
diff
changeset
|
5664 if (XPROCESS (proc)->gnutls_p) |
| 110584 | 5665 rv = emacs_gnutls_write (outfd, |
|
110648
256dd50b2a63
Make sure all reads/writes to gnutls streams go via the gnutls functions.
Lars Magne Ingebrigtsen <larsi@gnus.org>
parents:
110613
diff
changeset
|
5666 XPROCESS (proc), |
| 110584 | 5667 (char *) buf, this); |
| 5668 else | |
| 5669 #endif | |
| 5670 rv = emacs_write (outfd, (char *) buf, this); | |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5671 #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
|
5672 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
|
5673 && p->adaptive_read_buffering == 1) |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5674 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5675 p->read_output_delay = 0; |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5676 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
|
5677 p->read_output_skip = 0; |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5678 } |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5679 #endif |
|
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5680 } |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5681 signal (SIGPIPE, old_sigpipe); |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5682 |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5683 if (rv < 0) |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5684 { |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5685 if (0 |
|
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5686 #ifdef EWOULDBLOCK |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5687 || errno == EWOULDBLOCK |
| 6158 | 5688 #endif |
|
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5689 #ifdef EAGAIN |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5690 || errno == EAGAIN |
|
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5691 #endif |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5692 ) |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
5693 /* Buffer is full. Wait, accepting input; |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5694 that may allow the program |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5695 to finish doing output and read more. */ |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5696 { |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5697 int offset = 0; |
|
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5698 |
|
27705
2c53eb482802
(send_process) [BROKEN_PTY_READ_AFTER_EAGAIN]:
Gerd Moellmann <gerd@gnu.org>
parents:
27669
diff
changeset
|
5699 #ifdef BROKEN_PTY_READ_AFTER_EAGAIN |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5700 /* 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
|
5701 In the following sequence, read(2) returns |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5702 bogus data: |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5703 |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5704 write(2) 1022 bytes |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5705 write(2) 954 bytes, get EAGAIN |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5706 read(2) 1024 bytes in process_read_output |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5707 read(2) 11 bytes in process_read_output |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5708 |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5709 That is, read(2) returns more bytes than have |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5710 ever been written successfully. The 1033 bytes |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5711 read are the 1022 bytes written successfully |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5712 after processing (for example with CRs added if |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5713 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
|
5714 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
|
5715 later read(2), without the CRs. */ |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
5716 |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5717 if (errno == EAGAIN) |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5718 { |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5719 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
|
5720 ioctl (p->outfd, TIOCFLUSH, &flags); |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5721 } |
|
27705
2c53eb482802
(send_process) [BROKEN_PTY_READ_AFTER_EAGAIN]:
Gerd Moellmann <gerd@gnu.org>
parents:
27669
diff
changeset
|
5722 #endif /* BROKEN_PTY_READ_AFTER_EAGAIN */ |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
5723 |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5724 /* Running filters might relocate buffers or strings. |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5725 Arrange to relocate BUF. */ |
|
103621
444861df76cd
Simplify last change.
Andreas Schwab <schwab@linux-m68k.org>
parents:
103620
diff
changeset
|
5726 if (BUFFERP (object)) |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5727 offset = BUF_PTR_BYTE_POS (XBUFFER (object), buf); |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5728 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
|
5729 offset = buf - SDATA (object); |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5730 |
|
16718
ea26040865cb
(send_process) [EMACS_HAS_USECS]:
Richard M. Stallman <rms@gnu.org>
parents:
16644
diff
changeset
|
5731 #ifdef EMACS_HAS_USECS |
|
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
5732 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
|
5733 #else |
|
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
5734 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
|
5735 #endif |
|
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
5736 |
|
103621
444861df76cd
Simplify last change.
Andreas Schwab <schwab@linux-m68k.org>
parents:
103620
diff
changeset
|
5737 if (BUFFERP (object)) |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5738 buf = BUF_BYTE_ADDRESS (XBUFFER (object), offset); |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5739 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
|
5740 buf = offset + SDATA (object); |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5741 |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5742 rv = 0; |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5743 } |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5744 else |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5745 /* This is a real error. */ |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5746 report_file_error ("writing to process", Fcons (proc, Qnil)); |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5747 } |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5748 buf += rv; |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5749 len -= rv; |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5750 this -= rv; |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5751 } |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5752 } |
|
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5753 } |
| 578 | 5754 else |
| 5755 { | |
|
62581
7f6a053bbca4
(send_process): Restore the SIGPIPE handler if we catch a SIGPIPE.
Eli Zaretskii <eliz@gnu.org>
parents:
62334
diff
changeset
|
5756 signal (SIGPIPE, old_sigpipe); |
|
31806
b148beb59511
(process_sent_to): New variable.
Gerd Moellmann <gerd@gnu.org>
parents:
31419
diff
changeset
|
5757 proc = process_sent_to; |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5758 p = XPROCESS (proc); |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
5759 p->raw_status_new = 0; |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5760 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
|
5761 p->tick = ++process_tick; |
| 578 | 5762 deactivate_process (proc); |
|
53472
1a5fe79d27f3
(ADAPTIVE_READ_BUFFERING): New conditional.
Kim F. Storm <storm@cua.dk>
parents:
53072
diff
changeset
|
5763 error ("SIGPIPE raised on process %s; closed it", SDATA (p->name)); |
| 578 | 5764 } |
|
15895
85112cca0b22
(send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents:
15717
diff
changeset
|
5765 |
|
85112cca0b22
(send_process): GCPRO object.
Richard M. Stallman <rms@gnu.org>
parents:
15717
diff
changeset
|
5766 UNGCPRO; |
| 578 | 5767 } |
| 5768 | |
| 5769 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
|
5770 3, 3, 0, |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
5771 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
|
5772 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
|
5773 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
|
5774 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
|
5775 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
|
5776 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
|
5777 Output from processes can arrive in between bunches. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
5778 (Lisp_Object process, Lisp_Object start, Lisp_Object end) |
| 578 | 5779 { |
| 5780 Lisp_Object proc; | |
|
110562
ea50a897140e
Fix int/EMACS_INT use in process.c and term.c.
Eli Zaretskii <eliz@gnu.org>
parents:
110556
diff
changeset
|
5781 EMACS_INT start1, end1; |
| 578 | 5782 |
| 5783 proc = get_process (process); | |
| 5784 validate_region (&start, &end); | |
|
90777
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5785 |
|
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5786 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
|
5787 move_gap (XINT (start)); |
|
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5788 |
|
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5789 start1 = CHAR_TO_BYTE (XINT (start)); |
|
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5790 end1 = CHAR_TO_BYTE (XINT (end)); |
|
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5791 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
|
5792 Fcurrent_buffer ()); |
|
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5793 |
| 578 | 5794 return Qnil; |
| 5795 } | |
| 5796 | |
| 5797 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
|
5798 2, 2, 0, |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
5799 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
|
5800 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
|
5801 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
|
5802 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
|
5803 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
|
5804 Output from processes can arrive in between bunches. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
5805 (Lisp_Object process, Lisp_Object string) |
| 578 | 5806 { |
| 5807 Lisp_Object proc; | |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
5808 CHECK_STRING (string); |
| 578 | 5809 proc = get_process (process); |
|
90777
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5810 send_process (proc, SDATA (string), |
|
c0e889bf140c
Cancel the change done by sync with HEAD.
Kenichi Handa <handa@m17n.org>
parents:
90776
diff
changeset
|
5811 SBYTES (string), string); |
| 578 | 5812 return Qnil; |
| 5813 } | |
| 5814 | |
|
49903
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5815 /* 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
|
5816 the process P uses. */ |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5817 static int |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
5818 emacs_get_tty_pgrp (struct Lisp_Process *p) |
|
49903
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5819 { |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5820 int gid = -1; |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5821 |
|
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
5822 #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
|
5823 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
|
5824 { |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5825 int fd; |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5826 /* 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
|
5827 master side. Try the slave side. */ |
|
93324
41f9d37301a2
(server_accept_connection): Simplify naming.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
93201
diff
changeset
|
5828 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
|
5829 |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5830 if (fd != -1) |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5831 { |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5832 ioctl (fd, TIOCGPGRP, &gid); |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5833 emacs_close (fd); |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5834 } |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5835 } |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5836 #endif /* defined (TIOCGPGRP ) */ |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5837 |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5838 return gid; |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5839 } |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5840 |
|
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5841 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
|
5842 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
|
5843 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
|
5844 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
|
5845 return t unconditionally. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
5846 (Lisp_Object process) |
|
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5847 { |
|
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5848 /* 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
|
5849 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
|
5850 int gid; |
|
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5851 Lisp_Object proc; |
|
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5852 struct Lisp_Process *p; |
|
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5853 |
|
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5854 proc = get_process (process); |
|
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5855 p = XPROCESS (proc); |
|
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5856 |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
5857 if (!EQ (p->type, Qreal)) |
|
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5858 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
|
5859 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
|
5860 if (p->infd < 0) |
|
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5861 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
|
5862 SDATA (p->name)); |
|
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5863 |
|
49903
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5864 gid = emacs_get_tty_pgrp (p); |
|
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5865 |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
5866 if (gid == p->pid) |
|
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5867 return Qnil; |
|
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5868 return Qt; |
|
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5869 } |
|
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5870 |
| 578 | 5871 /* send a signal number SIGNO to PROCESS. |
|
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5872 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
|
5873 that currently owns the terminal being used to communicate with PROCESS. |
| 578 | 5874 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
|
5875 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
|
5876 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
|
5877 |
| 578 | 5878 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
|
5879 right away. |
|
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5880 |
|
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5881 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
|
5882 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
|
5883 their uid, for which killpg would return an EPERM error. */ |
| 578 | 5884 |
|
1522
19ccf004b172
* process.c: (status_convert): Declare this to return a
Jim Blandy <jimb@redhat.com>
parents:
1323
diff
changeset
|
5885 static void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
5886 process_send_signal (Lisp_Object process, int signo, Lisp_Object current_group, |
|
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
5887 int nomsg) |
| 578 | 5888 { |
| 5889 Lisp_Object proc; | |
| 5890 register struct Lisp_Process *p; | |
| 5891 int gid; | |
| 5892 int no_pgrp = 0; | |
| 5893 | |
| 5894 proc = get_process (process); | |
| 5895 p = XPROCESS (proc); | |
| 5896 | |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
5897 if (!EQ (p->type, Qreal)) |
| 578 | 5898 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
|
5899 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
|
5900 if (p->infd < 0) |
| 578 | 5901 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
|
5902 SDATA (p->name)); |
| 578 | 5903 |
|
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->pty_flag) |
| 578 | 5905 current_group = Qnil; |
| 5906 | |
| 5907 /* 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
|
5908 if (NILP (current_group)) |
|
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
5909 /* 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
|
5910 gid = p->pid; |
|
46411
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
5911 else |
| 578 | 5912 { |
|
1594
b476a97ad17e
* systty.h, process.c, buffer.h, callproc.c, sysdep.c, dired.c:
Jim Blandy <jimb@redhat.com>
parents:
1569
diff
changeset
|
5913 #ifdef SIGNALS_VIA_CHARACTERS |
| 578 | 5914 /* If possible, send signals to the entire pgrp |
| 5915 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
|
5916 |
|
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5917 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
|
5918 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
|
5919 |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
5920 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
|
5921 |
|
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5922 switch (signo) |
|
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5923 { |
|
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5924 case SIGINT: |
|
56695
62660593b0a2
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
Richard M. Stallman <rms@gnu.org>
parents:
56583
diff
changeset
|
5925 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
|
5926 break; |
|
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5927 |
|
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5928 case SIGQUIT: |
|
56695
62660593b0a2
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
Richard M. Stallman <rms@gnu.org>
parents:
56583
diff
changeset
|
5929 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
|
5930 break; |
|
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5931 |
|
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5932 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
|
5933 #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
|
5934 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
|
5935 #else |
|
56695
62660593b0a2
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
Richard M. Stallman <rms@gnu.org>
parents:
56583
diff
changeset
|
5936 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
|
5937 #endif |
|
62660593b0a2
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]: Clean up.
Richard M. Stallman <rms@gnu.org>
parents:
56583
diff
changeset
|
5938 break; |
|
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5939 } |
|
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
5940 |
|
56713
7e315ff338bf
(process_send_signal): Use CDISABLE.
Kim F. Storm <storm@cua.dk>
parents:
56701
diff
changeset
|
5941 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
|
5942 { |
|
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
5943 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
|
5944 return; |
|
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
5945 } |
|
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
5946 /* 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
|
5947 fall through and send it another way. */ |
|
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
5948 |
|
598599edd5ca
(process_send_signal) [SIGNALS_VIA_CHARACTERS, HAVE_TERMIOS]:
Richard M. Stallman <rms@gnu.org>
parents:
56728
diff
changeset
|
5949 /* 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
|
5950 handle the signal. */ |
|
46314
7c8eab7f2bd6
(process_send_signal): Add abort call.
Richard M. Stallman <rms@gnu.org>
parents:
46293
diff
changeset
|
5951 #endif /* defined (SIGNALS_VIA_CHARACTERS) */ |
| 849 | 5952 |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
5953 #ifdef TIOCGPGRP |
|
46411
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
5954 /* Get the current pgrp using the tty itself, if we have that. |
| 578 | 5955 Otherwise, use the pty to get the pgrp. |
| 5956 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
|
5957 "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
|
5958 But, TIOCGPGRP does not work on E50 ;-P works fine on E60" |
| 578 | 5959 His patch indicates that if TIOCGPGRP returns an error, then |
| 5960 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
|
5961 |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5962 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
|
5963 |
|
49903
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5964 if (gid == -1) |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
5965 /* 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
|
5966 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
|
5967 gid = p->pid; |
|
46411
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
5968 |
|
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
5969 /* 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
|
5970 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
|
5971 Or perhaps this is vestigial. */ |
| 578 | 5972 if (gid == -1) |
| 5973 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
|
5974 #else /* ! defined (TIOCGPGRP ) */ |
| 849 | 5975 /* Can't select pgrps on this system, so we know that |
| 5976 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
|
5977 gid = p->pid; |
| 849 | 5978 #endif /* ! defined (TIOCGPGRP ) */ |
|
24352
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5979 |
|
023601636a18
(syms_of_process): defsubr it.
Richard M. Stallman <rms@gnu.org>
parents:
23930
diff
changeset
|
5980 /* 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
|
5981 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
|
5982 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
|
5983 return; |
| 578 | 5984 } |
| 5985 | |
| 5986 switch (signo) | |
| 5987 { | |
| 5988 #ifdef SIGCONT | |
| 5989 case SIGCONT: | |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
5990 p->raw_status_new = 0; |
| 578 | 5991 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
|
5992 p->tick = ++process_tick; |
| 578 | 5993 if (!nomsg) |
|
104316
bb8ce3c842e7
* process.c (status_notify): Don't perform redisplay.
Chong Yidong <cyd@stupidchicken.com>
parents:
104265
diff
changeset
|
5994 { |
|
bb8ce3c842e7
* process.c (status_notify): Don't perform redisplay.
Chong Yidong <cyd@stupidchicken.com>
parents:
104265
diff
changeset
|
5995 status_notify (NULL); |
|
bb8ce3c842e7
* process.c (status_notify): Don't perform redisplay.
Chong Yidong <cyd@stupidchicken.com>
parents:
104265
diff
changeset
|
5996 redisplay_preserve_echo_area (13); |
|
bb8ce3c842e7
* process.c (status_notify): Don't perform redisplay.
Chong Yidong <cyd@stupidchicken.com>
parents:
104265
diff
changeset
|
5997 } |
| 578 | 5998 break; |
| 849 | 5999 #endif /* ! defined (SIGCONT) */ |
| 578 | 6000 case SIGINT: |
| 6001 case SIGQUIT: | |
| 6002 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
|
6003 flush_pending_output (p->infd); |
| 578 | 6004 break; |
| 6005 } | |
| 6006 | |
| 6007 /* If we don't have process groups, send the signal to the immediate | |
| 6008 subprocess. That isn't really right, but it's better than any | |
| 6009 obvious alternative. */ | |
| 6010 if (no_pgrp) | |
| 6011 { | |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6012 kill (p->pid, signo); |
| 578 | 6013 return; |
| 6014 } | |
| 6015 | |
| 6016 /* gid may be a pid, or minus a pgrp's number */ | |
| 6017 #ifdef TIOCSIGSEND | |
| 6018 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
|
6019 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6020 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
|
6021 EMACS_KILLPG (gid, signo); |
|
6dc5bfe9589b
Removed subtty, workaround for when TIOCSIGSEND fails.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
49894
diff
changeset
|
6022 } |
| 578 | 6023 else |
| 6024 { | |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6025 gid = - p->pid; |
| 578 | 6026 kill (gid, signo); |
| 6027 } | |
| 849 | 6028 #else /* ! defined (TIOCSIGSEND) */ |
|
46411
d17e7d2c1766
(create_process): Test USG_SUBTTY_WORKS.
Richard M. Stallman <rms@gnu.org>
parents:
46370
diff
changeset
|
6029 EMACS_KILLPG (gid, signo); |
| 849 | 6030 #endif /* ! defined (TIOCSIGSEND) */ |
| 578 | 6031 } |
| 6032 | |
| 6033 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
|
6034 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
|
6035 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
|
6036 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
|
6037 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
|
6038 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
|
6039 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
|
6040 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
|
6041 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
|
6042 |
|
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
6043 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
|
6044 don't send the signal. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
6045 (Lisp_Object process, Lisp_Object current_group) |
| 578 | 6046 { |
| 6047 process_send_signal (process, SIGINT, current_group, 0); | |
| 6048 return process; | |
| 6049 } | |
| 6050 | |
| 6051 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
|
6052 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
|
6053 See function `interrupt-process' for more details on usage. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
6054 (Lisp_Object process, Lisp_Object current_group) |
| 578 | 6055 { |
| 6056 process_send_signal (process, SIGKILL, current_group, 0); | |
| 6057 return process; | |
| 6058 } | |
| 6059 | |
| 6060 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
|
6061 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
|
6062 See function `interrupt-process' for more details on usage. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
6063 (Lisp_Object process, Lisp_Object current_group) |
| 578 | 6064 { |
| 6065 process_send_signal (process, SIGQUIT, current_group, 0); | |
| 6066 return process; | |
| 6067 } | |
| 6068 | |
| 6069 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
|
6070 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
|
6071 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
|
6072 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
|
6073 traffic. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
6074 (Lisp_Object process, Lisp_Object current_group) |
| 578 | 6075 { |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6076 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
|
6077 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6078 struct Lisp_Process *p; |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6079 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6080 p = XPROCESS (process); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6081 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
|
6082 && p->infd >= 0) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6083 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6084 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
|
6085 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
|
6086 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6087 p->command = Qt; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6088 return process; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6089 } |
| 578 | 6090 #ifndef SIGTSTP |
|
63701
9ef43e35d417
(Fstop_process, Fcontinue_process): Follow error conventions.
Juanma Barranquero <lekktu@gmail.com>
parents:
63615
diff
changeset
|
6091 error ("No SIGTSTP support"); |
| 578 | 6092 #else |
| 6093 process_send_signal (process, SIGTSTP, current_group, 0); | |
| 6094 #endif | |
| 6095 return process; | |
| 6096 } | |
| 6097 | |
| 6098 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
|
6099 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
|
6100 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
|
6101 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
|
6102 traffic. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
6103 (Lisp_Object process, Lisp_Object current_group) |
| 578 | 6104 { |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6105 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
|
6106 { |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6107 struct Lisp_Process *p; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6108 |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6109 p = XPROCESS (process); |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6110 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
|
6111 && p->infd >= 0 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6112 && (!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
|
6113 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6114 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
|
6115 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
|
6116 #ifdef WINDOWSNT |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6117 if (fd_info[ p->infd ].flags & FILE_SERIAL) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6118 PurgeComm (fd_info[ p->infd ].hnd, PURGE_RXABORT | PURGE_RXCLEAR); |
| 109949 | 6119 #else /* not WINDOWSNT */ |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6120 tcflush (p->infd, TCIFLUSH); |
| 109949 | 6121 #endif /* not WINDOWSNT */ |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6122 } |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6123 p->command = Qnil; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6124 return process; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6125 } |
| 578 | 6126 #ifdef SIGCONT |
| 6127 process_send_signal (process, SIGCONT, current_group, 0); | |
| 6128 #else | |
|
63701
9ef43e35d417
(Fstop_process, Fcontinue_process): Follow error conventions.
Juanma Barranquero <lekktu@gmail.com>
parents:
63615
diff
changeset
|
6129 error ("No SIGCONT support"); |
| 578 | 6130 #endif |
| 6131 return process; | |
| 6132 } | |
| 6133 | |
| 6134 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
|
6135 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
|
6136 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
|
6137 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
|
6138 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
|
6139 this Emacs. |
|
40103
6b389fb978bc
Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Jan?k <Pavel@Janik.cz>
parents:
39973
diff
changeset
|
6140 SIGCODE may be an integer, or a symbol whose name is a signal name. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
6141 (Lisp_Object process, Lisp_Object sigcode) |
| 578 | 6142 { |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6143 pid_t pid; |
|
48053
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6144 |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6145 if (INTEGERP (process)) |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6146 { |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6147 pid = XINT (process); |
|
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6148 goto got_it; |
|
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6149 } |
|
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6150 |
|
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6151 if (FLOATP (process)) |
|
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6152 { |
|
74540
b33acab48a40
(Fsignal_process): Doc fix. Use XFLOAT_DATA to extract the process ID from
Eli Zaretskii <eliz@gnu.org>
parents:
74468
diff
changeset
|
6153 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
|
6154 goto got_it; |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6155 } |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6156 |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6157 if (STRINGP (process)) |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6158 { |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6159 Lisp_Object tem; |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6160 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
|
6161 { |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6162 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
|
6163 if (pid > 0) |
|
48053
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6164 goto got_it; |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6165 } |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6166 process = tem; |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6167 } |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6168 else |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6169 process = get_process (process); |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6170 |
|
48053
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6171 if (NILP (process)) |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6172 return process; |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6173 |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6174 CHECK_PROCESS (process); |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6175 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
|
6176 if (pid <= 0) |
|
48053
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6177 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
|
6178 |
|
f840e449c328
(Fsignal_process): Allow PROCESS to be specified by
Kim F. Storm <storm@cua.dk>
parents:
47987
diff
changeset
|
6179 got_it: |
|
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6180 |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6181 #define parse_signal(NAME, VALUE) \ |
|
95216
ad146a8ff5dc
* dispextern.h, xfaces.c (xstrcasecmp): Renamed from xstricmp.
Jason Rumney <jasonr@gnu.org>
parents:
95111
diff
changeset
|
6182 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
|
6183 XSETINT (sigcode, VALUE) |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6184 |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6185 if (INTEGERP (sigcode)) |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6186 ; |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6187 else |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6188 { |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6189 unsigned char *name; |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6190 |
|
40656
cdfd4d09b79a
Update usage of CHECK_ macros (remove unused second argument).
Pavel Jan?k <Pavel@Janik.cz>
parents:
40641
diff
changeset
|
6191 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
|
6192 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
|
6193 |
|
109160
f8660b83cdbf
Fix whitespace to follow coding guidelines.
Juanma Barranquero <lekktu@gmail.com>
parents:
109145
diff
changeset
|
6194 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
|
6195 name += 3; |
|
715b819a0ad8
(Fsignal_process): Recognize signal names with and
Kim F. Storm <storm@cua.dk>
parents:
65764
diff
changeset
|
6196 |
|
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6197 if (0) |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6198 ; |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6199 #ifdef SIGUSR1 |
|
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6200 parse_signal ("usr1", SIGUSR1); |
|
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6201 #endif |
|
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6202 #ifdef SIGUSR2 |
|
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6203 parse_signal ("usr2", SIGUSR2); |
|
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6204 #endif |
|
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6205 #ifdef SIGTERM |
|
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6206 parse_signal ("term", SIGTERM); |
|
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6207 #endif |
|
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6208 #ifdef SIGHUP |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6209 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
|
6210 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6211 #ifdef SIGINT |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6212 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
|
6213 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6214 #ifdef SIGQUIT |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6215 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
|
6216 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6217 #ifdef SIGILL |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6218 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
|
6219 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6220 #ifdef SIGABRT |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6221 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
|
6222 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6223 #ifdef SIGEMT |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6224 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
|
6225 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6226 #ifdef SIGKILL |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6227 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
|
6228 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6229 #ifdef SIGFPE |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6230 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
|
6231 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6232 #ifdef SIGBUS |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6233 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
|
6234 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6235 #ifdef SIGSEGV |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6236 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
|
6237 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6238 #ifdef SIGSYS |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6239 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
|
6240 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6241 #ifdef SIGPIPE |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6242 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
|
6243 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6244 #ifdef SIGALRM |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6245 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
|
6246 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6247 #ifdef SIGURG |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6248 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
|
6249 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6250 #ifdef SIGSTOP |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6251 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
|
6252 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6253 #ifdef SIGTSTP |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6254 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
|
6255 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6256 #ifdef SIGCONT |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6257 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
|
6258 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6259 #ifdef SIGCHLD |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6260 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
|
6261 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6262 #ifdef SIGTTIN |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6263 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
|
6264 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6265 #ifdef SIGTTOU |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6266 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
|
6267 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6268 #ifdef SIGIO |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6269 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
|
6270 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6271 #ifdef SIGXCPU |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6272 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
|
6273 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6274 #ifdef SIGXFSZ |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6275 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
|
6276 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6277 #ifdef SIGVTALRM |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6278 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
|
6279 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6280 #ifdef SIGPROF |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6281 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
|
6282 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6283 #ifdef SIGWINCH |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6284 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
|
6285 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6286 #ifdef SIGINFO |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6287 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
|
6288 #endif |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6289 else |
|
11148
117b32676686
(Fsignal_process): SIGCODE is a symbol, not a string.
Karl Heuer <kwzh@gnu.org>
parents:
11144
diff
changeset
|
6290 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
|
6291 } |
|
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6292 |
|
74420
7f2e7cb6b161
(parse_signal): Rename macro from handle_signal.
Kim F. Storm <storm@cua.dk>
parents:
74406
diff
changeset
|
6293 #undef parse_signal |
|
11144
c2b689aeb934
(Fsignal_process): Allow signal names as well as numbers.
Richard M. Stallman <rms@gnu.org>
parents:
10914
diff
changeset
|
6294 |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6295 return make_number (kill (pid, XINT (sigcode))); |
| 578 | 6296 } |
| 6297 | |
| 6298 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
|
6299 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
|
6300 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
|
6301 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
|
6302 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
|
6303 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
|
6304 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
|
6305 text to PROCESS after you call this function. |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6306 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
|
6307 process has been transmitted to the serial port. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
6308 (Lisp_Object process) |
| 578 | 6309 { |
| 6310 Lisp_Object proc; | |
|
23879
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
6311 struct coding_system *coding; |
| 578 | 6312 |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6313 if (DATAGRAM_CONN_P (process)) |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6314 return process; |
|
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6315 |
| 578 | 6316 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
|
6317 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
|
6318 |
|
7edc78402205
(Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents:
2200
diff
changeset
|
6319 /* 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
|
6320 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
|
6321 update_status (XPROCESS (proc)); |
|
7edc78402205
(Fprocess_send_eof): Make sure proc is running.
Richard M. Stallman <rms@gnu.org>
parents:
2200
diff
changeset
|
6322 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
|
6323 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
|
6324 |
|
23879
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
6325 if (CODING_REQUIRE_FLUSHING (coding)) |
|
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
6326 { |
|
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
6327 coding->mode |= CODING_MODE_LAST_BLOCK; |
|
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
6328 send_process (proc, "", 0, Qnil); |
|
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
6329 } |
|
18e5d1cfa74b
(read_process_output): If NBYTES is zero and
Kenichi Handa <handa@m17n.org>
parents:
23762
diff
changeset
|
6330 |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6331 if (XPROCESS (proc)->pty_flag) |
|
8063
30861f2f4f84
(send_process): Major rewrite.
Richard M. Stallman <rms@gnu.org>
parents:
7937
diff
changeset
|
6332 send_process (proc, "\004", 1, Qnil); |
|
95900
99342636fa96
(Fserial_process_configure, Fprocess_send_eof):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95884
diff
changeset
|
6333 else if (EQ (XPROCESS (proc)->type, Qserial)) |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6334 { |
| 109949 | 6335 #ifndef WINDOWSNT |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6336 if (tcdrain (XPROCESS (proc)->outfd) != 0) |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6337 error ("tcdrain() failed: %s", emacs_strerror (errno)); |
| 109949 | 6338 #endif /* not WINDOWSNT */ |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6339 /* Do nothing on Windows because writes are blocking. */ |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6340 } |
| 578 | 6341 else |
| 6342 { | |
|
22939
572895549f80
(Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents:
22864
diff
changeset
|
6343 int old_outfd, new_outfd; |
|
572895549f80
(Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents:
22864
diff
changeset
|
6344 |
|
18329
ddaafa596bf5
(Fprocess_send_eof): Prooperly conditionalize prev. change.
Richard M. Stallman <rms@gnu.org>
parents:
18328
diff
changeset
|
6345 #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
|
6346 /* 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
|
6347 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
|
6348 (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
|
6349 Then we just can't win.) */ |
|
95900
99342636fa96
(Fserial_process_configure, Fprocess_send_eof):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
95884
diff
changeset
|
6350 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
|
6351 || 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
|
6352 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
|
6353 /* 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
|
6354 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
|
6355 emacs_close (XPROCESS (proc)->outfd); |
|
18329
ddaafa596bf5
(Fprocess_send_eof): Prooperly conditionalize prev. change.
Richard M. Stallman <rms@gnu.org>
parents:
18328
diff
changeset
|
6356 #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
|
6357 emacs_close (XPROCESS (proc)->outfd); |
|
18329
ddaafa596bf5
(Fprocess_send_eof): Prooperly conditionalize prev. change.
Richard M. Stallman <rms@gnu.org>
parents:
18328
diff
changeset
|
6358 #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
|
6359 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
|
6360 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
|
6361 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
|
6362 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
|
6363 |
|
572895549f80
(Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents:
22864
diff
changeset
|
6364 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
|
6365 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
|
6366 = (struct coding_system *) xmalloc (sizeof (struct coding_system)); |
|
109165
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
6367 memcpy (proc_encode_coding_system[new_outfd], |
|
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
6368 proc_encode_coding_system[old_outfd], |
|
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
6369 sizeof (struct coding_system)); |
|
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
6370 memset (proc_encode_coding_system[old_outfd], 0, |
|
750db9f3e6d8
Replace bcopy, bzero, bcmp by memcpy, memmove, memset, memcmp
Andreas Schwab <schwab@linux-m68k.org>
parents:
109164
diff
changeset
|
6371 sizeof (struct coding_system)); |
|
22939
572895549f80
(Fprocess_send_eof): Transfer proc_encode_coding_system
Richard M. Stallman <rms@gnu.org>
parents:
22864
diff
changeset
|
6372 |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6373 XPROCESS (proc)->outfd = new_outfd; |
| 578 | 6374 } |
| 6375 return process; | |
| 6376 } | |
| 6377 | |
|
39361
2d3bee6a3848
(sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents:
37758
diff
changeset
|
6378 /* 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
|
6379 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
|
6380 are no more. |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6381 |
|
39361
2d3bee6a3848
(sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents:
37758
diff
changeset
|
6382 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
|
6383 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
|
6384 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
|
6385 |
|
2d3bee6a3848
(sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents:
37758
diff
changeset
|
6386 ** 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
|
6387 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
|
6388 Lisp objects. |
|
2d3bee6a3848
(sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents:
37758
diff
changeset
|
6389 |
|
2d3bee6a3848
(sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents:
37758
diff
changeset
|
6390 ** 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
|
6391 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
|
6392 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
|
6393 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
|
6394 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
|
6395 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
|
6396 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
|
6397 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
|
6398 Inc. |
|
0341435e76ce
* process.c (sigchld_handler): Add comment about not calling malloc
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
53713
diff
changeset
|
6399 |
|
0341435e76ce
* process.c (sigchld_handler): Add comment about not calling malloc
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
53713
diff
changeset
|
6400 ** 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
|
6401 indirectly; if it does, that is a bug */ |
| 578 | 6402 |
|
71140
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6403 #ifdef SIGCHLD |
| 578 | 6404 SIGTYPE |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
6405 sigchld_handler (int signo) |
| 578 | 6406 { |
| 6407 int old_errno = errno; | |
| 6408 Lisp_Object proc; | |
|
109668
d9a022ec322c
Remove extern declarations in .c files, .h files have them.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109653
diff
changeset
|
6409 struct Lisp_Process *p; |
| 578 | 6410 |
|
58986
59945307b86b
* syssignal.h: Declare main_thread.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
58082
diff
changeset
|
6411 SIGNAL_THREAD_CHECK (signo); |
|
59945307b86b
* syssignal.h: Declare main_thread.
Jan Dj?rv <jan.h.d@swipnet.se>
parents:
58082
diff
changeset
|
6412 |
| 578 | 6413 while (1) |
| 6414 { | |
|
76493
e5e12c57c640
(sigchld_handler): Change type of pid to pid_t. Scan deleted_pid_list
Chong Yidong <cyd@stupidchicken.com>
parents:
76462
diff
changeset
|
6415 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
|
6416 int w; |
| 578 | 6417 Lisp_Object tail; |
| 6418 | |
| 6419 #ifdef WNOHANG | |
| 6420 #ifndef WUNTRACED | |
| 6421 #define WUNTRACED 0 | |
| 6422 #endif /* no WUNTRACED */ | |
| 6423 /* 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
|
6424 do |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
6425 { |
|
76494
f0a25b5d3ba0
(Fdelete_process): Properly handle deletion of first element of
Chong Yidong <cyd@stupidchicken.com>
parents:
76493
diff
changeset
|
6426 errno = 0; |
|
f0a25b5d3ba0
(Fdelete_process): Properly handle deletion of first element of
Chong Yidong <cyd@stupidchicken.com>
parents:
76493
diff
changeset
|
6427 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
|
6428 } |
|
76718
217f3f19f471
revert the last patch to the original fix: sleep BEFORE the first wait
Sam Steingold <sds@gnu.org>
parents:
76626
diff
changeset
|
6429 while (pid < 0 && errno == EINTR); |
| 578 | 6430 |
| 6431 if (pid <= 0) | |
| 6432 { | |
|
39361
2d3bee6a3848
(sigchld_handler): Use GC_CONSP, GC_INTEGERP, GC_EQ
Gerd Moellmann <gerd@gnu.org>
parents:
37758
diff
changeset
|
6433 /* 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
|
6434 failure. We have done all our job, so return. */ |
| 578 | 6435 |
| 6436 errno = old_errno; | |
| 6437 return; | |
| 6438 } | |
| 6439 #else | |
| 6440 pid = wait (&w); | |
| 6441 #endif /* no WNOHANG */ | |
| 6442 | |
| 6443 /* Find the process that signaled us, and record its status. */ | |
| 6444 | |
|
71140
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6445 /* 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
|
6446 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
|
6447 { |
|
76493
e5e12c57c640
(sigchld_handler): Change type of pid to pid_t. Scan deleted_pid_list
Chong Yidong <cyd@stupidchicken.com>
parents:
76462
diff
changeset
|
6448 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
|
6449 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
|
6450 || (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
|
6451 { |
|
e5e12c57c640
(sigchld_handler): Change type of pid to pid_t. Scan deleted_pid_list
Chong Yidong <cyd@stupidchicken.com>
parents:
76462
diff
changeset
|
6452 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
|
6453 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
|
6454 } |
|
71140
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6455 } |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6456 |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6457 /* Otherwise, if it is asynchronous, it is in Vprocess_alist. */ |
| 578 | 6458 p = 0; |
|
90970
3371fc48749b
Replace uses of GC_* macros with the non-GC_ versions.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
90851
diff
changeset
|
6459 for (tail = Vprocess_alist; CONSP (tail); tail = XCDR (tail)) |
| 578 | 6460 { |
|
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
6461 proc = XCDR (XCAR (tail)); |
| 578 | 6462 p = XPROCESS (proc); |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6463 if (EQ (p->type, Qreal) && p->pid == pid) |
| 578 | 6464 break; |
| 6465 p = 0; | |
| 6466 } | |
| 6467 | |
| 6468 /* Look for an asynchronous process whose pid hasn't been filled | |
| 6469 in yet. */ | |
| 6470 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
|
6471 for (tail = Vprocess_alist; CONSP (tail); tail = XCDR (tail)) |
| 578 | 6472 { |
|
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
6473 proc = XCDR (XCAR (tail)); |
| 578 | 6474 p = XPROCESS (proc); |
|
69873
2d844bbbccd4
* process.h (struct Lisp_Process): Replace Lisp_Objects `pid',
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
69634
diff
changeset
|
6475 if (p->pid == -1) |
| 578 | 6476 break; |
| 6477 p = 0; | |
| 6478 } | |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6479 |
| 578 | 6480 /* Change the status of the process that was found. */ |
| 6481 if (p != 0) | |
| 6482 { | |
|
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
6483 int clear_desc_flag = 0; |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6484 |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6485 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
|
6486 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
|
6487 p->raw_status_new = 1; |
|
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
49281
diff
changeset
|
6488 |
| 578 | 6489 /* 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
|
6490 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
|
6491 && p->infd >= 0) |
|
9793
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
6492 clear_desc_flag = 1; |
|
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
6493 |
|
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
6494 /* 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
|
6495 if (clear_desc_flag) |
|
28267fcc61be
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP,
Richard M. Stallman <rms@gnu.org>
parents:
9705
diff
changeset
|
6496 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6497 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
|
6498 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
|
6499 } |
|
1925
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
6500 |
|
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
6501 /* 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
|
6502 look around. */ |
|
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
6503 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
|
6504 EMACS_SET_SECS_USECS (*input_available_clear_time, 0, 0); |
| 578 | 6505 } |
| 6506 | |
|
71140
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6507 /* 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
|
6508 a synchronous process. */ |
| 578 | 6509 else |
| 6510 { | |
| 6511 synch_process_alive = 0; | |
| 6512 | |
| 6513 /* Report the status of the synchronous process. */ | |
| 6514 if (WIFEXITED (w)) | |
| 6515 synch_process_retcode = WRETCODE (w); | |
| 6516 else if (WIFSIGNALED (w)) | |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
6517 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
|
6518 |
|
56728
1686b397ef16
(wait_reading_process_output): Rename from
Kim F. Storm <storm@cua.dk>
parents:
56716
diff
changeset
|
6519 /* 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
|
6520 look around. */ |
|
3ddb163a9201
* process.c: Make sure we don't miss processes exiting, by having
Jim Blandy <jimb@redhat.com>
parents:
1886
diff
changeset
|
6521 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
|
6522 EMACS_SET_SECS_USECS (*input_available_clear_time, 0, 0); |
| 578 | 6523 } |
| 6524 | |
|
71140
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6525 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
|
6526 ; |
|
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6527 |
| 578 | 6528 /* On some systems, we must return right away. |
| 6529 If any more processes want to signal us, we will | |
| 6530 get another signal. | |
| 6531 Otherwise (on systems that have WNOHANG), loop around | |
| 6532 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
|
6533 #if (defined WINDOWSNT \ |
|
41969
e669966d496e
Test GNU_LINUX, not LINUX.
Richard M. Stallman <rms@gnu.org>
parents:
41856
diff
changeset
|
6534 || (defined USG && !defined GNU_LINUX \ |
|
100824
e5aa6a069f40
(conv_sockaddr_to_lisp): Add workaround for
Andreas Schwab <schwab@suse.de>
parents:
100573
diff
changeset
|
6535 && !(defined HPUX && defined WNOHANG))) |
| 578 | 6536 errno = old_errno; |
| 6537 return; | |
| 6538 #endif /* USG, but not HPUX with WNOHANG */ | |
| 6539 } | |
| 6540 } | |
|
71140
80310801887e
2006-06-01 Micha?l Cadilhac <michael.cadilhac@lrde.org>
Kim F. Storm <storm@cua.dk>
parents:
71109
diff
changeset
|
6541 #endif /* SIGCHLD */ |
| 578 | 6542 |
| 6543 | |
| 6544 static Lisp_Object | |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
6545 exec_sentinel_unwind (Lisp_Object data) |
| 578 | 6546 { |
|
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25356
diff
changeset
|
6547 XPROCESS (XCAR (data))->sentinel = XCDR (data); |
| 578 | 6548 return Qnil; |
| 6549 } | |
| 6550 | |
|
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6551 static Lisp_Object |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
6552 exec_sentinel_error_handler (Lisp_Object error) |
|
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6553 { |
|
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6554 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
|
6555 Vinhibit_quit = Qt; |
|
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6556 update_echo_area (); |
|
11277
d4547e4b0aab
(read_process_output_error_handler)
Richard M. Stallman <rms@gnu.org>
parents:
11235
diff
changeset
|
6557 Fsleep_for (make_number (2), Qnil); |
| 27558 | 6558 return Qt; |
|
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6559 } |
|
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6560 |
| 578 | 6561 static void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
6562 exec_sentinel (Lisp_Object proc, Lisp_Object reason) |
| 578 | 6563 { |
|
10914
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
6564 Lisp_Object sentinel, obuffer, odeactivate, okeymap; |
| 578 | 6565 register struct Lisp_Process *p = XPROCESS (proc); |
|
46293
1fb8f75062c6
Use macro SPECPDL_INDEX.
Juanma Barranquero <lekktu@gmail.com>
parents:
45410
diff
changeset
|
6566 int count = SPECPDL_INDEX (); |
|
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6567 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
|
6568 int waiting = waiting_for_user_input_p; |
| 578 | 6569 |
|
72727
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
6570 if (inhibit_sentinels) |
|
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
6571 return; |
|
5f2a73453aa3
(inhibit_sentinels): New variable.
Richard M. Stallman <rms@gnu.org>
parents:
72277
diff
changeset
|
6572 |
|
10914
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
6573 /* 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
|
6574 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
|
6575 odeactivate = Vdeactivate_mark; |
|
10914
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
6576 XSETBUFFER (obuffer, current_buffer); |
|
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
6577 okeymap = current_buffer->keymap; |
|
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
6578 |
|
107826
6438b98db9dd
* process.c (exec_sentinel): Preserve current-buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107825
diff
changeset
|
6579 /* There's no good reason to let sentinels change the current |
|
6438b98db9dd
* process.c (exec_sentinel): Preserve current-buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107825
diff
changeset
|
6580 buffer, and many callers of accept-process-output, sit-for, and |
|
6438b98db9dd
* process.c (exec_sentinel): Preserve current-buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107825
diff
changeset
|
6581 friends don't expect current-buffer to be changed from under them. */ |
|
108164
745e12b5af4a
Don't burp if process sentinel/filter kills the current buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107846
diff
changeset
|
6582 record_unwind_protect (set_buffer_if_live, Fcurrent_buffer ()); |
|
107826
6438b98db9dd
* process.c (exec_sentinel): Preserve current-buffer.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107825
diff
changeset
|
6583 |
| 578 | 6584 sentinel = p->sentinel; |
| 6585 if (NILP (sentinel)) | |
| 6586 return; | |
| 6587 | |
| 6588 /* Zilch the sentinel while it's running, to avoid recursive invocations; | |
| 6589 assure that it gets restored no matter how the sentinel exits. */ | |
| 6590 p->sentinel = Qnil; | |
| 6591 record_unwind_protect (exec_sentinel_unwind, Fcons (proc, sentinel)); | |
| 6592 /* Inhibit quit so that random quits don't screw up a running filter. */ | |
| 6593 specbind (Qinhibit_quit, Qt); | |
|
106397
210af1fb2669
(Qseqpacket): New symbol.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
106186
diff
changeset
|
6594 specbind (Qlast_nonmenu_event, Qt); /* Why? --Stef */ |
|
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6595 |
|
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6596 /* In case we get recursively called, |
|
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6597 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
|
6598 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
|
6599 if (outer_running_asynch_code) |
|
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6600 { |
|
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6601 Lisp_Object tem; |
|
63147
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
6602 tem = Fmatch_data (Qnil, Qnil, Qnil); |
|
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
6603 restore_search_regs (); |
|
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
6604 record_unwind_save_match_data (); |
|
9bde03db5726
* composite.c (compose_chars_in_text):
Kim F. Storm <storm@cua.dk>
parents:
63128
diff
changeset
|
6605 Fset_match_data (tem, Qt); |
|
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6606 } |
|
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6607 |
|
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6608 /* 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
|
6609 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
|
6610 running_asynch_code = 1; |
|
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6611 |
|
9030
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6612 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
|
6613 Fcons (sentinel, |
|
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6614 Fcons (proc, Fcons (reason, Qnil))), |
|
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6615 !NILP (Vdebug_on_error) ? Qnil : Qerror, |
|
b14532c71632
(exec_sentinel_error_handler): New function.
Richard M. Stallman <rms@gnu.org>
parents:
8570
diff
changeset
|
6616 exec_sentinel_error_handler); |
|
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6617 |
|
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6618 /* 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
|
6619 restore_search_regs (); |
|
16644
3a93437adce1
(status_notify): Test p->infd > 0
Richard M. Stallman <rms@gnu.org>
parents:
16464
diff
changeset
|
6620 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
|
6621 |
|
8d9e41a175fa
(exec_sentinel): Don't deactivate the mark. Check for asynch buffer switch.
Karl Heuer <kwzh@gnu.org>
parents:
7414
diff
changeset
|
6622 Vdeactivate_mark = odeactivate; |
|
23460
94f4ba741f22
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
23405
diff
changeset
|
6623 |
|
94f4ba741f22
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
23405
diff
changeset
|
6624 /* 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
|
6625 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
|
6626 waiting_for_user_input_p = waiting; |
|
94f4ba741f22
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
23405
diff
changeset
|
6627 |
|
12808
4db1f387e85f
(read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents:
12749
diff
changeset
|
6628 #if 0 |
|
10914
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
6629 if (! EQ (Fcurrent_buffer (), obuffer) |
|
413d44c0bd41
(exec_sentinel, read_process_output): If running filter
Richard M. Stallman <rms@gnu.org>
parents:
10744
diff
changeset
|
6630 || ! EQ (current_buffer->keymap, okeymap)) |
|
12808
4db1f387e85f
(read_process_output, exec_sentinel): Call
Richard M. Stallman <rms@gnu.org>
parents:
12749
diff
changeset
|
6631 #endif |
|
13159
2af96ac471bc
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
12808
diff
changeset
|
6632 /* 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
|
6633 Otherwise there's no need to make him wake up, and it could |
| 71762 | 6634 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
|
6635 if (waiting_for_user_input_p == -1) |
|
2af96ac471bc
(exec_sentinel, read_process_output):
Richard M. Stallman <rms@gnu.org>
parents:
12808
diff
changeset
|
6636 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
|
6637 |
|
5561
fd7524d61a8d
(read_process_output): Supply second arg to unbind_to.
Richard M. Stallman <rms@gnu.org>
parents:
5548
diff
changeset
|
6638 unbind_to (count, Qnil); |
| 578 | 6639 } |
| 6640 | |
| 6641 /* Report all recent events of a change in process status | |
| 6642 (either run the sentinel or output a message). | |
| 44372 | 6643 This is usually done while Emacs is waiting for keyboard input |
| 6644 but can be done at other times. */ | |
| 578 | 6645 |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
6646 static void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
6647 status_notify (struct Lisp_Process *deleting_process) |
| 578 | 6648 { |
| 6649 register Lisp_Object proc, buffer; | |
|
6515
df7438605e1e
(status_notify): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6429
diff
changeset
|
6650 Lisp_Object tail, msg; |
| 578 | 6651 struct gcpro gcpro1, gcpro2; |
| 6652 | |
|
6515
df7438605e1e
(status_notify): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6429
diff
changeset
|
6653 tail = Qnil; |
|
df7438605e1e
(status_notify): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6429
diff
changeset
|
6654 msg = Qnil; |
| 578 | 6655 /* We need to gcpro tail; if read_process_output calls a filter |
| 6656 which deletes a process and removes the cons to which tail points | |
| 6657 from Vprocess_alist, and then causes a GC, tail is an unprotected | |
| 6658 reference. */ | |
| 6659 GCPRO2 (tail, msg); | |
| 6660 | |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6661 /* 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
|
6662 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
|
6663 update_tick = process_tick; |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6664 |
|
85372
f7d19cfed7da
* xselect.c (x_own_selection, x_handle_selection_clear)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
85362
diff
changeset
|
6665 for (tail = Vprocess_alist; CONSP (tail); tail = XCDR (tail)) |
| 578 | 6666 { |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6667 Lisp_Object symbol; |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6668 register struct Lisp_Process *p; |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6669 |
|
85372
f7d19cfed7da
* xselect.c (x_own_selection, x_handle_selection_clear)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
85362
diff
changeset
|
6670 proc = Fcdr (XCAR (tail)); |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6671 p = XPROCESS (proc); |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6672 |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6673 if (p->tick != p->update_tick) |
| 578 | 6674 { |
|
81826
077a1e6fd3f2
(struct Lisp_Process): Turn slots infd, outfd, kill_without_query, pty_flag,
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
80984
diff
changeset
|
6675 p->update_tick = p->tick; |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6676 |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6677 /* 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
|
6678 while (! EQ (p->filter, Qt) |
|
43598
f49377cf2e3c
(Qconnect, Qfailed): New variables.
Kim F. Storm <storm@cua.dk>
parents:
42600
diff
changeset
|
6679 && ! EQ (p->status, Qconnect) |
|
43968
7ec801358b7e
(Qlocal, QCname, QCbuffer, QChost, QCservice, QCfamily)
Kim F. Storm <storm@cua.dk>
parents:
43642
diff
changeset
|
6680 && ! EQ (p->status, Qlisten) |
|
95884
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6681 /* Network or serial process not stopped: */ |
|
d6a4488883dc
Daniel Engeler <engeler at gmail.com>
Glenn Morris <rgm@gnu.org>
parents:
95387
diff
changeset
|
6682 && ! 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
|
6683 && p->infd >= 0 |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
6684 && 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
|
6685 && 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
|
6686 |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6687 buffer = p->buffer; |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6688 |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6689 /* 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
|
6690 if (p->raw_status_new) |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6691 update_status (p); |
|
55962
8979bc3ade70
(Fdelete_process): Undo 2004-05-28 change.
Kim F. Storm <storm@cua.dk>
parents:
55810
diff
changeset
|
6692 msg = status_message (p); |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6693 |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6694 /* 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
|
6695 symbol = p->status; |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6696 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
|
6697 symbol = XCAR (p->status); |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6698 |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6699 if (EQ (symbol, Qsignal) || EQ (symbol, Qexit) |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6700 || EQ (symbol, Qclosed)) |
| 578 | 6701 { |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6702 if (delete_exited_processes) |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6703 remove_process (proc); |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6704 else |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6705 deactivate_process (proc); |
| 578 | 6706 } |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6707 |
|
16464
c1f19d8e5b80
(status_notify): Update p->tick again
Richard M. Stallman <rms@gnu.org>
parents:
16220
diff
changeset
|
6708 /* 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
|
6709 So set p->update_tick again |
|
c1f19d8e5b80
(status_notify): Update p->tick again
Richard M. Stallman <rms@gnu.org>
parents:
16220
diff
changeset
|
6710 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
|
6711 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
|
6712 p->update_tick = p->tick; |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6713 /* Now output the message suitably. */ |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6714 if (!NILP (p->sentinel)) |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6715 exec_sentinel (proc, msg); |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6716 /* 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
|
6717 when a process becomes runnable. */ |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6718 else if (!EQ (symbol, Qrun) && !NILP (buffer)) |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6719 { |
|
107842
992ffbd77e15
* process.c (status_notify): Remove unused var `ro'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
107826
diff
changeset
|
6720 Lisp_Object tem; |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6721 struct buffer *old = current_buffer; |
|
110562
ea50a897140e
Fix int/EMACS_INT use in process.c and term.c.
Eli Zaretskii <eliz@gnu.org>
parents:
110556
diff
changeset
|
6722 EMACS_INT opoint, opoint_byte; |
|
ea50a897140e
Fix int/EMACS_INT use in process.c and term.c.
Eli Zaretskii <eliz@gnu.org>
parents:
110556
diff
changeset
|
6723 EMACS_INT before, before_byte; |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6724 |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6725 /* Avoid error if buffer is deleted |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6726 (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
|
6727 if (NILP (XBUFFER (buffer)->name)) |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6728 continue; |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6729 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
|
6730 |
|
16039
855c8d8ba0f0
Change all references from point to PT.
Karl Heuer <kwzh@gnu.org>
parents:
15895
diff
changeset
|
6731 opoint = PT; |
|
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6732 opoint_byte = PT_BYTE; |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6733 /* Insert new output into buffer |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6734 at the current end-of-output marker, |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6735 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
|
6736 if (XMARKER (p->mark)->buffer) |
|
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6737 Fgoto_char (p->mark); |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6738 else |
|
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6739 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
|
6740 |
|
77b137e2d9a7
(read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents:
17247
diff
changeset
|
6741 before = PT; |
|
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6742 before_byte = PT_BYTE; |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6743 |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6744 tem = current_buffer->read_only; |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6745 current_buffer->read_only = Qnil; |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6746 insert_string ("\nProcess "); |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6747 Finsert (1, &p->name); |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6748 insert_string (" "); |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6749 Finsert (1, &msg); |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6750 current_buffer->read_only = tem; |
|
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6751 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
|
6752 |
|
17604
77b137e2d9a7
(read_process_output): Update opoint, old_begv and old_zv
Richard M. Stallman <rms@gnu.org>
parents:
17247
diff
changeset
|
6753 if (opoint >= before) |
|
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6754 SET_PT_BOTH (opoint + (PT - before), |
|
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6755 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
|
6756 else |
|
20551
5f17380c85f1
(status_notify): Use byte and char pointers.
Richard M. Stallman <rms@gnu.org>
parents:
20433
diff
changeset
|
6757 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
|
6758 |
|
12215
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6759 set_buffer_internal (old); |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6760 } |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6761 } |
|
2f1f03964f08
(status_notify): Undo May 18 change.
Richard M. Stallman <rms@gnu.org>
parents:
12132
diff
changeset
|
6762 } /* end for */ |
| 578 | 6763 |
| 6764 update_mode_lines++; /* in case buffers use %s in mode-line-format */ | |
| 6765 UNGCPRO; | |
| 6766 } | |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6767 |
|
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6768 |
|
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6769 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
|
6770 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
|
6771 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
|
6772 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
|
6773 encode subprocess input. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
6774 (register Lisp_Object process, Lisp_Object decoding, Lisp_Object encoding) |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6775 { |
|
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6776 register struct Lisp_Process *p; |
|
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6777 |
|
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6778 CHECK_PROCESS (process); |
|
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6779 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
|
6780 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
|
6781 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
|
6782 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
|
6783 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
|
6784 Fcheck_coding_system (decoding); |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6785 Fcheck_coding_system (encoding); |
|
90392
8b24a6ec5090
(setup_process_coding_systems): Fix synching with
Kenichi Handa <handa@m17n.org>
parents:
90389
diff
changeset
|
6786 encoding = coding_inherit_eol_type (encoding, Qnil); |
|
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6787 p->decode_coding_system = decoding; |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6788 p->encode_coding_system = encoding; |
|
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6789 setup_process_coding_systems (process); |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6790 |
|
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6791 return Qnil; |
|
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6792 } |
|
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6793 |
|
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6794 DEFUN ("process-coding-system", |
|
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6795 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
|
6796 doc: /* Return a cons of coding systems for decoding and encoding of PROCESS. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
6797 (register Lisp_Object process) |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6798 { |
|
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6799 CHECK_PROCESS (process); |
|
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6800 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
|
6801 XPROCESS (process)->encode_coding_system); |
|
17041
b61cbe595be5
Include charset.h and coding.h.
Karl Heuer <kwzh@gnu.org>
parents:
16780
diff
changeset
|
6802 } |
|
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6803 |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6804 DEFUN ("set-process-filter-multibyte", Fset_process_filter_multibyte, |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6805 Sset_process_filter_multibyte, 2, 2, 0, |
| 49680 | 6806 doc: /* Set multibyteness of the strings given to PROCESS's filter. |
| 6807 If FLAG is non-nil, the filter is given multibyte strings. | |
| 6808 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
|
6809 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
|
6810 suppressed. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
6811 (Lisp_Object process, Lisp_Object flag) |
|
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6812 { |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6813 register struct Lisp_Process *p; |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6814 |
|
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6815 CHECK_PROCESS (process); |
|
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6816 p = XPROCESS (process); |
|
93201
5dbe361f12c2
* process.h (struct Lisp_Process): Remove filter_multibyte.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92266
diff
changeset
|
6817 if (NILP (flag)) |
|
5dbe361f12c2
* process.h (struct Lisp_Process): Remove filter_multibyte.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92266
diff
changeset
|
6818 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
|
6819 setup_process_coding_systems (process); |
|
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6820 |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6821 return Qnil; |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6822 } |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6823 |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6824 DEFUN ("process-filter-multibyte-p", Fprocess_filter_multibyte_p, |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6825 Sprocess_filter_multibyte_p, 1, 1, 0, |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6826 doc: /* Return t if a multibyte string is given to PROCESS's filter.*/) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
6827 (Lisp_Object process) |
|
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6828 { |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6829 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
|
6830 struct coding_system *coding; |
|
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6831 |
|
55444
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6832 CHECK_PROCESS (process); |
|
976d03256b41
(Fwaiting_for_user_input_p, Fmake_network_process)
Juanma Barranquero <lekktu@gmail.com>
parents:
53835
diff
changeset
|
6833 p = XPROCESS (process); |
|
93201
5dbe361f12c2
* process.h (struct Lisp_Process): Remove filter_multibyte.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92266
diff
changeset
|
6834 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
|
6835 return (CODING_FOR_UNIBYTE (coding) ? Qnil : Qt); |
|
49667
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6836 } |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6837 |
|
cbec1327e2f1
(QCfilter_multibyte): New variable.
Kenichi Handa <handa@m17n.org>
parents:
49600
diff
changeset
|
6838 |
| 578 | 6839 |
|
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
6840 |
|
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
6841 void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
6842 add_gpm_wait_descriptor (int desc) |
|
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
6843 { |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
6844 add_keyboard_wait_descriptor (desc); |
|
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
6845 } |
|
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
6846 |
|
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
6847 void |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
6848 delete_gpm_wait_descriptor (int desc) |
|
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
6849 { |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
6850 delete_keyboard_wait_descriptor (desc); |
|
80984
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
6851 } |
|
9247e9d47488
(gpm_wait_mask, max_gpm_desc): New variables.
Nick Roberts <nickrob@snap.net.nz>
parents:
77462
diff
changeset
|
6852 |
|
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
6853 /* Return nonzero if *MASK has a bit set |
|
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
6854 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
|
6855 |
|
64977
d26871fb1b7b
(deactivate_process, status_notify, read_process_output)
Kim F. Storm <storm@cua.dk>
parents:
64770
diff
changeset
|
6856 static int |
|
109144
7dceae91724c
Convert most remaining function definitions to standard C.
Juanma Barranquero <lekktu@gmail.com>
parents:
109100
diff
changeset
|
6857 keyboard_bit_set (fd_set *mask) |
|
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
6858 { |
|
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
6859 int fd; |
|
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
6860 |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
6861 for (fd = 0; fd <= max_input_desc; fd++) |
|
9686
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
6862 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
|
6863 && !FD_ISSET (fd, &non_keyboard_wait_mask)) |
|
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
6864 return 1; |
|
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
6865 |
|
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
6866 return 0; |
|
cd788aa8cb2a
Handle multiple keyboard input descriptors.
Richard M. Stallman <rms@gnu.org>
parents:
9334
diff
changeset
|
6867 } |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
6868 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
6869 #else /* not subprocesses */ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
6870 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
6871 /* Defined on msdos.c. */ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
6872 extern int sys_select (int, SELECT_TYPE *, SELECT_TYPE *, SELECT_TYPE *, |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
6873 EMACS_TIME *); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
6874 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
6875 /* Implementation of wait_reading_process_output, assuming that there |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
6876 are no subprocesses. Used only by the MS-DOS build. |
| 588 | 6877 |
| 6878 Wait for timeout to elapse and/or keyboard input to be available. | |
| 6879 | |
| 6880 time_limit is: | |
| 6881 timeout in seconds, or | |
| 6882 zero for no limit, or | |
| 6883 -1 means gobble data immediately available but don't wait for any. | |
| 6884 | |
| 650 | 6885 read_kbd is a Lisp_Object: |
| 588 | 6886 0 to ignore keyboard input, or |
| 6887 1 to return when input is available, or | |
| 6888 -1 means caller will actually read the input, so don't throw to | |
| 6889 the quit handler. | |
|
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
6890 |
|
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
6891 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
|
6892 always be NULL, since `subprocesses' isn't defined. |
| 588 | 6893 |
| 6894 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
|
6895 output that arrives. |
| 588 | 6896 |
| 78501 | 6897 Return true if we received input from any process. */ |
| 588 | 6898 |
| 6899 int | |
|
109370
a0caeaa02476
(wait_reading_process_output) [!subprocesses]: Convert arg list to ANSI C.
Eli Zaretskii <eliz@gnu.org>
parents:
109369
diff
changeset
|
6900 wait_reading_process_output (int time_limit, int microsecs, int read_kbd, |
|
a0caeaa02476
(wait_reading_process_output) [!subprocesses]: Convert arg list to ANSI C.
Eli Zaretskii <eliz@gnu.org>
parents:
109369
diff
changeset
|
6901 int do_display, |
|
a0caeaa02476
(wait_reading_process_output) [!subprocesses]: Convert arg list to ANSI C.
Eli Zaretskii <eliz@gnu.org>
parents:
109369
diff
changeset
|
6902 Lisp_Object wait_for_cell, |
|
a0caeaa02476
(wait_reading_process_output) [!subprocesses]: Convert arg list to ANSI C.
Eli Zaretskii <eliz@gnu.org>
parents:
109369
diff
changeset
|
6903 struct Lisp_Process *wait_proc, int just_wait_proc) |
| 588 | 6904 { |
|
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6905 register int nfds; |
|
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
6906 EMACS_TIME end_time, timeout; |
|
14278
3562c5f43780
(wait_reading_process_input) [not subprocesses]: Do
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
6907 SELECT_TYPE waitchannels; |
|
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
6908 int xerrno; |
| 588 | 6909 |
| 6910 /* What does time_limit really mean? */ | |
| 6911 if (time_limit || microsecs) | |
| 6912 { | |
| 6913 EMACS_GET_TIME (end_time); | |
|
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6914 EMACS_SET_SECS_USECS (timeout, time_limit, microsecs); |
| 588 | 6915 EMACS_ADD_TIME (end_time, end_time, timeout); |
| 6916 } | |
| 6917 | |
| 6918 /* 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
|
6919 and then turn off any other atimers, |
| 588 | 6920 because the select emulator uses alarms. */ |
|
47431
8871e67384e4
(wait_reading_process_input, both versions):
Richard M. Stallman <rms@gnu.org>
parents:
47020
diff
changeset
|
6921 stop_polling (); |
|
27430
1aa71680fe50
(toplevel): Include atimer.h.
Gerd Moellmann <gerd@gnu.org>
parents:
27028
diff
changeset
|
6922 turn_on_atimers (0); |
| 588 | 6923 |
|
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6924 while (1) |
| 588 | 6925 { |
|
14802
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6926 int timeout_reduced_for_timers = 0; |
| 588 | 6927 |
| 6928 /* If calling from keyboard input, do not quit | |
| 6929 since we want to return C-g as an input character. | |
| 6930 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
|
6931 if (read_kbd >= 0) |
| 588 | 6932 QUIT; |
| 6933 | |
|
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
6934 /* 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
|
6935 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
|
6936 break; |
|
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
6937 |
|
14802
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6938 /* 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
|
6939 /* Exit if already run out */ |
|
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6940 if (time_limit == -1) |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6941 { |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6942 /* -1 specified for timeout means |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6943 gobble output available now |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6944 but don't wait at all. */ |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6945 |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6946 EMACS_SET_SECS_USECS (timeout, 0, 0); |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6947 } |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6948 else if (time_limit || microsecs) |
| 588 | 6949 { |
|
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
6950 EMACS_GET_TIME (timeout); |
|
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
6951 EMACS_SUB_TIME (timeout, end_time, timeout); |
|
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
6952 if (EMACS_TIME_NEG_P (timeout)) |
| 588 | 6953 break; |
| 6954 } | |
|
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6955 else |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6956 { |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6957 EMACS_SET_SECS_USECS (timeout, 100000, 0); |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6958 } |
| 588 | 6959 |
|
14802
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6960 /* 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
|
6961 run timer events directly. |
|
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6962 (Callers that will immediately read keyboard events |
|
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6963 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
|
6964 if (NILP (wait_for_cell)) |
|
14802
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6965 { |
|
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6966 EMACS_TIME timer_delay; |
|
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
6967 |
|
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
6968 do |
|
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
6969 { |
|
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
6970 int old_timers_run = timers_run; |
|
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
6971 timer_delay = timer_check (1); |
|
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
6972 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
|
6973 /* 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
|
6974 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
|
6975 redisplay_preserve_echo_area (14); |
|
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
6976 else |
|
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
6977 break; |
|
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
6978 } |
|
34660
75866a7ebaec
(wait_reading_process_input): Check for pending
Gerd Moellmann <gerd@gnu.org>
parents:
34647
diff
changeset
|
6979 while (!detect_input_pending ()); |
|
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
6980 |
|
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6981 /* 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
|
6982 if (read_kbd != 0 |
|
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6983 && requeued_events_pending_p ()) |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6984 break; |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
6985 |
|
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
6986 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
|
6987 { |
|
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6988 EMACS_TIME difference; |
|
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
6989 EMACS_SUB_TIME (difference, timer_delay, timeout); |
|
14802
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6990 if (EMACS_TIME_NEG_P (difference)) |
|
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6991 { |
|
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
6992 timeout = timer_delay; |
|
14802
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6993 timeout_reduced_for_timers = 1; |
|
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6994 } |
|
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6995 } |
|
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6996 } |
|
45827a5afe4d
[!subprocesses] (wait_reading_process_input):
Richard M. Stallman <rms@gnu.org>
parents:
14785
diff
changeset
|
6997 |
| 588 | 6998 /* Cause C-g and alarm signals to take immediate action, |
| 6999 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
|
7000 if (read_kbd < 0) |
| 588 | 7001 set_waiting_for_input (&timeout); |
| 7002 | |
|
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7003 /* Wait till there is something to do. */ |
|
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7004 |
|
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7005 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
|
7006 FD_ZERO (&waitchannels); |
|
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7007 else |
|
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7008 FD_SET (0, &waitchannels); |
|
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7009 |
| 765 | 7010 /* If a frame has been newly mapped and needs updating, |
| 588 | 7011 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
|
7012 if (frame_garbaged && do_display) |
|
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7013 { |
|
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7014 clear_waiting_for_input (); |
|
35336
002c02db42d3
Call redisplay_preserve_echo_area with additional arg.
Gerd Moellmann <gerd@gnu.org>
parents:
34660
diff
changeset
|
7015 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
|
7016 if (read_kbd < 0) |
|
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7017 set_waiting_for_input (&timeout); |
|
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7018 } |
| 588 | 7019 |
|
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7020 if (read_kbd && detect_input_pending ()) |
|
15025
e5f54fd1c352
(wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents:
15021
diff
changeset
|
7021 { |
|
e5f54fd1c352
(wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents:
15021
diff
changeset
|
7022 nfds = 0; |
|
e5f54fd1c352
(wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents:
15021
diff
changeset
|
7023 FD_ZERO (&waitchannels); |
|
e5f54fd1c352
(wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents:
15021
diff
changeset
|
7024 } |
|
e5f54fd1c352
(wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents:
15021
diff
changeset
|
7025 else |
|
e5f54fd1c352
(wait_reading_process_input) [!subprocesses]:
Richard M. Stallman <rms@gnu.org>
parents:
15021
diff
changeset
|
7026 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
|
7027 &timeout); |
|
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7028 |
|
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7029 xerrno = errno; |
| 588 | 7030 |
| 7031 /* Make C-g and alarm signals set flags again */ | |
| 7032 clear_waiting_for_input (); | |
| 7033 | |
| 7034 /* 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
|
7035 do_pending_window_change (0); |
| 588 | 7036 |
|
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7037 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
|
7038 /* 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
|
7039 break; |
|
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7040 |
| 588 | 7041 if (nfds == -1) |
| 7042 { | |
| 7043 /* If the system call was interrupted, then go around the | |
| 7044 loop again. */ | |
|
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7045 if (xerrno == EINTR) |
|
14278
3562c5f43780
(wait_reading_process_input) [not subprocesses]: Do
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
7046 FD_ZERO (&waitchannels); |
|
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7047 else |
|
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
26019
diff
changeset
|
7048 error ("select error: %s", emacs_strerror (xerrno)); |
| 588 | 7049 } |
| 7050 | |
|
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7051 /* Check for keyboard input */ |
|
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7052 |
|
56716
c126b8b6a314
* process.c (wait_reading_process_input): Clean up.
Kim F. Storm <storm@cua.dk>
parents:
56713
diff
changeset
|
7053 if (read_kbd |
|
37413
49147b9fe206
(wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents:
37398
diff
changeset
|
7054 && detect_input_pending_run_timers (do_display)) |
|
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7055 { |
|
37413
49147b9fe206
(wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents:
37398
diff
changeset
|
7056 swallow_events (do_display); |
|
14806
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7057 if (detect_input_pending_run_timers (do_display)) |
|
232b90ad50e8
(wait_reading_process_input) [! subprocesses]: Run
Karl Heuer <kwzh@gnu.org>
parents:
14802
diff
changeset
|
7058 break; |
|
37413
49147b9fe206
(wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents:
37398
diff
changeset
|
7059 } |
|
49147b9fe206
(wait_reading_process_input) [!subprocesses]: Don't
Eli Zaretskii <eliz@gnu.org>
parents:
37398
diff
changeset
|
7060 |
|
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7061 /* 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
|
7062 if (read_kbd |
|
22535
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7063 && requeued_events_pending_p ()) |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7064 break; |
|
fd9324c5a498
(wait_reading_process_input): Recompute timeout each
Eli Zaretskii <eliz@gnu.org>
parents:
22523
diff
changeset
|
7065 |
|
15064
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7066 /* 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
|
7067 but don't run any timers. |
|
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7068 ??? (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
|
7069 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
|
7070 has been this way since July 1994. |
|
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7071 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
|
7072 if (! NILP (wait_for_cell) |
|
15064
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7073 && detect_input_pending ()) |
|
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7074 { |
|
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7075 swallow_events (do_display); |
|
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7076 if (detect_input_pending ()) |
|
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7077 break; |
|
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7078 } |
|
fb0f2804c34a
(wait_reading_process_input, both definitions):
Richard M. Stallman <rms@gnu.org>
parents:
15025
diff
changeset
|
7079 |
|
15021
af36df262fc5
(wait_reading_process_input) [!subprocesses]: Handle
Richard M. Stallman <rms@gnu.org>
parents:
14998
diff
changeset
|
7080 /* 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
|
7081 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
|
7082 break; |
| 588 | 7083 } |
| 7084 | |
|
2120
fc3cdca22f8d
* process.c (process_send_signal): In the TERMIOS code for sending
Jim Blandy <jimb@redhat.com>
parents:
1925
diff
changeset
|
7085 start_polling (); |
|
fc3cdca22f8d
* process.c (process_send_signal): In the TERMIOS code for sending
Jim Blandy <jimb@redhat.com>
parents:
1925
diff
changeset
|
7086 |
| 588 | 7087 return 0; |
| 7088 } | |
| 7089 | |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7090 #endif /* not subprocesses */ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7091 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7092 /* The following functions are needed even if async subprocesses are |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7093 not supported. Some of them are no-op stubs in that case. */ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7094 |
|
109376
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7095 /* Add DESC to the set of keyboard input descriptors. */ |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7096 |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7097 void |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7098 add_keyboard_wait_descriptor (int desc) |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7099 { |
|
110593
27428f586e5d
Reinstate ifdef subprocesses.
Jan D <jan.h.d@swipnet.se>
parents:
110592
diff
changeset
|
7100 #ifdef subprocesses /* actually means "not MSDOS" */ |
|
109376
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7101 FD_SET (desc, &input_wait_mask); |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7102 FD_SET (desc, &non_process_wait_mask); |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
7103 if (desc > max_input_desc) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
7104 max_input_desc = desc; |
|
110593
27428f586e5d
Reinstate ifdef subprocesses.
Jan D <jan.h.d@swipnet.se>
parents:
110592
diff
changeset
|
7105 #endif |
|
109376
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7106 } |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7107 |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7108 /* From now on, do not expect DESC to give keyboard input. */ |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7109 |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7110 void |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7111 delete_keyboard_wait_descriptor (int desc) |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7112 { |
|
110593
27428f586e5d
Reinstate ifdef subprocesses.
Jan D <jan.h.d@swipnet.se>
parents:
110592
diff
changeset
|
7113 #ifdef subprocesses |
|
109376
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7114 int fd; |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
7115 int lim = max_input_desc; |
|
109376
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7116 |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7117 FD_CLR (desc, &input_wait_mask); |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7118 FD_CLR (desc, &non_process_wait_mask); |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7119 |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
7120 if (desc == max_input_desc) |
|
109376
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7121 for (fd = 0; fd < lim; fd++) |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
7122 if (FD_ISSET (fd, &input_wait_mask) || FD_ISSET (fd, &write_mask)) |
|
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
7123 max_input_desc = fd; |
|
110593
27428f586e5d
Reinstate ifdef subprocesses.
Jan D <jan.h.d@swipnet.se>
parents:
110592
diff
changeset
|
7124 #endif |
|
109376
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7125 } |
|
409ecfd9731e
Remove subprocesses #ifdefs from term.c.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109370
diff
changeset
|
7126 |
|
109368
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7127 /* Setup coding systems of PROCESS. */ |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7128 |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7129 void |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7130 setup_process_coding_systems (Lisp_Object process) |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7131 { |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7132 #ifdef subprocesses |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7133 struct Lisp_Process *p = XPROCESS (process); |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7134 int inch = p->infd; |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7135 int outch = p->outfd; |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7136 Lisp_Object coding_system; |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7137 |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7138 if (inch < 0 || outch < 0) |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7139 return; |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7140 |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7141 if (!proc_decode_coding_system[inch]) |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7142 proc_decode_coding_system[inch] |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7143 = (struct coding_system *) xmalloc (sizeof (struct coding_system)); |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7144 coding_system = p->decode_coding_system; |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7145 if (! NILP (p->filter)) |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7146 ; |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7147 else if (BUFFERP (p->buffer)) |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7148 { |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7149 if (NILP (XBUFFER (p->buffer)->enable_multibyte_characters)) |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7150 coding_system = raw_text_coding_system (coding_system); |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7151 } |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7152 setup_coding_system (coding_system, proc_decode_coding_system[inch]); |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7153 |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7154 if (!proc_encode_coding_system[outch]) |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7155 proc_encode_coding_system[outch] |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7156 = (struct coding_system *) xmalloc (sizeof (struct coding_system)); |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7157 setup_coding_system (p->encode_coding_system, |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7158 proc_encode_coding_system[outch]); |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7159 #endif |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7160 } |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7161 |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7162 /* Close all descriptors currently in use for communication |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7163 with subprocess. This is used in a newly-forked subprocess |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7164 to get rid of irrelevant descriptors. */ |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7165 |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7166 void |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7167 close_process_descs (void) |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7168 { |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7169 #ifndef DOS_NT |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7170 int i; |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7171 for (i = 0; i < MAXDESC; i++) |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7172 { |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7173 Lisp_Object process; |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7174 process = chan_process[i]; |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7175 if (!NILP (process)) |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7176 { |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7177 int in = XPROCESS (process)->infd; |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7178 int out = XPROCESS (process)->outfd; |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7179 if (in >= 0) |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7180 emacs_close (in); |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7181 if (out >= 0 && in != out) |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7182 emacs_close (out); |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7183 } |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7184 } |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7185 #endif |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7186 } |
|
6d8c29fae125
Fix the MS-DOS build (fallout from revno 100791, 100794, 100795).
Eli Zaretskii <eliz@gnu.org>
parents:
109362
diff
changeset
|
7187 |
| 588 | 7188 DEFUN ("get-buffer-process", Fget_buffer_process, Sget_buffer_process, 1, 1, 0, |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7189 doc: /* Return the (or a) process associated with BUFFER. |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7190 BUFFER may be a buffer or the name of one. */) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7191 (register Lisp_Object buffer) |
| 588 | 7192 { |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7193 #ifdef subprocesses |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7194 register Lisp_Object buf, tail, proc; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7195 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7196 if (NILP (buffer)) return Qnil; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7197 buf = Fget_buffer (buffer); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7198 if (NILP (buf)) return Qnil; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7199 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7200 for (tail = Vprocess_alist; CONSP (tail); tail = XCDR (tail)) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7201 { |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7202 proc = Fcdr (XCAR (tail)); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7203 if (PROCESSP (proc) && EQ (XPROCESS (proc)->buffer, buf)) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7204 return proc; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7205 } |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7206 #endif /* subprocesses */ |
| 588 | 7207 return Qnil; |
| 7208 } | |
| 7209 | |
|
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7210 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
|
7211 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
|
7212 1, 1, 0, |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7213 doc: /* Return the value of inherit-coding-system flag for PROCESS. |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7214 If this flag is t, `buffer-file-coding-system' of the buffer |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7215 associated with PROCESS will inherit the coding system used to decode |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7216 the process output. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
7217 (register Lisp_Object process) |
|
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7218 { |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7219 #ifdef subprocesses |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7220 CHECK_PROCESS (process); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7221 return XPROCESS (process)->inherit_coding_system_flag ? Qt : Qnil; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7222 #else |
|
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7223 /* Ignore the argument and return the value of |
|
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7224 inherit-process-coding-system. */ |
|
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7225 return inherit_process_coding_system ? Qt : Qnil; |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7226 #endif |
|
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7227 } |
|
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7228 |
| 588 | 7229 /* Kill all processes associated with `buffer'. |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7230 If `buffer' is nil, kill all processes */ |
| 588 | 7231 |
|
21414
aac7354edaed
(kill_buffer_processes): Make consistent with
Karl Heuer <kwzh@gnu.org>
parents:
21281
diff
changeset
|
7232 void |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7233 kill_buffer_processes (Lisp_Object buffer) |
| 588 | 7234 { |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7235 #ifdef subprocesses |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7236 Lisp_Object tail, proc; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7237 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7238 for (tail = Vprocess_alist; CONSP (tail); tail = XCDR (tail)) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7239 { |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7240 proc = XCDR (XCAR (tail)); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7241 if (PROCESSP (proc) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7242 && (NILP (buffer) || EQ (XPROCESS (proc)->buffer, buffer))) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7243 { |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7244 if (NETCONN_P (proc) || SERIALCONN_P (proc)) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7245 Fdelete_process (proc); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7246 else if (XPROCESS (proc)->infd >= 0) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7247 process_send_signal (proc, SIGHUP, Qnil, 1); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7248 } |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7249 } |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7250 #else /* subprocesses */ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7251 /* Since we have no subprocesses, this does nothing. */ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7252 #endif /* subprocesses */ |
| 588 | 7253 } |
| 7254 | |
|
109378
4e99d7aa7526
Remove more "#ifdef subprocesses".
Eli Zaretskii <eliz@gnu.org>
parents:
109377
diff
changeset
|
7255 DEFUN ("waiting-for-user-input-p", Fwaiting_for_user_input_p, Swaiting_for_user_input_p, |
|
4e99d7aa7526
Remove more "#ifdef subprocesses".
Eli Zaretskii <eliz@gnu.org>
parents:
109377
diff
changeset
|
7256 0, 0, 0, |
|
4e99d7aa7526
Remove more "#ifdef subprocesses".
Eli Zaretskii <eliz@gnu.org>
parents:
109377
diff
changeset
|
7257 doc: /* Returns non-nil if Emacs is waiting for input from the user. |
|
4e99d7aa7526
Remove more "#ifdef subprocesses".
Eli Zaretskii <eliz@gnu.org>
parents:
109377
diff
changeset
|
7258 This is intended for use by asynchronous process output filters and sentinels. */) |
|
4e99d7aa7526
Remove more "#ifdef subprocesses".
Eli Zaretskii <eliz@gnu.org>
parents:
109377
diff
changeset
|
7259 (void) |
| 588 | 7260 { |
|
109378
4e99d7aa7526
Remove more "#ifdef subprocesses".
Eli Zaretskii <eliz@gnu.org>
parents:
109377
diff
changeset
|
7261 #ifdef subprocesses |
|
4e99d7aa7526
Remove more "#ifdef subprocesses".
Eli Zaretskii <eliz@gnu.org>
parents:
109377
diff
changeset
|
7262 return (waiting_for_user_input_p ? Qt : Qnil); |
|
4e99d7aa7526
Remove more "#ifdef subprocesses".
Eli Zaretskii <eliz@gnu.org>
parents:
109377
diff
changeset
|
7263 #else |
|
4e99d7aa7526
Remove more "#ifdef subprocesses".
Eli Zaretskii <eliz@gnu.org>
parents:
109377
diff
changeset
|
7264 return Qnil; |
|
4e99d7aa7526
Remove more "#ifdef subprocesses".
Eli Zaretskii <eliz@gnu.org>
parents:
109377
diff
changeset
|
7265 #endif |
| 588 | 7266 } |
| 7267 | |
|
109175
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7268 /* Stop reading input from keyboard sources. */ |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7269 |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7270 void |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7271 hold_keyboard_input (void) |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7272 { |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7273 kbd_is_on_hold = 1; |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7274 } |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7275 |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7276 /* Resume reading input from keyboard sources. */ |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7277 |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7278 void |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7279 unhold_keyboard_input (void) |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7280 { |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7281 kbd_is_on_hold = 0; |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7282 } |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7283 |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7284 /* Return non-zero if keyboard input is on hold, zero otherwise. */ |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7285 |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7286 int |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7287 kbd_on_hold_p (void) |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7288 { |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7289 return kbd_is_on_hold; |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7290 } |
|
fdb79ffbe27c
Fix MS-DOS build broken by revno 100745.
Eli Zaretskii <eliz@gnu.org>
parents:
109165
diff
changeset
|
7291 |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7292 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7293 /* Enumeration of and access to system processes a-la ps(1). */ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7294 |
|
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7295 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
|
7296 0, 0, 0, |
|
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7297 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
|
7298 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
|
7299 |
|
102205
0f4ba7f17aa0
Rename `system-process-attributes' to `process-attributes'
Miles Bader <miles@gnu.org>
parents:
101932
diff
changeset
|
7300 See `process-attributes' for getting attributes of a process given its ID. */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
7301 (void) |
|
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7302 { |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7303 return list_system_processes (); |
|
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7304 } |
|
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7305 |
|
102205
0f4ba7f17aa0
Rename `system-process-attributes' to `process-attributes'
Miles Bader <miles@gnu.org>
parents:
101932
diff
changeset
|
7306 DEFUN ("process-attributes", Fprocess_attributes, |
|
0f4ba7f17aa0
Rename `system-process-attributes' to `process-attributes'
Miles Bader <miles@gnu.org>
parents:
101932
diff
changeset
|
7307 Sprocess_attributes, 1, 1, 0, |
|
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7308 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
|
7309 |
|
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7310 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
|
7311 |
|
98084
cdd80926d2ea
(Fsystem_process_attributes): Doc fix.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
98062
diff
changeset
|
7312 \(KEY . VALUE) |
|
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7313 |
|
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7314 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
|
7315 |
|
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7316 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
|
7317 |
|
98084
cdd80926d2ea
(Fsystem_process_attributes): Doc fix.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
98062
diff
changeset
|
7318 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
|
7319 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
|
7320 Not all platforms support all of these attributes; unsupported |
|
115891550745
(Fsystem_process_attributes): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
97266
diff
changeset
|
7321 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
|
7322 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
|
7323 integer or floating point values. |
|
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7324 |
|
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7325 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
|
7326 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
|
7327 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
|
7328 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
|
7329 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
|
7330 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
|
7331 ppid -- Parent process ID (number) |
|
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7332 pgrp -- Process group ID (number) |
|
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7333 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
|
7334 ttname -- Controlling tty name (string) |
|
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7335 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
|
7336 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
|
7337 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
|
7338 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
|
7339 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
|
7340 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
|
7341 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
|
7342 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
|
7343 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
|
7344 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
|
7345 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
|
7346 pri -- priority of the process (number) |
|
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7347 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
|
7348 thcount -- process thread count (number) |
|
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7349 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
|
7350 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
|
7351 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
|
7352 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
|
7353 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
|
7354 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
|
7355 (floating-point number) |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7356 args -- command line which invoked the process (string). */) |
|
109179
8cfee7d2955f
Convert DEFUNs to standard C.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109175
diff
changeset
|
7357 ( Lisp_Object pid) |
|
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7358 { |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7359 return system_process_attributes (pid); |
|
97227
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7360 } |
|
1d85638347af
(Fsystem_processes_list, Fsystem_process_attributes): New functions.
Eli Zaretskii <eliz@gnu.org>
parents:
97142
diff
changeset
|
7361 |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7362 |
|
21978
ba8852d809f6
(init_process, syms_of_process): Make definition consistent with
Eli Zaretskii <eliz@gnu.org>
parents:
21950
diff
changeset
|
7363 void |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7364 init_process (void) |
| 588 | 7365 { |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7366 #ifdef subprocesses |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7367 register int i; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7368 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7369 inhibit_sentinels = 0; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7370 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7371 #ifdef SIGCHLD |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7372 #ifndef CANNOT_DUMP |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7373 if (! noninteractive || initialized) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7374 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7375 signal (SIGCHLD, sigchld_handler); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7376 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7377 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7378 FD_ZERO (&input_wait_mask); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7379 FD_ZERO (&non_keyboard_wait_mask); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7380 FD_ZERO (&non_process_wait_mask); |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
7381 FD_ZERO (&write_mask); |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7382 max_process_desc = 0; |
|
110592
c06958da83b5
Add fd handling with callbacks to select, dbus needs it for async operation.
Jan D <jan.h.d@swipnet.se>
parents:
110584
diff
changeset
|
7383 memset (fd_callback_info, 0, sizeof (fd_callback_info)); |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7384 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7385 #ifdef NON_BLOCKING_CONNECT |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7386 FD_ZERO (&connect_wait_mask); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7387 num_pending_connects = 0; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7388 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7389 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7390 #ifdef ADAPTIVE_READ_BUFFERING |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7391 process_output_delay_count = 0; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7392 process_output_skip = 0; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7393 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7394 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7395 /* Don't do this, it caused infinite select loops. The display |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7396 method should call add_keyboard_wait_descriptor on stdin if it |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7397 needs that. */ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7398 #if 0 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7399 FD_SET (0, &input_wait_mask); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7400 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7401 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7402 Vprocess_alist = Qnil; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7403 #ifdef SIGCHLD |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7404 deleted_pid_list = Qnil; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7405 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7406 for (i = 0; i < MAXDESC; i++) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7407 { |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7408 chan_process[i] = Qnil; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7409 proc_buffered_char[i] = -1; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7410 } |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7411 memset (proc_decode_coding_system, 0, sizeof proc_decode_coding_system); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7412 memset (proc_encode_coding_system, 0, sizeof proc_encode_coding_system); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7413 #ifdef DATAGRAM_SOCKETS |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7414 memset (datagram_address, 0, sizeof datagram_address); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7415 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7416 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7417 { |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7418 Lisp_Object subfeatures = Qnil; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7419 const struct socket_options *sopt; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7420 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7421 #define ADD_SUBFEATURE(key, val) \ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7422 subfeatures = pure_cons (pure_cons (key, pure_cons (val, Qnil)), subfeatures) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7423 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7424 #ifdef NON_BLOCKING_CONNECT |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7425 ADD_SUBFEATURE (QCnowait, Qt); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7426 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7427 #ifdef DATAGRAM_SOCKETS |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7428 ADD_SUBFEATURE (QCtype, Qdatagram); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7429 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7430 #ifdef HAVE_SEQPACKET |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7431 ADD_SUBFEATURE (QCtype, Qseqpacket); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7432 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7433 #ifdef HAVE_LOCAL_SOCKETS |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7434 ADD_SUBFEATURE (QCfamily, Qlocal); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7435 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7436 ADD_SUBFEATURE (QCfamily, Qipv4); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7437 #ifdef AF_INET6 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7438 ADD_SUBFEATURE (QCfamily, Qipv6); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7439 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7440 #ifdef HAVE_GETSOCKNAME |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7441 ADD_SUBFEATURE (QCservice, Qt); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7442 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7443 #if defined(O_NONBLOCK) || defined(O_NDELAY) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7444 ADD_SUBFEATURE (QCserver, Qt); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7445 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7446 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7447 for (sopt = socket_options; sopt->name; sopt++) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7448 subfeatures = pure_cons (intern_c_string (sopt->name), subfeatures); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7449 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7450 Fprovide (intern_c_string ("make-network-process"), subfeatures); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7451 } |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7452 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7453 #if defined (DARWIN_OS) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7454 /* PTYs are broken on Darwin < 6, but are sometimes useful for interactive |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7455 processes. As such, we only change the default value. */ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7456 if (initialized) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7457 { |
|
109726
64732fa6188a
Use const char* instead of char*.
Dan Nicolaescu <dann@ics.uci.edu>
parents:
109672
diff
changeset
|
7458 const char *release = get_operating_system_release (); |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7459 if (!release || !release[0] || (release[0] < MIN_PTY_KERNEL_VERSION |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7460 && release[1] == '.')) { |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7461 Vprocess_connection_type = Qnil; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7462 } |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7463 } |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7464 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7465 #endif /* subprocesses */ |
|
109164
a7b09b567d58
If kbd_buffer is becoming full, stop reading until it drains (Bug#6571).
Jan D <jan.h.d@swipnet.se>
parents:
109160
diff
changeset
|
7466 kbd_is_on_hold = 0; |
| 588 | 7467 } |
| 7468 | |
|
21978
ba8852d809f6
(init_process, syms_of_process): Make definition consistent with
Eli Zaretskii <eliz@gnu.org>
parents:
21950
diff
changeset
|
7469 void |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7470 syms_of_process (void) |
| 588 | 7471 { |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7472 #ifdef subprocesses |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7473 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7474 Qprocessp = intern_c_string ("processp"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7475 staticpro (&Qprocessp); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7476 Qrun = intern_c_string ("run"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7477 staticpro (&Qrun); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7478 Qstop = intern_c_string ("stop"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7479 staticpro (&Qstop); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7480 Qsignal = intern_c_string ("signal"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7481 staticpro (&Qsignal); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7482 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7483 /* Qexit is already staticpro'd by syms_of_eval; don't staticpro it |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7484 here again. |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7485 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7486 Qexit = intern_c_string ("exit"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7487 staticpro (&Qexit); */ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7488 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7489 Qopen = intern_c_string ("open"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7490 staticpro (&Qopen); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7491 Qclosed = intern_c_string ("closed"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7492 staticpro (&Qclosed); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7493 Qconnect = intern_c_string ("connect"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7494 staticpro (&Qconnect); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7495 Qfailed = intern_c_string ("failed"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7496 staticpro (&Qfailed); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7497 Qlisten = intern_c_string ("listen"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7498 staticpro (&Qlisten); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7499 Qlocal = intern_c_string ("local"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7500 staticpro (&Qlocal); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7501 Qipv4 = intern_c_string ("ipv4"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7502 staticpro (&Qipv4); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7503 #ifdef AF_INET6 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7504 Qipv6 = intern_c_string ("ipv6"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7505 staticpro (&Qipv6); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7506 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7507 Qdatagram = intern_c_string ("datagram"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7508 staticpro (&Qdatagram); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7509 Qseqpacket = intern_c_string ("seqpacket"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7510 staticpro (&Qseqpacket); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7511 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7512 QCport = intern_c_string (":port"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7513 staticpro (&QCport); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7514 QCspeed = intern_c_string (":speed"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7515 staticpro (&QCspeed); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7516 QCprocess = intern_c_string (":process"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7517 staticpro (&QCprocess); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7518 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7519 QCbytesize = intern_c_string (":bytesize"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7520 staticpro (&QCbytesize); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7521 QCstopbits = intern_c_string (":stopbits"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7522 staticpro (&QCstopbits); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7523 QCparity = intern_c_string (":parity"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7524 staticpro (&QCparity); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7525 Qodd = intern_c_string ("odd"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7526 staticpro (&Qodd); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7527 Qeven = intern_c_string ("even"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7528 staticpro (&Qeven); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7529 QCflowcontrol = intern_c_string (":flowcontrol"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7530 staticpro (&QCflowcontrol); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7531 Qhw = intern_c_string ("hw"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7532 staticpro (&Qhw); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7533 Qsw = intern_c_string ("sw"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7534 staticpro (&Qsw); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7535 QCsummary = intern_c_string (":summary"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7536 staticpro (&QCsummary); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7537 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7538 Qreal = intern_c_string ("real"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7539 staticpro (&Qreal); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7540 Qnetwork = intern_c_string ("network"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7541 staticpro (&Qnetwork); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7542 Qserial = intern_c_string ("serial"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7543 staticpro (&Qserial); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7544 QCbuffer = intern_c_string (":buffer"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7545 staticpro (&QCbuffer); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7546 QChost = intern_c_string (":host"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7547 staticpro (&QChost); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7548 QCservice = intern_c_string (":service"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7549 staticpro (&QCservice); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7550 QClocal = intern_c_string (":local"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7551 staticpro (&QClocal); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7552 QCremote = intern_c_string (":remote"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7553 staticpro (&QCremote); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7554 QCcoding = intern_c_string (":coding"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7555 staticpro (&QCcoding); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7556 QCserver = intern_c_string (":server"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7557 staticpro (&QCserver); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7558 QCnowait = intern_c_string (":nowait"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7559 staticpro (&QCnowait); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7560 QCsentinel = intern_c_string (":sentinel"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7561 staticpro (&QCsentinel); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7562 QClog = intern_c_string (":log"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7563 staticpro (&QClog); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7564 QCnoquery = intern_c_string (":noquery"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7565 staticpro (&QCnoquery); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7566 QCstop = intern_c_string (":stop"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7567 staticpro (&QCstop); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7568 QCoptions = intern_c_string (":options"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7569 staticpro (&QCoptions); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7570 QCplist = intern_c_string (":plist"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7571 staticpro (&QCplist); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7572 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7573 Qlast_nonmenu_event = intern_c_string ("last-nonmenu-event"); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7574 staticpro (&Qlast_nonmenu_event); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7575 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7576 staticpro (&Vprocess_alist); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7577 #ifdef SIGCHLD |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7578 staticpro (&deleted_pid_list); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7579 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7580 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7581 #endif /* subprocesses */ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7582 |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7583 QCname = intern_c_string (":name"); |
|
97650
8b1a761cfe61
[!subprocesses]: Define QCname.
Eli Zaretskii <eliz@gnu.org>
parents:
97498
diff
changeset
|
7584 staticpro (&QCname); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7585 QCtype = intern_c_string (":type"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7586 staticpro (&QCtype); |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7587 |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7588 Qeuid = intern_c_string ("euid"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7589 staticpro (&Qeuid); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7590 Qegid = intern_c_string ("egid"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7591 staticpro (&Qegid); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7592 Quser = intern_c_string ("user"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7593 staticpro (&Quser); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7594 Qgroup = intern_c_string ("group"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7595 staticpro (&Qgroup); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7596 Qcomm = intern_c_string ("comm"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7597 staticpro (&Qcomm); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7598 Qstate = intern_c_string ("state"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7599 staticpro (&Qstate); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7600 Qppid = intern_c_string ("ppid"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7601 staticpro (&Qppid); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7602 Qpgrp = intern_c_string ("pgrp"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7603 staticpro (&Qpgrp); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7604 Qsess = intern_c_string ("sess"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7605 staticpro (&Qsess); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7606 Qttname = intern_c_string ("ttname"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7607 staticpro (&Qttname); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7608 Qtpgid = intern_c_string ("tpgid"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7609 staticpro (&Qtpgid); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7610 Qminflt = intern_c_string ("minflt"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7611 staticpro (&Qminflt); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7612 Qmajflt = intern_c_string ("majflt"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7613 staticpro (&Qmajflt); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7614 Qcminflt = intern_c_string ("cminflt"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7615 staticpro (&Qcminflt); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7616 Qcmajflt = intern_c_string ("cmajflt"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7617 staticpro (&Qcmajflt); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7618 Qutime = intern_c_string ("utime"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7619 staticpro (&Qutime); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7620 Qstime = intern_c_string ("stime"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7621 staticpro (&Qstime); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7622 Qtime = intern_c_string ("time"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7623 staticpro (&Qtime); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7624 Qcutime = intern_c_string ("cutime"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7625 staticpro (&Qcutime); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7626 Qcstime = intern_c_string ("cstime"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7627 staticpro (&Qcstime); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7628 Qctime = intern_c_string ("ctime"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7629 staticpro (&Qctime); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7630 Qpri = intern_c_string ("pri"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7631 staticpro (&Qpri); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7632 Qnice = intern_c_string ("nice"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7633 staticpro (&Qnice); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7634 Qthcount = intern_c_string ("thcount"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7635 staticpro (&Qthcount); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7636 Qstart = intern_c_string ("start"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7637 staticpro (&Qstart); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7638 Qvsize = intern_c_string ("vsize"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7639 staticpro (&Qvsize); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7640 Qrss = intern_c_string ("rss"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7641 staticpro (&Qrss); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7642 Qetime = intern_c_string ("etime"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7643 staticpro (&Qetime); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7644 Qpcpu = intern_c_string ("pcpu"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7645 staticpro (&Qpcpu); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7646 Qpmem = intern_c_string ("pmem"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7647 staticpro (&Qpmem); |
|
105877
21bdda3ded62
* xterm.c (syms_of_xterm):
Dan Nicolaescu <dann@ics.uci.edu>
parents:
105872
diff
changeset
|
7648 Qargs = intern_c_string ("args"); |
|
100860
0d09a43201b6
(Qeuid, Qegid, Qcomm, Qstate, Qppid, Qpgrp, Qsess)
Eli Zaretskii <eliz@gnu.org>
parents:
100828
diff
changeset
|
7649 staticpro (&Qargs); |
|
44067
e8a136850817
(QCfeature, QCdatagram): Removed variables.
Kim F. Storm <storm@cua.dk>
parents:
44041
diff
changeset
|
7650 |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7651 DEFVAR_BOOL ("delete-exited-processes", &delete_exited_processes, |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7652 doc: /* *Non-nil means delete processes immediately when they exit. |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7653 A value of nil means don't delete them until `list-processes' is run. */); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7654 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7655 delete_exited_processes = 1; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7656 |
|
109305
33b59bdb0ac4
Don't use `subprocesses' in msdos.c.
Eli Zaretskii <eliz@gnu.org>
parents:
109188
diff
changeset
|
7657 #ifdef subprocesses |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7658 DEFVAR_LISP ("process-connection-type", &Vprocess_connection_type, |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7659 doc: /* Control type of device used to communicate with subprocesses. |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7660 Values are nil to use a pipe, or t or `pty' to use a pty. |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7661 The value has no effect if the system has no ptys or if all ptys are busy: |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7662 then a pipe is used in any case. |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7663 The value takes effect when `start-process' is called. */); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7664 Vprocess_connection_type = Qt; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7665 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7666 #ifdef ADAPTIVE_READ_BUFFERING |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7667 DEFVAR_LISP ("process-adaptive-read-buffering", &Vprocess_adaptive_read_buffering, |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7668 doc: /* If non-nil, improve receive buffering by delaying after short reads. |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7669 On some systems, when Emacs reads the output from a subprocess, the output data |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7670 is read in very small blocks, potentially resulting in very poor performance. |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7671 This behavior can be remedied to some extent by setting this variable to a |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7672 non-nil value, as it will automatically delay reading from such processes, to |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7673 allow them to produce more output before Emacs tries to read it. |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7674 If the value is t, the delay is reset after each write to the process; any other |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7675 non-nil value means that the delay is not reset on write. |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7676 The variable takes effect when `start-process' is called. */); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7677 Vprocess_adaptive_read_buffering = Qt; |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7678 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7679 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7680 defsubr (&Sprocessp); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7681 defsubr (&Sget_process); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7682 defsubr (&Sdelete_process); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7683 defsubr (&Sprocess_status); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7684 defsubr (&Sprocess_exit_status); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7685 defsubr (&Sprocess_id); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7686 defsubr (&Sprocess_name); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7687 defsubr (&Sprocess_tty_name); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7688 defsubr (&Sprocess_command); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7689 defsubr (&Sset_process_buffer); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7690 defsubr (&Sprocess_buffer); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7691 defsubr (&Sprocess_mark); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7692 defsubr (&Sset_process_filter); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7693 defsubr (&Sprocess_filter); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7694 defsubr (&Sset_process_sentinel); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7695 defsubr (&Sprocess_sentinel); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7696 defsubr (&Sset_process_window_size); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7697 defsubr (&Sset_process_inherit_coding_system_flag); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7698 defsubr (&Sset_process_query_on_exit_flag); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7699 defsubr (&Sprocess_query_on_exit_flag); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7700 defsubr (&Sprocess_contact); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7701 defsubr (&Sprocess_plist); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7702 defsubr (&Sset_process_plist); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7703 defsubr (&Slist_processes); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7704 defsubr (&Sprocess_list); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7705 defsubr (&Sstart_process); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7706 defsubr (&Sserial_process_configure); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7707 defsubr (&Smake_serial_process); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7708 defsubr (&Sset_network_process_option); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7709 defsubr (&Smake_network_process); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7710 defsubr (&Sformat_network_address); |
| 109640 | 7711 #if defined(HAVE_NET_IF_H) && defined(HAVE_SYS_IOCTL_H) |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7712 #ifdef SIOCGIFCONF |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7713 defsubr (&Snetwork_interface_list); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7714 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7715 #if defined(SIOCGIFADDR) || defined(SIOCGIFHWADDR) || defined(SIOCGIFFLAGS) |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7716 defsubr (&Snetwork_interface_info); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7717 #endif |
| 109640 | 7718 #endif /* defined(HAVE_NET_IF_H) && defined(HAVE_SYS_IOCTL_H) */ |
|
109188
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7719 #ifdef DATAGRAM_SOCKETS |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7720 defsubr (&Sprocess_datagram_address); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7721 defsubr (&Sset_process_datagram_address); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7722 #endif |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7723 defsubr (&Saccept_process_output); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7724 defsubr (&Sprocess_send_region); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7725 defsubr (&Sprocess_send_string); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7726 defsubr (&Sinterrupt_process); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7727 defsubr (&Skill_process); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7728 defsubr (&Squit_process); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7729 defsubr (&Sstop_process); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7730 defsubr (&Scontinue_process); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7731 defsubr (&Sprocess_running_child_p); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7732 defsubr (&Sprocess_send_eof); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7733 defsubr (&Ssignal_process); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7734 defsubr (&Swaiting_for_user_input_p); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7735 defsubr (&Sprocess_type); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7736 defsubr (&Sset_process_coding_system); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7737 defsubr (&Sprocess_coding_system); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7738 defsubr (&Sset_process_filter_multibyte); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7739 defsubr (&Sprocess_filter_multibyte_p); |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7740 |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7741 #endif /* subprocesses */ |
|
ff3561236472
Unify the two branches, with and without subprocesses.
Eli Zaretskii <eliz@gnu.org>
parents:
109179
diff
changeset
|
7742 |
| 588 | 7743 defsubr (&Sget_buffer_process); |
|
21656
bb39a5863a82
(Fset_process_inherit_coding_system_flag,
Eli Zaretskii <eliz@gnu.org>
parents:
21530
diff
changeset
|
7744 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
|
7745 defsubr (&Slist_system_processes); |
|
102205
0f4ba7f17aa0
Rename `system-process-attributes' to `process-attributes'
Miles Bader <miles@gnu.org>
parents:
101932
diff
changeset
|
7746 defsubr (&Sprocess_attributes); |
| 588 | 7747 } |
| 7748 | |
| 52401 | 7749 /* arch-tag: 3706c011-7b9a-4117-bd4f-59e7f701a4c4 |
| 7750 (do not change this comment) */ |
