diff --git a/src/main/clojure/cljs/closure.clj b/src/main/clojure/cljs/closure.clj index 060f75fbce..828b1f43fb 100644 --- a/src/main/clojure/cljs/closure.clj +++ b/src/main/clojure/cljs/closure.clj @@ -41,6 +41,7 @@ [cljs.env :as env] [cljs.js-deps :as deps] [clojure.java.io :as io] + [clojure.set :as set] [clojure.string :as string] [clojure.data.json :as json]) (:import [java.io File BufferedInputStream StringWriter] @@ -725,13 +726,25 @@ (find-cljs-dependencies ["cljs.core" "clojure.string"]) ) +(defn- module-entries + "Return the module entries of `compile-opts` as a set." + [compile-opts] + (->> compile-opts :modules vals + (map :entries) + (remove nil?) + (apply concat) + (set))) + (defn add-dependency-sources "Given list of IJavaScript objects, produce a new sequence of IJavaScript objects of all dependencies of inputs." - [inputs] - (let [inputs (set inputs) - requires (set (mapcat deps/-requires inputs))] - (into inputs (find-cljs-dependencies requires)))) + ([inputs] + (add-dependency-sources inputs nil)) + ([inputs compile-opts] + (let [inputs (set inputs) + requires (set (mapcat deps/-requires inputs)) + module-entries (module-entries compile-opts)] + (into inputs (find-cljs-dependencies (set/union requires module-entries)))))) (defn check-unprovided [inputs] @@ -1850,7 +1863,7 @@ (assoc all-opts :output-file (:output-to all-opts)) all-opts) js-sources (-> (-find-sources source all-opts) - add-dependency-sources + (add-dependency-sources compile-opts) deps/dependency-order (compile-sources compiler-stats compile-opts) (add-js-sources all-opts) diff --git a/src/test/cljs/module_test/main.cljs b/src/test/cljs/module_test/main.cljs new file mode 100644 index 0000000000..f44315e4f8 --- /dev/null +++ b/src/test/cljs/module_test/main.cljs @@ -0,0 +1,4 @@ +(ns module-test.main) + +(defn ^:export main [] + (println "Loading modules A and B ...")) diff --git a/src/test/cljs/module_test/modules/a.cljs b/src/test/cljs/module_test/modules/a.cljs new file mode 100644 index 0000000000..99e7fd02e5 --- /dev/null +++ b/src/test/cljs/module_test/modules/a.cljs @@ -0,0 +1,4 @@ +(ns module-test.modules.a) + +(defn ^:export main [] + (println "Module A loaded.")) diff --git a/src/test/cljs/module_test/modules/b.cljs b/src/test/cljs/module_test/modules/b.cljs new file mode 100644 index 0000000000..153319fe6d --- /dev/null +++ b/src/test/cljs/module_test/modules/b.cljs @@ -0,0 +1,4 @@ +(ns module-test.modules.b) + +(defn ^:export main [] + (println "Module B loaded.")) diff --git a/src/test/clojure/cljs/build_api_tests.clj b/src/test/clojure/cljs/build_api_tests.clj index f52e35ccb5..870e59996a 100644 --- a/src/test/clojure/cljs/build_api_tests.clj +++ b/src/test/clojure/cljs/build_api_tests.clj @@ -120,3 +120,28 @@ (build srcs opts) (is (not (every? #(zero? (.length %)) [common-tmp app-tmp])) "The files are not empty after compilation"))) + +(deftest cljs-1500-test-modules + (let [module-main (io/file "out/module-main.js") + module-a (io/file "out/module-a.js") + module-b (io/file "out/module-b.js")] + (.delete module-main) + (.delete module-a) + (.delete module-b) + (build + (inputs "src/test/cljs") + {:main "module-test.main" + :optimizations :advanced + :verbose true + :modules + {:cljs-base + {:output-to (str module-main)} + :module-a + {:output-to (str module-a) + :entries #{'module-test.modules.a}} + :module-b + {:output-to (str module-b) + :entries #{'module-test.modules.b}}}}) + (is (re-find #"Loading modules A and B" (slurp module-main))) + (is (re-find #"Module A loaded" (slurp module-a))) + (is (re-find #"Module B loaded" (slurp module-b)))))