diff options
| author | Joel Martin <github@martintribe.org> | 2014-04-17 21:49:07 -0500 |
|---|---|---|
| committer | Joel Martin <github@martintribe.org> | 2014-04-17 21:49:07 -0500 |
| commit | db4c329aff4621e05b92a55be4f18173f5a4f655 (patch) | |
| tree | 92baaa6d88246e509cfd6a7d03d8fab997e0b935 /java | |
| parent | 8cb5cda46cf3aef847ae3926dc53a5e5f87fe261 (diff) | |
| download | mal-db4c329aff4621e05b92a55be4f18173f5a4f655.tar.gz mal-db4c329aff4621e05b92a55be4f18173f5a4f655.zip | |
All: perf test, Makefile refactor, add *host-language*
Other:
- bash,make,postscript: quasiquote of vectors
- Fix Java slurp
- add time function to core.mal
- switches on *host-language* for make time-secs vs time-ms
- Ignore */experiments directories
Diffstat (limited to 'java')
| -rw-r--r-- | java/src/main/java/mal/core.java | 11 | ||||
| -rw-r--r-- | java/src/main/java/mal/stepA_more.java | 1 |
2 files changed, 11 insertions, 1 deletions
diff --git a/java/src/main/java/mal/core.java b/java/src/main/java/mal/core.java index ea6787d..0f1d226 100644 --- a/java/src/main/java/mal/core.java +++ b/java/src/main/java/mal/core.java @@ -117,8 +117,10 @@ public class core { public MalVal apply(MalList args) throws MalThrowable { String fname = ((MalString)args.nth(0)).getValue(); try { + // Scanner drops final newline, so add it back return new MalString( - new Scanner(new File(fname)).useDelimiter("\\Z").next()); + new Scanner(new File(fname)).useDelimiter("\\Z").next() + + "\n"); } catch (FileNotFoundException e) { throw new MalError(e.getMessage()); } @@ -169,6 +171,12 @@ public class core { } }; + static MalFunction time_ms = new MalFunction() { + public MalVal apply(MalList a) throws MalThrowable { + return new MalInteger((int)System.currentTimeMillis()); + } + }; + // List functions static MalFunction new_list = new MalFunction() { @@ -480,6 +488,7 @@ public class core { .put("-", subtract) .put("*", multiply) .put("/", divide) + .put("time-ms", time_ms) .put("list", new_list) .put("list?", list_Q) diff --git a/java/src/main/java/mal/stepA_more.java b/java/src/main/java/mal/stepA_more.java index 5ed5667..17bdb16 100644 --- a/java/src/main/java/mal/stepA_more.java +++ b/java/src/main/java/mal/stepA_more.java @@ -245,6 +245,7 @@ public class stepA_more { }); // core.mal: defined using the language itself + RE(repl_env, "(def! *host-language* \"java\")"); RE(repl_env, "(def! not (fn* (a) (if a false true)))"); RE(repl_env, "(def! load-file (fn* (f) (eval (read-string (str \"(do \" (slurp f) \")\")))))"); RE(repl_env, "(defmacro! cond (fn* (& xs) (if (> (count xs) 0) (list 'if (first xs) (if (> (count xs) 1) (nth xs 1) (throw \"odd number of forms to cond\")) (cons 'cond (rest (rest xs)))))))"); |
