]> git.eshelyaron.com Git - emacs.git/commitdiff
Fix numerical `comment-padding' value
authorLars Ingebrigtsen <larsi@gnus.org>
Thu, 28 Jan 2021 08:57:48 +0000 (09:57 +0100)
committerLars Ingebrigtsen <larsi@gnus.org>
Thu, 28 Jan 2021 08:57:48 +0000 (09:57 +0100)
* lisp/newcomment.el (comment-padright): Allow using a number for
`comment-padding', like the doc string says (bug#40056).

lisp/newcomment.el

index 4216fc1a397fec1b970c0798d19efe873e43429c..ea47eec4fda11cb9cf199cc7a5fecb3341a5826d 100644 (file)
@@ -832,12 +832,17 @@ Ensure that `comment-normalize-vars' has been called before you use this."
   (when (and (stringp str) (string-match "\\S-" str))
     ;; Separate the actual string from any leading/trailing padding
     (string-match "\\`\\s-*\\(.*?\\)\\s-*\\'" str)
-    (let ((s (match-string 1 str))     ;actual string
+    (let ((s (match-string 1 str))                     ;actual string
          (lpad (substring str 0 (match-beginning 1))) ;left padding
-         (rpad (concat (substring str (match-end 1)) ;original right padding
-                       (substring comment-padding ;additional right padding
-                                  (min (- (match-end 0) (match-end 1))
-                                       (length comment-padding)))))
+         (rpad (concat
+                 (substring str (match-end 1)) ;original right padding
+                 (if (numberp comment-padding)
+                     (make-string (min comment-padding
+                                       (- (match-end 0) (match-end 1)))
+                                  ?\s)
+                  (substring comment-padding ;additional right padding
+                             (min (- (match-end 0) (match-end 1))
+                                  (length comment-padding))))))
          ;; We can only duplicate C if the comment-end has multiple chars
          ;; or if comments can be nested, else the comment-end `}' would
          ;; be turned into `}}}' where only the first ends the comment
@@ -852,7 +857,7 @@ Ensure that `comment-normalize-vars' has been called before you use this."
        (concat (mapconcat (lambda (c) (concat (regexp-quote (string c)) "?"))
                           lpad "")     ;padding is not required
                (regexp-quote s)
-               (when multi "+")        ;the last char of S might be repeated
+               (when multi "+") ;the last char of S might be repeated
                (mapconcat (lambda (c) (concat (regexp-quote (string c)) "?"))
                           rpad "")))))) ;padding is not required