* org babel before excute hook
@ 2013-10-11 13:56 Henning Redestig
2013-10-11 20:31 ` John Kitchin
0 siblings, 1 reply; 11+ messages in thread
From: Henning Redestig @ 2013-10-11 13:56 UTC (permalink / raw)
To: emacs-orgmode
[-- Attachment #1: Type: text/plain, Size: 765 bytes --]
I collaborate with different people on the same orgfile which contains many
source blocks that generate graphics by e.g. :results graphics abc.pdf
It can happen that I or someone else accidentally create another
independent source block that overwrites my abc.pdf which is of course very
bad.
I would like to add functionality so that org-babel-execute-src-block
checks if in :results graphics FILE, FILE is already referred to by another
source block and if so refuse to evaluate.
However, I only see a org-babel-after-execute-hook but no
org-babel-before-execute-hook
any reason for this? I could try to write a patch but thought I'd ask
first.
....or if there is an even better approach to avoid overwriting output from
different source blocks..
//Henning
[-- Attachment #2: Type: text/html, Size: 905 bytes --]
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: org babel before excute hook
2013-10-11 13:56 org babel before excute hook Henning Redestig
@ 2013-10-11 20:31 ` John Kitchin
2013-10-12 2:28 ` Charles Berry
0 siblings, 1 reply; 11+ messages in thread
From: John Kitchin @ 2013-10-11 20:31 UTC (permalink / raw)
Cc: emacs-orgmode@gnu.org
[-- Attachment #1: Type: text/plain, Size: 1448 bytes --]
I have a related kind of problem. When preparing notes for a class, I may
end up with 70 code blocks in an org file, many of which create graphics. I
am always worried about accidentally using the same filename and
overwriting a graphic from an earlier block. A unique, but reproducible
filename would be sufficient for my needs.
John
John
-----------------------------------
John Kitchin
Associate Professor
Doherty Hall A207F
Department of Chemical Engineering
Carnegie Mellon University
Pittsburgh, PA 15213
412-268-7803
http://kitchingroup.cheme.cmu.edu
On Fri, Oct 11, 2013 at 9:56 AM, Henning Redestig <henning.red@gmail.com>wrote:
> I collaborate with different people on the same orgfile which contains
> many source blocks that generate graphics by e.g. :results graphics abc.pdf
>
> It can happen that I or someone else accidentally create another
> independent source block that overwrites my abc.pdf which is of course very
> bad.
>
> I would like to add functionality so that org-babel-execute-src-block
> checks if in :results graphics FILE, FILE is already referred to by another
> source block and if so refuse to evaluate.
>
> However, I only see a org-babel-after-execute-hook but no
> org-babel-before-execute-hook
>
> any reason for this? I could try to write a patch but thought I'd ask
> first.
>
> ....or if there is an even better approach to avoid overwriting output
> from different source blocks..
>
> //Henning
>
[-- Attachment #2: Type: text/html, Size: 2151 bytes --]
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: org babel before excute hook
2013-10-11 20:31 ` John Kitchin
@ 2013-10-12 2:28 ` Charles Berry
2013-10-12 13:11 ` Henning Redestig
2013-10-13 21:22 ` Henning Redestig
0 siblings, 2 replies; 11+ messages in thread
From: Charles Berry @ 2013-10-12 2:28 UTC (permalink / raw)
To: emacs-orgmode
John Kitchin <jkitchin <at> andrew.cmu.edu> writes:
>
>
>
> I have a related kind of problem. When preparing notes
> for a class, I may end up with 70 code blocks in an org file, many of
> which create graphics. I am always worried about accidentally using the
> same filename and overwriting a graphic from an earlier block. A unique,
> but reproducible filename would be sufficient for my needs.
>
Header arg values can be elisp calls. You can use `make-temp-file'.
So every time this block is executed, a new file is created and the
file link is added to the results.
#+BEGIN_SRC R :results output append :file (make-temp-file "temp")
cat(date(),"\n")
#+END_SRC
#+RESULTS:
[[file:/var/folders/kb/2hchpbyj7lb6z76l0q73w_fh0000gn/T/temp302IjV]]
[[file:/var/folders/kb/2hchpbyj7lb6z76l0q73w_fh0000gn/T/temp3028Lu]]
See `temporary-file-directory', too, if you want to use this, as the
default may not be what you intend.
You might want to use this:
#+BEGIN_SRC emacs-lisp
(defun local-tfile (file)
(let ((temporary-file-directory "."))
(make-temp-file file)))
#+END_SRC
Then the files go in the local directory when this is executed:
#+BEGIN_SRC R :file (local-tfile "tfile") :results output append
cat(date(),"\n")
#+END_SRC
You might not want `append' in this case.
HTH,
Chuck
[rest deleted]
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: org babel before excute hook
2013-10-12 2:28 ` Charles Berry
@ 2013-10-12 13:11 ` Henning Redestig
2013-10-13 21:22 ` Henning Redestig
1 sibling, 0 replies; 11+ messages in thread
From: Henning Redestig @ 2013-10-12 13:11 UTC (permalink / raw)
Cc: emacs-orgmode
[-- Attachment #1: Type: text/plain, Size: 2343 bytes --]
I thought about temp files, but that makes the file names cryptic which is
inconvenient for communication without people outside org.. also, I tend
recompile figures many times which would cause a lot of cluttering files
that are hard to delete since you don't know which file is the one
currently linked in your org file...
Anyway, I made this instead which appears to work as I intended
(defun org-babel-about-to-overwrite-file ()
(let ((info (org-babel-get-src-block-info)))
(setq result-file (cdr (assoc :file (nth 2 info))))
(if (save-excursion
(goto-char 0)
(re-search-forward (concat ":file +" result-file) nil t)
(re-search-forward (concat ":file +" result-file) nil t))
(message (concat result-file " defined in more than one source block"))
(org-babel-execute-maybe))))
(add-hook 'org-ctrl-c-ctrl-c-hook 'org-babel-about-to-overwrite-file)
2013/10/12 Charles Berry <ccberry@ucsd.edu>
> John Kitchin <jkitchin <at> andrew.cmu.edu> writes:
>
> >
> >
> >
> > I have a related kind of problem. When preparing notes
> > for a class, I may end up with 70 code blocks in an org file, many of
> > which create graphics. I am always worried about accidentally using the
> > same filename and overwriting a graphic from an earlier block. A unique,
> > but reproducible filename would be sufficient for my needs.
> >
>
> Header arg values can be elisp calls. You can use `make-temp-file'.
>
> So every time this block is executed, a new file is created and the
> file link is added to the results.
>
> #+BEGIN_SRC R :results output append :file (make-temp-file "temp")
> cat(date(),"\n")
> #+END_SRC
>
> #+RESULTS:
> [[file:/var/folders/kb/2hchpbyj7lb6z76l0q73w_fh0000gn/T/temp302IjV]]
> [[file:/var/folders/kb/2hchpbyj7lb6z76l0q73w_fh0000gn/T/temp3028Lu]]
>
> See `temporary-file-directory', too, if you want to use this, as the
> default may not be what you intend.
>
>
> You might want to use this:
>
> #+BEGIN_SRC emacs-lisp
> (defun local-tfile (file)
> (let ((temporary-file-directory "."))
> (make-temp-file file)))
> #+END_SRC
>
> Then the files go in the local directory when this is executed:
>
> #+BEGIN_SRC R :file (local-tfile "tfile") :results output append
> cat(date(),"\n")
> #+END_SRC
>
> You might not want `append' in this case.
>
>
> HTH,
>
> Chuck
>
> [rest deleted]
>
>
>
>
>
[-- Attachment #2: Type: text/html, Size: 3519 bytes --]
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: org babel before excute hook
2013-10-12 2:28 ` Charles Berry
2013-10-12 13:11 ` Henning Redestig
@ 2013-10-13 21:22 ` Henning Redestig
2013-10-13 21:35 ` Samuel Wales
2013-10-14 13:29 ` Eric Schulte
1 sibling, 2 replies; 11+ messages in thread
From: Henning Redestig @ 2013-10-13 21:22 UTC (permalink / raw)
To: emacs-orgmode
[-- Attachment #1: Type: text/plain, Size: 1776 bytes --]
Is it possible to add a function to org-ctrl-c-ctrl-c-hook without patching
ob-core.el? If I just add something like
(add-hook 'org-ctrl-c-ctrl-c-hook 'org-babel-stop-if-file-collision)
in my .emacs I notice that my addition gets overwritten later via the
autoloads (I think) that are defined in ob-core.el..
2013/10/12 Charles Berry <ccberry@ucsd.edu>
> John Kitchin <jkitchin <at> andrew.cmu.edu> writes:
>
> >
> >
> >
> > I have a related kind of problem. When preparing notes
> > for a class, I may end up with 70 code blocks in an org file, many of
> > which create graphics. I am always worried about accidentally using the
> > same filename and overwriting a graphic from an earlier block. A unique,
> > but reproducible filename would be sufficient for my needs.
> >
>
> Header arg values can be elisp calls. You can use `make-temp-file'.
>
> So every time this block is executed, a new file is created and the
> file link is added to the results.
>
> #+BEGIN_SRC R :results output append :file (make-temp-file "temp")
> cat(date(),"\n")
> #+END_SRC
>
> #+RESULTS:
> [[file:/var/folders/kb/2hchpbyj7lb6z76l0q73w_fh0000gn/T/temp302IjV]]
> [[file:/var/folders/kb/2hchpbyj7lb6z76l0q73w_fh0000gn/T/temp3028Lu]]
>
> See `temporary-file-directory', too, if you want to use this, as the
> default may not be what you intend.
>
>
> You might want to use this:
>
> #+BEGIN_SRC emacs-lisp
> (defun local-tfile (file)
> (let ((temporary-file-directory "."))
> (make-temp-file file)))
> #+END_SRC
>
> Then the files go in the local directory when this is executed:
>
> #+BEGIN_SRC R :file (local-tfile "tfile") :results output append
> cat(date(),"\n")
> #+END_SRC
>
> You might not want `append' in this case.
>
>
> HTH,
>
> Chuck
>
> [rest deleted]
>
>
>
>
>
[-- Attachment #2: Type: text/html, Size: 2495 bytes --]
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: org babel before excute hook
2013-10-13 21:22 ` Henning Redestig
@ 2013-10-13 21:35 ` Samuel Wales
2013-10-14 6:45 ` Henning Redestig
2013-10-14 13:24 ` Eric Schulte
2013-10-14 13:29 ` Eric Schulte
1 sibling, 2 replies; 11+ messages in thread
From: Samuel Wales @ 2013-10-13 21:35 UTC (permalink / raw)
To: Henning Redestig; +Cc: emacs-orgmode
In case it helps, there is org-confirm-babel-evaluate.
(But I have not found it to be useful, because it does not seem to
place point in a place where you can check properties, etc.)
Samuel
--
The Kafka Pandemic: http://thekafkapandemic.blogspot.com
The disease DOES progress. MANY people have died from it. ANYBODY can get it.
Denmark: free Karina Hansen NOW.
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: org babel before excute hook
2013-10-13 21:35 ` Samuel Wales
@ 2013-10-14 6:45 ` Henning Redestig
2013-10-14 8:11 ` [babel] Feature request - WAS: " Rainer M Krug
2013-10-14 13:24 ` Eric Schulte
1 sibling, 1 reply; 11+ messages in thread
From: Henning Redestig @ 2013-10-14 6:45 UTC (permalink / raw)
To: emacs-orgmode; +Cc: John Kitchin
[-- Attachment #1: Type: text/plain, Size: 1142 bytes --]
if anyone is interested in this, a simple defadvice appears to be a good
option, I put
(defadvice org-babel-execute-maybe (around org-babel-stop-on-collision)
"stop execution of result file defined more than once"
(let ((info (org-babel-get-src-block-info)))
(setq result-file (cdr (assoc :file (nth 2 info))))
(if (save-excursion
(goto-char 0)
(re-search-forward (concat ":file +" result-file) nil t)
(re-search-forward (concat ":file +" result-file) nil t))
(error (concat result-file " defined in more than one source
block"))
ad-do-it)))
(ad-activate 'org-babel-execute-maybe)
in my .emacs and appear to get the desired functionality
2013/10/13 Samuel Wales <samologist@gmail.com>
> In case it helps, there is org-confirm-babel-evaluate.
>
> (But I have not found it to be useful, because it does not seem to
> place point in a place where you can check properties, etc.)
>
> Samuel
>
> --
> The Kafka Pandemic: http://thekafkapandemic.blogspot.com
>
> The disease DOES progress. MANY people have died from it. ANYBODY can
> get it.
>
> Denmark: free Karina Hansen NOW.
>
[-- Attachment #2: Type: text/html, Size: 1734 bytes --]
^ permalink raw reply [flat|nested] 11+ messages in thread
* [babel] Feature request - WAS: org babel before excute hook
2013-10-14 6:45 ` Henning Redestig
@ 2013-10-14 8:11 ` Rainer M Krug
0 siblings, 0 replies; 11+ messages in thread
From: Rainer M Krug @ 2013-10-14 8:11 UTC (permalink / raw)
To: emacs-orgmode
At the moment, I have the feeling that there is no solution to the
actual problem (avoiding duplicate :file names) without doctoring in an
unsatisfying (and potentially fragile?) way.
I would therefore formulate a feature request:
It is a common error to accidentally use the same :file name and to have
consequently the wrong file in the exported file.
I would therefore suggest a property with the following possible values:
,----
| file_unique
|
| - false :: the actual behaviour, i.e. consequtive :file overwrite the
| original ones *without* warning
| - true :: if more then one :file exist, an consecutive number is automatically
| to the :file and cached to avoid having leftover files (as in temp files)
| - warn :: give a warning on export, so that this error can be fixed
| manually.
`----
I would see this as a valuable addition to the export feature as it
avoids errors.
Cheers,
Rainer
Henning Redestig <henning.red@gmail.com> writes:
> if anyone is interested in this, a simple defadvice appears to be a good
> option, I put
>
> (defadvice org-babel-execute-maybe (around org-babel-stop-on-collision)
> "stop execution of result file defined more than once"
> (let ((info (org-babel-get-src-block-info)))
> (setq result-file (cdr (assoc :file (nth 2 info))))
> (if (save-excursion
> (goto-char 0)
> (re-search-forward (concat ":file +" result-file) nil t)
> (re-search-forward (concat ":file +" result-file) nil t))
> (error (concat result-file " defined in more than one source
> block"))
> ad-do-it)))
> (ad-activate 'org-babel-execute-maybe)
>
>
> in my .emacs and appear to get the desired functionality
>
>
>
>
> 2013/10/13 Samuel Wales <samologist@gmail.com>
>
>> In case it helps, there is org-confirm-babel-evaluate.
>>
>> (But I have not found it to be useful, because it does not seem to
>> place point in a place where you can check properties, etc.)
>>
>> Samuel
>>
>> --
>> The Kafka Pandemic: http://thekafkapandemic.blogspot.com
>>
>> The disease DOES progress. MANY people have died from it. ANYBODY can
>> get it.
>>
>> Denmark: free Karina Hansen NOW.
>>
<#secure method=pgpmime mode=sign>
--
Rainer M. Krug
email: RMKrug<at>gmail<dot>com
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: org babel before excute hook
2013-10-13 21:35 ` Samuel Wales
2013-10-14 6:45 ` Henning Redestig
@ 2013-10-14 13:24 ` Eric Schulte
2013-10-26 22:05 ` Samuel Wales
1 sibling, 1 reply; 11+ messages in thread
From: Eric Schulte @ 2013-10-14 13:24 UTC (permalink / raw)
To: Samuel Wales; +Cc: emacs-orgmode, Henning Redestig
Samuel Wales <samologist@gmail.com> writes:
> In case it helps, there is org-confirm-babel-evaluate.
>
> (But I have not found it to be useful, because it does not seem to
> place point in a place where you can check properties, etc.)
>
I just pushed up a change so that `org-confirm-babel-evaluate' will
always be called from the head of the code block being evaluated. So
the info can always be reached with something like the following.
(setf org-confirm-babel-evaluate
(lambda (&rest args)
(message "info: %S" (org-babel-get-src-block-info 'light))
nil))
>
> Samuel
--
Eric Schulte
https://cs.unm.edu/~eschulte
PGP: 0x614CA05D
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: org babel before excute hook
2013-10-13 21:22 ` Henning Redestig
2013-10-13 21:35 ` Samuel Wales
@ 2013-10-14 13:29 ` Eric Schulte
1 sibling, 0 replies; 11+ messages in thread
From: Eric Schulte @ 2013-10-14 13:29 UTC (permalink / raw)
To: Henning Redestig; +Cc: emacs-orgmode
Henning Redestig <henning.red@gmail.com> writes:
> Is it possible to add a function to org-ctrl-c-ctrl-c-hook without patching
> ob-core.el? If I just add something like
>
Yes, see the documentation of `org-confirm-babel-evaluate'. So the
function posted in your previous email could be changed to something
like...
(setf org-confirm-babel-evaluate
(lambda (&rest args)
(let* ((info (org-babel-get-src-block-info))
(result-file (cdr (assoc :file (nth 2 info))))
(duplicat-file-p
(save-excursion
(goto-char 0)
(re-search-forward (concat ":file +" result-file) nil t)
(re-search-forward (concat ":file +" result-file) nil t)))))
(if duplicate-file-p
(prog1 t (message "duplicate result file"))
nil)))
>
> (add-hook 'org-ctrl-c-ctrl-c-hook 'org-babel-stop-if-file-collision)
>
> in my .emacs I notice that my addition gets overwritten later via the
> autoloads (I think) that are defined in ob-core.el..
>
>
>
> 2013/10/12 Charles Berry <ccberry@ucsd.edu>
>
>> John Kitchin <jkitchin <at> andrew.cmu.edu> writes:
>>
>> >
>> >
>> >
>> > I have a related kind of problem. When preparing notes
>> > for a class, I may end up with 70 code blocks in an org file, many of
>> > which create graphics. I am always worried about accidentally using the
>> > same filename and overwriting a graphic from an earlier block. A unique,
>> > but reproducible filename would be sufficient for my needs.
>> >
>>
>> Header arg values can be elisp calls. You can use `make-temp-file'.
>>
>> So every time this block is executed, a new file is created and the
>> file link is added to the results.
>>
>> #+BEGIN_SRC R :results output append :file (make-temp-file "temp")
>> cat(date(),"\n")
>> #+END_SRC
>>
>> #+RESULTS:
>> [[file:/var/folders/kb/2hchpbyj7lb6z76l0q73w_fh0000gn/T/temp302IjV]]
>> [[file:/var/folders/kb/2hchpbyj7lb6z76l0q73w_fh0000gn/T/temp3028Lu]]
>>
>> See `temporary-file-directory', too, if you want to use this, as the
>> default may not be what you intend.
>>
>>
>> You might want to use this:
>>
>> #+BEGIN_SRC emacs-lisp
>> (defun local-tfile (file)
>> (let ((temporary-file-directory "."))
>> (make-temp-file file)))
>> #+END_SRC
>>
>> Then the files go in the local directory when this is executed:
>>
>> #+BEGIN_SRC R :file (local-tfile "tfile") :results output append
>> cat(date(),"\n")
>> #+END_SRC
>>
>> You might not want `append' in this case.
>>
>>
>> HTH,
>>
>> Chuck
>>
>> [rest deleted]
>>
>>
>>
>>
>>
--
Eric Schulte
https://cs.unm.edu/~eschulte
PGP: 0x614CA05D
^ permalink raw reply [flat|nested] 11+ messages in thread
* Re: org babel before excute hook
2013-10-14 13:24 ` Eric Schulte
@ 2013-10-26 22:05 ` Samuel Wales
0 siblings, 0 replies; 11+ messages in thread
From: Samuel Wales @ 2013-10-26 22:05 UTC (permalink / raw)
To: Eric Schulte; +Cc: emacs-orgmode, Henning Redestig
I have confirmed that this works. Thank you.
On 10/14/13, Eric Schulte <schulte.eric@gmail.com> wrote:
> I just pushed up a change so that `org-confirm-babel-evaluate' will
> always be called from the head of the code block being evaluated. So
> the info can always be reached with something like the following.
>
> (setf org-confirm-babel-evaluate
> (lambda (&rest args)
> (message "info: %S" (org-babel-get-src-block-info 'light))
> nil))
--
The Kafka Pandemic: http://thekafkapandemic.blogspot.com
The disease DOES progress. MANY people have died from it. ANYBODY can get it.
Denmark: free Karina Hansen NOW.
^ permalink raw reply [flat|nested] 11+ messages in thread
end of thread, other threads:[~2013-10-26 22:05 UTC | newest]
Thread overview: 11+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-10-11 13:56 org babel before excute hook Henning Redestig
2013-10-11 20:31 ` John Kitchin
2013-10-12 2:28 ` Charles Berry
2013-10-12 13:11 ` Henning Redestig
2013-10-13 21:22 ` Henning Redestig
2013-10-13 21:35 ` Samuel Wales
2013-10-14 6:45 ` Henning Redestig
2013-10-14 8:11 ` [babel] Feature request - WAS: " Rainer M Krug
2013-10-14 13:24 ` Eric Schulte
2013-10-26 22:05 ` Samuel Wales
2013-10-14 13:29 ` Eric Schulte
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).