Fix c-ts-common-comment-indent-new-line (bug#73900)
* lisp/progmodes/c-ts-common.el: (c-ts-common-comment-indent-new-line): Delete trailing whitespace before inserting newline. The insert-line-break function is the same as in c-indent-new-comment-line.
This commit is contained in:
parent
df5ac0daf0
commit
e6a8492fab
1 changed files with 52 additions and 46 deletions
|
@ -302,55 +302,61 @@ and /* */ comments. SOFT works the same as in
|
|||
;; is a // comment, insert a newline and a // prefix; if the current
|
||||
;; line is in a /* comment, insert a newline and a * prefix. No
|
||||
;; auto-fill or other smart features.
|
||||
(cond
|
||||
;; Line starts with //, or ///, or ////...
|
||||
;; Or //! (used in rust).
|
||||
((save-excursion
|
||||
(beginning-of-line)
|
||||
(re-search-forward
|
||||
(rx "//" (group (* (any "/!")) (* " ")))
|
||||
(line-end-position)
|
||||
t nil))
|
||||
(let ((offset (- (match-beginning 0) (line-beginning-position)))
|
||||
(whitespaces (match-string 1)))
|
||||
(if soft (insert-and-inherit ?\n) (newline 1))
|
||||
(delete-region (line-beginning-position) (point))
|
||||
(insert (make-string offset ?\s) "//" whitespaces)))
|
||||
(let ((insert-line-break
|
||||
(lambda ()
|
||||
(delete-horizontal-space)
|
||||
(if soft
|
||||
(insert-and-inherit ?\n)
|
||||
(newline (if allow-auto-fill nil 1))))))
|
||||
(cond
|
||||
;; Line starts with //, or ///, or ////...
|
||||
;; Or //! (used in rust).
|
||||
((save-excursion
|
||||
(beginning-of-line)
|
||||
(re-search-forward
|
||||
(rx "//" (group (* (any "/!")) (* " ")))
|
||||
(line-end-position)
|
||||
t nil))
|
||||
(let ((offset (- (match-beginning 0) (line-beginning-position)))
|
||||
(whitespaces (match-string 1)))
|
||||
(funcall insert-line-break)
|
||||
(delete-region (line-beginning-position) (point))
|
||||
(insert (make-string offset ?\s) "//" whitespaces)))
|
||||
|
||||
;; Line starts with /* or /**.
|
||||
((save-excursion
|
||||
(beginning-of-line)
|
||||
(re-search-forward
|
||||
(rx "/*" (group (? "*") (* " ")))
|
||||
(line-end-position)
|
||||
t nil))
|
||||
(let ((offset (- (match-beginning 0) (line-beginning-position)))
|
||||
(whitespace-and-star-len (length (match-string 1))))
|
||||
(if soft (insert-and-inherit ?\n) (newline 1))
|
||||
(delete-region (line-beginning-position) (point))
|
||||
(insert
|
||||
(make-string offset ?\s)
|
||||
" *"
|
||||
(make-string whitespace-and-star-len ?\s))))
|
||||
;; Line starts with /* or /**.
|
||||
((save-excursion
|
||||
(beginning-of-line)
|
||||
(re-search-forward
|
||||
(rx "/*" (group (? "*") (* " ")))
|
||||
(line-end-position)
|
||||
t nil))
|
||||
(let ((offset (- (match-beginning 0) (line-beginning-position)))
|
||||
(whitespace-and-star-len (length (match-string 1))))
|
||||
(funcall insert-line-break)
|
||||
(delete-region (line-beginning-position) (point))
|
||||
(insert
|
||||
(make-string offset ?\s)
|
||||
" *"
|
||||
(make-string whitespace-and-star-len ?\s))))
|
||||
|
||||
;; Line starts with *.
|
||||
((save-excursion
|
||||
(beginning-of-line)
|
||||
(looking-at (rx (group (* " ") (any "*|") (* " ")))))
|
||||
(let ((prefix (match-string 1)))
|
||||
(if soft (insert-and-inherit ?\n) (newline 1))
|
||||
(delete-region (line-beginning-position) (point))
|
||||
(insert prefix)))
|
||||
;; Line starts with *.
|
||||
((save-excursion
|
||||
(beginning-of-line)
|
||||
(looking-at (rx (group (* " ") (any "*|") (* " ")))))
|
||||
(let ((prefix (match-string 1)))
|
||||
(funcall insert-line-break)
|
||||
(delete-region (line-beginning-position) (point))
|
||||
(insert prefix)))
|
||||
|
||||
;; Line starts with whitespaces or no space. This is basically the
|
||||
;; default case since (rx (* " ")) matches anything.
|
||||
((save-excursion
|
||||
(beginning-of-line)
|
||||
(looking-at (rx (* " "))))
|
||||
(let ((whitespaces (match-string 0)))
|
||||
(if soft (insert-and-inherit ?\n) (newline 1))
|
||||
(delete-region (line-beginning-position) (point))
|
||||
(insert whitespaces)))))
|
||||
;; Line starts with whitespaces or no space. This is basically the
|
||||
;; default case since (rx (* " ")) matches anything.
|
||||
((save-excursion
|
||||
(beginning-of-line)
|
||||
(looking-at (rx (* " "))))
|
||||
(let ((whitespaces (match-string 0)))
|
||||
(funcall insert-line-break)
|
||||
(delete-region (line-beginning-position) (point))
|
||||
(insert whitespaces))))))
|
||||
|
||||
;;; Statement indent
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue