1
0
mirror of https://git.savannah.gnu.org/git/emacs.git synced 2025-01-05 11:45:45 +00:00
emacs/lisp/w32-fns.el
Geoff Voelker ee82af565d (w32-using-nt, w32-shell-name, w32-using-system-shell-p,
w32-startup): New functions.
(w32-system-shells): New variable.
1997-04-24 02:58:11 +00:00

126 lines
4.4 KiB
EmacsLisp

;;; w32-fns.el --- Lisp routines for Windows NT.
;; Copyright (C) 1994 Free Software Foundation, Inc.
;; Author: Geoff Voelker (voelker@cs.washington.edu)
;; This file is part of GNU Emacs.
;; GNU Emacs is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation; either version 2, or (at your option)
;; any later version.
;; GNU Emacs is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with GNU Emacs; see the file COPYING. If not, write to the
;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
;; Boston, MA 02111-1307, USA.
;;; Commentary:
;; (August 12, 1993)
;; Created.
;; (November 21, 1994)
;; [C-M-backspace] defined.
;; mode-line-format defined to show buffer file type.
;; audio bell initialized.
;;; Code:
;; Map delete and backspace
(define-key function-key-map [backspace] "\177")
(define-key function-key-map [delete] "\C-d")
(define-key function-key-map [M-backspace] [?\M-\177])
(define-key function-key-map [C-M-backspace] [\C-\M-delete])
;; Ignore case on file-name completion
(setq completion-ignore-case t)
(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))
(defun make-auto-save-file-name ()
"Return file name to use for auto-saves of current buffer.
Does not consider `auto-save-visited-file-name' as that variable is checked
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))
;; 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
(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])
(global-unset-key [C-down-mouse-3])
;;; Set to a system sound if you want a fancy bell.
(set-message-beep nil)
;;; w32-fns.el ends here