* [PATCH] Strip text properties from string code block arguments
@ 2014-01-07 17:26 Daniel Gerber
2014-01-07 17:31 ` Bastien
2014-01-08 16:31 ` Bastien
0 siblings, 2 replies; 12+ messages in thread
From: Daniel Gerber @ 2014-01-07 17:26 UTC (permalink / raw)
To: emacs-orgmode
Hi,
This change in org-babel-python-var-to-python makes python code blocks
accept a string with text properties (as one gets when referring another
code block). I guess there should be something similar for other languages.
diff --git a/lisp/ob-python.el b/lisp/ob-python.el
index 1457682..baa5764 100644
--- a/lisp/ob-python.el
+++ b/lisp/ob-python.el
@@ -137,7 +137,7 @@ specifying a variable of the same value."
org-babel-python-hline-to
(format
(if (and (stringp var) (string-match "[\n\r]" var))
"\"\"%S\"\"" "%S")
- var))))
+ (if (stringp var) (substring-no-properties var) var)))))
(defun org-babel-python-table-or-string (results)
"Convert RESULTS into an appropriate elisp value.
^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH] Strip text properties from string code block arguments
2014-01-07 17:26 [PATCH] Strip text properties from string code block arguments Daniel Gerber
@ 2014-01-07 17:31 ` Bastien
2014-01-07 19:21 ` Achim Gratz
2014-01-08 10:03 ` Daniel Gerber
2014-01-08 16:31 ` Bastien
1 sibling, 2 replies; 12+ messages in thread
From: Bastien @ 2014-01-07 17:31 UTC (permalink / raw)
To: Daniel Gerber; +Cc: emacs-orgmode
Hi Daniel,
Daniel Gerber <daniel.g.gerber@gmail.com> writes:
> This change in org-babel-python-var-to-python makes python code blocks
> accept a string with text properties (as one gets when referring
> another code block). I guess there should be something similar for
> other languages.
I don't understand why properties would be a problem here.
Can you elaborate a bit on this?
Thanks,
--
Bastien
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] Strip text properties from string code block arguments
2014-01-07 17:31 ` Bastien
@ 2014-01-07 19:21 ` Achim Gratz
2014-01-08 8:47 ` Bastien
2014-01-08 10:03 ` Daniel Gerber
1 sibling, 1 reply; 12+ messages in thread
From: Achim Gratz @ 2014-01-07 19:21 UTC (permalink / raw)
To: emacs-orgmode
Bastien writes:
> I don't understand why properties would be a problem here.
> Can you elaborate a bit on this?
With format "%S" prints an s-expression via prin1, not a string. So
either the format should be "%s" or the properties need to be stripped
unless one really wants to interpret the result via read again.
Regards,
Achim.
--
+<[Q+ Matrix-12 WAVE#46+305 Neuron microQkb Andromeda XTk Blofeld]>+
Wavetables for the Terratec KOMPLEXER:
http://Synth.Stromeko.net/Downloads.html#KomplexerWaves
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] Strip text properties from string code block arguments
2014-01-07 19:21 ` Achim Gratz
@ 2014-01-08 8:47 ` Bastien
0 siblings, 0 replies; 12+ messages in thread
From: Bastien @ 2014-01-08 8:47 UTC (permalink / raw)
To: Achim Gratz; +Cc: emacs-orgmode
Achim Gratz <Stromeko@nexgo.de> writes:
> Bastien writes:
>> I don't understand why properties would be a problem here.
>> Can you elaborate a bit on this?
>
> With format "%S" prints an s-expression via prin1, not a string. So
> either the format should be "%s" or the properties need to be stripped
> unless one really wants to interpret the result via read again.
I think this is a simple typo and s/%S/%s would do.
I'll have a closer look and fix this later today.
--
Bastien
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] Strip text properties from string code block arguments
2014-01-07 17:31 ` Bastien
2014-01-07 19:21 ` Achim Gratz
@ 2014-01-08 10:03 ` Daniel Gerber
1 sibling, 0 replies; 12+ messages in thread
From: Daniel Gerber @ 2014-01-08 10:03 UTC (permalink / raw)
To: Bastien, emacs-orgmode
Hi Bastien,
On 07/01/2014 18:31, Bastien wrote:
> Daniel Gerber<daniel.g.gerber@gmail.com> writes:
>
>> This change in org-babel-python-var-to-python makes python code blocks
>> accept a string with text properties (as one gets when referring
>> another code block). I guess there should be something similar for
>> other languages.
> I don't understand why properties would be a problem here.
> Can you elaborate a bit on this?
The problem is that formatting as s-expression puts them into python code.
Here is what I want to do.
First edit a query string:
#+RESULTS: query
#+BEGIN_SRC sparql
select *
where { ?x rdf:label "x\\r"@en }
#+END_SRC
(The trick of naming this block with #+results: is so that:
1. org-edit-src-code uses the right mode
2. the code block is not evaluated
3. its body is passed as a string to other code blocks.
For lack of a better idea...)
Use the query string verbatim in another language:
#+NAME: py
#+BEGIN_SRC python :var q=query
# return some_graph.query(q)
return q
#+END_SRC
But now calling py() or tangling would give a syntax error because
#+BEGIN_SRC elisp :var q=query
(org-babel-python-var-to-python q)
#+END_SRC
#+RESULTS:
: ""#("select *
: where { ?x rdf:label \"x\\\\r\"@en }
: " 0 9 (face org-block font-lock-multiline t wrap-prefix #(" " 0 2
(face org-indent)) line-prefix nil font-lock-fontified t fontified t) 9
30 (face org-block font-lock-multiline t wrap-prefix #(" " 0 2 (face
org-indent)) line-prefix nil font-lock-fontified t fontified t) 30 35
(face org-block font-lock-multiline t font-lock-fontified t wrap-prefix
#(" " 0 2 (face org-indent)) line-prefix nil fontified t) 35 40 (face
org-block font-lock-multiline t font-lock-fontified t wrap-prefix #(" "
0 2 (face org-indent)) line-prefix nil fontified t) 40 41 (face
org-block font-lock-multiline t wrap-prefix #(" " 0 2 (face
org-indent)) line-prefix nil font-lock-fontified t fontified t) 41 42
(face org-block font-lock-multiline t wrap-prefix #(" " 0 2 (face
org-indent)) line-prefix nil font-lock-fontified t fontified t))""
If org-babel-python-var-to-python does
#+BEGIN_SRC elisp :var q=query
(format "%S" (substring-no-properties q))
#+END_SRC
#+RESULTS:
: "select *
: where { ?x rdf:label \"x\\\\r\"@en }
: "
then both evaluation and tangling work fine:
#+CALL: py()
#+RESULTS:
: select *
: where { ?x rdf:label "x\\r"@en }
Best,
Daniel
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] Strip text properties from string code block arguments
2014-01-07 17:26 [PATCH] Strip text properties from string code block arguments Daniel Gerber
2014-01-07 17:31 ` Bastien
@ 2014-01-08 16:31 ` Bastien
2014-01-08 17:27 ` Daniel Gerber
1 sibling, 1 reply; 12+ messages in thread
From: Bastien @ 2014-01-08 16:31 UTC (permalink / raw)
To: Daniel Gerber; +Cc: emacs-orgmode
Daniel Gerber <daniel.g.gerber@gmail.com> writes:
> This change in org-babel-python-var-to-python makes python code blocks
> accept a string with text properties (as one gets when referring
> another code block). I guess there should be something similar for
> other languages.
I've now fixed this by using %s instead of %S, let me know if this
works correctly for you.
--
Bastien
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] Strip text properties from string code block arguments
2014-01-08 16:31 ` Bastien
@ 2014-01-08 17:27 ` Daniel Gerber
2014-01-08 17:32 ` Bastien
2014-01-09 20:39 ` Achim Gratz
0 siblings, 2 replies; 12+ messages in thread
From: Daniel Gerber @ 2014-01-08 17:27 UTC (permalink / raw)
To: Bastien; +Cc: emacs-orgmode
On 08/01/2014 17:31, Bastien wrote:
> Daniel Gerber <daniel.g.gerber@gmail.com> writes:
>
>> This change in org-babel-python-var-to-python makes python code blocks
>> accept a string with text properties (as one gets when referring
>> another code block). I guess there should be something similar for
>> other languages.
> I've now fixed this by using %s instead of %S, let me know if this
> works correctly for you.
Not quite. I thought %S was not a typo because it escapes characters
more nicely. E.g. with %s the buffer should contain \"\"\" to mean """
in python.
Also, one quote is missing
- (if (and (stringp var) (string-match "[\n\r]" var)) "\"\"%s\"\""
"%s")
+ (if (and (stringp var) (string-match "[\n\r]" var))
"\"\"\"%s\"\"\"" "\"%s\"")
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] Strip text properties from string code block arguments
2014-01-08 17:27 ` Daniel Gerber
@ 2014-01-08 17:32 ` Bastien
2014-01-09 20:39 ` Achim Gratz
1 sibling, 0 replies; 12+ messages in thread
From: Bastien @ 2014-01-08 17:32 UTC (permalink / raw)
To: Daniel Gerber; +Cc: emacs-orgmode
Daniel Gerber <daniel.g.gerber@gmail.com> writes:
> On 08/01/2014 17:31, Bastien wrote:
>> Daniel Gerber <daniel.g.gerber@gmail.com> writes:
>>
>>> This change in org-babel-python-var-to-python makes python code blocks
>>> accept a string with text properties (as one gets when referring
>>> another code block). I guess there should be something similar for
>>> other languages.
>> I've now fixed this by using %s instead of %S, let me know if this
>> works correctly for you.
> Not quite. I thought %S was not a typo because it escapes characters
> more nicely. E.g. with %s the buffer should contain \"\"\" to mean """
> in python.
I reverted my change -- can you resubmit a proper patch,
i.e. one with an Emacs changelog and using git format-patch?
Thanks!
--
Bastien
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] Strip text properties from string code block arguments
2014-01-08 17:27 ` Daniel Gerber
2014-01-08 17:32 ` Bastien
@ 2014-01-09 20:39 ` Achim Gratz
2014-01-12 11:43 ` Bastien
1 sibling, 1 reply; 12+ messages in thread
From: Achim Gratz @ 2014-01-09 20:39 UTC (permalink / raw)
To: emacs-orgmode
Daniel Gerber writes:
> Not quite. I thought %S was not a typo because it escapes characters
> more nicely. E.g. with %s the buffer should contain \"\"\" to mean """
> in python.
If that's the intention, then %S is arguably a latent bug, since the
escaping it applies can only by accident be compatible with the targeted
language. I don't know if something like shell-quote arguments exists
for arbitrary programming languages.
Regards,
Achim.
--
+<[Q+ Matrix-12 WAVE#46+305 Neuron microQkb Andromeda XTk Blofeld]>+
SD adaptation for Waldorf microQ V2.22R2:
http://Synth.Stromeko.net/Downloads.html#WaldorfSDada
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] Strip text properties from string code block arguments
2014-01-09 20:39 ` Achim Gratz
@ 2014-01-12 11:43 ` Bastien
2014-01-12 16:35 ` Eric Schulte
0 siblings, 1 reply; 12+ messages in thread
From: Bastien @ 2014-01-12 11:43 UTC (permalink / raw)
To: Achim Gratz; +Cc: emacs-orgmode
Achim Gratz <Stromeko@nexgo.de> writes:
> Daniel Gerber writes:
>> Not quite. I thought %S was not a typo because it escapes characters
>> more nicely. E.g. with %s the buffer should contain \"\"\" to mean """
>> in python.
>
> If that's the intention, then %S is arguably a latent bug, since the
> escaping it applies can only by accident be compatible with the targeted
> language. I don't know if something like shell-quote arguments exists
> for arbitrary programming languages.
Maybe we should simply use %s (downcase) and escape quotes manually.
If feels less random to me.
What do you think?
--
Bastien
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] Strip text properties from string code block arguments
2014-01-12 11:43 ` Bastien
@ 2014-01-12 16:35 ` Eric Schulte
2014-01-12 23:28 ` Bastien
0 siblings, 1 reply; 12+ messages in thread
From: Eric Schulte @ 2014-01-12 16:35 UTC (permalink / raw)
To: Bastien; +Cc: Achim Gratz, emacs-orgmode
Bastien <bzg@gnu.org> writes:
> Achim Gratz <Stromeko@nexgo.de> writes:
>
>> Daniel Gerber writes:
>>> Not quite. I thought %S was not a typo because it escapes characters
>>> more nicely. E.g. with %s the buffer should contain \"\"\" to mean """
>>> in python.
>>
>> If that's the intention, then %S is arguably a latent bug, since the
>> escaping it applies can only by accident be compatible with the targeted
>> language. I don't know if something like shell-quote arguments exists
>> for arbitrary programming languages.
>
> Maybe we should simply use %s (downcase) and escape quotes manually.
> If feels less random to me.
>
> What do you think?
I think using %S with strip-properties will address the great majority
of cases, and is certainly a better interim solution than the current
use of %s with no escaping. I find string escaping is *normally* very
consistent between languages.
Then if someone wants to read the python spec, and implement custom
string escaping that would be useful, but it isn't immediately required.
Alternately maybe python's long-form """ strings should be used in all
cases?
--
Eric Schulte
https://cs.unm.edu/~eschulte
PGP: 0x614CA05D
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH] Strip text properties from string code block arguments
2014-01-12 16:35 ` Eric Schulte
@ 2014-01-12 23:28 ` Bastien
0 siblings, 0 replies; 12+ messages in thread
From: Bastien @ 2014-01-12 23:28 UTC (permalink / raw)
To: Eric Schulte; +Cc: Achim Gratz, emacs-orgmode
Hi Eric,
Eric Schulte <schulte.eric@gmail.com> writes:
> I think using %S with strip-properties will address the great majority
> of cases, and is certainly a better interim solution than the current
> use of %s with no escaping. I find string escaping is *normally* very
> consistent between languages.
Okay, that's now the case in maint.
> Then if someone wants to read the python spec, and implement custom
> string escaping that would be useful, but it isn't immediately required.
Indeed.
--
Bastien
^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2014-01-12 23:29 UTC | newest]
Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-01-07 17:26 [PATCH] Strip text properties from string code block arguments Daniel Gerber
2014-01-07 17:31 ` Bastien
2014-01-07 19:21 ` Achim Gratz
2014-01-08 8:47 ` Bastien
2014-01-08 10:03 ` Daniel Gerber
2014-01-08 16:31 ` Bastien
2014-01-08 17:27 ` Daniel Gerber
2014-01-08 17:32 ` Bastien
2014-01-09 20:39 ` Achim Gratz
2014-01-12 11:43 ` Bastien
2014-01-12 16:35 ` Eric Schulte
2014-01-12 23:28 ` Bastien
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/emacs.git
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.