Mercurial > hg > xemacs-beta
view lisp/keymap.el @ 826:6728e641994e
[xemacs-hg @ 2002-05-05 11:30:15 by ben]
syntax cache, 8-bit-format, lots of code cleanup
README.packages: Update info about --package-path.
i.c: Create an inheritable event and pass it on to XEmacs, so that ^C
can be handled properly. Intercept ^C and signal the event.
"Stop Build" in VC++ now works.
bytecomp-runtime.el: Doc string changes.
compat.el: Some attempts to redo this to
make it truly useful and fix the "multiple versions interacting
with each other" problem. Not yet done. Currently doesn't work.
files.el: Use with-obsolete-variable to avoid warnings in new revert-buffer code.
xemacs.mak: Split up CFLAGS into a version without flags specifying the C
library. The problem seems to be that minitar depends on zlib,
which depends specifically on libc.lib, not on any of the other C
libraries. Unless you compile with libc.lib, you get errors --
specifically, no _errno in the other libraries, which must make it
something other than an int. (#### But this doesn't seem to obtain
in XEmacs, which also uses zlib, and can be linked with any of the
C libraries. Maybe zlib is used differently and doesn't need
errno, or maybe XEmacs provides an int errno; ... I don't
understand.
Makefile.in.in: Fix so that packages are around when testing.
abbrev.c, alloc.c, buffer.c, buffer.h, bytecode.c, callint.c, casefiddle.c, casetab.c, casetab.h, charset.h, chartab.c, chartab.h, cmds.c, console-msw.h, console-stream.c, console-x.c, console.c, console.h, data.c, device-msw.c, device.c, device.h, dialog-msw.c, dialog-x.c, dired-msw.c, dired.c, doc.c, doprnt.c, dumper.c, editfns.c, elhash.c, emacs.c, eval.c, event-Xt.c, event-gtk.c, event-msw.c, event-stream.c, events.c, events.h, extents.c, extents.h, faces.c, file-coding.c, file-coding.h, fileio.c, fns.c, font-lock.c, frame-gtk.c, frame-msw.c, frame-x.c, frame.c, frame.h, glade.c, glyphs-gtk.c, glyphs-msw.c, glyphs-msw.h, glyphs-x.c, glyphs.c, glyphs.h, gui-msw.c, gui-x.c, gui.h, gutter.h, hash.h, indent.c, insdel.c, intl-win32.c, intl.c, keymap.c, lisp-disunion.h, lisp-union.h, lisp.h, lread.c, lrecord.h, lstream.c, lstream.h, marker.c, menubar-gtk.c, menubar-msw.c, menubar-x.c, menubar.c, minibuf.c, mule-ccl.c, mule-charset.c, mule-coding.c, mule-wnnfns.c, nas.c, objects-msw.c, objects-x.c, opaque.c, postgresql.c, print.c, process-nt.c, process-unix.c, process.c, process.h, profile.c, rangetab.c, redisplay-gtk.c, redisplay-msw.c, redisplay-output.c, redisplay-x.c, redisplay.c, redisplay.h, regex.c, regex.h, scrollbar-msw.c, search.c, select-x.c, specifier.c, specifier.h, symbols.c, symsinit.h, syntax.c, syntax.h, syswindows.h, tests.c, text.c, text.h, tooltalk.c, ui-byhand.c, ui-gtk.c, unicode.c, win32.c, window.c: Another big Ben patch.
-- FUNCTIONALITY CHANGES:
add partial support for 8-bit-fixed, 16-bit-fixed, and
32-bit-fixed formats. not quite done yet. (in particular, needs
functions to actually convert the buffer.) NOTE: lots of changes
to regex.c here. also, many new *_fmt() inline funs that take an
Internal_Format argument.
redo syntax cache code. make the cache per-buffer; keep the cache
valid across calls to functions that use it. also keep it valid
across insertions/deletions and extent changes, as much as is
possible. eliminate the junky regex-reentrancy code by passing in
the relevant lisp info to the regex routines as local vars.
add general mechanism in extents code for signalling extent changes.
fix numerous problems with the case-table implementation; yoshiki
never properly transferred many algorithms from old-style to
new-style case tables.
redo char tables to support a default argument, so that mapping
only occurs over changed args. change many chartab functions to
accept Lisp_Object instead of Lisp_Char_Table *.
comment out the code in font-lock.c by default, because
font-lock.el no longer uses it. we should consider eliminating it
entirely.
Don't output bell as ^G in console-stream when not a TTY.
add -mswindows-termination-handle to interface with i.c, so we can
properly kill a build.
add more error-checking to buffer/string macros.
add some additional buffer_or_string_() funs.
-- INTERFACE CHANGES AFFECTING MORE CODE:
switch the arguments of write_c_string and friends to be
consistent with write_fmt_string, which must have printcharfun
first.
change BI_* macros to BYTE_* for increased clarity; similarly for
bi_* local vars.
change VOID_TO_LISP to be a one-argument function. eliminate
no-longer-needed CVOID_TO_LISP.
-- char/string macro changes:
rename MAKE_CHAR() to make_emchar() for slightly less confusion
with make_char(). (The former generates an Emchar, the latter a
Lisp object. Conceivably we should rename make_char() -> wrap_char()
and similarly for make_int(), make_float().)
Similar changes for other *CHAR* macros -- we now consistently use
names with `emchar' whenever we are working with Emchars. Any
remaining name with just `char' always refers to a Lisp object.
rename macros with XSTRING_* to string_* except for those that
reference actual fields in the Lisp_String object, following
conventions used elsewhere.
rename set_string_{data,length} macros (the only ones to work with
a Lisp_String_* instead of a Lisp_Object) to set_lispstringp_*
to make the difference clear.
try to be consistent about caps vs. lowercase in macro/inline-fun
names for chars and such, which wasn't the case before. we now
reserve caps either for XFOO_ macros that reference object fields
(e.g. XSTRING_DATA) or for things that have non-function semantics,
e.g. directly modifying an arg (BREAKUP_EMCHAR) or evaluating an
arg (any arg) more than once. otherwise, use lowercase.
here is a summary of most of the macros/inline funs changed by all
of the above changes:
BYTE_*_P -> byte_*_p
XSTRING_BYTE -> string_byte
set_string_data/length -> set_lispstringp_data/length
XSTRING_CHAR_LENGTH -> string_char_length
XSTRING_CHAR -> string_emchar
INTBYTE_FIRST_BYTE_P -> intbyte_first_byte_p
INTBYTE_LEADING_BYTE_P -> intbyte_leading_byte_p
charptr_copy_char -> charptr_copy_emchar
LEADING_BYTE_* -> leading_byte_*
CHAR_* -> EMCHAR_*
*_CHAR_* -> *_EMCHAR_*
*_CHAR -> *_EMCHAR
CHARSET_BY_ -> charset_by_*
BYTE_SHIFT_JIS* -> byte_shift_jis*
BYTE_BIG5* -> byte_big5*
REP_BYTES_BY_FIRST_BYTE -> rep_bytes_by_first_byte
char_to_unicode -> emchar_to_unicode
valid_char_p -> valid_emchar_p
Change intbyte_strcmp -> qxestrcmp_c (duplicated functionality).
-- INTERFACE CHANGES AFFECTING LESS CODE:
use DECLARE_INLINE_HEADER in various places.
remove '#ifdef emacs' from XEmacs-only files.
eliminate CHAR_TABLE_VALUE(), which duplicated the functionality
of get_char_table().
add BUFFER_TEXT_LOOP to simplify iterations over buffer text.
define typedefs for signed and unsigned types of fixed sizes
(INT_32_BIT, UINT_32_BIT, etc.).
create ALIGN_FOR_TYPE as a higher-level interface onto ALIGN_SIZE;
fix code to use it.
add charptr_emchar_len to return the text length of the character
pointed to by a ptr; use it in place of
charcount_to_bytecount(..., 1). add emchar_len to return the text
length of a given character.
add types Bytexpos and Charxpos to generalize Bytebpos/Bytecount
and Charbpos/Charcount, in code (particularly, the extents code
and redisplay code) that works with either kind of index. rename
redisplay struct params with names such as `charbpos' to
e.g. `charpos' when they are e.g. a Charxpos, not a Charbpos.
eliminate xxDEFUN in place of DEFUN; no longer necessary with
changes awhile back to doc.c.
split up big ugly combined list of EXFUNs in lisp.h on a
file-by-file basis, since other prototypes are similarly split.
rewrite some "*_UNSAFE" macros as inline funs and eliminate the
_UNSAFE suffix.
move most string code from lisp.h to text.h; the string code and
text.h code is now intertwined in such a fashion that they need
to be in the same place and partially interleaved. (you can't
create forward references for inline funs)
automated/lisp-tests.el, automated/symbol-tests.el, automated/test-harness.el: Fix test harness to output FAIL messages to stderr when in
batch mode.
Fix up some problems in lisp-tests/symbol-tests that were
causing spurious failures.
author | ben |
---|---|
date | Sun, 05 May 2002 11:33:57 +0000 |
parents | 79940b592197 |
children | 1b0339b048ce |
line wrap: on
line source
;; 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)) ;; #### need to move xemacs-base into the core!!!!!! (declare-fboundp (read-kbd-macro keys)) `(declare-fboundp (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 OLDMAP is specified, we redefine in KEYMAP as NEWDEF those chars which are defined as OLDDEF in OLDMAP, unless that keybinding is already present in KEYMAP. If optional fifth argument PREFIX is non-nil, then only those occurrences of OLDDEF found in keymaps accessible through the keymap bound to PREFIX in KEYMAP 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) ))) ;; 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))))) (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 &optional accept-defaults) "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 lists as described in the documentation for the `define-key' function. The binding is probably a symbol with a function definition; see the documentation for `lookup-key' for more information." (let ((map (current-local-map))) (if map (lookup-key map keys accept-defaults) nil))) (defun global-key-binding (keys &optional accept-defaults) "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; see the documentation for `lookup-key' for more information." (lookup-key (current-global-map) keys accept-defaults)) (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 lists as described in the documentation for the `define-key' function. Note that if KEY has a local binding in the current buffer that 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) (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 lists as 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 lists as 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 lists as 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 is the symbol which names the minor mode binding KEY, and BINDING is KEY's definition in that mode. In particular, if KEY has no minor-mode bindings, return nil. If the first binding is a non-prefix, all subsequent bindings will be omitted, since they would be ignored. Similarly, the list doesn't include non-prefix bindings that come after prefix bindings. If optional argument ACCEPT-DEFAULT is non-nil, recognize default bindings; 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)) (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 l (cons v l)))) (nreverse l))) ;;#### What a crock (defun define-prefix-command (name &optional mapvar) "Define COMMAND as a prefix command. A new sparse keymap is stored as COMMAND's function definition. If second optional argument MAPVAR is not specified, COMMAND's value (as well as its function definition) is set to the keymap. If a second optional argument MAPVAR is given and is not `t', the map is stored as its value. Regardless of MAPVAR, COMMAND's function-value is always set to the keymap." (let ((map (make-sparse-keymap name))) (fset name map) (cond ((not mapvar) (set name map)) ((eq mapvar 't) ) (t (set mapvar map))) name)) ;;; Converting vectors of events to a read-equivalent form. ;;; This is used both by call-interactively (for the command history) ;;; and by macros.el (for saving keyboard macros to a file). ;; #### why does (events-to-keys [backspace]) return "\C-h"? ;; BTW, this function is a mess, and macros.el does *not* use it, in ;; spite of the above comment. `format-kbd-macro' is used to save ;; keyboard macros to a file. (defun events-to-keys (events &optional no-mice) "Given a vector of event objects, returns a vector of key descriptors, or a string (if they all fit in the ASCII range). Optional arg NO-MICE means that button events are not allowed." (if (and events (symbolp events)) (setq events (vector events))) (cond ((stringp events) events) ((not (vectorp events)) (signal 'wrong-type-argument (list 'vectorp events))) ((let* ((length (length events)) (string (make-string length 0)) c ce (i 0)) (while (< i length) (setq ce (aref events i)) (or (eventp ce) (setq ce (character-to-event ce))) ;; Normalize `c' to `?c' and `(control k)' to `?\C-k' ;; By passing t for the `allow-meta' arg we could get kbd macros ;; with meta in them to translate to the string form instead of ;; the list/symbol form; but I expect that would cause confusion, ;; so let's use the list/symbol form whenever there's ;; any ambiguity. (setq c (event-to-character ce)) (if (and c character-set-property (key-press-event-p ce)) (cond ((symbolp (event-key ce)) (if (get (event-key ce) character-set-property) ;; Don't use a string for `backspace' and `tab' to ;; avoid that unpleasant little ambiguity. (setq c nil))) ((and (= (event-modifier-bits ce) 1) ;control (integerp (event-key ce))) (let* ((te (character-to-event c))) (if (and (symbolp (event-key te)) (get (event-key te) character-set-property)) ;; Don't "normalize" (control i) to tab ;; to avoid the ambiguity in the other direction (setq c nil)) (deallocate-event te))))) (if c (aset string i c) (setq i length string nil)) (setq i (1+ i))) string)) (t (let* ((length (length events)) (new (copy-sequence events)) event mods key (i 0)) (while (< i length) (setq event (aref events i)) (cond ((key-press-event-p event) (setq mods (event-modifiers event) key (event-key event)) (if (numberp key) (setq key (intern (make-string 1 key)))) (aset new i (if mods (nconc mods (cons key nil)) key))) ((misc-user-event-p event) (aset new i (list 'menu-selection (event-function event) (event-object event)))) ((or (button-press-event-p event) (button-release-event-p event)) (if no-mice (error "Mouse events can't be saved in keyboard macros.")) (setq mods (event-modifiers event) key (intern (format "button%d%s" (event-button event) (if (button-release-event-p event) "up" "")))) (aset new i (if mods (nconc mods (cons key nil)) key))) ((or (and event (symbolp event)) (and (consp event) (symbolp (car event)))) (aset new i event)) (t (signal 'wrong-type-argument (list 'eventp event)))) (setq i (1+ i))) new)))) (defun next-key-event () "Return the next available keyboard event." (let (event) (while (not (key-press-event-p (setq event (next-command-event)))) (dispatch-event event)) event)) (defun key-sequence-list-description (keys) "Convert a key sequence KEYS to the full [(modifiers... key)...] form. Argument KEYS can be in any form accepted by `define-key' function. The output is always in a canonical form, meaning you can use this function to determine if two key sequence specifications are equivalent by comparing the respective outputs of this function using `equal'." (let ((vec (cond ((vectorp keys) keys) ((stringp keys) (vconcat keys)) (t (vector keys))))) (flet ((event-to-list (ev) (append (event-modifiers ev) (list (event-key ev))))) (mapvector #'(lambda (key) (let* ((full-key (cond ((key-press-event-p key) (event-to-list key)) ((characterp key) (event-to-list (character-to-event key))) ((listp key) (copy-sequence key)) (t (list key)))) (keysym (car (last full-key)))) (if (characterp keysym) (setcar (last full-key) (intern (char-to-string keysym)))) full-key)) vec)))) ;;; Support keyboard commands to turn on various modifiers. ;;; These functions -- which are not commands -- each add one modifier ;;; to the following event. (defun event-apply-alt-modifier (ignore-prompt) (event-apply-modifier 'alt)) (defun event-apply-super-modifier (ignore-prompt) (event-apply-modifier 'super)) (defun event-apply-hyper-modifier (ignore-prompt) (event-apply-modifier 'hyper)) (defun event-apply-shift-modifier (ignore-prompt) (event-apply-modifier 'shift)) (defun event-apply-control-modifier (ignore-prompt) (event-apply-modifier 'control)) (defun event-apply-meta-modifier (ignore-prompt) (event-apply-modifier 'meta)) ;;; #### `key-translate-map' is ignored for now. (defun event-apply-modifier (symbol) "Return the next key event, with a modifier flag applied. SYMBOL is the name of this modifier, as a symbol. `function-key-map' is scanned for prefix bindings." (let (events binding) ;; read keystrokes scanning `function-key-map' (while (keymapp (setq binding (lookup-key function-key-map (vconcat (setq events (append events (list (next-key-event))))))))) (if binding ; found a binding (progn ;; allow for several modifiers (if (and (symbolp binding) (fboundp binding)) (setq binding (funcall binding nil))) (setq events (append binding nil)) ;; put remaining keystrokes back into input queue (setq unread-command-events (mapcar 'character-to-event (cdr events)))) (setq unread-command-events (cdr events))) ;; add a modifier SYMBOL to the first keystroke or event (vector (append (list symbol) (delq symbol (aref (key-sequence-list-description (car events)) 0)))))) (defun synthesize-keysym (ignore-prompt) "Read a sequence of keys, and returned the corresponding key symbol. The characters must be from the [-_a-zA-Z0-9]. Reading is terminated by RET (which is discarded)." (let ((continuep t) event char list) (while continuep (setq event (next-key-event)) (cond ((and (setq char (event-to-character event)) (or (memq char '(?- ?_)) (eq ?w (char-syntax char (standard-syntax-table))))) ;; Advance a character. (push char list)) ((or (memq char '(?\r ?\n)) (memq (event-key event) '(return newline))) ;; Legal termination. (setq continuep nil)) (char ;; Illegal character. (error "Illegal character in keysym: %c" char)) (t ;; Illegal event. (error "Event has no character equivalent: %s" event)))) (vector (intern (concat "" (nreverse list)))))) ;; This looks dirty. The following code should maybe go to another ;; file, and `create-console-hook' should maybe default to nil. (add-hook 'create-console-hook #'(lambda (console) (letf (((selected-console) console)) (define-key function-key-map [?\C-x ?@ ?h] 'event-apply-hyper-modifier) (define-key function-key-map [?\C-x ?@ ?s] 'event-apply-super-modifier) (define-key function-key-map [?\C-x ?@ ?m] 'event-apply-meta-modifier) (define-key function-key-map [?\C-x ?@ ?S] 'event-apply-shift-modifier) (define-key function-key-map [?\C-x ?@ ?c] 'event-apply-control-modifier) (define-key function-key-map [?\C-x ?@ ?a] 'event-apply-alt-modifier) (define-key function-key-map [?\C-x ?@ ?k] 'synthesize-keysym)))) ;;; keymap.el ends here