ob-ref: fix bug
* lisp/ob-ref.el (org-babel-ref-resolve): Fix error when src block result is nil.
This commit is contained in:
parent
3f6e71e62e
commit
f0380f54c1
|
@ -162,44 +162,41 @@ the variable."
|
||||||
(goto-char (point-min))
|
(goto-char (point-min))
|
||||||
(let* ((params (append args '((:results . "silent"))))
|
(let* ((params (append args '((:results . "silent"))))
|
||||||
(regexp (org-babel-named-data-regexp-for-name ref))
|
(regexp (org-babel-named-data-regexp-for-name ref))
|
||||||
lob-info
|
|
||||||
(result
|
(result
|
||||||
(cond
|
(catch :found
|
||||||
;; Check for code blocks or named data.
|
;; Check for code blocks or named data.
|
||||||
((catch :found
|
(while (re-search-forward regexp nil t)
|
||||||
(while (re-search-forward regexp nil t)
|
;; Ignore COMMENTed headings and orphaned
|
||||||
;; Ignore COMMENTed headings and orphaned
|
;; affiliated keywords.
|
||||||
;; affiliated keywords.
|
(unless (org-in-commented-heading-p)
|
||||||
(unless (org-in-commented-heading-p)
|
(let ((e (org-element-at-point)))
|
||||||
(let ((e (org-element-at-point)))
|
(when (equal (org-element-property :name e) ref)
|
||||||
(when (equal (org-element-property :name e) ref)
|
(goto-char
|
||||||
(goto-char
|
(org-element-property :post-affiliated e))
|
||||||
(org-element-property :post-affiliated e))
|
(pcase (org-element-type e)
|
||||||
(pcase (org-element-type e)
|
(`babel-call
|
||||||
(`babel-call
|
(throw :found
|
||||||
(throw :found
|
(org-babel-lob-execute
|
||||||
(org-babel-lob-execute
|
(org-babel-lob-get-info))))
|
||||||
(org-babel-lob-get-info))))
|
(`src-block
|
||||||
(`src-block
|
(throw :found
|
||||||
(throw :found
|
(org-babel-execute-src-block
|
||||||
(org-babel-execute-src-block
|
nil nil
|
||||||
nil nil
|
(and
|
||||||
(and
|
(not org-babel-update-intermediate)
|
||||||
(not org-babel-update-intermediate)
|
params))))
|
||||||
params))))
|
((and (let v (org-babel-read-element e))
|
||||||
((and (let v (org-babel-read-element e))
|
(guard v))
|
||||||
(guard v))
|
(throw :found v))
|
||||||
(throw :found v))
|
(_ (error "Reference not found")))))))
|
||||||
(_ (error "Reference not found")))))))
|
;; Check for local or global headlines by ID.
|
||||||
nil))
|
(when (org-babel-ref-goto-headline-id ref)
|
||||||
;; Check for local or global headlines by ID.
|
(throw :found (org-babel-ref-headline-body)))
|
||||||
((org-babel-ref-goto-headline-id ref)
|
;; Check the Library of Babel.
|
||||||
(org-babel-ref-headline-body))
|
(let ((lob-info (cdr (assq (intern ref) org-babel-library-of-babel))))
|
||||||
;; Check the Library of Babel.
|
(when lob-info
|
||||||
((setq lob-info
|
(throw :found (org-babel-execute-src-block nil lob-info params))))
|
||||||
(cdr (assq (intern ref) org-babel-library-of-babel)))
|
(t (error "Reference `%s' not found in this buffer" ref)))))
|
||||||
(org-babel-execute-src-block nil lob-info params))
|
|
||||||
(t (error "Reference `%s' not found in this buffer" ref)))))
|
|
||||||
(cond
|
(cond
|
||||||
((symbolp result) (format "%S" result))
|
((symbolp result) (format "%S" result))
|
||||||
((and index (listp result))
|
((and index (listp result))
|
||||||
|
|
Loading…
Reference in New Issue