12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- (require 'ob)
- (defvar org-babel-default-header-args:plantuml
- '((:results . "file") (:exports . "results"))
- "Default arguments for evaluating a plantuml source block.")
- (defcustom org-plantuml-jar-path nil
- "Path to the plantuml.jar file."
- :group 'org-babel
- :version "24.1"
- :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-"))
- (java (or (cdr (assoc :java params)) ""))
- (cmd (if (not org-plantuml-jar-path)
- (error "`org-plantuml-jar-path' is not set")
- (concat "java " java " -jar "
- (shell-quote-argument
- (expand-file-name org-plantuml-jar-path))
- (if (string= (file-name-extension out-file) "svg")
- " -tsvg" "")
- (if (string= (file-name-extension out-file) "eps")
- " -teps" "")
- " -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 "")
- nil))
- (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)
|