Mercurial > emacs
view lisp/emulation/viper.el @ 18170:7776ee6215de
(time-stamp-format): Doc fix. Use %;y.
(time-stamp-string-preprocess): Don't just call format-time-string;
handle compatibility for some old constructs. Handle padding
the historical way, while giving a warning if people actually depend on it.
(time-stamp-conv-warn, time-stamp-conversion-warn)
(time-stamp-do-number): New functions.
author | Richard M. Stallman <rms@gnu.org> |
---|---|
date | Sun, 08 Jun 1997 21:43:08 +0000 |
parents | e92598964ee6 |
children | e145ccc61a22 |
line wrap: on
line source
;;; viper.el --- A full-featured Vi emulator for GNU Emacs 19 and XEmacs 19, ;; a VI Plan for Emacs Rescue, ;; and a venomous VI PERil. ;; Viper Is also a Package for Emacs Rebels. ;; ;; Keywords: emulations ;; Author: Michael Kifer <kifer@cs.sunysb.edu> ;; Copyright (C) 1994, 1995, 1996, 1997 Free Software Foundation, Inc. (defconst viper-version "2.94 of June 2, 1997" "The current version of Viper") ;; 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: ;; Viper is a full-featured Vi emulator for Emacs 19. It emulates and ;; improves upon the standard features of Vi and, at the same time, allows ;; full access to all Emacs facilities. Viper supports multiple undo, ;; file name completion, command, file, and search history and it extends ;; Vi in many other ways. Viper is highly customizable through the various ;; hooks, user variables, and keymaps. It is implemented as a collection ;; of minor modes and it is designed to provide full access to all Emacs ;; major and minor modes. ;; ;;; History ;; ;; Viper is a new name for a package formerly known as VIP-19, ;; which was a successor of VIP version 3.5 by Masahiko Sato ;; <ms@sail.stanford.edu> and VIP version 4.2 by Aamod Sane ;; <sane@cs.uiuc.edu>. Some ideas from vip 4.4.2 by Aamod Sane ;; were also shamelessly plagiarized. ;; ;; Viper maintains some degree of compatibility with these older ;; packages. See the documentation for customization. ;; ;; The main difference between Viper and these older packages are: ;; ;; 1. Viper emulates Vi at several levels, from almost complete conformity ;; to a rather loose Vi-compliance. ;; ;; 2. Viper provides full access to all major and minor modes of Emacs ;; without the need to type extra keys. ;; The older versions of VIP (and other Vi emulators) do not work with ;; some major and minor modes. ;; ;; 3. Viper supports vi-style undo. ;; ;; 4. Viper fully emulates (and improves upon) vi's replacement mode. ;; ;; 5. Viper has a better interface to ex, including command, variable, and ;; file name completion. ;; ;; 6. Viper uses native Emacs history and completion features; it doesn't ;; rely on other packages (such as gmhist.el and completer.el) to provide ;; these features. ;; ;; 7. Viper supports Vi-style editing in the minibuffer, by allowing the ;; user to switch from Insert state to Vi state to Replace state, etc. ;; ;; 8. Viper keeps history of recently inserted pieces of text and recently ;; executed Vi-style destructive commands, such as `i', `d', etc. ;; These pieces of text can be inserted in later insertion commands; ;; the previous destructive commands can be re-executed. ;; ;; 9. Viper has Vi-style keyboard macros, which enhances the similar ;; facility in the original Vi. ;; First, one can execute any Emacs command while defining a ;; macro, not just the Vi commands. Second, macros are defined in a ;; WYSYWYG mode, using an interface to Emacs' WYSIWYG style of defining ;; macros. Third, in Viper, one can define macros that are specific to ;; a given buffer, a given major mode, or macros defined for all buffers. ;; The same macro name can have several different definitions: ;; one global, several definitions for various major modes, and ;; definitions for specific buffers. ;; Buffer-specific definitions override mode-specific ;; definitions, which, in turn, override global definitions. ;; ;; ;;; Installation: ;; ------------- ;; ;; (require 'viper) ;; ;;; Acknowledgements: ;; ----------------- ;; Bug reports and ideas contributed by many users have helped ;; improve Viper and the various versions of VIP. ;; See the on-line manual for a complete list of contributors. ;; ;; ;;; Notes: ;; ;; 1. Major modes. ;; In most cases, Viper handles major modes correctly, i.e., they come up ;; in the right state (either vi-state or emacs-state). For instance, text ;; files come up in vi-state, while, say, Dired appears in emacs-state by ;; default. ;; However, some modes do not appear in the right mode in the beginning, ;; usually because they neglect to follow Emacs conventions (e.g., they don't ;; use kill-all-local-variables when they start). Some major modes ;; may fail to come up in emacs-state if they call hooks, such as ;; text-hook, for no good reason. ;; ;; As an immediate solution, you can hit C-z to bring about the right mode. ;; An interim solution is to add an appropriate hook to the mode like this: ;; ;; (add-hook 'your-favorite-mode 'viper-mode) ;; or ;; (add-hook 'your-favorite-mode 'vip-change-state-to-emacs) ;; ;; whichever applies. The right thing to do, however, is to complain to the ;; author of the respective package. (Sometimes they also neglect to equip ;; their modes with hooks, which is one more reason for complaining.) ;; ;; 2. Keymap handling ;; Because Emacs 19 has an elegant mechanism for turning minor mode keymaps ;; on and off, implementation of Viper has been greatly simplified. Viper ;; has several minor modes. ;; ;; Viper's Vi state consists of seven minor modes: ;; ;; vip-vi-intercept-minor-mode ;; vip-vi-local-user-minor-mode ;; vip-vi-global-user-minor-mode ;; vip-vi-kbd-minor-mode ;; vip-vi-state-modifier-minor-mode ;; vip-vi-diehard-minor-mode ;; vip-vi-basic-minor-mode ;; ;; Bindings done to the keymap of the first mode overshadow those done to ;; the second, which, in turn, overshadows those done to the third, etc. ;; ;; The last vip-vi-basic-minor-mode contains most of the usual Vi bindings ;; in its edit mode. This mode provides access to all Emacs facilities. ;; Novice users, however, may want to set their vip-expert-level to 1 ;; in their .vip file. This will enable vip-vi-diehard-minor-mode. This ;; minor mode's bindings make Viper simulate the usual Vi very closely. ;; For instance, C-c will not have its standard Emacs binding ;; and so many of the goodies of Emacs are not available. ;; ;; A skilled user should set vip-expert-level to at least 3. This will ;; enable `C-c' and many Emacs facilities will become available. ;; In this case, vip-vi-diehard-minor-mode is inactive. ;; ;; Viper gurus should have at least ;; (setq vip-expert-level 4) ;; in their ~/.vip files. This will unsuppress all Emacs keys that are not ;; essential for VI-style editing. ;; Pick-and-choose users may want to put ;; (setq vip-expert-level 5) ;; in ~/.vip. Viper will then leave it up to the user to set the variables ;; vip-want-* See vip-set-expert-level for details. ;; ;; The very first minor mode, vip-vi-intercept-minor-mode, is of no ;; concern for the user. It is needed to bind Viper's vital keys, such as ;; ESC and C-z. ;; ;; The second mode, vip-vi-local-user-minor-mode, usually has an ;; empty keymap. However, the user can set bindings in this keymap, which ;; will overshadow the corresponding bindings in the other two minor ;; modes. This is useful, for example, for setting up ZZ in gnus, ;; rmail, mh-e, etc., to send message instead of saving it in a file. ;; Likewise, in Dired mode, you may want to bind ZN and ZP to commands ;; that would visit the next or the previous file in the Dired buffer. ;; Setting local keys is tricky, so don't do it directly. Instead, use ;; vip-add-local-keys function (see its doc). ;; ;; The third minor mode, vip-vi-global-user-minor-mode, is also intended ;; for the users but, unlike vip-vi-local-user-minor-mode, its key ;; bindings are seen in all Viper buffers. This mode keys can be done ;; with define-key command. ;; ;; The fourth minor mode, vip-vi-kbd-minor-mode, is used by keyboard ;; macros. Users are NOT supposed to modify this keymap directly. ;; ;; The fifth mode, vip-vi-state-modifier-minor-mode, can be used to set ;; key bindings that are visible in some major modes but not in others. ;; ;; Users are allowed to modify keymaps that belong to ;; vip-vi-local-user-minor-mode, vip-vi-global-user-minor-mode, ;; and vip-vi-state-modifier-minor-mode only. ;; ;; Viper's Insert state also has seven minor modes: ;; ;; vip-insert-intercept-minor-mode ;; vip-insert-local-user-minor-mode ;; vip-insert-global-user-minor-mode ;; vip-insert-kbd-minor-mode ;; vip-insert-state-modifier-minor-mode ;; vip-insert-diehard-minor-mode ;; vip-insert-basic-minor-mode ;; ;; As with VI's editing modes, the first mode, vip-insert-intercept-minor-mode ;; is used to bind vital keys that are not to be changed by the user. ;; ;; The next mode, vip-insert-local-user-minor-mode, is used to customize ;; bindings in the insert state of Viper. The third mode, ;; vip-insert-global-user-minor-mode is like ;; vip-insert-local-user-minor-mode, except that its bindings are seen in ;; all Viper buffers. As with vip-vi-local-user-minor-mode, its bindings ;; should be done via the function vip-add-local-keys. Bindings for ;; vip-insert-global-user-minor-mode can be set with the define-key command. ;; ;; The next minor mode, vip-insert-kbd-minor-mode, ;; is used for keyboard VI-style macros defined with :map!. ;; ;; The fifth minor mode, vip-insert-state-modifier-minor-mode, is like ;; vip-vi-state-modifier-minor-mode, except that it is used in the Insert ;; state; it can be used to modify keys in a mode-specific fashion. ;; ;; The minor mode vip-insert-diehard-minor-mode is in effect when ;; the user wants a high degree of Vi compatibility (a bad idea, really!). ;; The last minor mode, vip-insert-basic-minor-mode, is always in effect ;; when Viper is in insert state. It binds a small number of keys needed for ;; Viper's operation. ;; ;; Finally, Viper provides minor modes for overriding bindings set by Emacs ;; modes when Viper is in Emacs state: ;; ;; vip-emacs-local-user-minor-mode ;; vip-emacs-global-user-minor-mode ;; vip-emacs-kbd-minor-mode ;; vip-emacs-state-modifier-minor-mode ;; ;; These minor modes are in effect when Viper is in Emacs state. The keymap ;; associated with vip-emacs-global-user-minor-mode, ;; vip-emacs-global-user-map, overrides the global and local keymaps as ;; well as the minor mode keymaps set by other modes. The keymap of ;; vip-emacs-local-user-minor-mode, vip-emacs-local-user-map, overrides ;; everything, but it is used on a per buffer basis. ;; The keymap associated with vip-emacs-state-modifier-minor-mode ;; overrides keys on a per-major-mode basis. The mode ;; vip-emacs-kbd-minor-mode is used to define Vi-style macros in Emacs ;; state. ;; ;; 3. There is also one minor mode that is used when Viper is in its ;; replace-state (used for commands like cw, C, etc.). This mode is ;; called ;; ;; vip-replace-minor-mode ;; ;; and its keymap is vip-replace-map. Replace minor mode is always ;; used in conjunction with the minor modes for insert-state, and its ;; keymap overshadows the keymaps for insert minor modes. ;; ;; 4. Defining buffer-local bindings in Vi and Insert modes. ;; As mentioned before, sometimes, it is convenient to have ;; buffer-specific of mode-specific key bindings in Vi and insert modes. ;; Viper provides a special function, vip-add-local-keys, to do precisely ;; this. For instance, is you need to add couple of mode-specific bindings ;; to Insert mode, you can put ;; ;; (vip-add-local-keys 'insert-state '((key1 . func1) (key2 .func2))) ;; ;; somewhere in a hook of this major mode. If you put something like this ;; in your own elisp function, this will define bindings specific to the ;; buffer that was current at the time of the call to vip-add-local-keys. ;; The only thing to make sure here is that the major mode of this buffer ;; is written according to Emacs conventions, which includes a call to ;; (kill-all-local-variables). See vip-add-local-keys for more details. ;; ;; ;; TO DO (volunteers?): ;; ;; 1. Some of the code that is inherited from VIP-3.5 is rather ;; convoluted. Instead of vip-command-argument, keymaps should bind the ;; actual commands. E.g., "dw" should be bound to a generic command ;; vip-delete that will delete things based on the value of ;; last-command-char. This would greatly simplify the logic and the code. ;; ;; 2. Somebody should venture to write a customization package a la ;; options.el that would allow the user to change values of variables ;; that meet certain specs (e.g., match a regexp) and whose doc string ;; starts with a '*'. Then, the user should be offered to save ;; variables that were changed. This will make user's customization job ;; much easier. ;; ;; Code (require 'advice) (require 'cl) (require 'ring) (eval-when-compile (let ((load-path (cons (expand-file-name ".") load-path))) (or (featurep 'viper-cmd) (load "viper-cmd.el" nil nil 'nosuffix)) )) (require 'viper-cmd) ;; Viper version (defun viper-version () (interactive) (message "Viper version is %s" viper-version)) (defalias 'vip-version 'viper-version) ;; The following is provided for compatibility with older VIP's (defalias 'vip-change-mode-to-vi 'vip-change-state-to-vi) (defalias 'vip-change-mode-to-insert 'vip-change-state-to-insert) (defalias 'vip-change-mode-to-emacs 'vip-change-state-to-emacs) ;; Viper changes the default mode-line-buffer-identification (setq-default mode-line-buffer-identification '(" %b")) ;; Variable displaying the current Viper state in the mode line. (vip-deflocalvar vip-mode-string vip-emacs-state-id) (or (memq 'vip-mode-string global-mode-string) (setq global-mode-string (append '("" vip-mode-string) (cdr global-mode-string)))) ;;; Load set up hooks then load .vip ;; This hook designed to enable Vi-style editing in comint-based modes." (defun vip-comint-mode-hook () (setq require-final-newline nil vip-ex-style-editing-in-insert nil vip-ex-style-motion nil) (vip-change-state-to-insert)) ;; This sets major mode hooks to make them come up in vi-state. (defun vip-set-hooks () ;; It is of course a misnomer to call viper-mode a `major mode'. ;; However, this has the effect that if the user didn't specify the ;; default mode, new buffers that fall back on the default will come up ;; in Fundamental Mode and Vi state. (setq default-major-mode 'viper-mode) ;; The following major modes should come up in vi-state (defadvice fundamental-mode (after vip-fundamental-mode-ad activate) "Run `vip-change-state-to-vi' on entry." (vip-change-state-to-vi)) (defvar makefile-mode-hook) (add-hook 'makefile-mode-hook 'viper-mode) (defvar help-mode-hook) (add-hook 'help-mode-hook 'viper-mode) (vip-modify-major-mode 'help-mode 'vi-state vip-help-modifier-map) (defvar awk-mode-hook) (add-hook 'awk-mode-hook 'viper-mode) (defvar html-mode-hook) (add-hook 'html-mode-hook 'viper-mode) (defvar html-helper-mode-hook) (add-hook 'html-helper-mode-hook 'viper-mode) (defvar java-mode-hook) (add-hook 'java-mode-hook 'viper-mode) (defvar emacs-lisp-mode-hook) (add-hook 'emacs-lisp-mode-hook 'viper-mode) (defvar lisp-mode-hook) (add-hook 'lisp-mode-hook 'viper-mode) (defvar bibtex-mode-hook) (add-hook 'bibtex-mode-hook 'viper-mode) (defvar cc-mode-hook) (add-hook 'cc-mode-hook 'viper-mode) (defvar c-mode-hook) (add-hook 'c-mode-hook 'viper-mode) (defvar c++-mode-hook) (add-hook 'c++-mode-hook 'viper-mode) (defvar lisp-interaction-mode-hook) (add-hook 'lisp-interaction-mode-hook 'viper-mode) (defvar fortran-mode-hook) (add-hook 'fortran-mode-hook 'vip-mode) (defvar basic-mode-hook) (add-hook 'basic-mode-hook 'vip-mode) (defvar bat-mode-hook) (add-hook 'bat-mode-hook 'vip-mode) (defvar text-mode-hook) (add-hook 'text-mode-hook 'viper-mode) (add-hook 'completion-list-mode-hook 'viper-mode) (add-hook 'compilation-mode-hook 'viper-mode) (add-hook 'perl-mode-hook 'viper-mode) (add-hook 'tcl-mode-hook 'viper-mode) (defvar emerge-startup-hook) (add-hook 'emerge-startup-hook 'vip-change-state-to-emacs) ;; Tell vc-diff to put *vc* in Vi mode (if (featurep 'vc) (defadvice vc-diff (after vip-vc-ad activate) "Force Vi state in VC diff buffer." (vip-change-state-to-vi)) (vip-eval-after-load "vc" '(defadvice vc-diff (after vip-vc-ad activate) "Force Vi state in VC diff buffer." (vip-change-state-to-vi)))) (vip-eval-after-load "emerge" '(defadvice emerge-quit (after vip-emerge-advice activate) "Run `vip-change-state-to-vi' after quitting emerge." (vip-change-state-to-vi))) ;; In case Emerge was loaded before Viper. (defadvice emerge-quit (after vip-emerge-advice activate) "Run `vip-change-state-to-vi' after quitting emerge." (vip-change-state-to-vi)) (vip-eval-after-load "asm-mode" '(defadvice asm-mode (after vip-asm-mode-ad activate) "Run `vip-change-state-to-vi' on entry." (vip-change-state-to-vi))) ;; passwd.el sets up its own buffer, which turns up in Vi mode, ;; thus overriding the local map. We don't need Vi mode here. (vip-eval-after-load "passwd" '(defadvice read-passwd-1 (before vip-passwd-ad activate) "Switch to emacs state while reading password." (vip-change-state-to-emacs))) (vip-eval-after-load "prolog" '(defadvice prolog-mode (after vip-prolog-ad activate) "Switch to Vi state in Prolog mode." (vip-change-state-to-vi))) ;; Emacs shell, ange-ftp, and comint-based modes (defvar comint-mode-hook) (vip-modify-major-mode 'comint-mode 'insert-state vip-comint-mode-modifier-map) (vip-modify-major-mode 'comint-mode 'vi-state vip-comint-mode-modifier-map) (vip-modify-major-mode 'shell-mode 'insert-state vip-comint-mode-modifier-map) (vip-modify-major-mode 'shell-mode 'vi-state vip-comint-mode-modifier-map) ;; ange-ftp in XEmacs (vip-modify-major-mode 'ange-ftp-shell-mode 'insert-state vip-comint-mode-modifier-map) (vip-modify-major-mode 'ange-ftp-shell-mode 'vi-state vip-comint-mode-modifier-map) ;; ange-ftp in Emacs (vip-modify-major-mode 'internal-ange-ftp-mode 'insert-state vip-comint-mode-modifier-map) (vip-modify-major-mode 'internal-ange-ftp-mode 'vi-state vip-comint-mode-modifier-map) ;; set hook (add-hook 'comint-mode-hook 'vip-comint-mode-hook) ;; Shell scripts (defvar sh-mode-hook) (add-hook 'sh-mode-hook 'viper-mode) (defvar ksh-mode-hook) (add-hook 'ksh-mode-hook 'viper-mode) ;; Dired (vip-modify-major-mode 'dired-mode 'emacs-state vip-dired-modifier-map) (vip-set-emacs-search-style-macros nil 'dired-mode) (add-hook 'dired-mode-hook 'vip-change-state-to-emacs) ;; Tar (vip-modify-major-mode 'tar-mode 'emacs-state vip-slash-and-colon-map) (vip-set-emacs-search-style-macros nil 'tar-mode) ;; MH-E (vip-modify-major-mode 'mh-folder-mode 'emacs-state vip-slash-and-colon-map) (vip-set-emacs-search-style-macros nil 'mh-folder-mode) ;; changing state to emacs is needed so the preceding will take hold (add-hook 'mh-folder-mode-hook 'vip-change-state-to-emacs) (add-hook 'mh-show-mode-hook 'viper-mode) ;; Gnus (vip-modify-major-mode 'gnus-group-mode 'emacs-state vip-slash-and-colon-map) (vip-set-emacs-search-style-macros nil 'gnus-group-mode) (vip-modify-major-mode 'gnus-summary-mode 'emacs-state vip-slash-and-colon-map) (vip-set-emacs-search-style-macros nil 'gnus-summary-mode) ;; changing state to emacs is needed so the preceding will take hold (add-hook 'gnus-group-mode-hook 'vip-change-state-to-emacs) (add-hook 'gnus-summary-mode-hook 'vip-change-state-to-emacs) (add-hook 'gnus-article-mode-hook 'viper-mode) ;; Info (vip-modify-major-mode 'Info-mode 'emacs-state vip-slash-and-colon-map) (vip-set-emacs-search-style-macros nil 'Info-mode) ;; Switching to emacs is needed so the above will take hold (defadvice Info-mode (after vip-Info-ad activate) "Switch to emacs mode." (vip-change-state-to-emacs)) ;; Buffer menu (vip-modify-major-mode 'Buffer-menu-mode 'emacs-state vip-slash-and-colon-map) (vip-set-emacs-search-style-macros nil 'Buffer-menu-mode) ;; Switching to emacs is needed so the above will take hold (defadvice Buffer-menu-mode (after vip-Buffer-menu-ad activate) "Switch to emacs mode." (vip-change-state-to-emacs)) ;; View mode (if vip-emacs-p (progn (defvar view-mode-hook) (add-hook 'view-mode-hook 'vip-change-state-to-emacs)) (defadvice view-minor-mode (after vip-view-ad activate) "Switch to Emacs state in View mode." (vip-change-state-to-emacs)) (defvar view-hook) (add-hook 'view-hook 'vip-change-state-to-emacs)) ;; For VM users. ;; Put summary and other VM buffers in Emacs state. (defvar vm-mode-hooks) (defvar vm-summary-mode-hooks) (add-hook 'vm-mode-hooks 'vip-change-state-to-emacs) (add-hook 'vm-summary-mode-hooks 'vip-change-state-to-emacs) ;; For RMAIL users. ;; Put buf in Emacs state after edit. (vip-eval-after-load "rmailedit" '(defadvice rmail-cease-edit (after vip-rmail-advice activate) "Switch to emacs state when done editing message." (vip-change-state-to-emacs))) ;; In case RMAIL was loaded before Viper. (defadvice rmail-cease-edit (after vip-rmail-advice activate) "Switch to emacs state when done editing message." (vip-change-state-to-emacs)) ) ; vip-set-hooks ;; Set some useful macros ;; These must be before we load .vip, so the user could unrecord them. ;; repeat the 2nd previous command without rotating the command history (vip-record-kbd-macro (vector vip-repeat-from-history-key '\1) 'vi-state [(meta x) v i p - r e p e a t - f r o m - h i s t o r y return] 't) ;; repeat the 3d previous command without rotating the command history (vip-record-kbd-macro (vector vip-repeat-from-history-key '\2) 'vi-state [(meta x) v i p - r e p e a t - f r o m - h i s t o r y return] 't) ;; set the toggle case sensitivity and regexp search macros (vip-set-vi-search-style-macros nil) ;; Make %%% toggle parsing comments for matching parentheses (vip-record-kbd-macro "%%%" 'vi-state [(meta x) v i p - t o g g l e - p a r s e - s e x p - i g n o r e - c o m m e n t s return] 't) ;; ~/.vip is loaded if it exists (if (and (file-exists-p vip-custom-file-name) (not noninteractive)) (load vip-custom-file-name)) ;; VIP compatibility: merge whatever the user has in vip-mode-map into ;; Viper's basic map. (vip-add-keymap vip-mode-map vip-vi-global-user-map) ;; Applying Viper customization -- runs after (load .vip) ;; Save user settings or Viper defaults for vars controled by vip-expert-level (setq vip-saved-user-settings (list (cons 'vip-want-ctl-h-help vip-want-ctl-h-help) (cons 'vip-always vip-always) (cons 'vip-no-multiple-ESC vip-no-multiple-ESC) (cons 'vip-ex-style-motion vip-ex-style-motion) (cons 'vip-ex-style-editing-in-insert vip-ex-style-editing-in-insert) (cons 'vip-want-emacs-keys-in-vi vip-want-emacs-keys-in-vi) (cons 'vip-want-emacs-keys-in-insert vip-want-emacs-keys-in-insert) (cons 'vip-re-search vip-re-search))) (vip-set-minibuffer-style) (if vip-buffer-search-char (vip-buffer-search-enable)) (vip-update-alphanumeric-class) ;;; Familiarize Viper with some minor modes that have their own keymaps (vip-harness-minor-mode "compile") (vip-harness-minor-mode "outline") (vip-harness-minor-mode "allout") (vip-harness-minor-mode "xref") (vip-harness-minor-mode "lmenu") (vip-harness-minor-mode "vc") (vip-harness-minor-mode "ltx-math") ; LaTeX-math-mode in AUC-TeX (vip-harness-minor-mode "latex") ; which is in one of these two files (vip-harness-minor-mode "cyrillic") (vip-harness-minor-mode "russian") (vip-harness-minor-mode "view-less") (vip-harness-minor-mode "view") ;; Intercept maps could go in viper-keym.el ;; We keep them here in case someone redefines them in ~/.vip (define-key vip-vi-intercept-map vip-ESC-key 'vip-intercept-ESC-key) (define-key vip-insert-intercept-map vip-ESC-key 'vip-intercept-ESC-key) ;; This is taken care of by vip-insert-global-user-map. ;;(define-key vip-replace-map vip-ESC-key 'vip-intercept-ESC-key) ;; The default vip-toggle-key is \C-z; for the novice, it suspends or ;; iconifies Emacs (define-key vip-vi-intercept-map vip-toggle-key 'vip-toggle-key-action) (define-key vip-emacs-intercept-map vip-toggle-key 'vip-change-state-to-vi) (if (or vip-always (and (< vip-expert-level 5) (> vip-expert-level 0))) (vip-set-hooks)) ;; Let all minor modes take effect after loading ;; this may not be enough, so we also set default minor-mode-alist. ;; Without setting the default, new buffers that come up in emacs mode have ;; minor-mode-map-alist = nil, unless we call vip-change-state-* (if (eq vip-current-state 'emacs-state) (progn (vip-change-state-to-emacs) (setq-default minor-mode-map-alist minor-mode-map-alist) )) (run-hooks 'vip-load-hook) ; the last chance to change something (provide 'vip) (provide 'viper) ;;; viper.el ends here