-
Notifications
You must be signed in to change notification settings - Fork 792
Enhanced Node.js Modules Support
Node.js CommonJS module support still lacks deeper integration to make the experience truly seamless. Currently users must define a JS entry point first in order to include a CommonJS module into the build, direct requires of CommonJS modules is not supported. Even when this becomes possible this doesn't solve the problem of creating and packaging ClojureScript libraries that can express their dependencies on NPM modules.
We should just index the top level of node_modules
. When a users requires a Node.js CommonJS module we can then easily check that it exists. We should also track all such requires.
All these requires will themselves become the entry points that we pass to module-deps
(we can just create a fake JS file with the necessary requires just so we can compute the dependency graph). The only questionable bit is that we might have to hook a bit into a Closure implementation detail in computing the module name so we generate the correct goog.require
in the ClojureScript namespace.
We can allow users to express their Node.js dependencies in deps.cljs
. We can then provide a way to shell out to Node.js to ensure that these dependencies get installed. For example something like the following:
{
;;..
:npm-deps {"react" "15.4.2"
"object-assign" "4.1.1"}
;; ...
}
We need to handle dependency conflicts. We probably need to warn about conflicts. To remove conflicts users can provide :npm-deps
directly to the compiler which overrides any versions defined via deps.cljs
.
- Rationale
- Quick Start
- Differences from Clojure
- [Usage of Google Closure](Google Closure)