From 59111b77efad2583e432a86479ccf8d175077e8e Mon Sep 17 00:00:00 2001 From: Nicolas Goaziou Date: Sun, 16 Nov 2014 15:47:40 +0100 Subject: [PATCH] Fix `org-insert-heading' * lisp/org.el (org-insert-heading): Fix some corner case when point is in an invisible list. * testing/lisp/test-org.el (test-org/insert-heading): Add tests. Reported-by: Luke Crook --- lisp/org.el | 4 +--- testing/lisp/test-org.el | 30 ++++++++++++++++++++++++++++++ 2 files changed, 31 insertions(+), 3 deletions(-) diff --git a/lisp/org.el b/lisp/org.el index 634374662..cd03230a3 100644 --- a/lisp/org.el +++ b/lisp/org.el @@ -7621,9 +7621,7 @@ command." (insert "\n* "))) (run-hooks 'org-insert-heading-hook)) - ((and itemp (not (member arg '((4) (16))))) - ;; Insert an item - (org-insert-item)) + ((and itemp (not (member arg '((4) (16)))) (org-insert-item))) (t ;; Maybe move at the end of the subtree diff --git a/testing/lisp/test-org.el b/testing/lisp/test-org.el index acd3d54cf..b542c08da 100644 --- a/testing/lisp/test-org.el +++ b/testing/lisp/test-org.el @@ -429,6 +429,36 @@ (let ((org-M-RET-may-split-line '((default . nil)))) (org-insert-heading)) (buffer-string)))) + ;; When on a list, insert an item instead, unless called with an + ;; universal argument or if list is invisible. In this case, create + ;; a new headline after contents. + (should + (equal "* H\n- item\n- " + (org-test-with-temp-text "* H\n- item" + (let ((org-insert-heading-respect-content nil)) + (org-insert-heading)) + (buffer-string)))) + (should + (equal "* H\n- item\n- item 2\n* " + (org-test-with-temp-text "* H\n- item\n- item 2" + (let ((org-insert-heading-respect-content nil)) + (org-insert-heading '(4))) + (buffer-string)))) + (should + (equal "* H\n- item\n* " + (org-test-with-temp-text "* H\n- item" + (org-cycle) + (goto-char (point-max)) + (let ((org-insert-heading-respect-content nil)) (org-insert-heading)) + (buffer-string)))) + ;; When called with two universal arguments, insert a new headline + ;; at the end of the grandparent subtree. + (should + (equal "* H1\n** H3\n- item\n** H2\n** " + (org-test-with-temp-text "* H1\n** H3\n- item\n** H2" + (let ((org-insert-heading-respect-content nil)) + (org-insert-heading '(16))) + (buffer-string)))) ;; Corner case: correctly insert a headline after an empty one. (should (equal "* \n* "