Initial revision
[bpt/emacs.git] / lisp / w32-fns.el
index 39eb75c..2bd25bc 100644 (file)
@@ -1,4 +1,4 @@
-;;; winnt.el --- Lisp routines for Windows NT.
+;;; w32-fns.el --- Lisp routines for Windows NT.
 
 ;; Copyright (C) 1994 Free Software Foundation, Inc.
 
 ;; Ignore case on file-name completion
 (setq completion-ignore-case t)
 
-;; The cmd.exe shell uses the "/c" switch instead of the "-c" switch
-;; for executing its command line argument (from simple.el).
-(setq shell-command-switch "/c")
-
-;;; Avoid creating auto-save file names containing illegal characters
-;;; (primarily "*", eg. for the *mail* buffer).
+(defvar w32-system-shells '("cmd" "cmd.exe" "command" "command.com")
+  "List of strings recognized as Windows NT/95 system shells.")
+
+(defun w32-using-nt ()
+  "Return t if running on Windows NT (as oppposed to, e.g., Windows 95)."
+  (and (eq system-type 'windows-nt) (getenv "SystemRoot")))
+
+(defun w32-shell-name ()
+  "Return the name of the shell being used on Windows NT/95."
+  (or (and (boundp 'explicit-shell-file-name) explicit-shell-file-name)
+      (getenv "ESHELL")
+      (getenv "SHELL")
+      (and (w32-using-nt) "cmd.exe")
+      "command.com"))
+
+(defun w32-using-system-shell-p ()
+  "Return t if using a Windows NT/95 system shell (cmd.exe or command.com)."
+  (member (downcase (file-name-nondirectory (w32-shell-name))) 
+         w32-system-shells))
+
+(defun w32-startup ()
+  "Configure Emacs during startup for running on Windows NT/95.
+This function is invoked after loading the init files and processing
+the command line, and is intended to initialize anything important 
+not initialized by the user or site."
+  ;; Configure shell mode if using a system shell.
+  (cond ((w32-using-system-shell-p)
+        (let ((shell (file-name-nondirectory (w32-shell-name))))
+          ;; "/c" is used for executing command line arguments.
+          (setq shell-command-switch "/c")
+          ;; Complete directories using a backslash.
+          (setq comint-completion-addsuffix '("\\" . " "))
+          ;; Initialize the explicit-"shell"-args variable.
+          (cond ((member (downcase shell) '("cmd" "cmd.exe"))
+                 (let* ((args-sym-name (format "explicit-%s-args" shell))
+                        (args-sym (intern-soft args-sym-name)))
+                   (cond ((not args-sym)
+                          (setq args-sym (intern args-sym-name))
+                          ;; The "/q" prevents cmd.exe from echoing commands.
+                          (set args-sym '("/q")))))))))))
+
+(add-hook 'emacs-startup-hook 'w32-startup)
+
+;; Avoid creating auto-save file names containing invalid characters.
 (fset 'original-make-auto-save-file-name
       (symbol-function 'make-auto-save-file-name))
 
@@ -58,15 +96,24 @@ before calling this function.  You can redefine this for customization.
 See also `auto-save-file-name-p'."
   (let ((name (original-make-auto-save-file-name))
        (start 0))
-    ;; destructively replace occurences of * or ? with $
-    (while (string-match "[?*]" name start)
+    ;; Skip drive letter if present.
+    (if (string-match "^[\/]?[a-zA-`]:" name)
+       (setq start (- (match-end 0) (match-beginning 0))))
+    ;; Destructively replace occurrences of *?"<>|: with $
+    (while (string-match "[?*\"<>|:]" name start)
       (aset name (match-beginning 0) ?$)
       (setq start (1+ (match-end 0))))
     name))
 
 ;;; Fix interface to (X-specific) mouse.el
-(defalias 'x-set-selection 'ignore)
-(fset 'x-get-selection '(lambda (&rest rest) ""))
+(defun x-set-selection (type data)
+  (or type (setq type 'PRIMARY))
+  (put 'x-selections type data))
+
+(defun x-get-selection (&optional type data-type)
+  (or type (setq type 'PRIMARY))
+  (get 'x-selections type))
+
 (fmakunbound 'font-menu-add-default)
 (global-unset-key [C-down-mouse-1])
 (global-unset-key [C-down-mouse-2])
@@ -75,4 +122,4 @@ See also `auto-save-file-name-p'."
 ;;; Set to a system sound if you want a fancy bell.
 (set-message-beep nil)
 
-;;; winnt.el ends here
+;;; w32-fns.el ends here