Mercurial > hg > xemacs-beta
view lisp/keydefs.el @ 4953:304aebb79cd3
function renamings to track names of char typedefs
-------------------- ChangeLog entries follow: --------------------
man/ChangeLog addition:
2010-01-27 Ben Wing <ben@xemacs.org>
* internals/internals.texi (lrecords):
* internals/internals.texi (The DFC API):
* internals/internals.texi (Conversion to and from External Data):
* internals/internals.texi (Mule-izing Code):
* internals/internals.texi (Pervasive changes throughout XEmacs sources):
* internals/internals.texi (Ben's README):
* internals/internals.texi (Future Work -- Localized Text/Messages):
* emodules.texi (Defining Variables):
Rename:
write_c_string -> write_cistring
build_intstring -> build_istring
build_string -> build_cistring
build_ext_string -> build_extstring
make_ext_string -> make_extstring
buffer_insert_c_string -> buffer_insert_ascstring
intern_int -> intern_istring
See comment in src/ChangeLog about this.
modules/ChangeLog addition:
2010-01-27 Ben Wing <ben@xemacs.org>
* postgresql/postgresql.c (print_pgconn):
* postgresql/postgresql.c (print_pgresult):
* postgresql/postgresql.c (Fpq_conn_defaults):
* postgresql/postgresql.c (Fpq_pgconn):
* postgresql/postgresql.c (Fpq_res_status):
* postgresql/postgresql.c (Fpq_result_error_message):
* postgresql/postgresql.c (Fpq_fname):
* postgresql/postgresql.c (Fpq_get_value):
* postgresql/postgresql.c (Fpq_cmd_status):
* postgresql/postgresql.c (Fpq_cmd_tuples):
* postgresql/postgresql.c (Fpq_notifies):
* postgresql/postgresql.c (Fpq_get_line):
* postgresql/postgresql.c (Fpq_get_line_async):
* postgresql/postgresql.c (FROB):
* postgresql/postgresql.c (init_postgresql_from_environment):
* ldap/eldap.c:
* ldap/eldap.c (Fldap_open):
* ldap/eldap.c (Fldap_search_basic):
* canna/canna_api.c:
* canna/canna_api.c (make_euc_string):
Rename:
write_c_string -> write_cistring
build_intstring -> build_istring
build_string -> build_cistring
build_ext_string -> build_extstring
make_ext_string -> make_extstring
buffer_insert_c_string -> buffer_insert_ascstring
intern_int -> intern_istring
See comment in src/ChangeLog about this.
src/ChangeLog addition:
2010-01-27 Ben Wing <ben@xemacs.org>
* .gdbinit.in.in:
* README:
* abbrev.c (write_abbrev):
* abbrev.c (describe_abbrev):
* alloc.c (make_extstring):
* alloc.c (build_istring):
* alloc.c (build_cistring):
* alloc.c (build_ascstring):
* alloc.c (build_extstring):
* alloc.c (build_msg_istring):
* alloc.c (build_defer_istring):
* buffer.c (Fgenerate_new_buffer_name):
* buffer.c (init_buffer_2):
* console-tty.c (tty_init_console):
* console-x.c (get_display_arg_connection):
* console-x.c (x_perhaps_init_unseen_key_defaults):
* database.c (dbm_map):
* database.c (dbm_get):
* database.c (berkdb_get):
* database.c (berkdb_map):
* device-gtk.c (FROB_PIXMAP):
* device-gtk.c (Fgtk_style_info):
* device-msw.c (msprinter_default_printer):
* device-msw.c (sync_printer_with_devmode):
* device-x.c (coding_system_of_xrm_database):
* device-x.c (x_init_device):
* device-x.c (signal_if_x_error):
* device-x.c (Fx_get_resource):
* device-x.c (Fx_server_vendor):
* device-x.c (Fx_get_font_path):
* dialog-x.c (maybe_run_dbox_text_callback):
* doc.c (extract_object_file_name):
* doc.c (unparesseuxify_doc_string):
* doc.c (get_doc_string):
* doc.c (get_object_file_name):
* doc.c (Fdocumentation):
* doc.c (Fsnarf_documentation):
* doc.c (Fsubstitute_command_keys):
* editfns.c (init_editfns):
* editfns.c (Ftemp_directory):
* editfns.c (Fuser_login_name):
* editfns.c (Fuser_real_login_name):
* editfns.c (Fuser_home_directory):
* editfns.c (Fformat_time_string):
* editfns.c (Fcurrent_time_string):
* editfns.c (Fcurrent_time_zone):
* emacs.c:
* emacs.c (main_1):
* emodules.c (Flist_modules):
* emodules.c (emodules_load):
* emodules.c (emodules_doc_sym):
* emodules.c (vars_of_module):
* event-Xt.c (x_has_keysym):
* event-gtk.c (emacs_gtk_format_magic_event):
* event-gtk.c (dragndrop_data_received):
* event-gtk.c (gtk_reset_key_mapping):
* event-msw.c (mswindows_dde_callback):
* event-msw.c (mswindows_wnd_proc):
* faces.c (complex_vars_of_faces):
* file-coding.c (find_coding_system):
* file-coding.c (setup_eol_coding_systems):
* file-coding.c (make_coding_system_1):
* file-coding.c (snarf_coding_system):
* fileio.c:
* fileio.c (lisp_strerror):
* fileio.c (Ffile_name_directory):
* fileio.c (Ffile_name_as_directory):
* fileio.c (Fdirectory_file_name):
* fileio.c (if):
* fileio.c (Ffile_symlink_p):
* fileio.c (Fencrypt_string):
* fileio.c (Fdecrypt_string):
* filelock.c (lock_file):
* filelock.c (Ffile_locked_p):
* floatfns.c (matherr):
* font-mgr.c (build_fcapi_string):
* font-mgr.c (make_xlfd_font_regexp):
* frame-msw.c (mswindows_window_id):
* frame-msw.c (mswindows_frame_property):
* frame-x.c:
* frame-x.c (color_to_string):
* frame-x.c (maybe_set_frame_title_format):
* frame-x.c (x_cde_transfer_callback):
* frame-x.c (Fx_window_id):
* glade.c (connector):
* glade.c (Fglade_xml_textdomain):
* glade.c (syms_of_glade):
* glyphs-eimage.c (jpeg_instantiate):
* glyphs-eimage.c (png_instantiate):
* glyphs-eimage.c (tiff_instantiate):
* glyphs-gtk.c (font_instantiate):
* glyphs-gtk.c (BUILD_GLYPH_INST):
* glyphs-x.c (x_locate_pixmap_file):
* glyphs-x.c (font_instantiate):
* glyphs-x.c (x_widget_property):
* glyphs-x.c (BUILD_GLYPH_INST):
* glyphs.c (print_image_instance):
* glyphs.c (bitmap_to_lisp_data):
* glyphs.c (pixmap_to_lisp_data):
* gpmevent.c (turn_off_gpm):
* gpmevent.c (Fgpm_enabled_p):
* gpmevent.c (Fgpm_enable):
* gtk-glue.c (__make_string_mapper):
* gtk-glue.c (xemacs_gtklist_to_list):
* gtk-xemacs.c (FROB_FACE):
* gtk-xemacs.c (xemacs_gtk_convert_color):
* hpplay.c (player_error_internal):
* hpplay.c (myHandler):
* insdel.c (buffer_insert_ascstring_1):
* insdel.h:
* insdel.h (buffer_insert_ascstring):
* intl.c (Fcurrent_locale):
* intl.c (Fset_current_locale):
* keymap.c (make_key_description):
* keymap.c (Ftext_char_description):
* keymap.c (describe_command):
* keymap.c (describe_map):
* lisp.h:
* lread.c:
* lread.c (locate_file_in_directory_mapper):
* lread.c (locate_file_construct_suffixed_files_mapper):
* mule-charset.c (Fmake_charset):
* nt.c (Fmswindows_short_file_name):
* nt.c (Fmswindows_long_file_name):
* objects-gtk.c (__get_gtk_font_truename):
* objects-gtk.c (__gtk_font_list_internal):
* objects-msw.c (font_enum_callback_2):
* objects-msw.c (create_hfont_from_font_spec):
* objects-msw.c (mswindows_font_list):
* objects-msw.c (mswindows_font_spec_matches_charset_stage_2):
* objects-tty.c (tty_initialize_font_instance):
* objects-x.c (x_font_truename):
* objects-x.c (x_font_instance_truename):
* objects-x.c (x_font_instance_properties):
* objects-x.c (x_font_list):
* print.c (write_cistring):
* print.c (print_vector_internal):
* print.c (print_cons):
* process-nt.c (nt_canonicalize_host_name):
* process-unix.c (unix_create_process):
* process-unix.c (unix_canonicalize_host_name):
* process.c (status_message):
* process.c (status_notify):
* process.c (init_xemacs_process):
* process.c (syms_of_process):
* redisplay-tty.c (term_get_fkeys_1):
* redisplay-tty.c (CONDITIONAL_REASSIGN):
* search.c (compile_pattern_1):
* select-common.h (selection_data_to_lisp_data):
* select-gtk.c (atom_to_symbol):
* select-gtk.c (PROCESSING_GTK_CODE):
* select-msw.c (mswindows_get_foreign_selection):
* select-x.c (x_atom_to_symbol):
* select-x.c (Fx_get_cutbuffer_internal):
* symbols.c (intern_istring):
* symbols.c (intern):
* symbols.c (intern_converting_underscores_to_dashes):
* symbols.c (Fintern):
* sysdep.c (init_system_name):
* sysdll.c (dll_error):
* sysdll.c (dll_open):
* syswindows.h:
* syswindows.h (build_tstr_string):
* tests.c (DFC_CHECK_LENGTH):
* tests.c (DFC_CHECK_CONTENT):
* tests.c (DFC_RESULT_PASS):
* tests.c (Ftest_data_format_conversion):
* text.c:
* text.c (new_dfc_convert_now_damn_it):
* text.h:
* text.h (build_wext_string):
* tooltalk.c (tt_build_c_string):
* tooltalk.c (Ftooltalk_default_procid):
* tooltalk.c (Ftooltalk_default_session):
* tooltalk.c (init_tooltalk):
* ui-byhand.c (Fgtk_clist_get_text):
* ui-byhand.c (Fgtk_clist_get_pixtext):
* ui-byhand.c (Fgtk_label_get):
* ui-byhand.c (Fgtk_notebook_query_tab_label_packing):
* ui-gtk.c (emacs_gtk_object_printer):
* ui-gtk.c (emacs_gtk_boxed_printer):
* ui-gtk.c (gtk_type_to_lisp):
* ui-gtk.c (symbol_to_enum):
* ui-gtk.c (enum_to_symbol):
* unexaix.c (report_error):
* unexaix.c (ERROR0):
* unexec.c (report_error):
* unexec.c (ERROR0):
* unicode.c (unicode_to_ichar):
* win32.c (tstr_to_local_file_format):
* win32.c (Fmswindows_cygwin_to_win32_path):
* win32.c (struct read_link_hash):
* xemacs.def.in.in:
Rename:
write_c_string -> write_cistring
build_intstring -> build_istring
build_string -> build_cistring
build_ext_string -> build_extstring
make_ext_string -> make_extstring
buffer_insert_c_string -> buffer_insert_ascstring
intern_int -> intern_istring
These functions have been renamed so that the naming harmonizes
with the typedefs for strings: `cistring' along with CIbyte *,
`istring' along with Ibyte *, `extstring' along with Extbyte *,
`ascstring' along with Ascbyte *.
Also make buffer_insert_ascstring take Ascbyte * and assert
that its argument is ASCII.
author | Ben Wing <ben@xemacs.org> |
---|---|
date | Wed, 27 Jan 2010 00:35:36 -0600 |
parents | 9e28067e3083 |
children | 308d34e9f07d |
line wrap: on
line source
;;; keydefs.el --- Define standard keybindings. ;; Copyright (C) 1992-4, 1997 Free Software Foundation, Inc. ;; Copyright (C) 2000, 2001, 2002 Ben Wing. ;; Maintainer: XEmacs Development Team ;; Keywords: internal, 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. ;; All the global bindings should be here so that one can reload things ;; like files.el without trashing one's personal bindings. ;;; Synched up with: Not synched with FSF. ;;; Commentary: ;; This file is dumped with XEmacs ;;; Code: (defgroup keyboard nil "Input from the keyboard." :group 'environment) ;; created by C code (defvar global-map (current-global-map) "\ Default global keymap mapping XEmacs keyboard input into commands. The value is a keymap which is usually (but not necessarily) XEmacs's global map.") ;; created by C code (defvar esc-map (symbol-function 'ESC-prefix) "\ Default keymap for ESC (meta) commands. The normal global definition of the character ESC indirects to this keymap.") (set-keymap-name global-map 'global-map) (set-keymap-name esc-map 'ESC-prefix) (define-prefix-command 'Control-X-prefix t) (defvar ctl-x-map (symbol-function 'Control-X-prefix) "\ Default keymap for C-x commands. The normal global definition of the character C-x indirects to this keymap.") (define-key global-map "\C-x" 'Control-X-prefix) (define-prefix-command 'ctl-x-4-prefix t) (defvar ctl-x-4-map (symbol-function 'ctl-x-4-prefix) "\ Keymap for subcommands of C-x 4") (define-key global-map "\C-x4" 'ctl-x-4-prefix) (define-prefix-command 'ctl-x-5-prefix t) (defvar ctl-x-5-map (symbol-function 'ctl-x-5-prefix) "\ Keymap for subcommands of C-x 5") (define-key global-map "\C-x5" 'ctl-x-5-prefix) (define-prefix-command 'mode-specific-command-prefix t) (defvar mode-specific-map (symbol-function 'mode-specific-command-prefix) "\ Keymap for characters following C-c.") (define-key global-map "\C-c" 'mode-specific-command-prefix) ;; FSFmacs buffer.c (define-key global-map "\C-xb" 'switch-to-buffer) (define-key global-map "\C-xk" 'kill-buffer) (define-key global-map "\C-x\C-b" 'list-buffers) (put 'erase-buffer 'disabled t) ;from buffer.c ;; FSFmacs casefiddle.c (define-key global-map "\C-x\C-u" 'upcase-region) ;; This is silly with zmacs regions ;(put 'upcase-region 'disabled t) (define-key global-map "\C-x\C-l" 'downcase-region) ;; This is silly with zmacs regions ;(put 'downcase-region 'disabled t) (define-key global-map "\M-u" 'upcase-region-or-word) (define-key global-map "\M-l" 'downcase-region-or-word) (define-key global-map "\M-c" 'capitalize-region-or-word) ;; FSFmacs cmds.c (let ((n 33)) (while (<= n 255) (if (not (= n 127)) (define-key global-map n 'self-insert-command)) (setq n (1+ n)))) (define-key global-map " " 'self-insert-command) (define-key global-map "\C-a" 'beginning-of-line) (define-key global-map "\C-b" 'backward-char-command) (define-key global-map "\C-e" 'end-of-line) (define-key global-map "\C-f" 'forward-char-command) (define-key global-map "\C-d" 'delete-char) ;; FSFmacs files.el (define-key global-map "\C-x\C-f" 'find-file) (define-key global-map "\C-x\C-q" 'toggle-read-only) (define-key global-map "\C-x\C-r" 'find-file-read-only) (define-key global-map "\C-x\C-v" 'find-alternate-file) (define-key global-map "\C-x\C-s" 'save-buffer) (define-key global-map "\C-xs" 'save-some-buffers) (define-key global-map "\C-x\C-w" 'write-file) (define-key global-map "\C-xi" 'insert-file) (define-key global-map "\M-~" 'not-modified) (define-key global-map "\C-x\C-d" 'list-directory) (define-key global-map "\C-x\C-c" 'save-buffers-kill-emacs) (define-key global-map "\C-x4c" 'clone-indirect-buffer-other-window) (define-key global-map "\C-x4f" 'find-file-other-window) (define-key global-map "\C-x4r" 'find-file-read-only-other-window) (define-key global-map "\C-x4\C-f" 'find-file-other-window) (define-key global-map "\C-x4b" 'switch-to-buffer-other-window) (define-key global-map "\C-x4\C-o" 'display-buffer) (define-key global-map "\C-x5b" 'switch-to-buffer-other-frame) (define-key global-map "\C-x5f" 'find-file-other-frame) (define-key global-map "\C-x5\C-f" 'find-file-other-frame) (define-key global-map "\C-x5r" 'find-file-read-only-other-frame) ;; FSFmacs frame.c ;FSFmacs has these. It's probably a good idea to provide ways of hooking ;these events, but it's unlikely that it's a good idea to do it this way. ;Just provide a hook, like the existing `select-frame-hook', ;`deselect-frame-hook', `map-frame-hook', and `unmap-frame-hook'. ;#### ergo need hooks for delete-frame and iconify-frame ;(define-key global-map 'switch-frame 'handle-switch-frame) ;(define-key global-map 'delete-frame 'handle-delete-frame) ;(define-key global-map 'iconify-frame 'ignore-event) ;(define-key global-map 'make-frame-visible 'ignore-event) ;; FSFmacs frame.el ;; New FSF19 bindings: C-x 5 as prefix for window commands (define-key global-map "\C-x52" 'make-frame) (define-key global-map "\C-x50" 'delete-frame) (define-key global-map "\C-x5o" 'other-frame) ;; New FSF21 binding: (define-key global-map "\C-x51" 'delete-other-frames) ;; FSFmacs help.el (define-key global-map (vector help-char) 'help-command) (define-key global-map 'help 'help-command) (define-key global-map 'f1 'help-command) ;; This is a failsafe mechanism, esp. on TTY's, in case the terminal is ;; somewhat broken and f1 keys can't work, and backspace is redefined to ;; do backspace. (define-key global-map '(meta ??) 'help-command) ;; FSFmacs indent.el ;;(define-key global-map "\t" 'self-insert-command) (define-key global-map "\t" 'indent-for-tab-command) (define-key global-map "\M-\C-\\" 'indent-region-or-balanced-expression) (define-key global-map "\C-x\t" 'indent-rigidly) (define-key global-map "\M-i" 'tab-to-tab-stop) ;; XEmacs addition: (define-key global-map [(shift tab)] 'self-insert-command) ;; FSFmacs isearch.el (define-key global-map "\C-s" 'isearch-forward) (define-key global-map "\C-r" 'isearch-backward) (define-key global-map "\M-\C-s" 'isearch-forward-regexp) (define-key global-map "\M-\C-r" 'isearch-backward-regexp) ;; FSFmacs keyboard.c (define-key global-tty-map "\C-z" 'suspend-or-iconify-emacs) (define-key global-window-system-map "\C-z" 'zap-up-to-char) (define-key global-window-system-map '(control Z) 'iconify-frame) (define-key global-map "\C-x\C-z" 'suspend-or-iconify-emacs) ;; FSFmacs loaddefs.el ;; New FSF19 bindings: C-x n as a prefix for narrowing commands. (define-key global-map "\C-xn" (let ((map (make-sparse-keymap))) (set-keymap-name map 'narrowing-prefix) map)) (put 'narrow-to-region 'disabled t) (define-key global-map "\C-xnn" 'narrow-to-region) (define-key global-map "\C-xnw" 'widen) (define-key global-map "\C-xnd" 'narrow-to-defun) ;; Old v18 bindings ;(define-key global-map "\C-xn" 'narrow-to-region) ;(define-key global-map "\C-xw" 'widen) (define-key global-map "\C-j" 'newline-and-indent) (define-key global-map "\C-m" 'newline) (define-key global-map "\C-o" 'open-line) (define-key global-map "\M-\C-o" 'split-line) (define-key global-map "\C-q" 'quoted-insert) (define-key global-map "\M-^" 'delete-indentation) (define-key global-map "\M-\\" 'delete-horizontal-space) (define-key global-map "\M-m" 'back-to-indentation) (define-key global-map "\C-x\C-o" 'delete-blank-lines) (define-key global-map "\M- " 'just-one-space) (define-key global-map "\M-z" 'zap-to-char) (define-key global-map "\M-=" 'count-lines-region) (define-key global-map "\C-x=" 'what-cursor-position) (define-key global-map "\M-:" 'eval-expression) ;; Define ESC ESC : like ESC : for people who type ESC ESC out of habit. ;(define-key global-map "\M-\e:" 'eval-expression) ;(define-key global-map "\M-\e" 'eval-expression) ;; Do we really need to disable this now that it is harder to type ;; by accident? ;; (put 'eval-expression 'disabled t) ;; Changed from C-x ESC so that function keys work following C-x. ;; FMH! I tried putting back C-x ESC using global-window-system-map and ;; removing the other bindings, but it doesn't work! I don't understand why ;; M-ESC ESC (i.e. ESC ESC ESC) does work. (define-key global-map "\C-x\e\e" 'repeat-complex-command) ;; From Emacs 20. (define-key global-map "\C-x\M-:" 'repeat-complex-command) (define-key global-map "\C-xu" 'undo) ;; Many people are used to typing C-/ on X terminals and getting C-_. (define-key global-map '(control /) 'undo) (define-key global-map "\C-_" 'undo) (define-key global-map "\M-!" 'shell-command) (define-key global-map "\M-|" 'shell-command-on-region) (define-key global-map "\C-u" 'universal-argument) ;; Make Control-0 - Control-9 set the prefix argument, like Meta-0. (let ((i ?0)) (while (<= i ?9) (define-key global-map (list 'meta i) 'digit-argument) (define-key global-map (list 'control i) 'digit-argument) (define-key global-map (list 'control 'meta i) 'digit-argument) (setq i (1+ i)))) (define-key global-map '(meta -) 'negative-argument) (define-key global-map '(control -) 'negative-argument) (define-key global-map '(control meta -) 'negative-argument) (define-key global-map "\C-k" 'kill-line) ;will change like this in 21.5. ;(define-key global-map "\M-k" 'kill-entire-line) (define-key global-map "\C-w" 'kill-region) (define-key global-map "\M-w" 'kill-ring-save) (define-key global-map "\M-\C-w" 'append-next-kill) (define-key global-map "\C-y" 'yank) (define-key global-map "\M-y" 'yank-pop) ;; Old v18 binding ;(define-key global-map "\C-xa" 'append-to-buffer) (define-key global-map "\C-@" 'set-mark-command) ;; Many people are used to typing C-SPC and getting C-@. (define-key global-map '(control ? ) 'set-mark-command) (define-key global-map "\C-x\C-x" 'exchange-point-and-mark) (define-key global-map "\C-x\C-@" 'pop-global-mark) (define-key global-map [(control x) (control ? )] 'pop-global-mark) (define-key global-map "\C-n" 'next-line) (define-key global-map "\C-p" 'previous-line) ;(define-key global-map "\C-x\C-n" 'set-goal-column) ;; XEmacs: ;;; Many people have said they rarely use this feature, and often type ;;; it by accident. Maybe it shouldn't even be on a key. ;;; Done. -hniksic ;(put 'set-goal-column 'disabled t) (define-key global-map 'menu 'popup-mode-menu) (define-key global-map [find] 'search-forward) (define-key global-map "\C-t" 'transpose-chars) (define-key global-map "\M-t" 'transpose-words) (define-key global-map "\M-\C-t" 'transpose-sexps) (define-key global-map "\C-x\C-t" 'transpose-lines) ;; XEmacs: much more reasonable and useful key definitions. (define-key global-map '(control T) 'transpose-line-down) (define-key global-map '(meta T) 'transpose-line-up) (define-key global-map "\M-;" 'indent-for-comment) (define-key global-map "\M-j" 'indent-new-comment-line) (define-key global-map "\M-\C-j" 'indent-new-comment-line) (define-key global-map "\C-x;" 'set-comment-column) (define-key global-map "\C-xf" 'set-fill-column) (define-key global-map "\C-x$" 'set-selective-display) (define-key global-map "\M-@" 'mark-word) (define-key global-map "\M-f" 'forward-word) (define-key global-map "\M-b" 'backward-word) (define-key global-map "\M-d" 'kill-word) (define-key global-map "\M-<" 'beginning-of-buffer) (define-key global-map "\M->" 'end-of-buffer) (define-key global-map "\C-xh" 'mark-whole-buffer) (define-key global-map "\M-\\" 'delete-horizontal-space) (define-key global-map "\M-\C-f" 'forward-sexp) (define-key global-map "\M-\C-b" 'backward-sexp) (define-key global-map "\M-\C-u" 'backward-up-list) (define-key global-map "\M-\C-@" 'mark-sexp) (define-key global-map "\M-\C-d" 'down-list) (define-key global-map "\M-\C-k" 'kill-sexp) (define-key global-map "\M-\C-n" 'forward-list) (define-key global-map "\M-\C-p" 'backward-list) (define-key global-map "\M-\C-a" 'beginning-of-defun) (define-key global-map "\M-\C-e" 'end-of-defun) (define-key global-map "\M-\C-h" 'mark-defun) (define-key global-map "\M-\(" 'insert-parentheses) (define-key global-map "\M-\)" 'move-past-close-and-reindent) (define-key global-map "\M-\t" 'lisp-complete-symbol) (define-key global-map "\C-x/" 'point-to-register) (define-key global-map "\C-xj" 'jump-to-register) (define-key global-map "\C-xx" 'copy-to-register) (define-key global-map "\C-xg" 'insert-register) ;; Old v18 binding ;(define-key global-map "\C-xr" 'copy-rectangle-to-register) ;; New FSF19 bindings: C-x r as a prefix for register commands (define-key global-map "\C-xr" (let ((map (make-sparse-keymap))) (set-keymap-name map 'rectangle-prefix) map)) (define-key global-map "\C-xr\C-@" 'point-to-register) (define-key global-map "\C-xr " 'point-to-register) (define-key global-map "\C-xrj" 'jump-to-register) (define-key global-map "\C-xrs" 'copy-to-register) (define-key global-map "\C-xrx" 'copy-to-register) (define-key global-map "\C-xri" 'insert-register) (define-key global-map "\C-xrg" 'insert-register) (define-key global-map "\C-xrr" 'copy-rectangle-to-register) (define-key global-map "\C-xrn" 'number-to-register) (define-key global-map "\C-xr+" 'increment-register) (define-key global-map "\C-xrc" 'clear-rectangle) (define-key global-map "\C-xrk" 'kill-rectangle) (define-key global-map "\C-xrd" 'delete-rectangle) (define-key global-map "\C-xry" 'yank-rectangle) (define-key global-map "\C-xro" 'open-rectangle) (define-key global-map "\C-xrt" 'string-rectangle) (define-key global-map "\C-xrp" 'replace-rectangle) (define-key global-map "\C-xrw" 'window-configuration-to-register) ;(define-key global-map "\C-xrf" 'frame-configuration-to-register) (define-key global-map "\M-q" 'fill-paragraph-or-region) ;(define-key global-map "\M-q" 'fill-paragraph) ;(define-key global-map "\M-g" 'fill-region) ;now bound to goto-line (define-key global-map "\C-x." 'set-fill-prefix) ; Using {} instead of [] is 1) FSF compatible and 2) allows function ; keys to work on ttys. M-[ is the beginning of most the function key ; sequences. (define-key global-map "\M-{" 'backward-paragraph) (define-key global-map "\M-}" 'forward-paragraph) (define-key global-map "\M-h" 'mark-paragraph) (define-key global-map "\M-a" 'backward-sentence) (define-key global-map "\M-e" 'forward-sentence) (define-key global-map "\M-k" 'kill-sentence) ;will change like this in 21.5. ;(define-key global-map "\M-K" 'kill-sentence) ;;(define-key global-map "\C-x\177" 'backward-kill-sentence) (define-key global-map "\C-x[" 'backward-page) (define-key global-map "\C-x]" 'forward-page) (define-key global-map "\C-x\C-p" 'mark-page) (define-key global-map "\C-xl" 'count-lines-page) (define-key global-map "\C-xnp" 'narrow-to-page) ;; Old v18 bindings ;(define-key global-map "\C-xp" 'narrow-to-page) (put 'narrow-to-page 'disabled t) ;; Old v18 bindings ;(define-key global-map "\C-x\C-a" 'add-mode-abbrev) ;(define-key global-map "\C-x+" 'add-global-abbrev) ;(define-key global-map "\C-x\C-h" 'inverse-add-mode-abbrev) ;(define-key global-map "\C-x-" 'inverse-add-global-abbrev) (define-key global-map "\M-'" 'abbrev-prefix-mark) (define-key global-map "\C-x'" 'expand-abbrev) ;; New FSF19 bindings: C-x a as a prefix for abbrev commands (define-key global-map "\C-xal" 'add-mode-abbrev) (define-key global-map "\C-xa\C-a" 'add-mode-abbrev) (define-key global-map "\C-xag" 'add-global-abbrev) (define-key global-map "\C-xa+" 'add-mode-abbrev) (define-key global-map "\C-xaig" 'inverse-add-global-abbrev) (define-key global-map "\C-xail" 'inverse-add-mode-abbrev) (define-key global-map "\C-xa-" 'inverse-add-global-abbrev) (define-key global-map "\C-xae" 'expand-abbrev) (define-key global-map "\C-xa'" 'expand-abbrev) (define-key global-map "\M-\C-l" 'switch-to-other-buffer) ;; Default binding of "Backspace" is no longer the same as delete. ;; Default binding of "Control-h" is help. (define-key global-map 'backspace 'delete-backward-char) (define-key global-map '(meta backspace) 'backward-kill-word) (define-key global-map [(control x) backspace] 'backward-kill-sentence) (define-key global-map "\M-\C-z" 'activate-region) ;; FSFmacs macros.c (define-key global-map "\C-xe" 'call-last-kbd-macro) (define-key global-map "\C-x\(" 'start-kbd-macro) (define-key global-map "\C-x\)" 'end-kbd-macro) ;; FSFmacs macros.el (define-key global-map "\C-xq" 'kbd-macro-query) ;; FSFmacs minibuffer.c ; see also minibuf.el (define-key global-map "\M-\C-c" 'exit-recursive-edit) (define-key global-map "\C-]" 'abort-recursive-edit) (define-key global-map "\M-x" 'execute-extended-command) ;; FSFmacs window.c (define-key global-map "\C-x0" 'delete-window) (define-key global-map "\C-x1" 'delete-other-windows) (define-key global-map "\C-x2" 'split-window-vertically) (define-key global-map "\C-x3" 'split-window-horizontally) ;; Old XEmacs binding ;;(define-key global-map "\C-x5" 'split-window-horizontally) (define-key global-map "\C-xo" 'other-window) (define-key global-map "\C-x^" 'enlarge-window) (define-key global-map "\C-x<" 'scroll-left) (define-key global-map "\C-x>" 'scroll-right) (define-key global-map "\C-v" 'scroll-up-command) (define-key global-map "\M-v" 'scroll-down-command) (define-key global-map "\M-\C-v" 'scroll-other-window) ; meta-shift-V, that is. (define-key global-map '(meta V) 'scroll-other-window-down) (define-key global-map "\C-l" 'recenter) (define-key global-map "\M-r" 'move-to-window-line) ;; FSFmacs window.el (define-key global-map "\C-x6" 'window-configuration-to-register) ;(define-key global-map "\C-x7" 'jump-to-register);ie register-to-window-config (define-key global-map "\C-x}" 'enlarge-window-horizontally) (define-key global-map "\C-x{" 'shrink-window-horizontally) ;; New FSF19 bindings (define-key global-map "\C-x-" 'shrink-window-if-larger-than-buffer) (define-key global-map "\C-x+" 'balance-windows) (define-key ctl-x-4-map "0" 'kill-buffer-and-window) ;;(define-key global-map "\C-g" 'keyboard-quit) (let ((ch (quit-char))) (if (or (characterp ch) (integerp ch)) (setq ch (char-to-string ch))) (define-key global-map ch 'keyboard-quit)) (define-key global-tty-map "\e\e\e" 'keyboard-escape-quit) (define-key global-window-system-map "\e\e" 'keyboard-escape-quit) (define-key global-map "\M-%" 'query-replace) ;; FSF v20 binding (define-key global-map [(control meta %)] 'query-replace-regexp) ; autoloaded ;(define-key global-map "\C-x4a" 'add-change-log-entry-other-window) ; autoloaded ;(define-key global-map "\C-x`" 'next-error) ; autoloaded ;(define-key global-map "\M-/" 'dabbrev-expand) ; autoloaded ;(define-key global-map "\C-xd" 'dired) ; autoloaded ;(define-key global-map "\C-x4d" 'dired-other-window) (define-key global-map "\M-$" 'ispell-word) (define-key global-map "\C-xm" 'compose-mail) (define-key global-map "\C-x4m" 'compose-mail-other-window) (define-key global-map "\C-x5m" 'compose-mail-other-frame) (define-key global-map "\M-." 'find-tag) (define-key global-map "\C-x4." 'find-tag-other-window) (define-key global-map "\M-," 'tags-loop-continue) (define-key global-map '(control <) 'mark-beginning-of-buffer) (define-key global-map '(control >) 'mark-end-of-buffer) (define-key global-map "\C-x\C-e" 'eval-last-sexp) ;bogus! (define-key global-map "\M-g" 'goto-line) ;; Keypad type things ;; I removed all the fkey crap, because where-is is now smart enough ;; to show all bindings. --ben ;;; These aren't bound to kbd macros like "\C-b" so that they have the ;; expected behavior even in, for example, vi-mode. ;; We use here symbolic names, assuming that the corresponding keys will ;; generate these keysyms. This is not true on Suns, but x-win-sun.el ;; fixes that. If it turns out that the semantics of these keys should ;; differ from server to server, this should be moved into server-specific ;; files, but these appear to be the standard Motif and PC bindings. ;; movement by units (define-key global-map 'left 'backward-char-command) (define-key global-map 'right 'forward-char-command) (define-key global-map 'up 'previous-line) (define-key global-map 'down 'next-line) (define-key global-map 'kp-left 'backward-char-command) (define-key global-map 'kp-right 'forward-char-command) (define-key global-map 'kp-up 'previous-line) (define-key global-map 'kp-down 'next-line) ;; movement by pages (define-key global-map 'prior 'scroll-down-command) (define-key global-map 'next 'scroll-up-command) (define-key global-map '(control prior) 'scroll-right) (define-key global-map '(control next) 'scroll-left) (define-key global-map 'kp-prior 'scroll-down-command) (define-key global-map 'kp-next 'scroll-up-command) (define-key global-map '(control kp-prior) 'scroll-right) (define-key global-map '(control kp-next) 'scroll-left) ;; movement to the limits (define-key global-map 'home 'beginning-of-line) (define-key global-map 'end 'end-of-line) (define-key global-map '(control home) 'beginning-of-buffer) (define-key global-map '(control end) 'end-of-buffer) (define-key global-map 'kp-home 'beginning-of-line) (define-key global-map 'kp-end 'end-of-line) (define-key global-map '(control kp-home) 'beginning-of-buffer) (define-key global-map '(control kp-end) 'end-of-buffer) ;; on which systems do these exist? (define-key global-map 'begin 'beginning-of-line) (define-key global-map '(control begin) 'beginning-of-buffer) ;; movement by larger blocks (define-key global-map '(control left) 'backward-word) (define-key global-map '(control right) 'forward-word) (define-key global-map '(control up) 'backward-block-of-lines) (define-key global-map '(control down) 'forward-block-of-lines) (define-key global-map '(control kp-left) 'backward-word) (define-key global-map '(control kp-right) 'forward-word) (define-key global-map '(control kp-up) 'backward-block-of-lines) (define-key global-map '(control kp-down) 'forward-block-of-lines) ;; context-sensitive movement (define-key global-map '(meta left) 'backward-sexp) (define-key global-map '(meta right) 'forward-sexp) (define-key global-map '(meta up) 'backward-paragraph) (define-key global-map '(meta down) 'forward-paragraph) (define-key global-map '(meta control left) 'backward-sentence) (define-key global-map '(meta control right) 'forward-sentence) (define-key global-map '(meta control up) 'scroll-down-one) (define-key global-map '(meta control down) 'scroll-up-one) (define-key global-map '(meta control home) 'beginning-of-defun) (define-key global-map '(meta control end) 'end-of-defun) (define-key global-map '(meta control prior) 'backward-page) (define-key global-map '(meta control next) 'forward-page) (define-key global-map '(meta kp-left) 'backward-sexp) (define-key global-map '(meta kp-right) 'forward-sexp) (define-key global-map '(meta kp-up) 'backward-paragraph) (define-key global-map '(meta kp-down) 'forward-paragraph) (define-key global-map '(meta control kp-left) 'backward-sentence) (define-key global-map '(meta control kp-right) 'forward-sentence) (define-key global-map '(meta control kp-up) 'scroll-down-one) (define-key global-map '(meta control kp-down) 'scroll-up-one) (define-key global-map '(meta control kp-home) 'beginning-of-defun) (define-key global-map '(meta control kp-end) 'end-of-defun) (define-key global-map '(meta control kp-prior) 'backward-page) (define-key global-map '(meta control kp-next) 'forward-page) ;; movement between windows (define-key global-map '(control tab) 'other-window) (define-key global-map '(control shift tab) 'backward-other-window) ;; movement in other windows (define-key global-map '(meta next) 'scroll-other-window) (define-key global-map '(meta prior) 'scroll-other-window-down) (define-key global-map '(meta kp-next) 'scroll-other-window) (define-key global-map '(meta kp-prior) 'scroll-other-window-down) ;; movement between buffers (global-set-key '(meta shift home) 'switch-to-previous-buffer-in-group) (global-set-key '(meta shift end) 'switch-to-next-buffer-in-group) (global-set-key '(meta home) 'switch-to-previous-buffer) (global-set-key '(meta end) 'switch-to-next-buffer) (global-set-key '(meta shift kp-home) 'switch-to-previous-buffer-in-group) (global-set-key '(meta shift kp-end) 'switch-to-next-buffer-in-group) (global-set-key '(meta kp-home) 'switch-to-previous-buffer) (global-set-key '(meta kp-end) 'switch-to-next-buffer) ;; the infamous delete key (define-key global-map 'delete 'backward-or-forward-delete-char) (define-key global-map '(control delete) 'backward-or-forward-kill-word) (define-key global-map '(meta delete) 'backward-or-forward-kill-word) (define-key global-map [(control x) (delete)] 'backward-or-forward-kill-sentence) (define-key global-map '(shift delete) 'kill-primary-selection) (define-key global-map 'kp-delete 'backward-or-forward-delete-char) (define-key global-map '(control kp-delete) 'backward-or-forward-kill-word) (define-key global-map '(meta kp-delete) 'backward-or-forward-kill-word) (define-key global-map [(control x) (kp-delete)] 'backward-or-forward-kill-sentence) (define-key global-map '(shift kp-delete) 'kill-primary-selection) ;; don't try this one at home, kids. (define-key global-map '(control meta delete) 'backward-or-forward-kill-sexp) (define-key global-map '(control meta kp-delete) 'backward-or-forward-kill-sexp) ;; or this one, either, on Linux. (define-key global-map '(control meta backspace) 'backward-kill-sexp) ;;; Miscellaneous key bindings (define-key global-map 'insert 'overwrite-mode) (define-key global-map 'kp-insert 'overwrite-mode) (define-key global-map 'again 'repeat-complex-command) (define-key global-map 'redo 'repeat-complex-command) (define-key global-map 'kp-enter [return]) ; do whatever RET does now (define-key global-map 'kp-tab [tab]) (define-key global-map 'undo 'undo) (define-key global-map 'help 'help-for-help) (define-key global-map 'kp-space 'self-insert-command) (define-key global-map 'kp-equal 'self-insert-command) (define-key global-map 'kp-multiply 'self-insert-command) (define-key global-map 'kp-add 'self-insert-command) (define-key global-map 'kp-separator 'self-insert-command) (define-key global-map 'kp-subtract 'self-insert-command) (define-key global-map 'kp-decimal 'self-insert-command) (define-key global-map 'kp-divide 'self-insert-command) (define-key global-map 'kp-0 'self-insert-command) (define-key global-map 'kp-1 'self-insert-command) (define-key global-map 'kp-2 'self-insert-command) (define-key global-map 'kp-3 'self-insert-command) (define-key global-map 'kp-4 'self-insert-command) (define-key global-map 'kp-5 'self-insert-command) (define-key global-map 'kp-6 'self-insert-command) (define-key global-map 'kp-7 'self-insert-command) (define-key global-map 'kp-8 'self-insert-command) (define-key global-map 'kp-9 'self-insert-command) ;(define-key global-map 'select 'function-key-error) ;(define-key global-map 'print 'function-key-error) (define-key global-map 'execute 'execute-extended-command) ;(define-key global-map 'clearline 'function-key-error) (define-key global-map 'insertline 'open-line) (define-key global-map 'deleteline 'kill-line) ;(define-key global-map 'insertchar 'function-key-error) (define-key global-map 'deletechar 'delete-char) ;; Bind the mouse wheel by default. (dolist (keyspec '([(mouse-4)] [(shift mouse-4)] [(control mouse-4)] [(mouse-5)] [(shift mouse-5)] [(control mouse-5)])) (define-key global-map keyspec #'(lambda (event) (interactive "e") (mwheel-install) (declare-fboundp (mwheel-scroll event))))) ;;; keydefs.el ends here