Commit | Line | Data |
---|---|---|
1cd7adc6 | 1 | ;;; bindings.el --- define standard key bindings and some variables |
4d120e8c | 2 | |
9d4850e5 | 3 | ;; Copyright (C) 1985,86,87,92,93,94,95,96,99,2000, 2001 |
9ff33afb | 4 | ;; Free Software Foundation, Inc. |
4d120e8c RS |
5 | |
6 | ;; Maintainer: FSF | |
7 | ;; Keywords: internal | |
8 | ||
9 | ;; This file is part of GNU Emacs. | |
10 | ||
11 | ;; GNU Emacs is free software; you can redistribute it and/or modify | |
12 | ;; it under the terms of the GNU General Public License as published by | |
13 | ;; the Free Software Foundation; either version 2, or (at your option) | |
14 | ;; any later version. | |
15 | ||
16 | ;; GNU Emacs is distributed in the hope that it will be useful, | |
17 | ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
18 | ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
19 | ;; GNU General Public License for more details. | |
20 | ||
21 | ;; You should have received a copy of the GNU General Public License | |
22 | ;; along with GNU Emacs; see the file COPYING. If not, write to | |
23 | ;; the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
24 | ;; Boston, MA 02111-1307, USA. | |
25 | ||
26 | ;;; Commentary: | |
27 | ||
28 | ;;; !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | |
29 | ;;; Special formatting conventions are used in this file! | |
30 | ;;; | |
8a42b336 | 31 | ;;; A backslash-newline is used at the beginning of a documentation string |
4d120e8c RS |
32 | ;;; when that string should be stored in the file etc/DOCnnn, not in core. |
33 | ;;; | |
34 | ;;; Such strings read into Lisp as numbers (during the pure-loading phase). | |
35 | ;;; | |
36 | ;;; But you must obey certain rules to make sure the string is understood | |
688953b5 | 37 | ;;; and goes into etc/DOCnnn properly. |
4d120e8c RS |
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 | ||
1ebfdece GM |
50 | (defun make-mode-line-mouse-map (mouse function) "\ |
51 | Return a keymap with single entry for mouse key MOUSE on the mode line. | |
52 | MOUSE is defined to run function FUNCTION with no args in the buffer | |
dfdabcf9 DL |
53 | corresponding to the mode line clicked." |
54 | (let ((map (make-sparse-keymap))) | |
1ebfdece | 55 | (define-key map (vector 'mode-line mouse) function) |
dfdabcf9 DL |
56 | map)) |
57 | ||
e9580d71 GM |
58 | |
59 | (defun mode-line-toggle-read-only (event) | |
60 | "Like `toggle-read-only', for the mode-line." | |
61 | (interactive "e") | |
62 | (save-selected-window | |
63 | (select-window (posn-window (event-start event))) | |
64 | (toggle-read-only) | |
65 | (force-mode-line-update))) | |
66 | ||
67 | ||
68 | (defun mode-line-toggle-modified (event) | |
69 | "Toggle the buffer-modified flag from the mode-line." | |
24127af0 | 70 | (interactive "e") |
e9580d71 GM |
71 | (save-selected-window |
72 | (select-window (posn-window (event-start event))) | |
73 | (set-buffer-modified-p (not (buffer-modified-p))) | |
74 | (force-mode-line-update))) | |
75 | ||
76 | ||
77 | (defun mode-line-widen (event) | |
78 | "Widen a buffer from the mode-line." | |
24127af0 | 79 | (interactive "e") |
e9580d71 GM |
80 | (save-selected-window |
81 | (select-window (posn-window (event-start event))) | |
82 | (widen) | |
83 | (force-mode-line-update))) | |
84 | ||
85 | ||
86 | (defun mode-line-abbrev-mode (event) | |
87 | "Turn off `abbrev-mode' from the mode-line." | |
24127af0 | 88 | (interactive "e") |
e9580d71 GM |
89 | (save-selected-window |
90 | (select-window (posn-window (event-start event))) | |
91 | (abbrev-mode) | |
92 | (force-mode-line-update))) | |
93 | ||
94 | ||
95 | (defun mode-line-auto-fill-mode (event) | |
96 | "Turn off `auto-fill-mode' from the mode-line." | |
24127af0 | 97 | (interactive "e") |
e9580d71 GM |
98 | (save-selected-window |
99 | (select-window (posn-window (event-start event))) | |
100 | (auto-fill-mode) | |
101 | (force-mode-line-update))) | |
102 | ||
103 | ||
5e1cddda DL |
104 | (defvar mode-line-input-method-map |
105 | (let ((map (make-sparse-keymap))) | |
106 | (define-key map [mode-line mouse-2] | |
107 | (lambda (e) | |
108 | (interactive "e") | |
109 | (save-selected-window | |
110 | (select-window | |
111 | (posn-window (event-start e))) | |
112 | (toggle-input-method) | |
113 | (force-mode-line-update)))) | |
114 | (define-key map [mode-line mouse-3] | |
115 | (lambda (e) | |
116 | (interactive "e") | |
117 | (save-selected-window | |
118 | (select-window | |
119 | (posn-window (event-start e))) | |
120 | (describe-current-input-method)))) | |
121 | (purecopy map))) | |
122 | ||
f3185924 GM |
123 | |
124 | (defvar mode-line-coding-system-map | |
125 | (let ((map (make-sparse-keymap))) | |
126 | (define-key map [mode-line mouse-3] | |
127 | (lambda (e) | |
128 | (interactive "e") | |
129 | (save-selected-window | |
130 | (select-window (posn-window (event-start e))) | |
131 | (when (and enable-multibyte-characters | |
132 | buffer-file-coding-system) | |
133 | (describe-coding-system buffer-file-coding-system))))) | |
134 | (purecopy map)) | |
135 | "Local keymap for the coding-system part of the mode line.") | |
136 | ||
137 | ||
18a9f968 SM |
138 | (defun mode-line-change-eol () |
139 | "Cycle through the various possible kinds of end-of-line styles." | |
140 | (interactive) | |
141 | (let ((eol (coding-system-eol-type buffer-file-coding-system))) | |
142 | (set-buffer-file-coding-system | |
143 | (cond ((eq eol 0) 'dos) ((eq eol 1) 'mac) (t 'unix))))) | |
144 | ||
145 | (defvar mode-line-eol-desc-cache nil) | |
146 | ||
147 | (defun mode-line-eol-desc () | |
148 | (let* ((eol (coding-system-eol-type buffer-file-coding-system)) | |
149 | (mnemonic (coding-system-eol-type-mnemonic buffer-file-coding-system)) | |
150 | (desc (assq eol mode-line-eol-desc-cache))) | |
151 | (if (and desc (eq (cadr desc) mnemonic)) | |
152 | (cddr desc) | |
153 | (if desc (setq mode-line-eol-desc-cache nil)) ;Flush the cache if stale. | |
154 | (setq desc | |
155 | (propertize | |
156 | mnemonic | |
157 | 'help-echo (format "%s end-of-line; mouse-3 to cycle" | |
158 | (if (eq eol 0) "Unix-style LF" | |
159 | (if (eq eol 1) "Dos-style CRLF" | |
160 | (if (eq eol 2) "Mac-style CR" | |
161 | "Undecided")))) | |
162 | 'keymap | |
163 | (eval-when-compile | |
164 | (let ((map (make-sparse-keymap))) | |
165 | (define-key map [mode-line mouse-3] 'mode-line-change-eol) | |
166 | map)))) | |
167 | (push (cons eol (cons mnemonic desc)) mode-line-eol-desc-cache) | |
168 | desc))) | |
169 | ||
dfdabcf9 DL |
170 | (defvar mode-line-mule-info |
171 | `("" | |
9ff33afb | 172 | (current-input-method |
27451bb4 RS |
173 | (:propertize ("" current-input-method-title) |
174 | help-echo (concat | |
175 | "Input method: " | |
176 | current-input-method | |
177 | ". mouse-2: disable, mouse-3: describe") | |
178 | local-map ,mode-line-input-method-map)) | |
3beb81fc | 179 | ,(propertize |
18a9f968 | 180 | "%z" |
7ed93890 | 181 | 'help-echo |
7e98f74c RS |
182 | #'(lambda (window object point) |
183 | (with-current-buffer (window-buffer window) | |
184 | ;; Don't show this tip if the coding system is nil, | |
185 | ;; it reads like a bug, and is not useful anyway. | |
186 | (when buffer-file-coding-system | |
187 | (if enable-multibyte-characters | |
188 | (concat (symbol-name buffer-file-coding-system) | |
189 | " buffer; mouse-3: describe coding system") | |
190 | (concat "Unibyte " (symbol-name buffer-file-coding-system) | |
191 | " buffer"))))) | |
18a9f968 SM |
192 | 'local-map mode-line-coding-system-map) |
193 | (:eval (mode-line-eol-desc))) | |
44c034c1 KH |
194 | "Mode-line control for displaying information of multilingual environment. |
195 | Normally it displays current input method (if any activated) and | |
196 | mnemonics of the following coding systems: | |
197 | coding system for saving or writing the current buffer | |
198 | coding system for keyboard input (if Emacs is running on terminal) | |
ebc6753f | 199 | coding system for terminal output (if Emacs is running on terminal)" |
18a9f968 SM |
200 | ;; Currently not: |
201 | ;; coding system for decoding output of buffer process (if any) | |
202 | ;; coding system for encoding text to send to buffer process (if any)." | |
ebc6753f | 203 | ) |
f8bce5df KH |
204 | |
205 | (make-variable-buffer-local 'mode-line-mule-info) | |
206 | ||
688953b5 DL |
207 | (defvar mode-line-buffer-identification (purecopy '("%12b")) "\ |
208 | Mode-line control for identifying the buffer being displayed. | |
4544e9db | 209 | Its default value is (\"%12b\"). |
4d120e8c RS |
210 | Major modes that edit things other than ordinary files may change this |
211 | \(e.g. Info, Dired,...)") | |
212 | ||
213 | (make-variable-buffer-local 'mode-line-buffer-identification) | |
214 | ||
e6188964 RS |
215 | (defvar mode-line-frame-identification '("-%F ") |
216 | "Mode-line control to describe the current frame.") | |
4544e9db | 217 | |
688953b5 DL |
218 | (defvar mode-line-process nil "\ |
219 | Mode-line control for displaying info on process status. | |
4d120e8c RS |
220 | Normally nil in most modes, since there is no process to display.") |
221 | ||
222 | (make-variable-buffer-local 'mode-line-process) | |
223 | ||
dfdabcf9 DL |
224 | (defvar mode-line-modified |
225 | (list (propertize | |
3beb81fc DL |
226 | "%1*" |
227 | 'help-echo (purecopy (lambda (window object point) | |
1ebfdece | 228 | (format "%sead-only: mouse-3 toggles" |
3beb81fc DL |
229 | (save-selected-window |
230 | (select-window window) | |
231 | (if buffer-read-only | |
232 | "R" | |
233 | "Not r"))))) | |
1ebfdece GM |
234 | 'local-map (purecopy (make-mode-line-mouse-map |
235 | 'mouse-3 | |
24127af0 | 236 | #'mode-line-toggle-read-only))) |
3beb81fc DL |
237 | (propertize |
238 | "%1+" | |
239 | 'help-echo (purecopy (lambda (window object point) | |
1ebfdece | 240 | (format "%sodified: mouse-3 toggles" |
3beb81fc DL |
241 | (save-selected-window |
242 | (select-window window) | |
243 | (if (buffer-modified-p) | |
244 | "M" | |
245 | "Not m"))))) | |
1ebfdece GM |
246 | 'local-map (purecopy (make-mode-line-mouse-map |
247 | 'mouse-3 #'mode-line-toggle-modified)))) | |
4d120e8c RS |
248 | "Mode-line control for displaying whether current buffer is modified.") |
249 | ||
250 | (make-variable-buffer-local 'mode-line-modified) | |
251 | ||
e6188964 RS |
252 | ;; Actual initialization is below. |
253 | (defvar mode-line-position nil | |
254 | "Mode-line control for displaying line number, column number and fraction.") | |
255 | ||
256 | (defvar mode-line-modes nil | |
257 | "Mode-line control for displaying major and minor modes.") | |
258 | ||
8a42b336 JB |
259 | (defvar mode-line-major-mode-keymap nil "\ |
260 | Keymap to display on major mode.") | |
261 | ||
5b1d5e63 | 262 | (defvar mode-line-minor-mode-keymap nil "\ |
8a42b336 JB |
263 | Keymap to display on minor modes.") |
264 | ||
265 | (let ((map (make-sparse-keymap))) | |
266 | (define-key map [mode-line mouse-2] 'describe-mode) | |
267 | (setq mode-line-major-mode-keymap map)) | |
5b1d5e63 RS |
268 | |
269 | ;; Menu of minor modes. | |
270 | (let ((map (make-sparse-keymap))) | |
8a42b336 | 271 | (define-key map [mode-line mouse-2] 'mode-line-minor-mode-help) |
5b1d5e63 RS |
272 | (define-key map [mode-line down-mouse-3] 'mode-line-mode-menu-1) |
273 | (define-key map [header-line down-mouse-3] 'mode-line-mode-menu-1) | |
274 | (setq mode-line-minor-mode-keymap map)) | |
275 | ||
e6188964 RS |
276 | (let* ((help-echo |
277 | ;; The multi-line message doesn't work terribly well on the | |
278 | ;; bottom mode line... Better ideas? | |
d1bf2a73 SM |
279 | ;; "\ |
280 | ;; mouse-1: select window, mouse-2: delete others, mouse-3: delete, | |
281 | ;; drag-mouse-1: resize, C-mouse-2: split horizontally" | |
3fa9a7df | 282 | "mouse-1: select (drag to resize), mouse-2: delete others, mouse-3: delete this") |
d1bf2a73 | 283 | (dashes (propertize "--" 'help-echo help-echo))) |
e6188964 | 284 | (setq-default mode-line-format |
2b4b2add DL |
285 | (list |
286 | (propertize "-" 'help-echo help-echo) | |
287 | 'mode-line-mule-info | |
288 | 'mode-line-modified | |
289 | 'mode-line-frame-identification | |
290 | 'mode-line-buffer-identification | |
291 | (propertize " " 'help-echo help-echo) | |
4c347bc8 RS |
292 | 'mode-line-position |
293 | '(vc-mode vc-mode) | |
294 | (propertize " " 'help-echo help-echo) | |
e6188964 RS |
295 | 'mode-line-modes |
296 | `(which-func-mode ("" which-func-format ,dashes)) | |
2ef6aac8 | 297 | `(global-mode-string (,dashes global-mode-string)) |
e6188964 RS |
298 | (propertize "-%-" 'help-echo help-echo))) |
299 | ||
300 | (setq-default mode-line-modes | |
301 | (list | |
4c347bc8 | 302 | (propertize "%[(" 'help-echo help-echo) |
8a42b336 JB |
303 | `(:propertize ("" mode-name) |
304 | help-echo "mouse-2: help for current major mode" | |
305 | local-map ,mode-line-major-mode-keymap) | |
306 | `(:propertize ("" mode-line-process)) | |
307 | `(:propertize ("" minor-mode-alist) | |
308 | help-echo "mouse-2: help for minor modes, mouse-3: minor mode menu" | |
5b1d5e63 | 309 | local-map ,mode-line-minor-mode-keymap) |
2b4b2add | 310 | (propertize "%n" 'help-echo "mouse-2: widen" |
7ed93890 | 311 | 'local-map (make-mode-line-mouse-map |
1ebfdece | 312 | 'mouse-2 #'mode-line-widen)) |
e6188964 RS |
313 | (propertize ")%]--" 'help-echo help-echo))) |
314 | ||
545f7310 | 315 | (setq-default mode-line-position |
2ef6aac8 | 316 | `((-3 . ,(propertize "%p" 'help-echo help-echo)) |
23b1ffb1 | 317 | (line-number-mode |
2ef6aac8 KS |
318 | ((column-number-mode |
319 | (10 ,(propertize " (%l,%c)" 'help-echo help-echo)) | |
320 | (6 ,(propertize " L%l" 'help-echo help-echo)))) | |
321 | ((column-number-mode | |
322 | (5 ,(propertize " C%c" 'help-echo help-echo)))))))) | |
4d120e8c | 323 | |
688953b5 DL |
324 | (defvar mode-line-buffer-identification-keymap nil "\ |
325 | Keymap for what is displayed by `mode-line-buffer-identification'.") | |
b1dcba7b | 326 | |
fa3f4090 | 327 | (defun last-buffer () "\ |
545f7310 | 328 | Return the last non-hidden buffer in the buffer list." |
cfabd093 RS |
329 | ;; This logic is more or less copied from bury-buffer, |
330 | ;; except that we reverse the buffer list. | |
196a1cba | 331 | (let ((list (nreverse (buffer-list (selected-frame)))) |
cfabd093 RS |
332 | (pred (frame-parameter nil 'buffer-predicate)) |
333 | found notsogood) | |
196a1cba | 334 | (while (and list (not found)) |
cfabd093 RS |
335 | (unless (or (eq (aref (buffer-name (car list)) 0) ? ) |
336 | ;; If the selected frame has a buffer_predicate, | |
337 | ;; disregard buffers that don't fit the predicate. | |
338 | (and pred (not (funcall pred (car list))))) | |
339 | (if (get-buffer-window (car list) 'visible) | |
196a1cba RS |
340 | (or notsogood (eq (car list) (current-buffer))) |
341 | (setq found (car list)))) | |
342 | (pop list)) | |
343 | (or found notsogood | |
344 | (get-buffer "*scratch*") | |
345 | (progn | |
346 | (set-buffer-major-mode | |
347 | (get-buffer-create "*scratch*")) | |
348 | (get-buffer "*scratch*"))))) | |
545f7310 | 349 | |
fa3f4090 RS |
350 | (defun unbury-buffer () "\ |
351 | Switch to the last buffer in the buffer list." | |
545f7310 SS |
352 | (interactive) |
353 | (switch-to-buffer (last-buffer))) | |
354 | ||
22b50772 | 355 | (defun mode-line-unbury-buffer (event) "\ |
545f7310 | 356 | Call `unbury-buffer' in this window." |
22b50772 GM |
357 | (interactive "e") |
358 | (save-selected-window | |
359 | (select-window (posn-window (event-start event))) | |
545f7310 | 360 | (unbury-buffer))) |
22b50772 GM |
361 | |
362 | (defun mode-line-bury-buffer (event) "\ | |
c85ee897 | 363 | Like `bury-buffer', but temporarily select EVENT's window." |
22b50772 GM |
364 | (interactive "e") |
365 | (save-selected-window | |
366 | (select-window (posn-window (event-start event))) | |
367 | (bury-buffer))) | |
b1dcba7b | 368 | |
688953b5 DL |
369 | (defun mode-line-other-buffer () "\ |
370 | Switch to the most recently selected buffer other than the current one." | |
b1dcba7b GM |
371 | (interactive) |
372 | (switch-to-buffer (other-buffer))) | |
373 | ||
5e1cddda DL |
374 | (defvar mode-line-mode-menu (make-sparse-keymap "Minor Modes") "\ |
375 | Menu of mode operations in the mode line.") | |
376 | ||
b1dcba7b GM |
377 | (defun mode-line-mode-menu-1 (event) |
378 | (interactive "e") | |
379 | (save-selected-window | |
380 | (select-window (posn-window (event-start event))) | |
381 | (let* ((selection (mode-line-mode-menu event)) | |
382 | (binding (and selection (lookup-key mode-line-mode-menu | |
383 | (vector (car selection)))))) | |
384 | (if binding | |
385 | (call-interactively binding))))) | |
386 | ||
842d2ee9 DL |
387 | (defmacro bound-and-true-p (var) |
388 | "Return the value of symbol VAR if it is bound, else nil." | |
ff69e012 | 389 | `(and (boundp (quote ,var)) ,var)) |
842d2ee9 | 390 | |
dfdabcf9 | 391 | (define-key mode-line-mode-menu [overwrite-mode] |
5b1d5e63 | 392 | `(menu-item ,(purecopy "Overwrite (Ovwrt)") overwrite-mode |
dfdabcf9 | 393 | :button (:toggle . overwrite-mode))) |
2a5405b6 | 394 | (define-key mode-line-mode-menu [outline-minor-mode] |
5b1d5e63 | 395 | `(menu-item ,(purecopy "Outline (Outl)") outline-minor-mode |
2a5405b6 GM |
396 | :button (:toggle . (bound-and-true-p outline-minor-mode)))) |
397 | (define-key mode-line-mode-menu [line-number-mode] | |
398 | `(menu-item ,(purecopy "Line number") line-number-mode | |
399 | :button (:toggle . line-number-mode))) | |
400 | (define-key mode-line-mode-menu [highlight-changes-mode] | |
5b1d5e63 | 401 | `(menu-item ,(purecopy "Highlight changes (Chg)") highlight-changes-mode |
2a5405b6 | 402 | :button (:toggle . highlight-changes-mode))) |
7f8661a0 | 403 | (define-key mode-line-mode-menu [glasses-mode] |
5b1d5e63 | 404 | `(menu-item ,(purecopy "Glasses (o^o)") glasses-mode |
e84c695d | 405 | :button (:toggle . (bound-and-true-p glasses-mode)))) |
2a5405b6 | 406 | (define-key mode-line-mode-menu [hide-ifdef-mode] |
5b1d5e63 | 407 | `(menu-item ,(purecopy "Hide ifdef (Ifdef)") hide-ifdef-mode |
2a5405b6 GM |
408 | :button (:toggle . (bound-and-true-p hide-ifdef-mode)))) |
409 | (define-key mode-line-mode-menu [font-lock-mode] | |
aa88b9e5 | 410 | `(menu-item ,(purecopy "Font Lock") font-lock-mode |
2a5405b6 GM |
411 | :button (:toggle . font-lock-mode))) |
412 | (define-key mode-line-mode-menu [flyspell-mode] | |
5b1d5e63 | 413 | `(menu-item ,(purecopy "Flyspell (Fly)") flyspell-mode |
2a5405b6 GM |
414 | :button (:toggle . (bound-and-true-p flyspell-mode)))) |
415 | (define-key mode-line-mode-menu [column-number-mode] | |
416 | `(menu-item ,(purecopy "Column number") column-number-mode | |
417 | :button (:toggle . column-number-mode))) | |
418 | (define-key mode-line-mode-menu [auto-fill-mode] | |
aa88b9e5 | 419 | `(menu-item ,(purecopy "Auto Fill (Fill)") auto-fill-mode |
2a5405b6 GM |
420 | :button (:toggle . auto-fill-function))) |
421 | (define-key mode-line-mode-menu [auto-revert-mode] | |
5b1d5e63 | 422 | `(menu-item ,(purecopy "Auto revert (ARev)") auto-revert-mode |
2a5405b6 GM |
423 | :button (:toggle . auto-revert-mode))) |
424 | (define-key mode-line-mode-menu [abbrev-mode] | |
5b1d5e63 | 425 | `(menu-item ,(purecopy "Abbrev (Abbrev)") abbrev-mode |
2a5405b6 | 426 | :button (:toggle . abbrev-mode))) |
dfdabcf9 | 427 | |
5e1cddda DL |
428 | (defun mode-line-mode-menu (event) |
429 | (interactive "@e") | |
430 | (x-popup-menu event mode-line-mode-menu)) | |
431 | ||
8a42b336 JB |
432 | (defun mode-line-minor-mode-help (event) |
433 | "Describe minor mode for EVENT occured on minor modes area of the mode line." | |
434 | (interactive "@e") | |
435 | (let ((indicator (car (nth 4 (car (cdr event)))))) | |
436 | (describe-minor-mode-from-indicator indicator))) | |
437 | ||
5e1cddda | 438 | ;; Add menu of buffer operations to the buffer identification part |
1ebfdece GM |
439 | ;; of the mode line.or header line. |
440 | ; | |
5e1cddda | 441 | (let ((map (make-sparse-keymap))) |
22b50772 GM |
442 | ;; Bind down- events so that the global keymap won't ``shine |
443 | ;; through''. | |
444 | (define-key map [mode-line down-mouse-1] 'ignore) | |
1ebfdece | 445 | (define-key map [mode-line mouse-1] 'mode-line-unbury-buffer) |
22b50772 | 446 | (define-key map [header-line down-mouse-1] 'ignore) |
1ebfdece | 447 | (define-key map [header-line mouse-1] 'mode-line-unbury-buffer) |
22b50772 GM |
448 | (define-key map [header-line down-mouse-3] 'ignore) |
449 | (define-key map [mode-line mouse-3] 'mode-line-bury-buffer) | |
450 | (define-key map [header-line down-mouse-3] 'ignore) | |
451 | (define-key map [header-line mouse-3] 'mode-line-bury-buffer) | |
ec9db7a7 GM |
452 | (setq mode-line-buffer-identification-keymap map)) |
453 | ||
454 | (defun propertized-buffer-identification (fmt) | |
455 | "Return a list suitable for `mode-line-buffer-identification'. | |
456 | FMT is a format specifier such as \"%12b\". This function adds | |
457 | text properties for face, help-echo, and local-map to it." | |
458 | (list (propertize fmt | |
459 | 'face '(:weight bold) | |
7ed93890 | 460 | 'help-echo |
1ebfdece | 461 | (purecopy "mouse-1: previous buffer, mouse-3: next buffer") |
ec9db7a7 | 462 | 'local-map mode-line-buffer-identification-keymap))) |
7ed93890 | 463 | |
ec9db7a7 GM |
464 | (setq-default mode-line-buffer-identification |
465 | (propertized-buffer-identification "%12b")) | |
5e1cddda | 466 | |
541b8aff GM |
467 | (defvar minor-mode-alist nil "\ |
468 | Alist saying how to show minor modes in the mode line. | |
469 | Each element looks like (VARIABLE STRING); | |
470 | STRING is included in the mode line iff VARIABLE's value is non-nil. | |
471 | ||
472 | Actually, STRING need not be a string; any possible mode-line element | |
473 | is okay. See `mode-line-format'.") | |
474 | ;; Don't use purecopy here--some people want to change these strings. | |
475 | (setq minor-mode-alist | |
476 | (list | |
5b1d5e63 | 477 | (list 'abbrev-mode " Abbrev") |
541b8aff | 478 | '(overwrite-mode overwrite-mode) |
5b1d5e63 | 479 | (list 'auto-fill-function " Fill") |
541b8aff GM |
480 | ;; not really a minor mode... |
481 | '(defining-kbd-macro " Def"))) | |
482 | ||
4d120e8c RS |
483 | ;; These variables are used by autoloadable packages. |
484 | ;; They are defined here so that they do not get overridden | |
485 | ;; by the loading of those packages. | |
486 | ||
487 | ;; Names in directory that end in one of these | |
488 | ;; are ignored in completion, | |
489 | ;; making it more likely you will get a unique match. | |
490 | (setq completion-ignored-extensions | |
d34c1b05 | 491 | (append |
a12ca054 EZ |
492 | (cond ((memq system-type '(ms-dos windows-nt)) |
493 | '(".o" "~" ".bin" ".bak" ".obj" ".map" ".ico" ".pif" ".lnk" | |
494 | ".a" ".ln" ".blg" ".bbl" ".dll" ".drv" ".vxd" ".386")) | |
d34c1b05 RS |
495 | ((eq system-type 'vax-vms) |
496 | '(".obj" ".exe" ".bin" ".lbin" ".sbin" | |
7ed93890 | 497 | ".brn" ".rnt" ".lni" ".lis" |
d34c1b05 RS |
498 | ".olb" ".tlb" ".mlb" ".hlb")) |
499 | (t | |
a12ca054 | 500 | '(".o" "~" ".bin" ".lbin" ".so" |
d34c1b05 RS |
501 | ".a" ".ln" ".blg" ".bbl"))) |
502 | '(".elc" ".lof" | |
503 | ".glo" ".idx" ".lot" | |
504 | ;; TeX-related | |
71a92751 | 505 | ".dvi" ".fmt" ".tfm" ".pdf" |
c79e04d8 RS |
506 | ;; Java compiled |
507 | ".class" | |
7ed93890 SS |
508 | ;; CLISP |
509 | ".fas" ".lib" ".mem" | |
c79e04d8 | 510 | ;; CMUCL |
ff69e012 | 511 | ".x86f" ".sparcf" |
7ed93890 SS |
512 | ;; Other CL implementations (Allegro, LispWorks) |
513 | ".fasl" ".ufsl" ".fsl" ".dxl" | |
f7e1a28d GM |
514 | ;; Libtool |
515 | ".lo" ".la" | |
008c915c RS |
516 | ;; Gettext |
517 | ".gmo" ".mo" | |
d34c1b05 RS |
518 | ;; Texinfo-related |
519 | ".toc" ".log" ".aux" | |
520 | ".cp" ".fn" ".ky" ".pg" ".tp" ".vr" | |
521 | ".cps" ".fns" ".kys" ".pgs" ".tps" ".vrs"))) | |
4d120e8c | 522 | |
ae95a95a SM |
523 | ;; Suffixes used for executables. |
524 | (setq exec-suffixes | |
525 | (cond | |
526 | ((memq system-type '(ms-dos windows-nt)) | |
527 | '(".exe" ".com" ".bat" ".cmd" ".btm" "")) | |
528 | (t | |
529 | '("")))) | |
530 | ||
2b4b2add DL |
531 | ;; Packages should add to this list appropriately when they are |
532 | ;; loaded, rather than listing everything here. | |
4d120e8c RS |
533 | (setq debug-ignored-errors |
534 | '(beginning-of-line beginning-of-buffer end-of-line | |
535 | end-of-buffer end-of-file buffer-read-only | |
c79e04d8 | 536 | file-supersession |
4d120e8c RS |
537 | "^Previous command was not a yank$" |
538 | "^Minibuffer window is not active$" | |
539 | "^End of history; no next item$" | |
540 | "^Beginning of history; no preceding item$" | |
541 | "^No recursive edit is in progress$" | |
542 | "^Changes to be undone are outside visible portion of buffer$" | |
543 | "^No undo information in this buffer$" | |
544 | "^No further undo information$" | |
545 | "^Save not confirmed$" | |
546 | "^Recover-file cancelled\\.$" | |
800c9512 | 547 | "^Cannot switch buffers in a dedicated window$" |
7ed93890 | 548 | |
cdd4703c RS |
549 | ;; ediff |
550 | "^Errors in diff output. Diff output is in " | |
551 | "^Hmm... I don't see an Ediff command around here...$" | |
552 | "^Undocumented command! Type `G' in Ediff Control Panel to drop a note to the Ediff maintainer$" | |
553 | ": This command runs in Ediff Control Buffer only!$" | |
554 | ": Invalid op in ediff-check-version$" | |
555 | "^ediff-shrink-window-C can be used only for merging jobs$" | |
556 | "^Lost difference info on these directories$" | |
557 | "^This command is inapplicable in the present context$" | |
558 | "^This session group has no parent$" | |
559 | "^Can't hide active session, $" | |
cdd4703c RS |
560 | "^Ediff: something wrong--no multiple diffs buffer$" |
561 | "^Can't make context diff for Session $" | |
562 | "^The patch buffer wasn't found$" | |
563 | "^Aborted$" | |
564 | "^This Ediff session is not part of a session group$" | |
565 | "^No active Ediff sessions or corrupted session registry$" | |
566 | "^No session info in this line$" | |
567 | "^`.*' is not an ordinary file$" | |
568 | "^Patch appears to have failed$" | |
569 | "^Recomputation of differences cancelled$" | |
570 | "^No fine differences in this mode$" | |
571 | "^Lost connection to ancestor buffer...sorry$" | |
572 | "^Not merging with ancestor$" | |
573 | "^Don't know how to toggle read-only in buffer " | |
574 | "Emacs is not running as a window application$" | |
575 | "^This command makes sense only when merging with an ancestor$" | |
576 | "^At end of the difference list$" | |
577 | "^At beginning of the difference list$" | |
cdd4703c RS |
578 | "^Nothing saved for diff .* in buffer " |
579 | "^Buffer is out of sync for file " | |
580 | "^Buffer out of sync for file " | |
581 | "^Output from `diff' not found$" | |
582 | "^You forgot to specify a region in buffer " | |
583 | "^All right. Make up your mind and come back...$" | |
584 | "^Current buffer is not visiting any file$" | |
585 | "^Failed to retrieve revision: $" | |
586 | "^Can't determine display width.$" | |
587 | "^File `.*' does not exist or is not readable$" | |
588 | "^File `.*' is a directory$" | |
589 | "^Buffer .* doesn't exist$" | |
590 | "^Directories . and . are the same: " | |
591 | "^Directory merge aborted$" | |
592 | "^Merge of directory revisions aborted$" | |
593 | "^Buffer .* doesn't exist$" | |
594 | "^There is no file to merge$" | |
d8d0fa6c | 595 | "^Version control package .*.el not found. Use vc.el instead$")) |
4d120e8c RS |
596 | |
597 | ||
598 | (make-variable-buffer-local 'indent-tabs-mode) | |
599 | ||
152d064d | 600 | ;; We have base64 and md5 functions built in now. |
d1bf2a73 SM |
601 | (provide 'base64) |
602 | (provide 'md5) | |
603 | (provide 'overlay '(display syntax-table field)) | |
604 | (provide 'text-properties '(display syntax-table field point-entered)) | |
acafa9cf | 605 | |
0094907b RS |
606 | (define-key esc-map "\t" 'complete-symbol) |
607 | ||
688953b5 DL |
608 | (defun complete-symbol (arg) "\ |
609 | Perform tags completion on the text around point. | |
4d120e8c RS |
610 | Completes to the set of names listed in the current tags table. |
611 | The string to complete is chosen in the same way as the default | |
364581dc RS |
612 | for \\[find-tag] (which see). |
613 | ||
614 | With a prefix argument, this command does completion within | |
615 | the collection of symbols listed in the index of the manual for the | |
616 | language you are using." | |
0094907b RS |
617 | (interactive "P") |
618 | (if arg | |
364581dc RS |
619 | (info-complete-symbol) |
620 | (if (fboundp 'complete-tag) | |
621 | (complete-tag) | |
622 | ;; Don't autoload etags if we have no tags table. | |
623 | (error (substitute-command-keys | |
624 | "No tags table loaded; use \\[visit-tags-table] to load one"))))) | |
4d120e8c RS |
625 | |
626 | ;; Reduce total amount of space we must allocate during this function | |
627 | ;; that we will not need to keep permanently. | |
628 | (garbage-collect) | |
629 | \f | |
d92921c3 KH |
630 | ;; Make all multibyte characters self-insert. |
631 | (let ((l (generic-character-list)) | |
632 | (table (nth 1 global-map))) | |
633 | (while l | |
634 | (set-char-table-default table (car l) 'self-insert-command) | |
635 | (setq l (cdr l)))) | |
3607b64d | 636 | |
4d120e8c RS |
637 | (setq help-event-list '(help f1)) |
638 | ||
97710114 RS |
639 | (make-variable-buffer-local 'minor-mode-overriding-map-alist) |
640 | ||
d1bf2a73 SM |
641 | ;; From frame.c |
642 | (global-set-key [switch-frame] 'handle-switch-frame) | |
b6cb37ae SM |
643 | (global-set-key [select-window] 'handle-select-window) |
644 | ||
645 | ;; FIXME: Do those 3 events really ever reach the global-map ? | |
646 | ;; It seems that they can't because they're handled via | |
647 | ;; special-event-map which is used at very low-level. -stef | |
d1bf2a73 SM |
648 | (global-set-key [delete-frame] 'handle-delete-frame) |
649 | (global-set-key [iconify-frame] 'ignore-event) | |
650 | (global-set-key [make-frame-visible] 'ignore-event) | |
651 | ||
652 | ||
4d120e8c RS |
653 | ;These commands are defined in editfns.c |
654 | ;but they are not assigned to keys there. | |
655 | (put 'narrow-to-region 'disabled t) | |
656 | (define-key ctl-x-map "nn" 'narrow-to-region) | |
657 | (define-key ctl-x-map "nw" 'widen) | |
658 | ;; (define-key ctl-x-map "n" 'narrow-to-region) | |
659 | ;; (define-key ctl-x-map "w" 'widen) | |
660 | ||
661 | (define-key global-map "\C-j" 'newline-and-indent) | |
662 | (define-key global-map "\C-m" 'newline) | |
663 | (define-key global-map "\C-o" 'open-line) | |
664 | (define-key esc-map "\C-o" 'split-line) | |
665 | (define-key global-map "\C-q" 'quoted-insert) | |
666 | (define-key esc-map "^" 'delete-indentation) | |
667 | (define-key esc-map "\\" 'delete-horizontal-space) | |
668 | (define-key esc-map "m" 'back-to-indentation) | |
669 | (define-key ctl-x-map "\C-o" 'delete-blank-lines) | |
670 | (define-key esc-map " " 'just-one-space) | |
671 | (define-key esc-map "z" 'zap-to-char) | |
672 | (define-key esc-map "=" 'count-lines-region) | |
673 | (define-key ctl-x-map "=" 'what-cursor-position) | |
674 | (define-key esc-map ":" 'eval-expression) | |
675 | ;; Define ESC ESC : like ESC : for people who type ESC ESC out of habit. | |
676 | (define-key esc-map "\M-:" 'eval-expression) | |
677 | ;; Changed from C-x ESC so that function keys work following C-x. | |
678 | (define-key ctl-x-map "\e\e" 'repeat-complex-command) | |
679 | ;; New binding analogous to M-:. | |
680 | (define-key ctl-x-map "\M-:" 'repeat-complex-command) | |
681 | (define-key ctl-x-map "u" 'advertised-undo) | |
682 | ;; Many people are used to typing C-/ on X terminals and getting C-_. | |
683 | (define-key global-map [?\C-/] 'undo) | |
684 | (define-key global-map "\C-_" 'undo) | |
685 | (define-key esc-map "!" 'shell-command) | |
686 | (define-key esc-map "|" 'shell-command-on-region) | |
687 | ||
a77dfeb0 SM |
688 | (let ((map minibuffer-local-map)) |
689 | (define-key map "\en" 'next-history-element) | |
690 | (define-key map [next] 'next-history-element) | |
691 | (define-key map [down] 'next-history-element) | |
692 | (define-key map "\ep" 'previous-history-element) | |
693 | (define-key map [prior] 'previous-history-element) | |
694 | (define-key map [up] 'previous-history-element) | |
695 | (define-key map "\es" 'next-matching-history-element) | |
696 | (define-key map "\er" 'previous-matching-history-element)) | |
4d120e8c RS |
697 | |
698 | (define-key global-map "\C-u" 'universal-argument) | |
699 | (let ((i ?0)) | |
700 | (while (<= i ?9) | |
701 | (define-key esc-map (char-to-string i) 'digit-argument) | |
702 | (setq i (1+ i)))) | |
703 | (define-key esc-map "-" 'negative-argument) | |
704 | ;; Define control-digits. | |
705 | (let ((i ?0)) | |
706 | (while (<= i ?9) | |
707 | (define-key global-map (read (format "[?\\C-%c]" i)) 'digit-argument) | |
708 | (setq i (1+ i)))) | |
709 | (define-key global-map [?\C--] 'negative-argument) | |
710 | ;; Define control-meta-digits. | |
711 | (let ((i ?0)) | |
712 | (while (<= i ?9) | |
713 | (define-key esc-map (read (format "[?\\C-%c]" i)) 'digit-argument) | |
714 | (setq i (1+ i)))) | |
715 | (define-key global-map [?\C-\M--] 'negative-argument) | |
716 | ||
717 | (define-key global-map "\C-k" 'kill-line) | |
718 | (define-key global-map "\C-w" 'kill-region) | |
719 | (define-key esc-map "w" 'kill-ring-save) | |
720 | (define-key esc-map "\C-w" 'append-next-kill) | |
721 | (define-key global-map "\C-y" 'yank) | |
722 | (define-key esc-map "y" 'yank-pop) | |
723 | ||
724 | ;; (define-key ctl-x-map "a" 'append-to-buffer) | |
725 | ||
726 | (define-key global-map "\C-@" 'set-mark-command) | |
727 | ;; Many people are used to typing C-SPC and getting C-@. | |
e68e61b5 | 728 | (define-key global-map [?\C- ] 'set-mark-command) |
4d120e8c RS |
729 | (define-key ctl-x-map "\C-x" 'exchange-point-and-mark) |
730 | (define-key ctl-x-map "\C-@" 'pop-global-mark) | |
e68e61b5 | 731 | (define-key ctl-x-map [?\C- ] 'pop-global-mark) |
4d120e8c RS |
732 | |
733 | (define-key global-map "\C-n" 'next-line) | |
734 | (define-key global-map "\C-p" 'previous-line) | |
735 | (define-key ctl-x-map "\C-n" 'set-goal-column) | |
736 | ||
737 | ;;(defun function-key-error () | |
738 | ;; (interactive) | |
1cd7adc6 | 739 | ;; (error "That function key is not bound to anything")) |
4d120e8c RS |
740 | |
741 | (define-key global-map [menu] 'execute-extended-command) | |
742 | (define-key global-map [find] 'search-forward) | |
743 | ||
9d4850e5 GM |
744 | ;; Don't do this. We define <delete> in function-key-map instead. |
745 | ;(define-key global-map [delete] 'backward-delete-char) | |
4e4f9651 | 746 | |
4d120e8c | 747 | ;; natural bindings for terminal keycaps --- defined in X keysym order |
1dfca644 GM |
748 | (define-key global-map [home] 'beginning-of-line) |
749 | (define-key global-map [C-home] 'beginning-of-buffer) | |
4d120e8c RS |
750 | (define-key global-map [M-home] 'beginning-of-buffer-other-window) |
751 | (define-key global-map [left] 'backward-char) | |
752 | (define-key global-map [up] 'previous-line) | |
753 | (define-key global-map [right] 'forward-char) | |
754 | (define-key global-map [down] 'next-line) | |
755 | (define-key global-map [prior] 'scroll-down) | |
756 | (define-key global-map [next] 'scroll-up) | |
757 | (define-key global-map [C-up] 'backward-paragraph) | |
758 | (define-key global-map [C-down] 'forward-paragraph) | |
759 | (define-key global-map [C-prior] 'scroll-right) | |
760 | (define-key global-map [C-next] 'scroll-left) | |
761 | (define-key global-map [M-next] 'scroll-other-window) | |
762 | (define-key global-map [M-prior] 'scroll-other-window-down) | |
1dfca644 GM |
763 | (define-key global-map [end] 'end-of-line) |
764 | (define-key global-map [C-end] 'end-of-buffer) | |
4d120e8c RS |
765 | (define-key global-map [M-end] 'end-of-buffer-other-window) |
766 | (define-key global-map [begin] 'beginning-of-buffer) | |
767 | (define-key global-map [M-begin] 'beginning-of-buffer-other-window) | |
768 | ;; (define-key global-map [select] 'function-key-error) | |
769 | ;; (define-key global-map [print] 'function-key-error) | |
770 | (define-key global-map [execute] 'execute-extended-command) | |
771 | (define-key global-map [insert] 'overwrite-mode) | |
772 | (define-key global-map [C-insert] 'kill-ring-save) | |
773 | (define-key global-map [S-insert] 'yank) | |
774 | (define-key global-map [undo] 'undo) | |
775 | (define-key global-map [redo] 'repeat-complex-command) | |
776 | ;; (define-key global-map [clearline] 'function-key-error) | |
777 | (define-key global-map [insertline] 'open-line) | |
778 | (define-key global-map [deleteline] 'kill-line) | |
779 | ;; (define-key global-map [insertchar] 'function-key-error) | |
780 | (define-key global-map [deletechar] 'delete-char) | |
781 | ;; (define-key global-map [backtab] 'function-key-error) | |
782 | ;; (define-key global-map [f1] 'function-key-error) | |
783 | ;; (define-key global-map [f2] 'function-key-error) | |
784 | ;; (define-key global-map [f3] 'function-key-error) | |
785 | ;; (define-key global-map [f4] 'function-key-error) | |
786 | ;; (define-key global-map [f5] 'function-key-error) | |
787 | ;; (define-key global-map [f6] 'function-key-error) | |
788 | ;; (define-key global-map [f7] 'function-key-error) | |
789 | ;; (define-key global-map [f8] 'function-key-error) | |
790 | ;; (define-key global-map [f9] 'function-key-error) | |
791 | ;; (define-key global-map [f10] 'function-key-error) | |
792 | ;; (define-key global-map [f11] 'function-key-error) | |
793 | ;; (define-key global-map [f12] 'function-key-error) | |
794 | ;; (define-key global-map [f13] 'function-key-error) | |
795 | ;; (define-key global-map [f14] 'function-key-error) | |
796 | ;; (define-key global-map [f15] 'function-key-error) | |
797 | ;; (define-key global-map [f16] 'function-key-error) | |
798 | ;; (define-key global-map [f17] 'function-key-error) | |
799 | ;; (define-key global-map [f18] 'function-key-error) | |
800 | ;; (define-key global-map [f19] 'function-key-error) | |
801 | ;; (define-key global-map [f20] 'function-key-error) | |
802 | ;; (define-key global-map [f21] 'function-key-error) | |
803 | ;; (define-key global-map [f22] 'function-key-error) | |
804 | ;; (define-key global-map [f23] 'function-key-error) | |
805 | ;; (define-key global-map [f24] 'function-key-error) | |
806 | ;; (define-key global-map [f25] 'function-key-error) | |
807 | ;; (define-key global-map [f26] 'function-key-error) | |
808 | ;; (define-key global-map [f27] 'function-key-error) | |
809 | ;; (define-key global-map [f28] 'function-key-error) | |
810 | ;; (define-key global-map [f29] 'function-key-error) | |
811 | ;; (define-key global-map [f30] 'function-key-error) | |
812 | ;; (define-key global-map [f31] 'function-key-error) | |
813 | ;; (define-key global-map [f32] 'function-key-error) | |
814 | ;; (define-key global-map [f33] 'function-key-error) | |
815 | ;; (define-key global-map [f34] 'function-key-error) | |
816 | ;; (define-key global-map [f35] 'function-key-error) | |
817 | ;; (define-key global-map [kp-backtab] 'function-key-error) | |
818 | ;; (define-key global-map [kp-space] 'function-key-error) | |
819 | ;; (define-key global-map [kp-tab] 'function-key-error) | |
820 | ;; (define-key global-map [kp-enter] 'function-key-error) | |
821 | ;; (define-key global-map [kp-f1] 'function-key-error) | |
822 | ;; (define-key global-map [kp-f2] 'function-key-error) | |
823 | ;; (define-key global-map [kp-f3] 'function-key-error) | |
824 | ;; (define-key global-map [kp-f4] 'function-key-error) | |
825 | ;; (define-key global-map [kp-multiply] 'function-key-error) | |
826 | ;; (define-key global-map [kp-add] 'function-key-error) | |
827 | ;; (define-key global-map [kp-separator] 'function-key-error) | |
828 | ;; (define-key global-map [kp-subtract] 'function-key-error) | |
829 | ;; (define-key global-map [kp-decimal] 'function-key-error) | |
830 | ;; (define-key global-map [kp-divide] 'function-key-error) | |
831 | ;; (define-key global-map [kp-0] 'function-key-error) | |
832 | ;; (define-key global-map [kp-1] 'function-key-error) | |
833 | ;; (define-key global-map [kp-2] 'function-key-error) | |
834 | ;; (define-key global-map [kp-3] 'function-key-error) | |
835 | ;; (define-key global-map [kp-4] 'function-key-error) | |
836 | ;; (define-key global-map [kp-5] 'recenter) | |
837 | ;; (define-key global-map [kp-6] 'function-key-error) | |
838 | ;; (define-key global-map [kp-7] 'function-key-error) | |
839 | ;; (define-key global-map [kp-8] 'function-key-error) | |
840 | ;; (define-key global-map [kp-9] 'function-key-error) | |
841 | ;; (define-key global-map [kp-equal] 'function-key-error) | |
842 | ||
843 | ;; X11R6 distinguishes these keys from the non-kp keys. | |
844 | ;; Make them behave like the non-kp keys unless otherwise bound. | |
845 | (define-key function-key-map [kp-home] [home]) | |
846 | (define-key function-key-map [kp-left] [left]) | |
847 | (define-key function-key-map [kp-up] [up]) | |
848 | (define-key function-key-map [kp-right] [right]) | |
849 | (define-key function-key-map [kp-down] [down]) | |
850 | (define-key function-key-map [kp-prior] [prior]) | |
851 | (define-key function-key-map [kp-next] [next]) | |
852 | (define-key function-key-map [M-kp-next] [M-next]) | |
853 | (define-key function-key-map [kp-end] [end]) | |
854 | (define-key function-key-map [kp-begin] [begin]) | |
855 | (define-key function-key-map [kp-insert] [insert]) | |
9d4850e5 GM |
856 | (define-key function-key-map [backspace] [?\C-?]) |
857 | (define-key function-key-map [delete] [?\C-?]) | |
ee5cece0 | 858 | (define-key function-key-map [kp-delete] [?\C-?]) |
9761cd3a EZ |
859 | (define-key function-key-map [S-kp-end] [S-end]) |
860 | (define-key function-key-map [S-kp-down] [S-down]) | |
861 | (define-key function-key-map [S-kp-next] [S-next]) | |
862 | (define-key function-key-map [S-kp-left] [S-left]) | |
863 | (define-key function-key-map [S-kp-right] [S-right]) | |
864 | (define-key function-key-map [S-kp-home] [S-home]) | |
865 | (define-key function-key-map [S-kp-up] [S-up]) | |
866 | (define-key function-key-map [S-kp-prior] [S-prior]) | |
867 | (define-key function-key-map [C-S-kp-end] [C-S-end]) | |
868 | (define-key function-key-map [C-S-kp-down] [C-S-down]) | |
869 | (define-key function-key-map [C-S-kp-next] [C-S-next]) | |
870 | (define-key function-key-map [C-S-kp-left] [C-S-left]) | |
871 | (define-key function-key-map [C-S-kp-right] [C-S-right]) | |
872 | (define-key function-key-map [C-S-kp-home] [C-S-home]) | |
873 | (define-key function-key-map [C-S-kp-up] [C-S-up]) | |
874 | (define-key function-key-map [C-S-kp-prior] [C-S-prior]) | |
7bc60154 EZ |
875 | ;; Don't bind shifted keypad numeric keys, they reportedly |
876 | ;; interfere with the feature of some keyboards to produce | |
877 | ;; numbers when NumLock is off. | |
878 | ;(define-key function-key-map [S-kp-1] [S-end]) | |
879 | ;(define-key function-key-map [S-kp-2] [S-down]) | |
880 | ;(define-key function-key-map [S-kp-3] [S-next]) | |
881 | ;(define-key function-key-map [S-kp-4] [S-left]) | |
882 | ;(define-key function-key-map [S-kp-6] [S-right]) | |
883 | ;(define-key function-key-map [S-kp-7] [S-home]) | |
884 | ;(define-key function-key-map [S-kp-8] [S-up]) | |
885 | ;(define-key function-key-map [S-kp-9] [S-prior]) | |
9761cd3a EZ |
886 | (define-key function-key-map [C-S-kp-1] [C-S-end]) |
887 | (define-key function-key-map [C-S-kp-2] [C-S-down]) | |
888 | (define-key function-key-map [C-S-kp-3] [C-S-next]) | |
889 | (define-key function-key-map [C-S-kp-4] [C-S-left]) | |
890 | (define-key function-key-map [C-S-kp-6] [C-S-right]) | |
891 | (define-key function-key-map [C-S-kp-7] [C-S-home]) | |
892 | (define-key function-key-map [C-S-kp-8] [C-S-up]) | |
893 | (define-key function-key-map [C-S-kp-9] [C-S-prior]) | |
4d120e8c RS |
894 | |
895 | (define-key global-map [mouse-movement] 'ignore) | |
896 | ||
897 | (define-key global-map "\C-t" 'transpose-chars) | |
898 | (define-key esc-map "t" 'transpose-words) | |
899 | (define-key esc-map "\C-t" 'transpose-sexps) | |
900 | (define-key ctl-x-map "\C-t" 'transpose-lines) | |
901 | ||
5589b330 | 902 | (define-key esc-map ";" 'comment-dwim) |
fedff3c6 SM |
903 | (define-key esc-map "j" 'indent-new-comment-line) |
904 | (define-key esc-map "\C-j" 'indent-new-comment-line) | |
5589b330 | 905 | (define-key ctl-x-map ";" 'comment-set-column) |
4d120e8c RS |
906 | (define-key ctl-x-map "f" 'set-fill-column) |
907 | (define-key ctl-x-map "$" 'set-selective-display) | |
908 | ||
909 | (define-key esc-map "@" 'mark-word) | |
910 | (define-key esc-map "f" 'forward-word) | |
911 | (define-key esc-map "b" 'backward-word) | |
912 | (define-key esc-map "d" 'kill-word) | |
913 | (define-key esc-map "\177" 'backward-kill-word) | |
914 | ||
915 | (define-key esc-map "<" 'beginning-of-buffer) | |
916 | (define-key esc-map ">" 'end-of-buffer) | |
917 | (define-key ctl-x-map "h" 'mark-whole-buffer) | |
918 | (define-key esc-map "\\" 'delete-horizontal-space) | |
919 | ||
920 | (defalias 'mode-specific-command-prefix (make-sparse-keymap)) | |
4b189189 | 921 | (defvar mode-specific-map (symbol-function 'mode-specific-command-prefix) |
4d120e8c RS |
922 | "Keymap for characters following C-c.") |
923 | (define-key global-map "\C-c" 'mode-specific-command-prefix) | |
924 | ||
925 | (global-set-key [M-right] 'forward-word) | |
926 | (global-set-key [M-left] 'backward-word) | |
927 | ;; ilya@math.ohio-state.edu says these bindings are standard on PC editors. | |
928 | (global-set-key [C-right] 'forward-word) | |
929 | (global-set-key [C-left] 'backward-word) | |
930 | ;; This is not quite compatible, but at least is analogous | |
27940e1f GM |
931 | (global-set-key [C-delete] 'backward-kill-word) |
932 | (global-set-key [C-backspace] 'kill-word) | |
4d120e8c RS |
933 | ;; This is "move to the clipboard", or as close as we come. |
934 | (global-set-key [S-delete] 'kill-region) | |
935 | ||
936 | (define-key esc-map "\C-f" 'forward-sexp) | |
937 | (define-key esc-map "\C-b" 'backward-sexp) | |
938 | (define-key esc-map "\C-u" 'backward-up-list) | |
939 | (define-key esc-map "\C-@" 'mark-sexp) | |
940 | (define-key esc-map [?\C-\ ] 'mark-sexp) | |
941 | (define-key esc-map "\C-d" 'down-list) | |
942 | (define-key esc-map "\C-k" 'kill-sexp) | |
943 | (define-key global-map [C-M-delete] 'backward-kill-sexp) | |
944 | (define-key global-map [C-M-backspace] 'backward-kill-sexp) | |
da7ddbed GM |
945 | (define-key esc-map [C-delete] 'backward-kill-sexp) |
946 | (define-key esc-map [C-backspace] 'backward-kill-sexp) | |
4d120e8c RS |
947 | (define-key esc-map "\C-n" 'forward-list) |
948 | (define-key esc-map "\C-p" 'backward-list) | |
949 | (define-key esc-map "\C-a" 'beginning-of-defun) | |
950 | (define-key esc-map "\C-e" 'end-of-defun) | |
951 | (define-key esc-map "\C-h" 'mark-defun) | |
952 | (define-key ctl-x-map "nd" 'narrow-to-defun) | |
953 | (define-key esc-map "(" 'insert-parentheses) | |
954 | (define-key esc-map ")" 'move-past-close-and-reindent) | |
4d120e8c RS |
955 | |
956 | (define-key ctl-x-map "\C-e" 'eval-last-sexp) | |
6d64bc9f RS |
957 | |
958 | (define-key ctl-x-map "m" 'compose-mail) | |
959 | (define-key ctl-x-4-map "m" 'compose-mail-other-window) | |
960 | (define-key ctl-x-5-map "m" 'compose-mail-other-frame) | |
4d120e8c RS |
961 | \f |
962 | (define-key ctl-x-map "r\C-@" 'point-to-register) | |
963 | (define-key ctl-x-map [?r ?\C-\ ] 'point-to-register) | |
964 | (define-key ctl-x-map "r " 'point-to-register) | |
965 | (define-key ctl-x-map "rj" 'jump-to-register) | |
966 | (define-key ctl-x-map "rs" 'copy-to-register) | |
967 | (define-key ctl-x-map "rx" 'copy-to-register) | |
968 | (define-key ctl-x-map "ri" 'insert-register) | |
969 | (define-key ctl-x-map "rg" 'insert-register) | |
970 | (define-key ctl-x-map "rr" 'copy-rectangle-to-register) | |
bdb45de9 KH |
971 | (define-key ctl-x-map "rn" 'number-to-register) |
972 | (define-key ctl-x-map "r+" 'increment-register) | |
4d120e8c RS |
973 | (define-key ctl-x-map "rc" 'clear-rectangle) |
974 | (define-key ctl-x-map "rk" 'kill-rectangle) | |
975 | (define-key ctl-x-map "rd" 'delete-rectangle) | |
976 | (define-key ctl-x-map "ry" 'yank-rectangle) | |
977 | (define-key ctl-x-map "ro" 'open-rectangle) | |
978 | (define-key ctl-x-map "rt" 'string-rectangle) | |
979 | (define-key ctl-x-map "rw" 'window-configuration-to-register) | |
980 | (define-key ctl-x-map "rf" 'frame-configuration-to-register) | |
981 | ||
982 | ;; These key bindings are deprecated; use the above C-x r map instead. | |
983 | ;; We use these aliases so \[...] will show the C-x r bindings instead. | |
984 | (defalias 'point-to-register-compatibility-binding 'point-to-register) | |
985 | (defalias 'jump-to-register-compatibility-binding 'jump-to-register) | |
986 | (defalias 'copy-to-register-compatibility-binding 'copy-to-register) | |
987 | (defalias 'insert-register-compatibility-binding 'insert-register) | |
988 | (define-key ctl-x-map "/" 'point-to-register-compatibility-binding) | |
989 | (define-key ctl-x-map "j" 'jump-to-register-compatibility-binding) | |
990 | (define-key ctl-x-map "x" 'copy-to-register-compatibility-binding) | |
991 | (define-key ctl-x-map "g" 'insert-register-compatibility-binding) | |
992 | ;; (define-key ctl-x-map "r" 'copy-rectangle-to-register) | |
993 | ||
994 | (define-key esc-map "q" 'fill-paragraph) | |
995 | ;; (define-key esc-map "g" 'fill-region) | |
996 | (define-key ctl-x-map "." 'set-fill-prefix) | |
997 | \f | |
998 | (define-key esc-map "{" 'backward-paragraph) | |
999 | (define-key esc-map "}" 'forward-paragraph) | |
1000 | (define-key esc-map "h" 'mark-paragraph) | |
1001 | (define-key esc-map "a" 'backward-sentence) | |
1002 | (define-key esc-map "e" 'forward-sentence) | |
1003 | (define-key esc-map "k" 'kill-sentence) | |
1004 | (define-key ctl-x-map "\177" 'backward-kill-sentence) | |
1005 | ||
1006 | (define-key ctl-x-map "[" 'backward-page) | |
1007 | (define-key ctl-x-map "]" 'forward-page) | |
1008 | (define-key ctl-x-map "\C-p" 'mark-page) | |
1009 | (define-key ctl-x-map "l" 'count-lines-page) | |
1010 | (define-key ctl-x-map "np" 'narrow-to-page) | |
1011 | ;; (define-key ctl-x-map "p" 'narrow-to-page) | |
1012 | \f | |
1013 | (define-key ctl-x-map "al" 'add-mode-abbrev) | |
1014 | (define-key ctl-x-map "a\C-a" 'add-mode-abbrev) | |
1015 | (define-key ctl-x-map "ag" 'add-global-abbrev) | |
1016 | (define-key ctl-x-map "a+" 'add-mode-abbrev) | |
1017 | (define-key ctl-x-map "aig" 'inverse-add-global-abbrev) | |
1018 | (define-key ctl-x-map "ail" 'inverse-add-mode-abbrev) | |
1019 | ;; (define-key ctl-x-map "a\C-h" 'inverse-add-global-abbrev) | |
1020 | (define-key ctl-x-map "a-" 'inverse-add-global-abbrev) | |
1021 | (define-key ctl-x-map "ae" 'expand-abbrev) | |
1022 | (define-key ctl-x-map "a'" 'expand-abbrev) | |
1023 | ;; (define-key ctl-x-map "\C-a" 'add-mode-abbrev) | |
1024 | ;; (define-key ctl-x-map "\+" 'add-global-abbrev) | |
1025 | ;; (define-key ctl-x-map "\C-h" 'inverse-add-mode-abbrev) | |
1026 | ;; (define-key ctl-x-map "\-" 'inverse-add-global-abbrev) | |
1027 | (define-key esc-map "'" 'abbrev-prefix-mark) | |
1028 | (define-key ctl-x-map "'" 'expand-abbrev) | |
1029 | ||
aa5ba90e | 1030 | (define-key ctl-x-map "z" 'repeat) |
e4ade21b | 1031 | |
d1bf2a73 SM |
1032 | ;; Don't look for autoload cookies in this file. |
1033 | ;; Local Variables: | |
1034 | ;; no-update-autoloads: t | |
1035 | ;; End: | |
4d120e8c RS |
1036 | |
1037 | ;;; bindings.el ends here |