diff options
| author | Alan Mackenzie | 2015-08-19 16:47:10 +0000 |
|---|---|---|
| committer | Alan Mackenzie | 2015-08-19 16:47:10 +0000 |
| commit | 82a3da21ffece64ce9f4f99f35cbc0afe851e6ee (patch) | |
| tree | 3e994ddb89d7014701323f28813097284d3ff266 /lisp/progmodes | |
| parent | ec07cfbee12528b9800a8c8fa019af72e3c9cfe4 (diff) | |
| download | emacs-82a3da21ffece64ce9f4f99f35cbc0afe851e6ee.tar.gz emacs-82a3da21ffece64ce9f4f99f35cbc0afe851e6ee.zip | |
Make electric-pair-mode, delete-selection-mode and CC Mode cooperate.
Fixes debbugs#21275.
In Emacs >= 25, let electric-pair-mode take precedence over
delete-selection-mode.
delsel.el (delete-selection-uses-region-p): New function, previously a
lambda expression in a property value for `self-insert-command'.
(top-level) Set the `delete-selection' property of `self-insert-command'
to `delete-selection-uses-region-p'.
progmodes/cc-cmds.el (top-level): Give the `delete-selection' property
for c-electric-\(brace\|paren\) the value `delete-selection-uses-region-p'
when the latter function exists.
Diffstat (limited to 'lisp/progmodes')
| -rw-r--r-- | lisp/progmodes/cc-cmds.el | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/lisp/progmodes/cc-cmds.el b/lisp/progmodes/cc-cmds.el index c9f59451b7e..0beaf268a80 100644 --- a/lisp/progmodes/cc-cmds.el +++ b/lisp/progmodes/cc-cmds.el | |||
| @@ -2853,19 +2853,28 @@ sentence motion in or near comments and multiline strings." | |||
| 2853 | 2853 | ||
| 2854 | ;; set up electric character functions to work with pending-del, | 2854 | ;; set up electric character functions to work with pending-del, |
| 2855 | ;; (a.k.a. delsel) mode. All symbols get the t value except | 2855 | ;; (a.k.a. delsel) mode. All symbols get the t value except |
| 2856 | ;; the functions which delete, which gets 'supersede. | 2856 | ;; the functions which delete, which gets 'supersede, and (from Emacs |
| 2857 | ;; 25) `c-electric-brace' and `c-electric-paren' get special handling | ||
| 2858 | ;; so as to work gracefully with `electric-pair-mode'. | ||
| 2857 | (mapc | 2859 | (mapc |
| 2858 | (function | 2860 | (function |
| 2859 | (lambda (sym) | 2861 | (lambda (sym) |
| 2860 | (put sym 'delete-selection t) ; for delsel (Emacs) | 2862 | (put sym 'delete-selection t) ; for delsel (Emacs) |
| 2861 | (put sym 'pending-delete t))) ; for pending-del (XEmacs) | 2863 | (put sym 'pending-delete t))) ; for pending-del (XEmacs) |
| 2862 | '(c-electric-pound | 2864 | '(c-electric-pound |
| 2863 | c-electric-brace | ||
| 2864 | c-electric-slash | 2865 | c-electric-slash |
| 2865 | c-electric-star | 2866 | c-electric-star |
| 2866 | c-electric-semi&comma | 2867 | c-electric-semi&comma |
| 2867 | c-electric-lt-gt | 2868 | c-electric-lt-gt |
| 2868 | c-electric-colon | 2869 | c-electric-colon)) |
| 2870 | (mapc | ||
| 2871 | (function | ||
| 2872 | (lambda (sym) | ||
| 2873 | (put sym 'delete-selection (if (fboundp 'delete-selection-uses-region-p) | ||
| 2874 | 'delete-selection-uses-region-p | ||
| 2875 | t)) | ||
| 2876 | (put sym 'pending-delete t))) | ||
| 2877 | '(c-electric-brace | ||
| 2869 | c-electric-paren)) | 2878 | c-electric-paren)) |
| 2870 | (put 'c-electric-delete 'delete-selection 'supersede) ; delsel | 2879 | (put 'c-electric-delete 'delete-selection 'supersede) ; delsel |
| 2871 | (put 'c-electric-delete 'pending-delete 'supersede) ; pending-del | 2880 | (put 'c-electric-delete 'pending-delete 'supersede) ; pending-del |