eggroll
Commonjs module bundler that hoists all modules into a single scope so they can be concatenated safely without wrapping them in individual function scopes.
This allows the resulting package to be minified more efficiently and minimizes the extra overhead at runtime from evaluating these modules. See: https://nolanlawson.com/2016/08/15/the-cost-of-small-modules/
How this works
We implement the ideas described in http://www.nonblocking.io/2011/12/experimental-support-for-common-js-and.html that have been implemented in Google's closure compiler.
- All local variables are prefixed with a module specific prefix so they don't collide with local variables in other modules when added to the same scope.
module.exports
andexports.*
are replaced with a module specific global that other modules then reference directly.require
calls are replace with the respective module specific globals.
Running eggroll on the rollup-comparison: with output: https://gist.github.com/ymichael/91ef54ca7c756530635285cf8eb41d6e (318 bytes gzipped).
Installation
npm install -g eggroll
Quick Start
# Outputs a bundle using main.js as the entry point. $ eggroll bundle --resolve main.js # Outputs a bundle using public/main.js as the entry point. $ eggroll bundle --resolve --root ./public ./public/main.js # Outputs a bundle containing just the given files $ eggroll bundle --root ./public ./public/foo.js ./public/bar.js
Usage
Usage: eggroll <command> [options] Commands: deps [options] Output the dependencies found
$ eggroll bundle -hbin/cli.js bundle [options] <files...> Options: -h, --help Show help [boolean] --prefix custom prefix
$ eggroll deps [options] Options: -h, --help Show help [boolean] --entry module id of bundle entry point [string] [required] --root root to resolve module ids [string] [default: "process.cwd()"]
API Example
var eggroll = ;// TODO