]> git.eshelyaron.com Git - emacs.git/commitdiff
duplicate-line: fix optional argument and add test (bug#46621)
authorMattias Engdegård <mattiase@acm.org>
Wed, 22 Jun 2022 13:55:19 +0000 (15:55 +0200)
committerMattias Engdegård <mattiase@acm.org>
Wed, 22 Jun 2022 14:03:46 +0000 (16:03 +0200)
The test assumes that the current semantics are intended and desired,
which may or may not be true, but it's better than not having any at
all.

* lisp/misc.el (duplicate-line): Don't crash if called with no argument.
* test/lisp/misc-tests.el (misc--duplicate-line): New test.

lisp/misc.el
test/lisp/misc-tests.el

index 3fb30e5372f12bf6f102071818e158de4fb43425..8a01b51c6d391dd70236ebeb40b512d246e49931 100644 (file)
@@ -69,6 +69,8 @@ Also see the `duplicate-line' command."
 Interactively, N is the prefix numeric argument, and defaults to 1.
 Also see the `copy-from-above-command' command."
   (interactive "p")
+  (unless n
+    (setq n 1))
   (let ((line (buffer-substring (line-beginning-position) (line-end-position))))
     (save-excursion
       (forward-line 1)
index 236223ef493b5a7f8e917a7f9ef926e9db60fd86..a56feaa04951a3d258ee729d5004f2ba75f77010 100644 (file)
     (backward-to-word 3)
     (should (equal (point) 1))))
 
+(ert-deftest misc--duplicate-line ()
+  ;; Duplicate a line (twice).
+  (with-temp-buffer
+    (insert "abc\ndefg\nh\n")
+    (goto-char 7)
+    (duplicate-line 2)
+    (should (equal (buffer-string) "abc\ndefg\ndefg\ndefg\nh\n"))
+    (should (equal (point) 7)))
+  ;; Duplicate a non-terminated line.
+  (with-temp-buffer
+    (insert "abc")
+    (goto-char 2)
+    (duplicate-line)
+    (should (equal (buffer-string) "abc\nabc\n"))
+    (should (equal (point) 2))))
+
 (provide 'misc-tests)
 ;;; misc-tests.el ends here