eggroll

0.0.4 • Public • Published

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.

  1. 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.
  2. module.exports and exports.* are replaced with a module specific global that other modules then reference directly.
  3. 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 for the given entry
                               point
  bundle [options] <files...>  Bundle the given files
 
Options:
  -h, --help  Show help                                                [boolean]
$ eggroll bundle -h
bin/cli.js bundle [options] <files...>
 
Options:
  -h, --help  Show help                                                [boolean]
  --prefix    custom prefix for module variables[string] [default: "$$module$$"]
  --resolve   whether to resolve dependencies         [boolean] [default: false]
  --root      root to resolve module ids
                                             [string] [default: "process.cwd()"]
$ 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 = require('eggroll');
// TODO
 

Other links

Versions

Current Tags

  • Version
    Downloads (Last 7 Days)
    • Tag
  • 0.0.4
    10
    • latest

Version History

  • Version
    Downloads (Last 7 Days)
    • Published
  • 0.0.4
    10
  • 0.0.3
    0
  • 0.0.2
    0
  • 0.0.1
    0

Package Sidebar

Install

npm i eggroll

Weekly Downloads

10

Version

0.0.4

License

MIT

Last publish

Collaborators

  • ymichael