summaryrefslogtreecommitdiff
path: root/lisp/org/ob-ditaa.el
diff options
context:
space:
mode:
Diffstat (limited to 'lisp/org/ob-ditaa.el')
-rw-r--r--lisp/org/ob-ditaa.el22
1 files changed, 12 insertions, 10 deletions
diff --git a/lisp/org/ob-ditaa.el b/lisp/org/ob-ditaa.el
index 336eaa93f12..a9b6b3ceaf1 100644
--- a/lisp/org/ob-ditaa.el
+++ b/lisp/org/ob-ditaa.el
@@ -5,7 +5,7 @@
;; Author: Eric Schulte
;; Keywords: literate programming, reproducible research
;; Homepage: http://orgmode.org
-;; Version: 7.01
+;; Version: 7.3
;; This file is part of GNU Emacs.
@@ -43,22 +43,24 @@
'((:results . "file") (:exports . "results"))
"Default arguments for evaluating a ditaa source block.")
-(defun org-babel-expand-body:ditaa (body params &optional processed-params)
- "Expand BODY according to PARAMS, return the expanded body." body)
-
(defvar org-ditaa-jar-path)
(defun org-babel-execute:ditaa (body params)
"Execute a block of Ditaa code with org-babel.
This function is called by `org-babel-execute-src-block'."
- (let ((result-params (split-string (or (cdr (assoc :results params)) "")))
- (out-file (cdr (assoc :file params)))
- (cmdline (cdr (assoc :cmdline params)))
- (in-file (make-temp-file "org-babel-ditaa")))
+ (let* ((result-params (split-string (or (cdr (assoc :results params)) "")))
+ (out-file (cdr (assoc :file params)))
+ (cmdline (cdr (assoc :cmdline params)))
+ (in-file (org-babel-temp-file "ditaa-"))
+ (cmd (concat "java -jar "
+ (shell-quote-argument
+ (expand-file-name org-ditaa-jar-path))
+ " " cmdline
+ " " (org-babel-process-file-name in-file)
+ " " (org-babel-process-file-name out-file))))
(unless (file-exists-p org-ditaa-jar-path)
(error "Could not find ditaa.jar at %s" org-ditaa-jar-path))
(with-temp-file in-file (insert body))
- (message (concat "java -jar " org-ditaa-jar-path " " cmdline " " in-file " " out-file))
- (shell-command (concat "java -jar " (shell-quote-argument org-ditaa-jar-path) " " cmdline " " in-file " " out-file))
+ (message cmd) (shell-command cmd)
out-file))
(defun org-babel-prep-session:ditaa (session params)