org-refile: Don't copy the refiled subtree to the clipboard

* org.el (org-paste-subtree): New parameter `remove', to
remove the pasted subtree from the `kill-ring'.
(org-refile): Use the new parameter of `org-paste-subtree'.

Thanks to Samuel Wales for suggesting this.
This commit is contained in:
Bastien Guerry 2014-07-28 00:49:01 +02:00
parent 99f999944e
commit aef3b6c3f9
1 changed files with 7 additions and 4 deletions

View File

@ -8417,7 +8417,7 @@ useful if the caller implements cut-and-paste as copy-then-paste-then-cut."
(if cut "Cut" "Copied") (if cut "Cut" "Copied")
(length org-subtree-clip))))) (length org-subtree-clip)))))
(defun org-paste-subtree (&optional level tree for-yank) (defun org-paste-subtree (&optional level tree for-yank remove)
"Paste the clipboard as a subtree, with modification of headline level. "Paste the clipboard as a subtree, with modification of headline level.
The entire subtree is promoted or demoted in order to match a new headline The entire subtree is promoted or demoted in order to match a new headline
level. level.
@ -8440,7 +8440,9 @@ If optional TREE is given, use this text instead of the kill ring.
When FOR-YANK is set, this is called by `org-yank'. In this case, do not When FOR-YANK is set, this is called by `org-yank'. In this case, do not
move back over whitespace before inserting, and move point to the end of move back over whitespace before inserting, and move point to the end of
the inserted text when done." the inserted text when done.
When REMOVE is non-nil, remove the subtree from the clipboard."
(interactive "P") (interactive "P")
(setq tree (or tree (and kill-ring (current-kill 0)))) (setq tree (or tree (and kill-ring (current-kill 0))))
(unless (org-kill-is-subtree-p tree) (unless (org-kill-is-subtree-p tree)
@ -8524,7 +8526,8 @@ the inserted text when done."
org-subtree-clip-folded) org-subtree-clip-folded)
;; The tree was folded before it was killed/copied ;; The tree was folded before it was killed/copied
(hide-subtree)) (hide-subtree))
(and for-yank (goto-char newend))))) (and for-yank (goto-char newend))
(and remove (setq kill-ring (cdr kill-ring))))))
(defun org-kill-is-subtree-p (&optional txt) (defun org-kill-is-subtree-p (&optional txt)
"Check if the current kill is an outline subtree, or a set of trees. "Check if the current kill is an outline subtree, or a set of trees.
@ -11871,7 +11874,7 @@ prefix argument (`C-u C-u C-u C-c C-w')."
(goto-char (point-min)) (goto-char (point-min))
(or (outline-next-heading) (goto-char (point-max))))) (or (outline-next-heading) (goto-char (point-max)))))
(if (not (bolp)) (newline)) (if (not (bolp)) (newline))
(org-paste-subtree level) (org-paste-subtree level nil nil t)
(when org-log-refile (when org-log-refile
(org-add-log-setup 'refile nil nil 'findpos org-log-refile) (org-add-log-setup 'refile nil nil 'findpos org-log-refile)
(unless (eq org-log-refile 'note) (unless (eq org-log-refile 'note)