From 0cc98bbe9cae3fd9fc50d8c78c1deaba7e557531 Mon Sep 17 00:00:00 2001 From: Eduardo Julian Date: Sat, 15 Jun 2019 19:45:32 -0400 Subject: Array machinery for the JavaScript compiler. --- lux-js/source/program.lux | 43 ++++++++++++++++++++++++++++--------------- 1 file changed, 28 insertions(+), 15 deletions(-) (limited to 'lux-js') 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 -- cgit v1.2.3