diff --git a/.travis.yml b/.travis.yml index 9672e1293..c8874bc58 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,6 +1,20 @@ language: node_js node_js: - - "0.8" + - "9" + - "8" + - "6" + - "4" + - "iojs" + - "0.12" - "0.10" + - "0.8" + - "0.6" before_install: - - npm install -g npm@~1.4.6 + - 'nvm install-latest-npm' +install: + - 'if [ "${TRAVIS_NODE_VERSION}" = "0.6" ] || [ "${TRAVIS_NODE_VERSION}" = "0.9" ]; then nvm install --latest-npm 0.8 && npm install && nvm use "${TRAVIS_NODE_VERSION}"; else npm install; fi;' +sudo: false +matrix: + fast_finish: true + allow_failures: + - node_js: "0.6" diff --git a/LICENSE b/LICENSE index c9016780d..dc49ca978 100644 --- a/LICENSE +++ b/LICENSE @@ -29,7 +29,7 @@ buffer_ieee754.js has this license in it: ---- -Copyright (c) 2008-2014, Fair Oaks Labs, Inc. +Copyright (c) 2008-2015, Fair Oaks Labs, Inc. All rights reserved. Redistribution and use in source and binary forms, with or without diff --git a/assets/browserify.png b/assets/browserify.png new file mode 100644 index 000000000..56a8f741d Binary files /dev/null and b/assets/browserify.png differ diff --git a/assets/logo.png b/assets/logo.png new file mode 100644 index 000000000..98d6bf5f6 Binary files /dev/null and b/assets/logo.png differ diff --git a/bin/advanced.txt b/bin/advanced.txt index 23ed10f31..6d7c08bdd 100644 --- a/bin/advanced.txt +++ b/bin/advanced.txt @@ -51,6 +51,24 @@ Advanced Options: to just "__filename,__dirname". This is handy if you want to run bundles in node. + --no-browser-field, --no-bf + + Turn off package.json browser field resolution. This is also handy if you + need to run a bundle in node. + + --transform-key + + Instead of the default package.json#browserify#transform field to list + all transforms to apply when running browserify, a custom field, like, e.g. + package.json#browserify#production or package.json#browserify#staging + can be used, by for example running: + * `browserify index.js --transform-key=production > bundle.js` + * `browserify index.js --transform-key=staging > bundle.js` + + --node + + Alias for --bare and --no-browser-field. + --full-paths Turn off converting module ids into numerical indexes. This is useful for @@ -61,6 +79,10 @@ Advanced Options: Instead of standard bundle output, print the dependency array generated by module-deps. + --no-dedupe + + Turn off deduping. + --list Print each file in the dependency graph. Useful for makefiles. @@ -70,7 +92,7 @@ Advanced Options: Consider files with specified EXTENSION as modules, this option can used multiple times. - --global-transform=MODULE, --g MODULE + --global-transform=MODULE, -g MODULE Use a transform module on all files after any ordinary transforms have run. diff --git a/bin/args.js b/bin/args.js index 11d9f00c7..6a4166afd 100644 --- a/bin/args.js +++ b/bin/args.js @@ -13,12 +13,14 @@ module.exports = function (args, opts) { var argv = subarg(args, { 'boolean': [ 'deps', 'pack', 'ig', 'dg', 'im', 'd', 'list', 'builtins', - 'commondir', 'bare', 'full-paths', 'bundle-external' + 'commondir', 'bare', 'full-paths', 'bundle-external', 'bf', + 'node' ], string: [ 's', 'r', 'u', 'x', 't', 'i', 'o', 'e', 'c', 'it' ], alias: { ig: [ 'insert-globals', 'fast' ], dg: [ 'detect-globals', 'detectGlobals', 'dg' ], + bf: [ 'browser-field', 'browserField' ], im: 'ignore-missing', it: 'ignore-transform', igv: 'insert-global-vars', @@ -43,7 +45,10 @@ module.exports = function (args, opts) { d: false, builtins: true, commondir: true, - 'bundle-external': true + 'bundle-external': true, + bf: true, + dedupe: true, + node: false } }); @@ -57,22 +62,41 @@ module.exports = function (args, opts) { s.resume(); return rs; } - return path.resolve(process.cwd(), entry); + return entry; }); + if (argv.node) { + argv.bare = true; + argv.browserField = false; + } if (argv.bare) { argv.builtins = false; argv.commondir = false; - argv.detectGlobals = false; if (argv.igv === undefined) { argv.igv = '__filename,__dirname'; } } - + + if (argv.igv) { + var insertGlobalVars = {}; + var wantedGlobalVars = argv.igv.split(','); + Object.keys(insertGlobals.vars).forEach(function (x) { + if (wantedGlobalVars.indexOf(x) === -1) { + insertGlobalVars[x] = undefined; + } + }); + } + var ignoreTransform = argv['ignore-transform'] || argv.it; var b = browserify(xtend({ noParse: Array.isArray(argv.noParse) ? argv.noParse : [argv.noParse], - extensions: [].concat(argv.extension).filter(Boolean), + extensions: [].concat(argv.extension).filter(Boolean).map(function (extension) { + if (extension.charAt(0) != '.') { + return '.' + extension; + } else { + return extension + } + }), ignoreTransform: [].concat(ignoreTransform).filter(Boolean), entries: entries, fullPaths: argv['full-paths'], @@ -80,7 +104,10 @@ module.exports = function (args, opts) { commondir: argv.commondir === false ? false : undefined, bundleExternal: argv['bundle-external'], basedir: argv.basedir, - + browserField: argv.browserField, + transformKey: argv['transform-key'] ? ['browserify', argv['transform-key']] : undefined, + dedupe: argv['dedupe'], + detectGlobals: argv.detectGlobals, insertGlobals: argv['insert-globals'] || argv.ig, insertGlobalVars: insertGlobalVars, @@ -134,7 +161,7 @@ module.exports = function (args, opts) { [].concat(argv.require).filter(Boolean) .forEach(function (r) { - var xs = r.split(':'); + var xs = splitOnColon(r); b.require(xs[0], { expose: xs.length === 1 ? xs[0] : xs[1] }) }) ; @@ -142,8 +169,8 @@ module.exports = function (args, opts) { // resolve any external files and add them to the bundle as externals [].concat(argv.external).filter(Boolean) .forEach(function (x) { - if (/:/.test(x)) { - var xs = x.split(':'); + var xs = splitOnColon(x); + if (xs.length === 2) { add(xs[0], { expose: xs[1] }); } else if (/\*/.test(x)) { @@ -225,20 +252,18 @@ module.exports = function (args, opts) { return b; } - var insertGlobalVars; - if (argv.igv) { - insertGlobalVars = argv.igv.split(',').reduce(function (vars, x) { - vars[x] = insertGlobals.vars[x]; - return vars; - }, {}); - } - return b; }; -function copy (obj) { - return Object.keys(obj).reduce(function (acc, key) { - acc[key] = obj[key]; - return acc; - }, {}); +function splitOnColon (f) { + var pos = f.lastIndexOf(':'); + if (pos == -1) { + return [f]; // No colon + } else { + if ((/[a-zA-Z]:[\\/]/.test(f)) && (pos == 1)){ + return [f]; // Windows path and colon is part of drive name + } else { + return [f.substr(0, pos), f.substr(pos + 1)]; + } + } } diff --git a/bin/cmd.js b/bin/cmd.js index d7cc844b9..1a63b19ac 100755 --- a/bin/cmd.js +++ b/bin/cmd.js @@ -22,7 +22,7 @@ if (b.argv._[0] === 'help' || b.argv.h || b.argv.help .on('close', function () { process.exit(1) }) ; } -if (b.argv.v || b.argv.version) { +if (b.argv.version) { return console.log(require('../package.json').version); } @@ -56,25 +56,25 @@ if (b.argv.list) { var bundle = b.bundle(); bundle.on('error', errorExit); +bundle.on('end', successExit); +var tmpfile; var outfile = b.argv.o || b.argv.outfile; if (outfile) { mkdirp.sync(path.dirname(outfile)); - bundle.pipe(fs.createWriteStream(outfile)); + + // we'll output to a temp file within same filesystem, then atomically overwrite outfile once successful + tmpfile = outfile + ".tmp-browserify-" + Math.random().toFixed(20).slice(2) + bundle.pipe(fs.createWriteStream(tmpfile)); } else { bundle.pipe(process.stdout); } -function packageFilter (info) { - if (info && typeof info.browserify === 'string' && !info.browser) { - info.browser = info.browserify; - delete info.browserify; - } - return info || {}; -} - function errorExit(err) { + if (tmpfile) fs.unlink(tmpfile, function (err) { + if (err) /* no-op, we're already exiting unhappily… */; + }); if (err.stack) { console.error(err.stack); } @@ -83,3 +83,9 @@ function errorExit(err) { } process.exit(1); } + +function successExit() { + if (tmpfile && outfile) fs.rename(tmpfile, outfile, function (err) { + if (err) errorExit(err); + }); +} diff --git a/changelog.markdown b/changelog.markdown index 936380555..bc4e12cce 100644 --- a/changelog.markdown +++ b/changelog.markdown @@ -1,3 +1,510 @@ +# 15.0.0 + +fixed repository url in package.json. + +https://github.com/browserify/browserify/commit/5ec19eed48a5f46cb48d44be8ffc2f6bfb73fbfb + +update `module-deps` to 5.0.0, which enables requiring modules in backtick-enclosed strings. + +https://github.com/browserify/browserify/pull/1785 + +dropped testing in node 0.10 and 0.12, set supported node versions to `>=4` + +https://github.com/browserify/browserify/pull/1743 +https://github.com/browserify/browserify/pull/1793 + +add support for passing arrays to the `exclude` and `ignore` methods. + +https://github.com/browserify/browserify/pull/1769 + +# 14.5.0 + +update `os-browserify` to 0.3.0, which adds a shim for node.js's `os.homedir` method. + +https://github.com/browserify/browserify/pull/1767 + +update `browserify-zlib` to 0.2.0, which adds support for dictionaries. + +https://github.com/browserify/browserify/pull/1733 + +# 14.4.0 + +update `string_decoder` to 1.0.0, which matches the latest node.js behavior more closely. + +https://github.com/substack/node-browserify/pull/1714 + +# 14.3.0 + +update `https-browserify` to 1.0.0, which matches node.js behavior more closely. + +- throw exception if non-https URL is passed to `https.request` or `https.get` +- support passing string URL as first argument to `https.request` and `https.get` + +https://github.com/substack/node-browserify/pull/1710 + +# 14.2.0 + +adds a --transform-key flag to the command-line tool + +https://github.com/substack/node-browserify/pull/1709 + +# 14.1.0 + +writes to a temp outfile until success + +Previously, browserify would overwrite output files when an error occurs. + +https://github.com/substack/node-browserify/pull/1673 +https://github.com/substack/node-browserify/issues/899 + +# 14.0.0 + +Updates the version of the buffer package, which drops support for IE8-10. + +buffer v5 removes the `Object` implementation and relies on a single, +fast Typed Array (`Uint8Array`) implementation, greatly simplifying the +maintanence of the buffer package. + +If IE8-10 support is critical to your web app, you can continue to rely on +browserify v13, or see the PR for other workarounds. + +https://github.com/substack/node-browserify/pull/1678 + +# 13.3.0 + +updates the version for the assert package + +https://github.com/substack/node-browserify/pull/1611 + +# 13.2.0 + +allow configuring transformKey from module-deps +https://github.com/substack/node-browserify/pull/1670 + +# 13.1.1 + +boost performance by memoizing calls to path.relative() + +https://github.com/substack/node-browserify/pull/1544 + +# 13.1.0 + +exposes `opts.dedupe` and `--no-deupe` to optionally turn off deduping behavior: +[#1581](https://github.com/substack/node-browserify/pull/1581) + +# 13.0.1 + +## Internal + +[#1552](https://github.com/substack/node-browserify/pull/1552), [#1555](https://github.com/substack/node-browserify/pull/1555): Use native `Array.isArray` and drop `isarray` dep. ([@kt3k](https://github.com/kt3k)) + +# 13.0.0 + +This release bumps the [`buffer`](https://www.npmjs.com/package/buffer) dependency +to v4, which has one possible breaking change: + +- The `buffer.toArrayBuffer()` method on `Buffer` instances has been removed. + +(This is probably not a problem for 99.9% of users.) + +This API was added in node v0.11.8 and +[removed before v0.12 was released](https://github.com/nodejs/node-v0.x-archive/issues/7609#issuecomment-42903457). +It was added to browserify's `buffer` implementation but was never removed when v0.12 + was released. `buffer` v4 removes it so we have full parity with node.js. + +Going forward, to get an `ArrayBuffer` from a node.js-style `Buffer`, users should +just use `buffer.buffer`. This works because `Buffer` is a subclass of `Uint8Array` +in both the browser and node.js (since v3). + +On the plus side, this release also includes: + +- Performance improvements to `buffer` that +[increase the speed](https://github.com/feross/buffer/pull/92) of some buffer +methods by as much as 30%! + +# 12.0.2 + +normalizes module paths on windows to consistently use `/` + +https://github.com/substack/node-browserify/pull/1424#issuecomment-170143099 + +# 12.0.1 + +adds the previously failing tests and a small change necessary for transforms to +be applied properly for symlinked packages + +https://github.com/substack/node-browserify/pull/1392 + +# 12.0.0 + +Node support changes: now testing against the latest node (currently 4.2.1). +node 0.8 is no longer supported, and iojs isn't actively tested. + +Stream3 everywhere! Everything has been updated to use streams3. + +Sourcemaps charset now uses an `=` instead of a `:`. This fixes certain issues +with Chinese characters in sourcemaps. See #753. + +module-deps has been updated to fix root transforms on symlinked modules. See +https://github.com/substack/module-deps/pull/99. + +stream-http, the module that provides `http` support, dropped IE8 support. If +you depend on this, see https://github.com/jhiesey/stream-http#ie8-note. + +Removed `builtins` and `commondir` – both unused dependencies. + +# 11.2.0 + +When `bundleExternal` is set to `false`, `process` and `buffer` are now correctly excluded. Also, using `--igv` via the CLI now works. That also means that `--bare` and `--node` actually insert `__filename` and `__dirname`. + +https://github.com/substack/node-browserify/pull/1361 + +# 11.1.0 + +adds a `'.'` to extensions if it wasn't added + +https://github.com/substack/node-browserify/pull/1380 + +# 11.0.1 + +The callback form of bundle() uses the returned output stream instead of the +pipeline so that the `'end'` event will fire on the bundle instance. + +https://github.com/substack/watchify/pull/249#issuecomment-126061169 + +# 11.0.0 + +## streams3 + +The [`readable-stream`](https://npmjs.com/package/readable-stream) dependency was updated to `^2.0.0`. This package is inserted into bundles as `require('stream')`. Bundles will now get the latest streams implementation from io.js/node.js core, instead of an old version from node.js 0.11.x. Go forth and stream ALL THE DATA without fear! + +## shiny new HTTP package + +[John Hiesey](https://github.com/jhiesey) rewrote the [http-browserify](https://npmjs.org/package/http-browserify) package +to create [stream-http](https://npmjs.org/package/stream-http), an implemention of `http` that supports streaming in modern browsers. Before v11.0.0, in most situations when you used `http.get` or `http.request`, the entire request would buffer in memory until the download was complete, and a single `'data'` event was emitted with the entire response as a string. + +`stream-http` uses the [Fetch API](https://fetch.spec.whatwg.org/) and various browser-specific XHR extensions to make binary streaming http requests work in as many browsers as possible. + +The following browsers support true streaming, where only a small amount of the request has to be held in memory at once: + +* Chrome >= 43 (using the `fetch` api) +* Firefox >= 9 (using `moz-chunked-arraybuffer` responseType with XHR) + +The following browsers support pseudo-streaming, where the data is available before the request finishes, but the entire response must be held in memory: + +* Safari >= 5 +* IE >= 10 +* Most other Webkit-based browsers, including the default Android browser + +Older browsers will work, without streaming support. There is no support for IE6 or IE7. + +Compared to `http-browserify`, it is not necessary to set `options.responseType`. The `responseType` property of the XHR object will be set automatically depending on what features are detected in the browser (although see `options.mode` in the [readme](https://github.com/jhiesey/stream-http) to see how you can optimize this choice manually). + +The `response` is a streams3 stream, so all data is passed as `Buffer`s, unlike the variable types provided by the `'data'` event in `http-browserify`. This behavior tries to mimic the node core `http` module as closely as possible. + +* [#1327](https://github.com/substack/node-browserify/pull/1327) + +If you're brave, go ahead and give v11.0.0 a try today! + +# 10.2.6 + +uses the non-sync version of fs.realpath + +# 10.2.5 + +fixes an issue with symlinked files executing multiple times + +https://github.com/substack/node-browserify/issues/1063 +https://github.com/substack/node-browserify/pull/1318 + +# 10.2.4 + +fixes requiring an entry from another entry + +remove unused dep "deep-equal" and unused file "lib/_exclude.js" + +https://github.com/substack/node-browserify/pull/1268 + +# 10.2.3 + +fixes an errant space in the `--no-browser-field` flag alias +that kept it from working + +https://github.com/substack/node-browserify/issues/1286 + +# 10.2.2 + +fix tests for tap@^1.1.0 (and update tap) + +https://github.com/substack/node-browserify/pull/1276 + +# 10.2.1 + +housekeeping - removed unused code + +https://github.com/substack/node-browserify/pull/1273 + +# 10.2.0 + +remove unnecessary "isDedupe" json check. this was a hack-fix for watchify <=2.4. + +https://github.com/substack/node-browserify/pull/1244 + +fixes for the "noParse" path matcher. + +https://github.com/substack/node-browserify/pull/1259 + +add syntax check cache. this speeds up rebuilds (like when using watchify). + +https://github.com/substack/node-browserify/pull/1253 + +update to browser-pack@^5.0.0 - includes several fixes related to source maps. + +https://github.com/substack/node-browserify/pull/1257 + +# 10.1.3 + +Replace jsonstream with JSONStream + +https://github.com/substack/node-browserify/pull/1252 + +# 10.1.2 + +Replace JSONStream with jsonstream +Update deps to avoid jsonstream npm case problems + +https://github.com/substack/node-browserify/pull/1247 +https://github.com/substack/node-browserify/commit/1ca71e23 + +# 10.1.1 + +ensures that entry paths are always full paths + +https://github.com/substack/node-browserify/pull/1248 + +# 10.1.0 + +adds `--no-browser-field` and `opts.browserField = false` behavior to turn off +the package.json browser field. This is useful if you want to make a bundle with +a target of node or some environment with shimmed node primitives. + +A new alias `--node` sets `--no-browser-field` and `--bare`. + +https://github.com/substack/node-browserify/pull/1240 + +# 10.0.0 + +## Possibly Breaking Change +The ‘process’ dependency was updated to ~0.11.0, this module is inserted into bundles as the ‘process’ global/dependency. +Previously, an unhandled error thrown in a ‘process.nextTick’ task would prevent any subsequent tasks from running, forever. +The task queue now recovers from this condition, but may do so on a future browser tick. +As part of this update, ‘process.nextTick’ now accepts variadic arguments, passed to the task, added to io.js in 1.8.1. + +* [#1231](https://github.com/substack/node-browserify/pull/1231) +* [defunctzombie/node-process#38](https://github.com/defunctzombie/node-process/pull/38) +* [iojs/io.js#1077](https://github.com/iojs/io.js/pull/1077) + +## Other changes + +* Escapes JavaScript-unsafe characters from JSON. [#1211](https://github.com/substack/node-browserify/pull/1211) +* Removes ‘-v’ shortcut for ‘--version’ (conflicted with watchify) [#1222](https://github.com/substack/node-browserify/pull/1222) +* Updated ‘defined’, ‘punycode’, ‘module-deps’, and ‘xtend’ dependencies to reduce install size [#1230](https://github.com/substack/node-browserify/pull/1230) + +# 9.0.8 + +makes `.require({ expose: 'name' })` and `require('name')` work at the same time + +https://github.com/substack/node-browserify/issues/850 +https://github.com/substack/node-browserify/pull/1202 + +# 9.0.7 + +fixes an issue with catching error events on the b.bundle() stream + +https://github.com/substack/node-browserify/issues/1194 +https://github.com/substack/node-browserify/pull/1195 + +# 9.0.6 + +republishing 9.0.5 in an attempt to satisfy npm. + +# 9.0.5 + +sets the stream returned by bundle() to be readable-only + +https://github.com/substack/node-browserify/pull/1187#issuecomment-89044008 + +# 9.0.4 + +handles the colon better for drive paths and improves the test suite for windows +users + +https://github.com/substack/node-browserify/pull/1182 +https://github.com/substack/node-browserify/pull/1183 + +# 9.0.3 + +fixes a problem with deduping for json files. + +This caused problems for running bundle() multiple times on the same instance +with caching turned on, which people reported encountering using watchify. + +https://github.com/substack/node-browserify/issues/1101 +https://github.com/substack/watchify/issues/143 + +# 9.0.2 + +fixes a bug where transforms in `opts.transform` were getting run twice + +https://github.com/substack/node-browserify/issues/1124 +https://github.com/substack/node-browserify/pull/1128 + +# 9.0.1 + +fixes exposed files persisting across bundles + +https://github.com/substack/node-browserify/pull/1030 + +# 9.0.0 + +updates browser-pack which uses umd 3.0.0. +This sligtly changes how `--standalone $name` works. + +https://github.com/substack/browser-pack/pull/49 +https://github.com/substack/node-browserify/pull/1105 + +Also some tidying up around handling expose that module-deps can do now: + +https://github.com/substack/node-browserify/pull/1077 + +and some fixes to regressions involving the `'package'` event: + +https://github.com/substack/node-resolve/issues/69 + +Upstream changes in resolve/browser-resolve mean that `require('foo/bar')` works +better with the package.json browser field. You can do something like: + +``` json +{ + "browser": { "./bar": "whatever.js" } +} +``` + +# 8.1.3 + +uses / instead of \ for source map url separators on windows +https://github.com/substack/node-browserify/pull/1096 + +# 8.1.2 + +resolves mappings from the browser field for externals + +https://github.com/substack/node-browserify/pull/1100 + +# 8.1.1 + +fixes an issue with resolving exposed packages relative to the basedir + +https://github.com/substack/node-browserify/pull/1059 +https://github.com/substack/node-browserify/issues/1039 +https://github.com/daiweilu/browserify-broken-require + +# 8.1.0 + +use assert@1.3, which fixes a bug in assert.deepEqual related to argument ordering, +and ensures assert.deepEqual continues working in Chrome 40 and Firefox 35. + +use process@0.10, which adds process.umask() and a faster process.nextTick() +implementation. + +https://github.com/substack/node-browserify/pull/1018 +https://github.com/substack/node-browserify/pull/1041 + +# 8.0.3 + +passes opts.debug through to insert-module-globals so that is can insert inline +source maps for its modifications + +# 8.0.2 + +ensures that transforms always execute in the order they were added + +https://github.com/substack/node-browserify/pull/1043 + +# 8.0.1 + +fixes some file path leaks in deduped deps + +https://github.com/substack/node-browserify/pull/994 +https://github.com/substack/node-browserify/issues/951 + +# 8.0.0 + +In previous releases, the deduping logic was over-zealous about how it handled +module references for duplicates. The prior behavior would detect when the +dependency tree of a module matched an existing module in addition to having the +exact same source code to share an instance. This was originally designed to +support libraries like threejs that internally use `instanceof` checks that +don't usually work very well across multiple packages. This feature didn't pan +out and didn't work very well in practice. + +Later, a better way of deduping emerged after some unrelated tweaks to +browser-pack to support source introspection for webworkers. The reflection form +of deduping using implicit arguments is now the only kind. + +The deduping instance feature resulted in this bug: +https://github.com/substack/node-browserify/issues/1027 +which created very surprising results when duplicate files were in use. + +# 7.1.0 + +uses the new buffer@3.0.0, which passes node's own buffer test suite + +https://github.com/substack/node-browserify/pull/1040 + +# 7.0.3 + +allows modules to be bundled with local paths and exposed at the same time + +https://github.com/substack/node-browserify/pull/1033 + +# 7.0.2 + +fixes the global transform getting added each re-bundle + +https://github.com/substack/node-browserify/issues/1026 + +# 7.0.1 + +fixes rebundling (used by watchify) when transforming + +https://github.com/substack/node-browserify/issues/1012 + +also fixes https://github.com/substack/node-browserify/issues/1015 + +# 7.0.0 + +Global transforms are now resolved to an absolute path before walking files. +This fixes some bugs with local module versions taking precedence over global +transforms and unresolvable global transforms spanning system directories. + +This is a small breaking change since now transform objects live in the pipeline +between the record and deps phases. This should only affect programs that expect +records in the pipeline to only contain file objects. + +# 6.3.4 + +fixes a bug setting placeholder filenames on stream inputs to be properly unique + +# 6.3.3 + +fixes an issue with the expose property when opts.fullPaths is enabled + +This issue commonly crops up in watchify. + +https://github.com/substack/node-browserify/pull/991 +https://github.com/substack/node-browserify/issues/850 + # 6.3.2 updates regexps that test for absolute and relative paths to work better on @@ -70,6 +577,13 @@ reproducible builds. https://github.com/substack/node-browserify/pull/923 +Version 6 is a tiny but breaking change to how source map paths work. + +Now all source map paths are relative by default. This makes it easier to have +deterministic debug builds across different systems and directories. If +browserify is installed in a project-local directory, all the source map paths +will be self-contained and relative against that location in node_modules. + # 5.13.1 bails early if opts.basedir is not the correct type @@ -240,7 +754,7 @@ adds an untracked test At a glance: * extensible internal labeled-stream-splicer pipeline -* bundle() - no longer accepts `opts`, callback gets a buffer +* bundle() - no longer accepts `opts`, callback gets a buffer * b.deps(), b.pack(), opts.pack, opts.deps are gone * can call bundle() multiple times on the same instance * a better --noparse matcher @@ -251,7 +765,78 @@ At a glance: * hashing is gone so `expose: true` or explicit expose id is required for doing multi-export bundles -In more depth: [doc/changelog/5_0.markdown](doc/changelog/5_0.markdown). +Version 5 is a big rearranging of browserify internals with more places for +external code to hook into the build pipeline. + +These changes are mostly aligned around the theme of making it easier for +external code to interface with browserify internals in a less hacky way. + +## pipeline + +Now the core of browserify is organized into a +[labeled-stream-splicer](https://npmjs.org/package/labeled-stream-splicer) +pipeline. This means that user code and plugins can hook into browserify by +pushing themselves onto the pipeline at a label: + +``` js +var browserify = require('browserify'); +var through = require('through2'); +var bundle = browserify(); + +bundle.pipeline.get('deps').push(through.obj(function (row, enc, next) { + console.log('DEP:', row.id); + this.push(row); + next(); +})); +``` + +User code can remove existing transforms or add its own hooks. These are the +labeled sections you can get a handle on with `bundle.pipeline.get()` + +* `'record'` - save inputs to play back later on subsequent `bundle()` calls +* `'deps'` - [module-deps](https://npmjs.org/package/module-deps) +* `'unbom'` - remove byte-order markers +* `'syntax'` - check for syntax errors +* `'sort'` - sort the dependencies for deterministic bundles +* `'dedupe'` - remove duplicate source contents +* `'label'` - apply integer labels to files +* `'emit-deps'` - emit `'dep'` event +* `'debug'` - apply source maps +* `'pack'` - [browser-pack](https://npmjs.org/package/browser-pack) +* `'wrap'` - apply final wrapping, `require=` and a newline and semicolon + +Because there is now a proper pipeline, `opts.pack`, `opts.deps`, `b.deps()`, +and `b.pack()` are removed. + +## bundle() + +Big changes have been made to the `bundle()` function. All options have been +moved out of the `bundle(opts)` form and into the browserify constructor. Before +there was an unclear split between which arguments went into which function. + +You can now call `bundle()` multiple times on the same instance, even in +parallel. This will greatly simplify the caching system under watchify and will +fix many long-standing bugs. + +The callback to `bundle(cb)` is now called with `cb(err, buf)` instead of +`cb(err, string)` as before. + +## labeling + +The former hashing system is removed, in favor of file paths rooted at the +`opts.basedir`, or the cwd. + +This removal means that browserify can be much more consistent about applying +integer ids, which avoids exposing system paths in bundle output. + +Hashes are used internally for deduping purposes, but they operate on the +source content only. + +## others + +The matching logic in the `--noparse` feature is greatly improved. + +derequire has been taken out of core, which should speed up `--standalone`. # 4.2.3 @@ -330,7 +915,25 @@ upgrades the version of buffer to ^2.3.0 # 4.0 -4.0 is hot off the presses. See [doc/changelog/4_0.markdown]. +Here are the new breaking changes in browserify v4. Most users should be unaffected. + +## readable-stream + +`require('stream')` is now using [readable-stream](https://npmjs.org/package/readable-stream) (but the classic-mode shim persists in stream-browserify just like in node core). This should result in much smaller files for all modules using a similar-enough version of readable-stream as browserify itself. Other modules should be relatively unaffected. + +## removed .expose() + +Removal of the previously-deprecated and obscure `bundle.expose()`. + +## took out implicit reading from stdin + +Previously if you invoked the browserify command without any entry files as arguments and stdin was a tty, stdin would be implicitly added as an entry file. This feature was causing problems so it has been removed. https://github.com/substack/node-browserify/issues/724#issuecomment-42731877 + +## more! + +In the run-up to the 4.0, [module-deps](https://npmjs.org/package/module-deps) got an extensive rewrite with minimal test changes. Mostly it was just getting really messy because it was a giant ball-of-mud closure instead of a more straightforward prototype-based implementation with more clearly-defined methods. + +The module-deps rewrite was triggered by [system paths showing up in build output](https://github.com/substack/node-browserify/issues/675) but was fixed in 3.46.1. The solution actually didn't end up needing changes in module-deps as originally anticipated but module-deps was in dire need of a cleanup. # 3.46.1 @@ -346,7 +949,7 @@ renders complete stack traces where before they were getting truncated https://g # 3.44.2 -slims down the dependency payload by 20M https://github.com/substack/node-browserify/pull/736 +slims down the dependency payload by 20M https://github.com/substack/node-browserify/pull/736 # 3.44.1 @@ -362,39 +965,39 @@ lets b.transform(opts, t) args to be swapped around since opts is more common as # 3.42.0 -passes through the dir parameter in opts.packageFilter from module-deps 1.10.0 https://github.com/substack/node-browserify/pull/731 +passes through the dir parameter in opts.packageFilter from module-deps 1.10.0 https://github.com/substack/node-browserify/pull/731 # 3.41.0 -has an option to disable external files, making it easier to run bundles in node for code coverage https://github.com/substack/node-browserify/pull/672 +has an option to disable external files, making it easier to run bundles in node for code coverage https://github.com/substack/node-browserify/pull/672 # 3.40.4 -makes --list work again https://github.com/substack/node-browserify/pull/727 +makes --list work again https://github.com/substack/node-browserify/pull/727 # 3.40.3 -merges a patch for piping via stdin and --require at the same time https://github.com/substack/node-browserify/pull/728 +merges a patch for piping via stdin and --require at the same time https://github.com/substack/node-browserify/pull/728 # 3.40.2 -upgrades module-deps to fix --list for $NODE_PATH https://github.com/substack/node-browserify/issues/726 +upgrades module-deps to fix --list for $NODE_PATH https://github.com/substack/node-browserify/issues/726 # 3.40.1 -upgrades module-deps to get this packageTransform bugfix https://github.com/substack/module-deps/pull/32 +upgrades module-deps to get this packageTransform bugfix https://github.com/substack/module-deps/pull/32 # 3.40.0 -modifies the behavior of opts.builtins to be more useful and intuitive https://github.com/substack/node-browserify/pull/717 +modifies the behavior of opts.builtins to be more useful and intuitive https://github.com/substack/node-browserify/pull/717 # 3.39.0 -adds a zlib that has parity with node https://github.com/substack/node-browserify/pull/721 +adds a zlib that has parity with node https://github.com/substack/node-browserify/pull/721 # 3.38.0 -upgrades derequire which uses esprima-fb https://github.com/substack/node-browserify/pull/710 +upgrades derequire which uses esprima-fb https://github.com/substack/node-browserify/pull/710 # 3.37.2 @@ -410,7 +1013,7 @@ also reverts that require('process') thing which was mistakenly briefly put in t # 3.37.0 -gives streams2 semantics for bundle() https://github.com/substack/node-browserify/pull/646 +gives streams2 semantics for bundle() https://github.com/substack/node-browserify/pull/646 # 3.36.1 @@ -422,35 +1025,35 @@ adds require('process') and removes the path resolution for process out of inser # 3.35.0 -adds an empty tls stub to the builtins list https://github.com/substack/node-browserify/issues/703 +adds an empty tls stub to the builtins list https://github.com/substack/node-browserify/issues/703 # 3.34.0 -fixes a bug with transforms not being applied in deps() https://github.com/substack/node-browserify/pull/708 +fixes a bug with transforms not being applied in deps() https://github.com/substack/node-browserify/pull/708 # 3.33.1 -fixes a bug with options in --global-transform on the command-line https://github.com/substack/node-browserify/pull/705 +fixes a bug with options in --global-transform on the command-line https://github.com/substack/node-browserify/pull/705 # 3.33.0 -fixes parsing errors while maintaining es6 support by switching to esprima-fb https://github.com/substack/node-browserify/issues/698 +fixes parsing errors while maintaining es6 support by switching to esprima-fb https://github.com/substack/node-browserify/issues/698 # 3.32.1 -should be easier to shinkwrap and install on windows https://github.com/substack/node-browserify/pull/684 +should be easier to shinkwrap and install on windows https://github.com/substack/node-browserify/pull/684 # 3.32.0 -adds --full-path and opts.fullPath to always expand ids to full paths https://github.com/substack/node-browserify/pull/668#issuecomment-36586786 +adds --full-path and opts.fullPath to always expand ids to full paths https://github.com/substack/node-browserify/pull/668#issuecomment-36586786 # 3.31.2 -fixes a bug in the subarg argument parsing for multiple transforms https://github.com/substack/node-browserify/issues/678 +fixes a bug in the subarg argument parsing for multiple transforms https://github.com/substack/node-browserify/issues/678 # 3.31.1 -uses process.cwd() as the default rebase target instead of commondir https://github.com/substack/node-browserify/pull/669#issuecomment-36078282 +uses process.cwd() as the default rebase target instead of commondir https://github.com/substack/node-browserify/pull/669#issuecomment-36078282 # 3.31.0 @@ -458,23 +1061,23 @@ merges https://github.com/substack/node-browserify/pull/669 which should help w # 3.30.4 -fixes parsing the --insert-global-vars argument properly https://github.com/substack/node-browserify/pull/674 +fixes parsing the --insert-global-vars argument properly https://github.com/substack/node-browserify/pull/674 # 3.30.3 -fixes exclude globbing in the arg parser https://github.com/substack/node-browserify/pull/676 +fixes exclude globbing in the arg parser https://github.com/substack/node-browserify/pull/676 # 3.30.2 -included a fix for --no-builtins for non-wrapped modules https://github.com/substack/node-browserify/pull/666 +included a fix for --no-builtins for non-wrapped modules https://github.com/substack/node-browserify/pull/666 # 3.30.1 -upgrades buffer for a utf8 fix https://github.com/substack/node-browserify/pull/656 +upgrades buffer for a utf8 fix https://github.com/substack/node-browserify/pull/656 # 3.30.0 -adds globs for -u, -i, and -x https://github.com/substack/node-browserify/issues/654 +adds globs for -u, -i, and -x https://github.com/substack/node-browserify/issues/654 # 3.29.1 @@ -490,11 +1093,11 @@ now always includes the full package.json content in the 'package' event # 3.28.1 -fixes a bug with stream entry order https://github.com/substack/node-browserify/pull/643 +fixes a bug with stream entry order https://github.com/substack/node-browserify/pull/643 # 3.28.0 -adds plugins for doing super fancy things like factored bundle output https://github.com/substack/node-browserify#plugins +adds plugins for doing super fancy things like factored bundle output https://github.com/substack/node-browserify#plugins # 3.27.1 @@ -502,11 +1105,11 @@ fixes a bug resolving transform modules when browserify is under a symlink # 3.27.0 -adds transform configuration in the package.json browserify.transform field https://github.com/substack/module-deps#packagejson-transformkey +adds transform configuration in the package.json browserify.transform field https://github.com/substack/module-deps#packagejson-transformkey # 3.26.0 -you can pass arguments to transforms https://github.com/substack/node-browserify/blob/master/bin/advanced.txt#L67-L77 +you can pass arguments to transforms https://github.com/substack/node-browserify/blob/master/bin/advanced.txt#L67-L77 # 3.25.2 @@ -518,7 +1121,7 @@ fixes the transform docs # 3.25.0 -adds 'bundle' and 'transform' events https://github.com/substack/node-browserify#bonbundle-function-bundle- +adds 'bundle' and 'transform' events https://github.com/substack/node-browserify#bonbundle-function-bundle- # 3.24.11 @@ -526,15 +1129,15 @@ upgrades derequire to 0.6.0. That should be the last piece needed for full es6 s # 3.24.10 -expands the documentation for the package.json browser and browserify.transform fields https://github.com/substack/node-browserify#packagejson +expands the documentation for the package.json browser and browserify.transform fields https://github.com/substack/node-browserify#packagejson # 3.24.9 -fixes generator syntax and other es6-isms in browserify https://github.com/substack/node-browserify/issues/614 +fixes generator syntax and other es6-isms in browserify https://github.com/substack/node-browserify/issues/614 # 3.24.7 -fixes noParse, which had accidentally been disabled in the insert-module-global changes and also closes https://github.com/substack/node-browserify/issues/504 +fixes noParse, which had accidentally been disabled in the insert-module-global changes and also closes https://github.com/substack/node-browserify/issues/504 # 3.24.6 @@ -542,15 +1145,15 @@ similar to 3.24.5, 3.24.6 fixes some error reporting propagation from the browse # 3.24.3 -fixes how require('buffer').Buffer wasn't the same as implicit Buffer https://github.com/substack/node-browserify/issues/612 +fixes how require('buffer').Buffer wasn't the same as implicit Buffer https://github.com/substack/node-browserify/issues/612 # 3.24.2 -fixes where the output stream didn't emit "close" in standalone mode https://github.com/substack/node-browserify/pull/608 +fixes where the output stream didn't emit "close" in standalone mode https://github.com/substack/node-browserify/pull/608 # 3.24.1 -fixes an issue where --standalone combined with expose caused a syntax error https://github.com/substack/node-browserify/issues/489 +fixes an issue where --standalone combined with expose caused a syntax error https://github.com/substack/node-browserify/issues/489 # 3.24.0 @@ -558,7 +1161,7 @@ removes require() calls from --standalone so you can require() a standalone bund # 3.23.0 -merges this tiny fix returning `this` in noParse() https://github.com/substack/node-browserify/pull/592 +merges this tiny fix returning `this` in noParse() https://github.com/substack/node-browserify/pull/592 # 3.22.0 @@ -574,7 +1177,7 @@ has a fix for the case where stdin is implicitly treated as the input stream ins # 3.20.0 -3.20.0 is out: parity with how $NODE_PATH works in node https://github.com/substack/node-browserify/issues/593 +3.20.0 is out: parity with how $NODE_PATH works in node https://github.com/substack/node-browserify/issues/593 # 3.19.1 @@ -582,5 +1185,77 @@ restores support for node 0.8 by upgrading concat-stream # 3.0 -See [doc/changelog/3_0.markdown](doc/changelog/3_0.markdown). - +A new [browserify](http://browserify.org) version is upon us, just in time for +the FESTIVE SEASON during which we in the northern hemisphere at mid to high +latitudes huddle for warmth around oxidizing hydrocarbons! + +There are 2 big changes in v3 but most code should be relatively unaffected. + +## shiny new Buffer + +[feross](https://github.com/feross) forked +the [buffer-browserify](https://npmjs.org/package/buffer-browserify) package +to create +[native-buffer-browserify](https://npmjs.org/package/native-buffer-browserify), +a `Buffer` implementation that uses `Uint8Array` to get `buf[i]` notation and +parity with the node core `Buffer` api without the performance hit of the +previous implementation and a much smaller file size. The downside is that +`Buffer` now only works in browsers with `Uint8Array` and `DataView` support. +All the other modules should maintain existing browser support. + +*Update*: a [shim was added](https://npmjs.org/package/typedarray) +to in 3.1 for Uint8Array and DataView support. Now you can use `Buffer` in every +browser. + +## direct builtin dependencies + +In v3, browserify no longer depends on +[browser-builtins](https://npmjs.org/package/browser-builtins), in favor of +depending on packages directly. Instead of having some separate packages and +some files in a `builtin/` directory like browser-builtins, browserify now uses +*only* external packages for the shims it uses. By only using external packages +we can keep browserify core focused purely on the static analysis and bundling +machinery while letting the individual packages worry about things like browser +compatibility and parity with the node core API as it evolves. + +Individual, tiny packages should also be much easier for newcomers to contribute +packages toward because they won't need to get up to speed with all the other +pieces going on and the packages can have their own tests and documentation. +Additionally, each package may find uses in other projects beside browserify +more easily and if people want variations on the versions of shims that ship +with browserify core this is easier to do when everything is separate. + +Back when we were using browser-builtins there was a large latency between +pushing out fixes to the individual packages and getting them into browserify +core because we had to wait on browser-builtins to upgrade the semvers in its +package.json. With direct dependencies we get much lower latency for package +upgrades and much more granular control over upgrading packages. + +Here is the list of packages we now directly depend on in v3: + +* [assert](https://npmjs.org/package/assert) +* [buffer](https://npmjs.org/package/native-buffer-browserify) +* [console](https://npmjs.org/package/console-browserify) +* [constants](https://npmjs.org/package/constants-browserify) +* [crypto](https://npmjs.org/package/crypto-browserify) +* [events](https://npmjs.org/package/events-browserify) +* [http](https://npmjs.org/package/http-browserify) +* [https](https://npmjs.org/package/https-browserify) +* [os](https://npmjs.org/package/os-browserify) +* [path](https://npmjs.org/package/path-browserify) +* [punycode](https://npmjs.org/package/punycode) +* [querystring](https://npmjs.org/package/querystring) +* [stream](https://npmjs.org/package/stream-browserify) +* [string_decoder](https://npmjs.org/package/string_decoder) +* [timers](https://npmjs.org/package/timers-browserify) +* [tty](https://npmjs.org/package/tty-browserify) +* [url](https://npmjs.org/package/url) +* [util](https://npmjs.org/package/util) +* [vm](https://npmjs.org/package/vm-browserify) +* [zlib](https://npmjs.org/package/zlib-browserify) + +That's it! If you're bold enough to give v3 a spin, just do: + +``` +npm install -g browserify +``` diff --git a/code-of-conduct.md b/code-of-conduct.md new file mode 100644 index 000000000..4a324853b --- /dev/null +++ b/code-of-conduct.md @@ -0,0 +1,78 @@ +# Contributor Covenant Code of Conduct + +## Our Pledge + +In the interest of fostering an open and welcoming environment, we as +contributors and maintainers pledge to making participation in our project and +our community a harassment-free experience for everyone, regardless of age, body +size, disability, ethnicity, gender identity and expression, level of experience, +nationality, personal appearance, race, religion, or sexual identity and +orientation. + +## Our Standards + +Examples of behavior that contributes to creating a positive environment +include: + +* Using welcoming and inclusive language +* Being respectful of differing viewpoints and experiences +* Gracefully accepting constructive criticism +* Focusing on what is best for the community +* Showing empathy towards other community members + +Examples of unacceptable behavior by participants include: + +* The use of sexualized language or imagery and unwelcome sexual attention or +advances +* Trolling, insulting/derogatory comments, and personal or political attacks +* Public or private harassment +* Publishing others' private information, such as a physical or electronic + address, without explicit permission +* Other conduct which could reasonably be considered inappropriate in a + professional setting + +## Our Responsibilities + +Project maintainers are responsible for clarifying the standards of acceptable +behavior and are expected to take appropriate and fair corrective action in +response to any instances of unacceptable behavior. + +Project maintainers have the right and responsibility to remove, edit, or +reject comments, commits, code, wiki edits, issues, and other contributions +that are not aligned to this Code of Conduct, or to ban temporarily or +permanently any contributor for other behaviors that they deem inappropriate, +threatening, offensive, or harmful. + +## Scope + +This Code of Conduct applies both within project spaces and in public spaces +when an individual is representing the project or its community. Examples of +representing a project or community include using an official project e-mail +address, posting via an official social media account, or acting as an appointed +representative at an online or offline event. Representation of a project may be +further defined and clarified by project maintainers. + +## Enforcement + +Instances of abusive, harassing, or otherwise unacceptable behavior may be +reported by contacting the project team at (any one or all of these): + +* substack@gmail.com + +All complaints will be reviewed and investigated and will result in a response +that is deemed necessary and appropriate to the circumstances. The project team +is obligated to maintain confidentiality with regard to the reporter of an +incident. Further details of specific enforcement policies may be posted +separately. + +Project maintainers who do not follow or enforce the Code of Conduct in good +faith may face temporary or permanent repercussions as determined by other +members of the project's leadership. + +## Attribution + +This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, +available at [http://contributor-covenant.org/version/1/4][version] + +[homepage]: http://contributor-covenant.org +[version]: http://contributor-covenant.org/version/1/4/ diff --git a/doc/changelog/3_0.markdown b/doc/changelog/3_0.markdown deleted file mode 100644 index 3e8db543c..000000000 --- a/doc/changelog/3_0.markdown +++ /dev/null @@ -1,74 +0,0 @@ -A new [browserify](http://browserify.org) version is upon us, just in time for -the FESTIVE SEASON during which we in the northern hemisphere at mid to high -latitudes huddle for warmth around oxidizing hydrocarbons! - -There are 2 big changes in v3 but most code should be relatively unaffected. - -# shiny new Buffer - -[feross](https://github.com/feross) forked -the [buffer-browserify](https://npmjs.org/package/buffer-browserify) package -to create -[native-buffer-browserify](https://npmjs.org/package/native-buffer-browserify), -a `Buffer` implementation that uses `Uint8Array` to get `buf[i]` notation and -parity with the node core `Buffer` api without the performance hit of the -previous implementation and a much smaller file size. The downside is that -`Buffer` now only works in browsers with `Uint8Array` and `DataView` support. -All the other modules should maintain existing browser support. - -*Update*: a [shim was added](https://npmjs.org/package/typedarray) -to in 3.1 for Uint8Array and DataView support. Now you can use `Buffer` in every -browser. - -# direct builtin dependencies - -In v3, browserify no longer depends on -[browser-builtins](https://npmjs.org/package/browser-builtins), in favor of -depending on packages directly. Instead of having some separate packages and -some files in a `builtin/` directory like browser-builtins, browserify now uses -*only* external packages for the shims it uses. By only using external packages -we can keep browserify core focused purely on the static analysis and bundling -machinery while letting the individual packages worry about things like browser -compatibility and parity with the node core API as it evolves. - -Individual, tiny packages should also be much easier for newcomers to contribute -packages toward because they won't need to get up to speed with all the other -pieces going on and the packages can have their own tests and documentation. -Additionally, each package may find uses in other projects beside browserify -more easily and if people want variations on the versions of shims that ship -with browserify core this is easier to do when everything is separate. - -Back when we were using browser-builtins there was a large latency between -pushing out fixes to the individual packages and getting them into browserify -core because we had to wait on browser-builtins to upgrade the semvers in its -package.json. With direct dependencies we get much lower latency for package -upgrades and much more granular control over upgrading packages. - -Here is the list of packages we now directly depend on in v3: - -* [assert](https://npmjs.org/package/assert) -* [buffer](https://npmjs.org/package/native-buffer-browserify) -* [console](https://npmjs.org/package/console-browserify) -* [constants](https://npmjs.org/package/constants-browserify) -* [crypto](https://npmjs.org/package/crypto-browserify) -* [events](https://npmjs.org/package/events-browserify) -* [http](https://npmjs.org/package/http-browserify) -* [https](https://npmjs.org/package/https-browserify) -* [os](https://npmjs.org/package/os-browserify) -* [path](https://npmjs.org/package/path-browserify) -* [punycode](https://npmjs.org/package/punycode) -* [querystring](https://npmjs.org/package/querystring) -* [stream](https://npmjs.org/package/stream-browserify) -* [string_decoder](https://npmjs.org/package/string_decoder) -* [timers](https://npmjs.org/package/timers-browserify) -* [tty](https://npmjs.org/package/tty-browserify) -* [url](https://npmjs.org/package/url) -* [util](https://npmjs.org/package/util) -* [vm](https://npmjs.org/package/vm-browserify) -* [zlib](https://npmjs.org/package/zlib-browserify) - -That's it! If you're bold enough to give v3 a spin, just do: - -``` -npm install -g browserify -``` diff --git a/doc/changelog/4_0.markdown b/doc/changelog/4_0.markdown deleted file mode 100644 index b734ca19e..000000000 --- a/doc/changelog/4_0.markdown +++ /dev/null @@ -1,19 +0,0 @@ -Here are the new breaking changes in browserify v4. Most users should be unaffected. - -# readable-stream - -`require('stream')` is now using [readable-stream](https://npmjs.org/package/readable-stream) (but the classic-mode shim persists in stream-browserify just like in node core). This should result in much smaller files for all modules using a similar-enough version of readable-stream as browserify itself. Other modules should be relatively unaffected. - -# removed .expose() - -Removal of the previously-deprecated and obscure `bundle.expose()`. - -# took out implicit reading from stdin - -Previously if you invoked the browserify command without any entry files as arguments and stdin was a tty, stdin would be implicitly added as an entry file. This feature was causing problems so it has been removed. https://github.com/substack/node-browserify/issues/724#issuecomment-42731877 - -# more! - -In the run-up to the 4.0, [module-deps](https://npmjs.org/package/module-deps) got an extensive rewrite with minimal test changes. Mostly it was just getting really messy because it was a giant ball-of-mud closure instead of a more straightforward prototype-based implementation with more clearly-defined methods. - -The module-deps rewrite was triggered by [system paths showing up in build output](https://github.com/substack/node-browserify/issues/675) but was fixed in 3.46.1. The solution actually didn't end up needing changes in module-deps as originally anticipated but module-deps was in dire need of a cleanup. diff --git a/doc/changelog/5_0.markdown b/doc/changelog/5_0.markdown deleted file mode 100644 index 5a8d9d28d..000000000 --- a/doc/changelog/5_0.markdown +++ /dev/null @@ -1,72 +0,0 @@ -Version 5 is a big rearranging of browserify internals with more places for -external code to hook into the build pipeline. - -These changes are mostly aligned around the theme of making it easier for -external code to interface with browserify internals in a less hacky way. - -# pipeline - -Now the core of browserify is organized into a -[labeled-stream-splicer](https://npmjs.org/package/labeled-stream-splicer) -pipeline. This means that user code and plugins can hook into browserify by -pushing themselves onto the pipeline at a label: - -``` js -var browserify = require('browserify'); -var through = require('through2'); -var bundle = browserify(); - -bundle.pipeline.get('deps').push(through.obj(function (row, enc, next) { - console.log('DEP:', row.id); - this.push(row); - next(); -})); -``` - -User code can remove existing transforms or add its own hooks. These are the -labeled sections you can get a handle on with `bundle.pipeline.get()` - -* `'record'` - save inputs to play back later on subsequent `bundle()` calls -* `'deps'` - [module-deps](https://npmjs.org/package/module-deps) -* `'unbom'` - remove byte-order markers -* `'syntax'` - check for syntax errors -* `'sort'` - sort the dependencies for deterministic bundles -* `'dedupe'` - remove duplicate source contents -* `'label'` - apply integer labels to files -* `'emit-deps'` - emit `'dep'` event -* `'debug'` - apply source maps -* `'pack'` - [browser-pack](https://npmjs.org/package/browser-pack) -* `'wrap'` - apply final wrapping, `require=` and a newline and semicolon - -Because there is now a proper pipeline, `opts.pack`, `opts.deps`, `b.deps()`, -and `b.pack()` are removed. - -# bundle() - -Big changes have been made to the `bundle()` function. All options have been -moved out of the `bundle(opts)` form and into the browserify constructor. Before -there was an unclear split between which arguments went into which function. - -You can now call `bundle()` multiple times on the same instance, even in -parallel. This will greatly simplify the caching system under watchify and will -fix many long-standing bugs. - -The callback to `bundle(cb)` is now called with `cb(err, buf)` instead of -`cb(err, string)` as before. - -# labeling - -The former hashing system is removed, in favor of file paths rooted at the -`opts.basedir`, or the cwd. - -This removal means that browserify can be much more consistent about applying -integer ids, which avoids exposing system paths in bundle output. - -Hashes are used internally for deduping purposes, but they operate on the -source content only. - -# others - -The matching logic in the `--noparse` feature is greatly improved. - -derequire has been taken out of core, which should speed up `--standalone`. diff --git a/doc/changelog/6_0.markdown b/doc/changelog/6_0.markdown deleted file mode 100644 index 8defb55f6..000000000 --- a/doc/changelog/6_0.markdown +++ /dev/null @@ -1,8 +0,0 @@ -Version 6 is a tiny but breaking change to how source map paths work. - -Now all source map paths are relative by default. This makes it easier to have -deterministic debug builds across different systems and directories. If -browserify is installed in a project-local directory, all the source map paths -will be self-contained and relative against that location in node_modules. - -https://github.com/substack/node-browserify/pull/923 diff --git a/index.js b/index.js index bd7068ccf..bd808b67d 100644 --- a/index.js +++ b/index.js @@ -9,22 +9,27 @@ var builtins = require('./lib/builtins.js'); var splicer = require('labeled-stream-splicer'); var through = require('through2'); var concat = require('concat-stream'); -var duplexer = require('duplexer2'); var inherits = require('inherits'); var EventEmitter = require('events').EventEmitter; var xtend = require('xtend'); -var copy = require('shallow-copy'); -var isarray = require('isarray'); +var isArray = Array.isArray; var defined = require('defined'); +var has = require('has'); +var sanitize = require('htmlescape').sanitize; +var shasum = require('shasum'); var bresolve = require('browser-resolve'); var resolve = require('resolve'); +var readonly = require('read-only-stream'); + module.exports = Browserify; inherits(Browserify, EventEmitter); +var fs = require('fs'); var path = require('path'); +var relativePath = require('cached-path-relative') var paths = { empty: path.join(__dirname, 'lib/_empty.js') }; @@ -34,7 +39,7 @@ function Browserify (files, opts) { if (!(this instanceof Browserify)) return new Browserify(files, opts); if (!opts) opts = {}; - if (typeof files === 'string' || isarray(files) || isStream(files)) { + if (typeof files === 'string' || isArray(files) || isStream(files)) { opts = xtend(opts, { entries: [].concat(opts.entries || [], files) }); } else opts = xtend(files, opts); @@ -45,27 +50,41 @@ function Browserify (files, opts) { if (opts.basedir !== undefined && typeof opts.basedir !== 'string') { throw new Error('opts.basedir must be either undefined or a string.'); } - + + opts.dedupe = opts.dedupe === false ? false : true; + self._external = []; self._exclude = []; self._ignore = []; self._expose = {}; self._hashes = {}; self._pending = 0; + self._transformOrder = 0; + self._transformPending = 0; + self._transforms = []; self._entryOrder = 0; self._ticked = false; + self._bresolve = opts.browserField === false + ? function (id, opts, cb) { + if (!opts.basedir) opts.basedir = path.dirname(opts.filename) + resolve(id, opts, cb) + } + : bresolve + ; + self._syntaxCache = {}; var ignoreTransform = [].concat(opts.ignoreTransform).filter(Boolean); - self._filterTransform = function(tr) { - if (Array.isArray(tr)) { + self._filterTransform = function (tr) { + if (isArray(tr)) { return ignoreTransform.indexOf(tr[0]) === -1; } return ignoreTransform.indexOf(tr) === -1; - } - + }; + self.pipeline = self._createPipeline(opts); - [].concat(opts.transform).filter(Boolean).forEach(function (tr) { + [].concat(opts.transform).filter(Boolean).filter(self._filterTransform) + .forEach(function (tr) { self.transform(tr); }); @@ -84,7 +103,7 @@ function Browserify (files, opts) { Browserify.prototype.require = function (file, opts) { var self = this; - if (isarray(file)) { + if (isArray(file)) { file.forEach(function (x) { if (typeof x === 'object') { self.require(x.file, xtend(opts, x)); @@ -95,16 +114,18 @@ Browserify.prototype.require = function (file, opts) { } if (!opts) opts = {}; - var basedir = defined(opts.basedir, process.cwd()); + var basedir = defined(opts.basedir, self._options.basedir, process.cwd()); var expose = opts.expose; if (file === expose && /^[\.]/.test(expose)) { - expose = '/' + path.relative(basedir, expose); + expose = '/' + relativePath(basedir, expose); + expose = expose.replace(/\\/g, '/'); } if (expose === undefined && this._options.exposeAll) { expose = true; } if (expose === true) { - expose = '/' + path.relative(basedir, file); + expose = '/' + relativePath(basedir, file); + expose = expose.replace(/\\/g, '/'); } if (isStream(file)) { @@ -113,7 +134,7 @@ Browserify.prototype.require = function (file, opts) { file.pipe(concat(function (buf) { var filename = opts.file || file.file || path.join( basedir, - '_stream_' + self._entryOrder + '.js' + '_stream_' + order + '.js' ); var id = file.id || expose || filename; if (expose || opts.entry === false) { @@ -132,43 +153,50 @@ Browserify.prototype.require = function (file, opts) { if (rec.transform === false) rec.transform = false; self.pipeline.write(rec); - self._pending --; - if (self._pending === 0) self.emit('_ready'); + if (-- self._pending === 0) self.emit('_ready'); })); return this; } - var row = typeof file === 'object' - ? xtend(file, opts) - : (isExternalModule(file) - ? xtend(opts, { id: expose || file }) - : xtend(opts, { file: file }) - ) - ; + var row; + if (typeof file === 'object') { + row = xtend(file, opts); + } + else if (!opts.entry && isExternalModule(file)) { + // external module or builtin + row = xtend(opts, { id: expose || file, file: file }); + } + else { + row = xtend(opts, { file: path.resolve(basedir, file) }); + } + if (!row.id) { - row.id = expose || file; + row.id = expose || row.file; } if (expose || !row.entry) { - this._expose[row.id] = file; + // Make this available to mdeps so that it can assign the value when it + // resolves the pathname. + row.expose = row.id; } - if (opts.external) return this.external(file, opts); + + if (opts.external) return self.external(file, opts); if (row.entry === undefined) row.entry = false; - if (!row.entry && this._options.exports === undefined) { - this._bpack.hasExports = true; + if (!row.entry && self._options.exports === undefined) { + self._bpack.hasExports = true; } if (row.entry) row.order = self._entryOrder ++; - if (opts.transform === false) row.transform = false; - this.pipeline.write(row); - return this; + if (opts.transform === false) row.transform = false; + self.pipeline.write(row); + return self; }; Browserify.prototype.add = function (file, opts) { var self = this; if (!opts) opts = {}; - if (isarray(file)) { + if (isArray(file)) { file.forEach(function (x) { self.add(x, opts) }); return this; } @@ -177,7 +205,7 @@ Browserify.prototype.add = function (file, opts) { Browserify.prototype.external = function (file, opts) { var self = this; - if (isarray(file)) { + if (isArray(file)) { file.forEach(function (f) { if (typeof f === 'object') { self.external(f, xtend(opts, f)); @@ -189,9 +217,37 @@ Browserify.prototype.external = function (file, opts) { if (file && typeof file === 'object' && typeof file.bundle === 'function') { var b = file; self._pending ++; + + var bdeps = {}; + var blabels = {}; + b.on('label', function (prev, id) { self._external.push(id); + + if (prev !== id) { + blabels[prev] = id; + self._external.push(prev); + } + }); + + b.pipeline.get('deps').push(through.obj(function (row, enc, next) { + bdeps = xtend(bdeps, row.deps); + this.push(row); + next(); + })); + + self.on('dep', function (row) { + Object.keys(row.deps).forEach(function (key) { + var prev = bdeps[key]; + if (prev) { + var id = blabels[prev]; + if (id) { + row.indexDeps[key] = id; + } + } + }); }); + b.pipeline.get('label').once('end', function () { if (-- self._pending === 0) self.emit('_ready'); }); @@ -201,20 +257,34 @@ Browserify.prototype.external = function (file, opts) { if (!opts) opts = {}; var basedir = defined(opts.basedir, process.cwd()); this._external.push(file); - this._external.push('/' + path.relative(basedir, file)); + this._external.push('/' + relativePath(basedir, file)); return this; }; Browserify.prototype.exclude = function (file, opts) { if (!opts) opts = {}; + if (isArray(file)) { + var self = this; + file.forEach(function(file) { + self.exclude(file, opts); + }); + return this; + } var basedir = defined(opts.basedir, process.cwd()); this._exclude.push(file); - this._exclude.push('/' + path.relative(basedir, file)); + this._exclude.push('/' + relativePath(basedir, file)); return this; }; Browserify.prototype.ignore = function (file, opts) { if (!opts) opts = {}; + if (isArray(file)) { + var self = this; + file.forEach(function(file) { + self.ignore(file, opts); + }); + return this; + } var basedir = defined(opts.basedir, process.cwd()); // Handle relative paths @@ -232,34 +302,63 @@ Browserify.prototype.transform = function (tr, opts) { if (typeof opts === 'function' || typeof opts === 'string') { tr = [ opts, tr ]; } - if (isarray(tr)) { + if (isArray(tr)) { opts = tr[1]; tr = tr[0]; } - - + //if the bundler is ignoring this transform - if (typeof tr === 'string' && !self._filterTransform(tr)) + if (typeof tr === 'string' && !self._filterTransform(tr)) { return this; + } - if (!opts) opts = {}; + function resolved () { + self._transforms[order] = rec; + -- self._pending; + if (-- self._transformPending === 0) { + self._transforms.forEach(function (transform) { + self.pipeline.write(transform); + }); + + if (self._pending === 0) { + self.emit('_ready'); + } + } + } + if (!opts) opts = {}; opts._flags = '_flags' in opts ? opts._flags : self._options; - apply(); - self.on('reset', apply); - - function apply () { - if (opts.global) { - self._mdeps.globalTransforms.push([ tr, opts ]); - } - else self._mdeps.transforms.push([ tr, opts ]); + var basedir = defined(opts.basedir, this._options.basedir, process.cwd()); + var order = self._transformOrder ++; + self._pending ++; + self._transformPending ++; + + var rec = { + transform: tr, + options: opts, + global: opts.global + }; + + if (typeof tr === 'string') { + var topts = { + basedir: basedir, + paths: (self._options.paths || []).map(function (p) { + return path.resolve(basedir, p); + }) + }; + resolve(tr, topts, function (err, res) { + if (err) return self.emit('error', err); + rec.transform = res; + resolved(); + }); } + else process.nextTick(resolved); return this; }; Browserify.prototype.plugin = function (p, opts) { - if (isarray(p)) { + if (isArray(p)) { opts = p[1]; p = p[0]; } @@ -298,7 +397,7 @@ Browserify.prototype._createPipeline = function (opts) { var dopts = { index: !opts.fullPaths && !opts.exposeAll, - dedupe: true, + dedupe: opts.dedupe, expose: this._expose }; this._bpack = bpack(xtend(opts, { raw: true })); @@ -325,10 +424,10 @@ Browserify.prototype._createPipeline = function (opts) { if (self._external.indexOf(row.file) >= 0) return next(); if (isAbsolutePath(row.id)) { - row.id = '/' + path.relative(basedir, row.file); + row.id = '/' + relativePath(basedir, row.file); } Object.keys(row.deps || {}).forEach(function (key) { - row.deps[key] = '/' + path.relative(basedir, row.deps[key]); + row.deps[key] = '/' + relativePath(basedir, row.deps[key]); }); this.push(row); next(); @@ -339,18 +438,17 @@ Browserify.prototype._createPipeline = function (opts) { Browserify.prototype._createDeps = function (opts) { var self = this; - var mopts = copy(opts); + var mopts = xtend(opts); var basedir = defined(opts.basedir, process.cwd()); - + + // Let mdeps populate these values since it will be resolving file paths + // anyway. + mopts.expose = this._expose; mopts.extensions = [ '.js', '.json' ].concat(mopts.extensions || []); self._extensions = mopts.extensions; - - //filter transforms on top-level - mopts.transform = [].concat(opts.transform) - .filter(Boolean) - .filter(self._filterTransform); - mopts.transformKey = [ 'browserify', 'transform' ]; + mopts.transform = []; + mopts.transformKey = defined(opts.transformKey, [ 'browserify', 'transform' ]); mopts.postFilter = function (id, file, pkg) { if (opts.postFilter && !opts.postFilter(id, file, pkg)) return false; if (self._external.indexOf(file) >= 0) return false; @@ -377,7 +475,7 @@ Browserify.prototype._createDeps = function (opts) { mopts.resolve = function (id, parent, cb) { if (self._ignore.indexOf(id) >= 0) return cb(null, paths.empty, {}); - bresolve(id, parent, function (err, file, pkg) { + self._bresolve(id, parent, function (err, file, pkg) { if (file && self._ignore.indexOf(file) >= 0) { return cb(null, paths.empty, {}); } @@ -392,7 +490,7 @@ Browserify.prototype._createDeps = function (opts) { } if (file) { - var ex = '/' + path.relative(basedir, file); + var ex = '/' + relativePath(basedir, file); if (self._external.indexOf(ex) >= 0) { return cb(null, ex); } @@ -403,7 +501,11 @@ Browserify.prototype._createDeps = function (opts) { return cb(null, paths.empty, {}); } } - cb(err, file, pkg); + if (err) cb(err, file, pkg) + else if (file) fs.realpath(file, function (err, res) { + cb(err, res, pkg, file); + }); + else cb(err, null, pkg) }); }; @@ -411,7 +513,7 @@ Browserify.prototype._createDeps = function (opts) { mopts.modules = {}; self._exclude.push.apply(self._exclude, Object.keys(builtins)); } - else if (opts.builtins && isarray(opts.builtins)) { + else if (opts.builtins && isArray(opts.builtins)) { mopts.modules = {}; opts.builtins.forEach(function (key) { mopts.modules[key] = builtins[key]; @@ -420,26 +522,36 @@ Browserify.prototype._createDeps = function (opts) { else if (opts.builtins && typeof opts.builtins === 'object') { mopts.modules = opts.builtins; } - else mopts.modules = builtins; + else mopts.modules = xtend(builtins); Object.keys(builtins).forEach(function (key) { if (!has(mopts.modules, key)) self._exclude.push(key); }); mopts.globalTransform = []; - this.once('bundle', function () { - self._mdeps.globalTransforms.push([ globalTr, {} ]); + if (!this._bundled) { + this.once('bundle', function () { + self.pipeline.write({ + transform: globalTr, + global: true, + options: {} + }); + }); + } + + var no = [].concat(opts.noParse).filter(Boolean); + var absno = no.filter(function(x) { + return typeof x === 'string'; + }).map(function (x) { + return path.resolve(basedir, x); }); function globalTr (file) { if (opts.detectGlobals === false) return through(); if (opts.noParse === true) return through(); - var no = [].concat(opts.noParse).filter(Boolean); if (no.indexOf(file) >= 0) return through(); - if (no.map(function (x){return path.resolve(x)}).indexOf(file)>=0){ - return through(); - } + if (absno.indexOf(file) >= 0) return through(); var parts = file.split('/node_modules/'); for (var i = 0; i < no.length; i++) { @@ -459,11 +571,12 @@ Browserify.prototype._createDeps = function (opts) { }, opts.insertGlobalVars); if (opts.bundleExternal === false) { - delete vars.process; - delete vars.buffer; + vars.process = undefined; + vars.buffer = undefined; } return insertGlobals(file, xtend(opts, { + debug: opts.debug, always: opts.insertGlobals, basedir: opts.commondir === false ? '/' @@ -507,7 +620,7 @@ Browserify.prototype._recorder = function (opts) { Browserify.prototype._json = function () { return through.obj(function (row, enc, next) { if (/\.json$/.test(row.file)) { - row.source = 'module.exports=' + row.source; + row.source = 'module.exports=' + sanitize(row.source); } this.push(row); next(); @@ -535,9 +648,14 @@ Browserify.prototype._unshebang = function () { }; Browserify.prototype._syntax = function () { + var self = this; return through.obj(function (row, enc, next) { - var err = syntaxError(row.source, row.file || row.id); - if (err) return this.emit('error', err); + var h = shasum(row.source); + if (typeof self._syntaxCache[h] === 'undefined') { + var err = syntaxError(row.source, row.file || row.id); + if (err) return this.emit('error', err); + self._syntaxCache[h] = true; + } this.push(row); next(); }); @@ -546,20 +664,10 @@ Browserify.prototype._syntax = function () { Browserify.prototype._dedupe = function () { return through.obj(function (row, enc, next) { if (!row.dedupeIndex && row.dedupe) { - row.source = 'module.exports=require(' + row.source = 'arguments[4][' + JSON.stringify(row.dedupe) - + ')' - ; - row.deps = {}; - row.deps[row.dedupe] = row.dedupe; - row.nomap = true; - } - if (row.dedupeIndex && row.sameDeps) { - row.source = 'module.exports=require(' - + JSON.stringify(row.dedupeIndex) - + ')' + + '][0].apply(exports,arguments)' ; - row.deps = {}; row.nomap = true; } else if (row.dedupeIndex) { @@ -569,8 +677,8 @@ Browserify.prototype._dedupe = function () { ; row.nomap = true; } - if (row.dedupeIndex && row.dedupe && row.indexDeps) { - row.indexDeps[row.dedupe] = row.dedupeIndex; + if (row.dedupeIndex && row.indexDeps) { + row.indexDeps.dup = row.dedupeIndex; } this.push(row); next(); @@ -583,13 +691,12 @@ Browserify.prototype._label = function (opts) { return through.obj(function (row, enc, next) { var prev = row.id; - - var relf = '/' + path.relative(basedir, row.id); - var reli = '/' + path.relative(basedir, row.id); + if (self._external.indexOf(row.id) >= 0) return next(); - if (self._external.indexOf(reli) >= 0) return next(); + if (self._external.indexOf('/' + relativePath(basedir, row.id)) >= 0) { + return next(); + } if (self._external.indexOf(row.file) >= 0) return next(); - if (self._external.indexOf(relf) >= 0) return next(); if (row.index) row.id = row.index; @@ -597,8 +704,13 @@ Browserify.prototype._label = function (opts) { if (row.indexDeps) row.deps = row.indexDeps || {}; Object.keys(row.deps).forEach(function (key) { + if (self._expose[key]) { + row.deps[key] = key; + return; + } + var afile = path.resolve(path.dirname(row.file), key); - var rfile = '/' + path.relative(basedir, afile); + var rfile = '/' + relativePath(basedir, afile); if (self._external.indexOf(rfile) >= 0) { row.deps[key] = rfile; } @@ -641,7 +753,8 @@ Browserify.prototype._debug = function (opts) { return through.obj(function (row, enc, next) { if (opts.debug) { row.sourceRoot = 'file://localhost'; - row.sourceFile = path.relative(basedir, row.file); + row.sourceFile = relativePath(basedir, row.file) + .replace(/\\/g, '/'); } this.push(row); next(); @@ -673,27 +786,26 @@ Browserify.prototype.bundle = function (cb) { self.pipeline.write(x); }); } - this.emit('bundle', this.pipeline); - + var output = readonly(this.pipeline); if (cb) { - this.pipeline.on('error', cb); - this.pipeline.pipe(concat(function (body) { + output.on('error', cb); + output.pipe(concat(function (body) { cb(null, body); })); } - - if (this._pending === 0) { - this.pipeline.end(); - } - else this.once('_ready', function () { + + function ready () { + self.emit('bundle', output); self.pipeline.end(); - }); - + } + + if (this._pending === 0) ready(); + else this.once('_ready', ready); + this._bundled = true; - return this.pipeline; + return output; }; -function has (obj, key) { return Object.hasOwnProperty.call(obj, key) } function isStream (s) { return s && typeof s.pipe === 'function' } function isAbsolutePath (file) { var regexp = process.platform === 'win32' ? diff --git a/lib/builtins.js b/lib/builtins.js index 743265150..26c8904ec 100644 --- a/lib/builtins.js +++ b/lib/builtins.js @@ -10,7 +10,7 @@ exports.dns = require.resolve('./_empty.js'); exports.domain = require.resolve('domain-browser'); exports.events = require.resolve('events/'); exports.fs = require.resolve('./_empty.js'); -exports.http = require.resolve('http-browserify'); +exports.http = require.resolve('stream-http'); exports.https = require.resolve('https-browserify'); exports.module = require.resolve('./_empty.js'); exports.net = require.resolve('./_empty.js'); diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 000000000..6bb15bf71 --- /dev/null +++ b/package-lock.json @@ -0,0 +1,3669 @@ +{ + "name": "browserify", + "version": "15.0.0", + "lockfileVersion": 1, + "requires": true, + "dependencies": { + "JSONStream": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/JSONStream/-/JSONStream-1.3.2.tgz", + "integrity": "sha1-wQI3G27Dp887hHygDCC7D85Mbeo=", + "requires": { + "jsonparse": "1.3.1", + "through": "2.3.8" + } + }, + "acorn": { + "version": "4.0.13", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-4.0.13.tgz", + "integrity": "sha1-EFSVrlNh1pe9GVyCUZLhrX8lN4c=" + }, + "amdefine": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/amdefine/-/amdefine-1.0.1.tgz", + "integrity": "sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU=", + "dev": true + }, + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "dev": true + }, + "ansi-styles": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", + "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", + "dev": true + }, + "argparse": { + "version": "1.0.9", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.9.tgz", + "integrity": "sha1-c9g7wmP4bpf4zE9rrhsOkKfSLIY=", + "dev": true, + "requires": { + "sprintf-js": "1.0.3" + } + }, + "array-filter": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/array-filter/-/array-filter-0.0.1.tgz", + "integrity": "sha1-fajPLiZijtcygDWB/SH2fKzS7uw=" + }, + "array-map": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/array-map/-/array-map-0.0.0.tgz", + "integrity": "sha1-iKK6tz0c97zVwbEYoAP2b2ZfpmI=" + }, + "array-reduce": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/array-reduce/-/array-reduce-0.0.0.tgz", + "integrity": "sha1-FziZ0//Rx9k4PkR5Ul2+J4yrXys=" + }, + "asn1": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.3.tgz", + "integrity": "sha1-2sh4dxPJlmhJ/IGAd36+nB3fO4Y=", + "dev": true + }, + "asn1.js": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/asn1.js/-/asn1.js-4.9.2.tgz", + "integrity": "sha512-b/OsSjvWEo8Pi8H0zsDd2P6Uqo2TK2pH8gNLSJtNLM2Db0v2QaAZ0pBQJXVjAn4gBuugeVDr7s63ZogpUIwWDg==", + "requires": { + "bn.js": "4.11.8", + "inherits": "2.0.3", + "minimalistic-assert": "1.0.0" + } + }, + "assert": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/assert/-/assert-1.4.1.tgz", + "integrity": "sha1-mZEtWRg2tab1s0XA8H7vwI/GXZE=", + "requires": { + "util": "0.10.3" + } + }, + "assert-plus": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-0.2.0.tgz", + "integrity": "sha1-104bh+ev/A24qttwIfP+SBAasjQ=", + "dev": true + }, + "astw": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/astw/-/astw-2.2.0.tgz", + "integrity": "sha1-e9QXhNMkk5h66yOba04cV6hzuRc=", + "requires": { + "acorn": "4.0.13" + } + }, + "asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", + "dev": true + }, + "aws-sign2": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.6.0.tgz", + "integrity": "sha1-FDQt0428yU0OW4fXY81jYSwOeU8=", + "dev": true + }, + "aws4": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.6.0.tgz", + "integrity": "sha1-g+9cqGCysy5KDe7e6MdxudtXRx4=", + "dev": true + }, + "backbone": { + "version": "0.9.10", + "resolved": "https://registry.npmjs.org/backbone/-/backbone-0.9.10.tgz", + "integrity": "sha1-ErhBwpwSpV7zfVgoA6D3+zUJT4o=", + "dev": true, + "requires": { + "underscore": "1.8.3" + } + }, + "balanced-match": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", + "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" + }, + "base64-js": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.2.1.tgz", + "integrity": "sha512-dwVUVIXsBZXwTuwnXI9RK8sBmgq09NDHzyR9SAph9eqk76gKK2JSQmZARC2zRC81JC2QTtxD0ARU5qTS25gIGw==" + }, + "bcrypt-pbkdf": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.1.tgz", + "integrity": "sha1-Y7xdy2EzG5K8Bf1SiVPDNGKgb40=", + "dev": true, + "optional": true, + "requires": { + "tweetnacl": "0.14.5" + } + }, + "bind-obj-methods": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/bind-obj-methods/-/bind-obj-methods-1.0.0.tgz", + "integrity": "sha1-T1l5ysFXk633DkiBYeRj4gnKUJw=", + "dev": true + }, + "bluebird": { + "version": "3.5.1", + "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.1.tgz", + "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==", + "dev": true + }, + "bn.js": { + "version": "4.11.8", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.11.8.tgz", + "integrity": "sha512-ItfYfPLkWHUjckQCk8xC+LwxgK8NYcXywGigJgSwOP8Y2iyWT4f2vsZnoOXTTbo+o5yXmIUJ4gn5538SO5S3gA==" + }, + "boom": { + "version": "2.10.1", + "resolved": "https://registry.npmjs.org/boom/-/boom-2.10.1.tgz", + "integrity": "sha1-OciRjO/1eZ+D+UkqhI9iWt0Mdm8=", + "dev": true, + "requires": { + "hoek": "2.16.3" + } + }, + "brace-expansion": { + "version": "1.1.8", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz", + "integrity": "sha1-wHshHHyVLsH479Uad+8NHTmQopI=", + "requires": { + "balanced-match": "1.0.0", + "concat-map": "0.0.1" + } + }, + "brorand": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz", + "integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8=" + }, + "browser-pack": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/browser-pack/-/browser-pack-6.0.2.tgz", + "integrity": "sha1-+GzWzvT1MAyOY+B6TVEvZfv/RTE=", + "requires": { + "JSONStream": "1.3.2", + "combine-source-map": "0.7.2", + "defined": "1.0.0", + "through2": "2.0.3", + "umd": "3.0.1" + } + }, + "browser-resolve": { + "version": "1.11.2", + "resolved": "https://registry.npmjs.org/browser-resolve/-/browser-resolve-1.11.2.tgz", + "integrity": "sha1-j/CbCixCFxihBRwmCzLkj0QpOM4=", + "requires": { + "resolve": "1.1.7" + }, + "dependencies": { + "resolve": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.1.7.tgz", + "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=" + } + } + }, + "browser-unpack": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/browser-unpack/-/browser-unpack-1.2.0.tgz", + "integrity": "sha1-NXruMfxGeDFoTQY+Q1XgcKeClw0=", + "dev": true, + "requires": { + "acorn": "4.0.13", + "browser-pack": "5.0.1", + "concat-stream": "1.5.2", + "minimist": "1.2.0" + }, + "dependencies": { + "browser-pack": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/browser-pack/-/browser-pack-5.0.1.tgz", + "integrity": "sha1-QZdxmyDG4KqglFHFER5T77b7wY0=", + "dev": true, + "requires": { + "JSONStream": "1.3.2", + "combine-source-map": "0.6.1", + "defined": "1.0.0", + "through2": "1.1.1", + "umd": "3.0.1" + } + }, + "combine-source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/combine-source-map/-/combine-source-map-0.6.1.tgz", + "integrity": "sha1-m0oJwxYDPXaODxHgKfonMOB5rZY=", + "dev": true, + "requires": { + "convert-source-map": "1.1.3", + "inline-source-map": "0.5.0", + "lodash.memoize": "3.0.4", + "source-map": "0.4.4" + } + }, + "inline-source-map": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/inline-source-map/-/inline-source-map-0.5.0.tgz", + "integrity": "sha1-Skxd2OT7Xps82mDIIt+tyu5m4K8=", + "dev": true, + "requires": { + "source-map": "0.4.4" + } + }, + "isarray": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", + "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", + "dev": true + }, + "readable-stream": { + "version": "1.1.14", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", + "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", + "dev": true, + "requires": { + "core-util-is": "1.0.2", + "inherits": "2.0.3", + "isarray": "0.0.1", + "string_decoder": "0.10.31" + } + }, + "source-map": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", + "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", + "dev": true, + "requires": { + "amdefine": "1.0.1" + } + }, + "string_decoder": { + "version": "0.10.31", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", + "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", + "dev": true + }, + "through2": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/through2/-/through2-1.1.1.tgz", + "integrity": "sha1-CEfLxESfNAVXTb3M2buEG4OsNUU=", + "dev": true, + "requires": { + "readable-stream": "1.1.14", + "xtend": "4.0.1" + } + } + } + }, + "browserify-aes": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/browserify-aes/-/browserify-aes-1.1.1.tgz", + "integrity": "sha512-UGnTYAnB2a3YuYKIRy1/4FB2HdM866E0qC46JXvVTYKlBlZlnvfpSfY6OKfXZAkv70eJ2a1SqzpAo5CRhZGDFg==", + "requires": { + "buffer-xor": "1.0.3", + "cipher-base": "1.0.4", + "create-hash": "1.1.3", + "evp_bytestokey": "1.0.3", + "inherits": "2.0.3", + "safe-buffer": "5.1.1" + } + }, + "browserify-cipher": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/browserify-cipher/-/browserify-cipher-1.0.0.tgz", + "integrity": "sha1-mYgkSHS/XtTijalWZtzWasj8Njo=", + "requires": { + "browserify-aes": "1.1.1", + "browserify-des": "1.0.0", + "evp_bytestokey": "1.0.3" + } + }, + "browserify-des": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/browserify-des/-/browserify-des-1.0.0.tgz", + "integrity": "sha1-2qJ3cXRwki7S/hhZQRihdUOXId0=", + "requires": { + "cipher-base": "1.0.4", + "des.js": "1.0.0", + "inherits": "2.0.3" + } + }, + "browserify-rsa": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/browserify-rsa/-/browserify-rsa-4.0.1.tgz", + "integrity": "sha1-IeCr+vbyApzy+vsTNWenAdQTVSQ=", + "requires": { + "bn.js": "4.11.8", + "randombytes": "2.0.5" + } + }, + "browserify-sign": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/browserify-sign/-/browserify-sign-4.0.4.tgz", + "integrity": "sha1-qk62jl17ZYuqa/alfmMMvXqT0pg=", + "requires": { + "bn.js": "4.11.8", + "browserify-rsa": "4.0.1", + "create-hash": "1.1.3", + "create-hmac": "1.1.6", + "elliptic": "6.4.0", + "inherits": "2.0.3", + "parse-asn1": "5.1.0" + } + }, + "browserify-zlib": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/browserify-zlib/-/browserify-zlib-0.2.0.tgz", + "integrity": "sha512-Z942RysHXmJrhqk88FmKBVq/v5tqmSkDz7p54G/MGyjMnCFFnC79XWNbg+Vta8W6Wb2qtSZTSxIGkJrRpCFEiA==", + "requires": { + "pako": "1.0.6" + } + }, + "buffer": { + "version": "5.0.8", + "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.0.8.tgz", + "integrity": "sha512-xXvjQhVNz50v2nPeoOsNqWCLGfiv4ji/gXZM28jnVwdLJxH4mFyqgqCKfaK9zf1KUbG6zTkjLOy7ou+jSMarGA==", + "requires": { + "base64-js": "1.2.1", + "ieee754": "1.1.8" + } + }, + "buffer-xor": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-1.0.3.tgz", + "integrity": "sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk=" + }, + "builtin-status-codes": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz", + "integrity": "sha1-hZgoeOIbmOHGZCXgPQF0eI9Wnug=" + }, + "cached-path-relative": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cached-path-relative/-/cached-path-relative-1.0.1.tgz", + "integrity": "sha1-0JxLUoAKpMB44t2BqGmqyQ0uVOc=" + }, + "caseless": { + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.11.0.tgz", + "integrity": "sha1-cVuW6phBWTzDMGeSP17GDr2k99c=", + "dev": true + }, + "chainsaw": { + "version": "0.0.9", + "resolved": "https://registry.npmjs.org/chainsaw/-/chainsaw-0.0.9.tgz", + "integrity": "sha1-EaBRAtHEx4W20EFdM21aOhYSkT4=", + "dev": true, + "requires": { + "traverse": "0.3.9" + } + }, + "chalk": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", + "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", + "dev": true, + "requires": { + "ansi-styles": "2.2.1", + "escape-string-regexp": "1.0.5", + "has-ansi": "2.0.0", + "strip-ansi": "3.0.1", + "supports-color": "2.0.0" + } + }, + "cipher-base": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/cipher-base/-/cipher-base-1.0.4.tgz", + "integrity": "sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q==", + "requires": { + "inherits": "2.0.3", + "safe-buffer": "5.1.1" + } + }, + "clean-yaml-object": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/clean-yaml-object/-/clean-yaml-object-0.1.0.tgz", + "integrity": "sha1-Y/sRDcLOGoTcIfbZM0h20BCui2g=", + "dev": true + }, + "coffee-script": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/coffee-script/-/coffee-script-1.10.0.tgz", + "integrity": "sha1-EpOLz5vhlI+gBvkuDEyegXBRCMA=", + "dev": true + }, + "coffeeify": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/coffeeify/-/coffeeify-1.1.0.tgz", + "integrity": "sha1-VYxNW9+p1algfFnqkq20oWF5p4s=", + "dev": true, + "requires": { + "coffee-script": "1.10.0", + "convert-source-map": "1.1.3", + "through": "2.3.8" + } + }, + "color-support": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-support/-/color-support-1.1.3.tgz", + "integrity": "sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg==", + "dev": true + }, + "combine-source-map": { + "version": "0.7.2", + "resolved": "https://registry.npmjs.org/combine-source-map/-/combine-source-map-0.7.2.tgz", + "integrity": "sha1-CHAxKFazB6h8xKxIbzqaYq7MwJ4=", + "requires": { + "convert-source-map": "1.1.3", + "inline-source-map": "0.6.2", + "lodash.memoize": "3.0.4", + "source-map": "0.5.7" + } + }, + "combined-stream": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.5.tgz", + "integrity": "sha1-k4NwpXtKUd6ix3wV1cX9+JUWQAk=", + "dev": true, + "requires": { + "delayed-stream": "1.0.0" + } + }, + "commander": { + "version": "2.12.2", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.12.2.tgz", + "integrity": "sha512-BFnaq5ZOGcDN7FlrtBT4xxkgIToalIIxwjxLWVJ8bGTpe1LroqMiqQXdA7ygc7CRvaYS+9zfPGFnJqFSayx+AA==", + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" + }, + "concat-stream": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.5.2.tgz", + "integrity": "sha1-cIl4Yk2FavQaWnQd790mHadSwmY=", + "requires": { + "inherits": "2.0.3", + "readable-stream": "2.0.6", + "typedarray": "0.0.6" + }, + "dependencies": { + "readable-stream": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.0.6.tgz", + "integrity": "sha1-j5A0HmilPMySh4jaz80Rs265t44=", + "requires": { + "core-util-is": "1.0.2", + "inherits": "2.0.3", + "isarray": "1.0.0", + "process-nextick-args": "1.0.7", + "string_decoder": "0.10.31", + "util-deprecate": "1.0.2" + } + }, + "string_decoder": { + "version": "0.10.31", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", + "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=" + } + } + }, + "console-browserify": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/console-browserify/-/console-browserify-1.1.0.tgz", + "integrity": "sha1-8CQcRXMKn8YyOyBtvzjtx0HQuxA=", + "requires": { + "date-now": "0.1.4" + } + }, + "constants-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/constants-browserify/-/constants-browserify-1.0.0.tgz", + "integrity": "sha1-wguW2MYXdIqvHBYCF2DNJ/y4y3U=" + }, + "convert-source-map": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.1.3.tgz", + "integrity": "sha1-SCnId+n+SbMWHzvzZziI4gRpmGA=" + }, + "core-util-is": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", + "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" + }, + "coveralls": { + "version": "2.13.3", + "resolved": "https://registry.npmjs.org/coveralls/-/coveralls-2.13.3.tgz", + "integrity": "sha512-iiAmn+l1XqRwNLXhW8Rs5qHZRFMYp9ZIPjEOVRpC/c4so6Y/f4/lFi0FfR5B9cCqgyhkJ5cZmbvcVRfP8MHchw==", + "dev": true, + "requires": { + "js-yaml": "3.6.1", + "lcov-parse": "0.0.10", + "log-driver": "1.2.5", + "minimist": "1.2.0", + "request": "2.79.0" + }, + "dependencies": { + "js-yaml": { + "version": "3.6.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.6.1.tgz", + "integrity": "sha1-bl/mfYsgXOTSL60Ft3geja3MSzA=", + "dev": true, + "requires": { + "argparse": "1.0.9", + "esprima": "2.7.3" + } + } + } + }, + "create-ecdh": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/create-ecdh/-/create-ecdh-4.0.0.tgz", + "integrity": "sha1-iIxyNZbN92EvZJgjPuvXo1MBc30=", + "requires": { + "bn.js": "4.11.8", + "elliptic": "6.4.0" + } + }, + "create-hash": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/create-hash/-/create-hash-1.1.3.tgz", + "integrity": "sha1-YGBCrIuSYnUPSDyt2rD1gZFy2P0=", + "requires": { + "cipher-base": "1.0.4", + "inherits": "2.0.3", + "ripemd160": "2.0.1", + "sha.js": "2.4.9" + } + }, + "create-hmac": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/create-hmac/-/create-hmac-1.1.6.tgz", + "integrity": "sha1-rLniIaThe9sHbpBlfEK5PjcmzwY=", + "requires": { + "cipher-base": "1.0.4", + "create-hash": "1.1.3", + "inherits": "2.0.3", + "ripemd160": "2.0.1", + "safe-buffer": "5.1.1", + "sha.js": "2.4.9" + } + }, + "cross-spawn": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-4.0.2.tgz", + "integrity": "sha1-e5JHYhwjrf3ThWAEqCPL45dCTUE=", + "dev": true, + "requires": { + "lru-cache": "4.1.1", + "which": "1.3.0" + } + }, + "cryptiles": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/cryptiles/-/cryptiles-2.0.5.tgz", + "integrity": "sha1-O9/s3GCBR8HGcgL6KR59ylnqo7g=", + "dev": true, + "requires": { + "boom": "2.10.1" + } + }, + "crypto-browserify": { + "version": "3.12.0", + "resolved": "https://registry.npmjs.org/crypto-browserify/-/crypto-browserify-3.12.0.tgz", + "integrity": "sha512-fz4spIh+znjO2VjL+IdhEpRJ3YN6sMzITSBijk6FK2UvTqruSQW+/cCZTSNsMiZNvUeq0CqurF+dAbyiGOY6Wg==", + "requires": { + "browserify-cipher": "1.0.0", + "browserify-sign": "4.0.4", + "create-ecdh": "4.0.0", + "create-hash": "1.1.3", + "create-hmac": "1.1.6", + "diffie-hellman": "5.0.2", + "inherits": "2.0.3", + "pbkdf2": "3.0.14", + "public-encrypt": "4.0.0", + "randombytes": "2.0.5", + "randomfill": "1.0.3" + } + }, + "dashdash": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", + "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", + "dev": true, + "requires": { + "assert-plus": "1.0.0" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true + } + } + }, + "date-now": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/date-now/-/date-now-0.1.4.tgz", + "integrity": "sha1-6vQ5/U1ISK105cx9vvIAZyueNFs=" + }, + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "defined": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/defined/-/defined-1.0.0.tgz", + "integrity": "sha1-yY2bzvdWdBiOEQlpFRGZ45sfppM=" + }, + "delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", + "dev": true + }, + "deps-sort": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/deps-sort/-/deps-sort-2.0.0.tgz", + "integrity": "sha1-CRckkC6EZYJg65EHSMzNGvbiH7U=", + "requires": { + "JSONStream": "1.3.2", + "shasum": "1.0.2", + "subarg": "1.0.0", + "through2": "2.0.3" + } + }, + "des.js": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/des.js/-/des.js-1.0.0.tgz", + "integrity": "sha1-wHTS4qpqipoH29YfmhXCzYPsjsw=", + "requires": { + "inherits": "2.0.3", + "minimalistic-assert": "1.0.0" + } + }, + "diff": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/diff/-/diff-1.4.0.tgz", + "integrity": "sha1-fyjS657nsVqX79ic5j3P2qPMur8=", + "dev": true + }, + "diffie-hellman": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/diffie-hellman/-/diffie-hellman-5.0.2.tgz", + "integrity": "sha1-tYNXOScM/ias9jIJn97SoH8gnl4=", + "requires": { + "bn.js": "4.11.8", + "miller-rabin": "4.0.1", + "randombytes": "2.0.5" + } + }, + "domain-browser": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/domain-browser/-/domain-browser-1.1.7.tgz", + "integrity": "sha1-hnqksJP6oF8d4IwG9NeyH9+GmLw=" + }, + "duplexer2": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/duplexer2/-/duplexer2-0.1.4.tgz", + "integrity": "sha1-ixLauHjA1p4+eJEFFmKjL8a93ME=", + "requires": { + "readable-stream": "2.3.3" + } + }, + "ecc-jsbn": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz", + "integrity": "sha1-D8c6ntXw1Tw4GTOYUj735UN3dQU=", + "dev": true, + "optional": true, + "requires": { + "jsbn": "0.1.1" + } + }, + "elliptic": { + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.4.0.tgz", + "integrity": "sha1-ysmvh2LIWDYYcAPI3+GT5eLq5d8=", + "requires": { + "bn.js": "4.11.8", + "brorand": "1.1.0", + "hash.js": "1.1.3", + "hmac-drbg": "1.0.1", + "inherits": "2.0.3", + "minimalistic-assert": "1.0.0", + "minimalistic-crypto-utils": "1.0.1" + } + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", + "dev": true + }, + "esprima": { + "version": "2.7.3", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-2.7.3.tgz", + "integrity": "sha1-luO3DVd59q1JzQMmc9HDEnZ7pYE=", + "dev": true + }, + "events": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/events/-/events-1.1.1.tgz", + "integrity": "sha1-nr23Y1rQmccNzEwqH1AEKI6L2SQ=" + }, + "events-to-array": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/events-to-array/-/events-to-array-1.1.2.tgz", + "integrity": "sha1-LUH1Y+H+QA7Uli/hpNXGp1Od9/Y=", + "dev": true + }, + "evp_bytestokey": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", + "integrity": "sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA==", + "requires": { + "md5.js": "1.3.4", + "safe-buffer": "5.1.1" + } + }, + "extend": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.1.tgz", + "integrity": "sha1-p1Xqe8Gt/MWjHOfnYtuq3F5jZEQ=", + "dev": true + }, + "extsprintf": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", + "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", + "dev": true + }, + "foreground-child": { + "version": "1.5.6", + "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-1.5.6.tgz", + "integrity": "sha1-T9ca0t/elnibmApcCilZN8svXOk=", + "dev": true, + "requires": { + "cross-spawn": "4.0.2", + "signal-exit": "3.0.2" + } + }, + "forever-agent": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", + "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", + "dev": true + }, + "form-data": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.1.4.tgz", + "integrity": "sha1-M8GDrPGTJ27KqYFDpp6Uv+4XUNE=", + "dev": true, + "requires": { + "asynckit": "0.4.0", + "combined-stream": "1.0.5", + "mime-types": "2.1.17" + } + }, + "fs-exists-cached": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs-exists-cached/-/fs-exists-cached-1.0.0.tgz", + "integrity": "sha1-zyVVTKBQ3EmuZla0HeQiWJidy84=", + "dev": true + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" + }, + "function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" + }, + "function-loop": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/function-loop/-/function-loop-1.0.1.tgz", + "integrity": "sha1-gHa7MF6OajzO7ikgdl8zDRkPNAw=", + "dev": true + }, + "generate-function": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/generate-function/-/generate-function-2.0.0.tgz", + "integrity": "sha1-aFj+fAlpt9TpCTM3ZHrHn2DfvnQ=", + "dev": true + }, + "generate-object-property": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/generate-object-property/-/generate-object-property-1.2.0.tgz", + "integrity": "sha1-nA4cQDCM6AT0eDYYuTf6iPmdUNA=", + "dev": true, + "requires": { + "is-property": "1.0.2" + } + }, + "getpass": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", + "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", + "dev": true, + "requires": { + "assert-plus": "1.0.0" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true + } + } + }, + "glob": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", + "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", + "requires": { + "fs.realpath": "1.0.0", + "inflight": "1.0.6", + "inherits": "2.0.3", + "minimatch": "3.0.4", + "once": "1.4.0", + "path-is-absolute": "1.0.1" + } + }, + "har-validator": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-2.0.6.tgz", + "integrity": "sha1-zcvAgYgmWtEZtqWnyKtw7s+10n0=", + "dev": true, + "requires": { + "chalk": "1.1.3", + "commander": "2.12.2", + "is-my-json-valid": "2.17.1", + "pinkie-promise": "2.0.1" + } + }, + "has": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.1.tgz", + "integrity": "sha1-hGFzP1OLCDfJNh45qauelwTcLyg=", + "requires": { + "function-bind": "1.1.1" + } + }, + "has-ansi": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", + "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", + "dev": true, + "requires": { + "ansi-regex": "2.1.1" + } + }, + "has-template-literals": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-template-literals/-/has-template-literals-1.0.0.tgz", + "integrity": "sha512-OjOC7MbUgpKFF2eOwD370uzNueJ4Yk3d0fstlTTwY7YsWPM5Awb2DOXQW3LXanULW/Sf/YAcKN5mDBhTIWI95Q==", + "dev": true + }, + "hash-base": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-2.0.2.tgz", + "integrity": "sha1-ZuodhW206KVHDK32/OI65SRO8uE=", + "requires": { + "inherits": "2.0.3" + } + }, + "hash.js": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.3.tgz", + "integrity": "sha512-/UETyP0W22QILqS+6HowevwhEFJ3MBJnwTf75Qob9Wz9t0DPuisL8kW8YZMK62dHAKE1c1p+gY1TtOLY+USEHA==", + "requires": { + "inherits": "2.0.3", + "minimalistic-assert": "1.0.0" + } + }, + "hashish": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/hashish/-/hashish-0.0.4.tgz", + "integrity": "sha1-bWC8b/r3Ebav1g5CbQd5iAFOZVQ=", + "dev": true, + "requires": { + "traverse": "0.3.9" + } + }, + "hawk": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/hawk/-/hawk-3.1.3.tgz", + "integrity": "sha1-B4REvXwWQLD+VA0sm3PVlnjo4cQ=", + "dev": true, + "requires": { + "boom": "2.10.1", + "cryptiles": "2.0.5", + "hoek": "2.16.3", + "sntp": "1.0.9" + } + }, + "hmac-drbg": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/hmac-drbg/-/hmac-drbg-1.0.1.tgz", + "integrity": "sha1-0nRXAQJabHdabFRXk+1QL8DGSaE=", + "requires": { + "hash.js": "1.1.3", + "minimalistic-assert": "1.0.0", + "minimalistic-crypto-utils": "1.0.1" + } + }, + "hoek": { + "version": "2.16.3", + "resolved": "https://registry.npmjs.org/hoek/-/hoek-2.16.3.tgz", + "integrity": "sha1-ILt0A9POo5jpHcRxCo/xuCdKJe0=", + "dev": true + }, + "htmlescape": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/htmlescape/-/htmlescape-1.1.1.tgz", + "integrity": "sha1-OgPtwiFLyjtmQko+eVk0lQnLA1E=" + }, + "http-signature": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.1.1.tgz", + "integrity": "sha1-33LiZwZs0Kxn+3at+OE0qPvPkb8=", + "dev": true, + "requires": { + "assert-plus": "0.2.0", + "jsprim": "1.4.1", + "sshpk": "1.13.1" + } + }, + "https-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/https-browserify/-/https-browserify-1.0.0.tgz", + "integrity": "sha1-7AbBDgo0wPL68Zn3/X/Hj//QPHM=" + }, + "ieee754": { + "version": "1.1.8", + "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.8.tgz", + "integrity": "sha1-vjPUCsEO8ZJnAfbwii2G+/0a0+Q=" + }, + "indexof": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/indexof/-/indexof-0.0.1.tgz", + "integrity": "sha1-gtwzbSMrkGIXnQWrMpOmYFn9Q10=" + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "requires": { + "once": "1.4.0", + "wrappy": "1.0.2" + } + }, + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" + }, + "inline-source-map": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/inline-source-map/-/inline-source-map-0.6.2.tgz", + "integrity": "sha1-+Tk0ccGKedFyT4Y/o4tYY3Ct4qU=", + "requires": { + "source-map": "0.5.7" + } + }, + "insert-module-globals": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/insert-module-globals/-/insert-module-globals-7.0.1.tgz", + "integrity": "sha1-wDv04BywhtW15azorQr+eInWOMM=", + "requires": { + "JSONStream": "1.3.2", + "combine-source-map": "0.7.2", + "concat-stream": "1.5.2", + "is-buffer": "1.1.6", + "lexical-scope": "1.2.0", + "process": "0.11.10", + "through2": "2.0.3", + "xtend": "4.0.1" + } + }, + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" + }, + "is-my-json-valid": { + "version": "2.17.1", + "resolved": "https://registry.npmjs.org/is-my-json-valid/-/is-my-json-valid-2.17.1.tgz", + "integrity": "sha512-Q2khNw+oBlWuaYvEEHtKSw/pCxD2L5Rc1C+UQme9X6JdRDh7m5D7HkozA0qa3DUkQ6VzCnEm8mVIQPyIRkI5sQ==", + "dev": true, + "requires": { + "generate-function": "2.0.0", + "generate-object-property": "1.2.0", + "jsonpointer": "4.0.1", + "xtend": "4.0.1" + } + }, + "is-property": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-property/-/is-property-1.0.2.tgz", + "integrity": "sha1-V/4cTkhHTt1lsJkR8msc1Ald2oQ=", + "dev": true + }, + "is-typedarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", + "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", + "dev": true + }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" + }, + "isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", + "dev": true + }, + "isstream": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", + "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", + "dev": true + }, + "js-yaml": { + "version": "3.10.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.10.0.tgz", + "integrity": "sha512-O2v52ffjLa9VeM43J4XocZE//WT9N0IiwDa3KSHH7Tu8CtH+1qM8SIZvnsTh6v+4yFy5KUY3BHUVwjpfAWsjIA==", + "dev": true, + "requires": { + "argparse": "1.0.9", + "esprima": "4.0.0" + }, + "dependencies": { + "esprima": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.0.tgz", + "integrity": "sha512-oftTcaMu/EGrEIu904mWteKIv8vMuOgGYo7EhVJJN00R/EED9DCua/xxHRdYnKtcECzVg7xOWhflvJMnqcFZjw==", + "dev": true + } + } + }, + "jsbn": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", + "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", + "dev": true, + "optional": true + }, + "json-schema": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", + "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", + "dev": true + }, + "json-stable-stringify": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-0.0.1.tgz", + "integrity": "sha1-YRwj6BTbN1Un34URk9tZ3Sryf0U=", + "requires": { + "jsonify": "0.0.0" + } + }, + "json-stringify-safe": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", + "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", + "dev": true + }, + "jsonify": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", + "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=" + }, + "jsonparse": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/jsonparse/-/jsonparse-1.3.1.tgz", + "integrity": "sha1-P02uSpH6wxX3EGL4UhzCOfE2YoA=" + }, + "jsonpointer": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/jsonpointer/-/jsonpointer-4.0.1.tgz", + "integrity": "sha1-T9kss04OnbPInIYi7PUfm5eMbLk=", + "dev": true + }, + "jsprim": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", + "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", + "dev": true, + "requires": { + "assert-plus": "1.0.0", + "extsprintf": "1.3.0", + "json-schema": "0.2.3", + "verror": "1.10.0" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true + } + } + }, + "labeled-stream-splicer": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/labeled-stream-splicer/-/labeled-stream-splicer-2.0.0.tgz", + "integrity": "sha1-pS4dE4AkwAuGscDJH2d5GLiuClk=", + "requires": { + "inherits": "2.0.3", + "isarray": "0.0.1", + "stream-splicer": "2.0.0" + }, + "dependencies": { + "isarray": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", + "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=" + } + } + }, + "lcov-parse": { + "version": "0.0.10", + "resolved": "https://registry.npmjs.org/lcov-parse/-/lcov-parse-0.0.10.tgz", + "integrity": "sha1-GwuP+ayceIklBYK3C3ExXZ2m2aM=", + "dev": true + }, + "lexical-scope": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/lexical-scope/-/lexical-scope-1.2.0.tgz", + "integrity": "sha1-/Ope3HBKSzqHls3KQZw6CvryLfQ=", + "requires": { + "astw": "2.2.0" + } + }, + "lodash.memoize": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-3.0.4.tgz", + "integrity": "sha1-LcvSwofLwKVcxCMovQxzYVDVPj8=" + }, + "log-driver": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/log-driver/-/log-driver-1.2.5.tgz", + "integrity": "sha1-euTsJXMC/XkNVXyxDJcQDYV7AFY=", + "dev": true + }, + "lru-cache": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.1.tgz", + "integrity": "sha512-q4spe4KTfsAS1SUHLO0wz8Qiyf1+vMIAgpRYioFYDMNqKfHQbg+AVDH3i4fvpl71/P1L0dBl+fQi+P37UYf0ew==", + "dev": true, + "requires": { + "pseudomap": "1.0.2", + "yallist": "2.1.2" + } + }, + "make-generator-function": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/make-generator-function/-/make-generator-function-1.1.0.tgz", + "integrity": "sha1-ho6TVRp/rx5rsab8EfcvyjIuJqg=", + "dev": true + }, + "md5.js": { + "version": "1.3.4", + "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.4.tgz", + "integrity": "sha1-6b296UogpawYsENA/Fdk1bCdkB0=", + "requires": { + "hash-base": "3.0.4", + "inherits": "2.0.3" + }, + "dependencies": { + "hash-base": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-3.0.4.tgz", + "integrity": "sha1-X8hoaEfs1zSZQDMZprCj8/auSRg=", + "requires": { + "inherits": "2.0.3", + "safe-buffer": "5.1.1" + } + } + } + }, + "miller-rabin": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/miller-rabin/-/miller-rabin-4.0.1.tgz", + "integrity": "sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA==", + "requires": { + "bn.js": "4.11.8", + "brorand": "1.1.0" + } + }, + "mime-db": { + "version": "1.30.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.30.0.tgz", + "integrity": "sha1-dMZD2i3Z1qRTmZY0ZbJtXKfXHwE=", + "dev": true + }, + "mime-types": { + "version": "2.1.17", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.17.tgz", + "integrity": "sha1-Cdejk/A+mVp5+K+Fe3Cp4KsWVXo=", + "dev": true, + "requires": { + "mime-db": "1.30.0" + } + }, + "minimalistic-assert": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.0.tgz", + "integrity": "sha1-cCvi3aazf0g2vLP121ZkG2Sh09M=" + }, + "minimalistic-crypto-utils": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz", + "integrity": "sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo=" + }, + "minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "requires": { + "brace-expansion": "1.1.8" + } + }, + "minimist": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", + "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=" + }, + "module-deps": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/module-deps/-/module-deps-4.1.1.tgz", + "integrity": "sha1-IyFYM/HaE/1gbMuAh7RIUty4If0=", + "requires": { + "JSONStream": "1.3.2", + "browser-resolve": "1.11.2", + "cached-path-relative": "1.0.1", + "concat-stream": "1.5.2", + "defined": "1.0.0", + "detective": "4.7.1", + "duplexer2": "0.1.4", + "inherits": "2.0.3", + "parents": "1.0.1", + "readable-stream": "2.3.3", + "resolve": "1.5.0", + "stream-combiner2": "1.1.1", + "subarg": "1.0.0", + "through2": "2.0.3", + "xtend": "4.0.1" + }, + "dependencies": { + "acorn": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.3.0.tgz", + "integrity": "sha512-Yej+zOJ1Dm/IMZzzj78OntP/r3zHEaKcyNoU2lAaxPtrseM6rF0xwqoz5Q5ysAiED9hTjI2hgtvLXitlCN1/Ug==" + }, + "detective": { + "version": "4.7.1", + "resolved": "https://registry.npmjs.org/detective/-/detective-4.7.1.tgz", + "integrity": "sha512-H6PmeeUcZloWtdt4DAkFyzFL94arpHr3NOwwmVILFiy+9Qd4JTxxXrzfyGk/lmct2qVGBwTSwSXagqu2BxmWig==", + "requires": { + "acorn": "5.3.0", + "defined": "1.0.0" + } + } + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true + }, + "nyc": { + "version": "11.4.1", + "resolved": "https://registry.npmjs.org/nyc/-/nyc-11.4.1.tgz", + "integrity": "sha512-5eCZpvaksFVjP2rt1r60cfXmt3MUtsQDw8bAzNqNEr4WLvUMLgiVENMf/B9bE9YAX0mGVvaGA3v9IS9ekNqB1Q==", + "dev": true, + "requires": { + "archy": "1.0.0", + "arrify": "1.0.1", + "caching-transform": "1.0.1", + "convert-source-map": "1.5.1", + "debug-log": "1.0.1", + "default-require-extensions": "1.0.0", + "find-cache-dir": "0.1.1", + "find-up": "2.1.0", + "foreground-child": "1.5.6", + "glob": "7.1.2", + "istanbul-lib-coverage": "1.1.1", + "istanbul-lib-hook": "1.1.0", + "istanbul-lib-instrument": "1.9.1", + "istanbul-lib-report": "1.1.2", + "istanbul-lib-source-maps": "1.2.2", + "istanbul-reports": "1.1.3", + "md5-hex": "1.3.0", + "merge-source-map": "1.0.4", + "micromatch": "2.3.11", + "mkdirp": "0.5.1", + "resolve-from": "2.0.0", + "rimraf": "2.6.2", + "signal-exit": "3.0.2", + "spawn-wrap": "1.4.2", + "test-exclude": "4.1.1", + "yargs": "10.0.3", + "yargs-parser": "8.0.0" + }, + "dependencies": { + "align-text": { + "version": "0.1.4", + "bundled": true, + "dev": true, + "requires": { + "kind-of": "3.2.2", + "longest": "1.0.1", + "repeat-string": "1.6.1" + } + }, + "amdefine": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "ansi-regex": { + "version": "2.1.1", + "bundled": true, + "dev": true + }, + "ansi-styles": { + "version": "2.2.1", + "bundled": true, + "dev": true + }, + "append-transform": { + "version": "0.4.0", + "bundled": true, + "dev": true, + "requires": { + "default-require-extensions": "1.0.0" + } + }, + "archy": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "arr-diff": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "arr-flatten": "1.1.0" + } + }, + "arr-flatten": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "array-unique": { + "version": "0.2.1", + "bundled": true, + "dev": true + }, + "arrify": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "async": { + "version": "1.5.2", + "bundled": true, + "dev": true + }, + "babel-code-frame": { + "version": "6.26.0", + "bundled": true, + "dev": true, + "requires": { + "chalk": "1.1.3", + "esutils": "2.0.2", + "js-tokens": "3.0.2" + } + }, + "babel-generator": { + "version": "6.26.0", + "bundled": true, + "dev": true, + "requires": { + "babel-messages": "6.23.0", + "babel-runtime": "6.26.0", + "babel-types": "6.26.0", + "detect-indent": "4.0.0", + "jsesc": "1.3.0", + "lodash": "4.17.4", + "source-map": "0.5.7", + "trim-right": "1.0.1" + } + }, + "babel-messages": { + "version": "6.23.0", + "bundled": true, + "dev": true, + "requires": { + "babel-runtime": "6.26.0" + } + }, + "babel-runtime": { + "version": "6.26.0", + "bundled": true, + "dev": true, + "requires": { + "core-js": "2.5.3", + "regenerator-runtime": "0.11.1" + } + }, + "babel-template": { + "version": "6.26.0", + "bundled": true, + "dev": true, + "requires": { + "babel-runtime": "6.26.0", + "babel-traverse": "6.26.0", + "babel-types": "6.26.0", + "babylon": "6.18.0", + "lodash": "4.17.4" + } + }, + "babel-traverse": { + "version": "6.26.0", + "bundled": true, + "dev": true, + "requires": { + "babel-code-frame": "6.26.0", + "babel-messages": "6.23.0", + "babel-runtime": "6.26.0", + "babel-types": "6.26.0", + "babylon": "6.18.0", + "debug": "2.6.9", + "globals": "9.18.0", + "invariant": "2.2.2", + "lodash": "4.17.4" + } + }, + "babel-types": { + "version": "6.26.0", + "bundled": true, + "dev": true, + "requires": { + "babel-runtime": "6.26.0", + "esutils": "2.0.2", + "lodash": "4.17.4", + "to-fast-properties": "1.0.3" + } + }, + "babylon": { + "version": "6.18.0", + "bundled": true, + "dev": true + }, + "balanced-match": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "brace-expansion": { + "version": "1.1.8", + "bundled": true, + "dev": true, + "requires": { + "balanced-match": "1.0.0", + "concat-map": "0.0.1" + } + }, + "braces": { + "version": "1.8.5", + "bundled": true, + "dev": true, + "requires": { + "expand-range": "1.8.2", + "preserve": "0.2.0", + "repeat-element": "1.1.2" + } + }, + "builtin-modules": { + "version": "1.1.1", + "bundled": true, + "dev": true + }, + "caching-transform": { + "version": "1.0.1", + "bundled": true, + "dev": true, + "requires": { + "md5-hex": "1.3.0", + "mkdirp": "0.5.1", + "write-file-atomic": "1.3.4" + } + }, + "camelcase": { + "version": "1.2.1", + "bundled": true, + "dev": true, + "optional": true + }, + "center-align": { + "version": "0.1.3", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "align-text": "0.1.4", + "lazy-cache": "1.0.4" + } + }, + "chalk": { + "version": "1.1.3", + "bundled": true, + "dev": true, + "requires": { + "ansi-styles": "2.2.1", + "escape-string-regexp": "1.0.5", + "has-ansi": "2.0.0", + "strip-ansi": "3.0.1", + "supports-color": "2.0.0" + } + }, + "cliui": { + "version": "2.1.0", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "center-align": "0.1.3", + "right-align": "0.1.3", + "wordwrap": "0.0.2" + }, + "dependencies": { + "wordwrap": { + "version": "0.0.2", + "bundled": true, + "dev": true, + "optional": true + } + } + }, + "code-point-at": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "commondir": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "bundled": true, + "dev": true + }, + "convert-source-map": { + "version": "1.5.1", + "bundled": true, + "dev": true + }, + "core-js": { + "version": "2.5.3", + "bundled": true, + "dev": true + }, + "cross-spawn": { + "version": "4.0.2", + "bundled": true, + "dev": true, + "requires": { + "lru-cache": "4.1.1", + "which": "1.3.0" + } + }, + "debug": { + "version": "2.6.9", + "bundled": true, + "dev": true, + "requires": { + "ms": "2.0.0" + } + }, + "debug-log": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "decamelize": { + "version": "1.2.0", + "bundled": true, + "dev": true + }, + "default-require-extensions": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "strip-bom": "2.0.0" + } + }, + "detect-indent": { + "version": "4.0.0", + "bundled": true, + "dev": true, + "requires": { + "repeating": "2.0.1" + } + }, + "error-ex": { + "version": "1.3.1", + "bundled": true, + "dev": true, + "requires": { + "is-arrayish": "0.2.1" + } + }, + "escape-string-regexp": { + "version": "1.0.5", + "bundled": true, + "dev": true + }, + "esutils": { + "version": "2.0.2", + "bundled": true, + "dev": true + }, + "execa": { + "version": "0.7.0", + "bundled": true, + "dev": true, + "requires": { + "cross-spawn": "5.1.0", + "get-stream": "3.0.0", + "is-stream": "1.1.0", + "npm-run-path": "2.0.2", + "p-finally": "1.0.0", + "signal-exit": "3.0.2", + "strip-eof": "1.0.0" + }, + "dependencies": { + "cross-spawn": { + "version": "5.1.0", + "bundled": true, + "dev": true, + "requires": { + "lru-cache": "4.1.1", + "shebang-command": "1.2.0", + "which": "1.3.0" + } + } + } + }, + "expand-brackets": { + "version": "0.1.5", + "bundled": true, + "dev": true, + "requires": { + "is-posix-bracket": "0.1.1" + } + }, + "expand-range": { + "version": "1.8.2", + "bundled": true, + "dev": true, + "requires": { + "fill-range": "2.2.3" + } + }, + "extglob": { + "version": "0.3.2", + "bundled": true, + "dev": true, + "requires": { + "is-extglob": "1.0.0" + } + }, + "filename-regex": { + "version": "2.0.1", + "bundled": true, + "dev": true + }, + "fill-range": { + "version": "2.2.3", + "bundled": true, + "dev": true, + "requires": { + "is-number": "2.1.0", + "isobject": "2.1.0", + "randomatic": "1.1.7", + "repeat-element": "1.1.2", + "repeat-string": "1.6.1" + } + }, + "find-cache-dir": { + "version": "0.1.1", + "bundled": true, + "dev": true, + "requires": { + "commondir": "1.0.1", + "mkdirp": "0.5.1", + "pkg-dir": "1.0.0" + } + }, + "find-up": { + "version": "2.1.0", + "bundled": true, + "dev": true, + "requires": { + "locate-path": "2.0.0" + } + }, + "for-in": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "for-own": { + "version": "0.1.5", + "bundled": true, + "dev": true, + "requires": { + "for-in": "1.0.2" + } + }, + "foreground-child": { + "version": "1.5.6", + "bundled": true, + "dev": true, + "requires": { + "cross-spawn": "4.0.2", + "signal-exit": "3.0.2" + } + }, + "fs.realpath": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "get-caller-file": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "get-stream": { + "version": "3.0.0", + "bundled": true, + "dev": true + }, + "glob": { + "version": "7.1.2", + "bundled": true, + "dev": true, + "requires": { + "fs.realpath": "1.0.0", + "inflight": "1.0.6", + "inherits": "2.0.3", + "minimatch": "3.0.4", + "once": "1.4.0", + "path-is-absolute": "1.0.1" + } + }, + "glob-base": { + "version": "0.3.0", + "bundled": true, + "dev": true, + "requires": { + "glob-parent": "2.0.0", + "is-glob": "2.0.1" + } + }, + "glob-parent": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "is-glob": "2.0.1" + } + }, + "globals": { + "version": "9.18.0", + "bundled": true, + "dev": true + }, + "graceful-fs": { + "version": "4.1.11", + "bundled": true, + "dev": true + }, + "handlebars": { + "version": "4.0.11", + "bundled": true, + "dev": true, + "requires": { + "async": "1.5.2", + "optimist": "0.6.1", + "source-map": "0.4.4", + "uglify-js": "2.8.29" + }, + "dependencies": { + "source-map": { + "version": "0.4.4", + "bundled": true, + "dev": true, + "requires": { + "amdefine": "1.0.1" + } + } + } + }, + "has-ansi": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "ansi-regex": "2.1.1" + } + }, + "has-flag": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "hosted-git-info": { + "version": "2.5.0", + "bundled": true, + "dev": true + }, + "imurmurhash": { + "version": "0.1.4", + "bundled": true, + "dev": true + }, + "inflight": { + "version": "1.0.6", + "bundled": true, + "dev": true, + "requires": { + "once": "1.4.0", + "wrappy": "1.0.2" + } + }, + "inherits": { + "version": "2.0.3", + "bundled": true, + "dev": true + }, + "invariant": { + "version": "2.2.2", + "bundled": true, + "dev": true, + "requires": { + "loose-envify": "1.3.1" + } + }, + "invert-kv": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "is-arrayish": { + "version": "0.2.1", + "bundled": true, + "dev": true + }, + "is-buffer": { + "version": "1.1.6", + "bundled": true, + "dev": true + }, + "is-builtin-module": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "builtin-modules": "1.1.1" + } + }, + "is-dotfile": { + "version": "1.0.3", + "bundled": true, + "dev": true + }, + "is-equal-shallow": { + "version": "0.1.3", + "bundled": true, + "dev": true, + "requires": { + "is-primitive": "2.0.0" + } + }, + "is-extendable": { + "version": "0.1.1", + "bundled": true, + "dev": true + }, + "is-extglob": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "is-finite": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "requires": { + "number-is-nan": "1.0.1" + } + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "number-is-nan": "1.0.1" + } + }, + "is-glob": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "requires": { + "is-extglob": "1.0.0" + } + }, + "is-number": { + "version": "2.1.0", + "bundled": true, + "dev": true, + "requires": { + "kind-of": "3.2.2" + } + }, + "is-posix-bracket": { + "version": "0.1.1", + "bundled": true, + "dev": true + }, + "is-primitive": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "is-stream": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "is-utf8": { + "version": "0.2.1", + "bundled": true, + "dev": true + }, + "isarray": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "isexe": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "isobject": { + "version": "2.1.0", + "bundled": true, + "dev": true, + "requires": { + "isarray": "1.0.0" + } + }, + "istanbul-lib-coverage": { + "version": "1.1.1", + "bundled": true, + "dev": true + }, + "istanbul-lib-hook": { + "version": "1.1.0", + "bundled": true, + "dev": true, + "requires": { + "append-transform": "0.4.0" + } + }, + "istanbul-lib-instrument": { + "version": "1.9.1", + "bundled": true, + "dev": true, + "requires": { + "babel-generator": "6.26.0", + "babel-template": "6.26.0", + "babel-traverse": "6.26.0", + "babel-types": "6.26.0", + "babylon": "6.18.0", + "istanbul-lib-coverage": "1.1.1", + "semver": "5.4.1" + } + }, + "istanbul-lib-report": { + "version": "1.1.2", + "bundled": true, + "dev": true, + "requires": { + "istanbul-lib-coverage": "1.1.1", + "mkdirp": "0.5.1", + "path-parse": "1.0.5", + "supports-color": "3.2.3" + }, + "dependencies": { + "supports-color": { + "version": "3.2.3", + "bundled": true, + "dev": true, + "requires": { + "has-flag": "1.0.0" + } + } + } + }, + "istanbul-lib-source-maps": { + "version": "1.2.2", + "bundled": true, + "dev": true, + "requires": { + "debug": "3.1.0", + "istanbul-lib-coverage": "1.1.1", + "mkdirp": "0.5.1", + "rimraf": "2.6.2", + "source-map": "0.5.7" + }, + "dependencies": { + "debug": { + "version": "3.1.0", + "bundled": true, + "dev": true, + "requires": { + "ms": "2.0.0" + } + } + } + }, + "istanbul-reports": { + "version": "1.1.3", + "bundled": true, + "dev": true, + "requires": { + "handlebars": "4.0.11" + } + }, + "js-tokens": { + "version": "3.0.2", + "bundled": true, + "dev": true + }, + "jsesc": { + "version": "1.3.0", + "bundled": true, + "dev": true + }, + "kind-of": { + "version": "3.2.2", + "bundled": true, + "dev": true, + "requires": { + "is-buffer": "1.1.6" + } + }, + "lazy-cache": { + "version": "1.0.4", + "bundled": true, + "dev": true, + "optional": true + }, + "lcid": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "invert-kv": "1.0.0" + } + }, + "load-json-file": { + "version": "1.1.0", + "bundled": true, + "dev": true, + "requires": { + "graceful-fs": "4.1.11", + "parse-json": "2.2.0", + "pify": "2.3.0", + "pinkie-promise": "2.0.1", + "strip-bom": "2.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "p-locate": "2.0.0", + "path-exists": "3.0.0" + }, + "dependencies": { + "path-exists": { + "version": "3.0.0", + "bundled": true, + "dev": true + } + } + }, + "lodash": { + "version": "4.17.4", + "bundled": true, + "dev": true + }, + "longest": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "loose-envify": { + "version": "1.3.1", + "bundled": true, + "dev": true, + "requires": { + "js-tokens": "3.0.2" + } + }, + "lru-cache": { + "version": "4.1.1", + "bundled": true, + "dev": true, + "requires": { + "pseudomap": "1.0.2", + "yallist": "2.1.2" + } + }, + "md5-hex": { + "version": "1.3.0", + "bundled": true, + "dev": true, + "requires": { + "md5-o-matic": "0.1.1" + } + }, + "md5-o-matic": { + "version": "0.1.1", + "bundled": true, + "dev": true + }, + "mem": { + "version": "1.1.0", + "bundled": true, + "dev": true, + "requires": { + "mimic-fn": "1.1.0" + } + }, + "merge-source-map": { + "version": "1.0.4", + "bundled": true, + "dev": true, + "requires": { + "source-map": "0.5.7" + } + }, + "micromatch": { + "version": "2.3.11", + "bundled": true, + "dev": true, + "requires": { + "arr-diff": "2.0.0", + "array-unique": "0.2.1", + "braces": "1.8.5", + "expand-brackets": "0.1.5", + "extglob": "0.3.2", + "filename-regex": "2.0.1", + "is-extglob": "1.0.0", + "is-glob": "2.0.1", + "kind-of": "3.2.2", + "normalize-path": "2.1.1", + "object.omit": "2.0.1", + "parse-glob": "3.0.4", + "regex-cache": "0.4.4" + } + }, + "mimic-fn": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "minimatch": { + "version": "3.0.4", + "bundled": true, + "dev": true, + "requires": { + "brace-expansion": "1.1.8" + } + }, + "minimist": { + "version": "0.0.8", + "bundled": true, + "dev": true + }, + "mkdirp": { + "version": "0.5.1", + "bundled": true, + "dev": true, + "requires": { + "minimist": "0.0.8" + } + }, + "ms": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "normalize-package-data": { + "version": "2.4.0", + "bundled": true, + "dev": true, + "requires": { + "hosted-git-info": "2.5.0", + "is-builtin-module": "1.0.0", + "semver": "5.4.1", + "validate-npm-package-license": "3.0.1" + } + }, + "normalize-path": { + "version": "2.1.1", + "bundled": true, + "dev": true, + "requires": { + "remove-trailing-separator": "1.1.0" + } + }, + "npm-run-path": { + "version": "2.0.2", + "bundled": true, + "dev": true, + "requires": { + "path-key": "2.0.1" + } + }, + "number-is-nan": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "object-assign": { + "version": "4.1.1", + "bundled": true, + "dev": true + }, + "object.omit": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "requires": { + "for-own": "0.1.5", + "is-extendable": "0.1.1" + } + }, + "once": { + "version": "1.4.0", + "bundled": true, + "dev": true, + "requires": { + "wrappy": "1.0.2" + } + }, + "optimist": { + "version": "0.6.1", + "bundled": true, + "dev": true, + "requires": { + "minimist": "0.0.8", + "wordwrap": "0.0.3" + } + }, + "os-homedir": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "os-locale": { + "version": "2.1.0", + "bundled": true, + "dev": true, + "requires": { + "execa": "0.7.0", + "lcid": "1.0.0", + "mem": "1.1.0" + } + }, + "p-finally": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "p-limit": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "p-locate": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "p-limit": "1.1.0" + } + }, + "parse-glob": { + "version": "3.0.4", + "bundled": true, + "dev": true, + "requires": { + "glob-base": "0.3.0", + "is-dotfile": "1.0.3", + "is-extglob": "1.0.0", + "is-glob": "2.0.1" + } + }, + "parse-json": { + "version": "2.2.0", + "bundled": true, + "dev": true, + "requires": { + "error-ex": "1.3.1" + } + }, + "path-exists": { + "version": "2.1.0", + "bundled": true, + "dev": true, + "requires": { + "pinkie-promise": "2.0.1" + } + }, + "path-is-absolute": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "path-key": { + "version": "2.0.1", + "bundled": true, + "dev": true + }, + "path-parse": { + "version": "1.0.5", + "bundled": true, + "dev": true + }, + "path-type": { + "version": "1.1.0", + "bundled": true, + "dev": true, + "requires": { + "graceful-fs": "4.1.11", + "pify": "2.3.0", + "pinkie-promise": "2.0.1" + } + }, + "pify": { + "version": "2.3.0", + "bundled": true, + "dev": true + }, + "pinkie": { + "version": "2.0.4", + "bundled": true, + "dev": true + }, + "pinkie-promise": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "requires": { + "pinkie": "2.0.4" + } + }, + "pkg-dir": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "find-up": "1.1.2" + }, + "dependencies": { + "find-up": { + "version": "1.1.2", + "bundled": true, + "dev": true, + "requires": { + "path-exists": "2.1.0", + "pinkie-promise": "2.0.1" + } + } + } + }, + "preserve": { + "version": "0.2.0", + "bundled": true, + "dev": true + }, + "pseudomap": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "randomatic": { + "version": "1.1.7", + "bundled": true, + "dev": true, + "requires": { + "is-number": "3.0.0", + "kind-of": "4.0.0" + }, + "dependencies": { + "is-number": { + "version": "3.0.0", + "bundled": true, + "dev": true, + "requires": { + "kind-of": "3.2.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "bundled": true, + "dev": true, + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, + "kind-of": { + "version": "4.0.0", + "bundled": true, + "dev": true, + "requires": { + "is-buffer": "1.1.6" + } + } + } + }, + "read-pkg": { + "version": "1.1.0", + "bundled": true, + "dev": true, + "requires": { + "load-json-file": "1.1.0", + "normalize-package-data": "2.4.0", + "path-type": "1.1.0" + } + }, + "read-pkg-up": { + "version": "1.0.1", + "bundled": true, + "dev": true, + "requires": { + "find-up": "1.1.2", + "read-pkg": "1.1.0" + }, + "dependencies": { + "find-up": { + "version": "1.1.2", + "bundled": true, + "dev": true, + "requires": { + "path-exists": "2.1.0", + "pinkie-promise": "2.0.1" + } + } + } + }, + "regenerator-runtime": { + "version": "0.11.1", + "bundled": true, + "dev": true + }, + "regex-cache": { + "version": "0.4.4", + "bundled": true, + "dev": true, + "requires": { + "is-equal-shallow": "0.1.3" + } + }, + "remove-trailing-separator": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "repeat-element": { + "version": "1.1.2", + "bundled": true, + "dev": true + }, + "repeat-string": { + "version": "1.6.1", + "bundled": true, + "dev": true + }, + "repeating": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "requires": { + "is-finite": "1.0.2" + } + }, + "require-directory": { + "version": "2.1.1", + "bundled": true, + "dev": true + }, + "require-main-filename": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "resolve-from": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "right-align": { + "version": "0.1.3", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "align-text": "0.1.4" + } + }, + "rimraf": { + "version": "2.6.2", + "bundled": true, + "dev": true, + "requires": { + "glob": "7.1.2" + } + }, + "semver": { + "version": "5.4.1", + "bundled": true, + "dev": true + }, + "set-blocking": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "shebang-command": { + "version": "1.2.0", + "bundled": true, + "dev": true, + "requires": { + "shebang-regex": "1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "signal-exit": { + "version": "3.0.2", + "bundled": true, + "dev": true + }, + "slide": { + "version": "1.1.6", + "bundled": true, + "dev": true + }, + "source-map": { + "version": "0.5.7", + "bundled": true, + "dev": true + }, + "spawn-wrap": { + "version": "1.4.2", + "bundled": true, + "dev": true, + "requires": { + "foreground-child": "1.5.6", + "mkdirp": "0.5.1", + "os-homedir": "1.0.2", + "rimraf": "2.6.2", + "signal-exit": "3.0.2", + "which": "1.3.0" + } + }, + "spdx-correct": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "requires": { + "spdx-license-ids": "1.2.2" + } + }, + "spdx-expression-parse": { + "version": "1.0.4", + "bundled": true, + "dev": true + }, + "spdx-license-ids": { + "version": "1.2.2", + "bundled": true, + "dev": true + }, + "string-width": { + "version": "2.1.1", + "bundled": true, + "dev": true, + "requires": { + "is-fullwidth-code-point": "2.0.0", + "strip-ansi": "4.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "bundled": true, + "dev": true + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "strip-ansi": { + "version": "4.0.0", + "bundled": true, + "dev": true, + "requires": { + "ansi-regex": "3.0.0" + } + } + } + }, + "strip-ansi": { + "version": "3.0.1", + "bundled": true, + "dev": true, + "requires": { + "ansi-regex": "2.1.1" + } + }, + "strip-bom": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "is-utf8": "0.2.1" + } + }, + "strip-eof": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "supports-color": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "test-exclude": { + "version": "4.1.1", + "bundled": true, + "dev": true, + "requires": { + "arrify": "1.0.1", + "micromatch": "2.3.11", + "object-assign": "4.1.1", + "read-pkg-up": "1.0.1", + "require-main-filename": "1.0.1" + } + }, + "to-fast-properties": { + "version": "1.0.3", + "bundled": true, + "dev": true + }, + "trim-right": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "uglify-js": { + "version": "2.8.29", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "source-map": "0.5.7", + "uglify-to-browserify": "1.0.2", + "yargs": "3.10.0" + }, + "dependencies": { + "yargs": { + "version": "3.10.0", + "bundled": true, + "dev": true, + "optional": true, + "requires": { + "camelcase": "1.2.1", + "cliui": "2.1.0", + "decamelize": "1.2.0", + "window-size": "0.1.0" + } + } + } + }, + "uglify-to-browserify": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "validate-npm-package-license": { + "version": "3.0.1", + "bundled": true, + "dev": true, + "requires": { + "spdx-correct": "1.0.2", + "spdx-expression-parse": "1.0.4" + } + }, + "which": { + "version": "1.3.0", + "bundled": true, + "dev": true, + "requires": { + "isexe": "2.0.0" + } + }, + "which-module": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "window-size": { + "version": "0.1.0", + "bundled": true, + "dev": true, + "optional": true + }, + "wordwrap": { + "version": "0.0.3", + "bundled": true, + "dev": true + }, + "wrap-ansi": { + "version": "2.1.0", + "bundled": true, + "dev": true, + "requires": { + "string-width": "1.0.2", + "strip-ansi": "3.0.1" + }, + "dependencies": { + "string-width": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "requires": { + "code-point-at": "1.1.0", + "is-fullwidth-code-point": "1.0.0", + "strip-ansi": "3.0.1" + } + } + } + }, + "wrappy": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "write-file-atomic": { + "version": "1.3.4", + "bundled": true, + "dev": true, + "requires": { + "graceful-fs": "4.1.11", + "imurmurhash": "0.1.4", + "slide": "1.1.6" + } + }, + "y18n": { + "version": "3.2.1", + "bundled": true, + "dev": true + }, + "yallist": { + "version": "2.1.2", + "bundled": true, + "dev": true + }, + "yargs": { + "version": "10.0.3", + "bundled": true, + "dev": true, + "requires": { + "cliui": "3.2.0", + "decamelize": "1.2.0", + "find-up": "2.1.0", + "get-caller-file": "1.0.2", + "os-locale": "2.1.0", + "require-directory": "2.1.1", + "require-main-filename": "1.0.1", + "set-blocking": "2.0.0", + "string-width": "2.1.1", + "which-module": "2.0.0", + "y18n": "3.2.1", + "yargs-parser": "8.0.0" + }, + "dependencies": { + "cliui": { + "version": "3.2.0", + "bundled": true, + "dev": true, + "requires": { + "string-width": "1.0.2", + "strip-ansi": "3.0.1", + "wrap-ansi": "2.1.0" + }, + "dependencies": { + "string-width": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "requires": { + "code-point-at": "1.1.0", + "is-fullwidth-code-point": "1.0.0", + "strip-ansi": "3.0.1" + } + } + } + } + } + }, + "yargs-parser": { + "version": "8.0.0", + "bundled": true, + "dev": true, + "requires": { + "camelcase": "4.1.0" + }, + "dependencies": { + "camelcase": { + "version": "4.1.0", + "bundled": true, + "dev": true + } + } + } + } + }, + "oauth-sign": { + "version": "0.8.2", + "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.8.2.tgz", + "integrity": "sha1-Rqarfwrq2N6unsBWV4C31O/rnUM=", + "dev": true + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "requires": { + "wrappy": "1.0.2" + } + }, + "opener": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/opener/-/opener-1.4.3.tgz", + "integrity": "sha1-XG2ixdflgx6P+jlklQ+NZnSskLg=", + "dev": true + }, + "os-browserify": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/os-browserify/-/os-browserify-0.3.0.tgz", + "integrity": "sha1-hUNzx/XCMVkU/Jv8a9gjj92h7Cc=" + }, + "os-homedir": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", + "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", + "dev": true + }, + "os-tmpdir": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", + "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", + "dev": true + }, + "own-or": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/own-or/-/own-or-1.0.0.tgz", + "integrity": "sha1-Tod/vtqaLsgAD7wLyuOWRe6L+Nw=", + "dev": true + }, + "own-or-env": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/own-or-env/-/own-or-env-1.0.0.tgz", + "integrity": "sha1-nvkg/IHi5jz1nUEQElg2jPT8pPs=", + "dev": true + }, + "pako": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.6.tgz", + "integrity": "sha512-lQe48YPsMJAig+yngZ87Lus+NF+3mtu7DVOBu6b/gHO1YpKwIj5AWjZ/TOS7i46HD/UixzWb1zeWDZfGZ3iYcg==" + }, + "parents": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parents/-/parents-1.0.1.tgz", + "integrity": "sha1-/t1NK/GTp3dF/nHjcdc8MwfZx1E=", + "requires": { + "path-platform": "0.11.15" + } + }, + "parse-asn1": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/parse-asn1/-/parse-asn1-5.1.0.tgz", + "integrity": "sha1-N8T5t+06tlx0gXtfJICTf7+XxxI=", + "requires": { + "asn1.js": "4.9.2", + "browserify-aes": "1.1.1", + "create-hash": "1.1.3", + "evp_bytestokey": "1.0.3", + "pbkdf2": "3.0.14" + } + }, + "path-browserify": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/path-browserify/-/path-browserify-0.0.0.tgz", + "integrity": "sha1-oLhwcpquIUAFt9UDLsLLuw+0RRo=" + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" + }, + "path-parse": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.5.tgz", + "integrity": "sha1-PBrfhx6pzWyUMbbqK9dKD/BVxME=" + }, + "path-platform": { + "version": "0.11.15", + "resolved": "https://registry.npmjs.org/path-platform/-/path-platform-0.11.15.tgz", + "integrity": "sha1-6GQhf3TDaFDwhSt43Hv31KVyG/I=" + }, + "pbkdf2": { + "version": "3.0.14", + "resolved": "https://registry.npmjs.org/pbkdf2/-/pbkdf2-3.0.14.tgz", + "integrity": "sha512-gjsZW9O34fm0R7PaLHRJmLLVfSoesxztjPjE9o6R+qtVJij90ltg1joIovN9GKrRW3t1PzhDDG3UMEMFfZ+1wA==", + "requires": { + "create-hash": "1.1.3", + "create-hmac": "1.1.6", + "ripemd160": "2.0.1", + "safe-buffer": "5.1.1", + "sha.js": "2.4.9" + } + }, + "pinkie": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", + "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", + "dev": true + }, + "pinkie-promise": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", + "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", + "dev": true, + "requires": { + "pinkie": "2.0.4" + } + }, + "process": { + "version": "0.11.10", + "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", + "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=" + }, + "process-nextick-args": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", + "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=" + }, + "pseudomap": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", + "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", + "dev": true + }, + "public-encrypt": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/public-encrypt/-/public-encrypt-4.0.0.tgz", + "integrity": "sha1-OfaZ86RlYN1eusvKaTyvfGXBjMY=", + "requires": { + "bn.js": "4.11.8", + "browserify-rsa": "4.0.1", + "create-hash": "1.1.3", + "parse-asn1": "5.1.0", + "randombytes": "2.0.5" + } + }, + "punycode": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=" + }, + "qs": { + "version": "6.3.2", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.3.2.tgz", + "integrity": "sha1-51vV9uJoEioqDgvaYwslUMFmUCw=", + "dev": true + }, + "querystring": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", + "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=" + }, + "querystring-es3": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/querystring-es3/-/querystring-es3-0.2.1.tgz", + "integrity": "sha1-nsYfeQSYdXB9aUFFlv2Qek1xHnM=" + }, + "randombytes": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.0.5.tgz", + "integrity": "sha512-8T7Zn1AhMsQ/HI1SjcCfT/t4ii3eAqco3yOcSzS4mozsOz69lHLsoMXmF9nZgnFanYscnSlUSgs8uZyKzpE6kg==", + "requires": { + "safe-buffer": "5.1.1" + } + }, + "randomfill": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/randomfill/-/randomfill-1.0.3.tgz", + "integrity": "sha512-YL6GrhrWoic0Eq8rXVbMptH7dAxCs0J+mh5Y0euNekPPYaxEmdVGim6GdoxoRzKW2yJoU8tueifS7mYxvcFDEQ==", + "requires": { + "randombytes": "2.0.5", + "safe-buffer": "5.1.1" + } + }, + "read-only-stream": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/read-only-stream/-/read-only-stream-2.0.0.tgz", + "integrity": "sha1-JyT9aoET1zdkrCiNQ4YnDB2/F/A=", + "requires": { + "readable-stream": "2.3.3" + } + }, + "readable-stream": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.3.tgz", + "integrity": "sha512-m+qzzcn7KUxEmd1gMbchF+Y2eIUbieUaxkWtptyHywrX0rE8QEYqPC07Vuy4Wm32/xE16NcdBctb8S0Xe/5IeQ==", + "requires": { + "core-util-is": "1.0.2", + "inherits": "2.0.3", + "isarray": "1.0.0", + "process-nextick-args": "1.0.7", + "safe-buffer": "5.1.1", + "string_decoder": "1.0.3", + "util-deprecate": "1.0.2" + } + }, + "request": { + "version": "2.79.0", + "resolved": "https://registry.npmjs.org/request/-/request-2.79.0.tgz", + "integrity": "sha1-Tf5b9r6LjNw3/Pk+BLZVd3InEN4=", + "dev": true, + "requires": { + "aws-sign2": "0.6.0", + "aws4": "1.6.0", + "caseless": "0.11.0", + "combined-stream": "1.0.5", + "extend": "3.0.1", + "forever-agent": "0.6.1", + "form-data": "2.1.4", + "har-validator": "2.0.6", + "hawk": "3.1.3", + "http-signature": "1.1.1", + "is-typedarray": "1.0.0", + "isstream": "0.1.2", + "json-stringify-safe": "5.0.1", + "mime-types": "2.1.17", + "oauth-sign": "0.8.2", + "qs": "6.3.2", + "stringstream": "0.0.5", + "tough-cookie": "2.3.3", + "tunnel-agent": "0.4.3", + "uuid": "3.1.0" + } + }, + "resolve": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.5.0.tgz", + "integrity": "sha512-hgoSGrc3pjzAPHNBg+KnFcK2HwlHTs/YrAGUr6qgTVUZmXv1UEXXl0bZNBKMA9fud6lRYFdPGz0xXxycPzmmiw==", + "requires": { + "path-parse": "1.0.5" + } + }, + "rimraf": { + "version": "2.2.8", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.2.8.tgz", + "integrity": "sha1-5Dm+Kq7jJzIZUnMPmaiSnk/FBYI=", + "dev": true + }, + "ripemd160": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/ripemd160/-/ripemd160-2.0.1.tgz", + "integrity": "sha1-D0WEKVxTo2KK9+bXmsohzlfRxuc=", + "requires": { + "hash-base": "2.0.2", + "inherits": "2.0.3" + } + }, + "safe-buffer": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", + "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==" + }, + "seq": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/seq/-/seq-0.3.5.tgz", + "integrity": "sha1-rgKvOkJHk9jMvyEtaRdODFTf/jg=", + "dev": true, + "requires": { + "chainsaw": "0.0.9", + "hashish": "0.0.4" + } + }, + "sha.js": { + "version": "2.4.9", + "resolved": "https://registry.npmjs.org/sha.js/-/sha.js-2.4.9.tgz", + "integrity": "sha512-G8zektVqbiPHrylgew9Zg1VRB1L/DtXNUVAM6q4QLy8NE3qtHlFXTf8VLL4k1Yl6c7NMjtZUTdXV+X44nFaT6A==", + "requires": { + "inherits": "2.0.3", + "safe-buffer": "5.1.1" + } + }, + "shasum": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/shasum/-/shasum-1.0.2.tgz", + "integrity": "sha1-5wEjENj0F/TetXEhUOVni4euVl8=", + "requires": { + "json-stable-stringify": "0.0.1", + "sha.js": "2.4.9" + } + }, + "shell-quote": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.6.1.tgz", + "integrity": "sha1-9HgZSczkAmlxJ0MOo7PFR29IF2c=", + "requires": { + "array-filter": "0.0.1", + "array-map": "0.0.0", + "array-reduce": "0.0.0", + "jsonify": "0.0.0" + } + }, + "signal-exit": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", + "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", + "dev": true + }, + "sntp": { + "version": "1.0.9", + "resolved": "https://registry.npmjs.org/sntp/-/sntp-1.0.9.tgz", + "integrity": "sha1-ZUEYTMkK7qbG57NeJlkIJEPGYZg=", + "dev": true, + "requires": { + "hoek": "2.16.3" + } + }, + "source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=" + }, + "source-map-support": { + "version": "0.4.18", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.4.18.tgz", + "integrity": "sha512-try0/JqxPLF9nOjvSta7tVondkP5dwgyLDjVoyMDlmjugT2lRZ1OfsrYTkCd2hkDnJTKRbO/Rl3orm8vlsUzbA==", + "dev": true, + "requires": { + "source-map": "0.5.7" + } + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", + "dev": true + }, + "sshpk": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.13.1.tgz", + "integrity": "sha1-US322mKHFEMW3EwY/hzx2UBzm+M=", + "dev": true, + "requires": { + "asn1": "0.2.3", + "assert-plus": "1.0.0", + "bcrypt-pbkdf": "1.0.1", + "dashdash": "1.14.1", + "ecc-jsbn": "0.1.1", + "getpass": "0.1.7", + "jsbn": "0.1.1", + "tweetnacl": "0.14.5" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true + } + } + }, + "stack-utils": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-1.0.1.tgz", + "integrity": "sha1-1PM6tU6OOHeLDKXP07OvsS22hiA=", + "dev": true + }, + "stream-browserify": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/stream-browserify/-/stream-browserify-2.0.1.tgz", + "integrity": "sha1-ZiZu5fm9uZQKTkUUyvtDu3Hlyds=", + "requires": { + "inherits": "2.0.3", + "readable-stream": "2.3.3" + } + }, + "stream-combiner2": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/stream-combiner2/-/stream-combiner2-1.1.1.tgz", + "integrity": "sha1-+02KFCDqNidk4hrUeAOXvry0HL4=", + "requires": { + "duplexer2": "0.1.4", + "readable-stream": "2.3.3" + } + }, + "stream-http": { + "version": "2.7.2", + "resolved": "https://registry.npmjs.org/stream-http/-/stream-http-2.7.2.tgz", + "integrity": "sha512-c0yTD2rbQzXtSsFSVhtpvY/vS6u066PcXOX9kBB3mSO76RiUQzL340uJkGBWnlBg4/HZzqiUXtaVA7wcRcJgEw==", + "requires": { + "builtin-status-codes": "3.0.0", + "inherits": "2.0.3", + "readable-stream": "2.3.3", + "to-arraybuffer": "1.0.1", + "xtend": "4.0.1" + } + }, + "stream-splicer": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/stream-splicer/-/stream-splicer-2.0.0.tgz", + "integrity": "sha1-G2O+Q4oTPktnHMGTUZdgAXWRDYM=", + "requires": { + "inherits": "2.0.3", + "readable-stream": "2.3.3" + } + }, + "string_decoder": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", + "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", + "requires": { + "safe-buffer": "5.1.1" + } + }, + "stringstream": { + "version": "0.0.5", + "resolved": "https://registry.npmjs.org/stringstream/-/stringstream-0.0.5.tgz", + "integrity": "sha1-TkhM1N5aC7vuGORjB3EKioFiGHg=", + "dev": true + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "dev": true, + "requires": { + "ansi-regex": "2.1.1" + } + }, + "subarg": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/subarg/-/subarg-1.0.0.tgz", + "integrity": "sha1-9izxdYHplrSPyWVpn1TAauJouNI=", + "requires": { + "minimist": "1.2.0" + } + }, + "supports-color": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", + "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", + "dev": true + }, + "syntax-error": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/syntax-error/-/syntax-error-1.3.0.tgz", + "integrity": "sha1-HtkmbE1AvnXcVb+bsct3Biu5bKE=", + "requires": { + "acorn": "4.0.13" + } + }, + "tap": { + "version": "10.7.3", + "resolved": "https://registry.npmjs.org/tap/-/tap-10.7.3.tgz", + "integrity": "sha512-oS/FIq+tcmxVgYn5usKtLsX+sOHNEj+G7JIQE9SBjO5mVYB1rbaEJJiDbnYp8k0ZqY2Pe4HbYEpkvzm9jfLDyw==", + "dev": true, + "requires": { + "bind-obj-methods": "1.0.0", + "bluebird": "3.5.1", + "clean-yaml-object": "0.1.0", + "color-support": "1.1.3", + "coveralls": "2.13.3", + "foreground-child": "1.5.6", + "fs-exists-cached": "1.0.0", + "function-loop": "1.0.1", + "glob": "7.1.2", + "isexe": "2.0.0", + "js-yaml": "3.10.0", + "nyc": "11.4.1", + "opener": "1.4.3", + "os-homedir": "1.0.2", + "own-or": "1.0.0", + "own-or-env": "1.0.0", + "readable-stream": "2.3.3", + "signal-exit": "3.0.2", + "source-map-support": "0.4.18", + "stack-utils": "1.0.1", + "tap-mocha-reporter": "3.0.6", + "tap-parser": "5.4.0", + "tmatch": "3.1.0", + "trivial-deferred": "1.0.1", + "tsame": "1.1.2", + "yapool": "1.0.0" + } + }, + "tap-mocha-reporter": { + "version": "3.0.6", + "resolved": "https://registry.npmjs.org/tap-mocha-reporter/-/tap-mocha-reporter-3.0.6.tgz", + "integrity": "sha512-UImgw3etckDQCoqZIAIKcQDt0w1JLVs3v0yxLlmwvGLZl6MGFxF7JME5PElXjAoDklVDU42P3vVu5jgr37P4Yg==", + "dev": true, + "requires": { + "color-support": "1.1.3", + "debug": "2.6.9", + "diff": "1.4.0", + "escape-string-regexp": "1.0.5", + "glob": "7.1.2", + "js-yaml": "3.10.0", + "readable-stream": "2.3.3", + "tap-parser": "5.4.0", + "unicode-length": "1.0.3" + } + }, + "tap-parser": { + "version": "5.4.0", + "resolved": "https://registry.npmjs.org/tap-parser/-/tap-parser-5.4.0.tgz", + "integrity": "sha512-BIsIaGqv7uTQgTW1KLTMNPSEQf4zDDPgYOBRdgOfuB+JFOLRBfEu6cLa/KvMvmqggu1FKXDfitjLwsq4827RvA==", + "dev": true, + "requires": { + "events-to-array": "1.1.2", + "js-yaml": "3.10.0", + "readable-stream": "2.3.3" + } + }, + "temp": { + "version": "0.8.3", + "resolved": "https://registry.npmjs.org/temp/-/temp-0.8.3.tgz", + "integrity": "sha1-4Ma8TSa5AxJEEOT+2BEDAU38H1k=", + "dev": true, + "requires": { + "os-tmpdir": "1.0.2", + "rimraf": "2.2.8" + } + }, + "through": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", + "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" + }, + "through2": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.3.tgz", + "integrity": "sha1-AARWmzfHx0ujnEPzzteNGtlBQL4=", + "requires": { + "readable-stream": "2.3.3", + "xtend": "4.0.1" + } + }, + "timers-browserify": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/timers-browserify/-/timers-browserify-1.4.2.tgz", + "integrity": "sha1-ycWLV1voQHN1y14kYtrO50NZ9B0=", + "requires": { + "process": "0.11.10" + } + }, + "tmatch": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/tmatch/-/tmatch-3.1.0.tgz", + "integrity": "sha512-W3MSATOCN4pVu2qFxmJLIArSifeSOFqnfx9hiUaVgOmeRoI2NbU7RNga+6G+L8ojlFeQge+ZPCclWyUpQ8UeNQ==", + "dev": true + }, + "to-arraybuffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz", + "integrity": "sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M=" + }, + "tough-cookie": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.3.tgz", + "integrity": "sha1-C2GKVWW23qkL80JdBNVe3EdadWE=", + "dev": true, + "requires": { + "punycode": "1.4.1" + } + }, + "traverse": { + "version": "0.3.9", + "resolved": "https://registry.npmjs.org/traverse/-/traverse-0.3.9.tgz", + "integrity": "sha1-cXuPIgzAu3tE5AUUwisui7xw2Lk=", + "dev": true + }, + "trivial-deferred": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/trivial-deferred/-/trivial-deferred-1.0.1.tgz", + "integrity": "sha1-N21NKdlR1jaKb3oK6FwvTV4GWPM=", + "dev": true + }, + "tsame": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/tsame/-/tsame-1.1.2.tgz", + "integrity": "sha512-ovCs24PGjmByVPr9tSIOs/yjUX9sJl0grEmOsj9dZA/UknQkgPOKcUqM84aSCvt9awHuhc/boMzTg3BHFalxWw==", + "dev": true + }, + "tty-browserify": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/tty-browserify/-/tty-browserify-0.0.0.tgz", + "integrity": "sha1-oVe6QC2iTpv5V/mqadUk7tQpAaY=" + }, + "tunnel-agent": { + "version": "0.4.3", + "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.4.3.tgz", + "integrity": "sha1-Y3PbdpCf5XDgjXNYM2Xtgop07us=", + "dev": true + }, + "tweetnacl": { + "version": "0.14.5", + "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", + "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", + "dev": true, + "optional": true + }, + "typedarray": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", + "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=" + }, + "umd": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/umd/-/umd-3.0.1.tgz", + "integrity": "sha1-iuVW4RAR9jwllnCKiDclnwGz1g4=" + }, + "underscore": { + "version": "1.8.3", + "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.8.3.tgz", + "integrity": "sha1-Tz+1OxBuYJf8+ctBCfKl6b36UCI=", + "dev": true + }, + "unicode-length": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/unicode-length/-/unicode-length-1.0.3.tgz", + "integrity": "sha1-Wtp6f+1RhBpBijKM8UlHisg1irs=", + "dev": true, + "requires": { + "punycode": "1.4.1", + "strip-ansi": "3.0.1" + } + }, + "url": { + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz", + "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=", + "requires": { + "punycode": "1.3.2", + "querystring": "0.2.0" + }, + "dependencies": { + "punycode": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", + "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=" + } + } + }, + "util": { + "version": "0.10.3", + "resolved": "https://registry.npmjs.org/util/-/util-0.10.3.tgz", + "integrity": "sha1-evsa/lCAUkZInj23/g7TeTNqwPk=", + "requires": { + "inherits": "2.0.1" + }, + "dependencies": { + "inherits": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.1.tgz", + "integrity": "sha1-sX0I0ya0Qj5Wjv9xn5GwscvfafE=" + } + } + }, + "util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" + }, + "uuid": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.1.0.tgz", + "integrity": "sha512-DIWtzUkw04M4k3bf1IcpS2tngXEL26YUD2M0tMDUpnUrz2hgzUBlD55a4FjdLGPvfHxS6uluGWvaVEqgBcVa+g==", + "dev": true + }, + "verror": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", + "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", + "dev": true, + "requires": { + "assert-plus": "1.0.0", + "core-util-is": "1.0.2", + "extsprintf": "1.3.0" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true + } + } + }, + "vm-browserify": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/vm-browserify/-/vm-browserify-0.0.4.tgz", + "integrity": "sha1-XX6kW7755Kb/ZflUOOCofDV9WnM=", + "requires": { + "indexof": "0.0.1" + } + }, + "which": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.0.tgz", + "integrity": "sha512-xcJpopdamTuY5duC/KnTTNBraPK54YwpenP4lzxU8H91GudWpFv38u0CKjclE1Wi2EH2EDz5LRcHcKbCIzqGyg==", + "dev": true, + "requires": { + "isexe": "2.0.0" + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" + }, + "xtend": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", + "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=" + }, + "yallist": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", + "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", + "dev": true + }, + "yapool": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/yapool/-/yapool-1.0.0.tgz", + "integrity": "sha1-9pPymjFbUNmp2iZGp6ZkXJaYW2o=", + "dev": true + } + } +} diff --git a/package.json b/package.json index 40f99183d..14d3f8af1 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "browserify", - "version": "6.3.2", + "version": "15.0.0", "description": "browser-side require() the node way", "main": "index.js", "bin": { @@ -8,7 +8,10 @@ }, "repository": { "type": "git", - "url": "http://github.com/substack/node-browserify.git" + "url": "http://github.com/browserify/browserify.git" + }, + "engines": { + "node": ">= 0.8" }, "keywords": [ "browser", @@ -20,68 +23,66 @@ "javascript" ], "dependencies": { - "JSONStream": "~0.8.3", - "assert": "~1.1.0", - "browser-pack": "^3.2.0", - "browser-resolve": "^1.3.0", - "browserify-zlib": "~0.1.2", - "buffer": "^2.3.0", - "builtins": "~0.0.3", - "commondir": "0.0.1", - "concat-stream": "~1.4.1", + "JSONStream": "^1.0.3", + "assert": "^1.4.0", + "browser-pack": "^6.0.1", + "browser-resolve": "^1.11.0", + "browserify-zlib": "~0.2.0", + "buffer": "^5.0.2", + "cached-path-relative": "^1.0.0", + "concat-stream": "~1.5.1", "console-browserify": "^1.1.0", - "constants-browserify": "~0.0.1", + "constants-browserify": "~1.0.0", "crypto-browserify": "^3.0.0", - "deep-equal": "~0.2.1", - "defined": "~0.0.0", - "deps-sort": "^1.3.5", + "defined": "^1.0.0", + "deps-sort": "^2.0.0", "domain-browser": "~1.1.0", - "duplexer2": "~0.0.2", - "events": "~1.0.0", - "glob": "^4.0.5", - "http-browserify": "^1.4.0", - "https-browserify": "~0.0.0", + "duplexer2": "~0.1.2", + "events": "~1.1.0", + "glob": "^7.1.0", + "has": "^1.0.0", + "htmlescape": "^1.1.0", + "https-browserify": "^1.0.0", "inherits": "~2.0.1", - "insert-module-globals": "^6.1.0", - "isarray": "0.0.1", - "labeled-stream-splicer": "^1.0.0", + "insert-module-globals": "^7.0.0", + "labeled-stream-splicer": "^2.0.0", "mkdirp": "^0.5.0", - "module-deps": "^3.5.0", - "os-browserify": "~0.1.1", - "parents": "~0.0.1", + "module-deps": "^5.0.1", + "os-browserify": "~0.3.0", + "parents": "^1.0.1", "path-browserify": "~0.0.0", - "process": "^0.8.0", - "punycode": "~1.2.3", + "process": "~0.11.0", + "punycode": "^1.3.2", "querystring-es3": "~0.2.0", - "readable-stream": "^1.0.33-1", - "resolve": "~0.7.1", - "shallow-copy": "0.0.1", + "read-only-stream": "^2.0.0", + "readable-stream": "^2.0.2", + "resolve": "^1.1.4", "shasum": "^1.0.0", - "shell-quote": "~0.0.1", - "stream-browserify": "^1.0.0", - "string_decoder": "~0.10.0", + "shell-quote": "^1.6.1", + "stream-browserify": "^2.0.0", + "stream-http": "^2.0.0", + "string_decoder": "~1.0.0", "subarg": "^1.0.0", "syntax-error": "^1.1.1", - "through2": "^1.0.0", + "through2": "^2.0.0", "timers-browserify": "^1.0.1", "tty-browserify": "~0.0.0", - "umd": "~2.1.0", - "url": "~0.10.1", + "url": "~0.11.0", "util": "~0.10.1", "vm-browserify": "~0.0.1", - "xtend": "^3.0.0" + "xtend": "^4.0.0" }, "devDependencies": { "backbone": "~0.9.2", - "browser-unpack": "~0.0.0", - "coffee-script": "~1.5.0", - "coffeeify": "~0.6.0", - "dnode": "~1.0.3", - "es6ify": "~0.4.8", - "mkdirp": "~0.3.3", - "osenv": "^0.1.0", - "seq": "0.3.3", - "tap": "~0.4.0", + "browser-unpack": "^1.1.1", + "coffee-script": "~1.10.0", + "coffeeify": "~1.1.0", + "has-template-literals": "^1.0.0", + "isstream": "^0.1.2", + "make-generator-function": "^1.1.0", + "seq": "0.3.5", + "tap": "^10.7.2", + "temp": "^0.8.1", "through": "^2.3.4" }, "author": { diff --git a/readme.markdown b/readme.markdown index cc19a9a2c..3e0db7d02 100644 --- a/readme.markdown +++ b/readme.markdown @@ -3,31 +3,28 @@ `require('modules')` in the browser Use a [node](http://nodejs.org)-style `require()` to organize your browser code -and load modules installed by [npm](https://npmjs.org). +and load modules installed by [npm](https://www.npmjs.com). browserify will recursively analyze all the `require()` calls in your app in order to build a bundle you can serve up to the browser in a single ` ``` +This approach using `-r` and `-x` works fine for a small number of split assets, +but there are plugins for automatically factoring out components which are +described in the +[partitioning section of the browserify handbook](https://github.com/browserify/browserify-handbook#partitioning). + ## api example You can use the API directly too: @@ -350,19 +373,55 @@ b.bundle().pipe(process.stdout); var browserify = require('browserify') ``` -## var b = browserify(files=[] or opts={}) +## `browserify([files] [, opts])` + +Returns a new browserify instance. + +
+
+files +
+ +
+String, file object, or array of those types (they may be mixed) specifying entry file(s). +
+ +
+opts +
+ +
+Object. +
+
+ +`files` and `opts` are both optional, but must be in the order shown if both are +passed. + +Entry files may be passed in `files` and / or `opts.entries`. + +External requires may be specified in `opts.require`, accepting the same formats +that the `files` argument does. -Create a browserify instance `b` from the entry main `files` or `opts.entries`. -`files` can be an array of files or a single file. +If an entry file is a stream, its contents will be used. You should pass +`opts.basedir` when using streaming files so that relative requires can be +resolved. -For each `file` in `files`, if `file` is a stream, its contents will be used. -You should use `opts.basedir` when using streaming files so that relative -requires will know where to resolve from. +`opts.entries` has the same definition as `files`. `opts.noParse` is an array which will skip all require() and global parsing for each file in the array. Use this for giant libs like jquery or threejs that don't have any requires or node-style globals but take forever to parse. +`opts.transform` is an array of transform functions or modules names which will +transform the source code before the parsing. + +`opts.ignoreTransform` is an array of transformations that will not be run, +even if specified elsewhere. + +`opts.plugin` is an array of plugin functions or module names to use. See the +plugins section below for details. + `opts.extensions` is an array of optional extra extensions for the module lookup machinery to use when the extension has not been specified. By default browserify considers only `.js` and `.json` files in such cases. @@ -370,9 +429,14 @@ By default browserify considers only `.js` and `.json` files in such cases. `opts.basedir` is the directory that browserify starts bundling from for filenames that start with `.`. +`opts.paths` is an array of directories that browserify searches when looking +for modules which are not referenced using relative path. Can be absolute or +relative to `basedir`. Equivalent of setting `NODE_PATH` environmental variable +when calling `browserify` command. + `opts.commondir` sets the algorithm used to parse out the common paths. Use `false` to turn this off, otherwise it uses the -[commondir](https://npmjs.org/package/commondir) module. +[commondir](https://www.npmjs.com/package/commondir) module. `opts.fullPaths` disables converting module ids into numerical indexes. This is useful for preserving the original paths that a bundle was generated with. @@ -383,6 +447,8 @@ useful for preserving the original paths that a bundle was generated with. `opts.bundleExternal` boolean option to set if external modules should be bundled. Defaults to true. +When `opts.browserField` is false, the package.json browser field will be ignored. + When `opts.insertGlobals` is true, always insert `process`, `global`, `__filename`, and `__dirname` without analyzing the AST for faster builds but larger output bundles. Default false. @@ -391,6 +457,9 @@ When `opts.detectGlobals` is true, scan all files for `process`, `global`, `__filename`, and `__dirname`, defining as necessary. With this option npm modules are more likely to work but bundling takes longer. Default true. +When `opts.ignoreMissing` is true, ignore `require()` statements that don't +resolve to anything. + When `opts.debug` is true, add a source map inline to the end of the bundle. This makes debugging easier because you can see all the original files if you are in a modern enough browser. @@ -398,12 +467,13 @@ you are in a modern enough browser. When `opts.standalone` is a non-empty string, a standalone module is created with that name and a [umd](https://github.com/forbeslindesay/umd) wrapper. You can use namespaces in the standalone global export using a `.` in the string -name as a separator. For example: `'A.B.C'` +name as a separator, for example `'A.B.C'`. The global export will be [sanitized +and camel cased](https://github.com/ForbesLindesay/umd#name-casing-and-characters). Note that in standalone mode the `require()` calls from the original source will still be around, which may trip up AMD loaders scanning for `require()` calls. You can remove these calls with -[derequire](https://npmjs.org/package/derequire): +[derequire](https://www.npmjs.com/package/derequire): ``` $ npm install -g derequire @@ -411,7 +481,7 @@ $ browserify main.js --standalone Foo | derequire > bundle.js ``` `opts.insertGlobalVars` will be passed to -[insert-module-globals](http://npmjs.org/package/insert-module-globals) +[insert-module-globals](https://www.npmjs.com/package/insert-module-globals) as the `opts.vars` parameter. `opts.externalRequireName` defaults to `'require'` in `expose` mode but you can @@ -421,8 +491,8 @@ Note that if files do not contain javascript source code then you also need to specify a corresponding transform for them. All other options are forwarded along to -[module-deps](https://npmjs.org/package/module-deps) -and [browser-pack](https://npmjs.org/package/browser-pack) directly. +[module-deps](https://www.npmjs.com/package/module-deps) +and [browser-pack](https://www.npmjs.com/package/browser-pack) directly. ## b.add(file, opts) @@ -444,7 +514,7 @@ In `file` array form, you can use a string or object for each item. Object items should have a `file` property and the rest of the parameters will be used for the `opts`. -Use the `expose` property of opts to specify a custom dependency name. +Use the `expose` property of opts to specify a custom dependency name. `require('./vendor/angular/angular.js', {expose: 'angular'})` enables `require('angular')` ## b.bundle(cb) @@ -468,12 +538,16 @@ from the current bundle as the bundle in `file` gets bundled. Prevent the module name or file at `file` from showing up in the output bundle. +If `file` is an array, each item in `file` will be ignored. + Instead you will get a file with `module.exports = {}`. ## b.exclude(file) Prevent the module name or file at `file` from showing up in the output bundle. +If `file` is an array, each item in `file` will be excluded. + If your code tries to `require()` that file it will throw unless you've provided another mechanism for loading it. @@ -487,7 +561,7 @@ If `tr` is a function, it will be called with `tr(file)` and it should return a that takes the raw file contents and produces the transformed source. If `tr` is a string, it should be a module name or file path of a -[transform module](https://github.com/substack/module-deps#transforms) +[transform module](https://github.com/browserify/module-deps#transforms) with a signature of: ``` js @@ -496,8 +570,10 @@ module.exports = function (file) { return through() }; ``` You don't need to necessarily use the -[through](https://npmjs.org/package/through) module, this is just a simple -example. +[through](https://www.npmjs.com/package/through) module. +Browserify is compatible with the newer, more verbose +[Transform streams](http://nodejs.org/api/stream.html#stream_class_stream_transform_1) +built into Node v0.10. Here's how you might compile coffee script on the fly using `.transform()`: @@ -508,7 +584,7 @@ var through = require('through'); b.transform(function (file) { var data = ''; return through(write, end); - + function write (buf) { data += buf } function end () { this.queue(coffee.compile(data)); @@ -523,7 +599,7 @@ Note that on the command-line with the `-c` flag you can just do: $ browserify -c 'coffee -sc' main.coffee > bundle.js ``` -Or better still, use the [coffeeify](https://github.com/substack/coffeeify) +Or better still, use the [coffeeify](https://github.com/jnordberg/coffeeify) module: ``` @@ -540,7 +616,7 @@ transform will suffice. You can also not configure global transforms in a Global transforms always run after any ordinary transforms have run. Transforms may obtain options from the command-line with -[subarg](https://npmjs.org/package/subarg) syntax: +[subarg](https://www.npmjs.com/package/subarg) syntax: ``` $ browserify -t [ foo --bar=555 ] main.js @@ -576,11 +652,11 @@ For more information, consult the plugins section below. ## b.pipeline There is an internal -[labeled-stream-splicer](https://npmjs.org/package/labeled-stream-splicer) +[labeled-stream-splicer](https://www.npmjs.com/package/labeled-stream-splicer) pipeline with these labels: * `'record'` - save inputs to play back later on subsequent `bundle()` calls -* `'deps'` - [module-deps](https://npmjs.org/package/module-deps) +* `'deps'` - [module-deps](https://www.npmjs.com/package/module-deps) * `'json'` - adds `module.exports=` to the beginning of json files * `'unbom'` - remove byte-order markers * `'unshebang'` - remove #! labels on the first line @@ -590,14 +666,14 @@ pipeline with these labels: * `'label'` - apply integer labels to files * `'emit-deps'` - emit `'dep'` event * `'debug'` - apply source maps -* `'pack'` - [browser-pack](https://npmjs.org/package/browser-pack) +* `'pack'` - [browser-pack](https://www.npmjs.com/package/browser-pack) * `'wrap'` - apply final wrapping, `require=` and a newline and semicolon -You can call `b.get()` with a label name to get a handle on a stream pipeline +You can call `b.pipeline.get()` with a label name to get a handle on a stream pipeline that you can `push()`, `unshift()`, or `splice()` to insert your own transform streams. -# b.reset(opts) +## b.reset(opts) Reset the pipeline back to a normal state. This function is called automatically when `bundle()` is called multiple times. @@ -642,9 +718,9 @@ transforms, it doesn't apply into `node_modules` directories. You can specify source transforms in the package.json in the `browserify.transform` field. There is more information about how source transforms work in package.json on the -[module-deps readme](https://github.com/substack/module-deps#transforms). +[module-deps readme](https://github.com/browserify/module-deps#transforms). -For example, if your module requires [brfs](https://npmjs.org/package/brfs), you +For example, if your module requires [brfs](https://www.npmjs.com/package/brfs), you can add ``` json @@ -698,10 +774,10 @@ Plugins are modules that take the bundle instance as their first parameter and an option hash as their second. Plugins can be used to do perform some fancy features that transforms can't do. -For example, [factor-bundle](https://npmjs.org/package/factor-bundle) is a +For example, [factor-bundle](https://www.npmjs.com/package/factor-bundle) is a plugin that can factor out common dependencies from multiple entry-points into a common bundle. Use plugins with `-p` and pass options to plugins with -[subarg](https://npmjs.org/package/subarg) syntax: +[subarg](https://www.npmjs.com/package/subarg) syntax: ``` browserify x.js y.js -p [ factor-bundle -o bundle/x.js -o bundle/y.js ] \ @@ -709,35 +785,32 @@ browserify x.js y.js -p [ factor-bundle -o bundle/x.js -o bundle/y.js ] \ ``` For a list of plugins, consult the -[browserify-plugin tag](https://npmjs.org/browse/keyword/browserify-plugin) +[browserify-plugin tag](https://www.npmjs.com/browse/keyword/browserify-plugin) on npm. # list of source transforms There is a [wiki page that lists the known browserify -transforms](https://github.com/substack/node-browserify/wiki/list-of-transforms). +transforms](https://github.com/browserify/browserify/wiki/list-of-transforms). If you write a transform, make sure to add your transform to that wiki page and add a package.json keyword of `browserify-transform` so that [people can browse for all the browserify -transforms](https://npmjs.org/browse/keyword/browserify-transform) on npmjs.org. +transforms](https://www.npmjs.com/browse/keyword/browserify-transform) on npmjs.org. # third-party tools There is a [wiki page that lists the known browserify -tools](https://github.com/substack/node-browserify/wiki/browserify-tools). +tools](https://github.com/browserify/browserify/wiki/browserify-tools). If you write a tool, make sure to add it to that wiki page and add a package.json keyword of `browserify-tool` so that [people can browse for all the browserify -tools](https://npmjs.org/browse/keyword/browserify-tool) on npmjs.org. +tools](https://www.npmjs.com/browse/keyword/browserify-tool) on npmjs.org. # changelog -Writeups for major releases are available in -[doc/changelog](doc/changelog). - -Minor and patch releases are documented in +Releases are documented in [changelog.markdown](changelog.markdown) and on the [browserify twitter feed](https://twitter.com/browserify). @@ -745,4 +818,4 @@ Minor and patch releases are documented in MIT -![browserify!](http://substack.net/images/browserify/browserify.png) +![browserify!](./assets/browserify.png) diff --git a/test/args.js b/test/args.js index 298b69425..6f8cb0216 100644 --- a/test/args.js +++ b/test/args.js @@ -26,7 +26,7 @@ test('external flag for node modules', function(t) { }); test('bundle from an arguments with --insert-global-vars', function (t) { - t.plan(3) + t.plan(4); var b = fromArgs([ __dirname + '/global/filename.js', @@ -35,12 +35,14 @@ test('bundle from an arguments with --insert-global-vars', function (t) { ]); b.require(__dirname + '/global/filename.js', { expose: 'x' }); b.bundle(function (err, src) { - t.ifError(err); - var c = {}; + t.ifError(err, 'b.bundle()'); + var c = {}, x; vm.runInNewContext(src, c); - var x = c.require('x'); - t.equal(x.filename, '/global/filename.js'); - t.equal(x.dirname, '/global'); + t.doesNotThrow(function() { + x = c.require('x'); + }, 'x = c.require(\'x\')'); + t.equal(x && x.filename, '/global/filename.js', 'x.filename'); + t.equal(x && x.dirname, '/global', 'x.dirname'); }) }); @@ -49,6 +51,22 @@ test('numeric module names', function(t) { var b = fromArgs([ '-x', '1337' ]); b.bundle(function (err, src) { - t.notOk(err); + t.ifError(err); }); }); + +test('entry expose', function (t) { + t.plan(3) + + var b = fromArgs([ + path.join(__dirname, '/entry_expose/main.js'), + '--require', path.join(__dirname, '/entry_expose/main.js') + ':x', + ]); + b.bundle(function (err, src) { + t.ifError(err); + var c = { console: { log: log } }; + function log (msg) { t.equal(msg, 'wow') } + vm.runInNewContext(src, c); + t.equal(c.require('x'), 555); + }) +}); diff --git a/test/array.js b/test/array.js index 990bc6509..31d4c89ee 100644 --- a/test/array.js +++ b/test/array.js @@ -7,7 +7,7 @@ test('array add', function (t) { t.plan(expected.length); var b = browserify(); - var files = [ + var files = [ __dirname + '/array/one.js', __dirname + '/array/two.js', __dirname + '/array/three.js' @@ -25,14 +25,14 @@ test('array require', function (t) { t.plan(3); var b = browserify(); - var files = [ 'isarray', 'subarg' ]; + var files = [ 'defined', 'subarg' ]; b.require(files); b.bundle(function (err, src) { var c = {}; vm.runInNewContext(src, c); - - t.equal(c.require('isarray')([]), true); - t.equal(c.require('isarray')({}), false); + + t.equal(c.require('defined')(undefined, true), true); + t.equal(c.require('defined')(undefined, false), false); t.deepEqual(c.require('subarg')(['-x', '3']), { x: 3, _: [] }); }); }); @@ -42,16 +42,16 @@ test('array require opts', function (t) { var b = browserify(); var files = [ - { file: require.resolve('isarray'), expose: 'abc' }, + { file: require.resolve('defined'), expose: 'abc' }, { file: require.resolve('subarg'), expose: 'def' } ]; b.require(files); b.bundle(function (err, src) { var c = {}; vm.runInNewContext(src, c); - - t.equal(c.require('abc')([]), true); - t.equal(c.require('abc')({}), false); + + t.equal(c.require('abc')(undefined, true), true); + t.equal(c.require('abc')(undefined, false), false); t.deepEqual(c.require('def')(['-x', '3']), { x: 3, _: [] }); }); }); diff --git a/test/async.js b/test/async.js new file mode 100644 index 000000000..e9bd246aa --- /dev/null +++ b/test/async.js @@ -0,0 +1,24 @@ +var browserify = require('../'); +var fs = require('fs'); +var vm = require('vm'); +var test = require('tap').test; + +var src = fs.readFileSync(__dirname + '/async/src.js','utf8'); +var canAsync = true; +try { Function(src) } catch (err) { canAsync = false } + +if (!canAsync) console.error('# async/await unsupported in this environment') +else test('async/await', function (t) { + t.plan(2); + var b = browserify(__dirname + '/async/src.js'); + b.bundle(function (err, src) { + t.error(err) + var c = { + console: { log: log }, + setTimeout: setTimeout, + clearTimeout: clearTimeout + } + vm.runInNewContext(src, c); + function log (msg) { t.equal(msg, 60) } + }); +}); diff --git a/test/async/src.js b/test/async/src.js new file mode 100644 index 000000000..7a50fbcd5 --- /dev/null +++ b/test/async/src.js @@ -0,0 +1,8 @@ +function f (x) { return new Promise(resolve => { + process.nextTick(() => { resolve(x) }) }) } + +async function add (x) { + return x + await f(20) + await f(30) +} + +add(10).then(v => { console.log(v) }) diff --git a/test/bare.js b/test/bare.js index 2ef1031ba..7503180c6 100644 --- a/test/bare.js +++ b/test/bare.js @@ -37,3 +37,34 @@ test('bare', function (t) { t.equal(code, 0); }); }); + +test('bare inserts __filename,__dirname but not process,global,Buffer', function (t) { + t.plan(2); + + var ps = spawn(process.execPath, [ + path.resolve(__dirname, '../bin/cmd.js'), + path.resolve(__dirname, 'bare/main.js'), + '--bare' + ]); + + ps.stdout.pipe(concat(function (body) { + vm.runInNewContext(body, { + console: { + log: function (msg) { + t.same(msg, [ + path.join(__dirname, 'bare'), + path.join(__dirname, 'bare/main.js'), + 'undefined', + 'undefined', + 'undefined' + ]); + } + } + }); + })); + ps.stdin.end(); + + ps.on('exit', function (code) { + t.equal(code, 0); + }); +}); diff --git a/test/bare/main.js b/test/bare/main.js new file mode 100644 index 000000000..e79174303 --- /dev/null +++ b/test/bare/main.js @@ -0,0 +1,7 @@ +console.log([ + __dirname, + __filename, + typeof process, + typeof global, + typeof Buffer +]); diff --git a/test/browser_field_file.js b/test/browser_field_file.js new file mode 100644 index 000000000..cecaef227 --- /dev/null +++ b/test/browser_field_file.js @@ -0,0 +1,13 @@ +var test = require('tap').test; +var vm = require('vm'); +var browserify = require('../'); + +test('browser field file no ext', function (t) { + t.plan(2); + var b = browserify(__dirname + '/browser_field_file/xyz'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (msg) { t.equal(msg, 'cool beans') } + }); +}); diff --git a/test/browser_field_file/package.json b/test/browser_field_file/package.json new file mode 100644 index 000000000..f146bccdb --- /dev/null +++ b/test/browser_field_file/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "./xyz": "wow.js" + } +} diff --git a/test/browser_field_file/wow.js b/test/browser_field_file/wow.js new file mode 100644 index 000000000..eca0d7591 --- /dev/null +++ b/test/browser_field_file/wow.js @@ -0,0 +1 @@ +console.log('cool beans'); diff --git a/test/browser_field_resolve.js b/test/browser_field_resolve.js new file mode 100644 index 000000000..0b26fef4a --- /dev/null +++ b/test/browser_field_resolve.js @@ -0,0 +1,124 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; + +test('browser field resolve (a)', function (t) { + t.plan(2); + var b = browserify(__dirname + '/browser_field_resolve/a/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (x) { t.equal(x, 555) } + }); +}); + +test('browser field resolve (b)', function (t) { + t.plan(2); + var b = browserify(__dirname + '/browser_field_resolve/b/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (x) { t.equal(x, 444) } + }); +}); + +test('browser field resolve (c)', function (t) { + t.plan(2); + var b = browserify(__dirname + '/browser_field_resolve/c/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (x) { t.equal(x, 333) } + }); + +}); + +test('browser field resolve (d)', function (t) { + t.plan(2); + var b = browserify(__dirname + '/browser_field_resolve/d/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (x) { t.equal(x, 222) } + }); +}); + +test('browser field resolve (e)', function (t) { + t.plan(2); + var b = browserify(__dirname + '/browser_field_resolve/e/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (x) { t.equal(x, 111) } + }); +}); + +test('browser field resolve (f)', function (t) { + t.plan(2); + var b = browserify(__dirname + '/browser_field_resolve/f/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (x) { t.equal(x, 999) } + }); +}); + +test('browser field resolve (g)', function (t) { + t.plan(2); + var b = browserify(__dirname + '/browser_field_resolve/g/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (x) { t.deepEqual(x, {}) } + }); +}); + +test('browser field resolve (h)', function (t) { + t.plan(2); + var b = browserify(__dirname + '/browser_field_resolve/h/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (x) { t.deepEqual(x, {}) } + }); +}); + +test('browser field resolve (i)', function (t) { + t.plan(2); + var b = browserify(__dirname + '/browser_field_resolve/i/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (x) { t.deepEqual(x, 5000) } + }); +}); + +test('browser field resolve (j)', function (t) { + t.plan(2); + var b = browserify(__dirname + '/browser_field_resolve/j/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (x) { t.deepEqual(x, 5000) } + }); +}); + +test('browser field resolve (k)', function (t) { + t.plan(2); + var b = browserify(__dirname + '/browser_field_resolve/k/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (x) { t.deepEqual(x, 3000) } + }); +}); + +test('browser field resolve (l)', function (t) { + t.plan(2); + var b = browserify(__dirname + '/browser_field_resolve/l/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (x) { t.deepEqual(x, 3000) } + }); +}); diff --git a/test/browser_field_resolve/a/main.js b/test/browser_field_resolve/a/main.js new file mode 100644 index 000000000..04798b6ba --- /dev/null +++ b/test/browser_field_resolve/a/main.js @@ -0,0 +1 @@ +console.log(require('zzz')) diff --git a/test/browser_field_resolve/a/node_modules/aaa/main.js b/test/browser_field_resolve/a/node_modules/aaa/main.js new file mode 100644 index 000000000..3e842e734 --- /dev/null +++ b/test/browser_field_resolve/a/node_modules/aaa/main.js @@ -0,0 +1 @@ +module.exports = 555 diff --git a/test/browser_field_resolve/a/node_modules/aaa/package.json b/test/browser_field_resolve/a/node_modules/aaa/package.json new file mode 100644 index 000000000..c13b8cf6a --- /dev/null +++ b/test/browser_field_resolve/a/node_modules/aaa/package.json @@ -0,0 +1,3 @@ +{ + "main": "main.js" +} diff --git a/test/browser_field_resolve/a/package.json b/test/browser_field_resolve/a/package.json new file mode 100644 index 000000000..36ad48686 --- /dev/null +++ b/test/browser_field_resolve/a/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "zzz": "aaa" + } +} diff --git a/test/browser_field_resolve/b/main.js b/test/browser_field_resolve/b/main.js new file mode 100644 index 000000000..04798b6ba --- /dev/null +++ b/test/browser_field_resolve/b/main.js @@ -0,0 +1 @@ +console.log(require('zzz')) diff --git a/test/browser_field_resolve/b/package.json b/test/browser_field_resolve/b/package.json new file mode 100644 index 000000000..ed91400b5 --- /dev/null +++ b/test/browser_field_resolve/b/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "zzz": "./x" + } +} diff --git a/test/browser_field_resolve/b/x.js b/test/browser_field_resolve/b/x.js new file mode 100644 index 000000000..41a4973b3 --- /dev/null +++ b/test/browser_field_resolve/b/x.js @@ -0,0 +1 @@ +module.exports = 444 diff --git a/test/browser_field_resolve/c/main.js b/test/browser_field_resolve/c/main.js new file mode 100644 index 000000000..d2bbb5368 --- /dev/null +++ b/test/browser_field_resolve/c/main.js @@ -0,0 +1 @@ +console.log(require('./z.js')) diff --git a/test/browser_field_resolve/c/package.json b/test/browser_field_resolve/c/package.json new file mode 100644 index 000000000..2bd5e9ded --- /dev/null +++ b/test/browser_field_resolve/c/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "./z": "./x" + } +} diff --git a/test/browser_field_resolve/c/x.js b/test/browser_field_resolve/c/x.js new file mode 100644 index 000000000..91238822e --- /dev/null +++ b/test/browser_field_resolve/c/x.js @@ -0,0 +1 @@ +module.exports = 333 diff --git a/test/browser_field_resolve/d/main.js b/test/browser_field_resolve/d/main.js new file mode 100644 index 000000000..d2bbb5368 --- /dev/null +++ b/test/browser_field_resolve/d/main.js @@ -0,0 +1 @@ +console.log(require('./z.js')) diff --git a/test/browser_field_resolve/d/package.json b/test/browser_field_resolve/d/package.json new file mode 100644 index 000000000..deeed5621 --- /dev/null +++ b/test/browser_field_resolve/d/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "./z.js": "./x.js" + } +} diff --git a/test/browser_field_resolve/d/x.js b/test/browser_field_resolve/d/x.js new file mode 100644 index 000000000..fb98b131b --- /dev/null +++ b/test/browser_field_resolve/d/x.js @@ -0,0 +1 @@ +module.exports = 222 diff --git a/test/browser_field_resolve/e/main.js b/test/browser_field_resolve/e/main.js new file mode 100644 index 000000000..d2bbb5368 --- /dev/null +++ b/test/browser_field_resolve/e/main.js @@ -0,0 +1 @@ +console.log(require('./z.js')) diff --git a/test/browser_field_resolve/e/package.json b/test/browser_field_resolve/e/package.json new file mode 100644 index 000000000..8538725e4 --- /dev/null +++ b/test/browser_field_resolve/e/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "./z": "./x.js" + } +} diff --git a/test/browser_field_resolve/e/x.js b/test/browser_field_resolve/e/x.js new file mode 100644 index 000000000..409ecf48a --- /dev/null +++ b/test/browser_field_resolve/e/x.js @@ -0,0 +1 @@ +module.exports = 111 diff --git a/test/browser_field_resolve/f/main.js b/test/browser_field_resolve/f/main.js new file mode 100644 index 000000000..9e1be0024 --- /dev/null +++ b/test/browser_field_resolve/f/main.js @@ -0,0 +1 @@ +console.log(require('aaa/what.js')) diff --git a/test/browser_field_resolve/f/package.json b/test/browser_field_resolve/f/package.json new file mode 100644 index 000000000..339004096 --- /dev/null +++ b/test/browser_field_resolve/f/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "aaa/what": "./x.js" + } +} diff --git a/test/browser_field_resolve/f/x.js b/test/browser_field_resolve/f/x.js new file mode 100644 index 000000000..95c041e1a --- /dev/null +++ b/test/browser_field_resolve/f/x.js @@ -0,0 +1 @@ +module.exports = 999 diff --git a/test/browser_field_resolve/g/main.js b/test/browser_field_resolve/g/main.js new file mode 100644 index 000000000..3100f1d9b --- /dev/null +++ b/test/browser_field_resolve/g/main.js @@ -0,0 +1,2 @@ +try { var x = require('./x') } catch (err) {} +console.log(x) diff --git a/test/browser_field_resolve/g/package.json b/test/browser_field_resolve/g/package.json new file mode 100644 index 000000000..3d0142ce6 --- /dev/null +++ b/test/browser_field_resolve/g/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "./x.js": false + } +} diff --git a/test/browser_field_resolve/g/x.js b/test/browser_field_resolve/g/x.js new file mode 100644 index 000000000..ae629b69b --- /dev/null +++ b/test/browser_field_resolve/g/x.js @@ -0,0 +1 @@ +module.exports = 1000 diff --git a/test/browser_field_resolve/h/main.js b/test/browser_field_resolve/h/main.js new file mode 100644 index 000000000..29ad627e9 --- /dev/null +++ b/test/browser_field_resolve/h/main.js @@ -0,0 +1,2 @@ +try { var x = require('./x.js') } catch (err) {} +console.log(x) diff --git a/test/browser_field_resolve/h/package.json b/test/browser_field_resolve/h/package.json new file mode 100644 index 000000000..d8bf9d12e --- /dev/null +++ b/test/browser_field_resolve/h/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "./x": false + } +} diff --git a/test/browser_field_resolve/h/x.js b/test/browser_field_resolve/h/x.js new file mode 100644 index 000000000..ae629b69b --- /dev/null +++ b/test/browser_field_resolve/h/x.js @@ -0,0 +1 @@ +module.exports = 1000 diff --git a/test/browser_field_resolve/i/browser.js b/test/browser_field_resolve/i/browser.js new file mode 100644 index 000000000..7651b1ab7 --- /dev/null +++ b/test/browser_field_resolve/i/browser.js @@ -0,0 +1 @@ +module.exports = 5000 diff --git a/test/browser_field_resolve/i/main.js b/test/browser_field_resolve/i/main.js new file mode 100644 index 000000000..164cd233e --- /dev/null +++ b/test/browser_field_resolve/i/main.js @@ -0,0 +1,2 @@ +var x = require('./x.js') +console.log(x) diff --git a/test/browser_field_resolve/i/package.json b/test/browser_field_resolve/i/package.json new file mode 100644 index 000000000..aac08b068 --- /dev/null +++ b/test/browser_field_resolve/i/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "./x": "./browser" + } +} diff --git a/test/browser_field_resolve/i/x.js b/test/browser_field_resolve/i/x.js new file mode 100644 index 000000000..ae629b69b --- /dev/null +++ b/test/browser_field_resolve/i/x.js @@ -0,0 +1 @@ +module.exports = 1000 diff --git a/test/browser_field_resolve/j/browser.js b/test/browser_field_resolve/j/browser.js new file mode 100644 index 000000000..7651b1ab7 --- /dev/null +++ b/test/browser_field_resolve/j/browser.js @@ -0,0 +1 @@ +module.exports = 5000 diff --git a/test/browser_field_resolve/j/main.js b/test/browser_field_resolve/j/main.js new file mode 100644 index 000000000..b9f40553b --- /dev/null +++ b/test/browser_field_resolve/j/main.js @@ -0,0 +1,2 @@ +var x = require('./x') +console.log(x) diff --git a/test/browser_field_resolve/j/package.json b/test/browser_field_resolve/j/package.json new file mode 100644 index 000000000..8f617288f --- /dev/null +++ b/test/browser_field_resolve/j/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "./x.js": "./browser.js" + } +} diff --git a/test/browser_field_resolve/j/x.js b/test/browser_field_resolve/j/x.js new file mode 100644 index 000000000..ae629b69b --- /dev/null +++ b/test/browser_field_resolve/j/x.js @@ -0,0 +1 @@ +module.exports = 1000 diff --git a/test/browser_field_resolve/k/main.js b/test/browser_field_resolve/k/main.js new file mode 100644 index 000000000..993b834eb --- /dev/null +++ b/test/browser_field_resolve/k/main.js @@ -0,0 +1,2 @@ +var zzz = require('x/zzz') +console.log(zzz) diff --git a/test/browser_field_resolve/k/node_modules/x/hey.js b/test/browser_field_resolve/k/node_modules/x/hey.js new file mode 100644 index 000000000..6202b34c2 --- /dev/null +++ b/test/browser_field_resolve/k/node_modules/x/hey.js @@ -0,0 +1 @@ +module.exports = 3000 diff --git a/test/browser_field_resolve/k/node_modules/x/package.json b/test/browser_field_resolve/k/node_modules/x/package.json new file mode 100644 index 000000000..cf1ec93f4 --- /dev/null +++ b/test/browser_field_resolve/k/node_modules/x/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "./zzz": "./hey" + } +} diff --git a/test/browser_field_resolve/l/main.js b/test/browser_field_resolve/l/main.js new file mode 100644 index 000000000..993b834eb --- /dev/null +++ b/test/browser_field_resolve/l/main.js @@ -0,0 +1,2 @@ +var zzz = require('x/zzz') +console.log(zzz) diff --git a/test/browser_field_resolve/l/node_modules/x/hey.js b/test/browser_field_resolve/l/node_modules/x/hey.js new file mode 100644 index 000000000..6202b34c2 --- /dev/null +++ b/test/browser_field_resolve/l/node_modules/x/hey.js @@ -0,0 +1 @@ +module.exports = 3000 diff --git a/test/browser_field_resolve/l/node_modules/x/package.json b/test/browser_field_resolve/l/node_modules/x/package.json new file mode 100644 index 000000000..aa9ac588b --- /dev/null +++ b/test/browser_field_resolve/l/node_modules/x/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "./zzz.js": "./hey" + } +} diff --git a/test/bundle-bundle-external.js b/test/bundle-bundle-external.js new file mode 100644 index 000000000..559e7f1fc --- /dev/null +++ b/test/bundle-bundle-external.js @@ -0,0 +1,31 @@ +var browserify = require('../'); +var test = require('tap').test; + +var pubdir = __dirname; +var dir = pubdir + '/bundle-bundle-external'; + +var opt = { + debug: true, + basedir: pubdir, + exposeAll: true +}; + +test('bundle bundle external', function (t) { + t.plan(1); + var bundle1 = browserify(opt); + var name = dir + '/foo.js'; + bundle1.require(name, { entry: true, expose: name, basedir: pubdir }); + + var bundle2 = browserify({ + debug: true, + basedir: pubdir, + entries: [ dir + '/baz.js' ] + }); + + // adding and removing this line causes failure // + //bundle2.external(bundle1); + + bundle2.bundle(function(err, src) { + t.ifError(err); + }); +}); diff --git a/test/bundle-bundle-external/bar.js b/test/bundle-bundle-external/bar.js new file mode 100644 index 000000000..8079379c1 --- /dev/null +++ b/test/bundle-bundle-external/bar.js @@ -0,0 +1,2 @@ +module.exports = 'bar'; +done(); diff --git a/test/bundle-bundle-external/baz.js b/test/bundle-bundle-external/baz.js new file mode 100644 index 000000000..1dda5de34 --- /dev/null +++ b/test/bundle-bundle-external/baz.js @@ -0,0 +1,3 @@ +var foo = require('./foo'); +assert.equal(foo, 'foo'); +done(); diff --git a/test/bundle-bundle-external/foo.js b/test/bundle-bundle-external/foo.js new file mode 100644 index 000000000..99cf946d2 --- /dev/null +++ b/test/bundle-bundle-external/foo.js @@ -0,0 +1,5 @@ +var bar = require('./bar'); +assert.equal(bar, 'bar'); + +module.exports = 'foo'; +done(); diff --git a/test/bundle-stream.js b/test/bundle-stream.js new file mode 100644 index 000000000..4193b3342 --- /dev/null +++ b/test/bundle-stream.js @@ -0,0 +1,18 @@ +var browserify = require('../'); +var test = require('tap').test; + +var isReadable = require('isstream').isReadable; +var isWritable = require('isstream').isWritable; + +test('bundle is readable stream', function (t) { + t.plan(4); + var b = browserify(__dirname + '/entry/main.js'); + b.on('bundle', function(bundle) { + t.ok(isReadable(bundle)); + t.notok(isWritable(bundle)); + }); + + var stream = b.bundle(); + t.ok(isReadable(stream)); + t.notok(isWritable(stream)); +}); diff --git a/test/bundle.js b/test/bundle.js index 025714414..115317a61 100644 --- a/test/bundle.js +++ b/test/bundle.js @@ -13,6 +13,7 @@ test('bundle', function (t) { var c = { setTimeout : setTimeout, + clearTimeout : clearTimeout, console : console }; vm.runInNewContext(src, c); diff --git a/test/bundle_external_global.js b/test/bundle_external_global.js index 47a9c943d..ae02b8105 100644 --- a/test/bundle_external_global.js +++ b/test/bundle_external_global.js @@ -18,7 +18,7 @@ test('bundle external global', function (t) { process: process }); function log (msg) { - t.equal(typeof msg.nextTick, 'function'); + t.equal(msg, process); } }); }); diff --git a/test/coffee_bin.js b/test/coffee_bin.js index 036f354fe..e50569236 100644 --- a/test/coffee_bin.js +++ b/test/coffee_bin.js @@ -11,7 +11,7 @@ test('compiling coffee with -c', function (t) { var ps = spawn(process.execPath, [ path.resolve(__dirname, '../bin/cmd.js'), - '-c', __dirname + '/../node_modules/.bin/coffee -sc', + '-c', '"' + process.execPath + '" "' + __dirname + '/../node_modules/coffee-script/bin/coffee" -sc', 'coffee_bin/main.coffee' ]); var src = ''; diff --git a/test/coffeeify.js b/test/coffeeify.js index e63416af9..176008c00 100644 --- a/test/coffeeify.js +++ b/test/coffeeify.js @@ -11,7 +11,8 @@ test('coffeeify with an implicit global', function (t) { if (err) t.fail(err); vm.runInNewContext(src, { console: { log: log }, - setTimeout: setTimeout + setTimeout: setTimeout, + clearTimeout: clearTimeout }); function log (msg) { t.equal(msg, 'eyo') } }); diff --git a/test/crypto.js b/test/crypto.js index cc0fd2f77..23d77cb04 100644 --- a/test/crypto.js +++ b/test/crypto.js @@ -5,9 +5,9 @@ var fs = require('fs'); var vm = require('vm'); var concat = require('concat-stream'); -var mkdirp = require('mkdirp'); -var tmpdir = '/tmp/browserify-test/' + Math.random().toString(16).slice(2); -mkdirp.sync(tmpdir); +var temp = require('temp'); +temp.track(); +var tmpdir = temp.mkdirSync({prefix: 'browserify-test'}); fs.writeFileSync(tmpdir + '/main.js', 'beep(require("crypto"))\n'); diff --git a/test/crypto_ig.js b/test/crypto_ig.js index 84c638ecd..67965fcd3 100644 --- a/test/crypto_ig.js +++ b/test/crypto_ig.js @@ -5,9 +5,9 @@ var fs = require('fs'); var vm = require('vm'); var concat = require('concat-stream'); -var mkdirp = require('mkdirp'); -var tmpdir = '/tmp/browserify-test/' + Math.random().toString(16).slice(2); -mkdirp.sync(tmpdir); +var temp = require('temp'); +temp.track(); +var tmpdir = temp.mkdirSync({prefix: 'browserify-test'}); fs.writeFileSync(tmpdir + '/main.js', 'beep(require("crypto"))\n'); @@ -15,7 +15,7 @@ test('crypto --insertGlobals', function (t) { t.plan(2); var bin = __dirname + '/../bin/cmd.js'; - var ps = spawn(bin, [ 'main.js', '--ig' ], { cwd : tmpdir }); + var ps = spawn(process.execPath, [ bin, 'main.js', '--ig' ], { cwd : tmpdir }); ps.stderr.pipe(process.stderr, { end : false }); diff --git a/test/debug_standalone.js b/test/debug_standalone.js index 0d9fcdfcb..207090c3a 100644 --- a/test/debug_standalone.js +++ b/test/debug_standalone.js @@ -16,7 +16,7 @@ test('ordinary debug', function (t) { var src = buf.toString('utf8'); var last = src.split('\n').slice(-2)[0]; t.ok( - /\/\/# sourceMappingURL=data:application\/json;base64,[\w+\/=]+$/ + /\/\/# sourceMappingURL=data:application\/json;charset=utf-8;base64,[\w+\/=]+$/ .test(last) ); }); @@ -35,7 +35,7 @@ test('debug standalone', function (t) { var src = buf.toString('utf8'); var last = src.split('\n').slice(-2)[0]; t.ok( - /\/\/# sourceMappingURL=data:application\/json;base64,[\w+\/=]+$/ + /\/\/# sourceMappingURL=data:application\/json;charset=utf-8;base64,[\w+\/=]+$/ .test(last) ); }); @@ -54,7 +54,7 @@ test('debug standalone exposed', function (t) { var src = buf.toString('utf8'); var last = src.split('\n').slice(-2)[0]; t.ok( - /\/\/# sourceMappingURL=data:application\/json;base64,[\w+\/=]+$/ + /\/\/# sourceMappingURL=data:application\/json;charset=utf-8;base64,[\w+\/=]+$/ .test(last) ); var c = { window: {} }; diff --git a/test/dedupe-deps.js b/test/dedupe-deps.js index 2e9e855b5..ebb6dedc2 100644 --- a/test/dedupe-deps.js +++ b/test/dedupe-deps.js @@ -14,10 +14,8 @@ test('identical content gets deduped and the row gets an implicit dep on the ori if (err) return t.fail(err); var deduped = rows.filter(function (x) { return x.dedupeIndex }); var d = deduped[0]; - var deps = {}; - deps[d.dedupe] = d.dedupeIndex; - t.deepEqual(d.deps, deps, "adds implicit dep"); + t.deepEqual(d.deps, { 'dup': d.dedupeIndex }, "adds implicit dep"); } }) @@ -35,6 +33,27 @@ test('identical content gets deduped with fullPaths', function (t) { var deduped = rows.filter(function (x) { return x.dedupe }); var d = deduped[0]; - t.deepEqual(d.source, 'module.exports=require('+ JSON.stringify(d.dedupe) + ')', "dedupes content"); + t.deepEqual( + d.source, + 'arguments[4]['+ JSON.stringify(d.dedupe) + '][0]' + + '.apply(exports,arguments)', + "dedupes content" + ); + } +}) + +test('identical content does not get deduped with dedupe option false', function (t) { + t.plan(1) + + var rows = []; + browserify({fullPaths: true, dedupe: false}) + .on('dep', [].push.bind(rows)) + .require(require.resolve('./dup'), { entry: true }) + .bundle(check); + + function check(err, src) { + if (err) return t.fail(err); + var deduped = rows.filter(function (x) { return x.dedupe }); + t.equal(deduped.length, 0, 'does not dedupe'); } }) diff --git a/test/dedupe-nomap.js b/test/dedupe-nomap.js index 44139d3b5..906fadc0e 100644 --- a/test/dedupe-nomap.js +++ b/test/dedupe-nomap.js @@ -24,7 +24,11 @@ test('identical content gets deduped and the row gets a "nomap" flag set when so 1, '2 rows with the same hash as the duplicate exist' ); - t.similar(nm.source, /module\.exports.*=.*require\(.+\)$/, 'redirects duplicate to original via require call'); + t.similar( + nm.source, + /arguments\[4\]\[.+\]\[0\]\.apply\(exports,arguments\)$/, + 'redirects duplicate to original via require call' + ); } }) @@ -51,6 +55,10 @@ test('identical content gets deduped and the row gets a "nomap" flag set when so 1, '2 rows with the same hash as the duplicate exist' ); - t.similar(nm.source, /module\.exports.*=.*require\(.+\)$/, 'redirects duplicate to original via require call'); + t.similar( + nm.source, + /arguments\[4\]\[.+\]\[0\]\.apply\(exports,arguments\)$/, + 'redirects duplicate to original via require call' + ); } }) diff --git a/test/delay.js b/test/delay.js index 35e7a2b85..6335ee832 100644 --- a/test/delay.js +++ b/test/delay.js @@ -8,8 +8,10 @@ test('delay for pipelines', function (t) { var b = browserify(__dirname + '/delay/main.js'); b.pipeline.get('record').push(through.obj(function (row, enc, next) { - t.equal(row.file, __dirname + '/delay/main.js'); - row.file = __dirname + '/delay/diverted.js'; + if (row.file) { + t.equal(row.file, __dirname + '/delay/main.js'); + row.file = __dirname + '/delay/diverted.js'; + } this.push(row); next(); })); diff --git a/test/dnode.js b/test/dnode.js deleted file mode 100644 index c33143326..000000000 --- a/test/dnode.js +++ /dev/null @@ -1,27 +0,0 @@ -var vm = require('vm'); -var browserify = require('../'); -var test = require('tap').test; - -test('dnode', function (t) { - t.plan(3); - - var b = browserify(); - b.require('dnode'); - - var c = { - console: console, - setTimeout: setTimeout - }; - - b.bundle(function (err, src) { - vm.runInNewContext(src, c); - var dnode = c.require('dnode'); - - t.equal(typeof dnode, 'function', 'dnode object exists'); - t.equal( - dnode.connect, undefined, - "dnode.connect doesn't exist in browsers" - ); - t.ok(dnode().pipe, "dnode() is pipe-able"); - }); -}); diff --git a/test/double_buffer.js b/test/double_buffer.js index 1535eb9b1..37fc6f307 100644 --- a/test/double_buffer.js +++ b/test/double_buffer.js @@ -9,6 +9,6 @@ test('double buffer', function (t) { b.require('buffer'); b.bundle(function (err, src) { if (err) return t.fail(err); - vm.runInNewContext(src, { t: t }); + vm.runInNewContext(src, { t: t, Uint8Array: Uint8Array }); }); }); diff --git a/test/double_bundle_error.js b/test/double_bundle_error.js new file mode 100644 index 000000000..02ff015e7 --- /dev/null +++ b/test/double_bundle_error.js @@ -0,0 +1,17 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; + +test('double bundle error', function (t) { + t.plan(2); + + var b = browserify(__dirname + '/double_bundle_error/main.js'); + var x = b.bundle(); + x.on('error', function (err) { + t.ok(err); + var y = b.bundle(); + y.on('error', function (err) { + t.ok(err); + }); + }); +}); diff --git a/test/double_bundle_error/main.js b/test/double_bundle_error/main.js new file mode 100644 index 000000000..89bb8a036 --- /dev/null +++ b/test/double_bundle_error/main.js @@ -0,0 +1 @@ +done(require('./one'), require('./two')); \ No newline at end of file diff --git a/test/double_bundle_error/needs_three.js b/test/double_bundle_error/needs_three.js new file mode 100644 index 000000000..9def415e6 --- /dev/null +++ b/test/double_bundle_error/needs_three.js @@ -0,0 +1 @@ +require("three"); diff --git a/test/double_bundle_error/one.js b/test/double_bundle_error/one.js new file mode 100644 index 000000000..bd816eaba --- /dev/null +++ b/test/double_bundle_error/one.js @@ -0,0 +1 @@ +module.exports = 1; diff --git a/test/double_bundle_error/package.json b/test/double_bundle_error/package.json new file mode 100644 index 000000000..ad2f40384 --- /dev/null +++ b/test/double_bundle_error/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "three": "./three.js" + } +} diff --git a/test/double_bundle_error/three.js b/test/double_bundle_error/three.js new file mode 100644 index 000000000..b15da2728 --- /dev/null +++ b/test/double_bundle_error/three.js @@ -0,0 +1,3 @@ +require('./nosuchfile.js'); + +module.exports = 3; diff --git a/test/double_bundle_error/two.js b/test/double_bundle_error/two.js new file mode 100644 index 000000000..72461a5d3 --- /dev/null +++ b/test/double_bundle_error/two.js @@ -0,0 +1 @@ +module.exports = require('./three.js') - 1; diff --git a/test/double_bundle_json.js b/test/double_bundle_json.js new file mode 100644 index 000000000..ac72709b7 --- /dev/null +++ b/test/double_bundle_json.js @@ -0,0 +1,37 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; +var through = require('through2'); +var xtend = require('xtend'); + +test('double bundle json', function (t) { + t.plan(6); + var expected0 = [ 'a=500', 'b=500' ]; + var expected1 = [ 'a=500', 'b=500' ]; + + function log0 (msg) { t.equal(msg, expected0.shift()) } + function log1 (msg) { t.equal(msg, expected1.shift()) } + + var cache = {}; + var b = browserify(__dirname + '/double_bundle_json/index.js', { + cache: cache + }); + b.pipeline.get('deps').push(through.obj(function(row, enc, next) { + cache[row.file] = { + source: row.source, + deps: xtend(row.deps) + }; + this.push(row); + next(); + })); + b.bundle(function (err, src0) { + t.ifError(err); + vm.runInNewContext(src0, { console: { log: log0 } }); + delete cache[__dirname + '/double_bundle_json/index.js']; + + b.bundle(function (err, src1) { + t.ifError(err); + vm.runInNewContext(src1, { console: { log: log1 } }); + }); + }); +}); diff --git a/test/double_bundle_json/a.json b/test/double_bundle_json/a.json new file mode 100644 index 000000000..bf0cf63b8 --- /dev/null +++ b/test/double_bundle_json/a.json @@ -0,0 +1 @@ +{"x":500} diff --git a/test/double_bundle_json/b.json b/test/double_bundle_json/b.json new file mode 100644 index 000000000..bf0cf63b8 --- /dev/null +++ b/test/double_bundle_json/b.json @@ -0,0 +1 @@ +{"x":500} diff --git a/test/double_bundle_json/index.js b/test/double_bundle_json/index.js new file mode 100644 index 000000000..fd8f6820d --- /dev/null +++ b/test/double_bundle_json/index.js @@ -0,0 +1,5 @@ +var a = require('./a.json'); +var b = require('./b.json'); + +console.log('a=' + a.x); +console.log('b=' + b.x); diff --git a/test/entry.js b/test/entry.js index f9b37d06c..34d91e9f6 100644 --- a/test/entry.js +++ b/test/entry.js @@ -3,9 +3,32 @@ var vm = require('vm'); var test = require('tap').test; test('entry', function (t) { - t.plan(2); + t.plan(3); var b = browserify(__dirname + '/entry/main.js'); + b.on('dep', function(row) { + if (row.entry) t.equal(row.file, __dirname + '/entry/main.js'); + }); + b.bundle(function (err, src) { + var c = { + done : function (one, two) { + t.equal(one, 1); + t.equal(two, 2); + t.end(); + } + }; + vm.runInNewContext(src, c); + }); +}); + +test('entry via add', function (t) { + t.plan(3); + + var b = browserify(); + b.add(__dirname + '/entry/main.js'); + b.on('dep', function(row) { + if (row.entry) t.equal(row.file, __dirname + '/entry/main.js'); + }); b.bundle(function (err, src) { var c = { done : function (one, two) { diff --git a/test/entry/needs_three.js b/test/entry/needs_three.js new file mode 100644 index 000000000..9def415e6 --- /dev/null +++ b/test/entry/needs_three.js @@ -0,0 +1 @@ +require("three"); diff --git a/test/entry/package.json b/test/entry/package.json new file mode 100644 index 000000000..ad2f40384 --- /dev/null +++ b/test/entry/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "three": "./three.js" + } +} diff --git a/test/entry/three.js b/test/entry/three.js new file mode 100644 index 000000000..690aad34a --- /dev/null +++ b/test/entry/three.js @@ -0,0 +1 @@ +module.exports = 3; diff --git a/test/entry_expose.js b/test/entry_expose.js new file mode 100644 index 000000000..2323c2cb9 --- /dev/null +++ b/test/entry_expose.js @@ -0,0 +1,19 @@ +var test = require('tap').test; +var browserify = require('../'); +var path = require('path'); +var vm = require('vm'); + +test('entry expose', function (t) { + t.plan(3) + + var b = browserify(); + b.add(__dirname + '/entry_expose/main.js'); + b.require(__dirname + '/entry_expose/main.js', { expose: 'x' }); + b.bundle(function (err, src) { + t.ifError(err); + var c = { console: { log: log } }; + function log (msg) { t.equal(msg, 'wow') } + vm.runInNewContext(src, c); + t.equal(c.require('x'), 555); + }) +}); diff --git a/test/entry_expose/main.js b/test/entry_expose/main.js new file mode 100644 index 000000000..bf2b2d6fe --- /dev/null +++ b/test/entry_expose/main.js @@ -0,0 +1,2 @@ +console.log('wow'); +module.exports = 555; diff --git a/test/entry_relative.js b/test/entry_relative.js new file mode 100644 index 000000000..f1ae37f2c --- /dev/null +++ b/test/entry_relative.js @@ -0,0 +1,44 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; + +test('entry - relative path', function (t) { + process.chdir(__dirname); + + t.plan(3); + + var b = browserify('entry/main.js'); + b.on('dep', function(row) { + if (row.entry) t.equal(row.file, __dirname + '/entry/main.js'); + }); + b.bundle(function (err, src) { + var c = { + done : function (one, two) { + t.equal(one, 1); + t.equal(two, 2); + t.end(); + } + }; + vm.runInNewContext(src, c); + }); +}); + +test('entry - relative path via add', function (t) { + t.plan(3); + + var b = browserify({basedir: __dirname}); + b.add('entry/main.js'); + b.on('dep', function(row) { + if (row.entry) t.equal(row.file, __dirname + '/entry/main.js'); + }); + b.bundle(function (err, src) { + var c = { + done : function (one, two) { + t.equal(one, 1); + t.equal(two, 2); + t.end(); + } + }; + vm.runInNewContext(src, c); + }); +}); diff --git a/test/exclude.js b/test/exclude.js new file mode 100644 index 000000000..382967737 --- /dev/null +++ b/test/exclude.js @@ -0,0 +1,21 @@ +var browserify = require('../'); +var test = require('tap').test; +var vm = require('vm'); + +test('exclude array', function(t) { + t.plan(2); + + var b = browserify(); + b.add(__dirname + '/exclude/array.js'); + b.exclude([ + __dirname + '/exclude/skip.js', + __dirname + '/exclude/skip2.js' + ]); + + b.bundle(function (err, src) { + if (err) { + t.fail(err); + } + vm.runInNewContext(src, { t: t }); + }); +}); diff --git a/test/exclude/array.js b/test/exclude/array.js new file mode 100644 index 000000000..de417c40e --- /dev/null +++ b/test/exclude/array.js @@ -0,0 +1,2 @@ +t.throws(function () { require('./skip.js') }); +t.throws(function () { require('./skip2.js') }); diff --git a/test/exclude/skip.js b/test/exclude/skip.js new file mode 100644 index 000000000..006521e56 --- /dev/null +++ b/test/exclude/skip.js @@ -0,0 +1 @@ +t.fail('this file should have been skipped'); diff --git a/test/exclude/skip2.js b/test/exclude/skip2.js new file mode 100644 index 000000000..006521e56 --- /dev/null +++ b/test/exclude/skip2.js @@ -0,0 +1 @@ +t.fail('this file should have been skipped'); diff --git a/test/external_shim.js b/test/external_shim.js new file mode 100644 index 000000000..63739c00a --- /dev/null +++ b/test/external_shim.js @@ -0,0 +1,27 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; + +test('requiring a shimmed module name from an external bundle', function (t) { + var b1 = browserify(); + var b2 = browserify(); + + b1.require(__dirname + '/external_shim/bundle1.js', { expose: 'bundle1' }); + b2.external(b1); + b2.require(__dirname + '/external_shim/bundle2.js', { expose: 'bundle2' }); + + b1.bundle(function (err, src1) { + b2.bundle(function (err, src2) { + t.plan(1); + + var c = { + console: console, + setTimeout: setTimeout, + clearTimeout: clearTimeout + }; + vm.runInNewContext(src1 + src2, c); + + t.ok(c.require('bundle1').shim === c.require('bundle2').shim); + }); + }); +}); diff --git a/test/external_shim/bundle1.js b/test/external_shim/bundle1.js new file mode 100644 index 000000000..4753f09b7 --- /dev/null +++ b/test/external_shim/bundle1.js @@ -0,0 +1 @@ +exports.shim = require('shim'); diff --git a/test/external_shim/bundle2.js b/test/external_shim/bundle2.js new file mode 100644 index 000000000..4753f09b7 --- /dev/null +++ b/test/external_shim/bundle2.js @@ -0,0 +1 @@ +exports.shim = require('shim'); diff --git a/test/external_shim/package.json b/test/external_shim/package.json new file mode 100644 index 000000000..2047ac699 --- /dev/null +++ b/test/external_shim/package.json @@ -0,0 +1,5 @@ +{ + "browser": { + "shim": "./shim.js" + } +} \ No newline at end of file diff --git a/lib/_exclude.js b/test/external_shim/shim.js similarity index 100% rename from lib/_exclude.js rename to test/external_shim/shim.js diff --git a/test/externalize.js b/test/externalize.js index a78a699ec..8d76055bb 100644 --- a/test/externalize.js +++ b/test/externalize.js @@ -2,17 +2,15 @@ var test = require('tap').test; var spawn = require('child_process').spawn; var concat = require('concat-stream'); var path = require('path'); -var mkdirp = require('mkdirp'); var fs = require('fs'); var vm = require('vm'); -var tmpdir = path.join( - require('osenv').tmpdir(), - 'browserify-test-' + Math.random() -); +var temp = require('temp'); +temp.track(); +var tmpdir = temp.mkdirSync({prefix: 'browserify-test'}); var pubdir = path.join(tmpdir, 'public'); -mkdirp.sync(pubdir); +fs.mkdirSync(pubdir); fs.writeFileSync( path.join(tmpdir, 'robot.js'), fs.readFileSync(path.join(__dirname, 'externalize/robot.js')) diff --git a/test/file_event.js b/test/file_event.js index bb7c1a99e..285ccafa6 100644 --- a/test/file_event.js +++ b/test/file_event.js @@ -15,7 +15,7 @@ test('file event', function (t) { b.on('file', function (file, id) { var key = path.basename(file); - t.equal(file, __dirname + '/entry/' + key); + t.equal(file, path.join(__dirname, 'entry', key)); t.equal(id, files[key]); delete files[key]; }); diff --git a/test/full_paths.js b/test/full_paths.js index 4f04035e2..11431beb2 100644 --- a/test/full_paths.js +++ b/test/full_paths.js @@ -1,11 +1,13 @@ var unpack = require('browser-unpack'); var browserify = require('../'); var test = require('tap').test; +var vm = require('vm'); +var path = require('path'); var deps = [ - __dirname + '/entry/main.js', - __dirname + '/entry/one.js', - __dirname + '/entry/two.js' + path.join(__dirname, '/entry/main.js'), + path.join(__dirname, '/entry/one.js'), + path.join(__dirname, '/entry/two.js') ]; test('fullPaths enabled', function (t) { @@ -37,3 +39,20 @@ test('fullPaths disabled', function (t) { }); }); }); + +test('fullPaths enabled, with custom exposed dependency name', function (t) { + t.plan(1); + + var b = browserify({ + entries: [__dirname + '/entry/needs_three.js'], + fullPaths: true + }); + + b.require(__dirname + '/entry/three.js', { expose: 'three' }); + + b.bundle(function (err, src) { + t.doesNotThrow(function () { + vm.runInNewContext(src, { console: console, t: t }); + }); + }); +}); diff --git a/test/global.js b/test/global.js index 954c0c371..3d55c67cd 100644 --- a/test/global.js +++ b/test/global.js @@ -26,7 +26,7 @@ test('__filename and __dirname with insertGlobals: true', function (t) { }); b.require(__dirname + '/global/filename.js', { expose: 'x' }); b.bundle(function (err, src) { - var c = {}; + var c = { Uint8Array: Uint8Array }; c.self = c; vm.runInNewContext(src, c); var x = c.require('x'); @@ -69,7 +69,7 @@ test('process.nextTick', function (t) { var b = browserify(); b.add(__dirname + '/global/tick.js'); b.bundle(function (err, src) { - var c = { t: t, setTimeout: setTimeout }; + var c = { t: t, setTimeout: setTimeout, clearTimeout: clearTimeout }; vm.runInNewContext(src, c); }); }); @@ -83,7 +83,7 @@ test('Buffer', function (t) { var c = { t: t, Uint8Array: Uint8Array, - DataView: DataView + ArrayBuffer: ArrayBuffer }; vm.runInNewContext(src, c); }); diff --git a/test/global/node_modules/aaa/index.js b/test/global/node_modules/aaa/index.js new file mode 100644 index 000000000..85dc112bf --- /dev/null +++ b/test/global/node_modules/aaa/index.js @@ -0,0 +1,2 @@ +exports.filename = __filename; +exports.dirname = __dirname; diff --git a/test/global/node_modules/robot/index.js b/test/global/node_modules/robot/index.js new file mode 100644 index 000000000..dc8377968 --- /dev/null +++ b/test/global/node_modules/robot/index.js @@ -0,0 +1 @@ +module.exports = require('./lib/beep'); diff --git a/test/global/node_modules/robot/lib/beep.js b/test/global/node_modules/robot/lib/beep.js new file mode 100644 index 000000000..85dc112bf --- /dev/null +++ b/test/global/node_modules/robot/lib/beep.js @@ -0,0 +1,2 @@ +exports.filename = __filename; +exports.dirname = __dirname; diff --git a/test/global_coffeeify.js b/test/global_coffeeify.js index 47e6da41d..00aa54a1d 100644 --- a/test/global_coffeeify.js +++ b/test/global_coffeeify.js @@ -11,7 +11,8 @@ test('coffeeify globally', function (t) { if (err) t.fail(err); vm.runInNewContext(src, { console: { log: log }, - setTimeout: setTimeout + setTimeout: setTimeout, + clearTimeout: clearTimeout }); function log (msg) { t.equal(msg, 'eyo') } }); diff --git a/test/global_noparse.js b/test/global_noparse.js new file mode 100644 index 000000000..decd772da --- /dev/null +++ b/test/global_noparse.js @@ -0,0 +1,101 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; + +test('global noparse module', function (t) { + t.plan(2); + + var b = browserify({ + noParse: 'aaa' + }); + b.require(__dirname + '/global/node_modules/aaa', { expose: 'x' }); + b.bundle(function (err, src) { + var c = { + __filename: __filename, + __dirname: __dirname + }; + vm.runInNewContext(src, c); + var x = c.require('x'); + t.equal(x.filename, __filename); + t.equal(x.dirname, __dirname); + }); +}); + +test('global noparse module file', function (t) { + t.plan(2); + + var b = browserify({ + noParse: 'aaa/index.js' + }); + b.require(__dirname + '/global/node_modules/aaa', { expose: 'x' }); + b.bundle(function (err, src) { + var c = { + __filename: __filename, + __dirname: __dirname + }; + vm.runInNewContext(src, c); + var x = c.require('x'); + t.equal(x.filename, __filename); + t.equal(x.dirname, __dirname); + }); +}); + +test('global noparse module deep file', function (t) { + t.plan(2); + + var b = browserify({ + noParse: 'robot/lib/beep.js' + }); + b.require(__dirname + '/global/node_modules/robot', { expose: 'x' }); + b.bundle(function (err, src) { + var c = { + __filename: __filename, + __dirname: __dirname + }; + vm.runInNewContext(src, c); + var x = c.require('x'); + t.equal(x.filename, __filename); + t.equal(x.dirname, __dirname); + }); +}); + +test('global noparse basedir', function (t) { + t.plan(2); + + var b = browserify({ + basedir: __dirname + '/global', + noParse: 'filename.js' + }); + b.require(__dirname + '/global/filename.js', { expose: 'x' }); + b.bundle(function (err, src) { + var c = { + __filename: __filename, + __dirname: __dirname + }; + vm.runInNewContext(src, c); + var x = c.require('x'); + t.equal(x.filename, __filename); + t.equal(x.dirname, __dirname); + }); +}); + +test('global noparse function', function (t) { + t.plan(2); + + var b = browserify({ + noParse: function(file) { + return file === __dirname + '/global/filename.js'; + } + }); + b.require(__dirname + '/global/filename.js', { expose: 'x' }); + b.bundle(function (err, src) { + var c = { + __filename: __filename, + __dirname: __dirname + }; + vm.runInNewContext(src, c); + var x = c.require('x'); + t.equal(x.filename, __filename); + t.equal(x.dirname, __dirname); + }); +}); diff --git a/test/global_recorder.js b/test/global_recorder.js new file mode 100644 index 000000000..7fdc07fb3 --- /dev/null +++ b/test/global_recorder.js @@ -0,0 +1,22 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; + +test('recorded global tr', function (t) { + t.plan(6); + + var b = browserify(__dirname + '/global_recorder/main.js'); + var context = { + console: { log: function (msg) { t.equal(msg, 'wow') } } + }; + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, context); + t.equal(b._recorded.length, 2); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, context); + t.equal(b._recorded.length, 2); + }); + }); +}); diff --git a/test/global_recorder/main.js b/test/global_recorder/main.js new file mode 100644 index 000000000..6036bec63 --- /dev/null +++ b/test/global_recorder/main.js @@ -0,0 +1 @@ +console.log('wow'); diff --git a/test/hash_instance.js b/test/hash_instance.js deleted file mode 100644 index 6b3adbf3e..000000000 --- a/test/hash_instance.js +++ /dev/null @@ -1,15 +0,0 @@ -var browserify = require('../'); -var vm = require('vm'); -var test = require('tap').test; - -test('hash instances', function (t) { - t.plan(6); - - var b = browserify(__dirname + '/hash_instance/main.js'); - b.bundle(function (err, buf) { - var c = { t: t }; - var src = buf.toString('utf8'); - t.equal(src.match(RegExp('// abcdefg', 'g')).length, 1); - vm.runInNewContext(src, c); - }); -}); diff --git a/test/hash_instance/foo/two.js b/test/hash_instance/foo/two.js deleted file mode 100644 index 9fee06365..000000000 --- a/test/hash_instance/foo/two.js +++ /dev/null @@ -1,3 +0,0 @@ -// abcdefg -module.exports = Foo; -function Foo () {} diff --git a/test/hash_instance/main.js b/test/hash_instance/main.js deleted file mode 100644 index a77abb25b..000000000 --- a/test/hash_instance/main.js +++ /dev/null @@ -1,11 +0,0 @@ -var Foo1 = require('./one.js'); -var Foo2 = require('./foo/two.js'); - -var f1 = new Foo1; -var f2 = new Foo2; - -t.equal(Foo1, Foo2); -t.ok(f1 instanceof Foo1); -t.ok(f1 instanceof Foo2); -t.ok(f2 instanceof Foo1); -t.ok(f2 instanceof Foo2); diff --git a/test/hash_instance/one.js b/test/hash_instance/one.js deleted file mode 100644 index 9fee06365..000000000 --- a/test/hash_instance/one.js +++ /dev/null @@ -1,3 +0,0 @@ -// abcdefg -module.exports = Foo; -function Foo () {} diff --git a/test/hash_instance_context/main.js b/test/hash_instance_context/main.js index 3c4d3d6f4..db1e23e97 100644 --- a/test/hash_instance_context/main.js +++ b/test/hash_instance_context/main.js @@ -12,6 +12,6 @@ t.equal(D(), 333); var E = require('./three/f.js'); var F = require('./three/dir/f.js'); -t.equal(E, F); +t.notEqual(E, F); t.equal(E(), 555); t.equal(F(), 555); diff --git a/test/identical.js b/test/identical.js new file mode 100644 index 000000000..7d0deaeb9 --- /dev/null +++ b/test/identical.js @@ -0,0 +1,19 @@ +var browserify = require('../'); +var test = require('tap').test; +var vm = require('vm'); + +test('identical', function (t) { + var expected = [ 0, 1, 0, 1 ]; + t.plan(expected.length + 1); + + var b = browserify(__dirname + '/identical/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src.toString('utf8'), { + console: { log: log } + }); + function log (msg) { + t.equal(msg, expected.shift()); + } + }); +}); diff --git a/test/identical/main.js b/test/identical/main.js new file mode 100644 index 000000000..c2e83ed20 --- /dev/null +++ b/test/identical/main.js @@ -0,0 +1,6 @@ +var x = require('./x'); +var y = require('./y'); +console.log(x()); +console.log(x()); +console.log(y()); +console.log(y()); diff --git a/test/identical/x.js b/test/identical/x.js new file mode 100644 index 000000000..13c441d79 --- /dev/null +++ b/test/identical/x.js @@ -0,0 +1,2 @@ +var i = 0; +module.exports = function () { return i++ }; diff --git a/test/identical/y.js b/test/identical/y.js new file mode 100644 index 000000000..13c441d79 --- /dev/null +++ b/test/identical/y.js @@ -0,0 +1,2 @@ +var i = 0; +module.exports = function () { return i++ }; diff --git a/test/identical_different.js b/test/identical_different.js new file mode 100644 index 000000000..a2e7911d3 --- /dev/null +++ b/test/identical_different.js @@ -0,0 +1,19 @@ +var browserify = require('../'); +var test = require('tap').test; +var vm = require('vm'); + +test('identical', function (t) { + var expected = [ 1, 2, 10, 110 ]; + t.plan(expected.length + 1); + + var b = browserify(__dirname + '/identical_different/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src.toString('utf8'), { + console: { log: log } + }); + function log (msg) { + t.equal(msg, expected.shift()); + } + }); +}); diff --git a/test/identical_different/main.js b/test/identical_different/main.js new file mode 100644 index 000000000..5a4154b1d --- /dev/null +++ b/test/identical_different/main.js @@ -0,0 +1,6 @@ +var x = require('./x'); +var y = require('./wow/y'); +console.log(x()); +console.log(x()); +console.log(y()); +console.log(y()); diff --git a/test/identical_different/node_modules/op/index.js b/test/identical_different/node_modules/op/index.js new file mode 100644 index 000000000..7014688aa --- /dev/null +++ b/test/identical_different/node_modules/op/index.js @@ -0,0 +1,3 @@ +module.exports = function (n) { + return n + 1; +}; diff --git a/test/identical_different/wow/node_modules/op/index.js b/test/identical_different/wow/node_modules/op/index.js new file mode 100644 index 000000000..e08a1ce12 --- /dev/null +++ b/test/identical_different/wow/node_modules/op/index.js @@ -0,0 +1,3 @@ +module.exports = function (n) { + return (n+1) * 10; +}; diff --git a/test/identical_different/wow/y.js b/test/identical_different/wow/y.js new file mode 100644 index 000000000..0b8636f5c --- /dev/null +++ b/test/identical_different/wow/y.js @@ -0,0 +1,3 @@ +var op = require('op'); +var i = 0; +module.exports = function () { i = op(i); return i }; diff --git a/test/identical_different/x.js b/test/identical_different/x.js new file mode 100644 index 000000000..0b8636f5c --- /dev/null +++ b/test/identical_different/x.js @@ -0,0 +1,3 @@ +var op = require('op'); +var i = 0; +module.exports = function () { i = op(i); return i }; diff --git a/test/ignore.js b/test/ignore.js index e4ad9775b..fe19a2e00 100644 --- a/test/ignore.js +++ b/test/ignore.js @@ -4,20 +4,38 @@ var vm = require('vm'); test('ignore', function (t) { t.plan(1); - + var b = browserify(); b.add(__dirname + '/ignore/main.js'); b.ignore( __dirname + '/ignore/skip.js'); - + b.bundle(function (err, src) { if (err) t.fail(err); vm.runInNewContext(src, { t: t }); }); }); +test('ignore array', function(t) { + t.plan(2); + + var b = browserify(); + b.add(__dirname + '/ignore/array.js'); + b.ignore([ + __dirname + '/ignore/skip.js', + __dirname + '/ignore/skip2.js' + ]); + + b.bundle(function (err, src) { + if (err) { + t.fail(err); + } + vm.runInNewContext(src, { t: t }); + }); +}); + test('ignore by package or id', function (t) { t.plan(3); - + var b = browserify(); b.add(__dirname + '/ignore/by-id.js'); b.ignore('events'); diff --git a/test/ignore/array.js b/test/ignore/array.js new file mode 100644 index 000000000..837e179b5 --- /dev/null +++ b/test/ignore/array.js @@ -0,0 +1,2 @@ +t.deepEqual(require('./skip.js'), {}); +t.deepEqual(require('./skip2.js'), {}); diff --git a/test/ignore/skip2.js b/test/ignore/skip2.js new file mode 100644 index 000000000..006521e56 --- /dev/null +++ b/test/ignore/skip2.js @@ -0,0 +1 @@ +t.fail('this file should have been skipped'); diff --git a/test/ignore_browser_field.js b/test/ignore_browser_field.js new file mode 100644 index 000000000..a925f2e62 --- /dev/null +++ b/test/ignore_browser_field.js @@ -0,0 +1,21 @@ +var test = require('tap').test; +var browserify = require('../'); +var path = require('path'); +var mainfile = path.join(__dirname, 'ignore_browser_field/main.js'); +var vm = require('vm'); + +test('ignore browser field', function (t) { + t.plan(3); + var b = browserify(mainfile, { browserField: false }); + var expected = [ 'A:NODE', 'B:X.JS' ]; + + b.bundle(function (err, src) { + t.ifError(err); + var c = { console: { log: log } }; + vm.runInNewContext(src, c); + + function log (msg) { + t.equal(msg, expected.shift()); + } + }); +}); diff --git a/test/ignore_browser_field/main.js b/test/ignore_browser_field/main.js new file mode 100644 index 000000000..bae4a2290 --- /dev/null +++ b/test/ignore_browser_field/main.js @@ -0,0 +1,2 @@ +console.log(require('a')); +console.log(require('b')); diff --git a/test/ignore_browser_field/node_modules/a/browser.js b/test/ignore_browser_field/node_modules/a/browser.js new file mode 100644 index 000000000..229aa83cb --- /dev/null +++ b/test/ignore_browser_field/node_modules/a/browser.js @@ -0,0 +1 @@ +module.exports = 'A:BROWSER' diff --git a/test/ignore_browser_field/node_modules/a/main.js b/test/ignore_browser_field/node_modules/a/main.js new file mode 100644 index 000000000..1f95fc3c3 --- /dev/null +++ b/test/ignore_browser_field/node_modules/a/main.js @@ -0,0 +1 @@ +module.exports = 'A:NODE' diff --git a/test/ignore_browser_field/node_modules/a/package.json b/test/ignore_browser_field/node_modules/a/package.json new file mode 100644 index 000000000..d7572b6f9 --- /dev/null +++ b/test/ignore_browser_field/node_modules/a/package.json @@ -0,0 +1,6 @@ +{ + "name": "a", + "version": "1.0.0", + "main": "main.js", + "browser": "browser.js" +} diff --git a/test/ignore_browser_field/node_modules/b/browser-x.js b/test/ignore_browser_field/node_modules/b/browser-x.js new file mode 100644 index 000000000..aca586288 --- /dev/null +++ b/test/ignore_browser_field/node_modules/b/browser-x.js @@ -0,0 +1 @@ +module.exports = 'browser-x.js' diff --git a/test/ignore_browser_field/node_modules/b/main.js b/test/ignore_browser_field/node_modules/b/main.js new file mode 100644 index 000000000..5b7a8817b --- /dev/null +++ b/test/ignore_browser_field/node_modules/b/main.js @@ -0,0 +1 @@ +module.exports = ('b:' + require('./x.js')).toUpperCase(); diff --git a/test/ignore_browser_field/node_modules/b/package.json b/test/ignore_browser_field/node_modules/b/package.json new file mode 100644 index 000000000..021d8bb38 --- /dev/null +++ b/test/ignore_browser_field/node_modules/b/package.json @@ -0,0 +1,8 @@ +{ + "name": "b", + "version": "1.0.0", + "main": "main.js", + "browser": { + "./x.js": "./browser-x.js" + } +} diff --git a/test/ignore_browser_field/node_modules/b/x.js b/test/ignore_browser_field/node_modules/b/x.js new file mode 100644 index 000000000..43396403b --- /dev/null +++ b/test/ignore_browser_field/node_modules/b/x.js @@ -0,0 +1 @@ +module.exports = 'x.js'; diff --git a/test/ignore_missing.js b/test/ignore_missing.js index e7410cb28..ddf72ed20 100644 --- a/test/ignore_missing.js +++ b/test/ignore_missing.js @@ -3,6 +3,8 @@ var test = require('tap').test; test('ignoreMissing option', function (t) { t.test('on browserify', function(t) { + t.plan(1); + var ignored = browserify({ entries: [__dirname + '/ignore_missing/main.js'], ignoreMissing: true @@ -10,27 +12,30 @@ test('ignoreMissing option', function (t) { ignored.bundle(function(err) { t.ok(!err, "bundle completed with missing file ignored"); - t.end() }); }); t.test('on .bundle', function(t) { + t.plan(1); + var ignored = browserify(__dirname + '/ignore_missing/main.js', { ignoreMissing: true }); ignored.bundle(function(err) { t.ok(!err, "bundle completed with missing file ignored"); - t.end(); }); }); - test('defaults to false', function (t) { + t.test('defaults to false', function (t) { + t.plan(1); + var expected = browserify(__dirname + '/ignore_missing/main.js'); expected.bundle(function(err) { t.ok(err, 'ignoreMissing was false, an error was raised'); - t.end(); }); }); + + t.end(); }); diff --git a/test/ignore_transform_key.js b/test/ignore_transform_key.js new file mode 100644 index 000000000..253f64051 --- /dev/null +++ b/test/ignore_transform_key.js @@ -0,0 +1,17 @@ +var browserify = require('../'); +var test = require('tap').test; +var vm = require('vm'); + +test('ignore transform', function(t) { + t.plan(1); + + var b = browserify({ + transformKey: false + }); + b.add(__dirname + '/ignore_transform_key/main.js'); + + b.bundle(function(err, src) { + if (err) t.fail(err); + vm.runInNewContext(src, {t: t}); + }); +}); diff --git a/test/ignore_transform_key/main.js b/test/ignore_transform_key/main.js new file mode 100644 index 000000000..97be0ea7c --- /dev/null +++ b/test/ignore_transform_key/main.js @@ -0,0 +1,3 @@ +var a = require('a'); + +t.equal(a, 'good'); diff --git a/test/ignore_transform_key/node_modules/a/index.js b/test/ignore_transform_key/node_modules/a/index.js new file mode 100644 index 000000000..1f9bee291 --- /dev/null +++ b/test/ignore_transform_key/node_modules/a/index.js @@ -0,0 +1 @@ +module.exports = 'good'; diff --git a/test/ignore_transform_key/node_modules/a/package.json b/test/ignore_transform_key/node_modules/a/package.json new file mode 100644 index 000000000..7d9c4b3d5 --- /dev/null +++ b/test/ignore_transform_key/node_modules/a/package.json @@ -0,0 +1,10 @@ +{ + "name": "a", + "version": "1.0.0", + "private": true, + "browserify": { + "transform": [ + "evil-transform" + ] + } +} diff --git a/test/ignore_transform_key/node_modules/evil-transform/index.js b/test/ignore_transform_key/node_modules/evil-transform/index.js new file mode 100644 index 000000000..a4dd44451 --- /dev/null +++ b/test/ignore_transform_key/node_modules/evil-transform/index.js @@ -0,0 +1,12 @@ +const through2 = require('through2'); + +module.exports = function() { + + return through2.obj(function(row, enc, next) { + return next(); + }, + function(next) { + next(null, "module.exports = 'evil';"); + } + ) +}; diff --git a/test/ignore_transform_key/node_modules/evil-transform/package.json b/test/ignore_transform_key/node_modules/evil-transform/package.json new file mode 100644 index 000000000..81ca8df1a --- /dev/null +++ b/test/ignore_transform_key/node_modules/evil-transform/package.json @@ -0,0 +1,5 @@ +{ + "name": "evil-transform", + "version": "1.0.0", + "private": true +} diff --git a/test/json.js b/test/json.js index 33dbbecfb..ffa5333f4 100644 --- a/test/json.js +++ b/test/json.js @@ -1,4 +1,5 @@ var browserify = require('../'); +var fs = require('fs'); var vm = require('vm'); var test = require('tap').test; @@ -16,3 +17,28 @@ test('json', function (t) { vm.runInNewContext(src, c); }); }); + +test('verify evil json', function(t) { + t.plan(1); + fs.readFile(__dirname + '/json/evil-chars.json', function(err, data) { + if (err) t.fail(err); + t.throws(function() { + vm.runInNewContext('(' + data.toString() + ')'); + }); + }); +}); + +test('evil json', function (t) { + t.plan(2); + var b = browserify(); + b.add(__dirname + '/json/evil.js'); + b.bundle(function (err, src) { + if (err) t.fail(err); + var c = { + ex : function (obj) { + t.same(obj, { evil : '\u2028\u2029' }); + } + }; + vm.runInNewContext(src, c); + }); +}); diff --git a/test/json/evil-chars.json b/test/json/evil-chars.json new file mode 100644 index 000000000..4a5851bb6 --- /dev/null +++ b/test/json/evil-chars.json @@ -0,0 +1,3 @@ +{ + "evil": "

" +} diff --git a/test/json/evil.js b/test/json/evil.js new file mode 100644 index 000000000..767e9cb27 --- /dev/null +++ b/test/json/evil.js @@ -0,0 +1,2 @@ +ex(require('./evil-chars.json')); +ex(require('./evil-chars')); diff --git a/test/leak.js b/test/leak.js index 2e2fa8d21..21efc659a 100644 --- a/test/leak.js +++ b/test/leak.js @@ -30,7 +30,11 @@ test('leaking information about system paths (process)', function (t) { t.equal(src.indexOf(dirstring), -1, 'temp directory visible'); t.equal(src.indexOf(process.cwd()), -1, 'cwd directory visible'); t.equal(src.indexOf('/home'), -1, 'home directory visible'); - vm.runInNewContext(src, { t: t, setTimeout: setTimeout }); + vm.runInNewContext(src, { + t: t, + setTimeout: setTimeout, + clearTimeout: clearTimeout + }); }); }); @@ -48,6 +52,6 @@ test('leaking information about system paths (Buffer)', function (t) { t.equal(src.indexOf(dirstring), -1, 'temp directory visible'); t.equal(src.indexOf(process.cwd()), -1, 'cwd directory visible'); t.equal(src.indexOf('/home'), -1, 'home directory visible'); - vm.runInNewContext(src, { t: t, setTimeout: setTimeout }); + vm.runInNewContext(src, { t: t, setTimeout: setTimeout, Uint8Array: Uint8Array, ArrayBuffer: ArrayBuffer }); }); }); diff --git a/test/multi_entry.js b/test/multi_entry.js index 3b5812cf3..f910eddc2 100644 --- a/test/multi_entry.js +++ b/test/multi_entry.js @@ -10,14 +10,48 @@ var testFiles = [ ]; test('multi entry', function (t) { - t.plan(3); + t.plan(6); var b = browserify([ testFiles[0], testFiles[1] ]); b.add(testFiles[2]); + + b.on('dep', function(row) { + if (row.entry) { + t.ok(testFiles.indexOf(row.file) > -1, 'should contain full entry path'); + } + }); + + b.bundle(function (err, src) { + var c = { + times : 0, + t : t + }; + vm.runInNewContext(src, c); + }); +}); +test('multi entry relative', function (t) { + t.plan(6); + + var rTestFiles = testFiles.map(function(x) { + return x.replace(__dirname + '/', ''); + }); + + var b = browserify({ + entries: [rTestFiles[0], rTestFiles[1]], + basedir: __dirname + }); + b.add(rTestFiles[2]); + + b.on('dep', function(row) { + if (row.entry) { + t.ok(testFiles.indexOf(row.file) > -1, 'should contain full entry path'); + } + }); + b.bundle(function (err, src) { var c = { times : 0, @@ -27,22 +61,55 @@ test('multi entry', function (t) { }); }); -test('entries as streams', function (t) { - t.plan(3); +test('multi entry relative cwd', function (t) { + t.plan(6); + + var rTestFiles = testFiles.map(function(x) { + return x.replace(__dirname + '/', './'); + }); + + var b = browserify({ + entries: [rTestFiles[0], rTestFiles[1]], + basedir: __dirname + }); + b.add(rTestFiles[2]); + + b.on('dep', function(row) { + if (row.entry) { + t.ok(testFiles.indexOf(row.file) > -1, 'should contain full entry path'); + } + }); - // transform paths to streams - for (var i = 0; i < testFiles.length; i++) { - testFiles[i] = fs.createReadStream(testFiles[i]); - } + b.bundle(function (err, src) { + var c = { + times : 0, + t : t + }; + vm.runInNewContext(src, c); + }); +}); + +test('entries as streams', function (t) { + t.plan(6); // commondir blows up with streams and without basedir var opts = { basedir: __dirname + '/multi_entry' }; var b = browserify([ - testFiles[0], - testFiles[1] + fs.createReadStream(testFiles[0]), + fs.createReadStream(testFiles[1]) ], opts); - b.add(testFiles[2]); + b.add(fs.createReadStream(testFiles[2])); + + b.on('dep', function(row) { + if (row.entry) { + t.similar( + row.file, + RegExp(__dirname + '/multi_entry/_stream_[\\d].js'), + 'should be full entry path' + ); + } + }); b.bundle(function (err, src) { var c = { diff --git a/test/multi_entry_cross_require.js b/test/multi_entry_cross_require.js new file mode 100644 index 000000000..0cc1a8829 --- /dev/null +++ b/test/multi_entry_cross_require.js @@ -0,0 +1,92 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; + +var testFiles = [ + __dirname + '/multi_entry_cross_require/a.js', + __dirname + '/multi_entry_cross_require/lib/b.js', + __dirname + '/multi_entry_cross_require/c.js' +]; + +test('multi entry cross require', function (t) { + t.plan(8); + + var b = browserify([ + testFiles[0], + testFiles[1] + ]); + b.add(testFiles[2]); + + b.on('dep', function(row) { + if (row.entry) { + t.ok(testFiles.indexOf(row.file) > -1, 'should contain full entry path'); + } + }); + + b.bundle(function (err, src) { + if (err) throw err; + var c = { + times : 0, + t : t + }; + vm.runInNewContext(src, c); + }); +}); + +test('multi entry cross require - relative cwd', function (t) { + t.plan(8); + + var dsTestFiles = testFiles.map(function(x) { + return x.replace(__dirname + '/', './'); + }); + + var b = browserify({ + entries: [dsTestFiles[0], dsTestFiles[1]], + basedir: __dirname + }); + b.add(dsTestFiles[2]); + + b.on('dep', function(row) { + if (row.entry) { + t.ok(testFiles.indexOf(row.file) > -1, 'should contain full entry path'); + } + }); + + b.bundle(function (err, src) { + if (err) throw err; + var c = { + times : 0, + t : t + }; + vm.runInNewContext(src, c); + }); +}); + +test('multi entry cross require - relative', function (t) { + t.plan(8); + + var rTestFiles = testFiles.map(function(x) { + return x.replace(__dirname + '/', ''); + }); + + var b = browserify({ + entries: [rTestFiles[0], rTestFiles[1]], + basedir: __dirname + }); + b.add(rTestFiles[2]); + + b.on('dep', function(row) { + if (row.entry) { + t.ok(testFiles.indexOf(row.file) > -1, 'should contain full entry path'); + } + }); + + b.bundle(function (err, src) { + if (err) throw err; + var c = { + times : 0, + t : t + }; + vm.runInNewContext(src, c); + }); +}); diff --git a/test/multi_entry_cross_require/a.js b/test/multi_entry_cross_require/a.js new file mode 100644 index 000000000..0223dafc0 --- /dev/null +++ b/test/multi_entry_cross_require/a.js @@ -0,0 +1,8 @@ +times ++; +t.equal(times, 1); + +var b = require('./lib/b'); +t.equal(times, 2); + +b.foo(); +t.equal(times, 3); diff --git a/test/multi_entry_cross_require/c.js b/test/multi_entry_cross_require/c.js new file mode 100644 index 000000000..e1918384b --- /dev/null +++ b/test/multi_entry_cross_require/c.js @@ -0,0 +1,7 @@ +times++; +t.equal(times, 4); + +var b = require('./lib/b'); +b.foo(); + +t.equal(times, 5); diff --git a/test/multi_entry_cross_require/lib/b.js b/test/multi_entry_cross_require/lib/b.js new file mode 100644 index 000000000..e7d2dad1f --- /dev/null +++ b/test/multi_entry_cross_require/lib/b.js @@ -0,0 +1,5 @@ +times++; + +module.exports.foo = function() { + times++; +}; diff --git a/test/multi_require.js b/test/multi_require.js new file mode 100644 index 000000000..a1b3f64e1 --- /dev/null +++ b/test/multi_require.js @@ -0,0 +1,18 @@ +var browserify = require('../'); +var test = require('tap').test; +var vm = require('vm'); + +test('require same file locally and globally', function (t) { + t.plan(2); + + var b = browserify(__dirname + '/multi_require/main.js', { + basedir: __dirname + }); + b.require('./multi_require/a.js', {expose: 'a'}); + + b.bundle(function (err, src) { + t.ifError(err); + var c = {t: t}; + vm.runInNewContext(src, c); + }); +}); diff --git a/test/multi_require/a.js b/test/multi_require/a.js new file mode 100644 index 000000000..18dea6747 --- /dev/null +++ b/test/multi_require/a.js @@ -0,0 +1,3 @@ +module.exports = function() { + return 'a'; +} diff --git a/test/multi_require/main.js b/test/multi_require/main.js new file mode 100644 index 000000000..6f548ec96 --- /dev/null +++ b/test/multi_require/main.js @@ -0,0 +1,4 @@ +var localA = require('./a.js'); +var globalA = require('a'); + +t.equal(localA, globalA); diff --git a/test/multi_symlink.js b/test/multi_symlink.js new file mode 100644 index 000000000..913c7a3be --- /dev/null +++ b/test/multi_symlink.js @@ -0,0 +1,13 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; + +test('multiple symlink execution', function (t) { + t.plan(1); + var b = browserify(__dirname + '/multi_symlink/main.js'); + b.bundle(function (err, src) { + var c = { console: { log: log } }; + vm.runInNewContext(src, c); + function log (msg) { t.equal(msg, 'X') } + }); +}); diff --git a/test/multi_symlink/main.js b/test/multi_symlink/main.js new file mode 100644 index 000000000..0f904dc91 --- /dev/null +++ b/test/multi_symlink/main.js @@ -0,0 +1,2 @@ +require('./x.js'); +require('./y.js'); diff --git a/test/multi_symlink/x.js b/test/multi_symlink/x.js new file mode 100644 index 000000000..e894542cb --- /dev/null +++ b/test/multi_symlink/x.js @@ -0,0 +1 @@ +console.log('X'); diff --git a/test/multi_symlink/y.js b/test/multi_symlink/y.js new file mode 120000 index 000000000..ca52ee1f4 --- /dev/null +++ b/test/multi_symlink/y.js @@ -0,0 +1 @@ +./x.js \ No newline at end of file diff --git a/test/node_modules/tr/index.js b/test/node_modules/tr/index.js new file mode 100644 index 000000000..b3c484f22 --- /dev/null +++ b/test/node_modules/tr/index.js @@ -0,0 +1,8 @@ +var through = require('through2'); + +module.exports = function () { + return through(function (buf, enc, next) { + this.push(buf.toString('utf8').replace(/X/g, 'Z')); + next(); + }); +}; diff --git a/test/noparse.js b/test/noparse.js new file mode 100644 index 000000000..7d0b3b272 --- /dev/null +++ b/test/noparse.js @@ -0,0 +1,31 @@ +var browserify = require('../'); +var test = require('tap').test; +var path = require('path'); + +test('noParse array', function (t) { + process.chdir(__dirname); + + t.plan(2); + + var actual = []; + var expected = [ + 'noparse/a.js', + 'noparse/b.js', + 'noparse/dir1/1.js', + 'noparse/node_modules/robot/main.js' + ].map(function (x) {return path.resolve(x);}).sort(); + + var b = browserify({ + entries: [ __dirname + '/noparse/a.js' ], + noParse: [ + __dirname + '/noparse/dir1/1.js', + __dirname + '/noparse/node_modules/robot/main.js' + ] + }); + b.on('dep', function(dep) { actual.push(dep.file); }); + b.bundle(function (err, src) { + actual.sort(); + t.ifError(err); + t.deepEqual(actual, expected); + }); +}); diff --git a/test/noparse/a.js b/test/noparse/a.js new file mode 100644 index 000000000..076812a66 --- /dev/null +++ b/test/noparse/a.js @@ -0,0 +1,4 @@ +module.exports = { + a: true, + b: require('./b') +}; diff --git a/test/noparse/b.js b/test/noparse/b.js new file mode 100644 index 000000000..de0ba559a --- /dev/null +++ b/test/noparse/b.js @@ -0,0 +1,5 @@ +module.exports = { + b: true, + 1: require('./dir1/1'), + robot: require('robot') +}; diff --git a/test/noparse/dir1/1.js b/test/noparse/dir1/1.js new file mode 100644 index 000000000..960968b0b --- /dev/null +++ b/test/noparse/dir1/1.js @@ -0,0 +1,4 @@ +module.exports = { + 1: true, + 2: require('./dir2/2') +}; diff --git a/test/noparse/dir1/dir2/2.js b/test/noparse/dir1/dir2/2.js new file mode 100644 index 000000000..ef4ba1962 --- /dev/null +++ b/test/noparse/dir1/dir2/2.js @@ -0,0 +1,3 @@ +module.exports = { + 2: true +}; diff --git a/test/noparse/node_modules/robot/lib/beep.js b/test/noparse/node_modules/robot/lib/beep.js new file mode 100644 index 000000000..6529dd85c --- /dev/null +++ b/test/noparse/node_modules/robot/lib/beep.js @@ -0,0 +1,4 @@ +module.exports = { + beep: true, + boop: require('./boop') +}; diff --git a/test/noparse/node_modules/robot/lib/boop.js b/test/noparse/node_modules/robot/lib/boop.js new file mode 100644 index 000000000..696a67245 --- /dev/null +++ b/test/noparse/node_modules/robot/lib/boop.js @@ -0,0 +1,3 @@ +module.exports = { + boop: true +}; diff --git a/test/noparse/node_modules/robot/main.js b/test/noparse/node_modules/robot/main.js new file mode 100644 index 000000000..87af6096a --- /dev/null +++ b/test/noparse/node_modules/robot/main.js @@ -0,0 +1,4 @@ +module.exports = { + robot: true, + beep: require('./lib/beep') +}; diff --git a/test/noparse/node_modules/robot/package.json b/test/noparse/node_modules/robot/package.json new file mode 100644 index 000000000..c13b8cf6a --- /dev/null +++ b/test/noparse/node_modules/robot/package.json @@ -0,0 +1,3 @@ +{ + "main": "main.js" +} diff --git a/test/paths/main.js b/test/paths/main.js index 73a782432..ec0d8a18d 100644 --- a/test/paths/main.js +++ b/test/paths/main.js @@ -1,3 +1,3 @@ -t.equal(require('aaa'), 'A'); -t.equal(require('bbb'), 'B'); -t.equal(require('ccc'), 'C'); +t.equal(require('aaa'), 'AX'); +t.equal(require('bbb'), 'BY'); +t.equal(require('ccc'), 'CX'); diff --git a/test/paths/x/aaa/index.js b/test/paths/x/aaa/index.js index 1ea591380..b76ce87ec 100644 --- a/test/paths/x/aaa/index.js +++ b/test/paths/x/aaa/index.js @@ -1 +1 @@ -module.exports = 'A' +module.exports = 'AX' diff --git a/test/paths/x/ccc/index.js b/test/paths/x/ccc/index.js index f186fa757..882058e33 100644 --- a/test/paths/x/ccc/index.js +++ b/test/paths/x/ccc/index.js @@ -1 +1 @@ -module.exports = 'C' +module.exports = 'CX' diff --git a/test/paths/y/bbb/index.js b/test/paths/y/bbb/index.js index e22dd83c0..5dbca4475 100644 --- a/test/paths/y/bbb/index.js +++ b/test/paths/y/bbb/index.js @@ -1 +1 @@ -module.exports = 'B' +module.exports = 'BY' diff --git a/test/paths_transform.js b/test/paths_transform.js new file mode 100644 index 000000000..bd0607052 --- /dev/null +++ b/test/paths_transform.js @@ -0,0 +1,76 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; + +function ensureTransform(t, buf) { + var srcAsString = (buf||'').toString('utf-8'), + containsAX = srcAsString.indexOf('AX') > -1, + containsAZ = srcAsString.indexOf('AZ') > -1; + t.notOk(containsAX,"should not contain AX's"); + t.ok(containsAZ,"should contain AZ's"); +} + +test('absolute paths with transform property', function (t) { + t.plan(6); + + var b = browserify({ + transform: ['tr'], + basedir: __dirname, + paths: [ __dirname + '/paths/x', __dirname + '/paths/y' ], + entries: __dirname + '/paths/main.js' + }); + b.bundle(function (err, src) { + t.ifError(err); + ensureTransform(t,src); + vm.runInNewContext(src, { t: t }); + }); +}); + +test('relative paths with transform property', function (t) { + t.plan(6); + + var b = browserify({ + transform: ['tr'], + basedir: __dirname, + paths: [ './paths/x', './paths/y' ], + entries: __dirname + '/paths/main.js' + }); + b.bundle(function (err, src) { + t.ifError(err); + ensureTransform(t,src); + vm.runInNewContext(src, { t: t }); + }); +}); + + +test('absolute paths with transform method', function (t) { + t.plan(6); + + var b = browserify({ + basedir: __dirname, + paths: [ __dirname + '/paths/x', __dirname + '/paths/y' ], + entries: __dirname + '/paths/main.js' + }); + b.transform('tr'); + b.bundle(function (err, src) { + t.ifError(err); + ensureTransform(t,src); + vm.runInNewContext(src, { t: t }); + }); +}); + + +test('relative paths with transform method', function (t) { + t.plan(6); + var b = browserify({ + basedir: __dirname, + paths: ['./paths/x', './paths/y' ], + entries: __dirname + '/paths/main.js' + }); + b.transform('tr'); + b.bundle(function (err, src) { + t.ifError(err); + ensureTransform(t,src); + vm.runInNewContext(src, { t: t }); + }); +}); diff --git a/test/pkg.js b/test/pkg.js index 4552f64ce..753e6d8c0 100644 --- a/test/pkg.js +++ b/test/pkg.js @@ -1,9 +1,10 @@ var browserify = require('../'); var vm = require('vm'); var test = require('tap').test; +var path = require('path'); var pkg = require('./pkg/package.json'); -pkg.__dirname = __dirname + '/pkg'; +pkg.__dirname = path.join(__dirname, 'pkg'); test('package', function (t) { t.plan(2); diff --git a/test/pkg_event.js b/test/pkg_event.js new file mode 100644 index 000000000..77ada96bf --- /dev/null +++ b/test/pkg_event.js @@ -0,0 +1,31 @@ +var browserify = require('../'); +var path = require('path'); +var vm = require('vm'); +var test = require('tap').test; + +var expected = [ + readpkg('pkg_event'), + readpkg('pkg_event/node_modules/aaa'), + readpkg('pkg_event/node_modules/aaa/lib') +]; + +test('package event', function (t) { + t.plan(2 + expected.length); + + var b = browserify(__dirname + '/pkg_event/main.js'); + b.on('package', function (pkg) { + t.deepEqual(pkg, expected.shift()); + }); + + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (msg) { t.equal(msg, 555) } + }); +}); + +function readpkg (dir) { + var pkg = require(path.join(__dirname, dir, 'package.json')); + pkg.__dirname = path.join(__dirname, dir); + return pkg; +} diff --git a/test/pkg_event/main.js b/test/pkg_event/main.js new file mode 100644 index 000000000..bef366aec --- /dev/null +++ b/test/pkg_event/main.js @@ -0,0 +1 @@ +console.log(require('aaa')) diff --git a/test/pkg_event/node_modules/aaa/lib/butts.js b/test/pkg_event/node_modules/aaa/lib/butts.js new file mode 100644 index 000000000..f4e8d9d29 --- /dev/null +++ b/test/pkg_event/node_modules/aaa/lib/butts.js @@ -0,0 +1 @@ +module.exports = 5; diff --git a/test/pkg_event/node_modules/aaa/lib/package.json b/test/pkg_event/node_modules/aaa/lib/package.json new file mode 100644 index 000000000..b47402f55 --- /dev/null +++ b/test/pkg_event/node_modules/aaa/lib/package.json @@ -0,0 +1,4 @@ +{ + "name": "aaa-lib", + "main": "woo.js" +} diff --git a/test/pkg_event/node_modules/aaa/lib/woo.js b/test/pkg_event/node_modules/aaa/lib/woo.js new file mode 100644 index 000000000..82cef514e --- /dev/null +++ b/test/pkg_event/node_modules/aaa/lib/woo.js @@ -0,0 +1 @@ +module.exports = require('./butts.js'); diff --git a/test/pkg_event/node_modules/aaa/main.js b/test/pkg_event/node_modules/aaa/main.js new file mode 100644 index 000000000..822d064da --- /dev/null +++ b/test/pkg_event/node_modules/aaa/main.js @@ -0,0 +1 @@ +module.exports = require('./lib') * 111; diff --git a/test/pkg_event/node_modules/aaa/package.json b/test/pkg_event/node_modules/aaa/package.json new file mode 100644 index 000000000..e9f2198f4 --- /dev/null +++ b/test/pkg_event/node_modules/aaa/package.json @@ -0,0 +1,4 @@ +{ + "name": "aaa", + "main": "main.js" +} diff --git a/test/pkg_event/package.json b/test/pkg_event/package.json new file mode 100644 index 000000000..21d82d8e6 --- /dev/null +++ b/test/pkg_event/package.json @@ -0,0 +1,3 @@ +{ + "name": "pkg_event" +} diff --git a/test/process.js b/test/process.js index 0660d5429..83ffa14ff 100644 --- a/test/process.js +++ b/test/process.js @@ -13,7 +13,8 @@ test('implicit process global', function (t) { t.equal(two, 2); t.end(); }, - setTimeout: setTimeout + setTimeout: setTimeout, + clearTimeout: clearTimeout }; vm.runInNewContext(src, c); }); diff --git a/test/quotes.js b/test/quotes.js new file mode 100644 index 000000000..4c82b7ebe --- /dev/null +++ b/test/quotes.js @@ -0,0 +1,38 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; + +var hasTemplateLiterals = require('has-template-literals')(); + +test('quotes', function (t) { + t.plan(2); + + var b = browserify(__dirname + '/quotes/main.js'); + b.bundle(function (err, src) { + var c = { + done : function (single, double) { + t.equal(single, 'success', 'single quotes'); + t.equal(double, 'success', 'double quotes'); + t.end(); + } + }; + vm.runInNewContext(src, c); + }); +}); + +test('interpolation literals', { skip: !hasTemplateLiterals }, function (t) { + t.plan(3); + + var b = browserify(__dirname + '/quotes/backtick.js'); + b.bundle(function (err, src) { + var c = { + done : function (single, double, backtick) { + t.equal(single, 'success', 'single quotes'); + t.equal(double, 'success', 'double quotes'); + t.equal(backtick, 'success', 'backtick quotes'); + t.end(); + } + }; + vm.runInNewContext(src, c); + }); +}); diff --git a/test/quotes/backtick.js b/test/quotes/backtick.js new file mode 100644 index 000000000..7dd85f1f3 --- /dev/null +++ b/test/quotes/backtick.js @@ -0,0 +1 @@ +done(require('./one.js'), require("./two.js"), require(`./three.js`)); diff --git a/test/quotes/main.js b/test/quotes/main.js new file mode 100644 index 000000000..327b5826b --- /dev/null +++ b/test/quotes/main.js @@ -0,0 +1 @@ +done(require('./one.js'), require("./two.js")); diff --git a/test/quotes/one.js b/test/quotes/one.js new file mode 100644 index 000000000..52b5cbb33 --- /dev/null +++ b/test/quotes/one.js @@ -0,0 +1 @@ +module.exports = 'success'; diff --git a/test/quotes/three.js b/test/quotes/three.js new file mode 100644 index 000000000..52b5cbb33 --- /dev/null +++ b/test/quotes/three.js @@ -0,0 +1 @@ +module.exports = 'success'; diff --git a/test/quotes/two.js b/test/quotes/two.js new file mode 100644 index 000000000..52b5cbb33 --- /dev/null +++ b/test/quotes/two.js @@ -0,0 +1 @@ +module.exports = 'success'; diff --git a/test/relative_dedupe.js b/test/relative_dedupe.js new file mode 100644 index 000000000..5a4a25250 --- /dev/null +++ b/test/relative_dedupe.js @@ -0,0 +1,17 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; + +test('relative dedupe', function (t) { + var expected = [ 'a a', 'a b', 'b a', 'b b' ]; + t.plan(expected.length + 1); + + var b = browserify(__dirname + '/relative_dedupe/main.js'); + b.bundle(function (err, src) { + t.ifError(err); + var c = { console: { log: log } }; + vm.runInNewContext(src, c); + }); + + function log (msg) { t.equal(msg, expected.shift()) } +}); diff --git a/test/relative_dedupe/a/a.js b/test/relative_dedupe/a/a.js new file mode 100644 index 000000000..fd6bd9491 --- /dev/null +++ b/test/relative_dedupe/a/a.js @@ -0,0 +1,3 @@ +module.exports = function() { + console.log("a a") +}; diff --git a/test/relative_dedupe/a/b.js b/test/relative_dedupe/a/b.js new file mode 100644 index 000000000..3bdfe50d3 --- /dev/null +++ b/test/relative_dedupe/a/b.js @@ -0,0 +1,3 @@ +module.exports = function() { + console.log("a b") +}; diff --git a/test/relative_dedupe/a/index.js b/test/relative_dedupe/a/index.js new file mode 100644 index 000000000..5002ffcb1 --- /dev/null +++ b/test/relative_dedupe/a/index.js @@ -0,0 +1,4 @@ +module.exports = { + a: require("./a"), + b: require("./b") +}; diff --git a/test/relative_dedupe/b/a.js b/test/relative_dedupe/b/a.js new file mode 100644 index 000000000..eb66e54be --- /dev/null +++ b/test/relative_dedupe/b/a.js @@ -0,0 +1,3 @@ +module.exports = function() { + console.log("b a") +}; diff --git a/test/relative_dedupe/b/b.js b/test/relative_dedupe/b/b.js new file mode 100644 index 000000000..94faa6281 --- /dev/null +++ b/test/relative_dedupe/b/b.js @@ -0,0 +1,3 @@ +module.exports = function() { + console.log("b b") +}; diff --git a/test/relative_dedupe/b/index.js b/test/relative_dedupe/b/index.js new file mode 100644 index 000000000..5002ffcb1 --- /dev/null +++ b/test/relative_dedupe/b/index.js @@ -0,0 +1,4 @@ +module.exports = { + a: require("./a"), + b: require("./b") +}; diff --git a/test/relative_dedupe/index.js b/test/relative_dedupe/index.js new file mode 100644 index 000000000..69ce41bf9 --- /dev/null +++ b/test/relative_dedupe/index.js @@ -0,0 +1,4 @@ +module.exports = { + a: require("./a"), + b: require("./b") +}; diff --git a/test/relative_dedupe/main.js b/test/relative_dedupe/main.js new file mode 100644 index 000000000..deb937044 --- /dev/null +++ b/test/relative_dedupe/main.js @@ -0,0 +1,5 @@ +var ix = require('./'); +ix.a.a(); +ix.a.b(); +ix.b.a(); +ix.b.b(); diff --git a/test/require_expose.js b/test/require_expose.js new file mode 100644 index 000000000..60f9383f4 --- /dev/null +++ b/test/require_expose.js @@ -0,0 +1,53 @@ +var browserify = require('../'); +var test = require('tap').test; +var vm = require('vm'); + +test('require expose external module', function (t) { + t.plan(2); + + var b = browserify({ basedir: __dirname }); + b.require('beep', { expose: 'bip' }); + b.bundle(function (err, src) { + t.ifError(err); + var c = { }; + vm.runInNewContext(src, c); + t.equal(c.require('bip'), 'boop'); + }) +}); + +test('renaming builtin', function (t) { + t.plan(2); + + var b = browserify({ basedir: __dirname }); + b.require('os', { expose: 'bone' }); + b.bundle(function (err, src) { + t.ifError(err); + var c = { }; + vm.runInNewContext(src, c); + t.equal(c.require('bone').platform(), 'browser'); + }) +}); + +test('exposed modules do not leak across bundles', function (t) { + var bundle1, bundle2; + + bundle1 = browserify(); + bundle1.add(__dirname + '/require_expose/main.js'); + bundle1.require(__dirname + '/require_expose/some_dep.js', { expose: 'foo' }); + + bundle1.bundle(function (err, src) { + if (err) t.fail(err); + + var c = {}; + vm.runInNewContext(src, c); + t.equal(c.foo, 'some_dep'); + + bundle2 = browserify(); + bundle2.add(__dirname + '/require_expose/main.js'); + + bundle2.bundle(function (err) { + t.ok(err && err.message.match(/Cannot find module 'foo'/), 'should fail with missing module'); + t.end(); + }); + }); +}); diff --git a/test/require_expose/main.js b/test/require_expose/main.js new file mode 100644 index 000000000..f99908f64 --- /dev/null +++ b/test/require_expose/main.js @@ -0,0 +1 @@ +foo = require('foo'); diff --git a/test/require_expose/some_dep.js b/test/require_expose/some_dep.js new file mode 100644 index 000000000..353c90dbf --- /dev/null +++ b/test/require_expose/some_dep.js @@ -0,0 +1 @@ +module.exports = 'some_dep'; diff --git a/test/reset.js b/test/reset.js index 10499c860..dad18b3af 100644 --- a/test/reset.js +++ b/test/reset.js @@ -18,6 +18,7 @@ test('reset', function (t) { t.ifError(err); var c = { setTimeout : setTimeout, + clearTimeout : clearTimeout, console : console }; vm.runInNewContext(src, c); diff --git a/test/resolve_exposed.js b/test/resolve_exposed.js new file mode 100644 index 000000000..0d3efc24b --- /dev/null +++ b/test/resolve_exposed.js @@ -0,0 +1,20 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; + +test('resolve exposed files', function (t) { + t.plan(2); + + var b = browserify(__dirname + '/resolve_exposed/main.js', { + basedir: __dirname + '/resolve_exposed' + }); + b.require('./x.js', { expose: 'xyz' }); + b.bundle(function (err, src) { + t.ifError(err); + var c = { console: { log: log } }; + vm.runInNewContext(src, c); + function log (x) { + t.equal(x, 333); + } + }); +}); diff --git a/test/resolve_exposed/main.js b/test/resolve_exposed/main.js new file mode 100644 index 000000000..08a137dc7 --- /dev/null +++ b/test/resolve_exposed/main.js @@ -0,0 +1,2 @@ +var xyz = require('xyz'); +console.log(xyz * 111); diff --git a/test/resolve_exposed/x.js b/test/resolve_exposed/x.js new file mode 100644 index 000000000..6887896a4 --- /dev/null +++ b/test/resolve_exposed/x.js @@ -0,0 +1 @@ +module.exports = 3 diff --git a/test/reverse_multi_bundle.js b/test/reverse_multi_bundle.js index 06f273375..8d9f8325f 100644 --- a/test/reverse_multi_bundle.js +++ b/test/reverse_multi_bundle.js @@ -38,6 +38,7 @@ test('reverse multi bundle', function (t) { var src = appSrc + ';' + lazySrc; var c = { setTimeout: setTimeout, + clearTimeout: clearTimeout, t: t }; vm.runInNewContext(src, c); diff --git a/test/shared_symlink.js b/test/shared_symlink.js new file mode 100644 index 000000000..d5287c139 --- /dev/null +++ b/test/shared_symlink.js @@ -0,0 +1,16 @@ +// https://github.com/substack/node-browserify/issues/1325 + +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; + +test('shared symlink', function (t) { + t.plan(1); + var b = browserify(__dirname + '/shared_symlink/main.js'); + b.bundle(function (err, src) { + // does the same thing as node: crashes + t.equal(err.message, "Cannot find module 'foo' from '" + + __dirname + "/shared_symlink/shared'" + ); + }); +}); diff --git a/test/shared_symlink/app/index.js b/test/shared_symlink/app/index.js new file mode 100644 index 000000000..489c017f6 --- /dev/null +++ b/test/shared_symlink/app/index.js @@ -0,0 +1 @@ +module.exports = require('shared') + require('foo') diff --git a/test/shared_symlink/app/node_modules/foo/index.js b/test/shared_symlink/app/node_modules/foo/index.js new file mode 100644 index 000000000..7afe02674 --- /dev/null +++ b/test/shared_symlink/app/node_modules/foo/index.js @@ -0,0 +1 @@ +module.exports = 1234 diff --git a/test/shared_symlink/app/node_modules/shared b/test/shared_symlink/app/node_modules/shared new file mode 120000 index 000000000..0ab0cb2b3 --- /dev/null +++ b/test/shared_symlink/app/node_modules/shared @@ -0,0 +1 @@ +../../shared \ No newline at end of file diff --git a/test/shared_symlink/main.js b/test/shared_symlink/main.js new file mode 100644 index 000000000..a13f52481 --- /dev/null +++ b/test/shared_symlink/main.js @@ -0,0 +1 @@ +console.log(require('./app')) diff --git a/test/shared_symlink/shared/index.js b/test/shared_symlink/shared/index.js new file mode 100644 index 000000000..176676407 --- /dev/null +++ b/test/shared_symlink/shared/index.js @@ -0,0 +1 @@ +module.exports = require('foo') * 2 diff --git a/test/stream_file.js b/test/stream_file.js index b010282c1..100471ce8 100644 --- a/test/stream_file.js +++ b/test/stream_file.js @@ -3,17 +3,18 @@ var vm = require('vm'); var test = require('tap').test; var fs = require('fs'); var through = require('through2'); +var path = require('path'); test('stream file', function (t) { var expected = {}; - expected[__dirname + '/stream/fake.js'] = true; - expected[__dirname + '/stream/bar.js'] = true; - expected[__dirname + '/stream/foo.js'] = true; + expected[ path.join(__dirname, 'stream/fake.js') ] = true; + expected[ path.join(__dirname, 'stream/bar.js' ) ] = true; + expected[ path.join(__dirname, 'stream/foo.js' ) ] = true; t.plan(5); var stream = fs.createReadStream(__dirname + '/stream/main.js'); - stream.file = __dirname + '/stream/fake.js'; + stream.file = path.join(__dirname, '/stream/fake.js'); var b = browserify(stream, { basedir: __dirname + '/stream' }); b.transform(function (file) { diff --git a/test/symlink_dedupe.js b/test/symlink_dedupe.js new file mode 100644 index 000000000..00d21d15c --- /dev/null +++ b/test/symlink_dedupe.js @@ -0,0 +1,16 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; + +test('hash instances with hashed contexts', function (t) { + t.plan(5); + + var b = browserify(__dirname + '/symlink_dedupe/main.js'); + b.bundle(function (err, buf) { + var c = { t: t }; + var src = buf.toString('utf8'); + t.equal(src.match(RegExp('// FILE F ONE', 'g')).length, 1); + t.equal(src.match(RegExp('// FILE G ONE', 'g')).length, 1); + vm.runInNewContext(src, c); + }); +}); diff --git a/test/symlink_dedupe/main.js b/test/symlink_dedupe/main.js new file mode 100644 index 000000000..92ff18df1 --- /dev/null +++ b/test/symlink_dedupe/main.js @@ -0,0 +1,6 @@ +var A = require('./one/f.js'); +var B = require('./one/dir/f.js'); +t.equal(A, B); +t.equal(A(), 555); +t.equal(B(), 555); + diff --git a/test/symlink_dedupe/one/dir b/test/symlink_dedupe/one/dir new file mode 120000 index 000000000..945c9b46d --- /dev/null +++ b/test/symlink_dedupe/one/dir @@ -0,0 +1 @@ +. \ No newline at end of file diff --git a/test/symlink_dedupe/one/f.js b/test/symlink_dedupe/one/f.js new file mode 100644 index 000000000..a315c1e7d --- /dev/null +++ b/test/symlink_dedupe/one/f.js @@ -0,0 +1,3 @@ +// FILE F ONE +var G = require('./g.js'); +module.exports = function () { return 111 * G }; diff --git a/test/symlink_dedupe/one/g.js b/test/symlink_dedupe/one/g.js new file mode 100644 index 000000000..837303206 --- /dev/null +++ b/test/symlink_dedupe/one/g.js @@ -0,0 +1,2 @@ +// FILE G ONE +module.exports = 5 diff --git a/test/syntax_cache.js b/test/syntax_cache.js new file mode 100644 index 000000000..ff2a5deec --- /dev/null +++ b/test/syntax_cache.js @@ -0,0 +1,47 @@ +var Seq = require('seq'); +var browserify = require('../'); +var test = require('tap').test; +var shasum = require('shasum'); + +test('syntax cache - valid', function (t) { + t.plan(2); + + var expectedCache = {} + var cacheKey; + + var b = browserify(__dirname + '/syntax_cache/valid.js'); + b.once('dep', function(row) { + cacheKey = shasum(row.source); + expectedCache[cacheKey] = true; + }); + + Seq() + .seq(function() { b.bundle(this); }) + .seq(function() { + t.deepEqual(b._syntaxCache, expectedCache); + b._syntaxCache[cacheKey] = expectedCache[cacheKey] = 'beep'; + b.bundle(function(err, src) { + // if the cache worked, the "cacheKey" + // should not be reset to "true" + t.deepEqual(b._syntaxCache, expectedCache); + }); + }); +}); + +test('syntax cache - skip invalid', function (t) { + t.plan(5); + + var b = browserify(__dirname + '/syntax_cache/invalid.js'); + + Seq() + .seq(function() { b.bundle(this); }) + .catch(function(lastErr) { + t.deepEqual(b._syntaxCache, {}); + t.similar(String(lastErr), /ParseError/); + b.bundle(function(err, src) { + t.deepEqual(b._syntaxCache, {}); + t.similar(String(err), /ParseError/); + t.notEqual(lastErr, err, 'errors should be unique'); + }); + }); +}); diff --git a/test/syntax_cache/invalid.js b/test/syntax_cache/invalid.js new file mode 100644 index 000000000..e85c07cca --- /dev/null +++ b/test/syntax_cache/invalid.js @@ -0,0 +1,2 @@ +var x = { +var y = 6; diff --git a/test/syntax_cache/valid.js b/test/syntax_cache/valid.js new file mode 100644 index 000000000..cf4f426f5 --- /dev/null +++ b/test/syntax_cache/valid.js @@ -0,0 +1,2 @@ +var x = {}; +var y = 6; diff --git a/test/tr_global.js b/test/tr_global.js new file mode 100644 index 000000000..941eaf4f3 --- /dev/null +++ b/test/tr_global.js @@ -0,0 +1,17 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; +var through = require('through2'); + +test('global transform precedence', function (t) { + t.plan(1); + + var b = browserify(__dirname + '/tr_global/main.js', { + basedir: __dirname + '/tr_global' + }); + b.transform('tr', { global: true }); + b.bundle(function (err, src) { + vm.runInNewContext(src, { console: { log: log } }); + function log (msg) { t.equal(msg, 444) } + }); +}); diff --git a/test/tr_global/main.js b/test/tr_global/main.js new file mode 100644 index 000000000..208d369bf --- /dev/null +++ b/test/tr_global/main.js @@ -0,0 +1 @@ +console.log(require('x')); diff --git a/test/tr_global/node_modules/tr/index.js b/test/tr_global/node_modules/tr/index.js new file mode 100644 index 000000000..b11f32dcb --- /dev/null +++ b/test/tr_global/node_modules/tr/index.js @@ -0,0 +1,8 @@ +var through = require('through2'); + +module.exports = function () { + return through(function (buf, enc, next) { + this.push(buf.toString('utf8').replace(/VAR/, 4)); + next(); + }); +}; diff --git a/test/tr_global/node_modules/x/index.js b/test/tr_global/node_modules/x/index.js new file mode 100644 index 000000000..1e8d9e3c0 --- /dev/null +++ b/test/tr_global/node_modules/x/index.js @@ -0,0 +1 @@ +module.exports = 111 * VAR diff --git a/test/tr_global/node_modules/x/node_modules/tr/index.js b/test/tr_global/node_modules/x/node_modules/tr/index.js new file mode 100644 index 000000000..597e4f81a --- /dev/null +++ b/test/tr_global/node_modules/x/node_modules/tr/index.js @@ -0,0 +1,8 @@ +var through = require('through2'); + +module.exports = function () { + return through(function (buf, enc, next) { + this.push(buf.toString('utf8').replace(/VAR/, 5)); + next(); + }); +}; diff --git a/test/tr_no_entry.js b/test/tr_no_entry.js new file mode 100644 index 000000000..f41d9ceb5 --- /dev/null +++ b/test/tr_no_entry.js @@ -0,0 +1,20 @@ +var browserify = require('../'); +var test = require('tap').test; +var path = require('path') + +test('transform with no entry files', function (t) { + process.chdir(__dirname); + + t.plan(2); + var b = browserify(); + b.transform('tr'); + b.require(path.join(__dirname, 'tr_no_entry/main.js'), { + expose: 'yoyo' + }); + b.bundle(function (err, body) { + t.ifError(err); + var src = body.toString('utf8') + 'require("yoyo")'; + var con = { log: function (msg) { t.equal(msg, 'ZZZ') } }; + Function('console', src)(con); + }); +}); diff --git a/test/tr_no_entry/main.js b/test/tr_no_entry/main.js new file mode 100644 index 000000000..3dce90898 --- /dev/null +++ b/test/tr_no_entry/main.js @@ -0,0 +1 @@ +console.log('XXX'); diff --git a/test/tr_once.js b/test/tr_once.js new file mode 100644 index 000000000..a892189e2 --- /dev/null +++ b/test/tr_once.js @@ -0,0 +1,21 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; +var through = require('through2'); +var path = require('path'); + +test('transform exactly once', function (t) { + t.plan(3); + + var b = browserify(__dirname + '/tr_once/main.js', { + transform: function (file) { + t.equal(file, path.join(__dirname, 'tr_once/main.js') ); + return through(); + } + }); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { console: { log: log } }); + function log (msg) { t.equal(msg, 'wow') } + }); +}); diff --git a/test/tr_once/main.js b/test/tr_once/main.js new file mode 100644 index 000000000..6036bec63 --- /dev/null +++ b/test/tr_once/main.js @@ -0,0 +1 @@ +console.log('wow'); diff --git a/test/tr_order.js b/test/tr_order.js new file mode 100644 index 000000000..020b86e32 --- /dev/null +++ b/test/tr_order.js @@ -0,0 +1,23 @@ +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; +var through = require('through2'); + +test('function transform', function (t) { + debugger; + t.plan(8); + + var b = browserify(__dirname + '/tr/main.js'); + b.transform({ global: true }, function (file) { + return through(function (buf, enc, next) { + this.push(String(buf).replace(/ZZZ/g, '1')); + next(); + }); + }); + b.transform(__dirname + '/tr_order/replace_aaa'); + b.transform(__dirname + '/tr_order/replace_bbb.js'); + b.bundle(function (err, src) { + t.ifError(err); + vm.runInNewContext(src, { t: t }); + }); +}); diff --git a/test/tr_order/replace_aaa.js b/test/tr_order/replace_aaa.js new file mode 100644 index 000000000..f1af976c0 --- /dev/null +++ b/test/tr_order/replace_aaa.js @@ -0,0 +1,10 @@ +var through = require('through2'); + +module.exports = function(file) { + return through(function (buf, enc, next) { + this.push(String(buf) + .replace(/AAA/g, '5') + ); + next(); + }) +} diff --git a/test/tr_order/replace_bbb.js b/test/tr_order/replace_bbb.js new file mode 100644 index 000000000..cf57725cd --- /dev/null +++ b/test/tr_order/replace_bbb.js @@ -0,0 +1,11 @@ +var through = require('through2'); + +module.exports = function(file) { + return through(function (buf, enc, next) { + this.push(String(buf) + .replace(/AAA/g, '6') + .replace(/BBB/g, '50') + ); + next(); + }) +} diff --git a/test/tr_symlink.js b/test/tr_symlink.js new file mode 100644 index 000000000..ae3210a50 --- /dev/null +++ b/test/tr_symlink.js @@ -0,0 +1,27 @@ +// based on this scenario: +// https://github.com/substack/node-browserify/pull/831#issuecomment-49546902 + +var browserify = require('../'); +var vm = require('vm'); +var test = require('tap').test; +var through = require('through2'); + +test('transform symlink', function (t) { + t.plan(4); + var expected = [ 9, 555, 777 ]; + var b = browserify(__dirname + '/tr_symlink/app/main.js', { + basedir: __dirname + '/tr_symlink/app' + }); + b.transform(function (file) { + return through(function (buf, enc, next) { + this.push(String(buf).replace(/7/g, 9)); + next(); + }) + }); + b.bundle(function (err, src) { + t.ifError(err); + var c = { console: { log: log } }; + vm.runInNewContext(src, c); + function log (msg) { t.equal(msg, expected.shift()) } + }); +}); diff --git a/test/tr_symlink/a-module/index.js b/test/tr_symlink/a-module/index.js new file mode 100644 index 000000000..3e842e734 --- /dev/null +++ b/test/tr_symlink/a-module/index.js @@ -0,0 +1 @@ +module.exports = 555 diff --git a/test/tr_symlink/app/main.js b/test/tr_symlink/app/main.js new file mode 100644 index 000000000..da0ac769b --- /dev/null +++ b/test/tr_symlink/app/main.js @@ -0,0 +1,6 @@ +var a = require('aaa'); +var b = require('bbb'); + +console.log(5); +console.log(a); +console.log(b); diff --git a/test/tr_symlink/app/node_modules/aaa b/test/tr_symlink/app/node_modules/aaa new file mode 120000 index 000000000..fcd5624d4 --- /dev/null +++ b/test/tr_symlink/app/node_modules/aaa @@ -0,0 +1 @@ +../../a-module \ No newline at end of file diff --git a/test/tr_symlink/app/node_modules/bbb b/test/tr_symlink/app/node_modules/bbb new file mode 120000 index 000000000..bbded2ad5 --- /dev/null +++ b/test/tr_symlink/app/node_modules/bbb @@ -0,0 +1 @@ +../../b-module \ No newline at end of file diff --git a/test/tr_symlink/app/node_modules/tr/index.js b/test/tr_symlink/app/node_modules/tr/index.js new file mode 100644 index 000000000..f9d056885 --- /dev/null +++ b/test/tr_symlink/app/node_modules/tr/index.js @@ -0,0 +1,14 @@ +var through = require('through2'); + +module.exports = function () { + var bufs = []; + return through(write, end); + function write (buf, enc, next) { + bufs.push(buf); + next(); + } + function end () { + this.push(Buffer.concat(bufs).toString().replace(/5/g, 9)); + this.push(null); + } +}; diff --git a/test/tr_symlink/app/package.json b/test/tr_symlink/app/package.json new file mode 100644 index 000000000..2f2bbfff8 --- /dev/null +++ b/test/tr_symlink/app/package.json @@ -0,0 +1,5 @@ +{ + "browserify": { + "transform": [ "tr" ] + } +} diff --git a/test/tr_symlink/b-module/ext.js b/test/tr_symlink/b-module/ext.js new file mode 100644 index 000000000..2fad98701 --- /dev/null +++ b/test/tr_symlink/b-module/ext.js @@ -0,0 +1 @@ +module.exports = 777; diff --git a/test/tr_symlink/b-module/index.js b/test/tr_symlink/b-module/index.js new file mode 100644 index 000000000..dae6275e7 --- /dev/null +++ b/test/tr_symlink/b-module/index.js @@ -0,0 +1,2 @@ +var ext = require('./ext'); +module.exports = ext; diff --git a/test/yield.js b/test/yield.js index 666c0e28d..164a5aaf7 100644 --- a/test/yield.js +++ b/test/yield.js @@ -1,18 +1,18 @@ var browserify = require('../'); var test = require('tap').test; var vm = require('vm'); +var generatorFunction = require('make-generator-function'); -test('yield', function (t) { +test('yield', { skip: !generatorFunction }, function (t) { t.plan(6); var b = browserify(__dirname + '/yield/main.js'); - b.transform('es6ify'); - + b.bundle(function (err, src) { t.error(err); var c = { console: { log: log } }; var index = 0; vm.runInNewContext(src, c); - + function log (msg) { t.equal(index++, msg); }