From dcba39b445e8f71c5f8df34a38ae8fc726a51843 Mon Sep 17 00:00:00 2001 From: Alan Mackenzie Date: Sun, 28 Jul 2019 13:30:38 +0000 Subject: [PATCH] CC Mode. Fix (c-beginning-of-defun -1) getting stuck with structs. In particular, with an initialization such as struct foo {..} bar = {...}; * lisp/progmodes/cc-cmds.el (c-forward-to-nth-EOF-{): Rename to c-forward-to-nth-EOF-\;-or-}, and when the starting (or ending) position is in the "variable" part of a struct/class/union/enum/etc., move to after the terminating semicolon. Adjust the counting such that N only gets decremented on a successful movement over {..}. (c-beginning-of-defun, c-end-of-defun): Rename the calls to c-forward-to-nth-EOF-}, as above. --- lisp/progmodes/cc-cmds.el | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/lisp/progmodes/cc-cmds.el b/lisp/progmodes/cc-cmds.el index efc6747de48..2ccdc1d0bc8 100644 --- a/lisp/progmodes/cc-cmds.el +++ b/lisp/progmodes/cc-cmds.el @@ -1775,7 +1775,7 @@ defun." (setq arg (1+ arg))) (if (< arg 0) (c-while-widening-to-decl-block - (< (setq arg (- (c-forward-to-nth-EOF-} (- arg) where))) 0))) + (< (setq arg (- (c-forward-to-nth-EOF-\;-or-} (- arg) where))) 0))) ;; Move forward to the next opening brace.... (when (and (= arg 0) (progn @@ -1811,10 +1811,11 @@ defun." (c-keep-region-active) (= arg 0))))) -(defun c-forward-to-nth-EOF-} (n where) - ;; Skip to the closing brace of the Nth function after point. If - ;; point is inside a function, this counts as the first. Point must be - ;; outside any comment/string or macro. +(defun c-forward-to-nth-EOF-\;-or-} (n where) + ;; Skip to the closing brace or semicolon of the Nth function after point. + ;; We move to a semicolon only for things like structs which don't end at a + ;; closing brace. If point is inside a function, this counts as the first. + ;; Point must be outside any comment/string or macro. ;; ;; N must be strictly positive. ;; WHERE describes the position of point, one of the symbols `at-header', @@ -1836,23 +1837,24 @@ defun." (forward-sexp) (setq n (1- n))) ((eq where 'in-trailer) - (c-syntactic-skip-backward "^}") + ;; The actual movement is done below. (setq n (1- n))) ((memq where '(at-function-end outwith-function at-header in-header)) (when (c-syntactic-re-search-forward "{" nil 'eob) (backward-char) (forward-sexp) (setq n (1- n)))) - (t (error "c-forward-to-nth-EOF-}: `where' is %s" where))) + (t (error "c-forward-to-nth-EOF-\\;-or-}: `where' is %s" where))) + + (when (c-in-function-trailer-p) + (c-syntactic-re-search-forward ";" nil 'eob t)) ;; Each time round the loop, go forward to a "}" at the outermost level. (while (and (> n 0) (not (eobp))) - ;(c-parse-state) ; This call speeds up the following one by a factor - ; of ~6. Hmmm. 2006/4/5. (when (c-syntactic-re-search-forward "{" nil 'eob) (backward-char) - (forward-sexp)) - (setq n (1- n))) + (forward-sexp) + (setq n (1- n)))) n) (defun c-end-of-defun (&optional arg) @@ -1907,7 +1909,7 @@ the open-parenthesis that starts a defun; see `beginning-of-defun'." ;; Move forward to the } of a function (if (> arg 0) (c-while-widening-to-decl-block - (> (setq arg (c-forward-to-nth-EOF-} arg where)) 0)))) + (> (setq arg (c-forward-to-nth-EOF-\;-or-} arg where)) 0)))) ;; Do we need to move forward from the brace to the semicolon? (when (eq arg 0) -- 2.39.2