]> git.eshelyaron.com Git - emacs.git/commitdiff
Improve CC Mode support for text conversion
authorPo Lu <luangruo@yahoo.com>
Fri, 2 Jun 2023 07:41:54 +0000 (15:41 +0800)
committerPo Lu <luangruo@yahoo.com>
Fri, 2 Jun 2023 07:41:54 +0000 (15:41 +0800)
* lisp/progmodes/cc-cmds.el (c-post-text-conversion): New
function.
* lisp/progmodes/cc-mode.el (c-initialize-cc-mode): Add it as
the `post-texxt-conversion-hook'.
* lisp/simple.el (post-text-conversion-hook): New hook.
(analyze-text-conversion): Run it until success before trying
post insert functions.

lisp/progmodes/cc-cmds.el
lisp/progmodes/cc-mode.el
lisp/simple.el

index 4c2340bfc2ca53888b5541ab2577083f12a9589f..15b103a081f76a3c250d1da59724338252196c57 100644 (file)
@@ -5144,6 +5144,41 @@ details."
       (goto-char here)
       (delete-char 1))))
 
+\f
+
+;; Text conversion support.
+
+(defun c-post-text-conversion ()
+  "Notice that the character `last-command-event' has been inserted.
+If said character is an electric character such as `*' or `{', delete
+it, then call the appropriate CC Mode function to electrically insert
+it again."
+  (cond ((eq last-command-event ?#)
+        (delete-char -1)
+        (c-electric-pound nil) t)
+       ((memq last-command-event '(?{ ?}))
+        (delete-char -1)
+        (c-electric-brace nil) t)
+       ((memq last-command-event '(?\( ?\)))
+        (delete-char -1)
+        (c-electric-paren nil) t)
+       ((eq last-command-event ?*)
+        (delete-char -1)
+        (c-electric-star nil) t)
+       ((eq last-command-event ?/)
+        (delete-char -1)
+        (c-electric-slash nil) t)
+       ((memq last-command-event '(?\; ?,))
+        (delete-char -1)
+        (c-electric-semi&comma nil) t)
+       ((eq last-command-event ?:)
+        (delete-char -1)
+        (c-electric-colon nil) t)
+       ((memq last-command-event '(?> ?<))
+        (delete-char -1)
+        (c-electric-lt-gt nil) t)))
+
+
 \f
 (cc-provide 'cc-cmds)
 
index 11a1d3fe6c22eedcae3b840a159c156fcfdbd1a6..1364117bdc8daf3193ffab986a322485e5156651 100644 (file)
@@ -251,7 +251,10 @@ control).  See \"cc-mode.el\" for more info."
             (when (fboundp 'electric-indent-local-mode)
              (add-hook 'electric-indent-mode-hook 'c-electric-indent-mode-hook)
               (add-hook 'electric-indent-local-mode-hook
-                        'c-electric-indent-local-mode-hook)))
+                        'c-electric-indent-local-mode-hook))
+           ;; Set up text conversion, for Emacs >= 30.0
+           (when (boundp 'post-text-conversion-hook)
+             (add-hook 'post-text-conversion-hook #'c-post-text-conversion)))
        ;; Will try initialization hooks again if they failed.
        (put 'c-initialize-cc-mode initprop c-initialization-ok))))
 
index 698458c4bc7c662b2c8cecbff650f5d41a7aedca..d23e2e20c62b41a347cab128bcc45bc482adeac4 100644 (file)
@@ -10980,7 +10980,6 @@ If the buffer doesn't exist, create it first."
 ;; Text conversion support.  See textconv.c for more details about
 ;; what this is.
 
-
 ;; Actually in textconv.c.
 (defvar text-conversion-edits)
 
@@ -10988,6 +10987,12 @@ If the buffer doesn't exist, create it first."
 (defvar electric-pair-preserve-balance)
 (declare-function electric-pair-analyze-conversion "elec-pair.el")
 
+(defvar-local post-text-conversion-hook nil
+  "Hook run after text is inserted by an input method.
+Each function in this list is run until one returns non-nil.
+When run, `last-command-event' is bound to the last character
+that was inserted by the input method.")
+
 (defun analyze-text-conversion ()
   "Analyze the results of the previous text conversion event.
 
@@ -11007,7 +11012,10 @@ For each insertion:
 
   - Run `post-self-insert-functions' for the last character of
     any inserted text so that modes such as `electric-pair-mode'
-    can work."
+    can work.
+
+  - Run `post-text-conversion-hook' with `last-command-event' set
+    to the last character of any inserted text to finish up."
   (interactive)
   ;; The list must be processed in reverse.
   (dolist (edit (reverse text-conversion-edits))
@@ -11041,7 +11049,9 @@ For each insertion:
                            (funcall auto-fill-function)))))
               (goto-char (nth 2 edit))
               (let ((last-command-event end))
-                (run-hooks 'post-self-insert-hook)))
+                (unless (run-hook-with-args-until-success
+                         'post-text-conversion-hook)
+                  (run-hooks 'post-self-insert-hook))))
           ;; Process this deletion before point.  (nth 2 edit) is the
           ;; text which was deleted.  Input methods typically prefer
           ;; to edit words instead of deleting characters off their