diff --git a/CHANGELOG.md b/CHANGELOG.md index 8b8da179..a6cbbb22 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -14,6 +14,7 @@ SCI is used in [babashka](https://github.com/babashka/babashka), - Fix [#942](https://github.com/babashka/sci/issues/942): improve error location of invalid destructuring - Add `volatile?` to core vars +- Fix [#950](https://github.com/babashka/sci/issues/950): interop on local in CLJS ## 0.9.44 (2024-10-17) diff --git a/src/sci/impl/analyzer.cljc b/src/sci/impl/analyzer.cljc index 7b7b6f66..1a4ab2c7 100644 --- a/src/sci/impl/analyzer.cljc +++ b/src/sci/impl/analyzer.cljc @@ -1563,10 +1563,16 @@ (sci.impl.types/->Node (interop/invoke-js-constructor* ctx bindings ctor children) nil)) - (let [method (unchecked-get class method-name)] + (if (instance? t/NodeR class) (sci.impl.types/->Node - (interop/invoke-static-method ctx bindings class method children) - nil))) + (let [class (t/eval class ctx bindings) + method (unchecked-get class method-name)] + (interop/invoke-static-method ctx bindings class method children)) + nil) + (let [method (unchecked-get class method-name)] + (sci.impl.types/->Node + (interop/invoke-static-method ctx bindings class method children) + nil)))) (if ctor? (sci.impl.types/->Node (let [arr (lookup-fn) @@ -1574,12 +1580,12 @@ (interop/invoke-js-constructor* ctx bindings ctor children)) nil) (sci.impl.types/->Node - (let [arr (lookup-fn) - class (aget arr 0) - method-name (aget arr 1) - method (unchecked-get class method-name)] - (interop/invoke-static-method ctx bindings class method children)) - nil))))) + (let [arr (lookup-fn) + class (aget arr 0) + method-name (aget arr 1) + method (unchecked-get class method-name)] + (interop/invoke-static-method ctx bindings class method children)) + nil))))) #?@(:clj [(and f-meta (:sci.impl.analyzer/interop f-meta)) (let [[obj & children] (analyze-children ctx (rest expr)) meth (-> (second f) diff --git a/src/sci/impl/resolve.cljc b/src/sci/impl/resolve.cljc index 73355020..4d8039ac 100644 --- a/src/sci/impl/resolve.cljc +++ b/src/sci/impl/resolve.cljc @@ -279,5 +279,5 @@ #?(:cljs (let [resolved (resolve-dotted-access ctx sym call? tag)] resolved)) (throw-error-with-location - (str "Could not resolve symbol: " (str sym)) + (str "Could not resolve symbol: " sym) sym))))) diff --git a/test/sci/interop_test.cljc b/test/sci/interop_test.cljc index b452911a..af46a456 100644 --- a/test/sci/interop_test.cljc +++ b/test/sci/interop_test.cljc @@ -329,3 +329,6 @@ (is (true? (tu/eval* "(when js/document js/document.getElementById) true" {:classes {'js goog/global :allow :all}}))))) + +#?(:cljs (deftest local-interop-test + (is (= 1 (tu/eval* "(def j #js {:a (fn [] 2)}) (let [j #js {:a (fn [] 1)}] (j.a))" nil)))))