Change mnemonic letters for iso-2022-7bit-ss2 and
[bpt/emacs.git] / lisp / bindings.el
CommitLineData
4d120e8c
RS
1;;; bindings.el --- define standard key bindings and some variables.
2
3;; Copyright (C) 1985,86,87,92,93,94,95,96 Free Software Foundation, Inc.
4
5;; Maintainer: FSF
6;; Keywords: internal
7
8;; This file is part of GNU Emacs.
9
10;; GNU Emacs is free software; you can redistribute it and/or modify
11;; it under the terms of the GNU General Public License as published by
12;; the Free Software Foundation; either version 2, or (at your option)
13;; any later version.
14
15;; GNU Emacs is distributed in the hope that it will be useful,
16;; but WITHOUT ANY WARRANTY; without even the implied warranty of
17;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18;; GNU General Public License for more details.
19
20;; You should have received a copy of the GNU General Public License
21;; along with GNU Emacs; see the file COPYING. If not, write to
22;; the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
23;; Boston, MA 02111-1307, USA.
24
25;;; Commentary:
26
27;;; !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
28;;; Special formatting conventions are used in this file!
29;;;
30;;; a backslash-newline is used at the beginning of a documentation string
31;;; when that string should be stored in the file etc/DOCnnn, not in core.
32;;;
33;;; Such strings read into Lisp as numbers (during the pure-loading phase).
34;;;
35;;; But you must obey certain rules to make sure the string is understood
36;;; and goes into etc/DOCnnn properly. Otherwise, the string will not go
37;;; anywhere!
38;;;
39;;; The doc string must appear in the standard place in a call to
40;;; defun, autoload, defvar or defconst. No Lisp macros are recognized.
41;;; The open-paren starting the definition must appear in column 0.
42;;;
43;;; In defvar and defconst, there is an additional rule:
44;;; The double-quote that starts the string must be on the same
45;;; line as the defvar or defconst.
46;;; !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
47
48;;; Code:
49
f8bce5df
KH
50(defconst mode-line-mule-info
51 (purecopy '(enable-multibyte-characters
52 ((current-input-method ("[" current-input-method-title "]"))
71e99a2f 53 "%z:")))
f8bce5df
KH
54 "Mode-line control for displaying information of multilingual environment.")
55
56(make-variable-buffer-local 'mode-line-mule-info)
57
4544e9db 58(defvar mode-line-buffer-identification (purecopy '("%12b"))
4d120e8c 59 "Mode-line control for identifying the buffer being displayed.
4544e9db 60Its default value is (\"%12b\").
4d120e8c
RS
61Major modes that edit things other than ordinary files may change this
62\(e.g. Info, Dired,...)")
63
64(make-variable-buffer-local 'mode-line-buffer-identification)
65
4544e9db
RS
66(defvar mode-line-frame-identification '("-%F "))
67
4b189189 68(defvar mode-line-process nil
4d120e8c
RS
69 "Mode-line control for displaying info on process status.
70Normally nil in most modes, since there is no process to display.")
71
72(make-variable-buffer-local 'mode-line-process)
73
71e99a2f 74(defvar mode-line-modified (purecopy '("%1*%1+"))
4d120e8c
RS
75 "Mode-line control for displaying whether current buffer is modified.")
76
77(make-variable-buffer-local 'mode-line-modified)
78
79(setq-default mode-line-format
4544e9db 80 (list (purecopy "-")
f8bce5df 81 'mode-line-mule-info
4d120e8c 82 'mode-line-modified
4544e9db 83 'mode-line-frame-identification
4d120e8c
RS
84 'mode-line-buffer-identification
85 (purecopy " ")
86 'global-mode-string
87 (purecopy " %[(")
88 'mode-name 'mode-line-process 'minor-mode-alist
89 (purecopy "%n")
90 (purecopy ")%]--")
91 (purecopy '(line-number-mode "L%l--"))
92 (purecopy '(column-number-mode "C%c--"))
93 (purecopy '(-3 . "%p"))
94 (purecopy "-%-")))
95
96(defvar minor-mode-alist nil "\
97Alist saying how to show minor modes in the mode line.
98Each element looks like (VARIABLE STRING);
99STRING is included in the mode line iff VARIABLE's value is non-nil.
100
101Actually, STRING need not be a string; any possible mode-line element
102is okay. See `mode-line-format'.")
2fa58881
RS
103;; Don't use purecopy here--some people want to change these strings.
104(setq minor-mode-alist '((abbrev-mode " Abbrev")
105 (overwrite-mode overwrite-mode)
106 (auto-fill-function " Fill")
107 ;; not really a minor mode...
108 (defining-kbd-macro " Def")))
4d120e8c
RS
109
110;; These variables are used by autoloadable packages.
111;; They are defined here so that they do not get overridden
112;; by the loading of those packages.
113
114;; Names in directory that end in one of these
115;; are ignored in completion,
116;; making it more likely you will get a unique match.
117(setq completion-ignored-extensions
d34c1b05
RS
118 (append
119 (cond ((or (eq system-type 'ms-dos) (eq system-type 'windows-nt))
120 '(".o" "~" ".bin" ".bak" ".obj" ".map"
121 ".a" ".ln" ".blg" ".bbl"))
122 ((eq system-type 'vax-vms)
123 '(".obj" ".exe" ".bin" ".lbin" ".sbin"
124 ".brn" ".rnt" ".mem" ".lni" ".lis"
125 ".olb" ".tlb" ".mlb" ".hlb"))
126 (t
127 '(".o" "~" ".bin" ".lbin" ".fasl"
128 ".a" ".ln" ".blg" ".bbl")))
129 '(".elc" ".lof"
130 ".glo" ".idx" ".lot"
131 ;; TeX-related
132 ".dvi" ".fmt"
133 ;; Texinfo-related
134 ".toc" ".log" ".aux"
135 ".cp" ".fn" ".ky" ".pg" ".tp" ".vr"
136 ".cps" ".fns" ".kys" ".pgs" ".tps" ".vrs")))
4d120e8c
RS
137
138(setq debug-ignored-errors
139 '(beginning-of-line beginning-of-buffer end-of-line
140 end-of-buffer end-of-file buffer-read-only
141 "^Previous command was not a yank$"
142 "^Minibuffer window is not active$"
143 "^End of history; no next item$"
144 "^Beginning of history; no preceding item$"
145 "^No recursive edit is in progress$"
146 "^Changes to be undone are outside visible portion of buffer$"
147 "^No undo information in this buffer$"
148 "^No further undo information$"
149 "^Save not confirmed$"
150 "^Recover-file cancelled\\.$"
151
152 ;; comint
153 "^Not at command line$"
154 "^Empty input ring$"
155 "^No history$"
156 "^Not found$";; To common?
157 "^Current buffer has no process$"
158
159 ;; dabbrev
ed4ccb03
RS
160 "^No dynamic expansion for .* found$"
161 "^No further dynamic expansion for .* found$"
4d120e8c
RS
162
163 ;; Completion
164 "^To complete, the point must be after a symbol at least [0-9]* character long\\.$"
165 "^The string \".*\" is too short to be saved as a completion\\.$"
166
167 ;; Compile
168 "^No more errors\\( yet\\|\\)$"
169
170 ;; Gnus
171 "^NNTP: Connection closed\\.$"
172
173 ;; info
174 "^Node has no Previous$"
175 "^No \".*\" in index$"
176
177 ;; imenu
178 "^No items suitable for an index found in this buffer\\.$"
179 "^The mode \".*\" does not take full advantage of imenu\\.el yet\\.$"
180
181 ;; ispell
182 "^No word found to check!$"
183
184 ;; mh-e
185 "^Cursor not pointing to message$"
186 "^There is no other window$"
187
188 ;; man
189 "^No manpage [0-9]* found$"
190
191 ;; etags
192 "^No tags table in use! Use .* to select one\\.$"
193 "^There is no default tag$"
194 "^No previous tag locations$"
195 "^File .* is not a valid tags table$"
196 "^No \\(more \\|\\)tags \\(matching\\|containing\\) "
197 "^Rerun etags: `.*' not found in "
198 "^All files processed\\.$"
199 "^No .* or .* in progress.$"
200 "^File .* not in current tags tables$"
201 "No tags table loaded."
202 "^Nothing to complete$"
203
204 ;; BBDB
205 "^no previous record$"
206 "^no next record$"))
207
208
209(make-variable-buffer-local 'indent-tabs-mode)
210
211;; This is here to avoid autoloading etags on M-TAB.
212;; M-x visit-tags-table will autoload etags, which will redefine complete-tag.
213(defun complete-tag ()
214 "Perform tags completion on the text around point.
215Completes to the set of names listed in the current tags table.
216The string to complete is chosen in the same way as the default
217for \\[find-tag] (which see)."
218 (interactive)
219 (error (substitute-command-keys
220 "No tags table loaded. Try \\[visit-tags-table].")))
221
222;; Reduce total amount of space we must allocate during this function
223;; that we will not need to keep permanently.
224(garbage-collect)
225\f
5a0c40ea
RS
226;; Make Latin-1, Latin-2, Latin-3 and Latin-4 characters self-insert.
227(aset (nth 1 global-map) (make-char 'latin-iso8859-1) 'self-insert-command)
228(aset (nth 1 global-map) (make-char 'latin-iso8859-2) 'self-insert-command)
229(aset (nth 1 global-map) (make-char 'latin-iso8859-3) 'self-insert-command)
230(aset (nth 1 global-map) (make-char 'latin-iso8859-4) 'self-insert-command)
3607b64d 231
4d120e8c
RS
232(define-key ctl-x-map "n" (make-sparse-keymap))
233(define-key ctl-x-map "r" (make-sparse-keymap))
234
235(setq help-event-list '(help f1))
236
237;These commands are defined in editfns.c
238;but they are not assigned to keys there.
239(put 'narrow-to-region 'disabled t)
240(define-key ctl-x-map "nn" 'narrow-to-region)
241(define-key ctl-x-map "nw" 'widen)
242;; (define-key ctl-x-map "n" 'narrow-to-region)
243;; (define-key ctl-x-map "w" 'widen)
244
245(define-key global-map "\C-j" 'newline-and-indent)
246(define-key global-map "\C-m" 'newline)
247(define-key global-map "\C-o" 'open-line)
248(define-key esc-map "\C-o" 'split-line)
249(define-key global-map "\C-q" 'quoted-insert)
250(define-key esc-map "^" 'delete-indentation)
251(define-key esc-map "\\" 'delete-horizontal-space)
252(define-key esc-map "m" 'back-to-indentation)
253(define-key ctl-x-map "\C-o" 'delete-blank-lines)
254(define-key esc-map " " 'just-one-space)
255(define-key esc-map "z" 'zap-to-char)
256(define-key esc-map "=" 'count-lines-region)
257(define-key ctl-x-map "=" 'what-cursor-position)
258(define-key esc-map ":" 'eval-expression)
259;; Define ESC ESC : like ESC : for people who type ESC ESC out of habit.
260(define-key esc-map "\M-:" 'eval-expression)
261;; Changed from C-x ESC so that function keys work following C-x.
262(define-key ctl-x-map "\e\e" 'repeat-complex-command)
263;; New binding analogous to M-:.
264(define-key ctl-x-map "\M-:" 'repeat-complex-command)
265(define-key ctl-x-map "u" 'advertised-undo)
266;; Many people are used to typing C-/ on X terminals and getting C-_.
267(define-key global-map [?\C-/] 'undo)
268(define-key global-map "\C-_" 'undo)
269(define-key esc-map "!" 'shell-command)
270(define-key esc-map "|" 'shell-command-on-region)
271
272;; This is an experiment--make up and down arrows do history.
273(define-key minibuffer-local-map [up] 'previous-history-element)
274(define-key minibuffer-local-map [down] 'next-history-element)
275(define-key minibuffer-local-ns-map [up] 'previous-history-element)
276(define-key minibuffer-local-ns-map [down] 'next-history-element)
277(define-key minibuffer-local-completion-map [up] 'previous-history-element)
278(define-key minibuffer-local-completion-map [down] 'next-history-element)
279(define-key minibuffer-local-must-match-map [up] 'previous-history-element)
280(define-key minibuffer-local-must-match-map [down] 'next-history-element)
281
282(define-key global-map "\C-u" 'universal-argument)
283(let ((i ?0))
284 (while (<= i ?9)
285 (define-key esc-map (char-to-string i) 'digit-argument)
286 (setq i (1+ i))))
287(define-key esc-map "-" 'negative-argument)
288;; Define control-digits.
289(let ((i ?0))
290 (while (<= i ?9)
291 (define-key global-map (read (format "[?\\C-%c]" i)) 'digit-argument)
292 (setq i (1+ i))))
293(define-key global-map [?\C--] 'negative-argument)
294;; Define control-meta-digits.
295(let ((i ?0))
296 (while (<= i ?9)
297 (define-key esc-map (read (format "[?\\C-%c]" i)) 'digit-argument)
298 (setq i (1+ i))))
299(define-key global-map [?\C-\M--] 'negative-argument)
300
301(define-key global-map "\C-k" 'kill-line)
302(define-key global-map "\C-w" 'kill-region)
303(define-key esc-map "w" 'kill-ring-save)
304(define-key esc-map "\C-w" 'append-next-kill)
305(define-key global-map "\C-y" 'yank)
306(define-key esc-map "y" 'yank-pop)
307
308;; (define-key ctl-x-map "a" 'append-to-buffer)
309
310(define-key global-map "\C-@" 'set-mark-command)
311;; Many people are used to typing C-SPC and getting C-@.
312(define-key global-map [?\C-\ ] 'set-mark-command)
313(define-key ctl-x-map "\C-x" 'exchange-point-and-mark)
314(define-key ctl-x-map "\C-@" 'pop-global-mark)
315(define-key ctl-x-map [?\C-\ ] 'pop-global-mark)
316
317(define-key global-map "\C-n" 'next-line)
318(define-key global-map "\C-p" 'previous-line)
319(define-key ctl-x-map "\C-n" 'set-goal-column)
320
321;;(defun function-key-error ()
322;; (interactive)
323;; (error "That function key is not bound to anything."))
324
325(define-key global-map [menu] 'execute-extended-command)
326(define-key global-map [find] 'search-forward)
327
328;; natural bindings for terminal keycaps --- defined in X keysym order
329(define-key global-map [home] 'beginning-of-buffer)
330(define-key global-map [M-home] 'beginning-of-buffer-other-window)
331(define-key global-map [left] 'backward-char)
332(define-key global-map [up] 'previous-line)
333(define-key global-map [right] 'forward-char)
334(define-key global-map [down] 'next-line)
335(define-key global-map [prior] 'scroll-down)
336(define-key global-map [next] 'scroll-up)
337(define-key global-map [C-up] 'backward-paragraph)
338(define-key global-map [C-down] 'forward-paragraph)
339(define-key global-map [C-prior] 'scroll-right)
340(define-key global-map [C-next] 'scroll-left)
341(define-key global-map [M-next] 'scroll-other-window)
342(define-key global-map [M-prior] 'scroll-other-window-down)
343(define-key global-map [end] 'end-of-buffer)
344(define-key global-map [M-end] 'end-of-buffer-other-window)
345(define-key global-map [begin] 'beginning-of-buffer)
346(define-key global-map [M-begin] 'beginning-of-buffer-other-window)
347;; (define-key global-map [select] 'function-key-error)
348;; (define-key global-map [print] 'function-key-error)
349(define-key global-map [execute] 'execute-extended-command)
350(define-key global-map [insert] 'overwrite-mode)
351(define-key global-map [C-insert] 'kill-ring-save)
352(define-key global-map [S-insert] 'yank)
353(define-key global-map [undo] 'undo)
354(define-key global-map [redo] 'repeat-complex-command)
355;; (define-key global-map [clearline] 'function-key-error)
356(define-key global-map [insertline] 'open-line)
357(define-key global-map [deleteline] 'kill-line)
358;; (define-key global-map [insertchar] 'function-key-error)
359(define-key global-map [deletechar] 'delete-char)
360;; (define-key global-map [backtab] 'function-key-error)
361;; (define-key global-map [f1] 'function-key-error)
362;; (define-key global-map [f2] 'function-key-error)
363;; (define-key global-map [f3] 'function-key-error)
364;; (define-key global-map [f4] 'function-key-error)
365;; (define-key global-map [f5] 'function-key-error)
366;; (define-key global-map [f6] 'function-key-error)
367;; (define-key global-map [f7] 'function-key-error)
368;; (define-key global-map [f8] 'function-key-error)
369;; (define-key global-map [f9] 'function-key-error)
370;; (define-key global-map [f10] 'function-key-error)
371;; (define-key global-map [f11] 'function-key-error)
372;; (define-key global-map [f12] 'function-key-error)
373;; (define-key global-map [f13] 'function-key-error)
374;; (define-key global-map [f14] 'function-key-error)
375;; (define-key global-map [f15] 'function-key-error)
376;; (define-key global-map [f16] 'function-key-error)
377;; (define-key global-map [f17] 'function-key-error)
378;; (define-key global-map [f18] 'function-key-error)
379;; (define-key global-map [f19] 'function-key-error)
380;; (define-key global-map [f20] 'function-key-error)
381;; (define-key global-map [f21] 'function-key-error)
382;; (define-key global-map [f22] 'function-key-error)
383;; (define-key global-map [f23] 'function-key-error)
384;; (define-key global-map [f24] 'function-key-error)
385;; (define-key global-map [f25] 'function-key-error)
386;; (define-key global-map [f26] 'function-key-error)
387;; (define-key global-map [f27] 'function-key-error)
388;; (define-key global-map [f28] 'function-key-error)
389;; (define-key global-map [f29] 'function-key-error)
390;; (define-key global-map [f30] 'function-key-error)
391;; (define-key global-map [f31] 'function-key-error)
392;; (define-key global-map [f32] 'function-key-error)
393;; (define-key global-map [f33] 'function-key-error)
394;; (define-key global-map [f34] 'function-key-error)
395;; (define-key global-map [f35] 'function-key-error)
396;; (define-key global-map [kp-backtab] 'function-key-error)
397;; (define-key global-map [kp-space] 'function-key-error)
398;; (define-key global-map [kp-tab] 'function-key-error)
399;; (define-key global-map [kp-enter] 'function-key-error)
400;; (define-key global-map [kp-f1] 'function-key-error)
401;; (define-key global-map [kp-f2] 'function-key-error)
402;; (define-key global-map [kp-f3] 'function-key-error)
403;; (define-key global-map [kp-f4] 'function-key-error)
404;; (define-key global-map [kp-multiply] 'function-key-error)
405;; (define-key global-map [kp-add] 'function-key-error)
406;; (define-key global-map [kp-separator] 'function-key-error)
407;; (define-key global-map [kp-subtract] 'function-key-error)
408;; (define-key global-map [kp-decimal] 'function-key-error)
409;; (define-key global-map [kp-divide] 'function-key-error)
410;; (define-key global-map [kp-0] 'function-key-error)
411;; (define-key global-map [kp-1] 'function-key-error)
412;; (define-key global-map [kp-2] 'function-key-error)
413;; (define-key global-map [kp-3] 'function-key-error)
414;; (define-key global-map [kp-4] 'function-key-error)
415;; (define-key global-map [kp-5] 'recenter)
416;; (define-key global-map [kp-6] 'function-key-error)
417;; (define-key global-map [kp-7] 'function-key-error)
418;; (define-key global-map [kp-8] 'function-key-error)
419;; (define-key global-map [kp-9] 'function-key-error)
420;; (define-key global-map [kp-equal] 'function-key-error)
421
422;; X11R6 distinguishes these keys from the non-kp keys.
423;; Make them behave like the non-kp keys unless otherwise bound.
424(define-key function-key-map [kp-home] [home])
425(define-key function-key-map [kp-left] [left])
426(define-key function-key-map [kp-up] [up])
427(define-key function-key-map [kp-right] [right])
428(define-key function-key-map [kp-down] [down])
429(define-key function-key-map [kp-prior] [prior])
430(define-key function-key-map [kp-next] [next])
431(define-key function-key-map [M-kp-next] [M-next])
432(define-key function-key-map [kp-end] [end])
433(define-key function-key-map [kp-begin] [begin])
434(define-key function-key-map [kp-insert] [insert])
435(define-key function-key-map [kp-delete] [delete])
436
437(define-key global-map [mouse-movement] 'ignore)
438
439(define-key global-map "\C-t" 'transpose-chars)
440(define-key esc-map "t" 'transpose-words)
441(define-key esc-map "\C-t" 'transpose-sexps)
442(define-key ctl-x-map "\C-t" 'transpose-lines)
443
444(define-key esc-map ";" 'indent-for-comment)
445(define-key esc-map "j" 'indent-new-comment-line)
446(define-key esc-map "\C-j" 'indent-new-comment-line)
447(define-key ctl-x-map ";" 'set-comment-column)
448(define-key ctl-x-map "f" 'set-fill-column)
449(define-key ctl-x-map "$" 'set-selective-display)
450
451(define-key esc-map "@" 'mark-word)
452(define-key esc-map "f" 'forward-word)
453(define-key esc-map "b" 'backward-word)
454(define-key esc-map "d" 'kill-word)
455(define-key esc-map "\177" 'backward-kill-word)
456
457(define-key esc-map "<" 'beginning-of-buffer)
458(define-key esc-map ">" 'end-of-buffer)
459(define-key ctl-x-map "h" 'mark-whole-buffer)
460(define-key esc-map "\\" 'delete-horizontal-space)
461
462(defalias 'mode-specific-command-prefix (make-sparse-keymap))
4b189189 463(defvar mode-specific-map (symbol-function 'mode-specific-command-prefix)
4d120e8c
RS
464 "Keymap for characters following C-c.")
465(define-key global-map "\C-c" 'mode-specific-command-prefix)
466
467(global-set-key [M-right] 'forward-word)
468(global-set-key [M-left] 'backward-word)
469;; ilya@math.ohio-state.edu says these bindings are standard on PC editors.
470(global-set-key [C-right] 'forward-word)
471(global-set-key [C-left] 'backward-word)
472;; This is not quite compatible, but at least is analogous
473(global-set-key [C-delete] 'backward-kill-word)
474;; This is "move to the clipboard", or as close as we come.
475(global-set-key [S-delete] 'kill-region)
476
477(define-key esc-map "\C-f" 'forward-sexp)
478(define-key esc-map "\C-b" 'backward-sexp)
479(define-key esc-map "\C-u" 'backward-up-list)
480(define-key esc-map "\C-@" 'mark-sexp)
481(define-key esc-map [?\C-\ ] 'mark-sexp)
482(define-key esc-map "\C-d" 'down-list)
483(define-key esc-map "\C-k" 'kill-sexp)
484(define-key global-map [C-M-delete] 'backward-kill-sexp)
485(define-key global-map [C-M-backspace] 'backward-kill-sexp)
486(define-key esc-map "\C-n" 'forward-list)
487(define-key esc-map "\C-p" 'backward-list)
488(define-key esc-map "\C-a" 'beginning-of-defun)
489(define-key esc-map "\C-e" 'end-of-defun)
490(define-key esc-map "\C-h" 'mark-defun)
491(define-key ctl-x-map "nd" 'narrow-to-defun)
492(define-key esc-map "(" 'insert-parentheses)
493(define-key esc-map ")" 'move-past-close-and-reindent)
4d120e8c
RS
494
495(define-key ctl-x-map "\C-e" 'eval-last-sexp)
6d64bc9f
RS
496
497(define-key ctl-x-map "m" 'compose-mail)
498(define-key ctl-x-4-map "m" 'compose-mail-other-window)
499(define-key ctl-x-5-map "m" 'compose-mail-other-frame)
4d120e8c
RS
500\f
501(define-key ctl-x-map "r\C-@" 'point-to-register)
502(define-key ctl-x-map [?r ?\C-\ ] 'point-to-register)
503(define-key ctl-x-map "r " 'point-to-register)
504(define-key ctl-x-map "rj" 'jump-to-register)
505(define-key ctl-x-map "rs" 'copy-to-register)
506(define-key ctl-x-map "rx" 'copy-to-register)
507(define-key ctl-x-map "ri" 'insert-register)
508(define-key ctl-x-map "rg" 'insert-register)
509(define-key ctl-x-map "rr" 'copy-rectangle-to-register)
510(define-key ctl-x-map "rc" 'clear-rectangle)
511(define-key ctl-x-map "rk" 'kill-rectangle)
512(define-key ctl-x-map "rd" 'delete-rectangle)
513(define-key ctl-x-map "ry" 'yank-rectangle)
514(define-key ctl-x-map "ro" 'open-rectangle)
515(define-key ctl-x-map "rt" 'string-rectangle)
516(define-key ctl-x-map "rw" 'window-configuration-to-register)
517(define-key ctl-x-map "rf" 'frame-configuration-to-register)
518
519;; These key bindings are deprecated; use the above C-x r map instead.
520;; We use these aliases so \[...] will show the C-x r bindings instead.
521(defalias 'point-to-register-compatibility-binding 'point-to-register)
522(defalias 'jump-to-register-compatibility-binding 'jump-to-register)
523(defalias 'copy-to-register-compatibility-binding 'copy-to-register)
524(defalias 'insert-register-compatibility-binding 'insert-register)
525(define-key ctl-x-map "/" 'point-to-register-compatibility-binding)
526(define-key ctl-x-map "j" 'jump-to-register-compatibility-binding)
527(define-key ctl-x-map "x" 'copy-to-register-compatibility-binding)
528(define-key ctl-x-map "g" 'insert-register-compatibility-binding)
529;; (define-key ctl-x-map "r" 'copy-rectangle-to-register)
530
531(define-key esc-map "q" 'fill-paragraph)
532;; (define-key esc-map "g" 'fill-region)
533(define-key ctl-x-map "." 'set-fill-prefix)
534\f
535(define-key esc-map "{" 'backward-paragraph)
536(define-key esc-map "}" 'forward-paragraph)
537(define-key esc-map "h" 'mark-paragraph)
538(define-key esc-map "a" 'backward-sentence)
539(define-key esc-map "e" 'forward-sentence)
540(define-key esc-map "k" 'kill-sentence)
541(define-key ctl-x-map "\177" 'backward-kill-sentence)
542
543(define-key ctl-x-map "[" 'backward-page)
544(define-key ctl-x-map "]" 'forward-page)
545(define-key ctl-x-map "\C-p" 'mark-page)
546(define-key ctl-x-map "l" 'count-lines-page)
547(define-key ctl-x-map "np" 'narrow-to-page)
548;; (define-key ctl-x-map "p" 'narrow-to-page)
549\f
550(define-key ctl-x-map "al" 'add-mode-abbrev)
551(define-key ctl-x-map "a\C-a" 'add-mode-abbrev)
552(define-key ctl-x-map "ag" 'add-global-abbrev)
553(define-key ctl-x-map "a+" 'add-mode-abbrev)
554(define-key ctl-x-map "aig" 'inverse-add-global-abbrev)
555(define-key ctl-x-map "ail" 'inverse-add-mode-abbrev)
556;; (define-key ctl-x-map "a\C-h" 'inverse-add-global-abbrev)
557(define-key ctl-x-map "a-" 'inverse-add-global-abbrev)
558(define-key ctl-x-map "ae" 'expand-abbrev)
559(define-key ctl-x-map "a'" 'expand-abbrev)
560;; (define-key ctl-x-map "\C-a" 'add-mode-abbrev)
561;; (define-key ctl-x-map "\+" 'add-global-abbrev)
562;; (define-key ctl-x-map "\C-h" 'inverse-add-mode-abbrev)
563;; (define-key ctl-x-map "\-" 'inverse-add-global-abbrev)
564(define-key esc-map "'" 'abbrev-prefix-mark)
565(define-key ctl-x-map "'" 'expand-abbrev)
566
567;;; Don't compile this file; it contains no large function definitions.
568;;; Don't look for autoload cookies in this file.
569;;; Local Variables:
570;;; no-byte-compile: t
571;;; no-update-autoloads: t
572;;; End:
573
574;;; bindings.el ends here