]> git.eshelyaron.com Git - emacs.git/commitdiff
Fix a recent Lisp mode filling test failure
authorLars Ingebrigtsen <larsi@gnus.org>
Sun, 26 Jun 2022 14:31:33 +0000 (16:31 +0200)
committerLars Ingebrigtsen <larsi@gnus.org>
Sun, 26 Jun 2022 14:31:43 +0000 (16:31 +0200)
* lisp/emacs-lisp/lisp-mode.el (lisp-fill-paragraph): Restore the
"fill first line separately" logic.

lisp/emacs-lisp/lisp-mode.el

index 781c80fd5a0364975f7a0c36e5ff32a3588dbb4d..6d5391d1e907bd5286079e741e69c9bc5cab6d82 100644 (file)
@@ -1426,6 +1426,9 @@ and initial semicolons."
       ;; a comment: Point is on a program line; we are interested
       ;; particularly in docstring lines.
       ;;
+      ;; FIXME: The below bindings are probably mostly irrelevant
+      ;; since we're now narrowing to a region before filling.
+      ;;
       ;; We bind `paragraph-start' and `paragraph-separate' temporarily.  They
       ;; are buffer-local, but we avoid changing them so that they can be set
       ;; to make `forward-paragraph' and friends do something the user wants.
@@ -1485,6 +1488,15 @@ and initial semicolons."
                                       (1- (point)))))
                 ;; Move back to where we were.
                 (goto-char start)
+                ;; We should fill the first line of a string
+                ;; separately (since it's usually a doc string).
+                (if (= (line-number-at-pos) 1)
+                    (narrow-to-region (line-beginning-position)
+                                      (line-beginning-position 2))
+                  (save-excursion
+                    (goto-char (point-min))
+                    (forward-line 1)
+                    (narrow-to-region (point) (point-max))))
                (fill-paragraph justify)))))))
   ;; Never return nil.
   t)