Mercurial > emacs
view lisp/w32-fns.el @ 17692:426dde653028 gnumach-release-1-1 gnumach-release-1-1-1 libc-970508 libc-970509 libc-970510 libc-970511 libc-970512 libc-970513 libc-970514 libc-970515 libc-970516 libc-970517 libc-970518 libc-970519 libc-970520 libc-970521 libc-970522 libc-970523 libc-970524 libc-970525 libc-970526 libc-970527 libc-970528 libc-970529 libc-970530 libc-970531 libc-970601 libc-970602 libc-970603 libc-970604 libc-970605
Recognize either / or - as a machine/suptype separator from uname -m
to cope with older systems that have the older uname.
author | Thomas Bushnell, BSG <thomas@gnu.org> |
---|---|
date | Wed, 07 May 1997 19:19:04 +0000 |
parents | f57de209f01b |
children | 4b8ff0021dcb |
line wrap: on
line source
;;; 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