]> git.eshelyaron.com Git - emacs.git/commitdiff
Fix c-ts-mode indentation for statement after preproc (bug#61893)
authorYuan Fu <casouri@gmail.com>
Fri, 3 Mar 2023 03:59:11 +0000 (19:59 -0800)
committerYuan Fu <casouri@gmail.com>
Fri, 3 Mar 2023 03:59:37 +0000 (19:59 -0800)
Originally our c-ts-mode--anchor-prev-sibling only specially handled
labeled_statements, now we add special case for preproc in the similar
fasion: instead of using the preproc directive as anchor, use the last
statement in that preproc as the anchor. Thus effectively ignore the
preproc.

There should be an accompanying test, but there are some problem in
the elif preproc directive indent so it would pass, we'll add the test
when that is fixed.

* lisp/progmodes/c-ts-mode.el:
(c-ts-mode--anchor-prev-sibling): Add special case for preproc
directives.

lisp/progmodes/c-ts-mode.el

index 3afd7a4a9134dbc161209c2d50bb9e70d6b6935a..eb07eb74676aade81d85c6a2ff055384a32de3aa 100644 (file)
@@ -282,12 +282,19 @@ PARENT and BOL are like other anchor functions."
               (or (treesit-node-prev-sibling node t)
                   (treesit-node-prev-sibling
                    (treesit-node-first-child-for-pos parent bol) t)
-                  (treesit-node-child parent -1 t))))
-    (while (and prev-sibling
-                (equal "labeled_statement"
-                       (treesit-node-type prev-sibling)))
-      ;; The 0th child is the label, the 1th the colon.
-      (setq prev-sibling (treesit-node-child prev-sibling 2)))
+                  (treesit-node-child parent -1 t)))
+             (continue t))
+    (while (and prev-sibling continue)
+      (pcase (treesit-node-type prev-sibling)
+        ;; Get the statement in the label.
+        ("labeled_statement"
+         (setq prev-sibling (treesit-node-child prev-sibling 2)))
+        ;; Get the last statement in the preproc.  Tested by
+        ;; "Prev-Sibling When Prev-Sibling is Preproc" test.
+        ((or "preproc_if" "preproc_ifdef" "preproc_elif" "preproc_else")
+         (setq prev-sibling (treesit-node-child prev-sibling -2)))
+        ;; Don't do anything special.
+        (_ (setq continue nil))))
     ;; This could be nil if a) there is no prev-sibling or b)
     ;; prev-sibling doesn't have a child.
     (treesit-node-start prev-sibling)))