]> git.eshelyaron.com Git - emacs.git/commitdiff
Handle single-line comments correctly (Bug#26049)
authorAntonin Houska <ah@melesmeles.cz>
Mon, 6 Nov 2017 08:59:07 +0000 (09:59 +0100)
committerNoam Postavsky <npostavs@gmail.com>
Tue, 7 Nov 2017 00:01:19 +0000 (19:01 -0500)
* lisp/newcomment.el (comment-region-internal): Previously, the
comment text had to contain at least one line break character for the
ending extra line to be added.  Make the behavior more consistent by
looking for end of line instead.
(comment-region-internal): Remove trailing white space from the
comment's initial line.

Copyright-paperwork-exempt: yes

lisp/newcomment.el

index 2a0f8a8ae50535c51e084ba5eca1ddb0b4145f8a..66296b818280c6560627c0c5023fdee70e880dc5 100644 (file)
@@ -69,6 +69,9 @@
 
 ;;; Code:
 
+(eval-when-compile
+  (require 'subr-x))
+
 ;;;###autoload
 (defalias 'indent-for-comment 'comment-indent)
 ;;;###autoload
@@ -1141,6 +1144,9 @@ the region rather than at left margin."
 
          ;; make the leading and trailing lines if requested
          (when lines
+            ;; Trim trailing whitespace from cs if there's some.
+            (setq cs (string-trim-right cs))
+
            (let ((csce
                   (comment-make-extra-lines
                    cs ce ccs cce min-indent max-indent block)))
@@ -1211,7 +1217,7 @@ changed with `comment-style'."
           (progn (goto-char end) (end-of-line) (skip-syntax-backward " ")
                  (<= (point) end))
           (or block (not (string= "" comment-end)))
-          (or block (progn (goto-char beg) (search-forward "\n" end t)))))
+           (or block (progn (goto-char beg) (re-search-forward "$" end t)))))
 
     ;; don't add end-markers just because the user asked for `block'
     (unless (or lines (string= "" comment-end)) (setq block nil))