hot take, javascript
There is no justifiable reason for so many different extensible (yet mutually incompatible) bundlers to exist, given how trivial of a task bundling is, and the fact that they *do* all exist should raise some uncomfortable questions about why
hot take, javascript
@serapath Bundlers are necessary because traversing a dependency graph over a high-latency link like the network is fundamentally not viable.
The problem I am talking about is not the existence of bundlers; it's that there are so many, and that most of them bring absolutely nothing to the table that wasn't already possible in their predecessor.
hot take, javascript
@joepie91
i would call that process "installation"
you do it once - on first page visit
or if not in production, then during "npm install".
a manifest file (even utilized in a web app), such as what `npm shrinkwrap` can produce can massively parallelize this process too.
no bundling needed.
hot take, javascript
@serapath Generating manifest files is functionally the same thing as bundling. "Bundling" is nothing more than statically traversing the dependency tree and string-concatenating the results with a minimal amount of boilerplate code to make the references work.
I don't know where people are getting this idea that bundling is some kind of highly complex or objectionable or slow process. It's kind of bizarre.
hot take, javascript
hmm... never considered `npm shrinkwrap` to be a bundler. ...it can work by transitioning package.jsons only technically.
Maybe it actually is implemented processing the sources too, but bundling is often associated with applying code transforms, tree shaking (a.k.a dead code elimination), maybe minifications and generating source maps and so on.
So saying `npm shrinkwrap` is a bundler feels like a stretch imho 🤷♀️
...anyway, just needed for first load speedup
hot take, javascript
@serapath None of those things (code transforms, tree shaking, minifying) are bundling. Source map generation is only a part of bundling insofar it describes the mapping from many files to one JS file.
Calling code transforms 'bundling' is like saying that Make 'compiles' your code. It doesn't. It just invokes the thing that does, if that's what you tell it to do in the process.
(Notably, switching from bundles to manifests also removes exactly zero of those things-that-are-not-bundling from your build stack)
hot take, javascript
@serapath Like, to be explicit about this: bundling code does not require *any* kind of code parsing or processing beyond identifying require/import calls, which can be done even if with a regex if you want. Which I believe is exactly what Browserify does, too.
hot take, javascript
@joepie91
hmm.. i think browserify uses acorn to parse into an AST, but now that you say it, i'm not 100% sure anymore.
I stipl use browserify for all my projects. never had any need for "newer" stuff and still feel browseries approach as a build+bundle tool was the best and its a shame it never got the support and money the big tech sponsored projects got.
i wosh we wpuld make browserify great again 😁
MBGA
hot take, javascript
@joepie91
oh alright. i misunderstood you then.
when you said there are so many bundlers, i though of webpack, browserify amd the many newer variants and they do transformation as well.
i am not aware of any "bundler" that just concatenates stuff, so i translated what you said with build+bundle
hot take, javascript
@serapath Neither Browserify nor Webpack do code transformation (or at least for Webpack that's true in its initial version). Both just do concatenation.
Both support plugins, which *can* do code transformation, but that happens entirely outside of the bundler.
hot take, javascript
@joepie91
i see.
yeah, if you dont apply any code transforms or plugins in browserify thata true, but if there qas NO support for it, it would be kinda useless and a .concat would be enough.
also browserify at least patches the environment with nodejs shims.
still imho we should not need bundlers as all
hot take, javascript
@serapath Just a .concat wouldn't be enough because it doesn't create a module scope; that's what the small amount of additional wiring is for, but that's also just strings
hot take, javascript
fair.
anyway, i can see some reason why you would need a builder to e.g. allow ppl to author in typescript ...but many other reasons too, basically to process sources.
But imho that should be part of the runtime and should happen dynamically and deterministically cached ...the web caches stufd so cpupd totally support that.
Bundling should not be necessary imho.
let me downloading missing modules instead of parge bundles containing stuff i already have
hot take, javascript
@serapath
What is the post web, if I may ask?
hot take, javascript
javascript is the lingua franca.
javascript and the web is also latin.
big tech and big tech standard bodies have to die and small modular tech which allows high decentralization needs to take over.
it will - and the way i see it is, by killing the web ...through carving out opinionated subsets of the current web that can be maintained by small teams.
dat ecosysyem is trying that and the latest example project is the `pear runtime` 🙂
...many search for right ways
re: hot take, javascript
@joepie91 the main issue imho is the fact that people wanted to code bundlers in javascript and javascript is an absolutely terrible choice for code that requires allocating and processing large amounts of data
most of the time spent in bundlers is just bound to garbage-collecting since they don't reuse buffers at all (you can't in JS) and have to instead rely on allocating massive buffers for each operation, which is slow
like even a garbage-collected language like go that at least lets you reuse buffers has a dramatic improvement in the time it takes to do things
re: hot take, javascript
@clarfonthey Bundlers have never been slow. You can bundle the frontend code for whole production sites in under like 400ms. The slow part was always all of the shit that people inserted *into* the bundling process (like code analysis, minification, etc.)
re: hot take, javascript
@joepie91 I mean, that's fair. I still think that all the preprocessing is ultimately a good idea, since limiting the required download size is good, but you're right that you get diminishing returns and with processing tools written in javascript you diminish the returns far more rapidly
re: hot take, javascript
@clarfonthey That's a whole different discussion, though, that isn't really relevant for my original post - which is that bundling is, itself, fundamentally a very simple operation (it's basically somewhat structured string concatenation) and there is no reason for people to reinvent that wheel 10 times.
re: hot take, javascript
@joepie91 this is also fair
the tech industry loves to make products instead of useful code, and so, there's no such thing as just a bundler; it has to do everything else too
hot take, javascript
@joepie91 browserify exists and everything else followed, because big tech standard bodies are an anti pattern.
They just cant make good tech.
Bundlers exist because the web sucks.
Imho designing for the need of bundlers is designing for the technical debt and big tech.
We should get rid of all bundlers.
nodejs didnt need them and post web shouldnt need them either.
Post web is in the air already and will manifest any time now 🙂