annotate lisp/win32-native.el @ 4792:95b04754ea8c

Make #'equalp more compatible with CL; add a compiler macro, test & doc it. lisp/ChangeLog addition: 2009-11-08 Aidan Kehoe <kehoea@parhasard.net> * cl-extra.el (cl-string-vector-equalp) (cl-bit-vector-vector-equalp, cl-vector-array-equalp) (cl-hash-table-contents-equalp): New functions, to implement equalp treating arrays with identical contents as equivalent, as specified by Common Lisp. (equalp): Revise this function to implement array equivalence, and the hash-table equalp behaviour specified by CL. * cl-macs.el (equalp): Add a compiler macro for this function, used when one of the arguments is constant, and as such, its type is known at compile time. man/ChangeLog addition: 2009-11-08 Aidan Kehoe <kehoea@parhasard.net> * lispref/objects.texi (Equality Predicates): Document #'equalp here, as well as #'equal and #'eq. tests/ChangeLog addition: 2009-12-31 Aidan Kehoe <kehoea@parhasard.net> * automated/lisp-tests.el: Test much of the functionality of equalp; add a pointer to Paul Dietz' ANSI test suite for this function, converted to Emacs Lisp. Not including the tests themselves in XEmacs because who owns the copyright on the files is unclear and the GCL people didn't respond to my queries.
author Aidan Kehoe <kehoea@parhasard.net>
date Thu, 31 Dec 2009 15:09:41 +0000
parents ecf1ebac70d8
children 308d34e9f07d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
611
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
1 ;;; win32-native.el --- Lisp routines when running on native MS Windows.
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
2
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
3 ;; Copyright (C) 1994 Free Software Foundation, Inc.
2367
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
4 ;; Copyright (C) 2000, 2004 Ben Wing.
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
5
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
6 ;; Maintainer: XEmacs Development Team
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
7 ;; Keywords: mouse, dumped
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
8
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
9 ;; This file is part of XEmacs.
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
10
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
11 ;; XEmacs is free software; you can redistribute it and/or modify it
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
12 ;; under the terms of the GNU General Public License as published by
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
13 ;; the Free Software Foundation; either version 2, or (at your option)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
14 ;; any later version.
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
15
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
16 ;; XEmacs is distributed in the hope that it will be useful, but
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
17 ;; WITHOUT ANY WARRANTY; without even the implied warranty of
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
19 ;; General Public License for more details.
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
20
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
21 ;; You should have received a copy of the GNU General Public License
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
22 ;; along with XEmacs; see the file COPYING. If not, write to the
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
23 ;; Free Software Foundation, 59 Temple Place - Suite 330,
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
24 ;; Boston, MA 02111-1307, USA.
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
25
611
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
26 ;;; Synched up with: Not in FSF.
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
27 ;;; (FSF has stuff in w32-fns.el and term/w32-win.el.)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
28
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
29 ;;; Commentary:
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
30
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
31 ;; This file is dumped with XEmacs for MS Windows (without cygwin).
611
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
32 ;; It is for stuff that is used specifically when `system-type' eq
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
33 ;; `windows-nt' (i.e. also applies to MinGW), and has nothing to do
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
34 ;; with the `mswindows' device type. Thus, it probably applies in
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
35 ;; non-interactive mode as well, and it DOES NOT APPLY to Cygwin.
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
36
611
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
37 ;; Based (originally) on NT Emacs version by Geoff Voelker
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
38 ;; (voelker@cs.washington.edu)
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
39 ;; Ported to XEmacs by Marc Paquette <marcpa@cam.org>
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
40 ;; Largely modified by Kirill M. Katsnelson <kkm@kis.ru>
611
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
41 ;; Rewritten from scratch by Ben Wing <ben@xemacs.org>. No code in common
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
42 ;; with FSF.
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
43
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
44 ;;; Code:
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
45
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
46 ;; For appending suffixes to directories and files in shell
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
47 ;; completions. This screws up cygwin users so we leave it out for
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
48 ;; now. Uncomment this if you only ever want to use cmd.
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
49
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
50 ;(defun nt-shell-mode-hook ()
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
51 ; (setq comint-completion-addsuffix '("\\" . " ")
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
52 ; comint-process-echoes t))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
53 ;(add-hook 'shell-mode-hook 'nt-shell-mode-hook)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
54
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
55 ;; Use ";" instead of ":" as a path separator (from files.el).
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
56 (setq path-separator ";")
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
57
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
58 ;; Set the grep regexp to match entries with drive letters.
776
79940b592197 [xemacs-hg @ 2002-03-15 07:43:14 by ben]
ben
parents: 611
diff changeset
59 (defvar grep-regexp-alist)
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
60 (setq grep-regexp-alist
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
61 '(("^\\(\\([a-zA-Z]:\\)?[^:( \t\n]+\\)[:( \t]+\\([0-9]+\\)[:) \t]" 1 3)))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
62
611
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
63 (defvar mswindows-system-shells '("cmd" "cmd.exe" "command" "command.com"
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
64 "4nt" "4nt.exe" "4dos" "4dos.exe"
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
65 "ndos" "ndos.exe")
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
66 "List of strings recognized as Windows NT/9X system shells.
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
67 These are shells with native semantics, e.g. they use `/c', not '-c',
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
68 to pass a command in.")
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
69
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
70 (defun mswindows-system-shell-p (shell-name)
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
71 (member (downcase (file-name-nondirectory shell-name))
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
72 mswindows-system-shells))
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
73
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
74 (defun init-mswindows-at-startup ()
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
75 ;; shell-file-name is initialized in the C code (callproc.c) from
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
76 ;; SHELL or COMSPEC.
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
77 ;; #### If only shell-command-switch could be a function. But there
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
78 ;; is code littered around that uses it.
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
79 ;; #### Maybe we should set a symbol-value handler on `shell-file-name'
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
80 ;; that automatically sets shell-command-switch?
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
81 (if (mswindows-system-shell-p shell-file-name)
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
82 (setq shell-command-switch "/c")))
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
83
2367
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
84 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
85 ;; ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
86 ;; Quoting process args ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
87 ;; ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
88 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
89
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
90 ;; Converting a bunch of args into a single command line or vice-versa is
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
91 ;; extremely hairy due to the quoting conventions needed. There is in fact
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
92 ;; code that does this in the CRT, and perhaps we should look at it and
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
93 ;; follow the logic.
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
94
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
95 ;; Here is some further info from MSDN, discovered *AFTER* the actual code
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
96 ;; below was written, and hence the code may not follow what it should.
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
97 ;; !!#### But this is definitely something to be fixed up. The article is
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
98 ;; called "Parsing C++ Command-Line Arguments", Visual Tools and Langs ->
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
99 ;; Visual Studio -> Visual C++ -> Reference -> C/C++ Lang and ... -> C++
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
100 ;; Lang Ref -> Basic Concepts -> Startup and Termination -> Program
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
101 ;; Startup: the main Function.
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
102
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
103 ;; Microsoft Specific
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
104 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
105 ;; Microsoft C/C++ startup code uses the following rules when interpreting
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
106 ;; arguments given on the operating system command line:
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
107 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
108 ;; Arguments are delimited by white space, which is either a space or a tab.
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
109 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
110 ;; The caret character (^) is not recognized as an escape character or
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
111 ;; delimiter. The character is handled completely by the command-line parser
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
112 ;; in the operating system before being passed to the argv array in the
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
113 ;; program.
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
114 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
115 ;; A string surrounded by double quotation marks ("string") is interpreted as
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
116 ;; a single argument, regardless of white space contained within. A quoted
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
117 ;; string can be embedded in an argument.
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
118 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
119 ;; A double quotation mark preceded by a backslash ( \") is interpreted as a
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
120 ;; literal double quotation mark character (").
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
121 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
122 ;; Backslashes are interpreted literally, unless they immediately precede a
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
123 ;; double quotation mark.
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
124 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
125 ;; If an even number of backslashes is followed by a double quotation mark,
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
126 ;; one backslash is placed in the argv array for every pair of backslashes,
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
127 ;; and the double quotation mark is interpreted as a string delimiter.
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
128 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
129 ;; If an odd number of backslashes is followed by a double quotation mark, one
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
130 ;; backslash is placed in the argv array for every pair of backslashes, and
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
131 ;; the double quotation mark is "escaped" by the remaining backslash,
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
132 ;; causing a literal double quotation mark (") to be placed in argv.
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
133 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
134 ;; The following program demonstrates how command-line arguments are passed:
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
135 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
136 ;; include <iostream.h>
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
137 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
138 ;; void main( int argc, // Number of strings in array argv
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
139 ;; char *argv[], // Array of command-line argument strings
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
140 ;; char *envp[] ) // Array of environment variable strings
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
141 ;; {
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
142 ;; int count;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
143 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
144 ;; // Display each command-line argument.
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
145 ;; cout << "\nCommand-line arguments:\n";
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
146 ;; for( count = 0; count < argc; count++ )
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
147 ;; cout << " argv[" << count << "] "
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
148 ;; << argv[count] << "\n";
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
149 ;; }
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
150 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
151 ;; Table 2.2 shows example input and expected output, demonstrating the rules
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
152 ;; in the preceding list.
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
153 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
154 ;; Table 2.2
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
155 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
156 ;; Command-Line Input argv[1] argv[2] argv[3]
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
157 ;; ------------------------------------------
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
158 ;; "abc" d e abc d e
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
159 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
160 ;; a\\\b d"e f"g h a\\\b de fg h
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
161 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
162 ;; a\\\"b c d a\"b c d
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
163 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
164 ;; a\\\\"b c" d e a\\b c d e
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
165 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
166 ;; END Microsoft Specific
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
167 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
168 ;; note: for pulling apart an arg:
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
169 ;; each arg consists of either
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
170
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
171 ;; something surrounded by single quotes
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
172
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
173 ;; or
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
174
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
175 ;; one or more of
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
176
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
177 ;; 1. a non-ws, non-" char
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
178 ;; 2. a section of double-quoted text
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
179 ;; 3. a section of double-quoted text with end-of-string instead of the final
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
180 ;; quote.
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
181
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
182 ;; 2 and 3 get handled together.
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
183
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
184 ;; quoted text is one of
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
185 ;;
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
186 ;; 1. quote + even number of backslashes + quote, or
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
187 ;; 2. quote + non-greedy anything + non-backslash + even number of
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
188 ;; backslashes + quote.
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
189
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
190 ;; we need to separate the two because we unfortunately have no non-greedy
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
191 ;; ? operator. (urk! we actually do, but it wasn't documented.) --ben
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
192
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
193 ;; if you want to mess around, keep this test case in mind:
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
194
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
195 ;; this string
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
196
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
197 ;; " as'f 'FOO BAR' '' \"\" \"asdf \\ \\\" \\\\\\\" asdfasdf\\\\\" foo\" "
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
198
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
199 ;; should tokenize into this:
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
200
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
201 ;; (" " "as'f" " " "'FOO BAR' " "'' " "\"\"" " " "\"asdf \\ \\\" \\\\\\\" asdfasdf\\\\\"" " " "foo" "\" ")
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 1695
diff changeset
202
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
203
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
204 (defvar debug-mswindows-process-command-lines nil
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
205 "If non-nil, output debug information about the command lines constructed.
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
206 This can be useful if you are getting process errors where the arguments
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
207 to the process appear to be getting passed incorrectly.")
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
208
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
209 ;; properly quotify one arg for the vc runtime argv constructor.
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
210 (defun mswindows-quote-one-vc-runtime-arg (arg &optional quote-shell)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
211 ;; we mess with any arg with whitespace, quotes, or globbing chars in it.
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
212 ;; we also include shell metachars if asked.
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
213 ;; note that \ is NOT included! it's perfectly OK to include an
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
214 ;; arg like c:\ or c:\foo.
611
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
215 (cond ((equal arg "") "\"\"")
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
216 ((string-match
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
217 (if quote-shell "[ \t\n\r\f*?\"<>|&^%]" "[ \t\n\r\f*?\"]")
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
218 arg)
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
219 ;; handle nested quotes, possibly preceded by backslashes
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
220 (setq arg (replace-in-string arg "\\([\\]*\\)\"" "\\1\\1\\\\\""))
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
221 ;; handle trailing backslashes
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
222 (setq arg (replace-in-string arg "\\([\\]+\\)$" "\\1\\1"))
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
223 (concat "\"" arg "\""))
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
224 (t arg)))
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
225
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
226 (defun mswindows-quote-one-simple-arg (arg &optional quote-shell)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
227 ;; just put double quotes around args with spaces (and maybe shell
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
228 ;; metachars).
611
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
229 (cond ((equal arg "") "\"\"")
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
230 ((string-match
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
231 (if quote-shell "[ \t\n\r\f*?\"<>|&^%]" "[ \t\n\r\f*?]")
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
232 arg)
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
233 (concat "\"" arg "\""))
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
234 (t arg)))
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
235
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
236 (defun mswindows-quote-one-command-arg (arg)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
237 ;; quote an arg to get it past COMMAND.COM/CMD.EXE: need to quote shell
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
238 ;; metachars with ^.
611
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
239 (cond ((equal arg "") "\"\"")
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
240 (t (replace-in-string "[<>|&^%]" "^\\1" arg))))
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
241
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
242 (defun mswindows-construct-verbatim-command-line (program args)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
243 (mapconcat #'identity args " "))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
244
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
245 ;; for use with either standard VC++ compiled programs or Cygwin programs,
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
246 ;; which emulate the same behavior.
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
247 (defun mswindows-construct-vc-runtime-command-line (program args)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
248 (mapconcat #'mswindows-quote-one-vc-runtime-arg args " "))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
249
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
250 ;; this regexp actually separates the arg into individual args, like a
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
251 ;; shell (such as sh) does, but using vc-runtime rules. it's easy to
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
252 ;; derive the tokenizing regexp from it, and that's exactly what i did.
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
253 ;; but oh was it hard to get this first regexp right. --ben
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
254 ;(defvar mswindows-match-one-cmd-exe-arg-regexp
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
255 ; (concat
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
256 ; "^\\("
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
257 ; "'\\([\\]*\\)\\2'" "\\|"
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
258 ; "'.*?[^\\]\\(\\([\\]*\\)\\4'\\)" "\\|"
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
259 ; "\\("
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
260 ; "[^ \t\n\r\f\v\"]" "\\|"
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
261 ; "\"\\([\\]*\\)\\6\"" "\\|"
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
262 ; "\".*?[^\\]\\(\\([\\]*\\)\\8\"\\|$\\)"
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
263 ; "\\)+"
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
264 ; "\\)"
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
265 ; "\\([ \t\n\r\f\v]+\\|$\\)"))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
266
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
267 (defvar mswindows-match-one-cmd-exe-token-regexp
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
268 (concat
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
269 "^\\("
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
270 "[ \t\n\r\f\v]+" "\\|"
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
271 "'\\([\\]*\\)\\2'" "\\([ \t\n\r\f\v]+\\|$\\)" "\\|"
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
272 "'.*?[^\\]\\(\\([\\]*\\)\\5'\\)" "\\([ \t\n\r\f\v]+\\|$\\)" "\\|"
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
273 "[^ \t\n\r\f\v\"]+" "\\|"
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
274 "\"\\([\\]*\\)\\7\"" "\\|"
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
275 "\".*?[^\\]\\(\\([\\]*\\)\\9\"\\|$\\)"
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
276 "\\)"))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
277
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
278 (defun mswindows-construct-command-command-line (program args)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
279 ;; for use with COMMAND.COM and CMD.EXE:
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
280 ;; for each arg, tokenize it into quoted and non-quoted sections;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
281 ;; then quote all the shell meta-chars with ^; then put everything
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
282 ;; back together. the truly hard part is the tokenizing -- typically
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
283 ;; we get a single argument (the command to execute) and we have to
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
284 ;; worry about quotes that are backslash-quoted and such.
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
285 (mapconcat
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
286 #'(lambda (arg)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
287 (mapconcat
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
288 #'(lambda (part)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
289 (if (string-match "^'" part)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
290 (replace-in-string part "\\([<>|^&%]\\)" "^\\1")
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
291 part))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
292 (let (parts)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
293 (while (and (> (length arg) 0)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
294 (string-match
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
295 mswindows-match-one-cmd-exe-token-regexp
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
296 arg))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
297 (push (match-string 0 arg) parts)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
298 (setq arg (substring arg (match-end 0))))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
299 (if (> (length arg) 0)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
300 (push arg parts))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
301 (nreverse parts))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
302 ""))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
303 args " "))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
304
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
305 (defvar mswindows-construct-process-command-line-alist
611
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
306 '(
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
307 ;; at one point (pre-1.0), this was required for Cygwin bash.
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
308 ;; evidently, Cygwin changed its arg handling to work just like
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
309 ;; any standard VC program, so we no longer need it.
38db05db9cb5 [xemacs-hg @ 2001-06-08 12:21:09 by ben]
ben
parents: 464
diff changeset
310 ;;("[\\/].?.?sh\\." . mswindows-construct-verbatim-command-line)
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
311 ("[\\/]command\\.com$" . mswindows-construct-command-command-line)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
312 ("[\\/]cmd\\.exe$" . mswindows-construct-command-command-line)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
313 ("" . mswindows-construct-vc-runtime-command-line))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
314 "An alist for determining proper argument quoting given executable
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
315 file name. Car of each cons should be a string, a regexp against
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
316 which the file name is matched. Matching is case-insensitive but does
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
317 include the directory, so you should begin your regexp with [\\\\/] if
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
318 you don't want the directory to matter. Alternatively, the car can be
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
319 a function of one arg, which is called with the executable's name and
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
320 should return t if this entry should be processed. Cdr is a function
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
321 symbol, which is called with two args, the executable name and a list
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
322 of the args passed to it. It should return a string, which includes
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
323 the executable's args (but not the executable name itself) properly
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
324 quoted and pasted together. The list is matched in order, and the
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
325 first matching entry specifies how the processing will happen.")
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
326
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
327 (defun mswindows-construct-process-command-line (args)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
328 ;;Properly quote process ARGS for executing (car ARGS).
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
329 ;;Called from the C code.
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
330 (let ((fname (car args))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
331 (alist mswindows-construct-process-command-line-alist)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
332 (case-fold-search t)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
333 (return-me nil)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
334 (assoc nil))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
335 (while (and alist
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
336 (null return-me))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
337 (setq assoc (pop alist))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
338 (if (if (stringp (car assoc))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
339 (string-match (car assoc) fname)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
340 (funcall (car assoc) fname))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
341 (setq return-me (cdr assoc))))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
342 (let* ((called-fun (or return-me
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
343 #'mswindows-construct-vc-runtime-command-line))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
344 (retval
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
345 (let ((str (funcall called-fun fname (cdr args)))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
346 (quoted-fname (mswindows-quote-one-simple-arg fname)))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
347 (if (and str (> (length str) 0))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
348 (concat quoted-fname " " str)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
349 quoted-fname))))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
350 (when debug-mswindows-process-command-lines
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
351 (debug-print "mswindows-construct-process-command-line called:\n")
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
352 (debug-print "received args: \n%s"
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
353 (let ((n -1))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
354 (mapconcat #'(lambda (arg)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
355 (incf n)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
356 (format " %d %s\n" n arg))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
357 args
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
358 "")))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
359 (debug-print "called fun %s\n" called-fun)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
360 (debug-print "resulting command line: %s\n" retval))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
361 retval)))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
362
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents:
diff changeset
363 ;;; win32-native.el ends here