* Generating the filename from name and file-ext for blocks with side-effects
@ 2024-12-23 21:58 Aitenate
2024-12-25 15:30 ` Ihor Radchenko
0 siblings, 1 reply; 10+ messages in thread
From: Aitenate @ 2024-12-23 21:58 UTC (permalink / raw)
To: emacs-orgmode
With ~:results file~, the absence of ~:file~ will cause the filename to
be constructed from the block name and ~:file-ext~, if they are both
present. To achieve that with ~:results file link~, I could only come up
with
~:var outFile=(alist-get :file (nth 2 (org-babel-get-src-block-info
't)))~
Have I missed something obvious? Is there a better way to do this?
If there isn't, would it be acceptable to add something like
`org-babel-get-src-block-param-value' or maybe more specific like
`org-babel-get-src-block-results-file-name'?
Regards,
Aitenate
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Generating the filename from name and file-ext for blocks with side-effects
2024-12-23 21:58 Generating the filename from name and file-ext for blocks with side-effects Aitenate
@ 2024-12-25 15:30 ` Ihor Radchenko
2024-12-25 19:03 ` Aitenate
0 siblings, 1 reply; 10+ messages in thread
From: Ihor Radchenko @ 2024-12-25 15:30 UTC (permalink / raw)
To: Aitenate; +Cc: emacs-orgmode
Aitenate <aitenate@outlook.com> writes:
> With ~:results file~, the absence of ~:file~ will cause the filename to
> be constructed from the block name and ~:file-ext~, if they are both
> present. To achieve that with ~:results file link~, I could only come up
> with
>
> ~:var outFile=(alist-get :file (nth 2 (org-babel-get-src-block-info
> 't)))~
Seems right, but I do not understand why you would need such thing.
--
Ihor Radchenko // yantar92,
Org mode maintainer,
Learn more about Org mode at <https://orgmode.org/>.
Support Org development at <https://liberapay.com/org-mode>,
or support my work at <https://liberapay.com/yantar92>
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Generating the filename from name and file-ext for blocks with side-effects
2024-12-25 15:30 ` Ihor Radchenko
@ 2024-12-25 19:03 ` Aitenate
2024-12-26 8:26 ` Rudolf Adamkovič
2024-12-26 9:08 ` Ihor Radchenko
0 siblings, 2 replies; 10+ messages in thread
From: Aitenate @ 2024-12-25 19:03 UTC (permalink / raw)
To: Ihor Radchenko; +Cc: emacs-orgmode
On 25/12/2024 15:30, Ihor Radchenko wrote:
> Aitenate <aitenate@outlook.com> writes:
>
>> With ~:results file~, the absence of ~:file~ will cause the filename to
>> be constructed from the block name and ~:file-ext~, if they are both
>> present. To achieve that with ~:results file link~, I could only come up
>> with
>>
>> ~:var outFile=(alist-get :file (nth 2 (org-babel-get-src-block-info
>> 't)))~
>
> Seems right, but I do not understand why you would need such thing.
>
The aim is to not need to define a filename for each image, to minimise
the boilerplate. Org has a mechanism for this, but it only works when
Org creates the file.
Using a combination of noweb and file header arguments, with a property
drawer, I was able to have each code block only require a unique name
and the image code. That is except, because the image library creates
the file, I need to specify a var to give a filename. Hence, I poked
around until I found a way to use the computed filename.
While I'm happy with the solution I found, as a novice Org user, it
seemed like I needed to reach into undocumented internals to do this. So
I queried this, partly to understand if there was a better way, and
partly to see if it was worth providing a better way or at least
documenting a method.
Based on your response, maybe I'm doing something unusual. In which
case, it's not surprising I couldn't find a more obvious way.
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Generating the filename from name and file-ext for blocks with side-effects
2024-12-25 19:03 ` Aitenate
@ 2024-12-26 8:26 ` Rudolf Adamkovič
2024-12-26 9:29 ` Ihor Radchenko
2024-12-26 9:08 ` Ihor Radchenko
1 sibling, 1 reply; 10+ messages in thread
From: Rudolf Adamkovič @ 2024-12-26 8:26 UTC (permalink / raw)
To: Aitenate, Ihor Radchenko; +Cc: emacs-orgmode
Ihor Radchenko <yantar92@posteo.net> writes:
> Seems right, but I do not understand why you would need such thing.
Aitenate <aitenate@outlook.com> writes:
> The aim is to not need to define a filename for each image, to minimise
> the boilerplate.
+1 This should be built into Org and enabled by default.
I currently generate image names with a custom snippet, but it gets
trying and should not be necessary in the first place.
Instead, Org should generate a unique file name automatically, similar
to how tangle ':comments' work, and use that as the default value for
the ':file` argument, getting rid of the dreaded error message
org-babel-execute:LANG: You need to specify a :file parameter
Rudy
--
"I would prefer an intelligent hell to a stupid paradise."
--- Blaise Pascal
Rudolf Adamkovič <rudolf@adamkovic.org> [he/him]
http://adamkovic.org
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Generating the filename from name and file-ext for blocks with side-effects
2024-12-26 8:26 ` Rudolf Adamkovič
@ 2024-12-26 9:29 ` Ihor Radchenko
2024-12-27 13:56 ` Rudolf Adamkovič
0 siblings, 1 reply; 10+ messages in thread
From: Ihor Radchenko @ 2024-12-26 9:29 UTC (permalink / raw)
To: Rudolf Adamkovič; +Cc: Aitenate, emacs-orgmode
Rudolf Adamkovič <rudolf@adamkovic.org> writes:
>> The aim is to not need to define a filename for each image, to minimise
>> the boilerplate.
>
> +1 This should be built into Org and enabled by default.
>
> I currently generate image names with a custom snippet, but it gets
> trying and should not be necessary in the first place.
Do you want to create a patch providing this functionality?
> Instead, Org should generate a unique file name automatically, similar
> to how tangle ':comments' work, and use that as the default value for
> the ':file` argument, getting rid of the dreaded error message
>
> org-babel-execute:LANG: You need to specify a :file parameter
Do you want to extend `org-babel-generate-file-param' to return
something even when src block is not named and :file-ext is not given?
But how will you know the desired extension?
--
Ihor Radchenko // yantar92,
Org mode maintainer,
Learn more about Org mode at <https://orgmode.org/>.
Support Org development at <https://liberapay.com/org-mode>,
or support my work at <https://liberapay.com/yantar92>
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Generating the filename from name and file-ext for blocks with side-effects
2024-12-26 9:29 ` Ihor Radchenko
@ 2024-12-27 13:56 ` Rudolf Adamkovič
2024-12-27 14:01 ` Ihor Radchenko
0 siblings, 1 reply; 10+ messages in thread
From: Rudolf Adamkovič @ 2024-12-27 13:56 UTC (permalink / raw)
To: Ihor Radchenko; +Cc: Aitenate, emacs-orgmode
Ihor Radchenko <yantar92@posteo.net> writes:
> [...] and :file-ext is not given? But how will you know the desired
> extension?
Oh, I missed that. My local hack assumes `.svg', but that is not enough
for the general use case.
Perhaps, we could save as `$BASENAME.out', detect the image format, and
then rename to `$BASENAME.svg', for example. If the file is not an
image, we leave it as `.out'.
We can detect the image type with `image-type':
(image-type "...-59b9176e65c9.svg") => svg
If the above is sufficient, the problem reduces to:
how to compute the `$BASENAME'?
[`org-babel-tangle-comment-format-beg' does something similar.]
Rudy
--
"One can begin to reason only when a clear picture has been formed in
the imagination."
--- Walter Warwick Sawyer, Mathematician's Delight, 1943
Rudolf Adamkovič <rudolf@adamkovic.org> [he/him]
http://adamkovic.org
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Generating the filename from name and file-ext for blocks with side-effects
2024-12-27 13:56 ` Rudolf Adamkovič
@ 2024-12-27 14:01 ` Ihor Radchenko
2024-12-30 21:36 ` Rudolf Adamkovič
0 siblings, 1 reply; 10+ messages in thread
From: Ihor Radchenko @ 2024-12-27 14:01 UTC (permalink / raw)
To: Rudolf Adamkovič; +Cc: Aitenate, emacs-orgmode
Rudolf Adamkovič <rudolf@adamkovic.org> writes:
>> [...] and :file-ext is not given? But how will you know the desired
>> extension?
>
> Oh, I missed that. My local hack assumes `.svg', but that is not enough
> for the general use case.
>
> Perhaps, we could save as `$BASENAME.out', detect the image format, and
> then rename to `$BASENAME.svg', for example. If the file is not an
> image, we leave it as `.out'.
>
> We can detect the image type with `image-type':
>
> (image-type "...-59b9176e65c9.svg") => svg
Why do you think that the output file is always an image? It may not
be. It can be anything.
--
Ihor Radchenko // yantar92,
Org mode maintainer,
Learn more about Org mode at <https://orgmode.org/>.
Support Org development at <https://liberapay.com/org-mode>,
or support my work at <https://liberapay.com/yantar92>
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Generating the filename from name and file-ext for blocks with side-effects
2024-12-27 14:01 ` Ihor Radchenko
@ 2024-12-30 21:36 ` Rudolf Adamkovič
2024-12-31 17:50 ` Ihor Radchenko
0 siblings, 1 reply; 10+ messages in thread
From: Rudolf Adamkovič @ 2024-12-30 21:36 UTC (permalink / raw)
To: Ihor Radchenko; +Cc: Aitenate, emacs-orgmode
Ihor Radchenko <yantar92@posteo.net> writes:
>> We can detect the image type with `image-type':
>>
>> (image-type "...-59b9176e65c9.svg") => svg
>
> Why do you think that the output file is always an image? It may not
> be. It can be anything.
I do not think that. I specifically addressed the non-image case: the
file would retain the `out' extension.
But, we could be smart about other file types as well, if we use
e.g. `file', like `dired-show-file-type' does.
Rudy
--
"All of humanity's problems stem from man's inability to sit quietly in a room alone."
--- Blaise Pascal, Pensées, 1670
Rudolf Adamkovič <rudolf@adamkovic.org> [he/him]
http://adamkovic.org
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Generating the filename from name and file-ext for blocks with side-effects
2024-12-30 21:36 ` Rudolf Adamkovič
@ 2024-12-31 17:50 ` Ihor Radchenko
0 siblings, 0 replies; 10+ messages in thread
From: Ihor Radchenko @ 2024-12-31 17:50 UTC (permalink / raw)
To: Rudolf Adamkovič; +Cc: Aitenate, emacs-orgmode
Rudolf Adamkovič <rudolf@adamkovic.org> writes:
>>> (image-type "...-59b9176e65c9.svg") => svg
>>
>> Why do you think that the output file is always an image? It may not
>> be. It can be anything.
>
> I do not think that. I specifically addressed the non-image case: the
> file would retain the `out' extension.
Reasonable.
> But, we could be smart about other file types as well, if we use
> e.g. `file', like `dired-show-file-type' does.
Yes. Although there is another possible problem - current
implementation computes file _before_ the code block is evaluated. In
fact, this thread started from exactly this scenario - get the file name
before it appears on disk. And we have no clue about what will be inside
the file at that point.
--
Ihor Radchenko // yantar92,
Org mode maintainer,
Learn more about Org mode at <https://orgmode.org/>.
Support Org development at <https://liberapay.com/org-mode>,
or support my work at <https://liberapay.com/yantar92>
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Generating the filename from name and file-ext for blocks with side-effects
2024-12-25 19:03 ` Aitenate
2024-12-26 8:26 ` Rudolf Adamkovič
@ 2024-12-26 9:08 ` Ihor Radchenko
1 sibling, 0 replies; 10+ messages in thread
From: Ihor Radchenko @ 2024-12-26 9:08 UTC (permalink / raw)
To: Aitenate; +Cc: emacs-orgmode
Aitenate <aitenate@outlook.com> writes:
>>> ~:var outFile=(alist-get :file (nth 2 (org-babel-get-src-block-info
>>> 't)))~
>>
>> Seems right, but I do not understand why you would need such thing.
>>
> The aim is to not need to define a filename for each image, to minimise
> the boilerplate. Org has a mechanism for this, but it only works when
> Org creates the file.
>
> Using a combination of noweb and file header arguments, with a property
> drawer, I was able to have each code block only require a unique name
> and the image code. That is except, because the image library creates
> the file, I need to specify a var to give a filename. Hence, I poked
> around until I found a way to use the computed filename.
Thanks for the explanation!
I do see how this can be useful.
> Based on your response, maybe I'm doing something unusual. In which
> case, it's not surprising I couldn't find a more obvious way.
AFAIK, most people just specify the file names manually.
I suspect that it is mostly because the part of Org manual explaining
this is not easy to understand.
--
Ihor Radchenko // yantar92,
Org mode maintainer,
Learn more about Org mode at <https://orgmode.org/>.
Support Org development at <https://liberapay.com/org-mode>,
or support my work at <https://liberapay.com/yantar92>
^ permalink raw reply [flat|nested] 10+ messages in thread
end of thread, other threads:[~2024-12-31 17:49 UTC | newest]
Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-12-23 21:58 Generating the filename from name and file-ext for blocks with side-effects Aitenate
2024-12-25 15:30 ` Ihor Radchenko
2024-12-25 19:03 ` Aitenate
2024-12-26 8:26 ` Rudolf Adamkovič
2024-12-26 9:29 ` Ihor Radchenko
2024-12-27 13:56 ` Rudolf Adamkovič
2024-12-27 14:01 ` Ihor Radchenko
2024-12-30 21:36 ` Rudolf Adamkovič
2024-12-31 17:50 ` Ihor Radchenko
2024-12-26 9:08 ` Ihor Radchenko
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).