Merge branch 'maint'

This commit is contained in:
Nicolas Goaziou 2017-12-15 00:00:55 +01:00
commit 5d4691dfbf
2 changed files with 34 additions and 12 deletions

View File

@ -65,24 +65,21 @@
(declare-function org-show-context "org" (&optional key)) (declare-function org-show-context "org" (&optional key))
(declare-function org-trim "org" (s &optional keep-lead)) (declare-function org-trim "org" (s &optional keep-lead))
(defvar org-babel-ref-split-regexp
"[ \f\t\n\r\v]*\\(.+?\\)[ \f\t\n\r\v]*=[ \f\t\n\r\v]*\\(.+\\)[ \f\t\n\r\v]*")
(defvar org-babel-update-intermediate nil (defvar org-babel-update-intermediate nil
"Update the in-buffer results of code blocks executed to resolve references.") "Update the in-buffer results of code blocks executed to resolve references.")
(defun org-babel-ref-parse (assignment) (defun org-babel-ref-parse (assignment)
"Parse a variable ASSIGNMENT in a header argument. "Parse a variable ASSIGNMENT in a header argument.
If the right hand side of the assignment has a literal value If the right hand side of the assignment has a literal value
return that value, otherwise interpret as a reference to an return that value, otherwise interpret it as a reference to an
external resource and find its value using external resource and find its value using `org-babel-ref-resolve'.
`org-babel-ref-resolve'. Return a list with two elements. The
first element of the list will be the name of the variable, and Return a list with two elements: the name of the variable, and an
the second will be an emacs-lisp representation of the value of Emacs Lisp representation of the value of the variable."
the variable." (when (string-match "\\(.+?\\)=" assignment)
(when (string-match org-babel-ref-split-regexp assignment) (let ((var (org-trim (match-string 1 assignment)))
(let ((var (match-string 1 assignment)) (ref (org-trim (substring assignment (match-end 0)))))
(ref (match-string 2 assignment)))
(cons (intern var) (cons (intern var)
(let ((out (save-excursion (let ((out (save-excursion
(when org-babel-current-src-block-location (when org-babel-current-src-block-location

View File

@ -168,6 +168,31 @@ for export
(should (should
(eq (org-babel-execute-src-block nil (org-babel-lob-get-info)) 1))))) (eq (org-babel-execute-src-block nil (org-babel-lob-get-info)) 1)))))
(ert-deftest test-ob-lob/assignment-with-newline ()
"Test call lines with an argument containing a newline character."
(should
(equal " foo"
(org-test-with-temp-text "
#+name: test-newline
#+begin_src emacs-lisp :var x=\"a\"
'foo
#+end_src
call_test-newline[:eval yes :results raw](\"a\nb\")<point>"
(org-babel-execute-src-block nil (org-babel-lob-get-info))
(buffer-substring (point) (point-max)))))
(should
(equal " bar"
(org-test-with-temp-text "
#+name: test-newline
#+begin_src emacs-lisp :var x=\"a\"
'bar
#+end_src
call_test-newline[:eval yes :results raw]('(1\n2))<point>"
(org-babel-execute-src-block nil (org-babel-lob-get-info))
(buffer-substring (point) (point-max))))))
(provide 'test-ob-lob) (provide 'test-ob-lob)
;;; test-ob-lob.el ends here ;;; test-ob-lob.el ends here