comparison lisp/utils/delbackspace.el @ 0:376386a54a3c r19-14

Import from CVS: tag r19-14
author cvs
date Mon, 13 Aug 2007 08:45:50 +0200
parents
children 49a24b4fd526
comparison
equal deleted inserted replaced
-1:000000000000 0:376386a54a3c
1 ;;; delbackspace.el --- rebind backspace and delete to be correct
2
3 ;; Copyright (C) 1994, 1995 Free Software Foundation, Inc.
4 ;; Copyright (C) 1996 Ben Wing.
5 ;;
6 ;; Author: Tibor Polgar??
7 ;; Maintainer: Ben Wing <wing@666.com>
8 ;; Keywords: terminals
9 ;;
10
11 ;;; Synched up with: Not in FSF.
12 ;;; #### should port FSF pc-bindings.el and nuke this.
13
14 ;; this is a hack that will have to do until function-key-map is implemented
15 (defconst delbackspace-backspace
16 (if (not (eq 'tty (device-type (selected-device))))
17 'backspace
18 "\C-h"))
19
20 (global-unset-key delbackspace-backspace)
21 (local-unset-key delbackspace-backspace)
22 (global-unset-key [(control delete)])
23 (global-unset-key [(meta delete)])
24 (global-unset-key [(meta shift delete)])
25 (global-unset-key [(control backspace)])
26 (global-unset-key [(meta backspace)])
27 (global-unset-key [(meta shift backspace)])
28
29 (if (eq 'tty (device-type (selected-device)))
30 (progn
31 (setq help-char '(meta h))
32 (define-key global-map "\M-h" 'help-command)))
33
34 (define-key key-translation-map 'delete 'delbackspace-compute-delete-value)
35 (define-key global-map 'intercepted_delete 'delete-char)
36
37 (defun delbackspace-compute-delete-value (prompt)
38 (let ((orig-binding (key-binding 'delete)))
39 (if (memq orig-binding '(delete-backward-char
40 backward-delete-char
41 backward-delete-char-untabify
42 c-electric-delete
43 c++-electric-delete
44 cperl-electric-backspace))
45 [intercepted_delete]
46 [delete])))
47
48 (define-key key-translation-map delbackspace-backspace [delete])
49
50 ;; (ctrl) backspace to beginning of line
51 (global-set-key [(control backspace)] 'backward-kill-line)
52
53 ;; (meta) backspace word before cursor
54 (define-key key-translation-map [(meta backspace)]
55 [intercepted_meta_backspace])
56 (define-key global-map 'intercepted_meta_backspace 'backward-kill-word)
57
58 ;; (alt) backspace sentence before cursor; backspace sexp before cursor
59 ;; in language modes
60 (define-key key-translation-map [(alt backspace)]
61 [intercepted_alt_backspace])
62 (define-key global-map 'intercepted_alt_backspace 'backward-kill-sentence)
63 (mapcar #'(lambda (map)
64 (define-key map [(alt backspace)] 'backward-kill-sexp))
65 (list
66 c-mode-map c++-mode-map objc-mode-map java-mode-map
67 emacs-lisp-mode-map lisp-mode-map minibuffer-local-map))
68
69 ;; (meta shift) backspace paragraph before cursor
70 (global-set-key [(meta shift backspace)] 'backward-kill-paragraph)
71
72 ;; (alt) delete rest of line (erase EOF)
73 (global-set-key [(control delete)] 'kill-line)
74
75 ;; (meta) delete word before cursor
76 (define-key key-translation-map [(meta delete)]
77 [intercepted_meta_delete])
78 (define-key global-map 'intercepted_meta_delete 'kill-word)
79
80 ;; (alt) delete sentence forward; delete sexp forward
81 ;; in language modes
82 (define-key key-translation-map [(alt delete)]
83 [intercepted_alt_delete])
84 (define-key global-map 'intercepted_alt_delete 'kill-sentence)
85 (mapcar #'(lambda (map)
86 (define-key map [(alt delete)] 'kill-sexp))
87 (list
88 c-mode-map c++-mode-map objc-mode-map java-mode-map
89 emacs-lisp-mode-map lisp-mode-map minibuffer-local-map))
90
91 ;; (meta shift) delete next paragraph
92 (global-set-key [(meta shift delete)] 'kill-paragraph)