annotate src/ntproc.c @ 247:e70b3a057e12 r20-5b22

Import from CVS: tag r20-5b22
author cvs
date Mon, 13 Aug 2007 10:18:21 +0200
parents 41f2f0e326e9
children 727739f917cb
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1 /* Process support for Windows NT port of XEMACS.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
2 Copyright (C) 1992, 1995 Free Software Foundation, Inc.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
3
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
4 This file is part of XEmacs.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
5
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
6 XEmacs is free software; you can redistribute it and/or modify it
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
7 under the terms of the GNU General Public License as published by the
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
8 Free Software Foundation; either version 2, or (at your option) any
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
9 later version.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
10
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
11 XEmacs is distributed in the hope that it will be useful, but WITHOUT
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
12 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
14 for more details.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
15
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
16 You should have received a copy of the GNU General Public License
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
17 along with XEmacs; see the file COPYING. If not, write to
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
19 Boston, MA 02111-1307, USA.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
20
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
21 Drew Bliss Oct 14, 1993
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
22 Adapted from alarm.c by Tim Fleehart */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
23
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
24 /* Adapted for XEmacs by David Hobley <david@spook-le0.cia.com.au> */
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
25 /* Synced with FSF Emacs 19.34.6 by Marc Paquette <marcpa@cam.org> */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
26
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
27 #include <stdio.h>
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
28 #include <stdlib.h>
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
29 #include <errno.h>
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
30 #include <io.h>
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
31 #include <fcntl.h>
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
32 #include <signal.h>
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
33
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
34 /* must include CRT headers *before* config.h */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
35 #include "config.h"
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
36 #undef signal
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
37 #undef wait
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
38 #undef spawnve
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
39 #undef select
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
40 #undef kill
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
41
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
42 #include <windows.h>
239
41f2f0e326e9 Import from CVS: tag r20-5b18
cvs
parents: 223
diff changeset
43 #include <sys/socket.h>
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
44
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
45 #include "lisp.h"
239
41f2f0e326e9 Import from CVS: tag r20-5b18
cvs
parents: 223
diff changeset
46 #include "sysproc.h"
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
47 #include "nt.h"
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
48 #include "ntheap.h" /* From 19.34.6 */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
49 #include "systime.h"
223
2c611d1463a6 Import from CVS: tag r20-4b10
cvs
parents: 209
diff changeset
50 #include "syssignal.h"
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
51 #include "syswait.h"
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
52 #include "process.h"
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
53 /*#include "w32term.h"*/ /* From 19.34.6: sync in ? --marcpa */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
54
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
55 /* Control whether spawnve quotes arguments as necessary to ensure
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
56 correct parsing by child process. Because not all uses of spawnve
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
57 are careful about constructing argv arrays, we make this behaviour
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
58 conditional (off by default). */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
59 Lisp_Object Vwin32_quote_process_args;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
60
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
61 /* Control whether create_child causes the process' window to be
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
62 hidden. The default is nil. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
63 Lisp_Object Vwin32_start_process_show_window;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
64
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
65 /* Control whether create_child causes the process to inherit Emacs'
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
66 console window, or be given a new one of its own. The default is
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
67 nil, to allow multiple DOS programs to run on Win95. Having separate
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
68 consoles also allows Emacs to cleanly terminate process groups. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
69 Lisp_Object Vwin32_start_process_share_console;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
70
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
71 /* Time to sleep before reading from a subprocess output pipe - this
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
72 avoids the inefficiency of frequently reading small amounts of data.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
73 This is primarily necessary for handling DOS processes on Windows 95,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
74 but is useful for Win32 processes on both Win95 and NT as well. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
75 Lisp_Object Vwin32_pipe_read_delay;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
76
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
77 /* Control conversion of upper case file names to lower case.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
78 nil means no, t means yes. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
79 Lisp_Object Vwin32_downcase_file_names;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
80
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
81 /* Control whether stat() attempts to generate fake but hopefully
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
82 "accurate" inode values, by hashing the absolute truenames of files.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
83 This should detect aliasing between long and short names, but still
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
84 allows the possibility of hash collisions. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
85 Lisp_Object Vwin32_generate_fake_inodes;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
86
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
87 /* Control whether stat() attempts to determine file type and link count
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
88 exactly, at the expense of slower operation. Since true hard links
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
89 are supported on NTFS volumes, this is only relevant on NT. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
90 Lisp_Object Vwin32_get_true_file_attributes;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
91
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
92 Lisp_Object Qhigh, Qlow;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
93
239
41f2f0e326e9 Import from CVS: tag r20-5b18
cvs
parents: 223
diff changeset
94 #ifndef DEBUG_XEMACS
41f2f0e326e9 Import from CVS: tag r20-5b18
cvs
parents: 223
diff changeset
95 __inline
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
96 #endif
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
97 void _DebPrint (const char *fmt, ...)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
98 {
239
41f2f0e326e9 Import from CVS: tag r20-5b18
cvs
parents: 223
diff changeset
99 #ifdef DEBUG_XEMACS
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
100 char buf[1024];
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
101 va_list args;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
102
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
103 va_start (args, fmt);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
104 vsprintf (buf, fmt, args);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
105 va_end (args);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
106 OutputDebugString (buf);
239
41f2f0e326e9 Import from CVS: tag r20-5b18
cvs
parents: 223
diff changeset
107 #endif
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
108 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
109
223
2c611d1463a6 Import from CVS: tag r20-4b10
cvs
parents: 209
diff changeset
110 /* sys_signal moved to nt.c. It's now called msw_signal... */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
111
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
112 /* Defined in <process.h> which conflicts with the local copy */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
113 #define _P_NOWAIT 1
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
114
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
115 /* Child process management list. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
116 int child_proc_count = 0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
117 child_process child_procs[ MAX_CHILDREN ];
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
118 child_process *dead_child = NULL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
119
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
120 DWORD WINAPI reader_thread (void *arg);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
121
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
122 /* Find an unused process slot. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
123 child_process *
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
124 new_child (void)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
125 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
126 child_process *cp;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
127 DWORD id;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
128
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
129 for (cp = child_procs+(child_proc_count-1); cp >= child_procs; cp--)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
130 if (!CHILD_ACTIVE (cp))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
131 goto Initialise;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
132 if (child_proc_count == MAX_CHILDREN)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
133 return NULL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
134 cp = &child_procs[child_proc_count++];
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
135
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
136 Initialise:
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
137 memset (cp, 0, sizeof(*cp));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
138 cp->fd = -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
139 cp->pid = -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
140 cp->procinfo.hProcess = NULL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
141 cp->status = STATUS_READ_ERROR;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
142
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
143 /* use manual reset event so that select() will function properly */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
144 cp->char_avail = CreateEvent (NULL, TRUE, FALSE, NULL);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
145 if (cp->char_avail)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
146 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
147 cp->char_consumed = CreateEvent (NULL, FALSE, FALSE, NULL);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
148 if (cp->char_consumed)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
149 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
150 cp->thrd = CreateThread (NULL, 1024, reader_thread, cp, 0, &id);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
151 if (cp->thrd)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
152 return cp;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
153 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
154 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
155 delete_child (cp);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
156 return NULL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
157 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
158
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
159 void
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
160 delete_child (child_process *cp)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
161 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
162 int i;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
163
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
164 /* Should not be deleting a child that is still needed. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
165 for (i = 0; i < MAXDESC; i++)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
166 if (fd_info[i].cp == cp)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
167 abort ();
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
168
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
169 if (!CHILD_ACTIVE (cp))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
170 return;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
171
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
172 /* reap thread if necessary */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
173 if (cp->thrd)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
174 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
175 DWORD rc;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
176
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
177 if (GetExitCodeThread (cp->thrd, &rc) && rc == STILL_ACTIVE)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
178 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
179 /* let the thread exit cleanly if possible */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
180 cp->status = STATUS_READ_ERROR;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
181 SetEvent (cp->char_consumed);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
182 if (WaitForSingleObject (cp->thrd, 1000) != WAIT_OBJECT_0)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
183 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
184 DebPrint (("delete_child.WaitForSingleObject (thread) failed "
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
185 "with %lu for fd %ld\n", GetLastError (), cp->fd));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
186 TerminateThread (cp->thrd, 0);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
187 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
188 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
189 CloseHandle (cp->thrd);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
190 cp->thrd = NULL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
191 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
192 if (cp->char_avail)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
193 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
194 CloseHandle (cp->char_avail);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
195 cp->char_avail = NULL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
196 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
197 if (cp->char_consumed)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
198 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
199 CloseHandle (cp->char_consumed);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
200 cp->char_consumed = NULL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
201 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
202
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
203 /* update child_proc_count (highest numbered slot in use plus one) */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
204 if (cp == child_procs + child_proc_count - 1)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
205 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
206 for (i = child_proc_count-1; i >= 0; i--)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
207 if (CHILD_ACTIVE (&child_procs[i]))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
208 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
209 child_proc_count = i + 1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
210 break;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
211 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
212 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
213 if (i < 0)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
214 child_proc_count = 0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
215 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
216
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
217 /* Find a child by pid. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
218 static child_process *
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
219 find_child_pid (DWORD pid)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
220 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
221 child_process *cp;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
222
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
223 for (cp = child_procs+(child_proc_count-1); cp >= child_procs; cp--)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
224 if (CHILD_ACTIVE (cp) && pid == cp->pid)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
225 return cp;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
226 return NULL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
227 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
228
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
229
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
230 /* Thread proc for child process and socket reader threads. Each thread
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
231 is normally blocked until woken by select() to check for input by
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
232 reading one char. When the read completes, char_avail is signalled
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
233 to wake up the select emulator and the thread blocks itself again. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
234 DWORD WINAPI
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
235 reader_thread (void *arg)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
236 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
237 child_process *cp;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
238
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
239 /* Our identity */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
240 cp = (child_process *)arg;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
241
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
242 /* We have to wait for the go-ahead before we can start */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
243 if (cp == NULL ||
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
244 WaitForSingleObject (cp->char_consumed, INFINITE) != WAIT_OBJECT_0)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
245 return 1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
246
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
247 for (;;)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
248 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
249 int rc;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
250
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
251 rc = _sys_read_ahead (cp->fd);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
252
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
253 /* The name char_avail is a misnomer - it really just means the
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
254 read-ahead has completed, whether successfully or not. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
255 if (!SetEvent (cp->char_avail))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
256 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
257 DebPrint (("reader_thread.SetEvent failed with %lu for fd %ld\n",
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
258 GetLastError (), cp->fd));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
259 return 1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
260 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
261
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
262 if (rc == STATUS_READ_ERROR)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
263 return 1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
264
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
265 /* If the read died, the child has died so let the thread die */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
266 if (rc == STATUS_READ_FAILED)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
267 break;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
268
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
269 /* Wait until our input is acknowledged before reading again */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
270 if (WaitForSingleObject (cp->char_consumed, INFINITE) != WAIT_OBJECT_0)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
271 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
272 DebPrint (("reader_thread.WaitForSingleObject failed with "
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
273 "%lu for fd %ld\n", GetLastError (), cp->fd));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
274 break;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
275 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
276 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
277 return 0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
278 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
279
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
280 /* To avoid Emacs changing directory, we just record here the directory
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
281 the new process should start in. This is set just before calling
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
282 sys_spawnve, and is not generally valid at any other time. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
283 static char * process_dir;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
284
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
285 static BOOL
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
286 create_child (char *exe, char *cmdline, char *env,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
287 int * pPid, child_process *cp)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
288 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
289 STARTUPINFO start;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
290 SECURITY_ATTRIBUTES sec_attrs;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
291 SECURITY_DESCRIPTOR sec_desc;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
292 char dir[ MAXPATHLEN ];
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
293
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
294 if (cp == NULL) abort ();
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
295
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
296 memset (&start, 0, sizeof (start));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
297 start.cb = sizeof (start);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
298
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
299 #ifdef HAVE_NTGUI
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
300 if (NILP (Vwin32_start_process_show_window))
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
301 start.dwFlags = STARTF_USESTDHANDLES | STARTF_USESHOWWINDOW;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
302 else
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
303 start.dwFlags = STARTF_USESTDHANDLES;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
304 start.wShowWindow = SW_HIDE;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
305
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
306 start.hStdInput = GetStdHandle (STD_INPUT_HANDLE);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
307 start.hStdOutput = GetStdHandle (STD_OUTPUT_HANDLE);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
308 start.hStdError = GetStdHandle (STD_ERROR_HANDLE);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
309 #endif /* HAVE_NTGUI */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
310
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
311 /* Explicitly specify no security */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
312 if (!InitializeSecurityDescriptor (&sec_desc, SECURITY_DESCRIPTOR_REVISION))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
313 goto EH_Fail;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
314 if (!SetSecurityDescriptorDacl (&sec_desc, TRUE, NULL, FALSE))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
315 goto EH_Fail;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
316 sec_attrs.nLength = sizeof (sec_attrs);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
317 sec_attrs.lpSecurityDescriptor = &sec_desc;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
318 sec_attrs.bInheritHandle = FALSE;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
319
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
320 strcpy (dir, process_dir);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
321 unixtodos_filename (dir);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
322
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
323 if (!CreateProcess (exe, cmdline, &sec_attrs, NULL, TRUE,
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
324 (!NILP (Vwin32_start_process_share_console)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
325 ? CREATE_NEW_PROCESS_GROUP
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
326 : CREATE_NEW_CONSOLE),
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
327 env, dir,
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
328 &start, &cp->procinfo))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
329 goto EH_Fail;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
330
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
331 cp->pid = (int) cp->procinfo.dwProcessId;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
332
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
333 /* Hack for Windows 95, which assigns large (ie negative) pids */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
334 if (cp->pid < 0)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
335 cp->pid = -cp->pid;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
336
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
337 /* pid must fit in a Lisp_Int */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
338 cp->pid = (cp->pid & VALMASK);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
339
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
340 *pPid = cp->pid;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
341
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
342 return TRUE;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
343
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
344 EH_Fail:
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
345 DebPrint (("create_child.CreateProcess failed: %ld\n", GetLastError()););
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
346 return FALSE;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
347 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
348
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
349 /* create_child doesn't know what emacs' file handle will be for waiting
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
350 on output from the child, so we need to make this additional call
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
351 to register the handle with the process
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
352 This way the select emulator knows how to match file handles with
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
353 entries in child_procs. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
354 void
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
355 register_child (int pid, int fd)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
356 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
357 child_process *cp;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
358
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
359 cp = find_child_pid (pid);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
360 if (cp == NULL)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
361 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
362 DebPrint (("register_child unable to find pid %lu\n", pid));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
363 return;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
364 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
365
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
366 #ifdef FULL_DEBUG
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
367 DebPrint (("register_child registered fd %d with pid %lu\n", fd, pid));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
368 #endif
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
369
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
370 cp->fd = fd;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
371
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
372 /* thread is initially blocked until select is called; set status so
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
373 that select will release thread */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
374 cp->status = STATUS_READ_ACKNOWLEDGED;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
375
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
376 /* attach child_process to fd_info */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
377 if (fd_info[fd].cp != NULL)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
378 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
379 DebPrint (("register_child: fd_info[%d] apparently in use!\n", fd));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
380 abort ();
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
381 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
382
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
383 fd_info[fd].cp = cp;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
384 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
385
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
386 /* When a process dies its pipe will break so the reader thread will
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
387 signal failure to the select emulator.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
388 The select emulator then calls this routine to clean up.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
389 Since the thread signaled failure we can assume it is exiting. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
390 static void
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
391 reap_subprocess (child_process *cp)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
392 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
393 if (cp->procinfo.hProcess)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
394 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
395 /* Reap the process */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
396 if (WaitForSingleObject (cp->procinfo.hProcess, INFINITE) != WAIT_OBJECT_0)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
397 DebPrint (("reap_subprocess.WaitForSingleObject (process) failed "
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
398 "with %lu for fd %ld\n", GetLastError (), cp->fd));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
399 CloseHandle (cp->procinfo.hProcess);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
400 cp->procinfo.hProcess = NULL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
401 CloseHandle (cp->procinfo.hThread);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
402 cp->procinfo.hThread = NULL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
403 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
404
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
405 /* For asynchronous children, the child_proc resources will be freed
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
406 when the last pipe read descriptor is closed; for synchronous
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
407 children, we must explicitly free the resources now because
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
408 register_child has not been called. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
409 if (cp->fd == -1)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
410 delete_child (cp);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
411 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
412
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
413 /* Wait for any of our existing child processes to die
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
414 When it does, close its handle
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
415 Return the pid and fill in the status if non-NULL. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
416
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
417 int
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
418 sys_wait (int *status)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
419 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
420 DWORD active, retval;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
421 int nh;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
422 int pid;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
423 child_process *cp, *cps[MAX_CHILDREN];
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
424 HANDLE wait_hnd[MAX_CHILDREN];
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
425
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
426 nh = 0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
427 if (dead_child != NULL)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
428 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
429 /* We want to wait for a specific child */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
430 wait_hnd[nh] = dead_child->procinfo.hProcess;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
431 cps[nh] = dead_child;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
432 if (!wait_hnd[nh]) abort ();
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
433 nh++;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
434 active = 0;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
435 goto get_result;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
436 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
437 else
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
438 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
439 for (cp = child_procs+(child_proc_count-1); cp >= child_procs; cp--)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
440 /* some child_procs might be sockets; ignore them */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
441 if (CHILD_ACTIVE (cp) && cp->procinfo.hProcess)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
442 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
443 wait_hnd[nh] = cp->procinfo.hProcess;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
444 cps[nh] = cp;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
445 if (!wait_hnd[nh]) abort (); /* Sync with FSF Emacs 19.34.6 note: only in XEmacs */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
446 nh++;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
447 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
448 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
449
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
450 if (nh == 0)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
451 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
452 /* Nothing to wait on, so fail */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
453 errno = ECHILD;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
454 return -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
455 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
456
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
457 do
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
458 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
459 /* Check for quit about once a second. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
460 QUIT;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
461 active = WaitForMultipleObjects (nh, wait_hnd, FALSE, 1000);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
462 } while (active == WAIT_TIMEOUT);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
463
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
464 if (active == WAIT_FAILED)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
465 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
466 errno = EBADF;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
467 return -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
468 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
469 else if (active >= WAIT_OBJECT_0 &&
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
470 active < WAIT_OBJECT_0+MAXIMUM_WAIT_OBJECTS)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
471 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
472 active -= WAIT_OBJECT_0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
473 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
474 else if (active >= WAIT_ABANDONED_0 &&
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
475 active < WAIT_ABANDONED_0+MAXIMUM_WAIT_OBJECTS)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
476 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
477 active -= WAIT_ABANDONED_0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
478 }
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
479 else
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
480 abort ();
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
481
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
482 get_result:
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
483 if (!GetExitCodeProcess (wait_hnd[active], &retval))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
484 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
485 DebPrint (("Wait.GetExitCodeProcess failed with %lu\n",
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
486 GetLastError ()));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
487 retval = 1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
488 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
489 if (retval == STILL_ACTIVE)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
490 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
491 /* Should never happen */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
492 DebPrint (("Wait.WaitForMultipleObjects returned an active process\n"));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
493 errno = EINVAL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
494 return -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
495 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
496
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
497 /* Massage the exit code from the process to match the format expected
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
498 by the WIFSTOPPED et al macros in syswait.h. Only WIFSIGNALED and
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
499 WIFEXITED are supported; WIFSTOPPED doesn't make sense under NT. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
500
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
501 if (retval == STATUS_CONTROL_C_EXIT)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
502 retval = SIGINT;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
503 else
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
504 retval <<= 8;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
505
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
506 cp = cps[active];
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
507 pid = cp->pid;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
508 #ifdef FULL_DEBUG
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
509 DebPrint (("Wait signaled with process pid %d\n", cp->pid));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
510 #endif
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
511
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
512 if (status)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
513 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
514 *status = retval;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
515 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
516 else if (synch_process_alive)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
517 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
518 synch_process_alive = 0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
519
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
520 /* Report the status of the synchronous process. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
521 if (WIFEXITED (retval))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
522 synch_process_retcode = WRETCODE (retval);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
523 else if (WIFSIGNALED (retval))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
524 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
525 int code = WTERMSIG (retval);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
526 char *signame = 0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
527
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
528 if (code < NSIG)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
529 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
530 /* Suppress warning if the table has const char *. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
531 signame = (char *) sys_siglist[code];
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
532 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
533 if (signame == 0)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
534 signame = "unknown";
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
535
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
536 synch_process_death = signame;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
537 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
538
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
539 reap_subprocess (cp);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
540 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
541
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
542 reap_subprocess (cp);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
543
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
544 return pid;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
545 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
546
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
547 void
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
548 win32_executable_type (char * filename, int * is_dos_app, int * is_cygnus_app)
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
549 {
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
550 file_data executable;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
551 char * p;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
552
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
553 /* Default values in case we can't tell for sure. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
554 *is_dos_app = FALSE;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
555 *is_cygnus_app = FALSE;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
556
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
557 if (!open_input_file (&executable, filename))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
558 return;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
559
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
560 p = strrchr (filename, '.');
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
561
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
562 /* We can only identify DOS .com programs from the extension. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
563 if (p && stricmp (p, ".com") == 0)
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
564 *is_dos_app = TRUE;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
565 else if (p && (stricmp (p, ".bat") == 0 ||
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
566 stricmp (p, ".cmd") == 0))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
567 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
568 /* A DOS shell script - it appears that CreateProcess is happy to
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
569 accept this (somewhat surprisingly); presumably it looks at
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
570 COMSPEC to determine what executable to actually invoke.
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
571 Therefore, we have to do the same here as well. */
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
572 /* Actually, I think it uses the program association for that
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
573 extension, which is defined in the registry. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
574 p = egetenv ("COMSPEC");
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
575 if (p)
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
576 win32_executable_type (p, is_dos_app, is_cygnus_app);
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
577 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
578 else
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
579 {
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
580 /* Look for DOS .exe signature - if found, we must also check that
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
581 it isn't really a 16- or 32-bit Windows exe, since both formats
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
582 start with a DOS program stub. Note that 16-bit Windows
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
583 executables use the OS/2 1.x format. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
584
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
585 IMAGE_DOS_HEADER * dos_header;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
586 IMAGE_NT_HEADERS * nt_header;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
587
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
588 dos_header = (PIMAGE_DOS_HEADER) executable.file_base;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
589 if (dos_header->e_magic != IMAGE_DOS_SIGNATURE)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
590 goto unwind;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
591
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
592 nt_header = (PIMAGE_NT_HEADERS) ((char *) dos_header + dos_header->e_lfanew);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
593
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
594 if ((char *) nt_header > (char *) dos_header + executable.size)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
595 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
596 /* Some dos headers (pkunzip) have bogus e_lfanew fields. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
597 *is_dos_app = TRUE;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
598 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
599 else if (nt_header->Signature != IMAGE_NT_SIGNATURE &&
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
600 LOWORD (nt_header->Signature) != IMAGE_OS2_SIGNATURE)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
601 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
602 *is_dos_app = TRUE;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
603 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
604 else if (nt_header->Signature == IMAGE_NT_SIGNATURE)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
605 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
606 /* Look for cygwin.dll in DLL import list. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
607 IMAGE_DATA_DIRECTORY import_dir =
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
608 nt_header->OptionalHeader.DataDirectory[IMAGE_DIRECTORY_ENTRY_IMPORT];
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
609 IMAGE_IMPORT_DESCRIPTOR * imports;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
610 IMAGE_SECTION_HEADER * section;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
611
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
612 section = rva_to_section (import_dir.VirtualAddress, nt_header);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
613 imports = RVA_TO_PTR (import_dir.VirtualAddress, section, executable);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
614
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
615 for ( ; imports->Name; imports++)
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
616 {
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
617 char * dllname = RVA_TO_PTR (imports->Name, section, executable);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
618
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
619 if (strcmp (dllname, "cygwin.dll") == 0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
620 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
621 *is_cygnus_app = TRUE;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
622 break;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
623 }
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
624 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
625 }
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
626 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
627
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
628 unwind:
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
629 close_file_data (&executable);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
630 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
631
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
632 int
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
633 compare_env (const char **strp1, const char **strp2)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
634 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
635 const char *str1 = *strp1, *str2 = *strp2;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
636
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
637 while (*str1 && *str2 && *str1 != '=' && *str2 != '=')
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
638 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
639 if ((*str1) > (*str2))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
640 return 1;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
641 else if ((*str1) < (*str2))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
642 return -1;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
643 str1++, str2++;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
644 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
645
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
646 if (*str1 == '=' && *str2 == '=')
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
647 return 0;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
648 else if (*str1 == '=')
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
649 return -1;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
650 else
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
651 return 1;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
652 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
653
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
654 void
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
655 merge_and_sort_env (char **envp1, char **envp2, char **new_envp)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
656 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
657 char **optr, **nptr;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
658 int num;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
659
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
660 nptr = new_envp;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
661 optr = envp1;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
662 while (*optr)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
663 *nptr++ = *optr++;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
664 num = optr - envp1;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
665
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
666 optr = envp2;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
667 while (*optr)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
668 *nptr++ = *optr++;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
669 num += optr - envp2;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
670
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
671 qsort (new_envp, num, sizeof (char *), compare_env);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
672
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
673 *nptr = NULL;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
674 }
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
675
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
676 /* When a new child process is created we need to register it in our list,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
677 so intercept spawn requests. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
678 int
239
41f2f0e326e9 Import from CVS: tag r20-5b18
cvs
parents: 223
diff changeset
679 sys_spawnve (int mode, CONST char *cmdname,
41f2f0e326e9 Import from CVS: tag r20-5b18
cvs
parents: 223
diff changeset
680 CONST char * CONST *argv, CONST char *CONST *envp)
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
681 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
682 Lisp_Object program, full;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
683 char *cmdline, *env, *parg, **targ;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
684 int arglen, numenv;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
685 int pid;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
686 child_process *cp;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
687 int is_dos_app, is_cygnus_app;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
688 int do_quoting = 0;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
689 char escape_char;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
690 /* We pass our process ID to our children by setting up an environment
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
691 variable in their environment. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
692 char ppid_env_var_buffer[64];
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
693 char *extra_env[] = {ppid_env_var_buffer, NULL};
124
9b50b4588a93 Import from CVS: tag r20-1b15
cvs
parents: 100
diff changeset
694 struct gcpro gcpro1;
9b50b4588a93 Import from CVS: tag r20-1b15
cvs
parents: 100
diff changeset
695
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
696 /* We don't care about the other modes */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
697 if (mode != _P_NOWAIT)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
698 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
699 errno = EINVAL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
700 return -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
701 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
702
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
703 /* Handle executable names without an executable suffix. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
704 program = make_string (cmdname, strlen (cmdname));
124
9b50b4588a93 Import from CVS: tag r20-1b15
cvs
parents: 100
diff changeset
705 GCPRO1 (program);
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
706 if (NILP (Ffile_executable_p (program)))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
707 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
708 full = Qnil;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
709 locate_file (Vexec_path, program, EXEC_SUFFIXES, &full, 1);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
710 if (NILP (full))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
711 {
124
9b50b4588a93 Import from CVS: tag r20-1b15
cvs
parents: 100
diff changeset
712 UNGCPRO;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
713 errno = EINVAL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
714 return -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
715 }
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
716 cmdname = XSTRING_DATA (full);
239
41f2f0e326e9 Import from CVS: tag r20-5b18
cvs
parents: 223
diff changeset
717 /* #### KLUDGE */
41f2f0e326e9 Import from CVS: tag r20-5b18
cvs
parents: 223
diff changeset
718 *(char**)(argv[0]) = cmdname;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
719 }
124
9b50b4588a93 Import from CVS: tag r20-1b15
cvs
parents: 100
diff changeset
720 UNGCPRO;
9b50b4588a93 Import from CVS: tag r20-1b15
cvs
parents: 100
diff changeset
721
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
722 /* make sure argv[0] and cmdname are both in DOS format */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
723 strcpy (cmdname = alloca (strlen (cmdname) + 1), argv[0]);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
724 unixtodos_filename (cmdname);
239
41f2f0e326e9 Import from CVS: tag r20-5b18
cvs
parents: 223
diff changeset
725 /* #### KLUDGE */
41f2f0e326e9 Import from CVS: tag r20-5b18
cvs
parents: 223
diff changeset
726 *(char**)(argv[0]) = cmdname;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
727
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
728 /* Determine whether program is a 16-bit DOS executable, or a Win32
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
729 executable that is implicitly linked to the Cygnus dll (implying it
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
730 was compiled with the Cygnus GNU toolchain and hence relies on
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
731 cygwin.dll to parse the command line - we use this to decide how to
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
732 escape quote chars in command line args that must be quoted). */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
733 win32_executable_type (cmdname, &is_dos_app, &is_cygnus_app);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
734
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
735 /* On Windows 95, if cmdname is a DOS app, we invoke a helper
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
736 application to start it by specifying the helper app as cmdname,
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
737 while leaving the real app name as argv[0]. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
738 if (is_dos_app)
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
739 {
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
740 cmdname = alloca (MAXPATHLEN);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
741 if (egetenv ("CMDPROXY"))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
742 strcpy (cmdname, egetenv ("CMDPROXY"));
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
743 else
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
744 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
745 strcpy (cmdname, XSTRING_DATA (Vinvocation_directory));
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
746 strcat (cmdname, "cmdproxy.exe");
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
747 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
748 unixtodos_filename (cmdname);
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
749 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
750
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
751 /* we have to do some conjuring here to put argv and envp into the
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
752 form CreateProcess wants... argv needs to be a space separated/null
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
753 terminated list of parameters, and envp is a null
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
754 separated/double-null terminated list of parameters.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
755
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
756 Additionally, zero-length args and args containing whitespace or
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
757 quote chars need to be wrapped in double quotes - for this to work,
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
758 embedded quotes need to be escaped as well. The aim is to ensure
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
759 the child process reconstructs the argv array we start with
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
760 exactly, so we treat quotes at the beginning and end of arguments
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
761 as embedded quotes.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
762
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
763 The Win32 GNU-based library from Cygnus doubles quotes to escape
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
764 them, while MSVC uses backslash for escaping. (Actually the MSVC
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
765 startup code does attempt to recognise doubled quotes and accept
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
766 them, but gets it wrong and ends up requiring three quotes to get a
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
767 single embedded quote!) So by default we decide whether to use
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
768 quote or backslash as the escape character based on whether the
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
769 binary is apparently a Cygnus compiled app.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
770
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
771 Note that using backslash to escape embedded quotes requires
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
772 additional special handling if an embedded quote is already
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
773 preceeded by backslash, or if an arg requiring quoting ends with
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
774 backslash. In such cases, the run of escape characters needs to be
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
775 doubled. For consistency, we apply this special handling as long
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
776 as the escape character is not quote.
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
777
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
778 Since we have no idea how large argv and envp are likely to be we
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
779 figure out list lengths on the fly and allocate them. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
780
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
781 if (!NILP (Vwin32_quote_process_args))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
782 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
783 do_quoting = 1;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
784 /* Override escape char by binding win32-quote-process-args to
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
785 desired character, or use t for auto-selection. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
786 if (INTP (Vwin32_quote_process_args))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
787 escape_char = XINT (Vwin32_quote_process_args);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
788 else
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
789 escape_char = is_cygnus_app ? '"' : '\\';
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
790 }
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
791
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
792 /* do argv... */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
793 arglen = 0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
794 targ = argv;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
795 while (*targ)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
796 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
797 char * p = *targ;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
798 int need_quotes = 0;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
799 int escape_char_run = 0;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
800
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
801 if (*p == 0)
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
802 need_quotes = 1;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
803 for ( ; *p; p++)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
804 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
805 if (*p == '"')
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
806 {
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
807 /* allow for embedded quotes to be escaped */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
808 arglen++;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
809 need_quotes = 1;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
810 /* handle the case where the embedded quote is already escaped */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
811 if (escape_char_run > 0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
812 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
813 /* To preserve the arg exactly, we need to double the
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
814 preceding escape characters (plus adding one to
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
815 escape the quote character itself). */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
816 arglen += escape_char_run;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
817 }
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
818 }
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
819 else if (*p == ' ' || *p == '\t')
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
820 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
821 need_quotes = 1;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
822 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
823
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
824 if (*p == escape_char && escape_char != '"')
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
825 escape_char_run++;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
826 else
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
827 escape_char_run = 0;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
828 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
829 if (need_quotes)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
830 {
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
831 arglen += 2;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
832 /* handle the case where the arg ends with an escape char - we
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
833 must not let the enclosing quote be escaped. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
834 if (escape_char_run > 0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
835 arglen += escape_char_run;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
836 }
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
837 arglen += strlen (*targ++) + 1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
838 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
839 cmdline = alloca (arglen);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
840 targ = argv;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
841 parg = cmdline;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
842 while (*targ)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
843 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
844 char * p = *targ;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
845 int need_quotes = 0;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
846
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
847 if (*p == 0)
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
848 need_quotes = 1;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
849
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
850 if (do_quoting)
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
851 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
852 for ( ; *p; p++)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
853 if (*p == ' ' || *p == '\t' || *p == '"')
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
854 need_quotes = 1;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
855 }
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
856 if (need_quotes)
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
857 {
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
858 int escape_char_run = 0;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
859 char * first;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
860 char * last;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
861
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
862 p = *targ;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
863 first = p;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
864 last = p + strlen (p) - 1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
865 *parg++ = '"';
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
866 #if 0
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
867 /* This version does not escape quotes if they occur at the
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
868 beginning or end of the arg - this could lead to incorrect
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
869 behaviour when the arg itself represents a command line
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
870 containing quoted args. I believe this was originally done
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
871 as a hack to make some things work, before
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
872 `win32-quote-process-args' was added. */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
873 while (*p)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
874 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
875 if (*p == '"' && p > first && p < last)
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
876 *parg++ = escape_char; /* escape embedded quotes */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
877 *parg++ = *p++;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
878 }
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
879 #else
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
880 for ( ; *p; p++)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
881 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
882 if (*p == '"')
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
883 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
884 /* double preceding escape chars if any */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
885 while (escape_char_run > 0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
886 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
887 *parg++ = escape_char;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
888 escape_char_run--;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
889 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
890 /* escape all quote chars, even at beginning or end */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
891 *parg++ = escape_char;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
892 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
893 *parg++ = *p;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
894
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
895 if (*p == escape_char && escape_char != '"')
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
896 escape_char_run++;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
897 else
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
898 escape_char_run = 0;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
899 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
900 /* double escape chars before enclosing quote */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
901 while (escape_char_run > 0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
902 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
903 *parg++ = escape_char;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
904 escape_char_run--;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
905 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
906 #endif
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
907 *parg++ = '"';
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
908 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
909 else
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
910 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
911 strcpy (parg, *targ);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
912 parg += strlen (*targ);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
913 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
914 *parg++ = ' ';
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
915 targ++;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
916 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
917 *--parg = '\0';
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
918
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
919 /* and envp... */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
920 arglen = 1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
921 targ = envp;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
922 numenv = 1; /* for end null */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
923 while (*targ)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
924 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
925 arglen += strlen (*targ++) + 1;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
926 numenv++;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
927 }
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
928 /* extra env vars... */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
929 sprintf (ppid_env_var_buffer, "__PARENT_PROCESS_ID=%d",
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
930 GetCurrentProcessId ());
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
931 arglen += strlen (ppid_env_var_buffer) + 1;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
932 numenv++;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
933
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
934 /* merge env passed in and extra env into one, and sort it. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
935 targ = (char **) alloca (numenv * sizeof (char *));
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
936 merge_and_sort_env (envp, extra_env, targ);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
937
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
938 /* concatenate env entries. */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
939 env = alloca (arglen);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
940 parg = env;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
941 while (*targ)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
942 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
943 strcpy (parg, *targ);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
944 parg += strlen (*targ++);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
945 *parg++ = '\0';
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
946 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
947 *parg++ = '\0';
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
948 *parg = '\0';
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
949
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
950 cp = new_child ();
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
951 if (cp == NULL)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
952 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
953 errno = EAGAIN;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
954 return -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
955 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
956
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
957 /* Now create the process. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
958 if (!create_child (cmdname, cmdline, env, &pid, cp))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
959 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
960 delete_child (cp);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
961 errno = ENOEXEC;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
962 return -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
963 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
964
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
965 return pid;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
966 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
967
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
968 /* Emulate the select call
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
969 Wait for available input on any of the given rfds, or timeout if
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
970 a timeout is given and no input is detected
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
971 wfds and efds are not supported and must be NULL.
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
972
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
973 For simplicity, we detect the death of child processes here and
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
974 synchronously call the SIGCHLD handler. Since it is possible for
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
975 children to be created without a corresponding pipe handle from which
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
976 to read output, we wait separately on the process handles as well as
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
977 the char_avail events for each process pipe. We only call
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
978 wait/reap_process when the process actually terminates. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
979
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
980 /* From ntterm.c */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
981 extern HANDLE keyboard_handle;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
982 /* From process.c */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
983 extern int proc_buffered_char[];
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
984
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
985 int
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
986 sys_select (int nfds, SELECT_TYPE *rfds, SELECT_TYPE *wfds, SELECT_TYPE *efds,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
987 EMACS_TIME *timeout)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
988 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
989 SELECT_TYPE orfds;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
990 DWORD timeout_ms, start_time;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
991 int i, nh, nc, nr;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
992 DWORD active;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
993 child_process *cp, *cps[MAX_CHILDREN];
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
994 HANDLE wait_hnd[MAXDESC + MAX_CHILDREN];
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
995 int fdindex[MAXDESC]; /* mapping from wait handles back to descriptors */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
996
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
997 timeout_ms = timeout ? (timeout->tv_sec * 1000 + timeout->tv_usec / 1000) : INFINITE;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
998
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
999 /* If the descriptor sets are NULL but timeout isn't, then just Sleep. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1000 if (rfds == NULL && wfds == NULL && efds == NULL && timeout != NULL)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1001 {
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1002 Sleep (timeout_ms);
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1003 return 0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1004 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1005
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1006 /* Otherwise, we only handle rfds, so fail otherwise. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1007 if (rfds == NULL || wfds != NULL || efds != NULL)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1008 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1009 errno = EINVAL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1010 return -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1011 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1012
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1013 orfds = *rfds;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1014 FD_ZERO (rfds);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1015 nr = 0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1016
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1017 /* Build a list of pipe handles to wait on. */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1018 nh = 0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1019 for (i = 0; i < nfds; i++)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1020 if (FD_ISSET (i, &orfds))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1021 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1022 if (i == 0)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1023 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1024 #if 0
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1025 /* Sync with FSF Emacs 19.34.6 note: ifdef'ed out in XEmacs */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1026 if (keyboard_handle)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1027 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1028 /* Handle stdin specially */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1029 wait_hnd[nh] = keyboard_handle;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1030 fdindex[nh] = i;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1031 nh++;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1032 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1033 #endif
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1034
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1035 /* Check for any emacs-generated input in the queue since
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1036 it won't be detected in the wait */
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1037 if (detect_input_pending ())
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1038 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1039 FD_SET (i, rfds);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1040 return 1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1041 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1042 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1043 else
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1044 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1045 /* Child process and socket input */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1046 cp = fd_info[i].cp;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1047 if (cp)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1048 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1049 int current_status = cp->status;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1050
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1051 if (current_status == STATUS_READ_ACKNOWLEDGED)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1052 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1053 /* Tell reader thread which file handle to use. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1054 cp->fd = i;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1055 /* Wake up the reader thread for this process */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1056 cp->status = STATUS_READ_READY;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1057 if (!SetEvent (cp->char_consumed))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1058 DebPrint (("nt_select.SetEvent failed with "
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1059 "%lu for fd %ld\n", GetLastError (), i));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1060 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1061
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1062 #ifdef CHECK_INTERLOCK
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1063 /* slightly crude cross-checking of interlock between threads */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1064
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1065 current_status = cp->status;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1066 if (WaitForSingleObject (cp->char_avail, 0) == WAIT_OBJECT_0)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1067 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1068 /* char_avail has been signalled, so status (which may
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1069 have changed) should indicate read has completed
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1070 but has not been acknowledged. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1071 current_status = cp->status;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1072 if (current_status != STATUS_READ_SUCCEEDED &&
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1073 current_status != STATUS_READ_FAILED)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1074 DebPrint (("char_avail set, but read not completed: status %d\n",
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1075 current_status));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1076 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1077 else
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1078 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1079 /* char_avail has not been signalled, so status should
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1080 indicate that read is in progress; small possibility
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1081 that read has completed but event wasn't yet signalled
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1082 when we tested it (because a context switch occurred
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1083 or if running on separate CPUs). */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1084 if (current_status != STATUS_READ_READY &&
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1085 current_status != STATUS_READ_IN_PROGRESS &&
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1086 current_status != STATUS_READ_SUCCEEDED &&
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1087 current_status != STATUS_READ_FAILED)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1088 DebPrint (("char_avail reset, but read status is bad: %d\n",
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1089 current_status));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1090 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1091 #endif
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1092 wait_hnd[nh] = cp->char_avail;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1093 fdindex[nh] = i;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1094 if (!wait_hnd[nh]) abort ();
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1095 nh++;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1096 #ifdef FULL_DEBUG
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1097 DebPrint (("select waiting on child %d fd %d\n",
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1098 cp-child_procs, i));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1099 #endif
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1100 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1101 else
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1102 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1103 /* Unable to find something to wait on for this fd, skip */
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1104
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1105 /* Note that this is not a fatal error, and can in fact
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1106 happen in unusual circumstances. Specifically, if
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1107 sys_spawnve fails, eg. because the program doesn't
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1108 exist, and debug-on-error is t so Fsignal invokes a
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1109 nested input loop, then the process output pipe is
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1110 still included in input_wait_mask with no child_proc
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1111 associated with it. (It is removed when the debugger
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1112 exits the nested input loop and the error is thrown.) */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1113
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1114 DebPrint (("sys_select: fd %ld is invalid! ignoring\n", i));
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1115 }
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1116 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1117 }
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1118
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1119 count_children:
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1120 /* Add handles of child processes. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1121 nc = 0;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1122 for (cp = child_procs+(child_proc_count-1); cp >= child_procs; cp--)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1123 /* Some child_procs might be sockets; ignore them. Also some
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1124 children may have died already, but we haven't finished reading
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1125 the process output; ignore them too. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1126 if (CHILD_ACTIVE (cp) && cp->procinfo.hProcess
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1127 && (cp->fd < 0
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1128 || (fd_info[cp->fd].flags & FILE_SEND_SIGCHLD) == 0
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1129 || (fd_info[cp->fd].flags & FILE_AT_EOF) != 0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1130 )
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1131 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1132 wait_hnd[nh + nc] = cp->procinfo.hProcess;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1133 cps[nc] = cp;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1134 nc++;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1135 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1136
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1137 /* Nothing to look for, so we didn't find anything */
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1138 if (nh + nc == 0)
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1139 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1140 if (timeout)
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1141 Sleep (timeout_ms);
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1142 return 0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1143 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1144
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1145 /* Wait for input or child death to be signalled. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1146 start_time = GetTickCount ();
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1147 active = WaitForMultipleObjects (nh + nc, wait_hnd, FALSE, timeout_ms);
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1148
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1149 if (active == WAIT_FAILED)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1150 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1151 DebPrint (("select.WaitForMultipleObjects (%d, %lu) failed with %lu\n",
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1152 nh + nc, timeout_ms, GetLastError ()));
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1153 /* don't return EBADF - this causes wait_reading_process_input to
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1154 abort; WAIT_FAILED is returned when single-stepping under
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1155 Windows 95 after switching thread focus in debugger, and
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1156 possibly at other times. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1157 errno = EINTR;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1158 return -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1159 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1160 else if (active == WAIT_TIMEOUT)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1161 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1162 return 0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1163 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1164 else if (active >= WAIT_OBJECT_0 &&
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1165 active < WAIT_OBJECT_0+MAXIMUM_WAIT_OBJECTS)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1166 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1167 active -= WAIT_OBJECT_0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1168 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1169 else if (active >= WAIT_ABANDONED_0 &&
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1170 active < WAIT_ABANDONED_0+MAXIMUM_WAIT_OBJECTS)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1171 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1172 active -= WAIT_ABANDONED_0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1173 }
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1174 else
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1175 abort ();
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1176
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1177 /* Loop over all handles after active (now officially documented as
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1178 being the first signalled handle in the array). We do this to
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1179 ensure fairness, so that all channels with data available will be
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1180 processed - otherwise higher numbered channels could be starved. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1181 do
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1182 {
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1183 if (active >= nh)
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1184 {
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1185 cp = cps[active - nh];
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1186
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1187 /* We cannot always signal SIGCHLD immediately; if we have not
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1188 finished reading the process output, we must delay sending
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1189 SIGCHLD until we do. */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1190
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1191 if (cp->fd >= 0 && (fd_info[cp->fd].flags & FILE_AT_EOF) == 0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1192 fd_info[cp->fd].flags |= FILE_SEND_SIGCHLD;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1193 /* SIG_DFL for SIGCHLD is ignore */
223
2c611d1463a6 Import from CVS: tag r20-4b10
cvs
parents: 209
diff changeset
1194 else
2c611d1463a6 Import from CVS: tag r20-4b10
cvs
parents: 209
diff changeset
1195 {
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1196 #ifdef FULL_DEBUG
223
2c611d1463a6 Import from CVS: tag r20-4b10
cvs
parents: 209
diff changeset
1197 DebPrint (("select is raising SIGCHLD handler for pid %d\n",
2c611d1463a6 Import from CVS: tag r20-4b10
cvs
parents: 209
diff changeset
1198 cp->pid));
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1199 #endif
223
2c611d1463a6 Import from CVS: tag r20-4b10
cvs
parents: 209
diff changeset
1200 dead_child = cp;
2c611d1463a6 Import from CVS: tag r20-4b10
cvs
parents: 209
diff changeset
1201 msw_raise (SIGCHLD);
2c611d1463a6 Import from CVS: tag r20-4b10
cvs
parents: 209
diff changeset
1202 dead_child = NULL;
2c611d1463a6 Import from CVS: tag r20-4b10
cvs
parents: 209
diff changeset
1203 }
2c611d1463a6 Import from CVS: tag r20-4b10
cvs
parents: 209
diff changeset
1204 }
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1205 else if (fdindex[active] == 0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1206 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1207 /* Keyboard input available */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1208 FD_SET (0, rfds);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1209 nr++;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1210 }
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1211 else
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1212 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1213 /* must be a socket or pipe - read ahead should have
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1214 completed, either succeeding or failing. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1215 FD_SET (fdindex[active], rfds);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1216 nr++;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1217 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1218
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1219 /* Even though wait_reading_process_output only reads from at most
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1220 one channel, we must process all channels here so that we reap
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1221 all children that have died. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1222 while (++active < nh + nc)
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1223 if (WaitForSingleObject (wait_hnd[active], 0) == WAIT_OBJECT_0)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1224 break;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1225 } while (active < nh + nc);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1226
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1227 /* If no input has arrived and timeout hasn't expired, wait again. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1228 if (nr == 0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1229 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1230 DWORD elapsed = GetTickCount () - start_time;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1231
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1232 if (timeout_ms > elapsed) /* INFINITE is MAX_UINT */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1233 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1234 if (timeout_ms != INFINITE)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1235 timeout_ms -= elapsed;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1236 goto count_children;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1237 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1238 }
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1239
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1240 return nr;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1241 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1242
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1243 /* Substitute for certain kill () operations */
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1244
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1245 static BOOL CALLBACK
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1246 find_child_console (HWND hwnd, child_process * cp)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1247 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1248 DWORD thread_id;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1249 DWORD process_id;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1250
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1251 thread_id = GetWindowThreadProcessId (hwnd, &process_id);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1252 if (process_id == cp->procinfo.dwProcessId)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1253 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1254 char window_class[32];
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1255
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1256 GetClassName (hwnd, window_class, sizeof (window_class));
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1257 if (strcmp (window_class,
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1258 (os_subtype == OS_WIN95)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1259 ? "tty"
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1260 : "ConsoleWindowClass") == 0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1261 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1262 cp->hwnd = hwnd;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1263 return FALSE;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1264 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1265 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1266 /* keep looking */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1267 return TRUE;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1268 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1269
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1270 int
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1271 sys_kill (int pid, int sig)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1272 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1273 child_process *cp;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1274 HANDLE proc_hand;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1275 int need_to_free = 0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1276 int rc = 0;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1277
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1278 /* Only handle signals that will result in the process dying */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1279 if (sig != SIGINT && sig != SIGKILL && sig != SIGQUIT && sig != SIGHUP)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1280 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1281 errno = EINVAL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1282 return -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1283 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1284
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1285 cp = find_child_pid (pid);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1286 if (cp == NULL)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1287 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1288 proc_hand = OpenProcess (PROCESS_TERMINATE, 0, pid);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1289 if (proc_hand == NULL)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1290 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1291 errno = EPERM;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1292 return -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1293 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1294 need_to_free = 1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1295 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1296 else
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1297 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1298 proc_hand = cp->procinfo.hProcess;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1299 pid = cp->procinfo.dwProcessId;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1300
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1301 /* Try to locate console window for process. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1302 EnumWindows (find_child_console, (LPARAM) cp);
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1303 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1304
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1305 if (sig == SIGINT)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1306 {
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1307 if (NILP (Vwin32_start_process_share_console) && cp && cp->hwnd)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1308 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1309 BYTE control_scan_code = (BYTE) MapVirtualKey (VK_CONTROL, 0);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1310 BYTE vk_break_code = VK_CANCEL;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1311 BYTE break_scan_code = (BYTE) MapVirtualKey (vk_break_code, 0);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1312 HWND foreground_window;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1313
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1314 if (break_scan_code == 0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1315 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1316 /* Fake Ctrl-C if we can't manage Ctrl-Break. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1317 vk_break_code = 'C';
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1318 break_scan_code = (BYTE) MapVirtualKey (vk_break_code, 0);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1319 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1320
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1321 foreground_window = GetForegroundWindow ();
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1322 if (foreground_window && SetForegroundWindow (cp->hwnd))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1323 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1324 /* Generate keystrokes as if user had typed Ctrl-Break or Ctrl-C. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1325 keybd_event (VK_CONTROL, control_scan_code, 0, 0);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1326 keybd_event (vk_break_code, break_scan_code, 0, 0);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1327 keybd_event (vk_break_code, break_scan_code, KEYEVENTF_KEYUP, 0);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1328 keybd_event (VK_CONTROL, control_scan_code, KEYEVENTF_KEYUP, 0);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1329
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1330 /* Sleep for a bit to give time for Emacs frame to respond
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1331 to focus change events (if Emacs was active app). */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1332 Sleep (10);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1333
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1334 SetForegroundWindow (foreground_window);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1335 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1336 }
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1337 /* Ctrl-Break is NT equivalent of SIGINT. */
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1338 else if (!GenerateConsoleCtrlEvent (CTRL_BREAK_EVENT, pid))
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1339 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1340 DebPrint (("sys_kill.GenerateConsoleCtrlEvent return %d "
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1341 "for pid %lu\n", GetLastError (), pid));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1342 errno = EINVAL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1343 rc = -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1344 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1345 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1346 else
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1347 {
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1348 if (NILP (Vwin32_start_process_share_console) && cp && cp->hwnd)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1349 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1350 #if 1
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1351 if (os_subtype == OS_WIN95)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1352 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1353 /*
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1354 Another possibility is to try terminating the VDM out-right by
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1355 calling the Shell VxD (id 0x17) V86 interface, function #4
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1356 "SHELL_Destroy_VM", ie.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1357
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1358 mov edx,4
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1359 mov ebx,vm_handle
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1360 call shellapi
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1361
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1362 First need to determine the current VM handle, and then arrange for
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1363 the shellapi call to be made from the system vm (by using
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1364 Switch_VM_and_callback).
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1365
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1366 Could try to invoke DestroyVM through CallVxD.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1367
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1368 */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1369 #if 0
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1370 /* On Win95, posting WM_QUIT causes the 16-bit subsystem
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1371 to hang when cmdproxy is used in conjunction with
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1372 command.com for an interactive shell. Posting
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1373 WM_CLOSE pops up a dialog that, when Yes is selected,
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1374 does the same thing. TerminateProcess is also less
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1375 than ideal in that subprocesses tend to stick around
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1376 until the machine is shutdown, but at least it
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1377 doesn't freeze the 16-bit subsystem. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1378 PostMessage (cp->hwnd, WM_QUIT, 0xff, 0);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1379 #endif
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1380 if (!TerminateProcess (proc_hand, 0xff))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1381 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1382 DebPrint (("sys_kill.TerminateProcess returned %d "
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1383 "for pid %lu\n", GetLastError (), pid));
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1384 errno = EINVAL;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1385 rc = -1;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1386 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1387 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1388 else
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1389 #endif
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1390 PostMessage (cp->hwnd, WM_CLOSE, 0, 0);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1391 }
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1392 /* Kill the process. On Win32 this doesn't kill child processes
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1393 so it doesn't work very well for shells which is why it's not
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1394 used in every case. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1395 else if (!TerminateProcess (proc_hand, 0xff))
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1396 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1397 DebPrint (("sys_kill.TerminateProcess returned %d "
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1398 "for pid %lu\n", GetLastError (), pid));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1399 errno = EINVAL;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1400 rc = -1;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1401 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1402 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1403
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1404 if (need_to_free)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1405 CloseHandle (proc_hand);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1406
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1407 return rc;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1408 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1409
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1410 #if 0
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1411 /* Sync with FSF Emacs 19.34.6 note: ifdef'ed out in XEmacs */
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1412 extern int report_file_error (CONST char *, Lisp_Object);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1413 #endif
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1414 /* The following two routines are used to manipulate stdin, stdout, and
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1415 stderr of our child processes.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1416
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1417 Assuming that in, out, and err are *not* inheritable, we make them
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1418 stdin, stdout, and stderr of the child as follows:
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1419
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1420 - Save the parent's current standard handles.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1421 - Set the std handles to inheritable duplicates of the ones being passed in.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1422 (Note that _get_osfhandle() is an io.h procedure that retrieves the
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1423 NT file handle for a crt file descriptor.)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1424 - Spawn the child, which inherits in, out, and err as stdin,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1425 stdout, and stderr. (see Spawnve)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1426 - Close the std handles passed to the child.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1427 - Reset the parent's standard handles to the saved handles.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1428 (see reset_standard_handles)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1429 We assume that the caller closes in, out, and err after calling us. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1430
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1431 void
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1432 prepare_standard_handles (int in, int out, int err, HANDLE handles[3])
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1433 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1434 HANDLE parent;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1435 HANDLE newstdin, newstdout, newstderr;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1436
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1437 parent = GetCurrentProcess ();
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1438
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1439 handles[0] = GetStdHandle (STD_INPUT_HANDLE);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1440 handles[1] = GetStdHandle (STD_OUTPUT_HANDLE);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1441 handles[2] = GetStdHandle (STD_ERROR_HANDLE);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1442
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1443 /* make inheritable copies of the new handles */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1444 if (!DuplicateHandle (parent,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1445 (HANDLE) _get_osfhandle (in),
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1446 parent,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1447 &newstdin,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1448 0,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1449 TRUE,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1450 DUPLICATE_SAME_ACCESS))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1451 report_file_error ("Duplicating input handle for child", Qnil);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1452
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1453 if (!DuplicateHandle (parent,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1454 (HANDLE) _get_osfhandle (out),
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1455 parent,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1456 &newstdout,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1457 0,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1458 TRUE,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1459 DUPLICATE_SAME_ACCESS))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1460 report_file_error ("Duplicating output handle for child", Qnil);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1461
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1462 if (!DuplicateHandle (parent,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1463 (HANDLE) _get_osfhandle (err),
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1464 parent,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1465 &newstderr,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1466 0,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1467 TRUE,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1468 DUPLICATE_SAME_ACCESS))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1469 report_file_error ("Duplicating error handle for child", Qnil);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1470
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1471 /* and store them as our std handles */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1472 if (!SetStdHandle (STD_INPUT_HANDLE, newstdin))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1473 report_file_error ("Changing stdin handle", Qnil);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1474
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1475 if (!SetStdHandle (STD_OUTPUT_HANDLE, newstdout))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1476 report_file_error ("Changing stdout handle", Qnil);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1477
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1478 if (!SetStdHandle (STD_ERROR_HANDLE, newstderr))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1479 report_file_error ("Changing stderr handle", Qnil);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1480 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1481
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1482 void
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1483 reset_standard_handles (int in, int out, int err, HANDLE handles[3])
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1484 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1485 /* close the duplicated handles passed to the child */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1486 CloseHandle (GetStdHandle (STD_INPUT_HANDLE));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1487 CloseHandle (GetStdHandle (STD_OUTPUT_HANDLE));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1488 CloseHandle (GetStdHandle (STD_ERROR_HANDLE));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1489
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1490 /* now restore parent's saved std handles */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1491 SetStdHandle (STD_INPUT_HANDLE, handles[0]);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1492 SetStdHandle (STD_OUTPUT_HANDLE, handles[1]);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1493 SetStdHandle (STD_ERROR_HANDLE, handles[2]);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1494 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1495
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1496 void
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1497 set_process_dir (char * dir)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1498 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1499 process_dir = dir;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1500 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1501
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1502 #ifdef HAVE_SOCKETS
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1503
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1504 /* To avoid problems with winsock implementations that work over dial-up
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1505 connections causing or requiring a connection to exist while Emacs is
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1506 running, Emacs no longer automatically loads winsock on startup if it
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1507 is present. Instead, it will be loaded when open-network-stream is
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1508 first called.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1509
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1510 To allow full control over when winsock is loaded, we provide these
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1511 two functions to dynamically load and unload winsock. This allows
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1512 dial-up users to only be connected when they actually need to use
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1513 socket services. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1514
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1515 /* From nt.c */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1516 extern HANDLE winsock_lib;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1517 extern BOOL term_winsock (void);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1518 extern BOOL init_winsock (int load_now);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1519
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1520 extern Lisp_Object Vsystem_name;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1521
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1522 DEFUN ("win32-has-winsock", Fwin32_has_winsock, 0, 1, "", /*
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1523 Test for presence of the Windows socket library `winsock'.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1524 Returns non-nil if winsock support is present, nil otherwise.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1525
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1526 If the optional argument LOAD-NOW is non-nil, the winsock library is
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1527 also loaded immediately if not already loaded. If winsock is loaded,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1528 the winsock local hostname is returned (since this may be different from
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1529 the value of `system-name' and should supplant it), otherwise t is
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1530 returned to indicate winsock support is present.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1531 */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1532 (load_now))
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1533 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1534 int have_winsock;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1535
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1536 have_winsock = init_winsock (!NILP (load_now));
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1537 if (have_winsock)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1538 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1539 if (winsock_lib != NULL)
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1540 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1541 /* Return new value for system-name. The best way to do this
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1542 is to call init_system_name, saving and restoring the
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1543 original value to avoid side-effects. */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1544 Lisp_Object orig_hostname = Vsystem_name;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1545 Lisp_Object hostname;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1546
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1547 init_system_name ();
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1548 hostname = Vsystem_name;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1549 Vsystem_name = orig_hostname;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1550 return hostname;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1551 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1552 return Qt;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1553 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1554 return Qnil;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1555 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1556
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1557 DEFUN ("win32-unload-winsock", Fwin32_unload_winsock, 0, 0, "", /*
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1558 Unload the Windows socket library `winsock' if loaded.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1559 This is provided to allow dial-up socket connections to be disconnected
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1560 when no longer needed. Returns nil without unloading winsock if any
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1561 socket connections still exist.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1562 */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1563 ())
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1564 {
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1565 return term_winsock () ? Qt : Qnil;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1566 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1567
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1568 #endif /* HAVE_SOCKETS */
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1569
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1570
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1571 /* Some miscellaneous functions that are Windows specific, but not GUI
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1572 specific (ie. are applicable in terminal or batch mode as well). */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1573
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1574 /* lifted from fileio.c */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1575 #define CORRECT_DIR_SEPS(s) \
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1576 do { if ('/' == DIRECTORY_SEP) dostounix_filename (s); \
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1577 else unixtodos_filename (s); \
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1578 } while (0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1579
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1580 DEFUN ("win32-short-file-name", Fwin32_short_file_name, 1, 1, "", /*
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1581 Return the short file name version (8.3) of the full path of FILENAME.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1582 If FILENAME does not exist, return nil.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1583 All path elements in FILENAME are converted to their short names.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1584 */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1585 (filename))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1586 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1587 char shortname[MAX_PATH];
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1588
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1589 CHECK_STRING (filename, 0);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1590
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1591 /* first expand it. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1592 filename = Fexpand_file_name (filename, Qnil);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1593
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1594 /* luckily, this returns the short version of each element in the path. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1595 if (GetShortPathName (XSTRING_DATA (filename), shortname, MAX_PATH) == 0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1596 return Qnil;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1597
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1598 CORRECT_DIR_SEPS (shortname);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1599
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1600 return build_string (shortname);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1601 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1602
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1603
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1604 DEFUN ("win32-long-file-name", Fwin32_long_file_name, 1, 1, "", /*
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1605 Return the long file name version of the full path of FILENAME.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1606 If FILENAME does not exist, return nil.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1607 All path elements in FILENAME are converted to their long names.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1608 */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1609 (filename))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1610 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1611 char longname[ MAX_PATH ];
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1612
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1613 CHECK_STRING (filename, 0);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1614
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1615 /* first expand it. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1616 filename = Fexpand_file_name (filename, Qnil);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1617
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1618 if (!win32_get_long_filename (XSTRING_DATA (filename), longname, MAX_PATH))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1619 return Qnil;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1620
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1621 CORRECT_DIR_SEPS (longname);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1622
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1623 return build_string (longname);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1624 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1625
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1626 DEFUN ("win32-set-process-priority", Fwin32_set_process_priority, 2, 2, "", /*
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1627 Set the priority of PROCESS to PRIORITY.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1628 If PROCESS is nil, the priority of Emacs is changed, otherwise the
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1629 priority of the process whose pid is PROCESS is changed.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1630 PRIORITY should be one of the symbols high, normal, or low;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1631 any other symbol will be interpreted as normal.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1632
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1633 If successful, the return value is t, otherwise nil.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1634 */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1635 (process, priority))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1636 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1637 HANDLE proc_handle = GetCurrentProcess ();
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1638 DWORD priority_class = NORMAL_PRIORITY_CLASS;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1639 Lisp_Object result = Qnil;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1640
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1641 CHECK_SYMBOL (priority, 0);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1642
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1643 if (!NILP (process))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1644 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1645 DWORD pid;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1646 child_process *cp;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1647
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1648 CHECK_INT (process);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1649
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1650 /* Allow pid to be an internally generated one, or one obtained
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1651 externally. This is necessary because real pids on Win95 are
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1652 negative. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1653
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1654 pid = XINT (process);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1655 cp = find_child_pid (pid);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1656 if (cp != NULL)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1657 pid = cp->procinfo.dwProcessId;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1658
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1659 proc_handle = OpenProcess (PROCESS_SET_INFORMATION, FALSE, pid);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1660 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1661
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1662 if (EQ (priority, Qhigh))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1663 priority_class = HIGH_PRIORITY_CLASS;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1664 else if (EQ (priority, Qlow))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1665 priority_class = IDLE_PRIORITY_CLASS;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1666
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1667 if (proc_handle != NULL)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1668 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1669 if (SetPriorityClass (proc_handle, priority_class))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1670 result = Qt;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1671 if (!NILP (process))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1672 CloseHandle (proc_handle);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1673 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1674
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1675 return result;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1676 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1677
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1678
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1679 DEFUN ("win32-get-locale-info", Fwin32_get_locale_info, 1, 2, "", /*
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1680 "Return information about the Windows locale LCID.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1681 By default, return a three letter locale code which encodes the default
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1682 language as the first two characters, and the country or regionial variant
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1683 as the third letter. For example, ENU refers to `English (United States)',
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1684 while ENC means `English (Canadian)'.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1685
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1686 If the optional argument LONGFORM is non-nil, the long form of the locale
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1687 name is returned, e.g. `English (United States)' instead.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1688
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1689 If LCID (a 16-bit number) is not a valid locale, the result is nil.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1690 */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1691 (lcid, longform))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1692 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1693 int got_abbrev;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1694 int got_full;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1695 char abbrev_name[32] = { 0 };
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1696 char full_name[256] = { 0 };
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1697
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1698 CHECK_INT (lcid);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1699
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1700 if (!IsValidLocale (XINT (lcid), LCID_SUPPORTED))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1701 return Qnil;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1702
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1703 if (NILP (longform))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1704 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1705 got_abbrev = GetLocaleInfo (XINT (lcid),
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1706 LOCALE_SABBREVLANGNAME | LOCALE_USE_CP_ACP,
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1707 abbrev_name, sizeof (abbrev_name));
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1708 if (got_abbrev)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1709 return build_string (abbrev_name);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1710 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1711 else
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1712 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1713 got_full = GetLocaleInfo (XINT (lcid),
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1714 LOCALE_SLANGUAGE | LOCALE_USE_CP_ACP,
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1715 full_name, sizeof (full_name));
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1716 if (got_full)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1717 return build_string (full_name);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1718 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1719
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1720 return Qnil;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1721 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1722
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1723
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1724 DEFUN ("win32-get-current-locale-id", Fwin32_get_current_locale_id, 0, 0, "", /*
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1725 "Return Windows locale id for current locale setting.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1726 This is a numerical value; use `win32-get-locale-info' to convert to a
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1727 human-readable form.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1728 */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1729 ())
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1730 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1731 return make_int (GetThreadLocale ());
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1732 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1733
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1734
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1735 DEFUN ("win32-get-default-locale-id", Fwin32_get_default_locale_id, 0, 1, "", /*
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1736 "Return Windows locale id for default locale setting.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1737 By default, the system default locale setting is returned; if the optional
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1738 parameter USERP is non-nil, the user default locale setting is returned.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1739 This is a numerical value; use `win32-get-locale-info' to convert to a
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1740 human-readable form.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1741 */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1742 (userp))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1743 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1744 if (NILP (userp))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1745 return make_int (GetSystemDefaultLCID ());
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1746 return make_int (GetUserDefaultLCID ());
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1747 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1748
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1749 DWORD int_from_hex (char * s)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1750 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1751 DWORD val = 0;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1752 static char hex[] = "0123456789abcdefABCDEF";
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1753 char * p;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1754
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1755 while (*s && (p = strchr(hex, *s)) != NULL)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1756 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1757 unsigned digit = p - hex;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1758 if (digit > 15)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1759 digit -= 6;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1760 val = val * 16 + digit;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1761 s++;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1762 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1763 return val;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1764 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1765
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1766 /* We need to build a global list, since the EnumSystemLocale callback
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1767 function isn't given a context pointer. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1768 Lisp_Object Vwin32_valid_locale_ids;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1769
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1770 BOOL CALLBACK enum_locale_fn (LPTSTR localeNum)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1771 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1772 DWORD id = int_from_hex (localeNum);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1773 Vwin32_valid_locale_ids = Fcons (make_int (id), Vwin32_valid_locale_ids);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1774 return TRUE;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1775 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1776
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1777 DEFUN ("win32-get-valid-locale-ids", Fwin32_get_valid_locale_ids, 0, 0, "", /*
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1778 Return list of all valid Windows locale ids.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1779 Each id is a numerical value; use `win32-get-locale-info' to convert to a
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1780 human-readable form.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1781 */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1782 ())
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1783 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1784 Vwin32_valid_locale_ids = Qnil;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1785
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1786 EnumSystemLocales (enum_locale_fn, LCID_SUPPORTED);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1787
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1788 Vwin32_valid_locale_ids = Fnreverse (Vwin32_valid_locale_ids);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1789 return Vwin32_valid_locale_ids;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1790 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1791
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1792
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1793 DEFUN ("win32-set-current-locale", Fwin32_set_current_locale, 1, 1, "", /*
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1794 Make Windows locale LCID be the current locale setting for Emacs.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1795 If successful, the new locale id is returned, otherwise nil.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1796 */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1797 (lcid))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1798 {
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1799 CHECK_INT (lcid);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1800
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1801 if (!IsValidLocale (XINT (lcid), LCID_SUPPORTED))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1802 return Qnil;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1803
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1804 if (!SetThreadLocale (XINT (lcid)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1805 return Qnil;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1806
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1807 /* Sync with FSF Emacs 19.34.6 note: dwWinThreadId declared in
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1808 w32term.h and defined in w32fns.c, both of which are not in current
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1809 XEmacs. ### Check what we lose by ifdef'ing out these. --marcpa */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1810 #if 0
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1811 /* Need to set input thread locale if present. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1812 if (dwWinThreadId)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1813 /* Reply is not needed. */
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1814 PostThreadMessage (dwWinThreadId, WM_EMACS_SETLOCALE, XINT (lcid), 0);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1815 #endif
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1816
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1817 return make_int (GetThreadLocale ());
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1818 }
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1819
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1820
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1821 syms_of_ntproc ()
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1822 {
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1823 Qhigh = intern ("high");
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1824 Qlow = intern ("low");
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1825
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1826 #ifdef HAVE_SOCKETS
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1827 DEFSUBR (Fwin32_has_winsock);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1828 DEFSUBR (Fwin32_unload_winsock);
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1829 #endif
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1830 DEFSUBR (Fwin32_short_file_name);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1831 DEFSUBR (Fwin32_long_file_name);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1832 DEFSUBR (Fwin32_set_process_priority);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1833 DEFSUBR (Fwin32_get_locale_info);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1834 DEFSUBR (Fwin32_get_current_locale_id);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1835 DEFSUBR (Fwin32_get_default_locale_id);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1836 DEFSUBR (Fwin32_get_valid_locale_ids);
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1837 DEFSUBR (Fwin32_set_current_locale);
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1838
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1839 DEFVAR_LISP ("win32-quote-process-args", &Vwin32_quote_process_args /*
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1840 Non-nil enables quoting of process arguments to ensure correct parsing.
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1841 Because Windows does not directly pass argv arrays to child processes,
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1842 programs have to reconstruct the argv array by parsing the command
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1843 line string. For an argument to contain a space, it must be enclosed
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1844 in double quotes or it will be parsed as multiple arguments.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1845
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1846 If the value is a character, that character will be used to escape any
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1847 quote characters that appear, otherwise a suitable escape character
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1848 will be chosen based on the type of the program.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1849 */ );
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1850 Vwin32_quote_process_args = Qt;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1851
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1852 DEFVAR_LISP ("win32-start-process-show-window",
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1853 &Vwin32_start_process_show_window /*
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1854 When nil, processes started via start-process hide their windows.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1855 When non-nil, they show their window in the method of their choice.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1856 */ );
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1857 Vwin32_start_process_show_window = Qnil;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1858
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1859 DEFVAR_LISP ("win32-start-process-share-console",
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1860 &Vwin32_start_process_share_console /*
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1861 When nil, processes started via start-process are given a new console.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1862 When non-nil, they share the Emacs console; this has the limitation of
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1863 allowing only only DOS subprocess to run at a time (whether started directly
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1864 or indirectly by Emacs), and preventing Emacs from cleanly terminating the
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1865 subprocess group, but may allow Emacs to interrupt a subprocess that doesn't
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1866 otherwise respond to interrupts from Emacs.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1867 */ );
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1868 Vwin32_start_process_share_console = Qnil;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1869
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1870 DEFVAR_INT ("win32-pipe-read-delay", &Vwin32_pipe_read_delay /*
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1871 Forced delay before reading subprocess output.
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1872 This is done to improve the buffering of subprocess output, by
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1873 avoiding the inefficiency of frequently reading small amounts of data.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1874
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1875 If positive, the value is the number of milliseconds to sleep before
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1876 reading the subprocess output. If negative, the magnitude is the number
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1877 of time slices to wait (effectively boosting the priority of the child
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1878 process temporarily). A value of zero disables waiting entirely.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1879 */ );
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1880 Vwin32_pipe_read_delay = 50;
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1881
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1882 DEFVAR_LISP ("win32-downcase-file-names", &Vwin32_downcase_file_names /*
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1883 Non-nil means convert all-upper case file names to lower case.
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1884 This applies when performing completions and file name expansion.*/ );
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1885 Vwin32_downcase_file_names = Qnil;
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1886
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1887 #if 0
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1888 DEFVAR_LISP ("win32-generate-fake-inodes", &Vwin32_generate_fake_inodes /*
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1889 "Non-nil means attempt to fake realistic inode values.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1890 This works by hashing the truename of files, and should detect
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1891 aliasing between long and short (8.3 DOS) names, but can have
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1892 false positives because of hash collisions. Note that determing
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1893 the truename of a file can be slow.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1894 */ );
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1895 Vwin32_generate_fake_inodes = Qnil;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1896 #endif
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1897
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1898 DEFVAR_LISP ("win32-get-true-file-attributes", &Vwin32_get_true_file_attributes /*
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1899 "Non-nil means determine accurate link count in file-attributes.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1900 This option slows down file-attributes noticeably, so is disabled by
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1901 default. Note that it is only useful for files on NTFS volumes,
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1902 where hard links are supported.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1903 */ );
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents: 124
diff changeset
1904 Vwin32_get_true_file_attributes = Qnil;
100
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1905 }
4be1180a9e89 Import from CVS: tag r20-1b2
cvs
parents:
diff changeset
1906 /* end of ntproc.c */