keymap.el
来自「A framework written in Java for implemen」· EL 代码 · 共 499 行 · 第 1/2 页
EL
499 行
;; keymap.el --- Keymap functions for XEmacs.;; Copyright (C) 1993-4, 1997 Free Software Foundation, Inc.;; Copyright (C) 1995 Tinker Systems and INS Engineering Corp.;; Maintainer: XEmacs Development Team;; Keywords: internals, dumped;; This file is part of XEmacs.;; XEmacs 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.;; XEmacs 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 XEmacs; see the file COPYING. If not, write to the;; Free Software Foundation, 59 Temple Place - Suite 330,;; Boston, MA 02111-1307, USA.;;; Synched up with: FSF 19.28.;;; Commentary:;; This file is dumped with XEmacs.;;; Note: FSF does not have a file keymap.el. This stuff is;;; in keymap.c.;Prevent the \{...} documentation construct;from mentioning keys that run this command.;;; Code:(put 'undefined 'suppress-keymap t)(defun undefined () (interactive) (ding));;(defmacro kbd (keys);; "Convert KEYS to the internal Emacs key representation.;;KEYS should be a string in the format used for saving keyboard macros;;\(see `insert-kbd-macro').";; (if (or (stringp keys);; (vectorp keys));; (read-kbd-macro keys);; `(read-kbd-macro ,keys)))(defun suppress-keymap (map &optional nodigits) "Make MAP override all normally self-inserting keys to be undefined.Normally, as an exception, digits and minus-sign are set to make prefix args,but optional second arg NODIGITS non-nil treats them like other chars." (substitute-key-definition 'self-insert-command 'undefined map global-map) (or nodigits (let ((string (make-string 1 ?0))) (define-key map "-" 'negative-argument) ;; Make plain numbers do numeric args. (while (<= (aref string 0) ?9) (define-key map string 'digit-argument) (incf (aref string 0))))))(defun substitute-key-definition (olddef newdef keymap &optional oldmap prefix) "Replace OLDDEF with NEWDEF for any keys in KEYMAP now defined as OLDDEF.In other words, OLDDEF is replaced with NEWDEF wherever it appears.Prefix keymaps are checked recursively. If optional fourth argument OLDMAPis specified, we redefine in KEYMAP as NEWDEF those chars which are definedas OLDDEF in OLDMAP, unless that keybinding is already present in keymap.If optional fifth argument PREFIX is defined, then only those occurrences ofOLDDEF found in keymaps accessible through the keymap bound to PREFIX inKEYMAP are redefined. See also `accessible-keymaps'." (let ((maps (accessible-keymaps (or oldmap keymap) prefix)) (shadowing (not (null oldmap))) prefix map) (while maps (setq prefix (car (car maps)) map (cdr (car maps)) maps (cdr maps)) ;; Substitute in this keymap (map-keymap #'(lambda (key binding) (if (eq binding olddef) ;; The new bindings always go in KEYMAP even if we ;; found them in OLDMAP or one of its children. ;; If KEYMAP will be shadowing OLDMAP, then do not ;; redefine the key if there is another binding ;; in KEYMAP that will shadow OLDDEF. (or (and shadowing (lookup-key keymap key)) ;; define-key will give an error if a prefix ;; of the key is already defined. Otherwise ;; it will define the key in the map. ;; #### - Perhaps this should be protected? (define-key keymap (vconcat prefix (list key)) newdef)))) map) )));; From Bill Dubuque <wgd@martigny.ai.mit.edu>;; This used to wrap forms into an interactive lambda. It is unclear;; to me why this is needed in this function. Anyway,;; `key-or-menu-binding' doesn't do it, so this function no longer;; does it, either.(defun insert-key-binding (key) ; modeled after describe-key "Insert the command bound to KEY." (interactive "kInsert command bound to key: ") (let ((defn (key-or-menu-binding key))) (if (or (null defn) (integerp defn)) (error "%s is undefined" (key-description key)) (if (or (stringp defn) (vectorp defn)) (setq defn (key-binding defn))) ;; a keyboard macro (insert (format "%s" defn)))))#|;; From Bill Dubuque <wgd@martigny.ai.mit.edu>(defun read-command-or-command-sexp (prompt) "Read a command symbol or command sexp.A command sexp is wrapped in an interactive lambda if needed.Prompts with PROMPT." ;; Todo: it would be better if we could reject symbols that are not ;; commandp (as does 'read-command') but that is not easy to do ;; because we must supply arg4 = require-match = nil for sexp case. (let ((result (car (read-from-string (completing-read prompt obarray 'commandp))))) (if (and (consp result) (not (eq (car result) 'lambda))) `(lambda () (interactive) ,result) result)))|#(defun local-key-binding (keys) "Return the binding for command KEYS in current local keymap only.KEYS is a string, a vector of events, or a vector of key-description listsas described in the documentation for the `define-key' function.The binding is probably a symbol with a function definition; seethe documentation for `lookup-key' for more information." (let ((map (current-local-map))) (if map (lookup-key map keys) nil)))(defun global-key-binding (keys) "Return the binding for command KEYS in current global keymap only.KEYS is a string or vector of events, a sequence of keystrokes.The binding is probably a symbol with a function definition; seethe documentation for `lookup-key' for more information." (lookup-key (current-global-map) keys));; from Bill Dubuque <wgd@martigny.ai.mit.edu>(defun global-set-key (key command) "Give KEY a global binding as COMMAND.COMMAND is a symbol naming an interactively-callable function.KEY is a string, a vector of events, or a vector of key-description listsas described in the documentation for the `define-key' function.Note that if KEY has a local binding in the current bufferthat local binding will continue to shadow any global binding." ;;(interactive "KSet key globally: \nCSet key %s to command: ") (interactive (list (setq key (read-key-sequence "Set key globally: ")) ;; Command sexps are allowed here so that this arg ;; may be supplied interactively via insert-key-binding. (read-command-or-command-sexp (format "Set key %s to command: " (key-description key))))) (define-key (current-global-map) key command) nil);; from Bill Dubuque <wgd@martigny.ai.mit.edu>(defun local-set-key (key command) "Give KEY a local binding as COMMAND.COMMAND is a symbol naming an interactively-callable function.KEY is a string, a vector of events, or a vector of key-description listsas described in the documentation for the `define-key' function.The binding goes in the current buffer's local map,which is shared with other buffers in the same major mode." ;;(interactive "KSet key locally: \nCSet key %s locally to command: ") (interactive (list (setq key (read-key-sequence "Set key locally: ")) ;; Command sexps are allowed here so that this arg ;; may be supplied interactively via insert-key-binding. (read-command-or-command-sexp (format "Set key %s locally to command: " (key-description key))))) (if (null (current-local-map)) (use-local-map (make-sparse-keymap))) (define-key (current-local-map) key command) nil)(defun global-unset-key (key) "Remove global binding of KEY.KEY is a string, a vector of events, or a vector of key-description listsas described in the documentation for the `define-key' function." (interactive "kUnset key globally: ") (global-set-key key nil))(defun local-unset-key (key) "Remove local binding of KEY.KEY is a string, a vector of events, or a vector of key-description listsas described in the documentation for the `define-key' function." (interactive "kUnset key locally: ") (if (current-local-map) (define-key (current-local-map) key nil)));; FSF-inherited brain-death.(defun minor-mode-key-binding (key &optional accept-default) "Find the visible minor mode bindings of KEY.Return an alist of pairs (MODENAME . BINDING), where MODENAME isthe symbol which names the minor mode binding KEY, and BINDING isKEY's definition in that mode. In particular, if KEY has nominor-mode bindings, return nil. If the first binding is anon-prefix, all subsequent bindings will be omitted, since they wouldbe ignored. Similarly, the list doesn't include non-prefix bindingsthat come after prefix bindings.If optional argument ACCEPT-DEFAULT is non-nil, recognize defaultbindings; see the description of `lookup-key' for more details about this." (let ((tail minor-mode-map-alist) a s v) (while tail (setq a (car tail) tail (cdr tail)) (and (consp a) (symbolp (setq s (car a))) (boundp s) (symbol-value s) ;; indirect-function deals with autoloadable keymaps (setq v (indirect-function (cdr a))) (setq v (lookup-key v key accept-default)) ;; Terminate loop, with v set to non-nil value (setq tail nil))) v))(defun current-minor-mode-maps () "Return a list of keymaps for the minor modes of the current buffer." (let ((l '()) (tail minor-mode-map-alist) a s v) (while tail (setq a (car tail) tail (cdr tail))
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?