emacs-orgmode
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[O] [PATCH] ob-java.el: Add `:var' variables import


From: Bart Post
Subject: [O] [PATCH] ob-java.el: Add `:var' variables import
Date: Sun, 22 Jun 2014 00:30:08 +0200
User-agent: Gnus/5.13 (Gnus v5.13) Emacs/24.4.50 (gnu/linux)

* lisp/ob-java.el: (org-babel-execute:java): Inject a private static
class inside the Java class designated by
`:classname'.
(org-babel-variable-assignments:java): Assign the header variables to
static fields in a private static class
`Data'.
(org-babel-java-var-to-java): Translate string to String, list to
java.util.List, float to double and others to int.
---
 lisp/ob-java.el | 39 ++++++++++++++++++++++++++++++++++++++-
 1 file changed, 38 insertions(+), 1 deletion(-)

diff --git a/lisp/ob-java.el b/lisp/ob-java.el
index 8c64171..a2a1f40 100644
--- a/lisp/ob-java.el
+++ b/lisp/ob-java.el
@@ -58,7 +58,13 @@ parameters may be used, like javac -verbose"
         (src-file (concat classname ".java"))
         (cmpflag (or (cdr (assoc :cmpflag params)) ""))
         (cmdline (or (cdr (assoc :cmdline params)) ""))
-        (full-body (org-babel-expand-body:generic body params))
+        (split-body
+         (split-string body (concat classname "[\n\t ]*{")))
+        (full-body
+         (org-babel-expand-body:generic
+          (concat (car split-body) (concat classname " {\n") 
(org-babel-variable-assignments:java params)
+                  (mapconcat 'identity (cdr split-body) (concat classname " 
{")))
+          params))
         (compile
          (progn (with-temp-file src-file (insert full-body))
                 (org-babel-eval
@@ -80,6 +86,37 @@ parameters may be used, like javac -verbose"
        (org-babel-pick-name
         (cdr (assoc :rowname-names params)) (cdr (assoc :rownames params)))))))
 
+(defun org-babel-variable-assignments:java (params)
+  "Return an internal Java class assigning the block's variables."
+  (concat "    private static class Data {\n"
+         (mapconcat 'identity
+                    (mapcar
+                     (lambda (pair)
+                       (format "        public static %s %s = %s;"
+                               (cond
+                                ((stringp (cdr pair)) "String")
+                                ((listp (cdr pair)) "java.util.List")
+                                ((floatp (cdr pair)) "double")
+                                (t "int"))
+                               (car pair)
+                               (org-babel-java-var-to-java (cdr pair))))
+                     (mapcar #'cdr (org-babel-get-header params :var)))
+                    "\n")
+         "\n    }")
+  )
+
+(defun org-babel-java-var-to-java (var)
+  "Convert an elisp value to a java string.
+Convert an elisp value, VAR, into a string of Java source code
+specifying a variable of the same value."
+  (if (listp var)
+      (concat "java.util.Arrays.asList(" (mapconcat 
#'org-babel-java-var-to-java var ", ") ")")
+    (if (equal var 'hline)
+       "null"
+      (format
+       (if (and (stringp var) (string-match "[\n\r]" var)) "\"\"%S\"\"" "%S")
+       var))))
+
 (provide 'ob-java)
 
 
-- 
1.9.1




reply via email to

[Prev in Thread] Current Thread [Next in Thread]