1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- (require 'ob)
- (require 'ob-eval)
- (defvar org-babel-default-header-args:plantuml
- '((:results . "file") (:exports . "results"))
- "Default arguments for evaluating a plantuml source block.")
- (defun org-babel-expand-body:plantuml (body params &optional processed-params)
- "Expand BODY according to PARAMS, return the expanded body." body)
- (defcustom org-plantuml-jar-path nil
- "Path to the plantuml.jar file."
- :group 'org-babel
- :type 'string)
- (defun org-babel-execute:plantuml (body params)
- "Execute a block of plantuml 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 (or (cdr (assoc :file params))
- (error "plantuml requires a \":file\" header argument")))
- (cmdline (cdr (assoc :cmdline params)))
- (in-file (org-babel-temp-file "plantuml-"))
- (cmd (if (not org-plantuml-jar-path)
- (error "`org-plantuml-jar-path' is not set")
- (concat "java -jar "
- (shell-quote-argument
- (expand-file-name org-plantuml-jar-path))
- (if (string= (file-name-extension out-file) "svg")
- " -tsvg" "")
- " -p " cmdline " < "
- (org-babel-process-file-name in-file)
- " > "
- (org-babel-process-file-name out-file)))))
- (unless (file-exists-p org-plantuml-jar-path)
- (error "Could not find plantuml.jar at %s" org-plantuml-jar-path))
- (with-temp-file in-file (insert (concat "@startuml\n" body "\n@enduml")))
- (message "%s" cmd) (org-babel-eval cmd "")
- out-file))
- (defun org-babel-prep-session:plantuml (session params)
- "Return an error because plantuml does not support sessions."
- (error "Plantuml does not support sessions"))
- (provide 'ob-plantuml)
|