This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2022-06-25
Channels
- # babashka (31)
- # beginners (38)
- # biff (1)
- # calva (10)
- # clj-kondo (10)
- # clj-otel (9)
- # clojure (9)
- # clojure-europe (4)
- # clojure-norway (4)
- # clojurescript (26)
- # cursive (2)
- # datahike (3)
- # datomic (4)
- # emacs (6)
- # inf-clojure (2)
- # missionary (11)
- # nbb (3)
- # off-topic (9)
- # portal (17)
- # re-frame (16)
- # reagent (1)
- # releases (3)
- # shadow-cljs (5)
- # tools-build (17)
- # tools-deps (2)
- # xtdb (6)
Has anyone successfully packaged a ClojureScript library as a UMD (or AMD for that matter) module? I’m really struggling with it. The basic approach I’ve been attempting is to compile the ClojureScript with :target :bundle
and then feed the output through Webpack as per the https://clojurescript.org/guides/webpack.
Here’s my attempt at a https://github.com/zane/experiment/tree/library. This is just with output.library
set. No UMD or AMD yet.
:main
contains:
(defn ^:export hello
[]
(.log js/console "Hello, world!"))
webpack.config.js
is:
module.exports = {
entry: './out/main.js',
output: {
path: __dirname + '/dist',
filename: 'bundle.js',
library: 'tinylib',
},
};
But the resulting tinylib
that gets bound to window
is empty.
If there’s a different or better way I should be going about this I’m all ears.I think the issue is essentially that Webpack expects the entrypoint to export
all the variables to be included in the module, and the compiled JavaScript uses goog.exportSymbol
instead.
I’m toying with wrapping the compiled JavaScript with some code that augments goog.exportSymbol
before I feed it to Webpack, but I’m aware that that’s a huge hack. Suggestions welcome.
https://www.scattered-thoughts.net/log/0025 has some notes about issues when developing a cljs app, maybe this might be of interest to cljs dev team?
I assume you mean specifically this section: https://www.scattered-thoughts.net/log/0025#clojurescript-blues At least the Rum compilation issue has been handled after a chat in #cljs-dev.
Is it expected that Webpack will fail to build the output of :target :bundle
when :optimizations
is set to :advanced
?
@U050B88UR When I use :optimizations :whitespace
I get the error goog.dom is undefined
in the browser console when I include the bundle in a script tag.
With mode=production
Webpack compilation actually fails:
> webpack --config webpack.config.js --mode=production
assets by status 1.85 MiB [cached] 1 asset
runtime modules 221 bytes 1 module
./out/main.js 1.84 MiB [built] [code generated]
ERROR in bundle.js
bundle.js from Terser plugin
Invalid assignment [bundle.js:4443,541]
…stacktrace…
Throwing the files in a repository. There’s not a lot to it, but perhaps I’ve misconfigured it somehow.
Probably won't have time to look at this. But these all sound like webpack specific problems especially if the CLJS works without it. For the assignment issue did you look at the generated JS to see what is wrong?
"a lot of conditional compilation to support REPL driven development" - never needed such a thing ever - what does this mean?
I'm sure behind each "issue" there is something real to look at - but without proper bug reporting of any kind there's nothing to do about such posts
the one thing that looked somewhat suspicious the def meta fn thing - I cannot reproduce
Here’s my attempt at a https://github.com/zane/experiment/tree/library. This is just with output.library
set. No UMD or AMD yet.
:main
contains:
(defn ^:export hello
[]
(.log js/console "Hello, world!"))
webpack.config.js
is:
module.exports = {
entry: './out/main.js',
output: {
path: __dirname + '/dist',
filename: 'bundle.js',
library: 'tinylib',
},
};
But the resulting tinylib
that gets bound to window
is empty.
If there’s a different or better way I should be going about this I’m all ears.