mirror of
https://git.savannah.gnu.org/git/emacs/org-mode.git
synced 2025-01-20 19:24:20 +00:00
Modify behavior at headling insertion.
C-RET now always inserts a heading, never an item. The folding state of the heading before the newly inserted one is preserved. Patch by Peter Jones.
This commit is contained in:
parent
69bf8ef2b4
commit
61cf8cd7ac
@ -897,8 +897,9 @@ of a headline), then a headline like the current one will be inserted
|
||||
after the end of the subtree.
|
||||
@kindex C-@key{RET}
|
||||
@item C-@key{RET}
|
||||
Just like @kbd{M-@key{RET}}, but if the heading is inserted after the current,
|
||||
insert it actually after the entire subtree.
|
||||
Just like @kbd{M-@key{RET}}, except when adding a new heading below the
|
||||
current heading, the new heading is placed after the body instead of before
|
||||
it. This command works from anywhere in the entry.
|
||||
@kindex M-S-@key{RET}
|
||||
@item M-S-@key{RET}
|
||||
Insert new TODO entry with same level as current heading.
|
||||
|
@ -1,3 +1,10 @@
|
||||
2008-10-22 Carsten Dominik <dominik@science.uva.nl>
|
||||
|
||||
* org.el (org-insert-heading-respect-content): Force heading
|
||||
creation.
|
||||
(org-insert-heading): keep the folding state of the heading before
|
||||
the inserted one.
|
||||
|
||||
2008-10-21 Carsten Dominik <dominik@science.uva.nl>
|
||||
|
||||
* org-archive.el (org-archive-to-archive-sibling): Handle top
|
||||
|
21
lisp/org.el
21
lisp/org.el
@ -4607,7 +4607,7 @@ but create the new hedline after the current line."
|
||||
(match-string 0))
|
||||
(error "*"))))
|
||||
(blank (cdr (assq 'heading org-blank-before-new-entry)))
|
||||
pos)
|
||||
pos hide-previous)
|
||||
(cond
|
||||
((and (org-on-heading-p) (bolp)
|
||||
(or (bobp)
|
||||
@ -4622,6 +4622,9 @@ but create the new hedline after the current line."
|
||||
nil)
|
||||
(t
|
||||
;; in the middle of the line
|
||||
(save-excursion
|
||||
(end-of-line)
|
||||
(setq hide-previous (org-invisible-p)))
|
||||
(org-show-entry)
|
||||
(let ((split
|
||||
(org-get-alist-option org-M-RET-may-split-line 'headline))
|
||||
@ -4652,6 +4655,10 @@ but create the new hedline after the current line."
|
||||
(setq pos (point))
|
||||
(end-of-line 1)
|
||||
(unless (= (point) pos) (just-one-space) (backward-delete-char 1))
|
||||
(when (and org-insert-heading-respect-content hide-previous)
|
||||
(save-excursion
|
||||
(outline-previous-visible-heading 1)
|
||||
(hide-entry)))
|
||||
(run-hooks 'org-insert-heading-hook)))))
|
||||
|
||||
(defun org-get-heading (&optional no-tags)
|
||||
@ -4675,20 +4682,20 @@ but create the new hedline after the current line."
|
||||
(defun org-insert-heading-respect-content ()
|
||||
(interactive)
|
||||
(let ((org-insert-heading-respect-content t))
|
||||
(call-interactively 'org-insert-heading)))
|
||||
(org-insert-heading t)))
|
||||
|
||||
(defun org-insert-todo-heading-respect-content ()
|
||||
(interactive)
|
||||
(defun org-insert-todo-heading-respect-content (&optional force-state)
|
||||
(interactive "P")
|
||||
(let ((org-insert-heading-respect-content t))
|
||||
(call-interactively 'org-insert-todo-heading)))
|
||||
(org-insert-todo-heading force-state t)))
|
||||
|
||||
(defun org-insert-todo-heading (arg)
|
||||
(defun org-insert-todo-heading (arg &optional force-heading)
|
||||
"Insert a new heading with the same level and TODO state as current heading.
|
||||
If the heading has no TODO state, or if the state is DONE, use the first
|
||||
state (TODO by default). Also with prefix arg, force first state."
|
||||
(interactive "P")
|
||||
(when (not (org-insert-item 'checkbox))
|
||||
(org-insert-heading)
|
||||
(org-insert-heading force-heading)
|
||||
(save-excursion
|
||||
(org-back-to-heading)
|
||||
(outline-previous-heading)
|
||||
|
Loading…
Reference in New Issue
Block a user