From: Bastien <bzg@gnu.org>
To: emacs-orgmode@gnu.org
Subject: [PATCH] C-3 C-c C-w to copy the subtree instead of moving it
Date: Fri, 05 Jul 2013 14:45:43 +0200 [thread overview]
Message-ID: <87siztfa4o.fsf@bzg.ath.cx> (raw)
[-- Attachment #1: Type: text/plain, Size: 253 bytes --]
When taking notes in a meeting, I often need to refile a subtree by
copying it (so that it stays in the meeting's notes.) For now you
can do this by setting (setq org-refile-keep t) but having this on
a temporary basis is nice.
This patch does this.
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: 0001-org.el-org-refile-allow-to-only-copy-the-subtree-wit.patch --]
[-- Type: text/x-patch, Size: 1785 bytes --]
From d35926a24d3741453d9ee2bc837ec540cccfae09 Mon Sep 17 00:00:00 2001
From: Bastien Guerry <bzg@altern.org>
Date: Fri, 5 Jul 2013 13:47:28 +0200
Subject: [PATCH] org.el (org-refile): allow to only copy the subtree without
moving it
* org.el (org-refile): With a numeric prefix argument of `3',
emulate (setq org-refile-keep t) and copy the subtree to the
target location, don't delete it.
---
lisp/org.el | 9 +++++++--
1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/lisp/org.el b/lisp/org.el
index 7ba78f5..5a386a0 100644
--- a/lisp/org.el
+++ b/lisp/org.el
@@ -11485,7 +11485,11 @@ and not actually move anything.
With a double prefix arg \\[universal-argument] \\[universal-argument], \
go to the location where the last refiling operation has put the subtree.
-With a prefix argument of `2', refile to the running clock.
+
+With a numeric prefix argument of `2', refile to the running clock.
+
+With a numeric prefix argument of `3', emulate `org-refile-keep'
+being set to `t' and copy to the target location, don't move it.
RFLOC can be a refile location obtained in a different way.
@@ -11508,6 +11512,7 @@ prefix argument (`C-u C-u C-u C-c C-w')."
(region-start (and regionp (region-beginning)))
(region-end (and regionp (region-end)))
(filename (buffer-file-name (buffer-base-buffer cbuf)))
+ (org-refile-keep (if (equal goto 3) t org-refile-keep))
pos it nbuf file re level reversed)
(setq last-command nil)
(when regionp
@@ -11566,7 +11571,7 @@ prefix argument (`C-u C-u C-u C-c C-w')."
(setq nbuf (or (find-buffer-visiting file)
(find-file-noselect file)))
- (if goto
+ (if (and goto (not (equal goto 3)))
(progn
(org-pop-to-buffer-same-window nbuf)
(goto-char pos)
--
1.8.2.2
[-- Attachment #3: Type: text/plain, Size: 14 bytes --]
--
Bastien
next reply other threads:[~2013-07-05 12:46 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-07-05 12:45 Bastien [this message]
2013-07-08 8:01 ` [PATCH] C-3 C-c C-w to copy the subtree instead of moving it Carsten Dominik
2013-07-08 8:26 ` Bastien
2013-07-08 8:35 ` Carsten Dominik
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.orgmode.org/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87siztfa4o.fsf@bzg.ath.cx \
--to=bzg@gnu.org \
--cc=emacs-orgmode@gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).