diff options
author | Eduardo Julian | 2019-06-15 19:45:32 -0400 |
---|---|---|
committer | Eduardo Julian | 2019-06-15 19:45:32 -0400 |
commit | 0cc98bbe9cae3fd9fc50d8c78c1deaba7e557531 (patch) | |
tree | 4439100c5f036870282b6c93ac45e3731bcdf6fd /lux-js | |
parent | 7ee04017ee2ef5376c566b00750fd521c0ecac42 (diff) |
Array machinery for the JavaScript compiler.
Diffstat (limited to '')
-rw-r--r-- | lux-js/source/program.lux | 43 |
1 files changed, 28 insertions, 15 deletions
diff --git a/lux-js/source/program.lux b/lux-js/source/program.lux index 00bdd2ef8..77b23e2f7 100644 --- a/lux-js/source/program.lux +++ b/lux-js/source/program.lux @@ -29,7 +29,10 @@ ["." name] [phase [macro (#+ Expander)] - ["." extension/bundle] + ["." extension #_ + ["#/." bundle] + ["." analysis #_ + ["#/." js]]] ["." generation ["." js ["." runtime] @@ -42,8 +45,11 @@ (import: #long java/lang/String) +(import: #long (java/lang/Class a)) + (import: #long java/lang/Object - (toString [] java/lang/String)) + (toString [] java/lang/String) + (getClass [] (java/lang/Class java/lang/Object))) (import: #long java/lang/Long (intValue [] java/lang/Integer)) @@ -220,8 +226,9 @@ (exception: null-has-no-lux-representation) (exception: undefined-has-no-lux-representation) -(exception: (unknown-kind-of-js-object {object java/lang/Object}) +(exception: (unknown-kind-of-host-object {object java/lang/Object}) (exception.report + ["Class" (java/lang/Object::toString (java/lang/Object::getClass object))] ["Object" (java/lang/Object::toString object)])) (exception: (cannot-apply-a-non-function {object java/lang/Object}) @@ -272,23 +279,27 @@ jdk/nashorn/api/scripting/ScriptObjectMirror (Maybe (Array java/lang/Object))) (if (jdk/nashorn/api/scripting/JSObject::isArray js-object) - (let [init-num-keys (.nat (jdk/nashorn/api/scripting/ScriptObjectMirror::size js-object))] - (loop [num-keys init-num-keys - idx 0 + (let [num-keys (.nat (jdk/nashorn/api/scripting/ScriptObjectMirror::size js-object))] + (loop [idx 0 output (: (Array java/lang/Object) - (array.new init-num-keys))] + (array.new num-keys))] (if (n/< num-keys idx) (case (jdk/nashorn/api/scripting/JSObject::getMember (%n idx) js-object) (#.Some member) - (case (lux-object member) - (#error.Success parsed-member) - (recur num-keys (inc idx) (array.write idx (:coerce java/lang/Object parsed-member) output)) + (case (host.check jdk/nashorn/internal/runtime/Undefined member) + (#.Some _) + (recur (inc idx) output) + + #.None + (case (lux-object member) + (#error.Success parsed-member) + (recur (inc idx) (array.write idx (:coerce java/lang/Object parsed-member) output)) - (#error.Failure error) - #.None) + (#error.Failure error) + #.None)) #.None - (recur num-keys (inc idx) output)) + (recur (inc idx) output)) (#.Some output)))) #.None)) @@ -335,10 +346,10 @@ #.None (if (jdk/nashorn/api/scripting/JSObject::isFunction js-object) (exception.return js-object) - (exception.throw unknown-kind-of-js-object (:coerce java/lang/Object js-object)))))) + (exception.throw ..unknown-kind-of-host-object (:coerce java/lang/Object js-object)))))) #.None) ## else - (exception.throw unknown-kind-of-js-object (:coerce java/lang/Object js-object)) + (exception.throw ..unknown-kind-of-host-object (:coerce java/lang/Object js-object)) ))) (def: (ensure-macro macro) @@ -449,7 +460,9 @@ (program: [{service /cli.service}] (/.compiler @.js + ".js" ..expander + analysis/js.bundle ..platform extension.bundle extension/bundle.empty |