0
|
1 ;; Define standard keybindings.
|
|
2 ;; Copyright (C) 1992, 1993, 1994 Free Software Foundation, Inc.
|
|
3
|
|
4 ;; This file is part of XEmacs.
|
|
5
|
|
6 ;; XEmacs is free software; you can redistribute it and/or modify it
|
|
7 ;; under the terms of the GNU General Public License as published by
|
|
8 ;; the Free Software Foundation; either version 2, or (at your option)
|
|
9 ;; any later version.
|
|
10
|
|
11 ;; XEmacs is distributed in the hope that it will be useful, but
|
|
12 ;; WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
13 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
14 ;; General Public License for more details.
|
|
15
|
|
16 ;; You should have received a copy of the GNU General Public License
|
16
|
17 ;; along with XEmacs; see the file COPYING. If not, write to the
|
70
|
18 ;; Free Software Foundation, 59 Temple Place - Suite 330,
|
16
|
19 ;; Boston, MA 02111-1307, USA.
|
0
|
20
|
|
21 ;; All the global bindings should be here so that one can reload things
|
|
22 ;; like files.el without trashing one's personal bindings.
|
|
23
|
|
24 ;;; Synched up with: Not synched with FSF.
|
|
25
|
74
|
26 ;;; Commentary:
|
|
27
|
|
28 ;;; Code:
|
|
29
|
0
|
30 ;; created by C code
|
|
31 (defvar global-map (current-global-map) "\
|
|
32 Default global keymap mapping XEmacs keyboard input into commands.
|
|
33 The value is a keymap which is usually (but not necessarily) XEmacs's
|
|
34 global map.")
|
|
35
|
|
36 ;; created by C code
|
|
37 (defvar esc-map (symbol-function 'ESC-prefix) "\
|
|
38 Default keymap for ESC (meta) commands.
|
|
39 The normal global definition of the character ESC indirects to this keymap.")
|
|
40
|
|
41 (set-keymap-name global-map 'global-map)
|
|
42 (set-keymap-name esc-map 'ESC-prefix)
|
|
43
|
|
44 (define-prefix-command 'Control-X-prefix t)
|
|
45 (defvar ctl-x-map (symbol-function 'Control-X-prefix) "\
|
|
46 Default keymap for C-x commands.
|
|
47 The normal global definition of the character C-x indirects to this keymap.")
|
|
48 (define-key global-map "\C-x" 'Control-X-prefix)
|
|
49
|
|
50 (define-prefix-command 'ctl-x-4-prefix t)
|
|
51 (defvar ctl-x-4-map (symbol-function 'ctl-x-4-prefix) "\
|
|
52 Keymap for subcommands of C-x 4")
|
|
53 (define-key global-map "\C-x4" 'ctl-x-4-prefix)
|
|
54
|
|
55 (define-prefix-command 'ctl-x-5-prefix t)
|
|
56 (defvar ctl-x-5-map (symbol-function 'ctl-x-5-prefix) "\
|
|
57 Keymap for subcommands of C-x 5")
|
|
58 (define-key global-map "\C-x5" 'ctl-x-5-prefix)
|
|
59
|
|
60 (define-prefix-command 'mode-specific-command-prefix t)
|
|
61 (defvar mode-specific-map (symbol-function 'mode-specific-command-prefix) "\
|
|
62 Keymap for characters following C-c.")
|
|
63 (define-key global-map "\C-c" 'mode-specific-command-prefix)
|
|
64
|
|
65 ;; FSFmacs buffer.c
|
|
66
|
|
67 (define-key global-map "\C-xb" 'switch-to-buffer)
|
|
68 (define-key global-map "\C-xk" 'kill-buffer)
|
|
69 (define-key global-map "\C-x\C-b" 'list-buffers)
|
|
70 (put 'erase-buffer 'disabled t) ;from buffer.c
|
|
71
|
|
72 ;; FSFmacs casefiddle.c
|
|
73
|
|
74 (define-key global-map "\C-x\C-u" 'upcase-region)
|
104
|
75 ;; This is silly with zmacs regions
|
|
76 ;(put 'upcase-region 'disabled t)
|
0
|
77 (define-key global-map "\C-x\C-l" 'downcase-region)
|
104
|
78 ;; This is silly with zmacs regions
|
|
79 ;(put 'downcase-region 'disabled t)
|
0
|
80 (define-key global-map "\M-u" 'upcase-region-or-word)
|
|
81 (define-key global-map "\M-l" 'downcase-region-or-word)
|
|
82 (define-key global-map "\M-c" 'capitalize-region-or-word)
|
|
83
|
|
84 ;; FSFmacs cmds.c
|
|
85
|
|
86 (let ((n 33))
|
|
87 (while (<= n 255)
|
|
88 (if (not (= n 127))
|
|
89 (define-key global-map n 'self-insert-command))
|
|
90 (setq n (1+ n))))
|
|
91 (define-key global-map " " 'self-insert-command)
|
|
92
|
|
93 (define-key global-map "\C-a" 'beginning-of-line)
|
|
94 (define-key global-map "\C-b" 'backward-char)
|
|
95 (define-key global-map "\C-e" 'end-of-line)
|
|
96 (define-key global-map "\C-f" 'forward-char)
|
|
97 (define-key global-map "\C-d" 'delete-char)
|
|
98 (define-key global-map "\177" 'delete-backward-char)
|
|
99
|
|
100 ;; FSFmacs files.el
|
|
101
|
|
102 (define-key global-map "\C-x\C-f" 'find-file)
|
|
103 (define-key global-map "\C-x\C-q" 'toggle-read-only)
|
|
104 (define-key global-map "\C-x\C-r" 'find-file-read-only)
|
|
105 (define-key global-map "\C-x\C-v" 'find-alternate-file)
|
|
106 (define-key global-map "\C-x\C-s" 'save-buffer)
|
|
107 (define-key global-map "\C-xs" 'save-some-buffers)
|
|
108 (define-key global-map "\C-x\C-w" 'write-file)
|
|
109 (define-key global-map "\C-xi" 'insert-file)
|
|
110 (define-key global-map "\M-~" 'not-modified)
|
|
111 (define-key global-map "\C-x\C-d" 'list-directory)
|
|
112 (define-key global-map "\C-x\C-c" 'save-buffers-kill-emacs)
|
|
113
|
|
114 (define-key global-map "\C-x4f" 'find-file-other-window)
|
|
115 (define-key global-map "\C-x4r" 'find-file-read-only-other-window)
|
|
116 (define-key global-map "\C-x4\C-f" 'find-file-other-window)
|
|
117 (define-key global-map "\C-x4b" 'switch-to-buffer-other-window)
|
|
118 (define-key global-map "\C-x4\C-o" 'display-buffer)
|
|
119
|
|
120 (define-key global-map "\C-x5b" 'switch-to-buffer-other-frame)
|
|
121 (define-key global-map "\C-x5f" 'find-file-other-frame)
|
|
122 (define-key global-map "\C-x5\C-f" 'find-file-other-frame)
|
|
123 (define-key global-map "\C-x5r" 'find-file-read-only-other-frame)
|
|
124
|
|
125 ;; FSFmacs frame.c
|
|
126 ;FSFmacs has these. It's probably a good idea to provide ways of hooking
|
|
127 ;these events, but it's unlikely that it's a good idea to do it this way.
|
|
128 ;Just provide a hook, like the existing `select-frame-hook',
|
|
129 ;`deselect-frame-hook', `map-frame-hook', and `unmap-frame-hook'.
|
|
130 ;#### ergo need hooks for delete-frame and iconify-frame
|
|
131 ;(define-key global-map 'switch-frame 'handle-switch-frame)
|
|
132 ;(define-key global-map 'delete-frame 'handle-delete-frame)
|
|
133 ;(define-key global-map 'iconify-frame 'ignore-event)
|
|
134 ;(define-key global-map 'make-frame-visible 'ignore-event)
|
|
135
|
|
136 ;; FSFmacs frame.el
|
|
137
|
|
138 ;; New FSF19 bindings: C-x 5 as prefix for window commands
|
|
139 (define-key global-map "\C-x52" 'make-frame)
|
|
140 (define-key global-map "\C-x50" 'delete-frame)
|
|
141 (define-key global-map "\C-x5o" 'other-frame)
|
|
142 ;; XEmacs addition:
|
70
|
143 (define-key global-map "\C-x5m" 'mail-other-frame)
|
0
|
144
|
|
145 ;; FSFmacs help.el
|
|
146
|
98
|
147 (define-key global-map (vector help-char) 'help-command)
|
0
|
148 (define-key global-map 'help 'help-command)
|
|
149 (define-key global-map 'f1 'help-command)
|
|
150
|
|
151 ;; FSFmacs indent.el
|
|
152
|
|
153 ;;(define-key global-map "\t" 'self-insert-command)
|
|
154 (define-key global-map "\t" 'indent-for-tab-command)
|
|
155 (define-key global-map "\M-\C-\\" 'indent-region)
|
|
156 (define-key global-map "\C-x\t" 'indent-rigidly)
|
|
157 (define-key global-map "\M-i" 'tab-to-tab-stop)
|
|
158 ;; XEmacs addition:
|
|
159 (define-key global-map [(shift tab)] 'tab-to-tab-stop)
|
|
160
|
|
161 ;; FSFmacs isearch.el
|
|
162
|
|
163 (define-key global-map "\C-s" 'isearch-forward)
|
|
164 (define-key global-map "\C-r" 'isearch-backward)
|
|
165 (define-key global-map "\M-\C-s" 'isearch-forward-regexp)
|
|
166 (define-key global-map "\M-\C-r" 'isearch-backward-regexp)
|
|
167
|
|
168 ;; FSFmacs keyboard.c
|
|
169
|
136
|
170 (define-key global-map "\C-z" 'suspend-emacs-or-iconify-frame)
|
0
|
171 (define-key global-map "\C-x\C-z" 'suspend-or-iconify-emacs)
|
|
172
|
|
173 ;; FSFmacs loaddefs.el
|
|
174
|
|
175 ;; New FSF19 bindings: C-x n as a prefix for narrowing commands.
|
|
176 (define-key global-map "\C-xn" (let ((map (make-sparse-keymap)))
|
|
177 (set-keymap-name map 'narrowing-prefix)
|
|
178 map))
|
|
179 (put 'narrow-to-region 'disabled t)
|
|
180 (define-key global-map "\C-xnn" 'narrow-to-region)
|
|
181 (define-key global-map "\C-xnw" 'widen)
|
|
182 ;; Old v18 bindings
|
|
183 ;(define-key global-map "\C-xn" 'narrow-to-region)
|
|
184 ;(define-key global-map "\C-xw" 'widen)
|
|
185
|
|
186 (define-key global-map "\C-j" 'newline-and-indent)
|
|
187 (define-key global-map "\C-m" 'newline)
|
|
188 (define-key global-map "\C-o" 'open-line)
|
|
189 (define-key global-map "\M-\C-o" 'split-line)
|
|
190 (define-key global-map "\C-q" 'quoted-insert)
|
|
191 (define-key global-map "\M-^" 'delete-indentation)
|
|
192 (define-key global-map "\M-\\" 'delete-horizontal-space)
|
|
193 (define-key global-map "\M-m" 'back-to-indentation)
|
|
194 (define-key global-map "\C-x\C-o" 'delete-blank-lines)
|
|
195 (define-key global-map "\M- " 'just-one-space)
|
|
196 (define-key global-map "\M-z" 'zap-to-char)
|
|
197 (define-key global-map "\M-=" 'count-lines-region)
|
|
198 (define-key global-map "\C-x=" 'what-cursor-position)
|
|
199 (define-key global-map "\M-:" 'eval-expression)
|
|
200 ;; Define ESC ESC : like ESC : for people who type ESC ESC out of habit.
|
|
201 (define-key global-map "\M-\e:" 'eval-expression)
|
|
202 ;(define-key global-map "\M-\e" 'eval-expression)
|
104
|
203 ;; Do we really need to disable this now that it is harder to type
|
|
204 ;; by accident?
|
|
205 ;; (put 'eval-expression 'disabled t)
|
0
|
206 ;; Changed from C-x ESC so that function keys work following C-x.
|
|
207 (define-key global-map "\C-x\e\e" 'repeat-complex-command)
|
|
208 ;(define-key global-map "\C-x\e" 'repeat-complex-command)
|
|
209 (define-key global-map "\C-xu" 'advertised-undo)
|
|
210 ;; Many people are used to typing C-/ on X terminals and getting C-_.
|
|
211 (define-key global-map '(control /) 'undo)
|
|
212 (define-key global-map "\C-_" 'undo)
|
|
213 (define-key global-map "\M-!" 'shell-command)
|
|
214 (define-key global-map "\M-|" 'shell-command-on-region)
|
|
215
|
|
216 (define-key global-map "\C-u" 'universal-argument)
|
|
217 ;; Make Control-0 - Control-9 set the prefix argument, like Meta-0.
|
|
218 (let ((i ?0))
|
|
219 (while (<= i ?9)
|
|
220 (define-key global-map (list 'meta i) 'digit-argument)
|
|
221 (define-key global-map (list 'control i) 'digit-argument)
|
|
222 (define-key global-map (list 'control 'meta i) 'digit-argument)
|
|
223 (setq i (1+ i))))
|
|
224 (define-key global-map '(meta -) 'negative-argument)
|
|
225 (define-key global-map '(control -) 'negative-argument)
|
|
226 (define-key global-map '(control meta -) 'negative-argument)
|
|
227
|
|
228 (define-key global-map "\C-k" 'kill-line)
|
|
229 (define-key global-map "\C-w" 'kill-region)
|
|
230 (define-key global-map "\M-w" 'kill-ring-save)
|
|
231 (define-key global-map "\M-\C-w" 'append-next-kill)
|
|
232 (define-key global-map "\C-y" 'yank)
|
|
233 (define-key global-map "\M-y" 'yank-pop)
|
|
234
|
|
235 ;; Old v18 binding
|
|
236 ;(define-key global-map "\C-xa" 'append-to-buffer)
|
|
237
|
|
238 (define-key global-map "\C-@" 'set-mark-command)
|
|
239 ;; Many people are used to typing C-SPC and getting C-@.
|
|
240 (define-key global-map '(control ? ) 'set-mark-command)
|
|
241 (define-key global-map "\C-x\C-x" 'exchange-point-and-mark)
|
|
242 (define-key global-map "\C-x\C-@" 'pop-global-mark)
|
|
243 (define-key global-map [(control x) (control ? )] 'pop-global-mark)
|
|
244
|
|
245 (define-key global-map "\C-n" 'next-line)
|
|
246 (define-key global-map "\C-p" 'previous-line)
|
104
|
247 ;(define-key global-map "\C-x\C-n" 'set-goal-column)
|
0
|
248 ;; XEmacs:
|
|
249 ;;; Many people have said they rarely use this feature, and often type
|
|
250 ;;; it by accident. Maybe it shouldn't even be on a key.
|
104
|
251 ;;; Done. -hniksic
|
|
252 ;(put 'set-goal-column 'disabled t)
|
0
|
253
|
|
254 (define-key global-map [menu] 'execute-extended-command)
|
|
255 (define-key global-map [find] 'search-forward)
|
|
256
|
|
257 (define-key global-map "\C-t" 'transpose-chars)
|
|
258 (define-key global-map "\M-t" 'transpose-words)
|
|
259 (define-key global-map "\M-\C-t" 'transpose-sexps)
|
|
260 (define-key global-map "\C-x\C-t" 'transpose-lines)
|
|
261
|
|
262 (define-key global-map "\M-;" 'indent-for-comment)
|
|
263 (define-key global-map "\M-j" 'indent-new-comment-line)
|
|
264 (define-key global-map "\M-\C-j" 'indent-new-comment-line)
|
|
265 (define-key global-map "\C-x;" 'set-comment-column)
|
|
266 (define-key global-map "\C-xf" 'set-fill-column)
|
|
267 (define-key global-map "\C-x$" 'set-selective-display)
|
|
268
|
|
269 (define-key global-map "\M-@" 'mark-word)
|
|
270 (define-key global-map "\M-f" 'forward-word)
|
|
271 (define-key global-map "\M-b" 'backward-word)
|
|
272 (define-key global-map "\M-d" 'kill-word)
|
|
273 (define-key global-map "\M-\177" 'backward-kill-word)
|
|
274
|
|
275 (define-key global-map "\M-<" 'beginning-of-buffer)
|
|
276 (define-key global-map "\M->" 'end-of-buffer)
|
|
277 (define-key global-map "\C-xh" 'mark-whole-buffer)
|
|
278 (define-key global-map "\M-\\" 'delete-horizontal-space)
|
|
279
|
|
280 (define-key global-map "\M-\C-f" 'forward-sexp)
|
|
281 (define-key global-map "\M-\C-b" 'backward-sexp)
|
|
282 (define-key global-map "\M-\C-u" 'backward-up-list)
|
|
283 (define-key global-map "\M-\C-@" 'mark-sexp)
|
|
284 (define-key global-map "\M-\C-d" 'down-list)
|
|
285 (define-key global-map "\M-\C-k" 'kill-sexp)
|
|
286 (define-key global-map "\M-\C-n" 'forward-list)
|
|
287 (define-key global-map "\M-\C-p" 'backward-list)
|
|
288 (define-key global-map "\M-\C-a" 'beginning-of-defun)
|
|
289 (define-key global-map "\M-\C-e" 'end-of-defun)
|
|
290 (define-key global-map "\M-\C-h" 'mark-defun)
|
|
291 (define-key global-map "\M-\(" 'insert-parentheses)
|
|
292 (define-key global-map "\M-\)" 'move-past-close-and-reindent)
|
|
293 (define-key global-map "\M-\t" 'lisp-complete-symbol)
|
|
294
|
|
295 (define-key global-map '(control meta delete) 'backward-kill-sexp)
|
|
296
|
|
297
|
|
298 (define-key global-map "\C-x/" 'point-to-register)
|
|
299 (define-key global-map "\C-xj" 'jump-to-register)
|
|
300 (define-key global-map "\C-xx" 'copy-to-register)
|
|
301 (define-key global-map "\C-xg" 'insert-register)
|
|
302 ;; Old v18 binding
|
|
303 ;(define-key global-map "\C-xr" 'copy-rectangle-to-register)
|
|
304
|
|
305 ;; New FSF19 bindings: C-x r as a prefix for register commands
|
|
306 (define-key global-map "\C-xr" (let ((map (make-sparse-keymap)))
|
|
307 (set-keymap-name map 'rectangle-prefix)
|
|
308 map))
|
|
309 (define-key global-map "\C-xr\C-@" 'point-to-register)
|
|
310 (define-key global-map "\C-xr " 'point-to-register)
|
|
311 (define-key global-map "\C-xrj" 'jump-to-register)
|
|
312 (define-key global-map "\C-xrs" 'copy-to-register)
|
|
313 (define-key global-map "\C-xrx" 'copy-to-register)
|
|
314 (define-key global-map "\C-xri" 'insert-register)
|
|
315 (define-key global-map "\C-xrg" 'insert-register)
|
|
316 (define-key global-map "\C-xrr" 'copy-rectangle-to-register)
|
|
317 (define-key global-map "\C-xrc" 'clear-rectangle)
|
|
318 (define-key global-map "\C-xrk" 'kill-rectangle)
|
|
319 (define-key global-map "\C-xry" 'yank-rectangle)
|
|
320 (define-key global-map "\C-xro" 'open-rectangle)
|
|
321 (define-key global-map "\C-xrt" 'string-rectangle)
|
|
322 (define-key global-map "\C-xrw" 'window-configuration-to-register)
|
|
323 ;(define-key global-map "\C-xrf" 'frame-configuration-to-register)
|
|
324
|
|
325 (define-key global-map "\M-q" 'fill-paragraph-or-region)
|
|
326 ;(define-key global-map "\M-q" 'fill-paragraph)
|
|
327 ;(define-key global-map "\M-g" 'fill-region) ;now bound to goto-line
|
|
328 (define-key global-map "\C-x." 'set-fill-prefix)
|
|
329
|
|
330 ; Using {} instead of [] is 1) FSF compatible and 2) allows function
|
|
331 ; keys to work on ttys. M-[ is the beginning of most the function key
|
|
332 ; sequences.
|
|
333 (define-key global-map "\M-{" 'backward-paragraph)
|
|
334 (define-key global-map "\M-}" 'forward-paragraph)
|
|
335 (define-key global-map "\M-h" 'mark-paragraph)
|
|
336 (define-key global-map "\M-a" 'backward-sentence)
|
|
337 (define-key global-map "\M-e" 'forward-sentence)
|
|
338 (define-key global-map "\M-k" 'kill-sentence)
|
|
339 (define-key global-map "\C-x\177" 'backward-kill-sentence)
|
|
340
|
|
341 (define-key global-map "\C-x[" 'backward-page)
|
|
342 (define-key global-map "\C-x]" 'forward-page)
|
|
343 (define-key global-map "\C-x\C-p" 'mark-page)
|
|
344 (define-key global-map "\C-xl" 'count-lines-page)
|
|
345 (define-key global-map "\C-xnp" 'narrow-to-page)
|
|
346 ;; Old v18 bindings
|
|
347 ;(define-key global-map "\C-xp" 'narrow-to-page)
|
|
348 (put 'narrow-to-page 'disabled t)
|
|
349
|
|
350 ;; Old v18 bindings
|
|
351 ;(define-key global-map "\C-x\C-a" 'add-mode-abbrev)
|
|
352 ;(define-key global-map "\C-x+" 'add-global-abbrev)
|
|
353 ;(define-key global-map "\C-x\C-h" 'inverse-add-mode-abbrev)
|
|
354 ;(define-key global-map "\C-x-" 'inverse-add-global-abbrev)
|
|
355
|
|
356 (define-key global-map "\M-'" 'abbrev-prefix-mark)
|
|
357 (define-key global-map "\C-x'" 'expand-abbrev)
|
|
358
|
|
359 ;; New FSF19 bindings: C-x a as a prefix for abbrev commands
|
|
360 (define-key global-map "\C-xal" 'add-mode-abbrev)
|
|
361 (define-key global-map "\C-xa\C-a" 'add-mode-abbrev)
|
|
362 (define-key global-map "\C-xag" 'add-global-abbrev)
|
|
363 (define-key global-map "\C-xa+" 'add-mode-abbrev)
|
|
364 (define-key global-map "\C-xaig" 'inverse-add-global-abbrev)
|
|
365 (define-key global-map "\C-xail" 'inverse-add-mode-abbrev)
|
|
366 (define-key global-map "\C-xa-" 'inverse-add-global-abbrev)
|
|
367 (define-key global-map "\C-xae" 'expand-abbrev)
|
|
368 (define-key global-map "\C-xa'" 'expand-abbrev)
|
|
369
|
|
370 (define-key global-map "\M-\C-l" 'switch-to-other-buffer)
|
|
371
|
|
372 ;; Default binding of "Backspace" is the same as delete.
|
|
373 ;; Default binding of "Control-h" is help.
|
|
374 (define-key global-map 'backspace '[delete])
|
|
375 (define-key global-map '(meta backspace) '[(meta delete)])
|
|
376 (define-key global-map '(control backspace) '[(control delete)])
|
|
377 (define-key global-map '(control meta backspace) '[(control meta delete)])
|
|
378
|
|
379 (define-key global-map "\M-\C-z" 'activate-region)
|
|
380
|
|
381 ;; FSFmacs macros.c
|
|
382
|
|
383 (define-key global-map "\C-xe" 'call-last-kbd-macro)
|
|
384 (define-key global-map "\C-x\(" 'start-kbd-macro)
|
|
385 (define-key global-map "\C-x\)" 'end-kbd-macro)
|
|
386
|
|
387 ;; FSFmacs macros.el
|
|
388
|
|
389 (define-key global-map "\C-xq" 'kbd-macro-query)
|
|
390
|
|
391
|
|
392 ;; FSFmacs minibuffer.c
|
|
393 ; see also minibuf.el
|
|
394
|
|
395 (define-key global-map "\M-\C-c" 'exit-recursive-edit)
|
|
396 (define-key global-map "\C-]" 'abort-recursive-edit)
|
|
397 (define-key global-map "\M-x" 'execute-extended-command)
|
|
398
|
|
399 ;; FSFmacs window.c
|
|
400
|
|
401 (define-key global-map "\C-x0" 'delete-window)
|
|
402 (define-key global-map "\C-x1" 'delete-other-windows)
|
|
403 (define-key global-map "\C-x2" 'split-window-vertically)
|
|
404 (define-key global-map "\C-x3" 'split-window-horizontally)
|
|
405 ;; Old XEmacs binding
|
|
406 ;;(define-key global-map "\C-x5" 'split-window-horizontally)
|
|
407 (define-key global-map "\C-xo" 'other-window)
|
|
408 (define-key global-map "\C-x^" 'enlarge-window)
|
|
409 (define-key global-map "\C-x<" 'scroll-left)
|
|
410 (define-key global-map "\C-x>" 'scroll-right)
|
|
411
|
|
412 (define-key global-map "\C-v" 'scroll-up)
|
|
413 (define-key global-map "\M-v" 'scroll-down)
|
|
414 (define-key global-map "\M-\C-v" 'scroll-other-window)
|
|
415 ; meta-shift-V, that is.
|
|
416 (define-key global-map '(meta V) 'scroll-other-window-down)
|
|
417
|
|
418 (define-key global-map "\C-l" 'recenter)
|
|
419 (define-key global-map "\M-r" 'move-to-window-line)
|
|
420
|
|
421 ;; FSFmacs window.el
|
|
422
|
|
423 (define-key global-map "\C-x6" 'window-configuration-to-register)
|
|
424 ;(define-key global-map "\C-x7" 'jump-to-register);ie register-to-window-config
|
|
425 (define-key global-map "\C-x}" 'enlarge-window-horizontally)
|
|
426 (define-key global-map "\C-x{" 'shrink-window-horizontally)
|
|
427 ;; New FSF19 bindings
|
|
428 (define-key global-map "\C-x-" 'shrink-window-if-larger-than-buffer)
|
|
429 (define-key global-map "\C-x+" 'balance-windows)
|
|
430
|
|
431
|
|
432 ;;(define-key global-map "\C-g" 'keyboard-quit)
|
|
433 (let ((ch (quit-char)))
|
|
434 (if (or (characterp ch) (integerp ch))
|
|
435 (setq ch (char-to-string ch)))
|
|
436 (define-key global-map ch 'keyboard-quit))
|
|
437 (define-key global-map "\e\e\e" 'keyboard-escape-quit)
|
|
438
|
|
439
|
|
440
|
|
441
|
|
442
|
|
443
|
|
444 (define-key global-map "\M-%" 'query-replace)
|
|
445
|
|
446
|
|
447 ; autoloaded
|
|
448 ;(define-key global-map "\C-x4a" 'add-change-log-entry-other-window)
|
|
449
|
|
450 ; autoloaded
|
|
451 ;(define-key global-map "\C-x`" 'next-error)
|
|
452
|
|
453 ; autoloaded
|
|
454 ;(define-key global-map "\M-/" 'dabbrev-expand)
|
|
455
|
|
456 ; autoloaded
|
|
457 ;(define-key global-map "\C-xd" 'dired)
|
|
458
|
|
459 ; autoloaded
|
|
460 ;(define-key global-map "\C-x4d" 'dired-other-window)
|
|
461
|
|
462 (define-key global-map "\M-$" 'ispell-word)
|
|
463
|
|
464 (define-key global-map "\C-x4m" 'mail-other-window)
|
|
465
|
|
466 (define-key global-map "\C-xm" 'mail)
|
|
467
|
|
468 (define-key global-map "\M-." 'find-tag)
|
|
469
|
|
470 (define-key global-map "\C-x4." 'find-tag-other-window)
|
|
471
|
|
472 (define-key global-map "\M-," 'tags-loop-continue)
|
|
473
|
|
474
|
|
475 (define-key global-map '(control <) 'mark-beginning-of-buffer)
|
|
476 (define-key global-map '(control >) 'mark-end-of-buffer)
|
|
477
|
|
478 (define-key global-map "\C-x\C-e" 'eval-last-sexp) ;bogus!
|
|
479
|
|
480
|
|
481 (define-key global-map "\M-g" 'goto-line)
|
|
482
|
|
483 ;; Keypad type things
|
|
484
|
|
485 ;; I removed all the fkey crap, because where-is is now smart enough
|
|
486 ;; to show all bindings. --ben
|
|
487
|
|
488 ;;; These aren't bound to kbd macros like "\C-b" so that they have the
|
|
489 ;; expected behavior even in, for example, vi-mode.
|
|
490
|
|
491 ;; We use here symbolic names, assuming that the corresponding keys will
|
|
492 ;; generate these keysyms. This is not true on Suns, but x-win-sun.el
|
|
493 ;; fixes that. If it turns out that the semantics of these keys should
|
|
494 ;; differ from server to server, this should be moved into server-specific
|
|
495 ;; files, but these appear to be the standard Motif and PC bindings.
|
|
496
|
|
497 ;; movement by units
|
|
498 (define-key global-map 'left 'backward-char)
|
|
499 (define-key global-map 'up 'previous-line)
|
|
500 (define-key global-map 'right 'forward-char)
|
|
501 (define-key global-map 'down 'next-line)
|
|
502
|
|
503 ;; movement by pages
|
|
504 (define-key global-map 'prior 'scroll-down)
|
|
505 (define-key global-map 'next 'scroll-up)
|
|
506
|
|
507 ;; movement to the limits
|
|
508 (define-key global-map 'home 'beginning-of-line)
|
|
509 (define-key global-map 'end 'end-of-line)
|
|
510
|
|
511 ;;; Miscellaneous key bindings
|
|
512 (define-key global-map 'again 'repeat-complex-command)
|
|
513 (define-key global-map 'insert 'overwrite-mode)
|
|
514
|
|
515 ;;; These aren't bound to kbd macros like "\C-b" so that they have the
|
|
516 ;; expected behavior even in, for example, vi-mode.
|
|
517
|
|
518 ;; We use here symbolic names, assuming that the corresponding keys will
|
|
519 ;; generate these keysyms. This is not true on Suns, but x-win-sun.el
|
|
520 ;; fixes that. If it turns out that the semantics of these keys should
|
|
521 ;; differ from server to server, this should be moved into server-specific
|
|
522 ;; files, but these appear to be the standard Motif and PC bindings.
|
|
523
|
|
524 ;; potential R6isms
|
74
|
525 (define-key global-map 'kp-left 'backward-char)
|
|
526 (define-key global-map 'kp-up 'previous-line)
|
|
527 (define-key global-map 'kp-right 'forward-char)
|
|
528 (define-key global-map 'kp-down 'next-line)
|
0
|
529
|
|
530
|
|
531 ;; movement by larger blocks
|
|
532 (define-key global-map '(control left) 'backward-word)
|
|
533 (define-key global-map '(control up) #'(lambda ()
|
|
534 (interactive "_")
|
|
535 (forward-line -6)))
|
|
536 (define-key global-map '(control right) 'forward-word)
|
|
537 (define-key global-map '(control down) #'(lambda ()
|
|
538 (interactive "_")
|
|
539 (forward-line 6)))
|
|
540
|
|
541 ;; context-sensitive movement
|
|
542 (define-key global-map '(meta left) 'backward-sexp)
|
|
543 (define-key global-map '(meta right) 'forward-sexp)
|
|
544 (define-key global-map '(meta up) 'backward-paragraph)
|
|
545 (define-key global-map '(meta down) 'forward-paragraph)
|
|
546
|
|
547 ;; movement by pages
|
|
548 (define-key global-map '(control prior) 'scroll-right)
|
|
549 (define-key global-map '(control next) 'scroll-left)
|
|
550 ;; potential R6isms
|
74
|
551 (define-key global-map 'kp-prior 'scroll-down)
|
|
552 (define-key global-map 'kp-next 'scroll-up)
|
|
553 (define-key global-map '(control kp-prior) 'scroll-right)
|
|
554 (define-key global-map '(control kp-next) 'scroll-left)
|
0
|
555
|
|
556
|
|
557 ;; movement to the limits
|
|
558 (define-key global-map '(control home) 'beginning-of-buffer)
|
|
559 (define-key global-map '(control end) 'end-of-buffer)
|
|
560 (define-key global-map 'begin 'beginning-of-line)
|
|
561 (define-key global-map '(control begin) 'beginning-of-buffer)
|
|
562 ;; potential R6isms
|
74
|
563 (define-key global-map 'kp-home 'beginning-of-line)
|
|
564 (define-key global-map '(control kp-home) 'beginning-of-buffer)
|
|
565 (define-key global-map 'kp-end 'end-of-line)
|
|
566 (define-key global-map '(control kp-end) 'end-of-buffer)
|
0
|
567
|
|
568 ;; movement between windows
|
|
569 (define-key global-map '(control tab) 'other-window)
|
|
570 (define-key global-map '(control shift tab) 'backward-other-window)
|
|
571
|
|
572 ;; movement in other windows
|
|
573 (define-key global-map '(meta next) 'scroll-other-window)
|
|
574 (define-key global-map '(meta prior) 'scroll-other-window-down)
|
|
575 (define-key global-map '(meta home) 'beginning-of-buffer-other-window)
|
|
576 (define-key global-map '(meta end) 'end-of-buffer-other-window)
|
|
577 ;; potential R6isms
|
74
|
578 (define-key global-map '(meta kp-next) 'scroll-other-window)
|
|
579 (define-key global-map '(meta kp-prior) 'scroll-other-window-down)
|
|
580 (define-key global-map '(meta kp-home) 'beginning-of-buffer-other-window)
|
|
581 (define-key global-map '(meta kp-end) 'end-of-buffer-other-window)
|
0
|
582
|
|
583 ;; potential R6isms
|
|
584 (define-key global-map 'redo 'repeat-complex-command)
|
74
|
585 (define-key global-map 'kp-insert 'overwrite-mode)
|
|
586 (define-key global-map 'kp-delete 'backward-delete-char-untabify)
|
0
|
587
|
74
|
588 (define-key global-map 'kp-enter [return]) ; do whatever RET does now
|
|
589 (define-key global-map 'kp-tab [tab])
|
0
|
590
|
|
591 (define-key global-map 'undo 'undo)
|
|
592 (define-key global-map 'help 'help-for-help)
|
|
593
|
74
|
594 (define-key global-map 'kp-space 'self-insert-command)
|
|
595 (define-key global-map 'kp-equal 'self-insert-command)
|
|
596 (define-key global-map 'kp-multiply 'self-insert-command)
|
|
597 (define-key global-map 'kp-add 'self-insert-command)
|
|
598 (define-key global-map 'kp-separator 'self-insert-command)
|
|
599 (define-key global-map 'kp-subtract 'self-insert-command)
|
|
600 (define-key global-map 'kp-decimal 'self-insert-command)
|
|
601 (define-key global-map 'kp-divide 'self-insert-command)
|
0
|
602
|
74
|
603 (define-key global-map 'kp-0 'self-insert-command)
|
|
604 (define-key global-map 'kp-1 'self-insert-command)
|
|
605 (define-key global-map 'kp-2 'self-insert-command)
|
|
606 (define-key global-map 'kp-3 'self-insert-command)
|
|
607 (define-key global-map 'kp-4 'self-insert-command)
|
|
608 (define-key global-map 'kp-5 'self-insert-command)
|
|
609 (define-key global-map 'kp-6 'self-insert-command)
|
|
610 (define-key global-map 'kp-7 'self-insert-command)
|
|
611 (define-key global-map 'kp-8 'self-insert-command)
|
|
612 (define-key global-map 'kp-9 'self-insert-command)
|
0
|
613
|
|
614 (define-key global-map 'select 'function-key-error)
|
|
615 (define-key global-map 'print 'function-key-error)
|
|
616 (define-key global-map 'execute 'execute-extended-command)
|
|
617 (define-key global-map 'clearline 'function-key-error)
|
|
618 (define-key global-map 'insertline 'open-line)
|
|
619 (define-key global-map 'deleteline 'kill-line)
|
|
620 (define-key global-map 'insertchar 'function-key-error)
|
|
621 (define-key global-map 'deletechar 'delete-char)
|
74
|
622
|
|
623 ;;; keydefs.el ends here
|