summaryrefslogtreecommitdiff
path: root/lisp/international/quail.el
diff options
context:
space:
mode:
authorRichard M. Stallman <rms@gnu.org>1997-08-29 07:21:44 +0000
committerRichard M. Stallman <rms@gnu.org>1997-08-29 07:21:44 +0000
commit5b3b919f59b04ec05db7ea00c02e7f79d99e92cd (patch)
treedb56edb33d9404508804a9442ef958f754b06383 /lisp/international/quail.el
parent6942e5f7b7cca2ae452a26f603606dc424017c49 (diff)
downloademacs-5b3b919f59b04ec05db7ea00c02e7f79d99e92cd.tar.gz
(quail-define-package): New arg SIMPLE.
(quail-simple-translation-keymap): New keymap.
Diffstat (limited to 'lisp/international/quail.el')
-rw-r--r--lisp/international/quail.el39
1 files changed, 33 insertions, 6 deletions
diff --git a/lisp/international/quail.el b/lisp/international/quail.el
index efffc7dbf43..a8ad5fb6c74 100644
--- a/lisp/international/quail.el
+++ b/lisp/international/quail.el
@@ -286,7 +286,26 @@ LEIM is available from the same ftp directory as Emacs."))
(define-key map [backspace] 'quail-delete-last-char)
;; At last, define default key binding.
(append map '((t . quail-execute-non-quail-command))))
- "Keymap used processing translation in Quail mode.
+ "Keymap used processing translation in complex Quail modes.
+Only a few especially complex input methods use this map;
+most use `quail-simple-translation-keymap' instead.
+This map is activated while translation region is active.")
+
+(defvar quail-simple-translation-keymap
+ (let ((map (make-keymap))
+ (i 0))
+ (while (< i ?\ )
+ (define-key map (char-to-string i) 'quail-execute-non-quail-command)
+ (setq i (1+ i)))
+ (while (< i 127)
+ (define-key map (char-to-string i) 'quail-self-insert-command)
+ (setq i (1+ i)))
+ (define-key map "\177" 'quail-delete-last-char)
+ (define-key map "\e" '(keymap (t . quail-execute-non-quail-command)))
+ ;; At last, define default key binding.
+ (append map '((t . quail-execute-non-quail-command))))
+ "Keymap used while processing translation in simple Quail modes.
+A few especially complex input methods use `quail--translation-keymap' instead.
This map is activated while translation region is active.")
(defvar quail-conversion-keymap
@@ -322,13 +341,13 @@ region is not active.")
kbd-translate show-layout create-decode-map
maximum-shortest overlay-plist
update-translation-function
- conversion-keys)
+ conversion-keys simple)
"Define NAME as a new Quail package for input LANGUAGE.
TITLE is a string to be displayed at mode-line to indicate this package.
Optional arguments are GUIDANCE, DOCSTRING, TRANLSATION-KEYS,
FORGET-LAST-SELECTION, DETERMINISTIC, KBD-TRANSLATE, SHOW-LAYOUT,
CREATE-DECODE-MAP, MAXIMUM-SHORTEST, OVERLAY-PLIST,
- UPDATE-TRANSLATION-FUNCTION, and CONVERSION-KEYS.
+ UPDATE-TRANSLATION-FUNCTION, CONVERSION-KEYS and SIMPLE.
GUIDANCE specifies how a guidance string is shown in echo area.
If it is t, list of all possible translations for the current key is shown
@@ -390,17 +409,25 @@ for it) is inserted.
CONVERSION-KEYS specifies additional key bindings used while
conversion region is active. It is an alist of single key character
-vs. corresponding command to be called."
+vs. corresponding command to be called.
+
+If SIMPLE is non-nil, then we do not alter the meanings of
+commands such as C-f, C-b, C-n, C-p and TAB; they are treated as
+non-Quail commands."
(let (translation-keymap conversion-keymap)
(if deterministic (setq forget-last-selection t))
(if translation-keys
(progn
- (setq translation-keymap (copy-keymap quail-translation-keymap))
+ (setq translation-keymap (copy-keymap
+ (if simple quail-simple-translation-keymap
+ quail-translation-keymap)))
(while translation-keys
(define-key translation-keymap
(car (car translation-keys)) (cdr (car translation-keys)))
(setq translation-keys (cdr translation-keys))))
- (setq translation-keymap quail-translation-keymap))
+ (setq translation-keymap
+ (if simple quail-simple-translation-keymap
+ quail-translation-keymap)))
(when conversion-keys
(setq conversion-keymap (copy-keymap quail-conversion-keymap))
(while conversion-keys