From 0379fb65c17fa0a9aa67d43c7b08e4507b440ece Mon Sep 17 00:00:00 2001 From: isaacs Date: Wed, 11 Dec 2019 11:09:58 -0800 Subject: [PATCH] deps: update npm to 6.13.4 PR-URL: https://github.com/nodejs/node/pull/30904 Reviewed-By: Ruben Bridgewater Reviewed-By: Rich Trott Reviewed-By: Jiawen Geng Reviewed-By: Michael Dawson Reviewed-By: Daijiro Wachi --- deps/npm/AUTHORS | 5 + deps/npm/CHANGELOG.md | 76 + deps/npm/Makefile | 4 +- deps/npm/bin/npm | 4 - deps/npm/bin/npx | 4 - .../public/cli-commands/npm-access/index.html | 145 + .../cli-commands/npm-adduser/index.html | 140 + .../public/cli-commands/npm-audit/index.html | 162 + .../public/cli-commands/npm-bin/index.html | 91 + .../public/cli-commands/npm-bugs/index.html | 111 + .../public/cli-commands/npm-build/index.html | 97 + .../public/cli-commands/npm-bundle/index.html | 88 + .../public/cli-commands/npm-cache/index.html | 142 + .../public/cli-commands/npm-ci/index.html | 119 + .../cli-commands/npm-completion/index.html | 101 + .../public/cli-commands/npm-config/index.html | 125 + .../public/cli-commands/npm-dedupe/index.html | 118 + .../cli-commands/npm-deprecate/index.html | 97 + .../cli-commands/npm-dist-tag/index.html | 146 + .../public/cli-commands/npm-docs/index.html | 112 + .../public/cli-commands/npm-doctor/index.html | 160 + .../public/cli-commands/npm-edit/index.html | 107 + .../cli-commands/npm-explore/index.html | 111 + .../public/cli-commands/npm-fund/index.html | 118 + .../cli-commands/npm-help-search/index.html | 102 + .../public/cli-commands/npm-help/index.html | 104 + .../public/cli-commands/npm-hook/index.html | 116 + .../public/cli-commands/npm-init/index.html | 123 + .../npm-install-ci-test/index.html | 90 + .../cli-commands/npm-install-test/index.html | 99 + .../cli-commands/npm-install/index.html | 465 +++ .../public/cli-commands/npm-link/index.html | 131 + .../public/cli-commands/npm-logout/index.html | 106 + .../public/cli-commands/npm-ls/index.html | 173 + .../public/cli-commands/npm-org/index.html | 104 + .../cli-commands/npm-outdated/index.html | 175 + .../public/cli-commands/npm-owner/index.html | 111 + .../public/cli-commands/npm-pack/index.html | 99 + .../public/cli-commands/npm-ping/index.html | 92 + .../public/cli-commands/npm-prefix/index.html | 95 + .../cli-commands/npm-profile/index.html | 145 + .../public/cli-commands/npm-prune/index.html | 105 + .../cli-commands/npm-publish/index.html | 137 + .../cli-commands/npm-rebuild/index.html | 90 + .../public/cli-commands/npm-repo/index.html | 98 + .../cli-commands/npm-restart/index.html | 110 + .../public/cli-commands/npm-root/index.html | 91 + .../cli-commands/npm-run-script/index.html | 140 + .../public/cli-commands/npm-search/index.html | 165 + .../cli-commands/npm-shrinkwrap/index.html | 98 + .../public/cli-commands/npm-star/index.html | 93 + .../public/cli-commands/npm-stars/index.html | 93 + .../public/cli-commands/npm-start/index.html | 95 + .../public/cli-commands/npm-stop/index.html | 91 + .../public/cli-commands/npm-team/index.html | 121 + .../public/cli-commands/npm-test/index.html | 93 + .../public/cli-commands/npm-token/index.html | 130 + .../cli-commands/npm-uninstall/index.html | 115 + .../cli-commands/npm-unpublish/index.html | 110 + .../public/cli-commands/npm-update/index.html | 163 + .../cli-commands/npm-version/index.html | 177 + .../public/cli-commands/npm-view/index.html | 142 + .../public/cli-commands/npm-whoami/index.html | 89 + .../docs/public/cli-commands/npm/index.html | 208 + .../public/configuring-npm/folders/index.html | 237 ++ .../public/configuring-npm/install/index.html | 120 + .../public/configuring-npm/npmrc/index.html | 142 + .../configuring-npm/package-json/index.html | 693 ++++ .../package-lock-json/index.html | 183 + .../configuring-npm/package-locks/index.html | 211 + .../shrinkwrap-json/index.html | 99 + .../v18/QldKNThLqRwH-OJ1UHjlKGlZ5q4.woff | Bin 0 -> 21764 bytes .../v18/QldKNThLqRwH-OJ1UHjlKGlZ5qg.woff2 | Bin 0 -> 17472 bytes .../v18/QldXNThLqRwH-OJ1UHjlKGHiw71p5_o.woff | Bin 0 -> 25172 bytes .../v18/QldXNThLqRwH-OJ1UHjlKGHiw71p5_w.woff2 | Bin 0 -> 20336 bytes .../v9/pxiByp8kv8JHgFVrLDz8Z1xlEw.woff | Bin 0 -> 10500 bytes .../v9/pxiByp8kv8JHgFVrLDz8Z1xlFQ.woff2 | Bin 0 -> 7988 bytes .../v9/pxiByp8kv8JHgFVrLGT9Z1xlEw.woff | Bin 0 -> 10512 bytes .../v9/pxiByp8kv8JHgFVrLGT9Z1xlFQ.woff2 | Bin 0 -> 7960 bytes .../s/poppins/v9/pxiEyp8kv8JHgFVrJJfecg.woff2 | Bin 0 -> 7968 bytes .../s/poppins/v9/pxiEyp8kv8JHgFVrJJfedA.woff | Bin 0 -> 10484 bytes deps/npm/docs/public/icons/icon-144x144.png | Bin 0 -> 829 bytes deps/npm/docs/public/icons/icon-192x192.png | Bin 0 -> 949 bytes deps/npm/docs/public/icons/icon-256x256.png | Bin 0 -> 1535 bytes deps/npm/docs/public/icons/icon-384x384.png | Bin 0 -> 3006 bytes deps/npm/docs/public/icons/icon-48x48.png | Bin 0 -> 581 bytes deps/npm/docs/public/icons/icon-512x512.png | Bin 0 -> 5056 bytes deps/npm/docs/public/icons/icon-72x72.png | Bin 0 -> 610 bytes deps/npm/docs/public/icons/icon-96x96.png | Bin 0 -> 712 bytes deps/npm/docs/public/index.html | 125 + deps/npm/docs/public/static/d/2215187023.json | 1 + deps/npm/docs/public/static/d/2417117884.json | 1 + ...-icon-f659855f70bb0e12addd96250807c241.svg | 1 + .../public/styles.e93b5499b63484750fba.css | 1 + .../docs/public/using-npm/config/index.html | 1158 ++++++ .../public/using-npm/developers/index.html | 256 ++ .../docs/public/using-npm/disputes/index.html | 189 + .../npm/docs/public/using-npm/orgs/index.html | 141 + .../docs/public/using-npm/registry/index.html | 153 + .../docs/public/using-npm/removal/index.html | 113 + .../docs/public/using-npm/scope/index.html | 156 + .../docs/public/using-npm/scripts/index.html | 300 ++ .../docs/public/using-npm/semver/index.html | 432 ++ deps/npm/lib/fund.js | 4 +- deps/npm/lib/install/deps.js | 13 +- deps/npm/lib/install/read-shrinkwrap.js | 3 +- deps/npm/lib/utils/error-message.js | 5 +- deps/npm/lib/utils/funding.js | 18 +- deps/npm/lib/version.js | 2 +- deps/npm/man/man1/npm-README.1 | 2 +- deps/npm/man/man1/npm-access.1 | 2 +- deps/npm/man/man1/npm-adduser.1 | 2 +- deps/npm/man/man1/npm-audit.1 | 2 +- deps/npm/man/man1/npm-bin.1 | 2 +- deps/npm/man/man1/npm-bugs.1 | 2 +- deps/npm/man/man1/npm-build.1 | 2 +- deps/npm/man/man1/npm-bundle.1 | 2 +- deps/npm/man/man1/npm-cache.1 | 2 +- deps/npm/man/man1/npm-ci.1 | 2 +- deps/npm/man/man1/npm-completion.1 | 2 +- deps/npm/man/man1/npm-config.1 | 2 +- deps/npm/man/man1/npm-dedupe.1 | 2 +- deps/npm/man/man1/npm-deprecate.1 | 2 +- deps/npm/man/man1/npm-dist-tag.1 | 2 +- deps/npm/man/man1/npm-docs.1 | 2 +- deps/npm/man/man1/npm-doctor.1 | 2 +- deps/npm/man/man1/npm-edit.1 | 2 +- deps/npm/man/man1/npm-explore.1 | 2 +- deps/npm/man/man1/npm-fund.1 | 2 +- deps/npm/man/man1/npm-help-search.1 | 2 +- deps/npm/man/man1/npm-help.1 | 2 +- deps/npm/man/man1/npm-hook.1 | 2 +- deps/npm/man/man1/npm-init.1 | 2 +- deps/npm/man/man1/npm-install-ci-test.1 | 2 +- deps/npm/man/man1/npm-install-test.1 | 2 +- deps/npm/man/man1/npm-install.1 | 2 +- deps/npm/man/man1/npm-link.1 | 2 +- deps/npm/man/man1/npm-logout.1 | 2 +- deps/npm/man/man1/npm-ls.1 | 4 +- deps/npm/man/man1/npm-org.1 | 2 +- deps/npm/man/man1/npm-outdated.1 | 2 +- deps/npm/man/man1/npm-owner.1 | 2 +- deps/npm/man/man1/npm-pack.1 | 2 +- deps/npm/man/man1/npm-ping.1 | 2 +- deps/npm/man/man1/npm-prefix.1 | 2 +- deps/npm/man/man1/npm-prune.1 | 2 +- deps/npm/man/man1/npm-publish.1 | 2 +- deps/npm/man/man1/npm-rebuild.1 | 2 +- deps/npm/man/man1/npm-repo.1 | 2 +- deps/npm/man/man1/npm-restart.1 | 2 +- deps/npm/man/man1/npm-root.1 | 2 +- deps/npm/man/man1/npm-run-script.1 | 2 +- deps/npm/man/man1/npm-search.1 | 2 +- deps/npm/man/man1/npm-shrinkwrap.1 | 2 +- deps/npm/man/man1/npm-star.1 | 2 +- deps/npm/man/man1/npm-stars.1 | 2 +- deps/npm/man/man1/npm-start.1 | 2 +- deps/npm/man/man1/npm-stop.1 | 2 +- deps/npm/man/man1/npm-team.1 | 2 +- deps/npm/man/man1/npm-test.1 | 2 +- deps/npm/man/man1/npm-uninstall.1 | 2 +- deps/npm/man/man1/npm-unpublish.1 | 2 +- deps/npm/man/man1/npm-update.1 | 2 +- deps/npm/man/man1/npm-version.1 | 2 +- deps/npm/man/man1/npm-view.1 | 2 +- deps/npm/man/man1/npm-whoami.1 | 2 +- deps/npm/man/man1/npm.1 | 4 +- deps/npm/man/man5/install.5 | 2 +- deps/npm/man/man5/npmrc.5 | 2 +- deps/npm/man/man5/package-json.5 | 2 +- deps/npm/man/man5/package-lock-json.5 | 2 +- deps/npm/man/man5/package-locks.5 | 2 +- deps/npm/man/man5/shrinkwrap-json.5 | 2 +- deps/npm/man/man7/developers.7 | 2 +- deps/npm/man/man7/disputes.7 | 2 +- deps/npm/man/man7/orgs.7 | 2 +- deps/npm/man/man7/registry.7 | 2 +- deps/npm/man/man7/removal.7 | 2 +- deps/npm/man/man7/scope.7 | 2 +- deps/npm/man/man7/scripts.7 | 2 +- deps/npm/man/man7/semver.7 | 2 +- deps/npm/node_modules/bin-links/CHANGELOG.md | 30 + deps/npm/node_modules/bin-links/index.js | 51 +- deps/npm/node_modules/bin-links/package.json | 27 +- deps/npm/node_modules/gentle-fs/CHANGELOG.md | 10 + deps/npm/node_modules/gentle-fs/index.js | 4 +- .../node_modules/gentle-fs/lib/bin-link.js | 96 + deps/npm/node_modules/gentle-fs/lib/link.js | 54 +- deps/npm/node_modules/gentle-fs/package.json | 25 +- deps/npm/node_modules/json-schema/README.md | 2 +- .../json-schema/draft-00/hyper-schema | 20 +- .../json-schema/draft-00/json-ref | 10 +- .../node_modules/json-schema/draft-00/links | 10 +- .../node_modules/json-schema/draft-00/schema | 50 +- .../json-schema/draft-01/hyper-schema | 20 +- .../json-schema/draft-01/json-ref | 10 +- .../node_modules/json-schema/draft-01/links | 10 +- .../node_modules/json-schema/draft-01/schema | 50 +- .../json-schema/draft-02/hyper-schema | 20 +- .../json-schema/draft-02/json-ref | 10 +- .../node_modules/json-schema/draft-02/links | 12 +- .../node_modules/json-schema/draft-02/schema | 52 +- .../json-schema/draft-03/examples/calendar | 12 +- .../json-schema/draft-03/examples/interfaces | 24 +- .../json-schema/draft-03/json-ref | 10 +- .../node_modules/json-schema/draft-03/links | 12 +- .../node_modules/json-schema/draft-03/schema | 62 +- .../node_modules/json-schema/draft-04/links | 14 +- .../node_modules/json-schema/draft-04/schema | 66 +- .../json-schema/draft-zyp-json-schema-03.xml | 400 +- .../json-schema/draft-zyp-json-schema-04.xml | 390 +- .../npm/node_modules/json-schema/lib/links.js | 8 +- .../node_modules/json-schema/lib/validate.js | 4 +- deps/npm/node_modules/npm-bundled/index.js | 18 +- .../npm/node_modules/npm-bundled/package.json | 15 +- .../.github/settings.yml | 2 + .../npm-normalize-package-bin/.npmignore | 24 + .../npm-normalize-package-bin/LICENSE | 15 + .../npm-normalize-package-bin/README.md | 14 + .../npm-normalize-package-bin/index.js | 60 + .../package-lock.json | 3529 +++++++++++++++++ .../npm-normalize-package-bin/package.json | 57 + .../npm-normalize-package-bin/test/array.js | 37 + .../npm-normalize-package-bin/test/nobin.js | 35 + .../npm-normalize-package-bin/test/object.js | 141 + .../npm-normalize-package-bin/test/string.js | 37 + deps/npm/node_modules/npm-packlist/index.js | 15 +- .../node_modules/npm-packlist/package.json | 25 +- deps/npm/node_modules/pacote/CHANGELOG.md | 20 + .../pacote/lib/fetchers/directory.js | 3 +- .../node_modules/pacote/lib/fetchers/git.js | 2 +- .../pacote/lib/finalize-manifest.js | 14 +- deps/npm/node_modules/pacote/lib/util/git.js | 7 +- deps/npm/node_modules/pacote/package.json | 26 +- .../read-package-json/CHANGELOG.md | 10 + .../read-package-json/package.json | 22 +- .../read-package-json/read-json.js | 9 +- deps/npm/node_modules/slash/index.js | 11 - deps/npm/node_modules/slash/package.json | 65 - deps/npm/node_modules/slash/readme.md | 44 - deps/npm/package.json | 12 +- deps/npm/scripts/install.sh | 2 + .../test/fixtures/config/userconfig-with-gc | 2 +- deps/npm/test/tap/bin-overwriting.js | 107 + deps/npm/test/tap/fund.js | 15 + .../test/tap/install-dep-classification.js | 45 +- deps/npm/test/tap/install-local-from-local.js | 94 + deps/npm/test/tap/utils.funding.js | 69 +- 248 files changed, 17558 insertions(+), 992 deletions(-) create mode 100644 deps/npm/docs/public/cli-commands/npm-access/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-adduser/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-audit/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-bin/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-bugs/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-build/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-bundle/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-cache/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-ci/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-completion/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-config/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-dedupe/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-deprecate/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-dist-tag/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-docs/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-doctor/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-edit/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-explore/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-fund/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-help-search/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-help/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-hook/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-init/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-install-ci-test/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-install-test/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-install/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-link/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-logout/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-ls/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-org/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-outdated/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-owner/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-pack/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-ping/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-prefix/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-profile/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-prune/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-publish/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-rebuild/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-repo/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-restart/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-root/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-run-script/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-search/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-shrinkwrap/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-star/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-stars/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-start/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-stop/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-team/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-test/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-token/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-uninstall/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-unpublish/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-update/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-version/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-view/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm-whoami/index.html create mode 100644 deps/npm/docs/public/cli-commands/npm/index.html create mode 100644 deps/npm/docs/public/configuring-npm/folders/index.html create mode 100644 deps/npm/docs/public/configuring-npm/install/index.html create mode 100644 deps/npm/docs/public/configuring-npm/npmrc/index.html create mode 100644 deps/npm/docs/public/configuring-npm/package-json/index.html create mode 100644 deps/npm/docs/public/configuring-npm/package-lock-json/index.html create mode 100644 deps/npm/docs/public/configuring-npm/package-locks/index.html create mode 100644 deps/npm/docs/public/configuring-npm/shrinkwrap-json/index.html create mode 100644 deps/npm/docs/public/google-fonts/s/inconsolata/v18/QldKNThLqRwH-OJ1UHjlKGlZ5q4.woff create mode 100644 deps/npm/docs/public/google-fonts/s/inconsolata/v18/QldKNThLqRwH-OJ1UHjlKGlZ5qg.woff2 create mode 100644 deps/npm/docs/public/google-fonts/s/inconsolata/v18/QldXNThLqRwH-OJ1UHjlKGHiw71p5_o.woff create mode 100644 deps/npm/docs/public/google-fonts/s/inconsolata/v18/QldXNThLqRwH-OJ1UHjlKGHiw71p5_w.woff2 create mode 100644 deps/npm/docs/public/google-fonts/s/poppins/v9/pxiByp8kv8JHgFVrLDz8Z1xlEw.woff create mode 100644 deps/npm/docs/public/google-fonts/s/poppins/v9/pxiByp8kv8JHgFVrLDz8Z1xlFQ.woff2 create mode 100644 deps/npm/docs/public/google-fonts/s/poppins/v9/pxiByp8kv8JHgFVrLGT9Z1xlEw.woff create mode 100644 deps/npm/docs/public/google-fonts/s/poppins/v9/pxiByp8kv8JHgFVrLGT9Z1xlFQ.woff2 create mode 100644 deps/npm/docs/public/google-fonts/s/poppins/v9/pxiEyp8kv8JHgFVrJJfecg.woff2 create mode 100644 deps/npm/docs/public/google-fonts/s/poppins/v9/pxiEyp8kv8JHgFVrJJfedA.woff create mode 100644 deps/npm/docs/public/icons/icon-144x144.png create mode 100644 deps/npm/docs/public/icons/icon-192x192.png create mode 100644 deps/npm/docs/public/icons/icon-256x256.png create mode 100644 deps/npm/docs/public/icons/icon-384x384.png create mode 100644 deps/npm/docs/public/icons/icon-48x48.png create mode 100644 deps/npm/docs/public/icons/icon-512x512.png create mode 100644 deps/npm/docs/public/icons/icon-72x72.png create mode 100644 deps/npm/docs/public/icons/icon-96x96.png create mode 100644 deps/npm/docs/public/index.html create mode 100644 deps/npm/docs/public/static/d/2215187023.json create mode 100644 deps/npm/docs/public/static/d/2417117884.json create mode 100644 deps/npm/docs/public/static/network-icon-f659855f70bb0e12addd96250807c241.svg create mode 100644 deps/npm/docs/public/styles.e93b5499b63484750fba.css create mode 100644 deps/npm/docs/public/using-npm/config/index.html create mode 100644 deps/npm/docs/public/using-npm/developers/index.html create mode 100644 deps/npm/docs/public/using-npm/disputes/index.html create mode 100644 deps/npm/docs/public/using-npm/orgs/index.html create mode 100644 deps/npm/docs/public/using-npm/registry/index.html create mode 100644 deps/npm/docs/public/using-npm/removal/index.html create mode 100644 deps/npm/docs/public/using-npm/scope/index.html create mode 100644 deps/npm/docs/public/using-npm/scripts/index.html create mode 100644 deps/npm/docs/public/using-npm/semver/index.html create mode 100644 deps/npm/node_modules/gentle-fs/lib/bin-link.js create mode 100644 deps/npm/node_modules/npm-normalize-package-bin/.github/settings.yml create mode 100644 deps/npm/node_modules/npm-normalize-package-bin/.npmignore create mode 100644 deps/npm/node_modules/npm-normalize-package-bin/LICENSE create mode 100644 deps/npm/node_modules/npm-normalize-package-bin/README.md create mode 100644 deps/npm/node_modules/npm-normalize-package-bin/index.js create mode 100644 deps/npm/node_modules/npm-normalize-package-bin/package-lock.json create mode 100644 deps/npm/node_modules/npm-normalize-package-bin/package.json create mode 100644 deps/npm/node_modules/npm-normalize-package-bin/test/array.js create mode 100644 deps/npm/node_modules/npm-normalize-package-bin/test/nobin.js create mode 100644 deps/npm/node_modules/npm-normalize-package-bin/test/object.js create mode 100644 deps/npm/node_modules/npm-normalize-package-bin/test/string.js delete mode 100644 deps/npm/node_modules/slash/index.js delete mode 100644 deps/npm/node_modules/slash/package.json delete mode 100644 deps/npm/node_modules/slash/readme.md create mode 100644 deps/npm/test/tap/bin-overwriting.js create mode 100644 deps/npm/test/tap/install-local-from-local.js diff --git a/deps/npm/AUTHORS b/deps/npm/AUTHORS index eef45f2df19be2..9e95ac15f62e79 100644 --- a/deps/npm/AUTHORS +++ b/deps/npm/AUTHORS @@ -672,3 +672,8 @@ Amal Hussein Brett Zamir Menelaos Kotsollaris Mehdi Hasan Khan +Craig Loewen +Fighting-Jack <574637316@qq.com> +Bakel, Roel van +Charlie West-Toebe <38671683+Hoidberg@users.noreply.github.com> +Richard Lau diff --git a/deps/npm/CHANGELOG.md b/deps/npm/CHANGELOG.md index d83c57f6d9a772..945ac7583bac2a 100644 --- a/deps/npm/CHANGELOG.md +++ b/deps/npm/CHANGELOG.md @@ -1,3 +1,79 @@ +## 6.13.4 (2019-12-11) + +## BUGFIXES + +* [`320ac9aee`](https://github.com/npm/cli/commit/320ac9aeeafd11bb693c53b31148b8d10c4165e8) + [npm/bin-links#12](https://github.com/npm/bin-links/pull/12) + [npm/gentle-fs#7](https://github.com/npm/gentle-fs/pull/7) + Do not remove global bin/man links inappropriately + ([@isaacs](https://github.com/isaacs)) + +## DEPENDENCIES + +* [`52fd21061`](https://github.com/npm/cli/commit/52fd21061ff8b1a73429294620ffe5ebaaa60d3e) + `gentle-fs@2.3.0` + ([@isaacs](https://github.com/isaacs)) +* [`d06f5c0b0`](https://github.com/npm/cli/commit/d06f5c0b0611c43b6e70ded92af24fa5d83a0f48) + `bin-links@1.1.6` + ([@isaacs](https://github.com/isaacs)) + +## 6.13.3 (2019-12-09) + +### DEPENDENCIES + +* [`19ce061a2`](https://github.com/npm/cli/commit/19ce061a2ee165d8de862c8f0f733c222846b9e1) + `bin-links@1.1.5` Properly normalize, sanitize, and verify `bin` entries + in `package.json`. +* [`59c836aae`](https://github.com/npm/cli/commit/59c836aae8d0104a767e80c540b963c91774012a) + `npm-packlist@1.4.7` +* [`fb4ecd7d2`](https://github.com/npm/cli/commit/fb4ecd7d2810b0b4897daaf081a5e2f3f483b310) + `pacote@9.5.11` + * [`5f33040`](https://github.com/npm/pacote/commit/5f3304028b6985fd380fc77c4840ff12a4898301) + [#476](https://github.com/npm/cli/issues/476) + [npm/pacote#22](https://github.com/npm/pacote/issues/22) + [npm/pacote#14](https://github.com/npm/pacote/issues/14) fix: Do not + drop perms in git when not root ([isaacs](https://github.com/isaacs), + [@darcyclarke](https://github.com/darcyclarke)) + * [`6f229f7`](https://github.com/npm/pacote/6f229f78d9911b4734f0a19c6afdc5454034c759) + sanitize and normalize package bin field + ([isaacs](https://github.com/isaacs)) +* [`1743cb339`](https://github.com/npm/cli/commit/1743cb339767e86431dcd565c7bdb0aed67b293d) + `read-package-json@2.1.1` + + +## 6.13.2 (2019-12-03) + +### BUG FIXES + +* [`4429645b3`](https://github.com/npm/cli/commit/4429645b3538e1cda54d8d1b7ecb3da7a88fdd3c) + [#546](https://github.com/npm/cli/pull/546) + fix docs target typo + ([@richardlau](https://github.com/richardlau)) +* [`867642942`](https://github.com/npm/cli/commit/867642942bec69bb9ab71cff1914fb6a9fe67de8) + [#142](https://github.com/npm/cli/pull/142) + fix(packageRelativePath): fix 'where' for file deps + ([@larsgw](https://github.com/larsgw)) +* [`d480f2c17`](https://github.com/npm/cli/commit/d480f2c176e6976b3cca3565e4c108b599b0379b) + [#527](https://github.com/npm/cli/pull/527) + Revert "windows: Add preliminary WSL support for npm and npx" + ([@craigloewen-msft](https://github.com/craigloewen-msft)) +* [`e4b97962e`](https://github.com/npm/cli/commit/e4b97962e5fce0d49beb541ce5a0f96aee0525de) + [#504](https://github.com/npm/cli/pull/504) + remove unnecessary package.json read when reading shrinkwrap + ([@Lighting-Jack](https://github.com/Lighting-Jack)) +* [`1c65d26ac`](https://github.com/npm/cli/commit/1c65d26ac9f10ac0037094c207d216fbf0e969bf) + [#501](https://github.com/npm/cli/pull/501) + fix(fund): open url for string shorthand + ([@ruyadorno](https://github.com/ruyadorno)) +* [`ae7afe565`](https://github.com/npm/cli/commit/ae7afe56504dbffabf9f73d55b6dac1e3e9fed4a) + [#263](https://github.com/npm/cli/pull/263) + Don't log error message if git tagging is disabled + ([@woppa684](https://github.com/woppa684)) +* [`4c1b16f6a`](https://github.com/npm/cli/commit/4c1b16f6aecaf78956b9335734cfde2ac076ee11) + [#182](https://github.com/npm/cli/pull/182) + Warn the user that it is uninstalling npm-install + ([@Hoidberg](https://github.com/Hoidberg)) + ## 6.13.1 (2019-11-18) ### BUG FIXES diff --git a/deps/npm/Makefile b/deps/npm/Makefile index 11e656c43a458f..dde925f1c438ca 100644 --- a/deps/npm/Makefile +++ b/deps/npm/Makefile @@ -129,11 +129,11 @@ publish: gitclean ls-ok link docs-clean docs git push origin --tags &&\ node bin/npm-cli.js publish --tag=$(PUBLISHTAG) -release: gitclean ls-ok markedclean marked-manclean docs-clean doc +release: gitclean ls-ok markedclean marked-manclean docs-clean docs node bin/npm-cli.js prune --production --no-save @bash scripts/release.sh sandwich: @[ $$(whoami) = "root" ] && (echo "ok"; echo "ham" > sandwich) || (echo "make it yourself" && exit 13) -.PHONY: all latest install dev link doc clean uninstall test man docs-clean docclean release ls-ok realclean +.PHONY: all latest install dev link docs clean uninstall test man docs-clean docclean release ls-ok realclean diff --git a/deps/npm/bin/npm b/deps/npm/bin/npm index 737d1f17064890..4183703a7857e9 100755 --- a/deps/npm/bin/npm +++ b/deps/npm/bin/npm @@ -8,10 +8,6 @@ case `uname` in esac NODE_EXE="$basedir/node.exe" -if [ -x "$NODE_EXE" ] && [ -f "/bin/wslpath" ]; then # run the corresponding command prompt when Node for Windows is executed within WSL - cmd.exe /c `wslpath -w "$basedir/npm.cmd"` "$@" - exit $? -fi if ! [ -x "$NODE_EXE" ]; then NODE_EXE="$basedir/node" fi diff --git a/deps/npm/bin/npx b/deps/npm/bin/npx index 3516c8c415dba2..261e339850da5e 100644 --- a/deps/npm/bin/npx +++ b/deps/npm/bin/npx @@ -8,10 +8,6 @@ case `uname` in esac NODE_EXE="$basedir/node.exe" -if [ -x "$NODE_EXE" ] && [ -f "/bin/wslpath" ]; then # run the corresponding command prompt when Node for Windows is executed within WSL - cmd.exe /c `wslpath -w "$basedir/npx.cmd"` "$@" - exit $? -fi if ! [ -x "$NODE_EXE" ]; then NODE_EXE=node fi diff --git a/deps/npm/docs/public/cli-commands/npm-access/index.html b/deps/npm/docs/public/cli-commands/npm-access/index.html new file mode 100644 index 00000000000000..7a4103aaaedf44 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-access/index.html @@ -0,0 +1,145 @@ +

npm access

+

Set access level on published packages

+

Synopsis

+
npm access public [<package>]
+npm access restricted [<package>]
+
+npm access grant <read-only|read-write> <scope:team> [<package>]
+npm access revoke <scope:team> [<package>]
+
+npm access 2fa-required [<package>]
+npm access 2fa-not-required [<package>]
+
+npm access ls-packages [<user>|<scope>|<scope:team>]
+npm access ls-collaborators [<package> [<user>]]
+npm access edit [<package>]
+

Description

+

Used to set access controls on private packages.

+

For all of the subcommands, npm access will perform actions on the packages +in the current working directory if no package name is passed to the +subcommand.

+
    +
  • public / restricted: +Set a package to be either publicly accessible or restricted.
  • +
  • grant / revoke: +Add or remove the ability of users and teams to have read-only or read-write +access to a package.
  • +
  • 2fa-required / 2fa-not-required: +Configure whether a package requires that anyone publishing it have two-factor +authentication enabled on their account.
  • +
  • ls-packages: +Show all of the packages a user or a team is able to access, along with the +access level, except for read-only public packages (it won't print the whole +registry listing)
  • +
  • ls-collaborators: +Show all of the access privileges for a package. Will only show permissions +for packages to which you have at least read access. If <user> is passed in, +the list is filtered only to teams that user happens to belong to.
  • +
  • edit: +Set the access privileges for a package at once using $EDITOR.
  • +
+

Details

+

npm access always operates directly on the current registry, configurable +from the command line using --registry=<registry url>.

+

Unscoped packages are always public.

+

Scoped packages default to restricted, but you can either publish them as +public using npm publish --access=public, or set their access as public using +npm access public after the initial publish.

+

You must have privileges to set the access of a package:

+
    +
  • You are an owner of an unscoped or scoped package.
  • +
  • You are a member of the team that owns a scope.
  • +
  • You have been given read-write privileges for a package, either as a member +of a team or directly as an owner.
  • +
+

If you have two-factor authentication enabled then you'll have to pass in an +otp with --otp when making access changes.

+

If your account is not paid, then attempts to publish scoped packages will fail +with an HTTP 402 status code (logically enough), unless you use +--access=public.

+

Management of teams and team memberships is done with the npm team command.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-adduser/index.html b/deps/npm/docs/public/cli-commands/npm-adduser/index.html new file mode 100644 index 00000000000000..9c6a0432096eda --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-adduser/index.html @@ -0,0 +1,140 @@ +

+

section: cli-commands +title: npm-adduser +description: Set access level on published packages

+
+

npm adduser

+

Add a registry user account

+

Synopsis

+
npm adduser [--registry=url] [--scope=@orgname] [--always-auth] [--auth-type=legacy]
+
+aliases: login, add-user
+

Description

+

Create or verify a user named <username> in the specified registry, and +save the credentials to the .npmrc file. If no registry is specified, +the default registry will be used (see config).

+

The username, password, and email are read in from prompts.

+

To reset your password, go to https://www.npmjs.com/forgot

+

To change your email address, go to https://www.npmjs.com/email-edit

+

You may use this command multiple times with the same user account to +authorize on a new machine. When authenticating on a new machine, +the username, password and email address must all match with +your existing record.

+

npm login is an alias to adduser and behaves exactly the same way.

+

Configuration

+

registry

+

Default: https://registry.npmjs.org/

+

The base URL of the npm package registry. If scope is also specified, +this registry will only be used for packages with that scope. scope defaults +to the scope of the project directory you're currently in, if any. See scope.

+

scope

+

Default: none

+

If specified, the user and login credentials given will be associated +with the specified scope. See scope. You can use both at the same time, +e.g.

+
    npm adduser --registry=http://myregistry.example.com --scope=@myco
+

This will set a registry for the given scope and login or create a user for +that registry at the same time.

+

always-auth

+

Default: false

+

If specified, save configuration indicating that all requests to the given +registry should include authorization information. Useful for private +registries. Can be used with --registry and / or --scope, e.g.

+
    npm adduser --registry=http://private-registry.example.com --always-auth
+

This will ensure that all requests to that registry (including for tarballs) +include an authorization header. This setting may be necessary for use with +private registries where metadata and package tarballs are stored on hosts with +different hostnames. See always-auth in config for more details on always-auth. Registry-specific configuration of always-auth takes precedence over any global configuration.

+

auth-type

+
    +
  • Default: 'legacy'
  • +
  • Type: 'legacy', 'sso', 'saml', 'oauth'
  • +
+

What authentication strategy to use with adduser/login. Some npm registries +(for example, npmE) might support alternative auth strategies besides classic +username/password entry in legacy npm.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-audit/index.html b/deps/npm/docs/public/cli-commands/npm-audit/index.html new file mode 100644 index 00000000000000..96b3cda738bb77 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-audit/index.html @@ -0,0 +1,162 @@ +

npm audit

+

Run a security audit

+

Synopsis

+
npm audit [--json|--parseable|--audit-level=(low|moderate|high|critical)]
+npm audit fix [--force|--package-lock-only|--dry-run]
+
+common options: [--production] [--only=(dev|prod)]
+

Examples

+

Scan your project for vulnerabilities and automatically install any compatible +updates to vulnerable dependencies:

+
$ npm audit fix
+

Run audit fix without modifying node_modules, but still updating the +pkglock:

+
$ npm audit fix --package-lock-only
+

Skip updating devDependencies:

+
$ npm audit fix --only=prod
+

Have audit fix install semver-major updates to toplevel dependencies, not just +semver-compatible ones:

+
$ npm audit fix --force
+

Do a dry run to get an idea of what audit fix will do, and also output +install information in JSON format:

+
$ npm audit fix --dry-run --json
+

Scan your project for vulnerabilities and just show the details, without fixing +anything:

+
$ npm audit
+

Get the detailed audit report in JSON format:

+
$ npm audit --json
+

Get the detailed audit report in plain text result, separated by tab characters, allowing for +future reuse in scripting or command line post processing, like for example, selecting +some of the columns printed:

+
$ npm audit --parseable
+

To parse columns, you can use for example awk, and just print some of them:

+
$ npm audit --parseable | awk -F $'\t' '{print $1,$4}'
+

Fail an audit only if the results include a vulnerability with a level of moderate or higher:

+
$ npm audit --audit-level=moderate
+

Description

+

The audit command submits a description of the dependencies configured in +your project to your default registry and asks for a report of known +vulnerabilities. The report returned includes instructions on how to act on +this information. The command will exit with a 0 exit code if no +vulnerabilities were found.

+

You can also have npm automatically fix the vulnerabilities by running npm +audit fix. Note that some vulnerabilities cannot be fixed automatically and +will require manual intervention or review. Also note that since npm audit fix +runs a full-fledged npm install under the hood, all configs that apply to the +installer will also apply to npm install -- so things like npm audit fix +--package-lock-only will work as expected.

+

By default, the audit command will exit with a non-zero code if any vulnerability +is found. It may be useful in CI environments to include the --audit-level parameter +to specify the minimum vulnerability level that will cause the command to fail. This +option does not filter the report output, it simply changes the command's failure +threshold.

+

Content Submitted

+
    +
  • npm_version
  • +
  • node_version
  • +
  • platform
  • +
  • node_env
  • +
  • A scrubbed version of your package-lock.json or npm-shrinkwrap.json
  • +
+

Scrubbing

+

In order to ensure that potentially sensitive information is not included in +the audit data bundle, some dependencies may have their names (and sometimes +versions) replaced with opaque non-reversible identifiers. It is done for +the following dependency types:

+
    +
  • Any module referencing a scope that is configured for a non-default +registry has its name scrubbed. (That is, a scope you did a npm login --scope=@ourscope for.)
  • +
  • All git dependencies have their names and specifiers scrubbed.
  • +
  • All remote tarball dependencies have their names and specifiers scrubbed.
  • +
  • All local directory and tarball dependencies have their names and specifiers scrubbed.
  • +
+

The non-reversible identifiers are a sha256 of a session-specific UUID and the +value being replaced, ensuring a consistent value within the payload that is +different between runs.

+

Exit Code

+

The npm audit command will exit with a 0 exit code if no vulnerabilities were found.

+

If vulnerabilities were found the exit code will depend on the audit-level +configuration setting.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-bin/index.html b/deps/npm/docs/public/cli-commands/npm-bin/index.html new file mode 100644 index 00000000000000..d7069d3798c7ee --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-bin/index.html @@ -0,0 +1,91 @@ +

npm bin

+

Display npm bin folder

+

Synopsis

+
npm bin [-g|--global]
+

Description

+

Print the folder where npm will install executables.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-bugs/index.html b/deps/npm/docs/public/cli-commands/npm-bugs/index.html new file mode 100644 index 00000000000000..d2d1c7f4563e63 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-bugs/index.html @@ -0,0 +1,111 @@ +

npm bugs

+

Bugs for a package in a web browser maybe

+

Synopsis

+
npm bugs [<pkgname>]
+
+aliases: issues
+

Description

+

This command tries to guess at the likely location of a package's +bug tracker URL, and then tries to open it using the --browser +config param. If no package name is provided, it will search for +a package.json in the current folder and use the name property.

+

Configuration

+

browser

+
    +
  • Default: OS X: "open", Windows: "start", Others: "xdg-open"
  • +
  • Type: String
  • +
+

The browser that is called by the npm bugs command to open websites.

+

registry

+ +

The base URL of the npm package registry.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-build/index.html b/deps/npm/docs/public/cli-commands/npm-build/index.html new file mode 100644 index 00000000000000..4ef773207957b2 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-build/index.html @@ -0,0 +1,97 @@ +

npm build

+

Build a package

+

Synopsis

+
npm build [<package-folder>]
+
    +
  • <package-folder>: +A folder containing a package.json file in its root.
  • +
+

Description

+

This is the plumbing command called by npm link and npm install.

+

It should generally be called during installation, but if you need to run it +directly, run:

+
    npm run-script build
+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-bundle/index.html b/deps/npm/docs/public/cli-commands/npm-bundle/index.html new file mode 100644 index 00000000000000..017939b4ecfb91 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-bundle/index.html @@ -0,0 +1,88 @@ +

npm bundle

+

REMOVED

+

Description

+

The npm bundle command has been removed in 1.0, for the simple reason +that it is no longer necessary, as the default behavior is now to +install packages into the local space.

+

Just use npm install now to do what npm bundle used to do.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-cache/index.html b/deps/npm/docs/public/cli-commands/npm-cache/index.html new file mode 100644 index 00000000000000..974582d36a1b66 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-cache/index.html @@ -0,0 +1,142 @@ +

npm cache

+

Manipulates packages cache

+

Synopsis

+
npm cache add <tarball file>
+npm cache add <folder>
+npm cache add <tarball url>
+npm cache add <name>@<version>
+
+npm cache clean [<path>]
+aliases: npm cache clear, npm cache rm
+
+npm cache verify
+

Description

+

Used to add, list, or clean the npm cache folder.

+
    +
  • add: +Add the specified package to the local cache. This command is primarily +intended to be used internally by npm, but it can provide a way to +add data to the local installation cache explicitly.
  • +
  • clean: +Delete all data out of the cache folder.
  • +
  • verify: +Verify the contents of the cache folder, garbage collecting any unneeded data, +and verifying the integrity of the cache index and all cached data.
  • +
+

Details

+

npm stores cache data in an opaque directory within the configured cache, +named _cacache. This directory is a cacache-based content-addressable cache +that stores all http request data as well as other package-related data. This +directory is primarily accessed through pacote, the library responsible for +all package fetching as of npm@5.

+

All data that passes through the cache is fully verified for integrity on both +insertion and extraction. Cache corruption will either trigger an error, or +signal to pacote that the data must be refetched, which it will do +automatically. For this reason, it should never be necessary to clear the cache +for any reason other than reclaiming disk space, thus why clean now requires +--force to run.

+

There is currently no method exposed through npm to inspect or directly manage +the contents of this cache. In order to access it, cacache must be used +directly.

+

npm will not remove data by itself: the cache will grow as new packages are +installed.

+

A note about the cache's design

+

The npm cache is strictly a cache: it should not be relied upon as a persistent +and reliable data store for package data. npm makes no guarantee that a +previously-cached piece of data will be available later, and will automatically +delete corrupted contents. The primary guarantee that the cache makes is that, +if it does return data, that data will be exactly the data that was inserted.

+

To run an offline verification of existing cache contents, use npm cache +verify.

+

Configuration

+

cache

+

Default: ~/.npm on Posix, or %AppData%/npm-cache on Windows.

+

The root cache folder.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-ci/index.html b/deps/npm/docs/public/cli-commands/npm-ci/index.html new file mode 100644 index 00000000000000..f5620f496ae57c --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-ci/index.html @@ -0,0 +1,119 @@ +

npm ci

+

Install a project with a clean slate

+

Synopsis

+
npm ci
+

Example

+

Make sure you have a package-lock and an up-to-date install:

+
$ cd ./my/npm/project
+$ npm install
+added 154 packages in 10s
+$ ls | grep package-lock
+

Run npm ci in that project

+
$ npm ci
+added 154 packages in 5s
+

Configure Travis to build using npm ci instead of npm install:

+
# .travis.yml
+install:
+- npm ci
+# keep the npm cache around to speed up installs
+cache:
+  directories:
+  - "$HOME/.npm"
+

Description

+

This command is similar to npm install, except it's meant to be used in +automated environments such as test platforms, continuous integration, and +deployment -- or any situation where you want to make sure you're doing a clean +install of your dependencies. It can be significantly faster than a regular npm +install by skipping certain user-oriented features. It is also more strict than +a regular install, which can help catch errors or inconsistencies caused by the +incrementally-installed local environments of most npm users.

+

In short, the main differences between using npm install and npm ci are:

+
    +
  • The project must have an existing package-lock.json or npm-shrinkwrap.json.
  • +
  • If dependencies in the package lock do not match those in package.json, npm ci will exit with an error, instead of updating the package lock.
  • +
  • npm ci can only install entire projects at a time: individual dependencies cannot be added with this command.
  • +
  • If a node_modules is already present, it will be automatically removed before npm ci begins its install.
  • +
  • It will never write to package.json or any of the package-locks: installs are essentially frozen.
  • +
+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-completion/index.html b/deps/npm/docs/public/cli-commands/npm-completion/index.html new file mode 100644 index 00000000000000..3483cbc66784f2 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-completion/index.html @@ -0,0 +1,101 @@ +

npm completion

+

Tab Completion for npm

+

Synopsis

+
source <(npm completion)
+

Description

+

Enables tab-completion in all npm commands.

+

The synopsis above +loads the completions into your current shell. Adding it to +your ~/.bashrc or ~/.zshrc will make the completions available +everywhere:

+
npm completion >> ~/.bashrc
+npm completion >> ~/.zshrc
+

You may of course also pipe the output of npm completion to a file +such as /usr/local/etc/bash_completion.d/npm or +/etc/bash_completion.d/npm if you have a system that will read +that file for you.

+

When COMP_CWORD, COMP_LINE, and COMP_POINT are defined in the +environment, npm completion acts in "plumbing mode", and outputs +completions based on the arguments.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-config/index.html b/deps/npm/docs/public/cli-commands/npm-config/index.html new file mode 100644 index 00000000000000..f9beefcd4039b5 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-config/index.html @@ -0,0 +1,125 @@ +

npm config

+

Manage the npm configuration files

+

Synopsis

+
npm config set <key> <value> [-g|--global]
+npm config get <key>
+npm config delete <key>
+npm config list [-l] [--json]
+npm config edit
+npm get <key>
+npm set <key> <value> [-g|--global]
+
+aliases: c
+

Description

+

npm gets its config settings from the command line, environment +variables, npmrc files, and in some cases, the package.json file.

+

See npmrc for more information about the npmrc files.

+

See config for a more thorough discussion of the mechanisms +involved.

+

The npm config command can be used to update and edit the contents +of the user and global npmrc files.

+

Sub-commands

+

Config supports the following sub-commands:

+

set

+
npm config set key value
+

Sets the config key to the value.

+

If value is omitted, then it sets it to "true".

+

get

+
npm config get key
+

Echo the config value to stdout.

+

list

+
npm config list
+

Show all the config settings. Use -l to also show defaults. Use --json +to show the settings in json format.

+

delete

+
npm config delete key
+

Deletes the key from all configuration files.

+

edit

+
npm config edit
+

Opens the config file in an editor. Use the --global flag to edit the +global config.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-dedupe/index.html b/deps/npm/docs/public/cli-commands/npm-dedupe/index.html new file mode 100644 index 00000000000000..571a3a34f2e02d --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-dedupe/index.html @@ -0,0 +1,118 @@ +

npm dedupe

+

Reduce duplication

+

Synopsis

+
npm dedupe
+npm ddp
+
+aliases: find-dupes, ddp
+

Description

+

Searches the local package tree and attempts to simplify the overall +structure by moving dependencies further up the tree, where they can +be more effectively shared by multiple dependent packages.

+

For example, consider this dependency graph:

+
a
++-- b <-- depends on c@1.0.x
+|   `-- c@1.0.3
+`-- d <-- depends on c@~1.0.9
+    `-- c@1.0.10
+

In this case, npm dedupe will transform the tree to:

+
a
++-- b
++-- d
+`-- c@1.0.10
+

Because of the hierarchical nature of node's module lookup, b and d +will both get their dependency met by the single c package at the root +level of the tree.

+

The deduplication algorithm walks the tree, moving each dependency as far +up in the tree as possible, even if duplicates are not found. This will +result in both a flat and deduplicated tree.

+

If a suitable version exists at the target location in the tree +already, then it will be left untouched, but the other duplicates will +be deleted.

+

Arguments are ignored. Dedupe always acts on the entire tree.

+

Modules

+

Note that this operation transforms the dependency tree, but will never +result in new modules being installed.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-deprecate/index.html b/deps/npm/docs/public/cli-commands/npm-deprecate/index.html new file mode 100644 index 00000000000000..ef5df5c9a1339e --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-deprecate/index.html @@ -0,0 +1,97 @@ +

npm deprecate

+

Deprecate a version of a package

+

Synopsis

+
npm deprecate <pkg>[@<version>] <message>
+

Description

+

This command will update the npm registry entry for a package, providing +a deprecation warning to all who attempt to install it.

+

It works on version ranges as well as specific +versions, so you can do something like this:

+
npm deprecate my-thing@"< 0.2.3" "critical bug fixed in v0.2.3"
+

Note that you must be the package owner to deprecate something. See the +owner and adduser help topics.

+

To un-deprecate a package, specify an empty string ("") for the message +argument. Note that you must use double quotes with no space between them to +format an empty string.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-dist-tag/index.html b/deps/npm/docs/public/cli-commands/npm-dist-tag/index.html new file mode 100644 index 00000000000000..c560d919aa6d29 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-dist-tag/index.html @@ -0,0 +1,146 @@ +

+

section: cli-commands +title: npm-dist-tag +description: Modify package distribution tags

+
+

npm dist-tag

+

Modify package distribution tags

+

Synopsis

+
npm dist-tag add <pkg>@<version> [<tag>]
+npm dist-tag rm <pkg> <tag>
+npm dist-tag ls [<pkg>]
+
+aliases: dist-tags
+

Description

+

Add, remove, and enumerate distribution tags on a package:

+
    +
  • add: +Tags the specified version of the package with the specified tag, or the +--tag config if not specified. If you have two-factor authentication on +auth-and-writes then you’ll need to include a one-time password on the +command line with --otp <one-time password>.
  • +
  • rm: +Clear a tag that is no longer in use from the package.
  • +
  • ls: +Show all of the dist-tags for a package, defaulting to the package in +the current prefix. This is the default action if none is specified.
  • +
+

A tag can be used when installing packages as a reference to a version instead +of using a specific version number:

+
npm install <name>@<tag>
+

When installing dependencies, a preferred tagged version may be specified:

+
npm install --tag <tag>
+

This also applies to npm dedupe.

+

Publishing a package sets the latest tag to the published version unless the +--tag option is used. For example, npm publish --tag=beta.

+

By default, npm install <pkg> (without any @<version> or @<tag> +specifier) installs the latest tag.

+

Purpose

+

Tags can be used to provide an alias instead of version numbers.

+

For example, a project might choose to have multiple streams of development +and use a different tag for each stream, +e.g., stable, beta, dev, canary.

+

By default, the latest tag is used by npm to identify the current version of +a package, and npm install <pkg> (without any @<version> or @<tag> +specifier) installs the latest tag. Typically, projects only use the latest +tag for stable release versions, and use other tags for unstable versions such +as prereleases.

+

The next tag is used by some projects to identify the upcoming version.

+

By default, other than latest, no tag has any special significance to npm +itself.

+

Caveats

+

This command used to be known as npm tag, which only created new tags, and so +had a different syntax.

+

Tags must share a namespace with version numbers, because they are specified in +the same slot: npm install <pkg>@<version> vs npm install <pkg>@<tag>.

+

Tags that can be interpreted as valid semver ranges will be rejected. For +example, v1.4 cannot be used as a tag, because it is interpreted by semver as +>=1.4.0 <1.5.0. See https://github.com/npm/npm/issues/6082.

+

The simplest way to avoid semver problems with tags is to use tags that do not +begin with a number or the letter v.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-docs/index.html b/deps/npm/docs/public/cli-commands/npm-docs/index.html new file mode 100644 index 00000000000000..99ba5bed69f941 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-docs/index.html @@ -0,0 +1,112 @@ +

npm docs

+

Docs for a package in a web browser maybe

+

Synopsis

+
npm docs [<pkgname> [<pkgname> ...]]
+npm docs .
+npm home [<pkgname> [<pkgname> ...]]
+npm home .
+

Description

+

This command tries to guess at the likely location of a package's +documentation URL, and then tries to open it using the --browser +config param. You can pass multiple package names at once. If no +package name is provided, it will search for a package.json in +the current folder and use the name property.

+

Configuration

+

browser

+
    +
  • Default: OS X: "open", Windows: "start", Others: "xdg-open"
  • +
  • Type: String
  • +
+

The browser that is called by the npm docs command to open websites.

+

registry

+ +

The base URL of the npm package registry.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-doctor/index.html b/deps/npm/docs/public/cli-commands/npm-doctor/index.html new file mode 100644 index 00000000000000..1edad5dff749e6 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-doctor/index.html @@ -0,0 +1,160 @@ +

npm doctor

+

Check your environments

+

Synopsis

+
npm doctor
+

Description

+

npm doctor runs a set of checks to ensure that your npm installation has +what it needs to manage your JavaScript packages. npm is mostly a standalone tool, but it does +have some basic requirements that must be met:

+
    +
  • Node.js and git must be executable by npm.
  • +
  • The primary npm registry, registry.npmjs.com, or another service that uses +the registry API, is available.
  • +
  • The directories that npm uses, node_modules (both locally and globally), +exist and can be written by the current user.
  • +
  • The npm cache exists, and the package tarballs within it aren't corrupt.
  • +
+

Without all of these working properly, npm may not work properly. Many issues +are often attributable to things that are outside npm's code base, so npm +doctor confirms that the npm installation is in a good state.

+

Also, in addition to this, there are also very many issue reports due to using +old versions of npm. Since npm is constantly improving, running npm@latest is +better than an old version.

+

npm doctor verifies the following items in your environment, and if there are +any recommended changes, it will display them.

+

npm ping

+

By default, npm installs from the primary npm registry, registry.npmjs.org. +npm doctor hits a special ping endpoint within the registry. This can also be +checked with npm ping. If this check fails, you may be using a proxy that +needs to be configured, or may need to talk to your IT staff to get access over +HTTPS to registry.npmjs.org.

+

This check is done against whichever registry you've configured (you can see +what that is by running npm config get registry), and if you're using a +private registry that doesn't support the /whoami endpoint supported by the +primary registry, this check may fail.

+

npm -v

+

While Node.js may come bundled with a particular version of npm, it's the +policy of the CLI team that we recommend all users run npm@latest if they +can. As the CLI is maintained by a small team of contributors, there are only +resources for a single line of development, so npm's own long-term support +releases typically only receive critical security and regression fixes. The +team believes that the latest tested version of npm is almost always likely to +be the most functional and defect-free version of npm.

+

node -v

+

For most users, in most circumstances, the best version of Node will be the +latest long-term support (LTS) release. Those of you who want access to new +ECMAscript features or bleeding-edge changes to Node's standard library may be +running a newer version, and some of you may be required to run an older +version of Node because of enterprise change control policies. That's OK! But +in general, the npm team recommends that most users run Node.js LTS.

+

npm config get registry

+

Some of you may be installing from private package registries for your project +or company. That's great! Others of you may be following tutorials or +StackOverflow questions in an effort to troubleshoot problems you may be +having. Sometimes, this may entail changing the registry you're pointing at. +This part of npm doctor just lets you, and maybe whoever's helping you with +support, know that you're not using the default registry.

+

which git

+

While it's documented in the README, it may not be obvious that npm needs Git +installed to do many of the things that it does. Also, in some cases +– especially on Windows – you may have Git set up in such a way that it's not +accessible via your PATH so that npm can find it. This check ensures that Git +is available.

+

Permissions checks

+
    +
  • Your cache must be readable and writable by the user running npm.
  • +
  • Global package binaries must be writable by the user running npm.
  • +
  • Your local node_modules path, if you're running npm doctor with a project +directory, must be readable and writable by the user running npm.
  • +
+

Validate the checksums of cached packages

+

When an npm package is published, the publishing process generates a checksum +that npm uses at install time to verify that the package didn't get corrupted +in transit. npm doctor uses these checksums to validate the package tarballs +in your local cache (you can see where that cache is located with npm config +get cache, and see what's in that cache with npm cache ls – probably more +than you were expecting!). In the event that there are corrupt packages in your +cache, you should probably run npm cache clean and reset the cache.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-edit/index.html b/deps/npm/docs/public/cli-commands/npm-edit/index.html new file mode 100644 index 00000000000000..54e257bf84feef --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-edit/index.html @@ -0,0 +1,107 @@ +

npm edit

+

Edit an installed package

+

Synopsis

+
npm edit <pkg>[/<subpkg>...]
+

Description

+

Selects a (sub)dependency in the current +working directory and opens the package folder in the default editor +(or whatever you've configured as the npm editor config -- see +npm-config.)

+

After it has been edited, the package is rebuilt so as to pick up any +changes in compiled packages.

+

For instance, you can do npm install connect to install connect +into your package, and then npm edit connect to make a few +changes to your locally installed copy.

+

Configuration

+

editor

+
    +
  • Default: EDITOR environment variable if set, or "vi" on Posix, +or "notepad" on Windows.
  • +
  • Type: path
  • +
+

The command to run for npm edit or npm config edit.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-explore/index.html b/deps/npm/docs/public/cli-commands/npm-explore/index.html new file mode 100644 index 00000000000000..0b94db69d86c4e --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-explore/index.html @@ -0,0 +1,111 @@ +

+

section: cli-commands +title: npm-explore +description: Browse an installed package

+
+

npm explore

+

Browse an installed package

+

Synopsis

+
npm explore <pkg> [ -- <command>]
+

Description

+

Spawn a subshell in the directory of the installed package specified.

+

If a command is specified, then it is run in the subshell, which then +immediately terminates.

+

This is particularly handy in the case of git submodules in the +node_modules folder:

+
npm explore some-dependency -- git pull origin master
+

Note that the package is not automatically rebuilt afterwards, so be +sure to use npm rebuild <pkg> if you make any changes.

+

Configuration

+

shell

+
    +
  • Default: SHELL environment variable, or "bash" on Posix, or "cmd" on +Windows
  • +
  • Type: path
  • +
+

The shell to run for the npm explore command.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-fund/index.html b/deps/npm/docs/public/cli-commands/npm-fund/index.html new file mode 100644 index 00000000000000..77f637f4ba388c --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-fund/index.html @@ -0,0 +1,118 @@ +

npm fund

+

Retrieve funding information

+

Synopsis

+
    npm fund [<pkg>]
+

Description

+

This command retrieves information on how to fund the dependencies of +a given project. If no package name is provided, it will list all +dependencies that are looking for funding in a tree-structure in which +are listed the type of funding and the url to visit. If a package name +is provided then it tries to open its funding url using the --browser +config param.

+

The list will avoid duplicated entries and will stack all packages +that share the same type/url as a single entry. Given this nature the +list is not going to have the same shape of the output from npm ls.

+

Configuration

+

browser

+
    +
  • Default: OS X: "open", Windows: "start", Others: "xdg-open"
  • +
  • Type: String
  • +
+

The browser that is called by the npm fund command to open websites.

+

json

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Show information in JSON format.

+

unicode

+
    +
  • Type: Boolean
  • +
  • Default: true
  • +
+

Whether to represent the tree structure using unicode characters. +Set it to false in order to use all-ansi output.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-help-search/index.html b/deps/npm/docs/public/cli-commands/npm-help-search/index.html new file mode 100644 index 00000000000000..9c4a06fa9114d0 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-help-search/index.html @@ -0,0 +1,102 @@ +

npm help-search

+

Search npm help documentation

+

Synopsis

+
npm help-search <text>
+

Description

+

This command will search the npm markdown documentation files for the +terms provided, and then list the results, sorted by relevance.

+

If only one result is found, then it will show that help topic.

+

If the argument to npm help is not a known help topic, then it will +call help-search. It is rarely if ever necessary to call this +command directly.

+

Configuration

+

long

+
    +
  • Type: Boolean
  • +
  • Default: false
  • +
+

If true, the "long" flag will cause help-search to output context around +where the terms were found in the documentation.

+

If false, then help-search will just list out the help topics found.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-help/index.html b/deps/npm/docs/public/cli-commands/npm-help/index.html new file mode 100644 index 00000000000000..f6fb102efb1b3b --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-help/index.html @@ -0,0 +1,104 @@ +

npm help

+

Get help on npm

+

Synopsis

+
npm help <term> [<terms..>]
+

Description

+

If supplied a topic, then show the appropriate documentation page.

+

If the topic does not exist, or if multiple terms are provided, then run +the help-search command to find a match. Note that, if help-search +finds a single subject, then it will run help on that topic, so unique +matches are equivalent to specifying a topic name.

+

Configuration

+

viewer

+
    +
  • Default: "man" on Posix, "browser" on Windows
  • +
  • Type: path
  • +
+

The program to use to view help content.

+

Set to "browser" to view html help content in the default web browser.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-hook/index.html b/deps/npm/docs/public/cli-commands/npm-hook/index.html new file mode 100644 index 00000000000000..6556b3b3dc967d --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-hook/index.html @@ -0,0 +1,116 @@ +

npm hook

+

Manage registry hooks

+

Synopsis

+
npm hook ls [pkg]
+npm hook add <entity> <url> <secret>
+npm hook update <id> <url> [secret]
+npm hook rm <id>
+

Example

+

Add a hook to watch a package for changes:

+
$ npm hook add lodash https://example.com/ my-shared-secret
+

Add a hook to watch packages belonging to the user substack:

+
$ npm hook add ~substack https://example.com/ my-shared-secret
+

Add a hook to watch packages in the scope @npm

+
$ npm hook add @npm https://example.com/ my-shared-secret
+

List all your active hooks:

+
$ npm hook ls
+

List your active hooks for the lodash package:

+
$ npm hook ls lodash
+

Update an existing hook's url:

+
$ npm hook update id-deadbeef https://my-new-website.here/
+

Remove a hook:

+
$ npm hook rm id-deadbeef
+

Description

+

Allows you to manage npm hooks, +including adding, removing, listing, and updating.

+

Hooks allow you to configure URL endpoints that will be notified whenever a +change happens to any of the supported entity types. Three different types of +entities can be watched by hooks: packages, owners, and scopes.

+

To create a package hook, simply reference the package name.

+

To create an owner hook, prefix the owner name with ~ (as in, ~youruser).

+

To create a scope hook, prefix the scope name with @ (as in, @yourscope).

+

The hook id used by update and rm are the IDs listed in npm hook ls for +that particular hook.

+

The shared secret will be sent along to the URL endpoint so you can verify the +request came from your own configured hook.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-init/index.html b/deps/npm/docs/public/cli-commands/npm-init/index.html new file mode 100644 index 00000000000000..4f619bb65d0e7a --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-init/index.html @@ -0,0 +1,123 @@ +

npm init

+

create a package.json file

+

Synopsis

+
npm init [--force|-f|--yes|-y|--scope]
+npm init <@scope> (same as `npx <@scope>/create`)
+npm init [<@scope>/]<name> (same as `npx [<@scope>/]create-<name>`)
+

Examples

+

Create a new React-based project using create-react-app:

+
$ npm init react-app ./my-react-app
+

Create a new esm-compatible package using create-esm:

+
$ mkdir my-esm-lib && cd my-esm-lib
+$ npm init esm --yes
+

Generate a plain old package.json using legacy init:

+
$ mkdir my-npm-pkg && cd my-npm-pkg
+$ git init
+$ npm init
+

Generate it without having it ask any questions:

+
$ npm init -y
+

Description

+

npm init <initializer> can be used to set up a new or existing npm package.

+

initializer in this case is an npm package named create-<initializer>, which +will be installed by npx, and then have its main bin +executed -- presumably creating or updating package.json and running any other +initialization-related operations.

+

The init command is transformed to a corresponding npx operation as follows:

+
    +
  • npm init foo -> npx create-foo
  • +
  • npm init @usr/foo -> npx @usr/create-foo
  • +
  • npm init @usr -> npx @usr/create
  • +
+

Any additional options will be passed directly to the command, so npm init foo +--hello will map to npx create-foo --hello.

+

If the initializer is omitted (by just calling npm init), init will fall back +to legacy init behavior. It will ask you a bunch of questions, and then write a +package.json for you. It will attempt to make reasonable guesses based on +existing fields, dependencies, and options selected. It is strictly additive, so +it will keep any fields and values that were already set. You can also use +-y/--yes to skip the questionnaire altogether. If you pass --scope, it +will create a scoped package.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-install-ci-test/index.html b/deps/npm/docs/public/cli-commands/npm-install-ci-test/index.html new file mode 100644 index 00000000000000..8e54986627e34a --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-install-ci-test/index.html @@ -0,0 +1,90 @@ +

npm install-ci-test

+

Install a project with a clean slate and run tests

+

Synopsis

+
npm install-ci-test
+
+alias: npm cit
+

Description

+

This command runs an npm ci followed immediately by an npm test.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-install-test/index.html b/deps/npm/docs/public/cli-commands/npm-install-test/index.html new file mode 100644 index 00000000000000..7cde472b8564c7 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-install-test/index.html @@ -0,0 +1,99 @@ +

npm install-test

+

Install package(s) and run tests

+

Synopsis

+
npm install-test (with no args, in package dir)
+npm install-test [<@scope>/]<name>
+npm install-test [<@scope>/]<name>@<tag>
+npm install-test [<@scope>/]<name>@<version>
+npm install-test [<@scope>/]<name>@<version range>
+npm install-test <tarball file>
+npm install-test <tarball url>
+npm install-test <folder>
+
+alias: npm it
+common options: [--save|--save-dev|--save-optional] [--save-exact] [--dry-run]
+

Description

+

This command runs an npm install followed immediately by an npm test. It +takes exactly the same arguments as npm install.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-install/index.html b/deps/npm/docs/public/cli-commands/npm-install/index.html new file mode 100644 index 00000000000000..9ab2a20f5ecc62 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-install/index.html @@ -0,0 +1,465 @@ +

npm install

+

Install a package

+

Synopsis

+
npm install (with no args, in package dir)
+npm install [<@scope>/]<name>
+npm install [<@scope>/]<name>@<tag>
+npm install [<@scope>/]<name>@<version>
+npm install [<@scope>/]<name>@<version range>
+npm install <alias>@npm:<name>
+npm install <git-host>:<git-user>/<repo-name>
+npm install <git repo url>
+npm install <tarball file>
+npm install <tarball url>
+npm install <folder>
+
+aliases: npm i, npm add
+common options: [-P|--save-prod|-D|--save-dev|-O|--save-optional] [-E|--save-exact] [-B|--save-bundle] [--no-save] [--dry-run]
+

Description

+

This command installs a package, and any packages that it depends on. If the +package has a package-lock or shrinkwrap file, the installation of dependencies +will be driven by that, with an npm-shrinkwrap.json taking precedence if both +files exist. See package-lock.json and npm shrinkwrap.

+

A package is:

+
    +
  • a) a folder containing a program described by a package.json file
  • +
  • b) a gzipped tarball containing (a)
  • +
  • c) a url that resolves to (b)
  • +
  • d) a <name>@<version> that is published on the registry (see registry) with (c)
  • +
  • e) a <name>@<tag> (see npm dist-tag) that points to (d)
  • +
  • f) a <name> that has a "latest" tag satisfying (e)
  • +
  • g) a <git remote url> that resolves to (a)
  • +
+

Even if you never publish your package, you can still get a lot of +benefits of using npm if you just want to write a node program (a), and +perhaps if you also want to be able to easily install it elsewhere +after packing it up into a tarball (b).

+
    +
  • +

    npm install (in package directory, no arguments):

    +

    Install the dependencies in the local node_modules folder.

    +

    In global mode (ie, with -g or --global appended to the command), +it installs the current package context (ie, the current working +directory) as a global package.

    +

    By default, npm install will install all modules listed as dependencies +in package.json.

    +

    With the --production flag (or when the NODE_ENV environment variable +is set to production), npm will not install modules listed in +devDependencies. To install all modules listed in both dependencies +and devDependencies when NODE_ENV environment variable is set to production, +you can use --production=false.

    +
    +

    NOTE: The --production flag has no particular meaning when adding a +dependency to a project.

    +
    +
  • +
  • +

    npm install <folder>:

    +

    Install the package in the directory as a symlink in the current project. +Its dependencies will be installed before it's linked. If <folder> sits +inside the root of your project, its dependencies may be hoisted to the +toplevel node_modules as they would for other types of dependencies.

    +
  • +
  • +

    npm install <tarball file>:

    +

    Install a package that is sitting on the filesystem. Note: if you just want +to link a dev directory into your npm root, you can do this more easily by +using npm link.

    +

    Tarball requirements:

    +
      +
    • The filename must use .tar, .tar.gz, or .tgz as +the extension.
    • +
    • The package contents should reside in a subfolder inside the tarball (usually it is called package/). npm strips one directory layer when installing the package (an equivalent of tar x --strip-components=1 is run).
    • +
    • The package must contain a package.json file with name and version properties.
    • +
    +

    Example:

    +
      npm install ./package.tgz
    +
  • +
  • +

    npm install <tarball url>:

    +

    Fetch the tarball url, and then install it. In order to distinguish between +this and other options, the argument must start with "http://" or "https://"

    +

    Example:

    +
      npm install https://github.com/indexzero/forever/tarball/v0.5.6
    +
  • +
  • +

    npm install [<@scope>/]<name>:

    +

    Do a <name>@<tag> install, where <tag> is the "tag" config. (See +config. The config's default value is latest.)

    +

    In most cases, this will install the version of the modules tagged as +latest on the npm registry.

    +

    Example:

    +
      npm install sax
    +
  • +
  • +

    npm install <alias>@npm:<name>:

    +

    Install a package under a custom alias. Allows multiple versions of +a same-name package side-by-side, more convenient import names for +packages with otherwise long ones and using git forks replacements +or forked npm packages as replacements. Aliasing works only on your +project and does not rename packages in transitive dependencies. +Aliases should follow the naming conventions stated in +validate-npm-package-name.

    +

    Examples:

    +
      npm install my-react@npm:react
    +  npm install jquery2@npm:jquery@2
    +  npm install jquery3@npm:jquery@3
    +  npm install npa@npm:npm-package-arg
    +

    npm install saves any specified packages into dependencies by default. +Additionally, you can control where and how they get saved with some +additional flags:

    +
      +
    • -P, --save-prod: Package will appear in your dependencies. This is the +default unless -D or -O are present.
    • +
    • -D, --save-dev: Package will appear in your devDependencies.
    • +
    • -O, --save-optional: Package will appear in your optionalDependencies.
    • +
    • --no-save: Prevents saving to dependencies.
    • +
    +

    When using any of the above options to save dependencies to your +package.json, there are two additional, optional flags:

    +
      +
    • -E, --save-exact: Saved dependencies will be configured with an +exact version rather than using npm's default semver range +operator.
    • +
    • -B, --save-bundle: Saved dependencies will also be added to your bundleDependencies list.
    • +
    +

    Further, if you have an npm-shrinkwrap.json or package-lock.json then it +will be updated as well.

    +

    <scope> is optional. The package will be downloaded from the registry +associated with the specified scope. If no registry is associated with +the given scope the default registry is assumed. See scope.

    +

    Note: if you do not include the @-symbol on your scope name, npm will +interpret this as a GitHub repository instead, see below. Scopes names +must also be followed by a slash.

    +

    Examples:

    +
    npm install sax
    +npm install githubname/reponame
    +npm install @myorg/privatepackage
    +npm install node-tap --save-dev
    +npm install dtrace-provider --save-optional
    +npm install readable-stream --save-exact
    +npm install ansi-regex --save-bundle
    +

    Note: If there is a file or folder named <name> in the current +working directory, then it will try to install that, and only try to +fetch the package by name if it is not valid.

    +
  • +
  • +

    npm install [<@scope>/]<name>@<tag>:

    +

    Install the version of the package that is referenced by the specified tag. +If the tag does not exist in the registry data for that package, then this +will fail.

    +

    Example:

    +
    npm install sax@latest
    +npm install @myorg/mypackage@latest
    +
  • +
  • +

    npm install [<@scope>/]<name>@<version>:

    +

    Install the specified version of the package. This will fail if the +version has not been published to the registry.

    +

    Example:

    +
    npm install sax@0.1.1
    +npm install @myorg/privatepackage@1.5.0
    +
  • +
  • +

    npm install [<@scope>/]<name>@<version range>:

    +

    Install a version of the package matching the specified version range. This +will follow the same rules for resolving dependencies described in package.json.

    +

    Note that most version ranges must be put in quotes so that your shell will +treat it as a single argument.

    +

    Example:

    +
    npm install sax@">=0.1.0 <0.2.0"
    +npm install @myorg/privatepackage@">=0.1.0 <0.2.0"
    +
  • +
  • +

    npm install <git remote url>:

    +

    Installs the package from the hosted git provider, cloning it with git. +For a full git remote url, only that URL will be attempted.

    +
      <protocol>://[<user>[:<password>]@]<hostname>[:<port>][:][/]<path>[#<commit-ish> | #semver:<semver>]
    +

    <protocol> is one of git, git+ssh, git+http, git+https, or +git+file.

    +

    If #<commit-ish> is provided, it will be used to clone exactly that +commit. If the commit-ish has the format #semver:<semver>, <semver> can +be any valid semver range or exact version, and npm will look for any tags +or refs matching that range in the remote repository, much as it would for a +registry dependency. If neither #<commit-ish> or #semver:<semver> is +specified, then the default branch of the repository is used.

    +

    If the repository makes use of submodules, those submodules will be cloned +as well.

    +

    If the package being installed contains a prepare script, its +dependencies and devDependencies will be installed, and the prepare +script will be run, before the package is packaged and installed.

    +

    The following git environment variables are recognized by npm and will be +added to the environment when running git:

    +
      +
    • GIT_ASKPASS
    • +
    • GIT_EXEC_PATH
    • +
    • GIT_PROXY_COMMAND
    • +
    • GIT_SSH
    • +
    • GIT_SSH_COMMAND
    • +
    • GIT_SSL_CAINFO
    • +
    • GIT_SSL_NO_VERIFY
    • +
    +

    See the git man page for details.

    +

    Examples:

    +
    npm install git+ssh://git@github.com:npm/cli.git#v1.0.27
    +npm install git+ssh://git@github.com:npm/cli#semver:^5.0
    +npm install git+https://isaacs@github.com/npm/cli.git
    +npm install git://github.com/npm/cli.git#v1.0.27
    +GIT_SSH_COMMAND='ssh -i ~/.ssh/custom_ident' npm install git+ssh://git@github.com:npm/cli.git
    +
  • +
  • npm install <githubname>/<githubrepo>[#<commit-ish>]:
  • +
  • +

    npm install github:<githubname>/<githubrepo>[#<commit-ish>]:

    +

    Install the package at https://github.com/githubname/githubrepo by +attempting to clone it using git.

    +

    If #<commit-ish> is provided, it will be used to clone exactly that +commit. If the commit-ish has the format #semver:<semver>, <semver> can +be any valid semver range or exact version, and npm will look for any tags +or refs matching that range in the remote repository, much as it would for a +registry dependency. If neither #<commit-ish> or #semver:<semver> is +specified, then master is used.

    +

    As with regular git dependencies, dependencies and devDependencies will +be installed if the package has a prepare script, before the package is +done installing.

    +

    Examples:

    +
    npm install mygithubuser/myproject
    +npm install github:mygithubuser/myproject
    +
  • +
  • +

    npm install gist:[<githubname>/]<gistID>[#<commit-ish>|#semver:<semver>]:

    +

    Install the package at https://gist.github.com/gistID by attempting to +clone it using git. The GitHub username associated with the gist is +optional and will not be saved in package.json.

    +

    As with regular git dependencies, dependencies and devDependencies will +be installed if the package has a prepare script, before the package is +done installing.

    +

    Example:

    +
    npm install gist:101a11beef
    +
  • +
  • +

    npm install bitbucket:<bitbucketname>/<bitbucketrepo>[#<commit-ish>]:

    +

    Install the package at https://bitbucket.org/bitbucketname/bitbucketrepo +by attempting to clone it using git.

    +

    If #<commit-ish> is provided, it will be used to clone exactly that +commit. If the commit-ish has the format #semver:<semver>, <semver> can +be any valid semver range or exact version, and npm will look for any tags +or refs matching that range in the remote repository, much as it would for a +registry dependency. If neither #<commit-ish> or #semver:<semver> is +specified, then master is used.

    +

    As with regular git dependencies, dependencies and devDependencies will +be installed if the package has a prepare script, before the package is +done installing.

    +

    Example:

    +
    npm install bitbucket:mybitbucketuser/myproject
    +
  • +
  • +

    npm install gitlab:<gitlabname>/<gitlabrepo>[#<commit-ish>]:

    +

    Install the package at https://gitlab.com/gitlabname/gitlabrepo +by attempting to clone it using git.

    +

    If #<commit-ish> is provided, it will be used to clone exactly that +commit. If the commit-ish has the format #semver:<semver>, <semver> can +be any valid semver range or exact version, and npm will look for any tags +or refs matching that range in the remote repository, much as it would for a +registry dependency. If neither #<commit-ish> or #semver:<semver> is +specified, then master is used.

    +

    As with regular git dependencies, dependencies and devDependencies will +be installed if the package has a prepare script, before the package is +done installing.

    +

    Example:

    +
    npm install gitlab:mygitlabuser/myproject
    +npm install gitlab:myusr/myproj#semver:^5.0
    +
  • +
+

You may combine multiple arguments, and even multiple types of arguments. +For example:

+
npm install sax@">=0.1.0 <0.2.0" bench supervisor
+

The --tag argument will apply to all of the specified install targets. If a +tag with the given name exists, the tagged version is preferred over newer +versions.

+

The --dry-run argument will report in the usual way what the install would +have done without actually installing anything.

+

The --package-lock-only argument will only update the package-lock.json, +instead of checking node_modules and downloading dependencies.

+

The -f or --force argument will force npm to fetch remote resources even if a +local copy exists on disk.

+
npm install sax --force
+

The --no-fund argument will hide the message displayed at the end of each +install that acknowledges the number of dependencies looking for funding. +See npm-fund(1)

+

The -g or --global argument will cause npm to install the package globally +rather than locally. See folders.

+

The --global-style argument will cause npm to install the package into +your local node_modules folder with the same layout it uses with the +global node_modules folder. Only your direct dependencies will show in +node_modules and everything they depend on will be flattened in their +node_modules folders. This obviously will eliminate some deduping.

+

The --ignore-scripts argument will cause npm to not execute any +scripts defined in the package.json. See scripts.

+

The --legacy-bundling argument will cause npm to install the package such +that versions of npm prior to 1.4, such as the one included with node 0.8, +can install the package. This eliminates all automatic deduping.

+

The --link argument will cause npm to link global installs into the +local space in some cases.

+

The --no-bin-links argument will prevent npm from creating symlinks for +any binaries the package might contain.

+

The --no-optional argument will prevent optional dependencies from +being installed.

+

The --no-shrinkwrap argument, which will ignore an available +package lock or shrinkwrap file and use the package.json instead.

+

The --no-package-lock argument will prevent npm from creating a +package-lock.json file. When running with package-lock's disabled npm +will not automatically prune your node modules when installing.

+

The --nodedir=/path/to/node/source argument will allow npm to find the +node source code so that npm can compile native modules.

+

The --only={prod[uction]|dev[elopment]} argument will cause either only +devDependencies or only non-devDependencies to be installed regardless of the NODE_ENV.

+

The --no-audit argument can be used to disable sending of audit reports to +the configured registries. See npm-audit for details on what is sent.

+

See config. Many of the configuration params have some +effect on installation, since that's most of what npm does.

+

Algorithm

+

To install a package, npm uses the following algorithm:

+
load the existing node_modules tree from disk
+clone the tree
+fetch the package.json and assorted metadata and add it to the clone
+walk the clone and add any missing dependencies
+  dependencies will be added as close to the top as is possible
+  without breaking any other modules
+compare the original tree with the cloned tree and make a list of
+actions to take to convert one to the other
+execute all of the actions, deepest first
+  kinds of actions are install, update, remove and move
+

For this package{dep} structure: A{B,C}, B{C}, C{D}, +this algorithm produces:

+
A
++-- B
++-- C
++-- D
+

That is, the dependency from B to C is satisfied by the fact that A +already caused C to be installed at a higher level. D is still installed +at the top level because nothing conflicts with it.

+

For A{B,C}, B{C,D@1}, C{D@2}, this algorithm produces:

+
A
++-- B
++-- C
+   `-- D@2
++-- D@1
+

Because B's D@1 will be installed in the top level, C now has to install D@2 +privately for itself. This algorithm is deterministic, but different trees may +be produced if two dependencies are requested for installation in a different +order.

+

See folders for a more detailed description of the specific folder structures that npm creates.

+

Limitations of npm's Install Algorithm

+

npm will refuse to install any package with an identical name to the +current package. This can be overridden with the --force flag, but in +most cases can simply be addressed by changing the local package name.

+

There are some very rare and pathological edge-cases where a cycle can +cause npm to try to install a never-ending tree of packages. Here is +the simplest case:

+
A -> B -> A' -> B' -> A -> B -> A' -> B' -> A -> ...
+

where A is some version of a package, and A' is a different version +of the same package. Because B depends on a different version of A +than the one that is already in the tree, it must install a separate +copy. The same is true of A', which must install B'. Because B' +depends on the original version of A, which has been overridden, the +cycle falls into infinite regress.

+

To avoid this situation, npm flat-out refuses to install any +name@version that is already present anywhere in the tree of package +folder ancestors. A more correct, but more complex, solution would be +to symlink the existing version into the new location. If this ever +affects a real use-case, it will be investigated.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-link/index.html b/deps/npm/docs/public/cli-commands/npm-link/index.html new file mode 100644 index 00000000000000..330ea407c2767f --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-link/index.html @@ -0,0 +1,131 @@ +

npm link

+ +

Synopsis

+
npm link (in package dir)
+npm link [<@scope>/]<pkg>[@<version>]
+
+alias: npm ln
+

Description

+

Package linking is a two-step process.

+

First, npm link in a package folder will create a symlink in the global folder +{prefix}/lib/node_modules/<package> that links to the package where the npm +link command was executed. (see npm-config for the value of prefix). It +will also link any bins in the package to {prefix}/bin/{name}.

+

Next, in some other location, npm link package-name will create a +symbolic link from globally-installed package-name to node_modules/ +of the current folder.

+

Note that package-name is taken from package.json, +not from directory name.

+

The package name can be optionally prefixed with a scope. See scope. +The scope must be preceded by an @-symbol and followed by a slash.

+

When creating tarballs for npm publish, the linked packages are +"snapshotted" to their current state by resolving the symbolic links.

+

This is handy for installing your own stuff, so that you can work on it and +test it iteratively without having to continually rebuild.

+

For example:

+
    cd ~/projects/node-redis    # go into the package directory
+    npm link                    # creates global link
+    cd ~/projects/node-bloggy   # go into some other package directory.
+    npm link redis              # link-install the package
+

Now, any changes to ~/projects/node-redis will be reflected in +~/projects/node-bloggy/node_modules/node-redis/. Note that the link should +be to the package name, not the directory name for that package.

+

You may also shortcut the two steps in one. For example, to do the +above use-case in a shorter way:

+
cd ~/projects/node-bloggy  # go into the dir of your main project
+npm link ../node-redis     # link the dir of your dependency
+

The second line is the equivalent of doing:

+
(cd ../node-redis; npm link)
+npm link redis
+

That is, it first creates a global link, and then links the global +installation target into your project's node_modules folder.

+

Note that in this case, you are referring to the directory name, node-redis, +rather than the package name redis.

+

If your linked package is scoped (see scope) your link command must include that scope, e.g.

+
npm link @myorg/privatepackage
+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-logout/index.html b/deps/npm/docs/public/cli-commands/npm-logout/index.html new file mode 100644 index 00000000000000..a5126df803b915 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-logout/index.html @@ -0,0 +1,106 @@ +

npm logout

+

Log out of the registry

+

Synopsis

+
npm logout [--registry=<url>] [--scope=<@scope>]
+

Description

+

When logged into a registry that supports token-based authentication, tell the +server to end this token's session. This will invalidate the token everywhere +you're using it, not just for the current environment.

+

When logged into a legacy registry that uses username and password authentication, this will +clear the credentials in your user configuration. In this case, it will only affect +the current environment.

+

If --scope is provided, this will find the credentials for the registry +connected to that scope, if set.

+

Configuration

+

registry

+

Default: https://registry.npmjs.org/

+

The base URL of the npm package registry. If scope is also specified, +it takes precedence.

+

scope

+

Default: The scope of your current project, if any, otherwise none.

+

If specified, you will be logged out of the specified scope. See scope.

+
npm logout --scope=@myco
+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-ls/index.html b/deps/npm/docs/public/cli-commands/npm-ls/index.html new file mode 100644 index 00000000000000..5658a377e99742 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-ls/index.html @@ -0,0 +1,173 @@ +

npm ls

+

List installed packages

+

Synopsis

+
npm ls [[<@scope>/]<pkg> ...]
+
+aliases: list, la, ll
+

Description

+

This command will print to stdout all the versions of packages that are +installed, as well as their dependencies, in a tree-structure.

+

Positional arguments are name@version-range identifiers, which will +limit the results to only the paths to the packages named. Note that +nested packages will also show the paths to the specified packages. +For example, running npm ls promzard in npm's source tree will show:

+
    npm@6.13.4 /path/to/npm
+    └─┬ init-package-json@0.0.4
+      └── promzard@0.1.5
+

It will print out extraneous, missing, and invalid packages.

+

If a project specifies git urls for dependencies these are shown +in parentheses after the name@version to make it easier for users to +recognize potential forks of a project.

+

The tree shown is the logical dependency tree, based on package +dependencies, not the physical layout of your node_modules folder.

+

When run as ll or la, it shows extended information by default.

+

Configuration

+

json

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Show information in JSON format.

+

long

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Show extended information.

+

parseable

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Show parseable output instead of tree view.

+

global

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

List packages in the global install prefix instead of in the current +project.

+

depth

+
    +
  • Type: Int
  • +
+

Max display depth of the dependency tree.

+

prod / production

+
    +
  • Type: Boolean
  • +
  • Default: false
  • +
+

Display only the dependency tree for packages in dependencies.

+

dev / development

+
    +
  • Type: Boolean
  • +
  • Default: false
  • +
+

Display only the dependency tree for packages in devDependencies.

+

only

+
    +
  • Type: String
  • +
+

When "dev" or "development", is an alias to dev.

+

When "prod" or "production", is an alias to production.

+ +
    +
  • Type: Boolean
  • +
  • Default: false
  • +
+

Display only dependencies which are linked

+

unicode

+
    +
  • Type: Boolean
  • +
  • Default: true
  • +
+

Whether to represent the tree structure using unicode characters. +Set it to false in order to use all-ansi output.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-org/index.html b/deps/npm/docs/public/cli-commands/npm-org/index.html new file mode 100644 index 00000000000000..977f4e8cef976e --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-org/index.html @@ -0,0 +1,104 @@ +

npm org

+

Manage orgs

+

Synopsis

+
npm org set <orgname> <username> [developer | admin | owner]
+npm org rm <orgname> <username>
+npm org ls <orgname> [<username>]
+

Example

+

Add a new developer to an org:

+
$ npm org set my-org @mx-smith
+

Add a new admin to an org (or change a developer to an admin):

+
$ npm org set my-org @mx-santos admin
+

Remove a user from an org:

+
$ npm org rm my-org mx-santos
+

List all users in an org:

+
$ npm org ls my-org
+

List all users in JSON format:

+
$ npm org ls my-org --json
+

See what role a user has in an org:

+
$ npm org ls my-org @mx-santos
+

Description

+

You can use the npm org commands to manage and view users of an organization. +It supports adding and removing users, changing their roles, listing them, and +finding specific ones and their roles.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-outdated/index.html b/deps/npm/docs/public/cli-commands/npm-outdated/index.html new file mode 100644 index 00000000000000..98b2cf029157e7 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-outdated/index.html @@ -0,0 +1,175 @@ +

npm outdated

+

Check for outdated packages

+

Synopsis

+
npm outdated [[<@scope>/]<pkg> ...]
+

Description

+

This command will check the registry to see if any (or, specific) installed +packages are currently outdated.

+

In the output:

+
    +
  • wanted is the maximum version of the package that satisfies the semver +range specified in package.json. If there's no available semver range (i.e. +you're running npm outdated --global, or the package isn't included in +package.json), then wanted shows the currently-installed version.
  • +
  • latest is the version of the package tagged as latest in the registry. +Running npm publish with no special configuration will publish the package +with a dist-tag of latest. This may or may not be the maximum version of +the package, or the most-recently published version of the package, depending +on how the package's developer manages the latest dist-tag.
  • +
  • location is where in the dependency tree the package is located. Note that +npm outdated defaults to a depth of 0, so unless you override that, you'll +always be seeing only top-level dependencies that are outdated.
  • +
  • package type (when using --long / -l) tells you whether this package is +a dependency or a devDependency. Packages not included in package.json +are always marked dependencies.
  • +
  • homepage (when using --long / -l) is the homepage value contained in the package's package.json
  • +
  • Red means there's a newer version matching your semver requirements, so you should update now.
  • +
  • Yellow indicates that there's a newer version above your semver requirements (usually new major, or new 0.x minor) so proceed with caution.
  • +
+

An example

+
$ npm outdated
+Package      Current   Wanted   Latest  Location
+glob          5.0.15   5.0.15    6.0.1  test-outdated-output
+nothingness    0.0.3      git      git  test-outdated-output
+npm            3.5.1    3.5.2    3.5.1  test-outdated-output
+local-dev      0.0.3   linked   linked  test-outdated-output
+once           1.3.2    1.3.3    1.3.3  test-outdated-output
+

With these dependencies:

+
{
+  "glob": "^5.0.15",
+  "nothingness": "github:othiym23/nothingness#master",
+  "npm": "^3.5.1",
+  "once": "^1.3.1"
+}
+

A few things to note:

+
    +
  • glob requires ^5, which prevents npm from installing glob@6, which is +outside the semver range.
  • +
  • Git dependencies will always be reinstalled, because of how they're specified. +The installed committish might satisfy the dependency specifier (if it's +something immutable, like a commit SHA), or it might not, so npm outdated and +npm update have to fetch Git repos to check. This is why currently doing a +reinstall of a Git dependency always forces a new clone and install.
  • +
  • npm@3.5.2 is marked as "wanted", but "latest" is npm@3.5.1 because npm +uses dist-tags to manage its latest and next release channels. npm update +will install the newest version, but npm install npm (with no semver range) +will install whatever's tagged as latest.
  • +
  • once is just plain out of date. Reinstalling node_modules from scratch or +running npm update will bring it up to spec.
  • +
+

Configuration

+

json

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Show information in JSON format.

+

long

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Show extended information.

+

parseable

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Show parseable output instead of tree view.

+

global

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Check packages in the global install prefix instead of in the current +project.

+

depth

+
    +
  • Default: 0
  • +
  • Type: Int
  • +
+

Max depth for checking dependency tree.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-owner/index.html b/deps/npm/docs/public/cli-commands/npm-owner/index.html new file mode 100644 index 00000000000000..87d6510c7d37da --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-owner/index.html @@ -0,0 +1,111 @@ +

npm owner

+

Manage package owners

+

Synopsis

+
npm owner add <user> [<@scope>/]<pkg>
+npm owner rm <user> [<@scope>/]<pkg>
+npm owner ls [<@scope>/]<pkg>
+
+aliases: author
+

Description

+

Manage ownership of published packages.

+
    +
  • ls: +List all the users who have access to modify a package and push new versions. +Handy when you need to know who to bug for help.
  • +
  • add: +Add a new user as a maintainer of a package. This user is enabled to modify +metadata, publish new versions, and add other owners.
  • +
  • rm: +Remove a user from the package owner list. This immediately revokes their +privileges.
  • +
+

Note that there is only one level of access. Either you can modify a package, +or you can't. Future versions may contain more fine-grained access levels, but +that is not implemented at this time.

+

If you have two-factor authentication enabled with auth-and-writes then +you'll need to include an otp on the command line when changing ownership +with --otp.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-pack/index.html b/deps/npm/docs/public/cli-commands/npm-pack/index.html new file mode 100644 index 00000000000000..3db98ee2758b4a --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-pack/index.html @@ -0,0 +1,99 @@ +

npm pack

+

Create a tarball from a package

+

Synopsis

+
npm pack [[<@scope>/]<pkg>...] [--dry-run]
+

Description

+

For anything that's installable (that is, a package folder, tarball, +tarball url, name@tag, name@version, name, or scoped name), this +command will fetch it to the cache, and then copy the tarball to the +current working directory as <name>-<version>.tgz, and then write +the filenames out to stdout.

+

If the same package is specified multiple times, then the file will be +overwritten the second time.

+

If no arguments are supplied, then npm packs the current package folder.

+

The --dry-run argument will do everything that pack usually does without +actually packing anything. Reports on what would have gone into the tarball.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-ping/index.html b/deps/npm/docs/public/cli-commands/npm-ping/index.html new file mode 100644 index 00000000000000..202f197dd8a6e8 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-ping/index.html @@ -0,0 +1,92 @@ +

npm ping

+

Ping npm registry

+

Synopsis

+
npm ping [--registry <registry>]
+

Description

+

Ping the configured or given npm registry and verify authentication. +If it works it will output something like:

+
Ping success: {*Details about registry*}
+

otherwise you will get:

+
Ping error: {*Detail about error}
+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-prefix/index.html b/deps/npm/docs/public/cli-commands/npm-prefix/index.html new file mode 100644 index 00000000000000..35f8f6cdce2180 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-prefix/index.html @@ -0,0 +1,95 @@ +

npm prefix

+

Display prefix

+

Synopsis

+
npm prefix [-g]
+

Description

+

Print the local prefix to standard out. This is the closest parent directory +to contain a package.json file or node_modules directory, unless -g is +also specified.

+

If -g is specified, this will be the value of the global prefix. See +npm config for more detail.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-profile/index.html b/deps/npm/docs/public/cli-commands/npm-profile/index.html new file mode 100644 index 00000000000000..e8301c809d213a --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-profile/index.html @@ -0,0 +1,145 @@ +

npm profile

+

Change settings on your registry profile

+

Synopsis

+
npm profile get [--json|--parseable] [<property>]
+npm profile set [--json|--parseable] <property> <value>
+npm profile set password
+npm profile enable-2fa [auth-and-writes|auth-only]
+npm profile disable-2fa
+

Description

+

Change your profile information on the registry. This not be available if +you're using a non-npmjs registry.

+
    +
  • npm profile get [<property>]: +Display all of the properties of your profile, or one or more specific +properties. It looks like:
  • +
+
+-----------------+---------------------------+
+| name            | example                   |
++-----------------+---------------------------+
+| email           | me@example.com (verified) |
++-----------------+---------------------------+
+| two factor auth | auth-and-writes           |
++-----------------+---------------------------+
+| fullname        | Example User              |
++-----------------+---------------------------+
+| homepage        |                           |
++-----------------+---------------------------+
+| freenode        |                           |
++-----------------+---------------------------+
+| twitter         |                           |
++-----------------+---------------------------+
+| github          |                           |
++-----------------+---------------------------+
+| created         | 2015-02-26T01:38:35.892Z  |
++-----------------+---------------------------+
+| updated         | 2017-10-02T21:29:45.922Z  |
++-----------------+---------------------------+
+
    +
  • npm profile set <property> <value>: +Set the value of a profile property. You can set the following properties this way: +email, fullname, homepage, freenode, twitter, github
  • +
  • npm profile set password: +Change your password. This is interactive, you'll be prompted for your +current password and a new password. You'll also be prompted for an OTP +if you have two-factor authentication enabled.
  • +
  • +

    npm profile enable-2fa [auth-and-writes|auth-only]: +Enables two-factor authentication. Defaults to auth-and-writes mode. Modes are:

    +
      +
    • auth-only: Require an OTP when logging in or making changes to your +account's authentication. The OTP will be required on both the website +and the command line.
    • +
    • auth-and-writes: Requires an OTP at all the times auth-only does, and also requires one when +publishing a module, setting the latest dist-tag, or changing access +via npm access and npm owner.
    • +
    +
  • +
  • npm profile disable-2fa: +Disables two-factor authentication.
  • +
+

Details

+

All of the npm profile subcommands accept --json and --parseable and +will tailor their output based on those. Some of these commands may not be +available on non npmjs.com registries.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-prune/index.html b/deps/npm/docs/public/cli-commands/npm-prune/index.html new file mode 100644 index 00000000000000..34c2f9905f1c50 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-prune/index.html @@ -0,0 +1,105 @@ +

npm prune

+

Remove extraneous packages

+

Synopsis

+
npm prune [[<@scope>/]<pkg>...] [--production] [--dry-run] [--json]
+

Description

+

This command removes "extraneous" packages. If a package name is +provided, then only packages matching one of the supplied names are +removed.

+

Extraneous packages are packages that are not listed on the parent +package's dependencies list.

+

If the --production flag is specified or the NODE_ENV environment +variable is set to production, this command will remove the packages +specified in your devDependencies. Setting --no-production will +negate NODE_ENV being set to production.

+

If the --dry-run flag is used then no changes will actually be made.

+

If the --json flag is used then the changes npm prune made (or would +have made with --dry-run) are printed as a JSON object.

+

In normal operation with package-locks enabled, extraneous modules are +pruned automatically when modules are installed and you'll only need +this command with the --production flag.

+

If you've disabled package-locks then extraneous modules will not be removed +and it's up to you to run npm prune from time-to-time to remove them.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-publish/index.html b/deps/npm/docs/public/cli-commands/npm-publish/index.html new file mode 100644 index 00000000000000..8096dd81de6628 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-publish/index.html @@ -0,0 +1,137 @@ +

npm publish

+

Publish a package

+

Synopsis

+
npm publish [<tarball>|<folder>] [--tag <tag>] [--access <public|restricted>] [--otp otpcode] [--dry-run]
+
+Publishes '.' if no argument supplied
+Sets tag 'latest' if no --tag specified
+

Description

+

Publishes a package to the registry so that it can be installed by name. All +files in the package directory are included if no local .gitignore or +.npmignore file exists. If both files exist and a file is ignored by +.gitignore but not by .npmignore then it will be included. See +developers for full details on what's included in the published package, as well as details on how the package is built.

+

By default npm will publish to the public registry. This can be overridden by +specifying a different default registry or using a scope in the name (see package.json).

+
    +
  • <folder>: +A folder containing a package.json file
  • +
  • <tarball>: +A url or file path to a gzipped tar archive containing a single folder +with a package.json file inside.
  • +
  • [--tag <tag>] +Registers the published package with the given tag, such that npm install +<name>@<tag> will install this version. By default, npm publish updates +and npm install installs the latest tag. See npm-dist-tag for +details about tags.
  • +
  • [--access <public|restricted>] +Tells the registry whether this package should be published as public or +restricted. Only applies to scoped packages, which default to restricted. +If you don't have a paid account, you must publish with --access public +to publish scoped packages.
  • +
  • [--otp <otpcode>] +If you have two-factor authentication enabled in auth-and-writes mode +then you can provide a code from your authenticator with this. If you +don't include this and you're running from a TTY then you'll be prompted.
  • +
  • [--dry-run] +As of npm@6, does everything publish would do except actually publishing +to the registry. Reports the details of what would have been published.
  • +
+

Fails if the package name and version combination already exists in +the specified registry.

+

Once a package is published with a given name and version, that +specific name and version combination can never be used again, even if +it is removed with npm unpublish.

+

As of npm@5, both a sha1sum and an integrity field with a sha512sum of the +tarball will be submitted to the registry during publication. Subsequent +installs will use the strongest supported algorithm to verify downloads.

+

Similar to --dry-run see npm pack, which figures out the files to be +included and packs them into a tarball to be uploaded to the registry.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-rebuild/index.html b/deps/npm/docs/public/cli-commands/npm-rebuild/index.html new file mode 100644 index 00000000000000..cd37ea2810314e --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-rebuild/index.html @@ -0,0 +1,90 @@ +

npm rebuild

+

Rebuild a package

+

Synopsis

+
npm rebuild [[<@scope>/<name>]...]
+
+alias: npm rb
+

Description

+

This command runs the npm build command on the matched folders. This is useful when you install a new version of node, and must recompile all your C++ addons with the new binary.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-repo/index.html b/deps/npm/docs/public/cli-commands/npm-repo/index.html new file mode 100644 index 00000000000000..20bf77637ffb3b --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-repo/index.html @@ -0,0 +1,98 @@ +

npm repo

+

Open package repository page in the browser

+

Synopsis

+
npm repo [<pkg>]
+

Description

+

This command tries to guess at the likely location of a package's +repository URL, and then tries to open it using the --browser +config param. If no package name is provided, it will search for +a package.json in the current folder and use the name property.

+

Configuration

+

browser

+
    +
  • Default: OS X: "open", Windows: "start", Others: "xdg-open"
  • +
  • Type: String
  • +
+

The browser that is called by the npm repo command to open websites.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-restart/index.html b/deps/npm/docs/public/cli-commands/npm-restart/index.html new file mode 100644 index 00000000000000..16a9827976f183 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-restart/index.html @@ -0,0 +1,110 @@ +

npm restart

+

Restart a package

+

Synopsis

+
npm restart [-- <args>]
+

Description

+

This restarts a package.

+

This runs a package's "stop", "restart", and "start" scripts, and associated +pre- and post- scripts, in the order given below:

+
    +
  1. prerestart
  2. +
  3. prestop
  4. +
  5. stop
  6. +
  7. poststop
  8. +
  9. restart
  10. +
  11. prestart
  12. +
  13. start
  14. +
  15. poststart
  16. +
  17. postrestart
  18. +
+

Note

+

Note that the "restart" script is run in addition to the "stop" +and "start" scripts, not instead of them.

+

This is the behavior as of npm major version 2. A change in this +behavior will be accompanied by an increase in major version number

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-root/index.html b/deps/npm/docs/public/cli-commands/npm-root/index.html new file mode 100644 index 00000000000000..6c415ca02c99ae --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-root/index.html @@ -0,0 +1,91 @@ +

npm root

+

Display npm root

+

Synopsis

+
npm root [-g]
+

Description

+

Print the effective node_modules folder to standard out.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-run-script/index.html b/deps/npm/docs/public/cli-commands/npm-run-script/index.html new file mode 100644 index 00000000000000..7b437ad7a938f8 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-run-script/index.html @@ -0,0 +1,140 @@ +

npm run-script

+

Run arbitrary package scripts

+

Synopsis

+
npm run-script <command> [--silent] [-- <args>...]
+
+alias: npm run
+

Description

+

This runs an arbitrary command from a package's "scripts" object. If no +"command" is provided, it will list the available scripts. run[-script] is +used by the test, start, restart, and stop commands, but can be called +directly, as well. When the scripts in the package are printed out, they're +separated into lifecycle (test, start, restart) and directly-run scripts.

+

As of npm@2.0.0, you can +use custom arguments when executing scripts. The special option -- is used by +getopt to delimit the end of the options. npm will pass +all the arguments after the -- directly to your script:

+
npm run test -- --grep="pattern"
+

The arguments will only be passed to the script specified after npm run +and not to any pre or post script.

+

The env script is a special built-in command that can be used to list +environment variables that will be available to the script at runtime. If an +"env" command is defined in your package, it will take precedence over the +built-in.

+

In addition to the shell's pre-existing PATH, npm run adds +node_modules/.bin to the PATH provided to scripts. Any binaries provided by +locally-installed dependencies can be used without the node_modules/.bin +prefix. For example, if there is a devDependency on tap in your package, +you should write:

+
"scripts": {"test": "tap test/\*.js"}
+

instead of

+
"scripts": {"test": "node_modules/.bin/tap test/\*.js"}
+

to run your tests.

+

The actual shell your script is run within is platform dependent. By default, +on Unix-like systems it is the /bin/sh command, on Windows it is the cmd.exe. +The actual shell referred to by /bin/sh also depends on the system. +As of npm@5.1.0 you can +customize the shell with the script-shell configuration.

+

Scripts are run from the root of the module, regardless of what your current +working directory is when you call npm run. If you want your script to +use different behavior based on what subdirectory you're in, you can use the +INIT_CWD environment variable, which holds the full path you were in when +you ran npm run.

+

npm run sets the NODE environment variable to the node executable with +which npm is executed. Also, if the --scripts-prepend-node-path is passed, +the directory within which node resides is added to the +PATH. If --scripts-prepend-node-path=auto is passed (which has been the +default in npm v3), this is only performed when that node executable is +not found in the PATH.

+

If you try to run a script without having a node_modules directory and it fails, +you will be given a warning to run npm install, just in case you've forgotten.

+

You can use the --silent flag to prevent showing npm ERR! output on error.

+

You can use the --if-present flag to avoid exiting with a non-zero exit code +when the script is undefined. This lets you run potentially undefined scripts +without breaking the execution chain.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-search/index.html b/deps/npm/docs/public/cli-commands/npm-search/index.html new file mode 100644 index 00000000000000..b2e91e373cf91e --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-search/index.html @@ -0,0 +1,165 @@ +

npm search

+

Search for packages

+

Synopsis

+
npm search [-l|--long] [--json] [--parseable] [--no-description] [search terms ...]
+
+aliases: s, se, find
+

Description

+

Search the registry for packages matching the search terms. npm search +performs a linear, incremental, lexically-ordered search through package +metadata for all files in the registry. If color is enabled, it will further +highlight the matches in the results.

+

Additionally, using the --searchopts and --searchexclude options paired with +more search terms will respectively include and exclude further patterns. The +main difference between --searchopts and the standard search terms is that the +former does not highlight results in the output and can be used for more +fine-grained filtering. Additionally, both of these can be added to .npmrc for +default search filtering behavior.

+

Search also allows targeting of maintainers in search results, by prefixing +their npm username with =.

+

If a term starts with /, then it's interpreted as a regular expression and +supports standard JavaScript RegExp syntax. A trailing / will be ignored in +this case. (Note that many regular expression characters must be escaped or +quoted in most shells.)

+

A Note on caching

+

Configuration

+

description

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

Used as --no-description, disables search matching in package descriptions and +suppresses display of that field in results.

+

json

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Output search results as a JSON array.

+

parseable

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Output search results as lines with tab-separated columns.

+

long

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Display full package descriptions and other long text across multiple +lines. When disabled (default) search results are truncated to fit +neatly on a single line. Modules with extremely long names will +fall on multiple lines.

+

searchopts

+
    +
  • Default: ""
  • +
  • Type: String
  • +
+

Space-separated options that are always passed to search.

+

searchexclude

+
    +
  • Default: ""
  • +
  • Type: String
  • +
+

Space-separated options that limit the results from search.

+

searchstaleness

+
    +
  • Default: 900 (15 minutes)
  • +
  • Type: Number
  • +
+

The age of the cache, in seconds, before another registry request is made.

+

registry

+ +

Search the specified registry for modules. If you have configured npm to point +to a different default registry, such as your internal private module +repository, npm search will default to that registry when searching. Pass a +different registry url such as the default above in order to override this +setting.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-shrinkwrap/index.html b/deps/npm/docs/public/cli-commands/npm-shrinkwrap/index.html new file mode 100644 index 00000000000000..c4537b43edec05 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-shrinkwrap/index.html @@ -0,0 +1,98 @@ +

npm shrinkwrap

+

Lock down dependency versions for publication

+

Synopsis

+
npm shrinkwrap
+

Description

+

This command repurposes package-lock.json into a publishable +npm-shrinkwrap.json or simply creates a new one. The file created and updated +by this command will then take precedence over any other existing or future +package-lock.json files. For a detailed explanation of the design and purpose +of package locks in npm, see package-locks.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-star/index.html b/deps/npm/docs/public/cli-commands/npm-star/index.html new file mode 100644 index 00000000000000..f00ac985b1433a --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-star/index.html @@ -0,0 +1,93 @@ +

npm star

+

Mark your favorite packages

+

Synopsis

+
npm star [<pkg>...]
+npm unstar [<pkg>...]
+

Description

+

"Starring" a package means that you have some interest in it. It's +a vaguely positive way to show that you care.

+

"Unstarring" is the same thing, but in reverse.

+

It's a boolean thing. Starring repeatedly has no additional effect.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-stars/index.html b/deps/npm/docs/public/cli-commands/npm-stars/index.html new file mode 100644 index 00000000000000..ee36575ada2452 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-stars/index.html @@ -0,0 +1,93 @@ +

npm stars

+

View packages marked as favorites

+

Synopsis

+
npm stars [<user>]
+

Description

+

If you have starred a lot of neat things and want to find them again +quickly this command lets you do just that.

+

You may also want to see your friend's favorite packages, in this case +you will most certainly enjoy this command.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-start/index.html b/deps/npm/docs/public/cli-commands/npm-start/index.html new file mode 100644 index 00000000000000..c5b8984a11ecd2 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-start/index.html @@ -0,0 +1,95 @@ +

npm start

+

Start a package

+

Synopsis

+
npm start [-- <args>]
+

Description

+

This runs an arbitrary command specified in the package's "start" property of +its "scripts" object. If no "start" property is specified on the +"scripts" object, it will run node server.js.

+

As of npm@2.0.0, you can +use custom arguments when executing scripts. Refer to npm run-script for more details.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-stop/index.html b/deps/npm/docs/public/cli-commands/npm-stop/index.html new file mode 100644 index 00000000000000..3559b9b8ca3bf6 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-stop/index.html @@ -0,0 +1,91 @@ +

npm stop

+

Stop a package

+

Synopsis

+
npm stop [-- <args>]
+

Description

+

This runs a package's "stop" script, if one was provided.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-team/index.html b/deps/npm/docs/public/cli-commands/npm-team/index.html new file mode 100644 index 00000000000000..58c99f13f84da2 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-team/index.html @@ -0,0 +1,121 @@ +

npm team

+

Manage organization teams and team memberships

+

Synopsis

+
npm team create <scope:team>
+npm team destroy <scope:team>
+
+npm team add <scope:team> <user>
+npm team rm <scope:team> <user>
+
+npm team ls <scope>|<scope:team>
+
+npm team edit <scope:team>
+

Description

+

Used to manage teams in organizations, and change team memberships. Does not +handle permissions for packages.

+

Teams must always be fully qualified with the organization/scope they belong to +when operating on them, separated by a colon (:). That is, if you have a wombats team in a wisdom organization, you must always refer to that team as wisdom:wombats in these commands.

+
    +
  • create / destroy: +Create a new team, or destroy an existing one. Note: You cannot remove the developers team, learn more.
  • +
  • add / rm: +Add a user to an existing team, or remove a user from a team they belong to.
  • +
  • ls: +If performed on an organization name, will return a list of existing teams +under that organization. If performed on a team, it will instead return a list +of all users belonging to that particular team.
  • +
  • edit: +Edit a current team.
  • +
+

Details

+

npm team always operates directly on the current registry, configurable from +the command line using --registry=<registry url>.

+

In order to create teams and manage team membership, you must be a team admin +under the given organization. Listing teams and team memberships may be done by +any member of the organizations.

+

Organization creation and management of team admins and organization members +is done through the website, not the npm CLI.

+

To use teams to manage permissions on packages belonging to your organization, +use the npm access command to grant or revoke the appropriate permissions.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-test/index.html b/deps/npm/docs/public/cli-commands/npm-test/index.html new file mode 100644 index 00000000000000..f0a6a411dc1783 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-test/index.html @@ -0,0 +1,93 @@ +

npm test

+

Test a package

+

Synopsis

+
npm test [-- <args>]
+
+aliases: t, tst
+

Description

+

This runs a package's "test" script, if one was provided.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-token/index.html b/deps/npm/docs/public/cli-commands/npm-token/index.html new file mode 100644 index 00000000000000..f42f3b5e32e7f9 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-token/index.html @@ -0,0 +1,130 @@ +

npm token

+

Manage your authentication tokens

+

Synopsis

+
  npm token list [--json|--parseable]
+  npm token create [--read-only] [--cidr=1.1.1.1/24,2.2.2.2/16]
+  npm token revoke <id|token>
+

Description

+

This lets you list, create and revoke authentication tokens.

+
    +
  • npm token list: +Shows a table of all active authentication tokens. You can request this as +JSON with --json or tab-separated values with --parseable.
  • +
+
+--------+---------+------------+----------+----------------+
+| id     | token   | created    | read-only | CIDR whitelist |
++--------+---------+------------+----------+----------------+
+| 7f3134 | 1fa9ba… | 2017-10-02 | yes      |                |
++--------+---------+------------+----------+----------------+
+| c03241 | af7aef… | 2017-10-02 | no       | 192.168.0.1/24 |
++--------+---------+------------+----------+----------------+
+| e0cf92 | 3a436a… | 2017-10-02 | no       |                |
++--------+---------+------------+----------+----------------+
+| 63eb9d | 74ef35… | 2017-09-28 | no       |                |
++--------+---------+------------+----------+----------------+
+| 2daaa8 | cbad5f… | 2017-09-26 | no       |                |
++--------+---------+------------+----------+----------------+
+| 68c2fe | 127e51… | 2017-09-23 | no       |                |
++--------+---------+------------+----------+----------------+
+| 6334e1 | 1dadd1… | 2017-09-23 | no       |                |
++--------+---------+------------+----------+----------------+
+
    +
  • npm token create [--read-only] [--cidr=<cidr-ranges>]: +Create a new authentication token. It can be --read-only or accept a list of +CIDR ranges to +limit use of this token to. This will prompt you for your password, and, if you have +two-factor authentication enabled, an otp.
  • +
+
+----------------+--------------------------------------+
+| token          | a73c9572-f1b9-8983-983d-ba3ac3cc913d |
++----------------+--------------------------------------+
+| cidr_whitelist |                                      |
++----------------+--------------------------------------+
+| readonly       | false                                |
++----------------+--------------------------------------+
+| created        | 2017-10-02T07:52:24.838Z             |
++----------------+--------------------------------------+
+
    +
  • npm token revoke <token|id>: +This removes an authentication token, making it immediately unusable. This can accept +both complete tokens (as you get back from npm token create and will +find in your .npmrc) and ids as seen in the npm token list output. +This will NOT accept the truncated token found in npm token list output.
  • +

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-uninstall/index.html b/deps/npm/docs/public/cli-commands/npm-uninstall/index.html new file mode 100644 index 00000000000000..869c5d76cce8aa --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-uninstall/index.html @@ -0,0 +1,115 @@ +

npm uninstall

+

Remove a package

+

Synopsis

+
npm uninstall [<@scope>/]<pkg>[@<version>]... [-S|--save|-D|--save-dev|-O|--save-optional|--no-save]
+
+aliases: remove, rm, r, un, unlink
+

Description

+

This uninstalls a package, completely removing everything npm installed +on its behalf.

+

Example:

+
npm uninstall sax
+

In global mode (ie, with -g or --global appended to the command), +it uninstalls the current package context as a global package.

+

npm uninstall takes 3 exclusive, optional flags which save or update +the package version in your main package.json:

+
    +
  • -S, --save: Package will be removed from your dependencies.
  • +
  • -D, --save-dev: Package will be removed from your devDependencies.
  • +
  • -O, --save-optional: Package will be removed from your optionalDependencies.
  • +
  • --no-save: Package will not be removed from your package.json file.
  • +
+

Further, if you have an npm-shrinkwrap.json then it will be updated as +well.

+

Scope is optional and follows the usual rules for scope.

+

Examples:

+
npm uninstall sax --save
+npm uninstall @myorg/privatepackage --save
+npm uninstall node-tap --save-dev
+npm uninstall dtrace-provider --save-optional
+npm uninstall lodash --no-save
+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-unpublish/index.html b/deps/npm/docs/public/cli-commands/npm-unpublish/index.html new file mode 100644 index 00000000000000..ef80682fba888b --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-unpublish/index.html @@ -0,0 +1,110 @@ +

npm unpublish

+

Remove a package from the registry

+

Synopsis

+
npm unpublish [<@scope>/]<pkg>[@<version>]
+

Warning

+

It is generally considered bad behavior to remove versions of a library +that others are depending on!

+

Consider using the deprecate command +instead, if your intent is to encourage users to upgrade.

+

There is plenty of room on the registry.

+

Description

+

This removes a package version from the registry, deleting its +entry and removing the tarball.

+

If no version is specified, or if all versions are removed then +the root package entry is removed from the registry entirely.

+

Even if a package version is unpublished, that specific name and +version combination can never be reused. In order to publish the +package again, a new version number must be used. Additionally, +new versions of packages with every version unpublished may not +be republished until 24 hours have passed.

+

With the default registry (registry.npmjs.org), unpublish is +only allowed with versions published in the last 72 hours. If you +are trying to unpublish a version published longer ago than that, +contact support@npmjs.com.

+

The scope is optional and follows the usual rules for scope.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-update/index.html b/deps/npm/docs/public/cli-commands/npm-update/index.html new file mode 100644 index 00000000000000..e7db5859958bc5 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-update/index.html @@ -0,0 +1,163 @@ +

npm update

+

Update a package

+

Synopsis

+
npm update [-g] [<pkg>...]
+
+aliases: up, upgrade
+

Description

+

This command will update all the packages listed to the latest version +(specified by the tag config), respecting semver.

+

It will also install missing packages. As with all commands that install +packages, the --dev flag will cause devDependencies to be processed +as well.

+

If the -g flag is specified, this command will update globally installed +packages.

+

If no package name is specified, all packages in the specified location (global +or local) will be updated.

+

As of npm@2.6.1, the npm update will only inspect top-level packages. +Prior versions of npm would also recursively inspect all dependencies. +To get the old behavior, use npm --depth 9999 update.

+

As of npm@5.0.0, the npm update will change package.json to save the +new version as the minimum required dependency. To get the old behavior, +use npm update --no-save.

+

Example

+

IMPORTANT VERSION NOTE: these examples assume npm@2.6.1 or later. For +older versions of npm, you must specify --depth 0 to get the behavior +described below.

+

For the examples below, assume that the current package is app and it depends +on dependencies, dep1 (dep2, .. etc.). The published versions of dep1 are:

+
{
+  "dist-tags": { "latest": "1.2.2" },
+  "versions": [
+    "1.2.2",
+    "1.2.1",
+    "1.2.0",
+    "1.1.2",
+    "1.1.1",
+    "1.0.0",
+    "0.4.1",
+    "0.4.0",
+    "0.2.0"
+  ]
+}
+

Caret Dependencies

+

If app's package.json contains:

+
"dependencies": {
+  "dep1": "^1.1.1"
+}
+

Then npm update will install dep1@1.2.2, because 1.2.2 is latest and +1.2.2 satisfies ^1.1.1.

+

Tilde Dependencies

+

However, if app's package.json contains:

+
"dependencies": {
+  "dep1": "~1.1.1"
+}
+

In this case, running npm update will install dep1@1.1.2. Even though the latest +tag points to 1.2.2, this version does not satisfy ~1.1.1, which is equivalent +to >=1.1.1 <1.2.0. So the highest-sorting version that satisfies ~1.1.1 is used, +which is 1.1.2.

+

Caret Dependencies below 1.0.0

+

Suppose app has a caret dependency on a version below 1.0.0, for example:

+
"dependencies": {
+  "dep1": "^0.2.0"
+}
+

npm update will install dep1@0.2.0, because there are no other +versions which satisfy ^0.2.0.

+

If the dependence were on ^0.4.0:

+
"dependencies": {
+  "dep1": "^0.4.0"
+}
+

Then npm update will install dep1@0.4.1, because that is the highest-sorting +version that satisfies ^0.4.0 (>= 0.4.0 <0.5.0)

+

Updating Globally-Installed Packages

+

npm update -g will apply the update action to each globally installed +package that is outdated -- that is, has a version that is different from +latest.

+

NOTE: If a package has been upgraded to a version newer than latest, it will +be downgraded.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-version/index.html b/deps/npm/docs/public/cli-commands/npm-version/index.html new file mode 100644 index 00000000000000..442bd78028293d --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-version/index.html @@ -0,0 +1,177 @@ +

npm version

+

Bump a package version

+

Synopsis

+
npm version [<newversion> | major | minor | patch | premajor | preminor | prepatch | prerelease [--preid=<prerelease-id>] | from-git]
+
+'npm [-v | --version]' to print npm version
+'npm view <pkg> version' to view a package's published version
+'npm ls' to inspect current package/dependency versions
+

Description

+

Run this in a package directory to bump the version and write the new +data back to package.json, package-lock.json, and, if present, npm-shrinkwrap.json.

+

The newversion argument should be a valid semver string, a +valid second argument to semver.inc (one of patch, minor, major, +prepatch, preminor, premajor, prerelease), or from-git. In the second case, +the existing version will be incremented by 1 in the specified field. +from-git will try to read the latest git tag, and use that as the new npm version.

+

If run in a git repo, it will also create a version commit and tag. +This behavior is controlled by git-tag-version (see below), and can +be disabled on the command line by running npm --no-git-tag-version version. +It will fail if the working directory is not clean, unless the -f or +--force flag is set.

+

If supplied with -m or --message config option, npm will +use it as a commit message when creating a version commit. If the +message config contains %s then that will be replaced with the +resulting version number. For example:

+
npm version patch -m "Upgrade to %s for reasons"
+

If the sign-git-tag config is set, then the tag will be signed using +the -s flag to git. Note that you must have a default GPG key set up +in your git config for this to work properly. For example:

+
$ npm config set sign-git-tag true
+$ npm version patch
+
+You need a passphrase to unlock the secret key for
+user: "isaacs (http://blog.izs.me/) <i@izs.me>"
+2048-bit RSA key, ID 6C481CF6, created 2010-08-31
+
+Enter passphrase:
+

If preversion, version, or postversion are in the scripts property of +the package.json, they will be executed as part of running npm version.

+

The exact order of execution is as follows:

+
    +
  1. Check to make sure the git working directory is clean before we get started. +Your scripts may add files to the commit in future steps. +This step is skipped if the --force flag is set.
  2. +
  3. Run the preversion script. These scripts have access to the old version in package.json. +A typical use would be running your full test suite before deploying. +Any files you want added to the commit should be explicitly added using git add.
  4. +
  5. Bump version in package.json as requested (patch, minor, major, etc).
  6. +
  7. Run the version script. These scripts have access to the new version in package.json +(so they can incorporate it into file headers in generated files for example). +Again, scripts should explicitly add generated files to the commit using git add.
  8. +
  9. Commit and tag.
  10. +
  11. Run the postversion script. Use it to clean up the file system or automatically push +the commit and/or tag.
  12. +
+

Take the following example:

+
    "scripts": {
+      "preversion": "npm test",
+      "version": "npm run build && git add -A dist",
+      "postversion": "git push && git push --tags && rm -rf build/temp"
+    }
+

This runs all your tests, and proceeds only if they pass. Then runs your build script, and +adds everything in the dist directory to the commit. After the commit, it pushes the new commit +and tag up to the server, and deletes the build/temp directory.

+

Configuration

+

allow-same-version

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Prevents throwing an error when npm version is used to set the new version +to the same value as the current version.

+

git-tag-version

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

Commit and tag the version change.

+

commit-hooks

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

Run git commit hooks when committing the version change.

+

sign-git-tag

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Pass the -s flag to git to sign the tag.

+

Note that you must have a default GPG key set up in your git config for this to work properly.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-view/index.html b/deps/npm/docs/public/cli-commands/npm-view/index.html new file mode 100644 index 00000000000000..ffb7342d0fe1fa --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-view/index.html @@ -0,0 +1,142 @@ +

npm view

+

View registry info

+

Synopsis

+
npm view [<@scope>/]<name>[@<version>] [<field>[.<subfield>]...]
+
+aliases: info, show, v
+

Description

+

This command shows data about a package and prints it to the stream +referenced by the outfd config, which defaults to stdout.

+

To show the package registry entry for the connect package, you can do +this:

+
npm view connect
+

The default version is "latest" if unspecified.

+

Field names can be specified after the package descriptor. +For example, to show the dependencies of the ronn package at version +0.3.5, you could do the following:

+
npm view ronn@0.3.5 dependencies
+

You can view child fields by separating them with a period. +To view the git repository URL for the latest version of npm, you could +do this:

+
npm view npm repository.url
+

This makes it easy to view information about a dependency with a bit of +shell scripting. For example, to view all the data about the version of +opts that ronn depends on, you can do this:

+
npm view opts@$(npm view ronn dependencies.opts)
+

For fields that are arrays, requesting a non-numeric field will return +all of the values from the objects in the list. For example, to get all +the contributor names for the "express" project, you can do this:

+
npm view express contributors.email
+

You may also use numeric indices in square braces to specifically select +an item in an array field. To just get the email address of the first +contributor in the list, you can do this:

+
npm view express contributors[0].email
+

Multiple fields may be specified, and will be printed one after another. +For example, to get all the contributor names and email addresses, you +can do this:

+
npm view express contributors.name contributors.email
+

"Person" fields are shown as a string if they would be shown as an +object. So, for example, this will show the list of npm contributors in +the shortened string format. (See package.json for more on this.)

+
npm view npm contributors
+

If a version range is provided, then data will be printed for every +matching version of the package. This will show which version of jsdom +was required by each matching version of yui3:

+
npm view yui3@'>0.5.4' dependencies.jsdom
+

To show the connect package version history, you can do +this:

+
npm view connect versions
+

Output

+

If only a single string field for a single version is output, then it +will not be colorized or quoted, so as to enable piping the output to +another command. If the field is an object, it will be output as a JavaScript object literal.

+

If the --json flag is given, the outputted fields will be JSON.

+

If the version range matches multiple versions, than each printed value +will be prefixed with the version it applies to.

+

If multiple fields are requested, than each of them are prefixed with +the field name.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm-whoami/index.html b/deps/npm/docs/public/cli-commands/npm-whoami/index.html new file mode 100644 index 00000000000000..37249551ba1e66 --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm-whoami/index.html @@ -0,0 +1,89 @@ +

npm whoami

+

Display npm username

+

Synopsis

+
npm whoami [--registry <registry>]
+

Description

+

Print the username config to standard output.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/cli-commands/npm/index.html b/deps/npm/docs/public/cli-commands/npm/index.html new file mode 100644 index 00000000000000..96bdcfe10462df --- /dev/null +++ b/deps/npm/docs/public/cli-commands/npm/index.html @@ -0,0 +1,208 @@ +

npm

+

javascript package manager

+

Synopsis

+
npm <command> [args]
+

Version

+

6.13.4

+

Description

+

npm is the package manager for the Node JavaScript platform. It puts +modules in place so that node can find them, and manages dependency +conflicts intelligently.

+

It is extremely configurable to support a wide variety of use cases. +Most commonly, it is used to publish, discover, install, and develop node +programs.

+

Run npm help to get a list of available commands.

+

Important

+

npm is configured to use npm, Inc.'s public registry at +https://registry.npmjs.org by default. Use of the npm public registry is +subject to terms of use available at https://www.npmjs.com/policies/terms.

+

You can configure npm to use any compatible registry you like, and even run +your own registry. Use of someone else's registry may be governed by their +terms of use.

+

Introduction

+

You probably got npm because you want to install stuff.

+

Use npm install blerg to install the latest version of "blerg". Check out +npm install for more info. It can do a lot of stuff.

+

Use the npm search command to show everything that's available. +Use npm ls to show everything you've installed.

+

Dependencies

+

If a package references to another package with a git URL, npm depends +on a preinstalled git.

+

If one of the packages npm tries to install is a native node module and +requires compiling of C++ Code, npm will use +node-gyp for that task. +For a Unix system, node-gyp +needs Python, make and a buildchain like GCC. On Windows, +Python and Microsoft Visual Studio C++ are needed. Python 3 is +not supported by node-gyp. +For more information visit +the node-gyp repository and +the node-gyp Wiki.

+

Directories

+

See folders to learn about where npm puts stuff.

+

In particular, npm has two modes of operation:

+
    +
  • global mode: +npm installs packages into the install prefix at +prefix/lib/node_modules and bins are installed in prefix/bin.
  • +
  • local mode: +npm installs packages into the current project directory, which +defaults to the current working directory. Packages are installed to +./node_modules, and bins are installed to ./node_modules/.bin.
  • +
+

Local mode is the default. Use -g or --global on any command to +operate in global mode instead.

+

Developer Usage

+

If you're using npm to develop and publish your code, check out the +following help topics:

+
    +
  • json: +Make a package.json file. See package.json.
  • +
  • link: +For linking your current working code into Node's path, so that you +don't have to reinstall every time you make a change. Use +npm link to do this.
  • +
  • install: +It's a good idea to install things if you don't need the symbolic link. +Especially, installing other peoples code from the registry is done via +npm install
  • +
  • adduser: +Create an account or log in. Credentials are stored in the +user config file.
  • +
  • publish: +Use the npm publish command to upload your code to the registry.
  • +
+

Configuration

+

npm is extremely configurable. It reads its configuration options from +5 places.

+
    +
  • Command line switches: +Set a config with --key val. All keys take a value, even if they +are booleans (the config parser doesn't know what the options are at +the time of parsing). If no value is provided, then the option is set +to boolean true.
  • +
  • Environment Variables: +Set any config by prefixing the name in an environment variable with +npm_config_. For example, export npm_config_key=val.
  • +
  • User Configs: +The file at $HOME/.npmrc is an ini-formatted list of configs. If +present, it is parsed. If the userconfig option is set in the cli +or env, then that will be used instead.
  • +
  • Global Configs: +The file found at ../etc/npmrc (from the node executable, by default +this resolves to /usr/local/etc/npmrc) will be parsed if it is found. +If the globalconfig option is set in the cli, env, or user config, +then that file is parsed instead.
  • +
  • Defaults: +npm's default configuration options are defined in +lib/utils/config-defs.js. These must not be changed.
  • +
+

See config for much much more information.

+

Contributions

+

Patches welcome!

+

If you would like to contribute, but don't know what to work on, read +the contributing guidelines and check the issues list.

+ +

Bugs

+

When you find issues, please report them:

+ +

Be sure to follow the template and bug reporting guidelines. You can also ask +for help in the support forum if you're +unsure if it's actually a bug or are having trouble coming up with a detailed +reproduction to report.

+

Author

+

Isaac Z. Schlueter :: +isaacs :: +@izs :: +i@izs.me

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/configuring-npm/folders/index.html b/deps/npm/docs/public/configuring-npm/folders/index.html new file mode 100644 index 00000000000000..bf66afffd5d541 --- /dev/null +++ b/deps/npm/docs/public/configuring-npm/folders/index.html @@ -0,0 +1,237 @@ +

folders

+

Folder Structures Used by npm

+

Description

+

npm puts various things on your computer. That's its job.

+

This document will tell you what it puts where.

+

tl;dr

+
    +
  • Local install (default): puts stuff in ./node_modules of the current +package root.
  • +
  • Global install (with -g): puts stuff in /usr/local or wherever node +is installed.
  • +
  • Install it locally if you're going to require() it.
  • +
  • Install it globally if you're going to run it on the command line.
  • +
  • If you need both, then install it in both places, or use npm link.
  • +
+

prefix Configuration

+

The prefix config defaults to the location where node is installed. +On most systems, this is /usr/local. On Windows, it's %AppData%\npm. +On Unix systems, it's one level up, since node is typically installed at +{prefix}/bin/node rather than {prefix}/node.exe.

+

When the global flag is set, npm installs things into this prefix. +When it is not set, it uses the root of the current package, or the +current working directory if not in a package already.

+

Node Modules

+

Packages are dropped into the node_modules folder under the prefix. +When installing locally, this means that you can +require("packagename") to load its main module, or +require("packagename/lib/path/to/sub/module") to load other modules.

+

Global installs on Unix systems go to {prefix}/lib/node_modules. +Global installs on Windows go to {prefix}/node_modules (that is, no +lib folder.)

+

Scoped packages are installed the same way, except they are grouped together +in a sub-folder of the relevant node_modules folder with the name of that +scope prefix by the @ symbol, e.g. npm install @myorg/package would place +the package in {prefix}/node_modules/@myorg/package. See scope for more details.

+

If you wish to require() a package, then install it locally.

+

Executables

+

When in global mode, executables are linked into {prefix}/bin on Unix, +or directly into {prefix} on Windows.

+

When in local mode, executables are linked into +./node_modules/.bin so that they can be made available to scripts run +through npm. (For example, so that a test runner will be in the path +when you run npm test.)

+

Man Pages

+

When in global mode, man pages are linked into {prefix}/share/man.

+

When in local mode, man pages are not installed.

+

Man pages are not installed on Windows systems.

+

Cache

+

See npm cache. Cache files are stored in ~/.npm on Posix, or +%AppData%/npm-cache on Windows.

+

This is controlled by the cache configuration param.

+

Temp Files

+

Temporary files are stored by default in the folder specified by the +tmp config, which defaults to the TMPDIR, TMP, or TEMP environment +variables, or /tmp on Unix and c:\windows\temp on Windows.

+

Temp files are given a unique folder under this root for each run of the +program, and are deleted upon successful exit.

+

More Information

+

When installing locally, npm first tries to find an appropriate +prefix folder. This is so that npm install foo@1.2.3 will install +to the sensible root of your package, even if you happen to have cded +into some other folder.

+

Starting at the $PWD, npm will walk up the folder tree checking for a +folder that contains either a package.json file, or a node_modules +folder. If such a thing is found, then that is treated as the effective +"current directory" for the purpose of running npm commands. (This +behavior is inspired by and similar to git's .git-folder seeking +logic when running git commands in a working dir.)

+

If no package root is found, then the current folder is used.

+

When you run npm install foo@1.2.3, then the package is loaded into +the cache, and then unpacked into ./node_modules/foo. Then, any of +foo's dependencies are similarly unpacked into +./node_modules/foo/node_modules/....

+

Any bin files are symlinked to ./node_modules/.bin/, so that they may +be found by npm scripts when necessary.

+

Global Installation

+

If the global configuration is set to true, then npm will +install packages "globally".

+

For global installation, packages are installed roughly the same way, +but using the folders described above.

+

Cycles, Conflicts, and Folder Parsimony

+

Cycles are handled using the property of node's module system that it +walks up the directories looking for node_modules folders. So, at every +stage, if a package is already installed in an ancestor node_modules +folder, then it is not installed at the current location.

+

Consider the case above, where foo -> bar -> baz. Imagine if, in +addition to that, baz depended on bar, so you'd have: +foo -> bar -> baz -> bar -> baz .... However, since the folder +structure is: foo/node_modules/bar/node_modules/baz, there's no need to +put another copy of bar into .../baz/node_modules, since when it calls +require("bar"), it will get the copy that is installed in +foo/node_modules/bar.

+

This shortcut is only used if the exact same +version would be installed in multiple nested node_modules folders. It +is still possible to have a/node_modules/b/node_modules/a if the two +"a" packages are different versions. However, without repeating the +exact same package multiple times, an infinite regress will always be +prevented.

+

Another optimization can be made by installing dependencies at the +highest level possible, below the localized "target" folder.

+

Example

+

Consider this dependency graph:

+
foo
++-- blerg@1.2.5
++-- bar@1.2.3
+|   +-- blerg@1.x (latest=1.3.7)
+|   +-- baz@2.x
+|   |   `-- quux@3.x
+|   |       `-- bar@1.2.3 (cycle)
+|   `-- asdf@*
+`-- baz@1.2.3
+    `-- quux@3.x
+        `-- bar
+

In this case, we might expect a folder structure like this:

+
foo
++-- node_modules
+    +-- blerg (1.2.5) <---[A]
+    +-- bar (1.2.3) <---[B]
+    |   `-- node_modules
+    |       +-- baz (2.0.2) <---[C]
+    |       |   `-- node_modules
+    |       |       `-- quux (3.2.0)
+    |       `-- asdf (2.3.4)
+    `-- baz (1.2.3) <---[D]
+        `-- node_modules
+            `-- quux (3.2.0) <---[E]
+

Since foo depends directly on bar@1.2.3 and baz@1.2.3, those are +installed in foo's node_modules folder.

+

Even though the latest copy of blerg is 1.3.7, foo has a specific +dependency on version 1.2.5. So, that gets installed at [A]. Since the +parent installation of blerg satisfies bar's dependency on blerg@1.x, +it does not install another copy under [B].

+

Bar [B] also has dependencies on baz and asdf, so those are installed in +bar's node_modules folder. Because it depends on baz@2.x, it cannot +re-use the baz@1.2.3 installed in the parent node_modules folder [D], +and must install its own copy [C].

+

Underneath bar, the baz -> quux -> bar dependency creates a cycle. +However, because bar is already in quux's ancestry [B], it does not +unpack another copy of bar into that folder.

+

Underneath foo -> baz [D], quux's [E] folder tree is empty, because its +dependency on bar is satisfied by the parent folder copy installed at [B].

+

For a graphical breakdown of what is installed where, use npm ls.

+

Publishing

+

Upon publishing, npm will look in the node_modules folder. If any of +the items there are not in the bundledDependencies array, then they will +not be included in the package tarball.

+

This allows a package maintainer to install all of their dependencies +(and dev dependencies) locally, but only re-publish those items that +cannot be found elsewhere. See package.json for more information.

+

See also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/configuring-npm/install/index.html b/deps/npm/docs/public/configuring-npm/install/index.html new file mode 100644 index 00000000000000..2d220314d40c8b --- /dev/null +++ b/deps/npm/docs/public/configuring-npm/install/index.html @@ -0,0 +1,120 @@ +

install

+

Download and Install npm

+

Description

+

To publish and install packages to and from the public npm registry, you must install Node.js and the npm command line interface using either a Node version manager or a Node installer. We strongly recommend using a Node version manager to install Node.js and npm. We do not recommend using a Node installer, since the Node installation process installs npm in a directory with local permissions and can cause permissions errors when you run npm packages globally.

+

Overview

+ +

Checking your version of npm and Node.js

+

To see if you already have Node.js and npm installed and check the installed version, run the following commands:

+
node -v
+npm -v
+

Using a Node version manager to install Node.js and npm

+

Node version managers allow you to install and switch between multiple versions of Node.js and npm on your system so you can test your applications on multiple versions of npm to ensure they work for users on different versions.

+

OSX or Linux Node version managers

+ +

Windows Node version managers

+ +

Using a Node installer to install Node.js and npm

+

If you are unable to use a Node version manager, you can use a Node installer to install both Node.js and npm on your system.

+ +

OS X or Windows Node installers

+

If you're using OS X or Windows, use one of the installers from the Node.js download page. Be sure to install the version labeled LTS. Other versions have not yet been tested with npm.

+

Linux or other operating systems Node installers

+

If you're using Linux or another operating system, use one of the following installers:

+ +

Or see this page to install npm for Linux in the way many Linux developers prefer.

+

Less-common operating systems

+

For more information on installing Node.js on a variety of operating systems, see this page.

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/configuring-npm/npmrc/index.html b/deps/npm/docs/public/configuring-npm/npmrc/index.html new file mode 100644 index 00000000000000..efffdb4cfb40f8 --- /dev/null +++ b/deps/npm/docs/public/configuring-npm/npmrc/index.html @@ -0,0 +1,142 @@ +

npmrc

+

The npm config files

+

Description

+

npm gets its config settings from the command line, environment +variables, and npmrc files.

+

The npm config command can be used to update and edit the contents +of the user and global npmrc files.

+

For a list of available configuration options, see config.

+

Files

+

The four relevant files are:

+
    +
  • per-project config file (/path/to/my/project/.npmrc)
  • +
  • per-user config file (~/.npmrc)
  • +
  • global config file ($PREFIX/etc/npmrc)
  • +
  • npm builtin config file (/path/to/npm/npmrc)
  • +
+

All npm config files are an ini-formatted list of key = value +parameters. Environment variables can be replaced using +${VARIABLE_NAME}. For example:

+
prefix = ${HOME}/.npm-packages
+

Each of these files is loaded, and config options are resolved in +priority order. For example, a setting in the userconfig file would +override the setting in the globalconfig file.

+

Array values are specified by adding "[]" after the key name. For +example:

+
key[] = "first value"
+key[] = "second value"
+

Comments

+

Lines in .npmrc files are interpreted as comments when they begin with a ; or # character. .npmrc files are parsed by npm/ini, which specifies this comment syntax.

+

For example:

+
# last modified: 01 Jan 2016
+; Set a new registry for a scoped package
+@myscope:registry=https://mycustomregistry.example.org
+

Per-project config file

+

When working locally in a project, a .npmrc file in the root of the +project (ie, a sibling of node_modules and package.json) will set +config values specific to this project.

+

Note that this only applies to the root of the project that you're +running npm in. It has no effect when your module is published. For +example, you can't publish a module that forces itself to install +globally, or in a different location.

+

Additionally, this file is not read in global mode, such as when running +npm install -g.

+

Per-user config file

+

$HOME/.npmrc (or the userconfig param, if set in the environment +or on the command line)

+

Global config file

+

$PREFIX/etc/npmrc (or the globalconfig param, if set above): +This file is an ini-file formatted list of key = value parameters. +Environment variables can be replaced as above.

+

Built-in config file

+

path/to/npm/itself/npmrc

+

This is an unchangeable "builtin" configuration file that npm keeps +consistent across updates. Set fields in here using the ./configure +script that comes with npm. This is primarily for distribution +maintainers to override default configs in a standard and consistent +manner.

+

See also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/configuring-npm/package-json/index.html b/deps/npm/docs/public/configuring-npm/package-json/index.html new file mode 100644 index 00000000000000..da8a44c1c371d0 --- /dev/null +++ b/deps/npm/docs/public/configuring-npm/package-json/index.html @@ -0,0 +1,693 @@ +

package.json

+

Specifics of npm's package.json handling

+

Description

+

This document is all you need to know about what's required in your package.json +file. It must be actual JSON, not just a JavaScript object literal.

+

A lot of the behavior described in this document is affected by the config +settings described in config.

+

name

+

If you plan to publish your package, the most important things in your +package.json are the name and version fields as they will be required. The name +and version together form an identifier that is assumed to be completely unique. +Changes to the package should come along with changes to the version. If you don't +plan to publish your package, the name and version fields are optional.

+

The name is what your thing is called.

+

Some rules:

+
    +
  • The name must be less than or equal to 214 characters. This includes the scope for +scoped packages.
  • +
  • The names of scoped packages can begin with a dot or an underscore. This is not permitted without a scope.
  • +
  • New packages must not have uppercase letters in the name.
  • +
  • The name ends up being part of a URL, an argument on the command line, and a +folder name. Therefore, the name can't contain any non-URL-safe characters.
  • +
+

Some tips:

+
    +
  • Don't use the same name as a core Node module.
  • +
  • Don't put "js" or "node" in the name. It's assumed that it's js, since you're +writing a package.json file, and you can specify the engine using the "engines" +field. (See below.)
  • +
  • The name will probably be passed as an argument to require(), so it should +be something short, but also reasonably descriptive.
  • +
  • You may want to check the npm registry to see if there's something by that name +already, before you get too attached to it. https://www.npmjs.com/
  • +
+

A name can be optionally prefixed by a scope, e.g. @myorg/mypackage. See +scope for more detail.

+

version

+

If you plan to publish your package, the most important things in your +package.json are the name and version fields as they will be required. The name +and version together form an identifier that is assumed to be completely unique. +Changes to the package should come along with changes to the version. If you don't +plan to publish your package, the name and version fields are optional.

+

Version must be parseable by +node-semver, which is bundled +with npm as a dependency. (npm install semver to use it yourself.)

+

More on version numbers and ranges at semver.

+

description

+

Put a description in it. It's a string. This helps people discover your +package, as it's listed in npm search.

+

keywords

+

Put keywords in it. It's an array of strings. This helps people +discover your package as it's listed in npm search.

+

homepage

+

The url to the project homepage.

+

Example:

+
"homepage": "https://github.com/owner/project#readme"
+

bugs

+

The url to your project's issue tracker and / or the email address to which +issues should be reported. These are helpful for people who encounter issues +with your package.

+

It should look like this:

+
{ "url" : "https://github.com/owner/project/issues"
+, "email" : "project@hostname.com"
+}
+

You can specify either one or both values. If you want to provide only a url, +you can specify the value for "bugs" as a simple string instead of an object.

+

If a url is provided, it will be used by the npm bugs command.

+

license

+

You should specify a license for your package so that people know how they are +permitted to use it, and any restrictions you're placing on it.

+

If you're using a common license such as BSD-2-Clause or MIT, add a +current SPDX license identifier for the license you're using, like this:

+
{ "license" : "BSD-3-Clause" }
+

You can check the full list of SPDX license IDs. +Ideally you should pick one that is +OSI approved.

+

If your package is licensed under multiple common licenses, use an SPDX license +expression syntax version 2.0 string, like this:

+
{ "license" : "(ISC OR GPL-3.0)" }
+

If you are using a license that hasn't been assigned an SPDX identifier, or if +you are using a custom license, use a string value like this one:

+
{ "license" : "SEE LICENSE IN <filename>" }
+

Then include a file named <filename> at the top level of the package.

+

Some old packages used license objects or a "licenses" property containing an +array of license objects:

+
// Not valid metadata
+{ "license" :
+  { "type" : "ISC"
+  , "url" : "https://opensource.org/licenses/ISC"
+  }
+}
+
+// Not valid metadata
+{ "licenses" :
+  [
+    { "type": "MIT"
+    , "url": "https://www.opensource.org/licenses/mit-license.php"
+    }
+  , { "type": "Apache-2.0"
+    , "url": "https://opensource.org/licenses/apache2.0.php"
+    }
+  ]
+}
+

Those styles are now deprecated. Instead, use SPDX expressions, like this:

+
{ "license": "ISC" }
+
+{ "license": "(MIT OR Apache-2.0)" }
+

Finally, if you do not wish to grant others the right to use a private or +unpublished package under any terms:

+
{ "license": "UNLICENSED" }
+

Consider also setting "private": true to prevent accidental publication.

+

people fields: author, contributors

+

The "author" is one person. "contributors" is an array of people. A "person" +is an object with a "name" field and optionally "url" and "email", like this:

+
{ "name" : "Barney Rubble"
+, "email" : "b@rubble.com"
+, "url" : "http://barnyrubble.tumblr.com/"
+}
+

Or you can shorten that all into a single string, and npm will parse it for you:

+
"Barney Rubble <b@rubble.com> (http://barnyrubble.tumblr.com/)"
+

Both email and url are optional either way.

+

npm also sets a top-level "maintainers" field with your npm user info.

+

funding

+

You can specify an object containing an URL that provides up-to-date +information about ways to help fund development of your package:

+
"funding": {
+  "type" : "individual",
+  "url" : "http://example.com/donate"
+}
+
+"funding": {
+  "type" : "patreon",
+  "url" : "https://www.patreon.com/my-account"
+}
+

Users can use the npm fund subcommand to list the funding URLs of all +dependencies of their project, direct and indirect. A shortcut to visit each +funding url is also available when providing the project name such as: +npm fund <projectname>.

+

files

+

The optional files field is an array of file patterns that describes +the entries to be included when your package is installed as a +dependency. File patterns follow a similar syntax to .gitignore, but +reversed: including a file, directory, or glob pattern (*, **/*, and such) +will make it so that file is included in the tarball when it's packed. Omitting +the field will make it default to ["*"], which means it will include all files.

+

Some special files and directories are also included or excluded regardless of +whether they exist in the files array (see below).

+

You can also provide a .npmignore file in the root of your package or +in subdirectories, which will keep files from being included. At the +root of your package it will not override the "files" field, but in +subdirectories it will. The .npmignore file works just like a +.gitignore. If there is a .gitignore file, and .npmignore is +missing, .gitignore's contents will be used instead.

+

Files included with the "package.json#files" field cannot be excluded +through .npmignore or .gitignore.

+

Certain files are always included, regardless of settings:

+
    +
  • package.json
  • +
  • README
  • +
  • CHANGES / CHANGELOG / HISTORY
  • +
  • LICENSE / LICENCE
  • +
  • NOTICE
  • +
  • The file in the "main" field
  • +
+

README, CHANGES, LICENSE & NOTICE can have any case and extension.

+

Conversely, some files are always ignored:

+
    +
  • .git
  • +
  • CVS
  • +
  • .svn
  • +
  • .hg
  • +
  • .lock-wscript
  • +
  • .wafpickle-N
  • +
  • .*.swp
  • +
  • .DS_Store
  • +
  • ._*
  • +
  • npm-debug.log
  • +
  • .npmrc
  • +
  • node_modules
  • +
  • config.gypi
  • +
  • *.orig
  • +
  • package-lock.json (use shrinkwrap instead)
  • +
+

main

+

The main field is a module ID that is the primary entry point to your program. +That is, if your package is named foo, and a user installs it, and then does +require("foo"), then your main module's exports object will be returned.

+

This should be a module ID relative to the root of your package folder.

+

For most modules, it makes the most sense to have a main script and often not +much else.

+

browser

+

If your module is meant to be used client-side the browser field should be +used instead of the main field. This is helpful to hint users that it might +rely on primitives that aren't available in Node.js modules. (e.g. window)

+

bin

+

A lot of packages have one or more executable files that they'd like to +install into the PATH. npm makes this pretty easy (in fact, it uses this +feature to install the "npm" executable.)

+

To use this, supply a bin field in your package.json which is a map of +command name to local file name. On install, npm will symlink that file into +prefix/bin for global installs, or ./node_modules/.bin/ for local +installs.

+

For example, myapp could have this:

+
{ "bin" : { "myapp" : "./cli.js" } }
+

So, when you install myapp, it'll create a symlink from the cli.js script to +/usr/local/bin/myapp.

+

If you have a single executable, and its name should be the name +of the package, then you can just supply it as a string. For example:

+
{ "name": "my-program"
+, "version": "1.2.5"
+, "bin": "./path/to/program" }
+

would be the same as this:

+
{ "name": "my-program"
+, "version": "1.2.5"
+, "bin" : { "my-program" : "./path/to/program" } }
+

Please make sure that your file(s) referenced in bin starts with +#!/usr/bin/env node, otherwise the scripts are started without the node +executable!

+

man

+

Specify either a single file or an array of filenames to put in place for the +man program to find.

+

If only a single file is provided, then it's installed such that it is the +result from man <pkgname>, regardless of its actual filename. For example:

+
{ "name" : "foo"
+, "version" : "1.2.3"
+, "description" : "A packaged foo fooer for fooing foos"
+, "main" : "foo.js"
+, "man" : "./man/doc.1"
+}
+

would link the ./man/doc.1 file in such that it is the target for man foo

+

If the filename doesn't start with the package name, then it's prefixed. +So, this:

+
{ "name" : "foo"
+, "version" : "1.2.3"
+, "description" : "A packaged foo fooer for fooing foos"
+, "main" : "foo.js"
+, "man" : [ "./man/foo.1", "./man/bar.1" ]
+}
+

will create files to do man foo and man foo-bar.

+

Man files must end with a number, and optionally a .gz suffix if they are +compressed. The number dictates which man section the file is installed into.

+
{ "name" : "foo"
+, "version" : "1.2.3"
+, "description" : "A packaged foo fooer for fooing foos"
+, "main" : "foo.js"
+, "man" : [ "./man/foo.1", "./man/foo.2" ]
+}
+

will create entries for man foo and man 2 foo

+

directories

+

The CommonJS Packages spec details a +few ways that you can indicate the structure of your package using a directories +object. If you look at npm's package.json, +you'll see that it has directories for doc, lib, and man.

+

In the future, this information may be used in other creative ways.

+

directories.lib

+

Tell people where the bulk of your library is. Nothing special is done +with the lib folder in any way, but it's useful meta info.

+

directories.bin

+

If you specify a bin directory in directories.bin, all the files in +that folder will be added.

+

Because of the way the bin directive works, specifying both a +bin path and setting directories.bin is an error. If you want to +specify individual files, use bin, and for all the files in an +existing bin directory, use directories.bin.

+

directories.man

+

A folder that is full of man pages. Sugar to generate a "man" array by +walking the folder.

+

directories.doc

+

Put markdown files in here. Eventually, these will be displayed nicely, +maybe, someday.

+

directories.example

+

Put example scripts in here. Someday, it might be exposed in some clever way.

+

directories.test

+

Put your tests in here. It is currently not exposed, but it might be in the +future.

+

repository

+

Specify the place where your code lives. This is helpful for people who +want to contribute. If the git repo is on GitHub, then the npm docs +command will be able to find you.

+

Do it like this:

+
"repository": {
+  "type" : "git",
+  "url" : "https://github.com/npm/cli.git"
+}
+
+"repository": {
+  "type" : "svn",
+  "url" : "https://v8.googlecode.com/svn/trunk/"
+}
+

The URL should be a publicly available (perhaps read-only) url that can be handed +directly to a VCS program without any modification. It should not be a url to an +html project page that you put in your browser. It's for computers.

+

For GitHub, GitHub gist, Bitbucket, or GitLab repositories you can use the same +shortcut syntax you use for npm install:

+
"repository": "npm/npm"
+
+"repository": "github:user/repo"
+
+"repository": "gist:11081aaa281"
+
+"repository": "bitbucket:user/repo"
+
+"repository": "gitlab:user/repo"
+

If the package.json for your package is not in the root directory (for example +if it is part of a monorepo), you can specify the directory in which it lives:

+
"repository": {
+  "type" : "git",
+  "url" : "https://github.com/facebook/react.git",
+  "directory": "packages/react-dom"
+}
+

scripts

+

The "scripts" property is a dictionary containing script commands that are run +at various times in the lifecycle of your package. The key is the lifecycle +event, and the value is the command to run at that point.

+

See scripts to find out more about writing package scripts.

+

config

+

A "config" object can be used to set configuration parameters used in package +scripts that persist across upgrades. For instance, if a package had the +following:

+
{ "name" : "foo"
+, "config" : { "port" : "8080" } }
+

and then had a "start" command that then referenced the +npm_package_config_port environment variable, then the user could +override that by doing npm config set foo:port 8001.

+

See config and scripts for more on package +configs.

+

dependencies

+

Dependencies are specified in a simple object that maps a package name to a +version range. The version range is a string which has one or more +space-separated descriptors. Dependencies can also be identified with a +tarball or git URL.

+

Please do not put test harnesses or transpilers in your +dependencies object. See devDependencies, below.

+

See semver for more details about specifying version ranges.

+
    +
  • version Must match version exactly
  • +
  • >version Must be greater than version
  • +
  • >=version etc
  • +
  • <version
  • +
  • <=version
  • +
  • ~version "Approximately equivalent to version" See semver
  • +
  • ^version "Compatible with version" See semver
  • +
  • 1.2.x 1.2.0, 1.2.1, etc., but not 1.3.0
  • +
  • http://... See 'URLs as Dependencies' below
  • +
  • * Matches any version
  • +
  • "" (just an empty string) Same as *
  • +
  • version1 - version2 Same as >=version1 <=version2.
  • +
  • range1 || range2 Passes if either range1 or range2 are satisfied.
  • +
  • git... See 'Git URLs as Dependencies' below
  • +
  • user/repo See 'GitHub URLs' below
  • +
  • tag A specific version tagged and published as tag See npm dist-tag
  • +
  • path/path/path See Local Paths below
  • +
+

For example, these are all valid:

+
{ "dependencies" :
+  { "foo" : "1.0.0 - 2.9999.9999"
+  , "bar" : ">=1.0.2 <2.1.2"
+  , "baz" : ">1.0.2 <=2.3.4"
+  , "boo" : "2.0.1"
+  , "qux" : "<1.0.0 || >=2.3.1 <2.4.5 || >=2.5.2 <3.0.0"
+  , "asd" : "http://asdf.com/asdf.tar.gz"
+  , "til" : "~1.2"
+  , "elf" : "~1.2.3"
+  , "two" : "2.x"
+  , "thr" : "3.3.x"
+  , "lat" : "latest"
+  , "dyl" : "file:../dyl"
+  }
+}
+

URLs as Dependencies

+

You may specify a tarball URL in place of a version range.

+

This tarball will be downloaded and installed locally to your package at +install time.

+

Git URLs as Dependencies

+

Git urls are of the form:

+
<protocol>://[<user>[:<password>]@]<hostname>[:<port>][:][/]<path>[#<commit-ish> | #semver:<semver>]
+

<protocol> is one of git, git+ssh, git+http, git+https, or +git+file.

+

If #<commit-ish> is provided, it will be used to clone exactly that +commit. If the commit-ish has the format #semver:<semver>, <semver> can +be any valid semver range or exact version, and npm will look for any tags +or refs matching that range in the remote repository, much as it would for a +registry dependency. If neither #<commit-ish> or #semver:<semver> is +specified, then master is used.

+

Examples:

+
git+ssh://git@github.com:npm/cli.git#v1.0.27
+git+ssh://git@github.com:npm/cli#semver:^5.0
+git+https://isaacs@github.com/npm/cli.git
+git://github.com/npm/cli.git#v1.0.27
+

GitHub URLs

+

As of version 1.1.65, you can refer to GitHub urls as just "foo": +"user/foo-project". Just as with git URLs, a commit-ish suffix can be +included. For example:

+
{
+  "name": "foo",
+  "version": "0.0.0",
+  "dependencies": {
+    "express": "expressjs/express",
+    "mocha": "mochajs/mocha#4727d357ea",
+    "module": "user/repo#feature\/branch"
+  }
+}
+

Local Paths

+

As of version 2.0.0 you can provide a path to a local directory that contains a +package. Local paths can be saved using npm install -S or +npm install --save, using any of these forms:

+
../foo/bar
+~/foo/bar
+./foo/bar
+/foo/bar
+

in which case they will be normalized to a relative path and added to your +package.json. For example:

+
{
+  "name": "baz",
+  "dependencies": {
+    "bar": "file:../foo/bar"
+  }
+}
+

This feature is helpful for local offline development and creating +tests that require npm installing where you don't want to hit an +external server, but should not be used when publishing packages +to the public registry.

+

devDependencies

+

If someone is planning on downloading and using your module in their +program, then they probably don't want or need to download and build +the external test or documentation framework that you use.

+

In this case, it's best to map these additional items in a devDependencies +object.

+

These things will be installed when doing npm link or npm install +from the root of a package, and can be managed like any other npm +configuration param. See config for more on the topic.

+

For build steps that are not platform-specific, such as compiling +CoffeeScript or other languages to JavaScript, use the prepare +script to do this, and make the required package a devDependency.

+

For example:

+
{ "name": "ethopia-waza",
+  "description": "a delightfully fruity coffee varietal",
+  "version": "1.2.3",
+  "devDependencies": {
+    "coffee-script": "~1.6.3"
+  },
+  "scripts": {
+    "prepare": "coffee -o lib/ -c src/waza.coffee"
+  },
+  "main": "lib/waza.js"
+}
+

The prepare script will be run before publishing, so that users +can consume the functionality without requiring them to compile it +themselves. In dev mode (ie, locally running npm install), it'll +run this script as well, so that you can test it easily.

+

peerDependencies

+

In some cases, you want to express the compatibility of your package with a +host tool or library, while not necessarily doing a require of this host. +This is usually referred to as a plugin. Notably, your module may be exposing +a specific interface, expected and specified by the host documentation.

+

For example:

+
{
+  "name": "tea-latte",
+  "version": "1.3.5",
+  "peerDependencies": {
+    "tea": "2.x"
+  }
+}
+

This ensures your package tea-latte can be installed along with the second +major version of the host package tea only. npm install tea-latte could +possibly yield the following dependency graph:

+
├── tea-latte@1.3.5
+└── tea@2.2.0
+

NOTE: npm versions 1 and 2 will automatically install peerDependencies if +they are not explicitly depended upon higher in the dependency tree. In the +next major version of npm (npm@3), this will no longer be the case. You will +receive a warning that the peerDependency is not installed instead. The +behavior in npms 1 & 2 was frequently confusing and could easily put you into +dependency hell, a situation that npm is designed to avoid as much as possible.

+

Trying to install another plugin with a conflicting requirement will cause an +error. For this reason, make sure your plugin requirement is as broad as +possible, and not to lock it down to specific patch versions.

+

Assuming the host complies with semver, only changes in +the host package's major version will break your plugin. Thus, if you've worked +with every 1.x version of the host package, use "^1.0" or "1.x" to express +this. If you depend on features introduced in 1.5.2, use ">= 1.5.2 < 2".

+

bundledDependencies

+

This defines an array of package names that will be bundled when publishing +the package.

+

In cases where you need to preserve npm packages locally or have them +available through a single file download, you can bundle the packages in a +tarball file by specifying the package names in the bundledDependencies +array and executing npm pack.

+

For example:

+

If we define a package.json like this:

+
{
+  "name": "awesome-web-framework",
+  "version": "1.0.0",
+  "bundledDependencies": [
+    "renderized", "super-streams"
+  ]
+}
+

we can obtain awesome-web-framework-1.0.0.tgz file by running npm pack. +This file contains the dependencies renderized and super-streams which +can be installed in a new project by executing npm install +awesome-web-framework-1.0.0.tgz. Note that the package names do not include +any versions, as that information is specified in dependencies.

+

If this is spelled "bundleDependencies", then that is also honored.

+

optionalDependencies

+

If a dependency can be used, but you would like npm to proceed if it cannot be +found or fails to install, then you may put it in the optionalDependencies +object. This is a map of package name to version or url, just like the +dependencies object. The difference is that build failures do not cause +installation to fail.

+

It is still your program's responsibility to handle the lack of the +dependency. For example, something like this:

+
try {
+  var foo = require('foo')
+  var fooVersion = require('foo/package.json').version
+} catch (er) {
+  foo = null
+}
+if ( notGoodFooVersion(fooVersion) ) {
+  foo = null
+}
+
+// .. then later in your program ..
+
+if (foo) {
+  foo.doFooThings()
+}
+

Entries in optionalDependencies will override entries of the same name in +dependencies, so it's usually best to only put in one place.

+

engines

+

You can specify the version of node that your stuff works on:

+
{ "engines" : { "node" : ">=0.10.3 <0.12" } }
+

And, like with dependencies, if you don't specify the version (or if you +specify "*" as the version), then any version of node will do.

+

If you specify an "engines" field, then npm will require that "node" be +somewhere on that list. If "engines" is omitted, then npm will just assume +that it works on node.

+

You can also use the "engines" field to specify which versions of npm +are capable of properly installing your program. For example:

+
{ "engines" : { "npm" : "~1.0.20" } }
+

Unless the user has set the engine-strict config flag, this +field is advisory only and will only produce warnings when your package is installed as a dependency.

+

engineStrict

+

This feature was removed in npm 3.0.0

+

Prior to npm 3.0.0, this feature was used to treat this package as if the +user had set engine-strict. It is no longer used.

+

os

+

You can specify which operating systems your +module will run on:

+
"os" : [ "darwin", "linux" ]
+

You can also blacklist instead of whitelist operating systems, +just prepend the blacklisted os with a '!':

+
"os" : [ "!win32" ]
+

The host operating system is determined by process.platform

+

It is allowed to both blacklist, and whitelist, although there isn't any +good reason to do this.

+

cpu

+

If your code only runs on certain cpu architectures, +you can specify which ones.

+
"cpu" : [ "x64", "ia32" ]
+

Like the os option, you can also blacklist architectures:

+
"cpu" : [ "!arm", "!mips" ]
+

The host architecture is determined by process.arch

+

preferGlobal

+

DEPRECATED

+

This option used to trigger an npm warning, but it will no longer warn. It is +purely there for informational purposes. It is now recommended that you install +any binaries as local devDependencies wherever possible.

+

private

+

If you set "private": true in your package.json, then npm will refuse +to publish it.

+

This is a way to prevent accidental publication of private repositories. If +you would like to ensure that a given package is only ever published to a +specific registry (for example, an internal registry), then use the +publishConfig dictionary described below to override the registry config +param at publish-time.

+

publishConfig

+

This is a set of config values that will be used at publish-time. It's +especially handy if you want to set the tag, registry or access, so that +you can ensure that a given package is not tagged with "latest", published +to the global public registry or that a scoped module is private by default.

+

Any config values can be overridden, but only "tag", "registry" and "access" +probably matter for the purposes of publishing.

+

See config to see the list of config options that can be +overridden.

+

DEFAULT VALUES

+

npm will default some values based on package contents.

+
    +
  • +

    "scripts": {"start": "node server.js"}

    +

    If there is a server.js file in the root of your package, then npm +will default the start command to node server.js.

    +
  • +
  • +

    "scripts":{"install": "node-gyp rebuild"}

    +

    If there is a binding.gyp file in the root of your package and you have not defined an install or preinstall script, npm will +default the install command to compile using node-gyp.

    +
  • +
  • +

    "contributors": [...]

    +

    If there is an AUTHORS file in the root of your package, npm will +treat each line as a Name <email> (url) format, where email and url +are optional. Lines which start with a # or are blank, will be +ignored.

    +
  • +
+

SEE ALSO

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/configuring-npm/package-lock-json/index.html b/deps/npm/docs/public/configuring-npm/package-lock-json/index.html new file mode 100644 index 00000000000000..3f09e0ec572c60 --- /dev/null +++ b/deps/npm/docs/public/configuring-npm/package-lock-json/index.html @@ -0,0 +1,183 @@ +

package-lock.json

+

A manifestation of the manifest

+

Description

+

package-lock.json is automatically generated for any operations where npm +modifies either the node_modules tree, or package.json. It describes the +exact tree that was generated, such that subsequent installs are able to +generate identical trees, regardless of intermediate dependency updates.

+

This file is intended to be committed into source repositories, and serves +various purposes:

+
    +
  • Describe a single representation of a dependency tree such that teammates, deployments, and continuous integration are guaranteed to install exactly the same dependencies.
  • +
  • Provide a facility for users to "time-travel" to previous states of node_modules without having to commit the directory itself.
  • +
  • To facilitate greater visibility of tree changes through readable source control diffs.
  • +
  • And optimize the installation process by allowing npm to skip repeated metadata resolutions for previously-installed packages.
  • +
+

One key detail about package-lock.json is that it cannot be published, and it +will be ignored if found in any place other than the toplevel package. It shares +a format with npm-shrinkwrap.json, which is essentially the same file, but +allows publication. This is not recommended unless deploying a CLI tool or +otherwise using the publication process for producing production packages.

+

If both package-lock.json and npm-shrinkwrap.json are present in the root of +a package, package-lock.json will be completely ignored.

+

File Format

+

name

+

The name of the package this is a package-lock for. This must match what's in +package.json.

+

version

+

The version of the package this is a package-lock for. This must match what's in +package.json.

+

lockfileVersion

+

An integer version, starting at 1 with the version number of this document +whose semantics were used when generating this package-lock.json.

+

packageIntegrity

+

This is a subresource +integrity value +created from the package.json. No preprocessing of the package.json should +be done. Subresource integrity strings can be produced by modules like +ssri.

+ +

Indicates that the install was done with the environment variable +NODE_PRESERVE_SYMLINKS enabled. The installer should insist that the value of +this property match that environment variable.

+

dependencies

+

A mapping of package name to dependency object. Dependency objects have the +following properties:

+
version
+

This is a specifier that uniquely identifies this package and should be +usable in fetching a new copy of it.

+
    +
  • bundled dependencies: Regardless of source, this is a version number that is purely for informational purposes.
  • +
  • registry sources: This is a version number. (eg, 1.2.3)
  • +
  • git sources: This is a git specifier with resolved committish. (eg, git+https://example.com/foo/bar#115311855adb0789a0466714ed48a1499ffea97e)
  • +
  • http tarball sources: This is the URL of the tarball. (eg, https://example.com/example-1.3.0.tgz)
  • +
  • local tarball sources: This is the file URL of the tarball. (eg file:///opt/storage/example-1.3.0.tgz)
  • +
  • local link sources: This is the file URL of the link. (eg file:libs/our-module)
  • +
+
integrity
+

This is a Standard Subresource +Integrity for this +resource.

+
    +
  • For bundled dependencies this is not included, regardless of source.
  • +
  • For registry sources, this is the integrity that the registry provided, or if one wasn't provided the SHA1 in shasum.
  • +
  • For git sources this is the specific commit hash we cloned from.
  • +
  • For remote tarball sources this is an integrity based on a SHA512 of +the file.
  • +
  • For local tarball sources: This is an integrity field based on the SHA512 of the file.
  • +
+
resolved
+
    +
  • For bundled dependencies this is not included, regardless of source.
  • +
  • For registry sources this is path of the tarball relative to the registry +URL. If the tarball URL isn't on the same server as the registry URL then +this is a complete URL.
  • +
+
bundled
+

If true, this is the bundled dependency and will be installed by the parent +module. When installing, this module will be extracted from the parent +module during the extract phase, not installed as a separate dependency.

+
dev
+

If true then this dependency is either a development dependency ONLY of the +top level module or a transitive dependency of one. This is false for +dependencies that are both a development dependency of the top level and a +transitive dependency of a non-development dependency of the top level.

+
optional
+

If true then this dependency is either an optional dependency ONLY of the +top level module or a transitive dependency of one. This is false for +dependencies that are both an optional dependency of the top level and a +transitive dependency of a non-optional dependency of the top level.

+

All optional dependencies should be included even if they're uninstallable +on the current platform.

+
requires
+

This is a mapping of module name to version. This is a list of everything +this module requires, regardless of where it will be installed. The version +should match via normal matching rules a dependency either in our +dependencies or in a level higher than us.

+
dependencies
+

The dependencies of this dependency, exactly as at the top level.

+

See also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/configuring-npm/package-locks/index.html b/deps/npm/docs/public/configuring-npm/package-locks/index.html new file mode 100644 index 00000000000000..3308e55e82051a --- /dev/null +++ b/deps/npm/docs/public/configuring-npm/package-locks/index.html @@ -0,0 +1,211 @@ +

package-locks

+

An explanation of npm lockfiles

+

Description

+

Conceptually, the "input" to npm install is a package.json, while its +"output" is a fully-formed node_modules tree: a representation of the +dependencies you declared. In an ideal world, npm would work like a pure +function: the same package.json should produce the exact same node_modules +tree, any time. In some cases, this is indeed true. But in many others, npm is +unable to do this. There are multiple reasons for this:

+
    +
  • different versions of npm (or other package managers) may have been used to install a package, each using slightly different installation algorithms.
  • +
  • a new version of a direct semver-range package may have been published since the last time your packages were installed, and thus a newer version will be used.
  • +
  • A dependency of one of your dependencies may have published a new version, which will update even if you used pinned dependency specifiers (1.2.3 instead of ^1.2.3)
  • +
  • The registry you installed from is no longer available, or allows mutation of versions (unlike the primary npm registry), and a different version of a package exists under the same version number now.
  • +
+

As an example, consider package A:

+
{
+  "name": "A",
+  "version": "0.1.0",
+  "dependencies": {
+    "B": "<0.1.0"
+  }
+}
+

package B:

+
{
+  "name": "B",
+  "version": "0.0.1",
+  "dependencies": {
+    "C": "<0.1.0"
+  }
+}
+

and package C:

+
{
+  "name": "C",
+  "version": "0.0.1"
+}
+

If these are the only versions of A, B, and C available in the +registry, then a normal npm install A will install:

+
A@0.1.0
+`-- B@0.0.1
+    `-- C@0.0.1
+

However, if B@0.0.2 is published, then a fresh npm install A will +install:

+
A@0.1.0
+`-- B@0.0.2
+    `-- C@0.0.1
+

assuming the new version did not modify B's dependencies. Of course, +the new version of B could include a new version of C and any number +of new dependencies. If such changes are undesirable, the author of A +could specify a dependency on B@0.0.1. However, if A's author and B's +author are not the same person, there's no way for A's author to say +that he or she does not want to pull in newly published versions of C +when B hasn't changed at all.

+

To prevent this potential issue, npm uses package-lock.json or, if present, npm-shrinkwrap.json. These files are called package locks, or lockfiles.

+

Whenever you run npm install, npm generates or updates your package lock, +which will look something like this:

+
{
+  "name": "A",
+  "version": "0.1.0",
+  ...metadata fields...
+  "dependencies": {
+    "B": {
+      "version": "0.0.1",
+      "resolved": "https://registry.npmjs.org/B/-/B-0.0.1.tgz",
+      "integrity": "sha512-DeAdb33F+"
+      "dependencies": {
+        "C": {
+          "version": "git://github.com/org/C.git#5c380ae319fc4efe9e7f2d9c78b0faa588fd99b4"
+        }
+      }
+    }
+  }
+}
+

This file describes an exact, and more importantly reproducible +node_modules tree. Once it's present, any future installation will base its +work off this file, instead of recalculating dependency versions off +package.json.

+

The presence of a package lock changes the installation behavior such that:

+
    +
  1. The module tree described by the package lock is reproduced. This means +reproducing the structure described in the file, using the specific files +referenced in "resolved" if available, falling back to normal package resolution +using "version" if one isn't.
  2. +
  3. The tree is walked and any missing dependencies are installed in the usual +fashion.
  4. +
+

If preshrinkwrap, shrinkwrap or postshrinkwrap are in the scripts +property of the package.json, they will be executed in order. preshrinkwrap +and shrinkwrap are executed before the shrinkwrap, postshrinkwrap is +executed afterwards. These scripts run for both package-lock.json and +npm-shrinkwrap.json. For example to run some postprocessing on the generated +file:

+
  "scripts": {
+    "postshrinkwrap": "json -I -e \"this.myMetadata = $MY_APP_METADATA\""
+  }
+

Using locked packages

+

Using a locked package is no different than using any package without a package +lock: any commands that update node_modules and/or package.json's +dependencies will automatically sync the existing lockfile. This includes npm +install, npm rm, npm update, etc. To prevent this update from happening, +you can use the --no-save option to prevent saving altogether, or +--no-shrinkwrap to allow package.json to be updated while leaving +package-lock.json or npm-shrinkwrap.json intact.

+

It is highly recommended you commit the generated package lock to source +control: this will allow anyone else on your team, your deployments, your +CI/continuous integration, and anyone else who runs npm install in your +package source to get the exact same dependency tree that you were developing +on. Additionally, the diffs from these changes are human-readable and will +inform you of any changes npm has made to your node_modules, so you can notice +if any transitive dependencies were updated, hoisted, etc.

+

Resolving lockfile conflicts

+

Occasionally, two separate npm install will create package locks that cause +merge conflicts in source control systems. As of npm@5.7.0, these conflicts +can be resolved by manually fixing any package.json conflicts, and then +running npm install [--package-lock-only] again. npm will automatically +resolve any conflicts for you and write a merged package lock that includes all +the dependencies from both branches in a reasonable tree. If +--package-lock-only is provided, it will do this without also modifying your +local node_modules/.

+

To make this process seamless on git, consider installing +npm-merge-driver, which will teach git how +to do this itself without any user interaction. In short: $ npx +npm-merge-driver install -g will let you do this, and even works with +pre-npm@5.7.0 versions of npm 5, albeit a bit more noisily. Note that if +package.json itself conflicts, you will have to resolve that by hand and run +npm install manually, even with the merge driver.

+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/configuring-npm/shrinkwrap-json/index.html b/deps/npm/docs/public/configuring-npm/shrinkwrap-json/index.html new file mode 100644 index 00000000000000..9c90ad71c562fb --- /dev/null +++ b/deps/npm/docs/public/configuring-npm/shrinkwrap-json/index.html @@ -0,0 +1,99 @@ +

npm shrinkwrap.json

+

A publishable lockfile

+

Description

+

npm-shrinkwrap.json is a file created by npm shrinkwrap. It is identical to +package-lock.json, with one major caveat: Unlike package-lock.json, +npm-shrinkwrap.json may be included when publishing a package.

+

The recommended use-case for npm-shrinkwrap.json is applications deployed +through the publishing process on the registry: for example, daemons and +command-line tools intended as global installs or devDependencies. It's +strongly discouraged for library authors to publish this file, since that would +prevent end users from having control over transitive dependency updates.

+

Additionally, if both package-lock.json and npm-shrinkwrap.json are present +in a package root, package-lock.json will be ignored in favor of this file.

+

For full details and description of the npm-shrinkwrap.json file format, refer +to the manual page for package-lock.json.

+

See also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/google-fonts/s/inconsolata/v18/QldKNThLqRwH-OJ1UHjlKGlZ5q4.woff b/deps/npm/docs/public/google-fonts/s/inconsolata/v18/QldKNThLqRwH-OJ1UHjlKGlZ5q4.woff new file mode 100644 index 0000000000000000000000000000000000000000..9771531d13dd6ea24f9bac976573d14d7880f6e4 GIT binary patch literal 21764 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

P)GKALp;r>c_14rVh$KFE_<5vTQ)C= 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 literal 0 HcmV?d00001 diff --git a/deps/npm/docs/public/google-fonts/s/inconsolata/v18/QldKNThLqRwH-OJ1UHjlKGlZ5qg.woff2 b/deps/npm/docs/public/google-fonts/s/inconsolata/v18/QldKNThLqRwH-OJ1UHjlKGlZ5qg.woff2 new file mode 100644 index 0000000000000000000000000000000000000000..77829329c652e995b779d575754a50a464533b26 GIT binary patch literal 17472 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 Q))Y1d7Z(5<11b^#0H9iCumAu6 literal 0 HcmV?d00001 diff --git a/deps/npm/docs/public/google-fonts/s/inconsolata/v18/QldXNThLqRwH-OJ1UHjlKGHiw71p5_w.woff2 b/deps/npm/docs/public/google-fonts/s/inconsolata/v18/QldXNThLqRwH-OJ1UHjlKGHiw71p5_w.woff2 new file mode 100644 index 0000000000000000000000000000000000000000..8be24ab2809ad54732bd20017e91f83db3b9f330 GIT binary patch literal 20336 zcmV)6K*+y$Pew8T0RR9108elL5dZ)H0JaPO08b470RR9100000000000000000000 z0000QA{!taheQTo0EHL`ffxyz77+*vf}?bTgc=KkGynlM0we>7L_7|~2Y@5q&5jHN8wUWSJ6`es|7Ro}V>r;pFq2z#&|%q&X*qz=@&I zFoX;tbB!vL4L>X`{Re^|Z}fTFwi9YeFDv@)@}BEMebeOalKq#*2=57KbgR2#rF=I4}y2gS-KnTX(xLLM3y+0!9zU#u%_FYK&X~ z3$mp`XaP~dLcwTSP*l{{elsyq-wa;=zBcRs#*+8CBUQkN>dJACVqXYMmdOxjO@M!) zclH!Ex4?*d7*obtMvN6PtWVXxs_O2U0Z7@Sfjqx)PUqHgjW*$9goVsPxafS$L`s9T z%as+OtmMadA~*gaZ|~2OLR^=mleoY&3w0$GWx{Gk*$1)%^x%*T_XygcbX3$|)at5{ z!!{Ob(xQimO2*#L4zu^yk`qHc$eX;AY*Vo(HA97et&yh0hjeEDW;Bw4L}U?JCR&^T zZterS`&5)zv_D;y+?{vZ108HT18cJ6s)rJ$JK7{&leH8Qg+eWdP%o6gmtWJo%A}HM zMDRfv+quc^?11jr4%)-=BRNEBOOJg3_(U6mDvEk*u&o;jVo;CpD(bg;{n~yo>AEFJ zl3ur0<3w8rNkiqublUs(rkd@4yIjT#&_$k{=zJ;HBt%|{MdhN2)!+aB;%@>L*ab*% znL#R%3JjtWq&Y5jbprwyl;(zV<~gLqAc{9sxR68V?(B+{Q|Mfjae9}oYZq1JvN1e; zYniS8x+_3J5gCgrQZ4knNo}V>XapYOED3kgoN~bGgc4`KvD9pPomGI$XB$R|-Kzh8 zjp>y@K~VwHks1Y_Ae;f{0~rnetLbbm?|ur%?(7M-@|2}1vJ}nus!ZZ&<9RI8f~Ya4 z9Z?W;`_KROGk*@YEp-fG@rqYO#Iog;`YTC}u~m=tm*EoW4z!4R`{z&fa3F)&?RG#y ztRWPM;`FoS?&7!P)(5W5ZS-&83hxX`MVkr!5h%gZ$LLyw$ z+LI1__F}9zf1NgSU!r9;o+&mq%3?u~O;b{=8Y5~jE)xUn^Wi7};|~rHo$oHD5Dw6M2xur)dn&xBvSwlsfb$Z@~!p8SQ(JaTM`IEE6EpWc5z`utLom2o-Anh~TP+4__v zqu@z8d_*i@5YYXP$LC6b*2+BqKLF^R)kVZ2XbD13o8|^sEP$7X#?I@)un)rXi{y=L z@Uo)0LvNo#S|V+)9FGimG1+~EI0n!y1AzP){2~7FpT9JJ5dh|A0bss+e&zg``PK8O z^Z0q6N7o)nA4wiwes~_V2?z=`8?!m_5RmU#@8aa+HZcCLqn-l}n{nS8AM`ryj1iAb zI`5!46OLN&+zW@i2e;HR28@`qV9AO-2S|>bpt$qo#hVX2B9Z`P6eo>3<)>2_2*Sd~ z#TPC@B$0R$QZjOhQl-m~DO-+0MT(VJ?u75odgYdBcRh5^BR~9}8lNfudhLQQsq@XZ zhHY($|9rH!rG`|vXrI0Io25ewf*x(Ume6O$m>VdT>10mhaixL zEHuGFFi_DkafA^N3Kd5zS_~cql_beDl%7#5kSkBVQfbP#Nl7=&IcHsU%@r5zPedbp zOBVBO*3vi&@Ml-i`M*2tdjImg(no(m86jVQm^T`s-!Y6}J-=pkWZ1xjl|Q4l8KnjB zN8c)N@DJms14_@IJ$F~EUcwaVkDk=y|E`Rr9?8&HOI(OI()1w0;0h8jDy9V~Fb03Q zA8tKb+V4n&*#jmU32N-G`cVuYUNf{HDl#U#QYU;PlG1S!+OJ;fE)RDwT94#Z zK*3Kv58+TUcj@b0>&*)*(-DPfNQlae9{MYX9B>5kD94Be8OOb5;E;xd#6wS1_pbpB zGg;BqrRO9$v>YVIexgt~1d{T%axg2q^61iEvpNX=Kdzo=K^+;|dO-u3NXQf@vIGIy z0z-}Ju53p{=TCF%rFfv zA%p-TFo?k*0fQ6_GBC)&pa6ps3@Whh7N}+`nhy+A3e?gy>Je4RrMC+(W1LJTbQk>V zvtv$v=6}+=`8)HI=J`u?&(ppxky4Ymbo+K0A4)wu)7W>92`Ix@C@_w*+)G45dU&4Y zG`v+&0J1Dy+%&>2J5qm9TRRL$O?h&v>?UK;EP7-)tGZ;_FT=Z1?twiqM_5$#j@<-9 z!zd+Yq@~(4l-)Y)lGF}J+hhu3cLdreCCuyN557bt*2sK21{6mkA-Oba?|VEOL*Lo0 zOqZS(cGb7O!wcH@W-0-N@aZ?>8vS z?SI5z@e*Iilj?IT*)(>Uq^vrM-nHYj9t`chgpZV!O!0^J9X^=GeQx)7pw&CW^4+37 zAD4aF$RNE0_oRMyYR4CP+7rxHP@+p|87}+F#!SW*xijF0ja~{OFF_~(MU?{9#0Zf(TTs0w{^m%a*|vDny`aB|uGxUME5z zGzd_$5}+jnHMgC^2_2l!#R)x}(8mb_oG`=*Bb@6oGAZMjC#nM)TbyFHW<%c;Sle^m zL6n6eEETdkBbA$VRM|u|Z_zxlD^9Xk$U$Mpdr;#PHO^7v5;d*`N_wtcts+sGu0;T~|2i>j|5jB}qe2{@)c12cZ=;Ir;xOWg6UXG>AGlV+Bao=j0_^O?quqkATATdl-FRew;2lFx^0Mwntg(Bn|%` zC)pF2D^jx;QW&MGmgt&M>R01|NF1Z9j9eW@T{4`Sb(M2rIzEHeD3f%`UnI9I?s8(7 z_uJ^wEJ%IvE(`E%Tq@7TOG3f^Z&a#7xYM3WlFD zOSVGNvv`nZ_@vue1wP#iNHGAkmVn~8@k3c$eX}CU-f`J=oxn{t zE3-9Sf(gkevbf~zPoBJmtA9l|U(s%(?ZjAkUvl;+^>sGgY_WT$?OO}G{RslioU{bI zko5Ca73N8HabJQshilL#$1f21%@K~ao2eBi=12zj3}yq7K!$OuL+`w|{)q|#qam|I zED2cVrev2H7Wxn+wS>2M^Z}AFMn8Z#eUO?uPSYCII<2Qyl^p~++nW_E_a^mcEjBWk zR+z$9a~vB>95VRWB|EVphV31CG-7x%Mn@b|np8EkUdqUA>Vu@N;t?;<8@{Hd8K_m_ zMs!;KbLBD#%oHbKO>&sH0(DDl;(I4i{n)C$#lbgRx^p{#L(?~aMmNGJ2`la$5%Wtx2HxKDV3kyKbd|;pE&M5rgP{2mnPoo3kV(M#_g- zSs)Q;Tz|Amrf64qI>Zl#*i0+fJ&SD_dz9~rS=xUuv=f^uH*Z%w0k?_slRndMn*7L@ zHvE|K{1X|n;nQh43tgjwkws}+8`GSsd($2@PlD8_25M9pWT+RVY%_aC7ME$0m)%DX z4{*M~HgY)<@VW0>ncDbZPb;qoU$1!s{^V>O52oa1k+(y1aP<37GvmHkerKDS{oQf7 zh#6Z0mjT7Kq1M<%gKwhs=TJs=aj<7G(aw;D+bZz3A*~eC>juB7Ruw+|Q=0|>wW(XS z1~_B#BQGJm2;(DsuW%Y;ofD+46nN)how9!=w_J)28|Vu$YL(`PfVrRuyipZ>bITY= zl(JvX;>CTL!Su)yh%JYd9r)1uixwoqpFFUZa2TlOK?WORV_nsNi5lJeplCf%@cKS2 zwzV1!F>G$pqY(hEu_}c_=88I;|z`rOWsM3QWc2Z2do^JKvv!b`Xw{c^hTN@!LJJg=a-YHctL4U|Kk|<`x$M(j;sA$f~3D3@9 zZKq*vBbdXRPod%SK_P!)aC^=)Az}v6*%iD~u!c;WhA%|jMPuu9Xk%M^R+h{=+&Z7P zFyYp1xV2k%6bw>{4AMpUlpS<;n@iii*aup2a~}zu)F(aZ#U5NOUSMP;)+Z zjLa`t5?XRia#vs;wYRfj!>+{aEmKOD>>M$k^h zn_nrBa7KK(%mc?kCqqrQ-SJz;Z|%)vg3D+rx;EXvwyOT7KW;3Tg1dU;bb4PyI#06O zM|!}6M6@HUiqKD0GE&7rYt>@qB?#A=U$|{+x-XX4MHhx#9KYcbF~%c+A~;!5a+=?z zaiZ#?`8M-+@7BBfKZ#c-gWVI0E)`*Dh3;CPDqQUAl$G?D9&lU-)0)6Sxr^p za|KDHY5W>=%_f$$e~vYf@e^srf_)&3MFJ4dTzL8IxBwA@3XD$5xOj5K7*+Mkq?YV^w2@xyGmsT`^%*Xkt z^R2Rb%cw0oEHkRRm&TbDx~LE(?i|(KNux*qz!^?$&B_1{wU<_zQ~!8Kfg7>IPfKKD zbN98snD@D@<7aK#QUX=P>_gA9ZRz>2 zv+r_3a3;;Vw)S5d-s&uAE5mXEYX6O2=)d|MOriZWxmyEL7N|J@B)a?gOkwiQUOA+F zQhP}2_ZrcND!Yl5HK4fiYUQ=+{#$omrd1$g5Lh8GzOl*RURpiUz?s)koIJaHlF-}N z5Ax}4Ky_-6Bj11)p?Jd6b3Aw)CSjt#e~`wR*umzNOhIR82BDK$v&;VS@&$O-A6!Ey zwG^ALr0>5+(?n&cBJaH0#v9&g`Nw&2eK%*a)VS1C*w1>O>asDRXq7yGe)+e;T6a?#(Cry- z+1JQ%)wq8?W$k*IRlrI;&;>8bMReJ+KHOrQ{cix-^|bCsuinLyF}ci0g94_O?_Qb9 z_gk|6p^cJh&{pf0TlcPwOZ%^-_{9OBQ*0BCUfbxd9as&7kxJnexzRTFc4bBBY$vO z6sD5_^rw92O^PITu&9C<{=dCYq7lP-nW${Yh!|(zU>mlu1^>%MMbt}g?P(dYrmM8I z^=R~J5Qa9l9NB(xiejl0kri4Xn;;QNU{gSTx;iX4g>WfSK-5+FLQ7x=i=3ZRs;F#G zBF4Y^6QU7^9;R%;mUL|@a8Oa?FcNg(Uyc$9URffj;DQ2P^L{!=J9N_IfBT9PwiWjU z%5e2UC}+}L?by6G4xe<1AdQ;P-+-;FOwAtfzpS7?2|Tux_r`j7u_<5XSo!j8;r9G3 zHyXI==d*}3I*}wz^ba5>`IDtYdSu!cwE-WDn)E`ENWQIY0um{+)oyTHeNa{ama7&E zPSAr4&KhI~pEP0bi)Xcil_%jlv`~xn^AAS)L!-LcnBCH3ztW)nKTiLwwJ^~u&x+!@ zdNLI*>_OjAc0s9Fomi9K*3+@-M2~80Z!Tx~wW{WoPkZa#@4a2?^`^P8`&xfM^VSGM z5S>~X8M>g;LBcJpx`AK&-*&c#q= zOL{ybVm6{uzXlzfJ+`v5U@_!mV&IRnKeDAK>)IBrPWZZ=nmZL%sMRoLnIJgE${&8U zv&{Q5wL9J3l;zc2YYNWqUj^*J?{$dsr0^?cVHXG2aOP`@MR`oW4|o2)!y)+6lD`}{ z2g+v-kUZW(KPy+xUyT-rGLcv#WZPP_KGVX`-5(0Wpk$x@WoZnZ=ac9Q`)lAIp#PVOxvK(@b%`a$|Old zf;?6;Ew6n%+?5|#Db~nF&SkCtIW?->3mUB&IGvappWxxn&EzR?qry!`tEHNOiG;lB z15r`2`I|rx1U&iO%ve$crVHcY$;{(s`VGE=!C+_UD0dtLf>2XzQV$FUEztY}2@n8+ z!~S{ogoM+3PNx#&INOJdPXoTrgLi9(tUIqz-rG%h?E7iq^F{uc)w9JQP z8eR^&u7OM2Q6-u58{;fo*cTvz89k$AjkKu z>#5SzbbaFQWb0O_(^Kgk%)^DN<0CIdso+DbqUt3ro+FzDB2t7e=gMu%MtWGCBuU+O zFs1@Z4$dY;F>`ae@U%916s3~sWt>7I_H;ftrRp=}sbb6cB1&p*D}lO#DP)z=c45nz zbW~LcGERy_7u!jRKh8QCv<8TQYhwMl&>_TiW(0)+Zdx8>$E-&>Q-NF>|7f_ItIKfW=AF2x;M}0E{xS+J z;58*+?GWyaPVTVs>&fOW>Rdd_w<9Hm*eDGmQRFN_lU(B4nHWJ$+=#qYvV6XOUBSY? z6?FyE=^0o1ECX!{^y?ZMWb{VLwyLU?yYKXCD4yyVN`N@4R8O5oYDffum(eanxgsYU zi=ILw9w9DGT|(ESO^wU5rW+c{dLRh0>5?GCRoM7LsgOh(gP zF&rEY!=}4pUFa?f3Qnh7bbKFWhxj{8u#Bk9VawKJJCgH>n!lg4CpF&(by@E+ZwO%w z>^yRj`I4T_O`!(J0tx9%*M-cf=@-I#({u1E(;Ba*v!#8?qdViWR9iyX!pb4gII6si z$4}0@Cp-v5y@X)!C2TuwH~@km!;$5^e}5=XvjAw>S$8|K)47K3eNCnN$rie*mN5kE z=h)*3_?QOneEJ`XZH&8@Pb^_KFP_Lq7q|DFxUoLMhUpkKTXd~kie%Wh;v&@L7vE}+ z&n_fm+k!>STjnk>U(hqd)L}ki3_dhKvrt!uyi{AVu&S->+2#6*3WkQ*wo1gHKGlqA zRRp0YDVflr5-@4W0{>1y(+`I|oGHlnj9g7)a1Lg7R=m90P|0MPhUAYbSXERS`*6v+ z{AcIOY9a)->?R}U4Ka4+4{3ae*UqBh)p83Kcyl`{akqWFj}bG;-8ZI3E}fs=BYn75 zBgHH5roJj)yu3-m8L3#m57r|r=Ha~?-cNCluI#Q9P13Yhfr4Aaz*ZIs>C zwk*;HVOD8@+Tc`^w3)Sw_8jqf_Cc{5cR4LQeWW1m>EKYtll^%q!sS#9>&WvvpJgm! zPj-uRt2#}wZ`C^GnwU0(S_4}Wk(OCtwCh+QIq*qv$UC#&O_gSl%6;1UUS9tCJh*E$ zduf^F1WL|yUB;{4RjH4s%L^$D{^ZaHfR^!d)%V2B8#bv|%lzZGel0SEf3GZ(w2`o7 z0FcG{1@elR^y=s@FK6Ghpm{w}5>C6Hvi>3nLN9$_yzzKA2!oVW*UTHaLF&+`NI%P1O}d#no)%=H^awL-_@RAP55M8falbk*+Am ziwS74Rc|5;2EB6h`(BYsgCoZ)C*9ehKkZZONAkyaaO_=ZzUV|M*Dp7PD$q<7gvyf= z66D!2)8=a*RDZesX|`mCB4%BjT)9o=+ThYK*PSmK8C2$-CR1bh#6hyWZ^QmuL@k=3 z{UvDT=F&&MUHy%}ZG`I&W1ty~nE{-Is}54pgVVgei}YN!9Jw6xBqrmbxl=QkK?}&B zoQLyg646*@uZW#R9-4(m`EA43J_(*RAD?~pZnilAn~&WT9sxqLPZV2<{W_ZPHdCfS zSs{0<--Lp$7tU9h6q#Jn`0}2yZo-cH&G`NBz7+c(;xgkOMjY9B78dET16TOAD`4Zc zrV>WF`(^$R2pR!iT{VvQSS2dnd}w<9{l@ZWJE?se(?ka~jD+A2hQy=6z;QG=w)1`Z z+2e~{uQDdSt*z&45d$e;P9QCnUVJ=fqnA?XOC@;6U|;3tGFZLAlFotlrmN?q=i~%l z?&erQg2+xP^!B#>?Gjlv_-63jfPJ4VW@l!ebbLS+C+&@k-c?d8*}qmA?>y7)7)uFu zl;%1*)i@>uQ;>0$PT5;WK8&bbCQVOnNOiw@l@U&EY->|fGwq%f@6OsVZGP)@ zn@C9v1+F}=ERYvbf)2O+mQA!YA-G}BkGnMgw)mO;#i+vV-`?DOoO@gosg}q1$t*rr zVL93$Xjqg4ANsK-pI3adsxg03uGyKLr8&Lr(B{pN5u1Cy(k@%hdVgvu+ftLGnK+i( zh-ls|KLUX6F)Ic6^3+^;O1`Sad+W@+?Z)M52|q>>&MNf!Ra4K6IVR37nut>kB&MXU z;v$zNXu)7Gk>uEn|C8D45xB6@sn=&KY}c_}0rQ_>l@+c-apP%8r&}9S&L7RIv99^J zv(^wCBC@01g90TaLQZ5!Mnim%jQpr4*mJ|a6VDC5@y!@Z0SIdK-2*}Ij2f@@xQvVT z=V(q^u)hyxqr4`Ku{{B<_5Tx}x z#UK;{&iLv*4HS^vGKE5)v`{>bm`bqlHO=6G_> zPK~POU^+R>H>p2Trrxkunv%LJK51=yWa@?pf|^t{laiLV`-HMst00E1_D5AQ&@L`i zX9_B7d#rhq$ip+#o0nHDcVwgD%h+D{$QW;YrMueVj6dc4l=`F~T+q@F7%?+EX%P~p zTd#IaLQ-YoNM6?2s*0=&CyFXa`$SwvF02vL%_asUWi>9(OUzApr+~xZ*3J6gm>{st zco5S|Sf>;nZfFo4UZ>2;O3DfEja^wQc&R7Z$q93gqkn`89@Y`nGRW@&XBp&T%Ju?t z#|oRO5Kd`iTvTH(SDv~t-Yu#w!4PC9a{^ejfM6cg*M(|*y$)wT`gKjHP76Euks}L) ztuxvHY5m>i1Z!MM>CB2KY50mpZn(T7ML1ho8+CL;YG!x_=CU-?=+^;^yTH{$Xt*G< zz!Y=gaKz6t`wG|{Fz=mjL@<{vBn1w@el+t3^N72}&xv`g5qmkiy*QNhX3k-|c{@2W zgT)srBOR|$qXQUJRhhrIepPO2Kv47=wsWk4$rk5y21Qd0Ofe4s`jgTe(6p~48HeoV zE)p=!v7~TUH#RAlfMF0il)?iQHR2QNv(iKJUG$PO0N@bQ4(%D??i=g*JHpb7mCs<5 z2qSs5wY*5X{%A8ls8pb!6N1BufdMqX?xzr>{kqgZ4xVx1>+0%a`oe}iSk+tW>=%si zU^kBi{ul2WT*VInuh8>-c#$G2Z z3z-0PRj$o5Yj7Zse=4Sso=F4hoklBe2VWZHOTK=vm4mb$6mzLdFsv{+0)gFZPt(^x zu!xTTXLhuF%kS8laO|X}E($UJ-|+?~PucsL$|~IqUdQUs?21j_wA?Wsam80q=TdFo3$qaBN)#@Mt?R;2FM{x#-O=7!qxr0S$K zMnSUC~C%^b3h2 zIJ(mQY$NepC_GuY9~UYRwjl1Z=y_F-f4{lry;*QFdj{2POa6o-+tvv7ha|tW*iv=M z-TH+B`!#V)hW(m~IAqB|yV6~-Zgeij#g*^k!9ZbgbRNdT{?b;tA2H64z|eRgkraOZ zaRfg_KK7GJ7TT4HMsM2fV9^}sOV~@3&1}0=u~5}$Oi;PW4dqV7qC5Ky7w-MBQIL<+ zg$&Qx*}9-Pep$#KDX@Nj2=XskPfkHs+@{Z8=<5sOx! zl00xGGbYw$0#oKV`OfuUD_!Hb&~Q3aD2msHOyJ%hm*L_IT*5AZsIajmn-1HVpVJ+@ zhGJX=G1P1n`6`Ga?J*hJV{baOWaF$$l+L?6q-nw4lh#xeii$ypQBfH5voJIUMSX@Q z?Ef#=MMD-sd+=1paL;hLR7#RMoLlL})&fDpqD1)E%jV_WtUDD|`FoONgAz72HGr)@ zs!v6|}S zOHRb}2}hN{M7z6Fd(F$z3Y@)SA{slHI3_`mFCJ|@iXpI$G1ObTwRR^3@F_6|#8gUX zG<64AbD%?{qc_I)8@-TvU;Vr<#pvX%6(N3m5jRh5IM5~bJy&6X2}YPP zK|C-siRp63`3MvIq1%V->)rx~0Lwao5>P2ubWstV%Lr$vvp@fUP|wqk{6iTzh5vtA z>ZJ2mQJi_;L>G!JMqW-jgmS{oEu6v736Cv@70zmEef8+G7NRw_we^J#x==!}5X!qn zB8JBDFFxf#3TF2A?t4Y&r8EihkoqRUCw`%@jd@vKMU;`Cuy4o`i;lOG`Bty3kFW6a zBTnBn87%nZPZU3I zfxDYHu-O;&qca-%`QjN-DrkLSmED6>>kTc@XG;FkQjG1@4!dVU)5@rdKet@4zg%P= z9&dk2xRQ>H6o1o*$Zhct#<%T=Oxv5A?;aMN;Lgv@Z7j{orbnB(iUpXg%%1JsEKjaN z=BZO;*DE8FiIK@UE*aU91%ZUm7f6LdrquitNQB|z%j5=o<#b-fenLP&7?UIP(al~% zTt8SK;MFuG#2c0TJ7IvJCL@p{!)|#Xw{)#BTp7uUqq~wkw)<_~QYQ}W=}Jj5$^I7@ zPT1v&LwQg?_*kYYOL2~gOYBdlHJq|sQH?u5g|v-P0a>`2MC8iugU6$Dk5n`ZPA%r< z9tyXoNZQNn@}96}4u;zqI1I86Fm21)YE#Im{@Y~R1=MvkX&0$Sgp>%d`BIdQw5f4Q zT8_(6j_y&W$M-PloaUX*ryX9Dd*C=8ZW5YfvBT7t6m5wU!+JSlr>%X`SW=I@107u% zy`M!Y@MWWUW@;77)HzUvQTz1=U0;;#UMyQoUo2Vt_UM~ViB7ss8C0_S&$}lNo@~&i z4SC_TZq+>xKR-Zv#Bp?vz3AjJ_0rl`$nvK~{l71HpTA>S zdM&sL!td3k*RanMuiPj>Pz)o8pO%&oYj2#dVmGEE){&CJj)XC9Flk3#yy20Mkh-Do%*#%!z$8xJmtTSDCsZ zDJpU`i?G&R7XSZYi^_}$Alr?=aSI~zy#Ly{`BdsokvMx@Ojv(XC~csihU3B#ayKx; zBkNiPqL>vC{CZvpzFv|wviGO03022PH|zCuP4vpZnC9`_RVL1PKB**sA1=<*hvp}W zFEs2+2ti%K-5^)9JTOrVUz}>DS+T4?HFlFcQPuxcazF`aJw6X;xs?H0ZvQ$K7amLD zB)4zXpH)^o6yw}jVJshK;|O=2*#@8XP8Aj#&Ekyau!;gjlCI4$s+@_U0M(8jlb-M% zF^}k!^VI=!Tj3pLm+aKrr4HujEsrB-P-L>T+ha4DtLAMqn~7923y!UKWO%q04eREU zhkDvx|GuN6`TdLb=B9=AmiHak`}#S8>F~7l;;q?9Gntu*2e)P?D~B@`2XnI()596c z=&0s6-m2Kx(5^a>aQT{YOZ6sFU8uc2d9WDe&E$kd1|NsmCC1!ZXFB9dUWT?P!VF;RzszRYEL-}ZoLxb~8WUF#065*h7j>TsP`60ZA zZDPYHF2NL+{UFc_Yv&28M1PWu_^(oPB3Ty9?CKJ33K@lLh7)W_x@K0GP<1rL{YlT_ zZ##EsN|mpJq+BNUW}$k1uC=s^%_4XbN~lg!XJ;AJ8RJSr3!R)Z=}s8YCzr22u2i&# zqqCIigu$6M2IkZ#Mo0??Y;>RtFJM72g7CTF!;R(Mr_yf=C8kZrx>IgeSA&OH{enF; z!5n^}WX($(e<7QKWxBZXyjm_?uylF$&6}aI(|K&L=C&14$PdOc-Eg7aEAKq8be?d& ziQJku6pla+2gbMlp?@+&x11dA{2#>W6zD!-bL#N@!;xVoE_4%|wek2EAV(rMEW18f zA6$>I6%V_K!vM6fD>>403c8cx&u@a76JXS5FBRV(85F;`h}6zf&&%-M_UN)I)TIW-O2@S z$%;i;0mzEya^gosjiGx&0SMKH!@{9gu5ERQcPPcD_!K`R8<#)aa}b2yIE>(YW^PCRE8HAr5w5=i{*+Ny;D6|c>Iwswe8>&B?AA~EAIwI216_iC z4A1H0PLAO)C2~%Q=qM3DiTw|Bhp9Y=i!;gr5p#Clc@B8zCC2WmwpN4j1qQ4r7tKph z8yG(S|2&7S;Y8T>Tp*x@xNjA-(M|_j7-E>MY-2k+*vYQFC)mB*nIqL8f@}tKRlu10 z3+PHPnvH=(!2Qr3eD5pxQ0w4iQ0ibtJmXI`ss`0=sL3{lW=FNE)kJEH?&#e!)pa{l=Et zA@vqYhct5RN`!sv4h2%Lm5$+40FdbNfJJf7;l1oAlujBr1>w)M0m?Vrc$Eb9v1gZ= zB=r_b*J5`~YF*bWLh7~B#cI<(+k$5!ox#2`P6FQm0JcqYuJn&`eHrOVxf)Rk07Z!5 zeE*XvhSN(3orohsh;~*)!~_d2Eu^`1g9C%&E{tz5o7r|gTp26nsErJPt5w2=5f{Sw zfkVuookoPNh$Dn(XAu#PVPW7H{zU*lbO9|<_+vFK28Os^y52NxMCmyB;gkBr&hp$;8mF;?o@ya{?v!$bX~Y?7)fkIMwnZrB6oEl z*99TFg36}^R%AT|$xG@X(E`w);2v$^D`M()YRhXu^9$w;03xv8uJ#CD?e^*MLKm(A zii`<%_AXcH>qxF*j8ktYLGW{NkD1+dJGirD(6*#9J6<&fAPCl<(& zhZToz;w82zJBl-lx|#_e+)j#2k<7ixO;E9eJhqGsU1|#9Pl0F>?t(x@4eAm=SYxPw zi_3)%n|gqLS!AN-!u9)ekyE7boseRipe@^3=1Bo7ZZ$`2AlfQR`& z&8#7flnI0c>z=W}x~#Hn*3p41j>9;fAz9m>gn=x%<%2CDwMK?)yPr`q+RNL1vbaQ| zX6p7DNnj?N=n@ZY^e0qj<}Rp?MuV14U3V+{?BlX1?xhH)HOUCQtT*Wg6P# zP`E{`$UQYC=|R+j=Zf#9ARB^{DoIc$M(zpzR4|}%HwG9@BkW(qQ7}Zred@dh#DgZm zgLaJhy$OTOv_i6gsH~9!dZ_kF)7@%>D~no@*7xU{?m%2!0Nr&=WC89KMO5jGnO}J7X6aF|X5Oj~vE`}9W zh0waN7c$>omWE<5S-M?Nm5>_G0Q?<{2pX~p$oFgzdjk+GR~96hp4A!!pY9DO1SmR@Exy}VB3rGMs;CONSJfB~7FIk3CA zMo}=xa|PP@5ic&6=Ts^xQzKW>U#6S~*`!`0O|{_M7onM%8vwx_N?eUoP%m}4Mne{A z<*`~ZGw@=xCIr)F;p`?yO8iL_Rr&sW#)K77C2bp_R5-y9m{$?2OJAi=ktA0H|rha4Bi)&M-g!FRUudfE>z! zZDNA$4?RtVPc5C2A6;CBnMOr0TdoX>CuJx+-m*@=-^X=aRZV`Ip1zge{DrGM2q(mJ zO!8R;i!b-%lD3E<^>EBRhbmQ-$%>{`&h2yHv2B9KSSNck6>UGtzIYm3A4A&U6 z(Cf~k80eN)Z1Mo3-iJI)_*ZtNss=!Vwv8Gf9A{gTYP8PQWf3*mTVG>cx&uB4!Wp-LL+0wG@JbS#khK(Sz4}Cx z-QzEpd=-dvm|VAW(l)-UPmQTk6mmz6JTEBO?1R^Wm0?Euzey|8FN=MSbYKw>BP9LQ z%()qXwS0}^4(ghUXr7l~eQiK+*iddAXCzI~-F6(nDV#hCV8g2Gj%ISr)Ct9Kff1OB zaFF+S;!nn3AOb11KLB`B7Wt-`Yzs?Ktmxl?xf~MH`L1uYil8+EBX=0vkn5H|4twab zK|w`q*ZVat&%4cwLT#&*j3rARYczZ=vlq>34a9{3>$ah#6_U2@?98W&K`AB9k#2{! zT_SOjqrnrRQi&;th3+={j8R+XKAJOT#H#I7yyr2Qbk6>)MFanBY4k|M)-~ zgn~v;TJzaDRZDU^RTj7)PHPQUj~o5vnh@ zuDl0rpVw3bliZDsbi-}{*kc~;_iYR8ANKd>Q@d+->m_DrvQ*2m#GL3z_}Hg7qDw>s z1BBiw2xn(8B%)2c1AQJk$tV&=$G9vCC^<4(q{u@(7|u@cK$N$!VK>A|usbugq}!rf z7GR}T68JD-l#159xp6>6A>>yVmAc6YyW_jjaA&5r3vI#;UP5;`g92hib@BU)^MbfN zc$U<|cRe%34nbeuEY;GTEx}PYGI1{CtGIY)sB88ZC6oqtDc+rs;&mbNPEz$!P~x%mE$hJ9X8PtPh{ z$`HL6UNXSyY$0Jo$*p|Z8xnl%txrVhC}nDgRMmqO=VzfKqs~BoVfhu5%Q?p|O(Wm4 z%f2*9RRVGHGLt~O|H+#-+b!_sw{L#)`Q!HW_SNkf8?0w_8V9~@W}~pF(IgU3X+Ks2 z<`dM6V(u@r{c)g?b#D&UKj{Op?n_R!QWl+QDGT7ug1Hs8X6@A%iC?>P0Vo~tE5seq z-DgwI?H;K@P)mBRXw8}{qbME@K!c{aa%UNO6nAPGKp;cm1f&^{OU5S~Yz7H220*h| z3qf($Os?TKVAjA{_!+TsP(H)~#vn&W5o2lUxLRbP8>LQojRSeT6LXXjGJ*%(mW=C3 zXs{!9CS6PAmOy_@%?I^SO|>kQyE+EDL<8wjA(&E?Z&9s;Yi`l>Ibwmu5-IgE?*@ht z25=Nj@Hu7%Ij{mxEP^DGHzu+uF%`hMQ{n(RQ5Bb2Q-a+ZT_(XFQ2Js^ z-4>eg%rom0Qw68V2FNha)~lDw9J#|#lu*%kt!RT-3xYi2j|ioZHt|_8fI7V+B7DKoq&({aYp$(>BBSzo8^ zXLN!HE%*0Il&6VMrjkYo7Ytk=6~YAp2nZKVQllKt71EQ-TF=W7p>5iu08pke@O>+Q zX;hj76u%KD^&m9zkY{)$!qCg}Q1q0!E+AU)$9^Eybts)F6d6@DP>z&kx}Nu}EXv&T z_yS}EMThcfhnQ|#w8REQN5m}tJl18NOwnQ~vg{%RNV2eAf~8>^*}E=7f~U=Q4UP_^ z8&YQ3J>-c3=4ewji;KLgL*e6Hz#x~?WU}SbK5d4PRAy+ah=~d55Ru5y=vZ&Wd*{+t zjKpIz=DH!UMVm#zQ!A#{_Dd-SCrV=+saAs)B+`hGp}&FgQ{@-wnD8huN{wOTvxmy_nAga&8q#0@um}Svc zZOa(nanR;&pLT#{cl_v>)HNcV$~VSEIX6zsl%CSdNs0_1LaiyJ9281v@Vue(F!NGp z9l_<-xZ6=*K$JUaPC#uFEDW5Ihz3gmrernfj979}g`l&3U$q;5cPT=DHvdRsQ?F74--|V0aW{%&8Hmy-O=8udA}n8{x7(TqJNDq(A`;t3!b$#E z{HFPu6TFo~-Ed9U?M#-Nx{2(_c1Oy6t^H!65wFJ3=?s)}a-O3waHMn-Vzm-bV!(4? z_T8Z?CPq_PnQIQaMiU5HHTQQV%NOlJSN~&<8a!fYZ~!p;KpxFg-*07+C9Ykd=>e>i zc)W}G7tm(bh!r0EUIC&lx#9fU2R;vu3egNaf(WO}heT+tM%35EewQbvM@Jx1S z2eKubC^zyT=?18n9r`4~)Ck(-w*g^%{&4I;O+0f`ciG2iZ37gMR`e_n>f{6AAE>tS z<0Bl2-{hu4>1$TeG))6E+h(&`fP=WEyLo;&erJ6}=tuY%eUh0KO+f0|w1u`xBJ*E+ zg}#~dRs!XwT*o0?IIT3my?#hY@(GL|-Ude1i|eyoqrM(yB8p1L@_ZEoARVT?)`(YHV$l=cckfCs66ST2a{F5XfuiNFx z3-j^k57+30VNNo`tSbIlE1mK&Y>AfYX#$Z{u>mPk3O#V7oAr3Ht#>aRxqj#V0#ZEZ z%U8sceH_QU$UPwqTk0zG;yL`0EBjz?a|$#l6>{KydP_I6nQx2MT#C7|l4a1MX$hL05iO7!<_T{#St zvL5RXmoT;8!oythY19J}5kO^zCzptxoIDCjsb2d>)(tDZQX00S8;62_rcN(tH8<}g(XyWietpj!Z@&CPKQu9jLx*~(Sb6yTfkYbEW00GMkX4;{8nBpGW#Ahc zS1R|_{XOuY+R{Hv-VnEK$_tY`mv$%jWUCAhD!Ih_W2r4jmR?jbV3~t;ylymAktgGE zEp?*5w*T$6kzjsSQ`#p$`-Y$x_!|lG&qVo_n#vM~$!!2Ep7$XmBL;G*^Qxj$Om#^; zIoEANo$D8mJ@AU}ANP+B_jk89=i>n@EVC@v>#+`6a_6}<9*;+LRl-di<1v7LnMBix zb-9OmfHif2^??_FwO1Gg$BEeeSzx5Vfq7{T!Xn?zU1Fv+&PO7<0C*FlCee06tJIQF z8P$bhxtlG8ex*BEqYN4mnB= zS0i;Qw9Ofe9nvRLpdTJ?ye~``v{ns2T%@~Vxe5??xDoijkM+TW=N=;O&^6`9n9f0IIv zTpNb~Bd9BJ34O0u;CyNu-=!!k$^a z8Gr!WGY@_0`Z9kQjRCqU6SOSMUg(5_s2}DP>(M<(OzIswN7lx9jPyCzLbp1OCBR{R z2zfz3HBF4X>;Q;l!VkHmcu4=kRY~g&2@7!ti$QP|kl$r9-3|1(@baH#9emB98+@v; zr?#OJe_4Y}H6smv>3^-+ps$<5TK2A=3`~OG2Cmk&E;t?&fPbZNOG}+141KS!l<;H` zWc{WL12Af%f)0&o;w$YbJ4k zM^jrLjoh$De5wWIc{cajME+oX72e~L!{@zcV;XcS9aYmwX0rH#iZ4m4eH@lI5-i8v znED)6M17v7#yi|6LtT%$n$c(xe?oJxa&!NptLo9HUKhicb0LQDWUsNB)n%b8YMCm! zqK$MS+|`I_0_=MNpAe-VC^?od60DK<62oI^tTe-jbZt3j1bLej#oSN5F7rytBPE z0??;2#@roBT0W>M!pssu#3>2~(^jYo#ddt`EI*h*g%1l?a4f;$Snyx&tuN|vQvmG6 zd_8Xy5qstC_^5_BbM%fMjDqP{WOZD~{*e$PRIO91 zYO7B%LAgEc5K)sUIFL}PR0f|k&^`K3W2(w78-HZJCXga4LiVVU;@1E%pkcejfF)W5 z%Dv>g@L$gvhHEC_51??!H=gV&SC%&bVVypeCR$ug)w&wYjaNY(E1K0RiYR=I)$Qu$ zu+wnArXK2nYg4XWb8ou;u=KiA*6MtLdYN81sgnwIFAAggJly z!zz5SFcWL6brou}9*3yG0+ud+C=9t+9?J1vQ+z{4#}Leid{v|rYf^ma7vpDGFzcM# zdNXfPp)3+3)rtY&|0kDq*l+SQnR@P^nm%MOEpKFae3mH9N1t`0`|aJLohRaBH9P>J zxI9n5k9!g2Nhl}fiyz(|)5I27;I={8mW79+*+c*jxNoW`sL7mii;aH&aNo{YM6nF0 zW9;^cNFD>JX10`vLX3-ros;}UuCby3@vE5Mp7-0jR3asGEXbIA7@MrO@9#6>`E!zg zfrTvzHxG@znrgN}d zv8#@9Op%dnz#IACRSOLugS!XtiK)hi&2 zs6vMIdyR<~PS^ZEW%ha@gHJOJnUS@W6vm28NiuHS-uz5yzMTH{`^qu4J}|gUP_y3y zcI|4PCr+HzIK;FyR+u5a5IDraH%}(Zvt&!qHi}l%+qe4gp7vK+zq~meRhszTZ1`oa zKKYQz`|N5$QKUi3+8T+hGh}zbiU~u>ijki%4eHg-`^THA?VQ)tP=(9XAbP{LI3^*Y zPoC1}S*mp6Zu0)`=Vo5V{W1aII0Asb1Tein&wmxlU-mQre*Gn50Ko67{_}6)*SYJP z4v;n&00G3Xv|o9K+SJqAm&x?2j=J6KG?;QC4I}}*jS6VPk+_XkyRV>72`q*K0nianh>luiKUv_RML%?5%X$2DMzL=V&U zOBMKH*voeUiSrI8U^76B3zeS5!U~TmF~~R0%jp(4shsUxAaF%S{s*9vOnE1eK$p~E zkWT>Y9iPQ{3<_}oU>g#5^1K}affI0mopcEt2KjKw0>+hk@ zFFg!7a+S%KCPk`3NO<17`9l&*rG~_lO(};{aFHp=ZAo|$AwOBVGb_z6Xo?z3Ma%bp zfN7>H?yKN=^1ePDh#{T`>-+%2J&)o8NQ20$7-|P{8nFXu>*M$v0eHGlE;27(Au9u8 zxv3^(PhQJx8va>|>$z}jLNJ%v^KWQu6@NVofD|wgl(SAtwwKaAE1_YiV7=l(?TmBI zbA{u^-39-;=n{`8zD$#U#${KexTf2FBYeH(hrk~Z$#plRx+wrzAd3G4VM;q#I)-e? zG8peyb`Fl$xN-yaVDj+r2?*U%s8~smBB8;BMFpmnW}__Hw3(LMtkS3`@1pFwKP_U# zsZyg>wRj06q~18_l-uaiR{aS&jOfHzWM8*~BqnASR;)SVm|Kyj>AS^=@V$ZU}-ACtGOIW6u~p4Y@?YsFql2 z+!({aPP-g&)JYR2O*!D7ko9SBn0Bbq>OkLnA524XhOZ;ZcxO3MnN@Ww(4rVzL6g9-W+Q^*&ixqBiuR52S^z`>}+XoJuPuA5oB2 zN>^dX_B5tKwohfJHOnlK73LAJw*&+X^vFPV3UP9(`7SPInGI2S9*s zM$2q~dS#dx0+^#HusJergxVYzkV?SxJE&6wfbhpvisLG3@%5G*py;^hnCd`Fans=6 T#sR!z6s8Xz*HR$>CKCVv{vQ*U literal 0 HcmV?d00001 diff --git a/deps/npm/docs/public/google-fonts/s/poppins/v9/pxiByp8kv8JHgFVrLDz8Z1xlEw.woff b/deps/npm/docs/public/google-fonts/s/poppins/v9/pxiByp8kv8JHgFVrLDz8Z1xlEw.woff new file mode 100644 index 0000000000000000000000000000000000000000..cdafba1a23117de4184554b8a743cd69ed6e4024 GIT binary patch literal 10500 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
hXHJU+?zFU4g&YF-v%X|z0 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 literal 0 HcmV?d00001 diff --git a/deps/npm/docs/public/google-fonts/s/poppins/v9/pxiByp8kv8JHgFVrLGT9Z1xlEw.woff b/deps/npm/docs/public/google-fonts/s/poppins/v9/pxiByp8kv8JHgFVrLGT9Z1xlEw.woff new file mode 100644 index 0000000000000000000000000000000000000000..a2d64a1fb360d48d8c4f42fa421a320ea9a972d3 GIT binary patch literal 10512 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 I9V$Tn4}km!82|tP literal 0 HcmV?d00001 diff --git a/deps/npm/docs/public/google-fonts/s/poppins/v9/pxiByp8kv8JHgFVrLGT9Z1xlFQ.woff2 b/deps/npm/docs/public/google-fonts/s/poppins/v9/pxiByp8kv8JHgFVrLGT9Z1xlFQ.woff2 new file mode 100644 index 0000000000000000000000000000000000000000..fcf632b49d3edb12100012bb60b18467bbea1f40 GIT binary patch literal 7960 zcmV+zALrnAPew8T0RR9103R3t4FCWD06ruD03O8v0RR9100000000000000000000 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 OX7HbX(O4dhF2evwAzSGH literal 0 HcmV?d00001 diff --git a/deps/npm/docs/public/google-fonts/s/poppins/v9/pxiEyp8kv8JHgFVrJJfecg.woff2 b/deps/npm/docs/public/google-fonts/s/poppins/v9/pxiEyp8kv8JHgFVrJJfecg.woff2 new file mode 100644 index 0000000000000000000000000000000000000000..6711b0b85fcf49c5e792a27416bfc4830c140dd3 GIT binary patch literal 7968 zcmV+*AK&12Pew8T0RR9103RR#4FCWD06v@m03ON!0RR9100000000000000000000 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 WhD*(nxV(`6Ka4JNBodJd0000fD^6el literal 0 HcmV?d00001 diff --git a/deps/npm/docs/public/google-fonts/s/poppins/v9/pxiEyp8kv8JHgFVrJJfedA.woff b/deps/npm/docs/public/google-fonts/s/poppins/v9/pxiEyp8kv8JHgFVrJJfedA.woff new file mode 100644 index 0000000000000000000000000000000000000000..606db1d7a3129997d3bd80e6598fd354475f1560 GIT binary patch literal 10484 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

c^Ws#8~az=*wf$XC$EhcoL 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 WV_Pcv!B0+c@z4^$c(8pL;Qs)zcmYQM literal 0 HcmV?d00001 diff --git a/deps/npm/docs/public/icons/icon-144x144.png b/deps/npm/docs/public/icons/icon-144x144.png new file mode 100644 index 0000000000000000000000000000000000000000..cdc55431449e2e71a25227d51dfd87d2aeda4378 GIT binary patch literal 829 zcmeAS@N?(olHy`uVBq!ia0vp^6F``Q4M;wBd$a>caTa()7Bet#3xP1>rMq>17#Nt| zd%8G=RNQ)d+t*v#QRcwIBjJCZ#D)IRySH?y6<3wO7XbmsElm@H7N7lHqTZ>>?*I1P zwaEGQecgZSq>!L5)x8^i42sto$FnBU>Dln=vs5G!l01AMGI2FJ`EEj&W zO8<%H?q%4rP0auL_0aO8`_j2JbY9wP{aSX*y6U;kr(KO*<_fxxjvsV!(lu zc>T(&^vcU4aU8`KZ_DQWKXl1-*1eXN<5%n_*V)T0-y9KnQaWH)F z{p$QahF>lXW@cJHZ<@oM33ls{AOc=CTzXWrqRioO;mZ5_BO9#d&bYlt_R!&fb*c@1 z;tg^7dRozkfBdv8cIftf)heL=w@#*X_vYAh{GfCPOm&lh=?+&yti4soyhUk_UKICyL12Dh@O1TaS?83{1ORx| BA{GDu literal 0 HcmV?d00001 diff --git a/deps/npm/docs/public/icons/icon-192x192.png b/deps/npm/docs/public/icons/icon-192x192.png new file mode 100644 index 0000000000000000000000000000000000000000..31dcbfa6bdc2191bbbe2185d6e08761e1bfcef58 GIT binary patch literal 949 zcmeAS@N?(olHy`uVBq!ia0vp^2SAvE4M+yv$zcaloCO|{#S9GGLLkg|>2BR01_tJI zPZ!6Kid%2*+WI*;inKkveIu%~kUyurbpumw@80eOix22(h%Xk~rq=erUq{4?w@umE zq>#1eqfPv$Z$^iU*UO$wz1%Wo>oG+R22Qe|rfNgyCAJ2AMuwY=TV5aY3ZE@`;Jokx znL}Id_y5cgS>N0^DdgSmJJr!Ya|2`@Dut#T-cY0c-HvU+O&dX-`=|CY1APVtK%Y_z znQn_(8}wh6p@R8H(Z-JNzkgTE_uGE&c#hcWrwEpttAI)U){%>CY9+%F<-v0Giw?N-)&dn^Cr-Cs_I w$xl-4fSJal_8o%<$&iDgU4cP`VM$3X+N-WKWRsa_QYr=@gI31GAR>(1T!vrq;oAm^KPtSbE^xky&Yt3l}9+S#8H#$#XP~c>kL<>TQL8gg?!IME_SNckI zpx>An7>bw!wx3<%w3>0l-v7Toey=g{(tlhyOJ2sq_3GWz-|Eb4tE6A>GJJjZFg_$S z%6Iw8S|iW*+qVZvZvAffF7?j&9m`D_J~0Wb4_C~Q*%Z05`?uux61Ijv3`erVJhH=H zJ*qoq%X(lNLq`1eGhM6;_ReQuXaI$&0T45QLiGTMAps(ofj9xg-~nPhip~I~je#10 z$_#*dsK8yI9=-m0tR2u$28Q{P3=B7p{;jF<>R#p5{rK^hs;a0sb@i8D-{`EBlmE*C zR8sW*?WsEBzKU@K31`^XHx)}q@ z$DWJkOE#Q550#%Y>9^{(?U-I@|9IXth7lbM~aY{Ga{pd-t9d^-LGuycMmVc6V>i`{(!H z=`t9_c2#{YcBouc`~K$n&pX}EhrDM9_*e6NcjYn$0S1N(^ZB*$7k`WnLJTUD5Kmu< Ym*^arE6j26DJaT3UHx3vIVCg!0Es&)tZP2OR_I^54nr^lZ0ky2FD|32^ek;p@n$_g#Ne{Gk)Hq-L_&Sx^epZ)sfG-=9u zJNYIRMu$l(44y&^DxM4zDC2N4Oj2R+n8cvq$<&}i8HeG6q6bkCTFY|O-@Cr`dOcV1ub%9S@N{ze5&UUjatcHipaxO3H(-`6_( zGc$OwIlM32@JC5QymjW&2#^8a-!U?H@HkZJ=HF{U-sI#R`}Qg;r}m#rw72)ht$XhLS+#%jpR?9?^WMCFQ^CptRH<;kY=2$v z+4A>Exk*aX-rebZy1P92>A~i-^8a;f?(7zSeSV&6dD=2Jkf{s|mvWb1?zE5F)6uFO zp7icWX9hpd5&!1qvu_Ty?)v%pdGfz6FMm9JbyceIlL|z`Plg|#RIka|_kBA#`J;2G z?4O9MSrzj8{?26uDhY^V2gNmmgCE1OhF;=88Zp;Aa=eelXs}j- zFb_aQKnV;83?Nhk*f|Ugpril<31E_e0hH)~KmtM?fKUvy(h4;mM$y{31gJ$6coJg5 zpa?wtzJYobMh$2*<98`EaY0>5r<6yOldxwMSdc>L15lb)c_aa9{%E45AOyf#8{V@Y zIN_1wyMwGo;ECh6S0{8f8g~$cRoJ;n!TX^`ns$0 zk3Kp(`|SUF{Bz%foNoVVGoyo@NK|_qr>1**{omBR&!Ri`|Bn1_2TX2Eo7Yv|w`M3} zUT|mUwc7WfiiRWR^S*Kh3!Wn7g0sKxF;b(^M`8OD(ST)Y;CCXe9s1J#b^fcGH|hGF R9v?v2%hT1*Wt~$(69BC8ZM^^h literal 0 HcmV?d00001 diff --git a/deps/npm/docs/public/icons/icon-48x48.png b/deps/npm/docs/public/icons/icon-48x48.png new file mode 100644 index 0000000000000000000000000000000000000000..a6fe2644f92e34d9fc860144f128074c78a72290 GIT binary patch literal 581 zcmV-L0=oT)P)4&OfT@stQ6Tb6O3~0NDCN0E|2~ZNCRymVJ>XNyeP=VgW)b zvERaNf;5{E009sH0T2KI5C8!X009sH z0T94d04(?6z;{bk?*lOZ6Jz=1!d4bV?*LdO_R>a$!c_oyxwN%aHk%&+x5Zs7abrZV z(26O&M>2{>PhIP&DuuaRBfs;_ z@0V@_mwlLK7wEX@v5?fAgvrvWd`jzztu!5bOBa=Eu! zdZ4#=+lbDa0azkNuNP3&qs^&yvwYn)AgPF>As~Ff#sPxM;*AH-Y-ct_e3X!{uO}tal$VFn$C`n+}vHket$ms@}$?fM~}YGT%K0HCd&U_Wd&!Ea$>xE zqdiO;3t=wJ-&I!TUJ^zh+HrrJON=6JV{Gi99S?#XnJqWN#UL;Q z4|u~AW&w)UVr;aQ%|vg}-;vHC_LPYBKd^gsye}?_<%NKQA<}UgzsdFo?w4M(-*)>& z`D)CyP{12)T8HYuU2CCudGjxA`a;Uy%a<=pf^(b^!r?4vbieHvjsdf%_^L_Eot)gh z?oJ8k#vb2Hl;Eh`a5g-GNP$;>Ac-CN_;K6cce|b*I&^E++QhSA&b9%$C#KHGsc8u0 zj31vE8Why_s4d9Fl1u^WaICE5VamhG;|CKXrAeE(+_pb*Hb;ebDy;7RxS{2KbwKIA z#oRepBLkvr{w5R8vIwN7fp=|JlrrSO!l)?;-R)($`FjL@O@AIL3y2$4WIg{$gh0?$ z_xxFuup-^+Y?nGeIg!##Eo5e%{~@CwW>!hc#OZGN?c(gaS=~k4>}yA>w_nK4&P`UW zYv1jT55!m?C8M7#6gCs|33w-KG&M<&6m;vX#1xP9uHY{3Zj0A=-6pI!% zjF}=m77=I=4kO|)1F#}JHdhPW320~aN(2Ggk$wT6Vk6I(MoWe9CU_{Yc+vk<7<>_} z7f}W9Gt}{gxLLvOs{~OJ8=K6eRrNX*(Y%uIx1zZdU!fFT6i6MQw@7O4OHu3KA*@c! zB2nleny8qzlMTAeKm`$L2W0Pq2+Uj>AX;Rg+BYt2kqU$64eFPZ7 zgymq!(1asGIA#RNVftN2pY%edIZ>JSrLLB6CQaUrZ#DjVA0!jC>5*%!ny*t44f@nicp#DzNS^B#$P?ySe@Q{|i>@(P>jpbN%p{ss*YzwM@o+IV z(e@EdR7`8&^_5oCVEpuf`u{lDT0DoaFe7>!iiONTClTssm41OSX80vCBk8RA|AFymsU^M4H%_x>~}uW%J$m#*d%DG7+6)+c`?d z7oCX>HJJT+Ux|HhcKvwjXSa}e8%S=S?!h^fL&%tozd_CqF~LSy-Fb$BDu~e={sRzHm0nQ{8Y!-QfW~u27(wD)yHu8hvNN-AWn9L&?Ffw@;3502`Y*c@dk) z7ovFeiu{f%-Uav5j{LJ`QO`_8QH|y71Cp%BNv;+}f7}~8X=?$?ry&yVNm9r^U$sgp z@mE(=mglylpJ@|p>;DDk`FzO91=Yoe?H}K1tSJ60)g@~Ad}-yKSYK7qxNXz-eA={r zg_vudvMMuq@56XYY1}g}%~O@Un7a^fLJWBRrJ5VHbwQ;E3J7}JlalX_T(1` z!p&j@#Z{r1*E<$BdPZ~$W$g>hC7Z3QuWp|%R$50_*Th%f>=IQ+D9)EhJIQEl;vbVQ zZX0N{NZnN-k+j=*cc(7(ZSt=>m>D;EpS}0Zz)czMf>DrK9ko-{{wS{?=J>M~#ZR^W z63Iiwr&>7SMi9)ImNjCL+4*^zk9fXW6I$E@R6Q;-H6@Q<+!-2N-}Sq#5p`sd#kX_4 zjHsSpg`MTI6NY6m9}UZzY#&3; OFn{T)B{?4ke*QmbwQ~Rf literal 0 HcmV?d00001 diff --git a/deps/npm/docs/public/icons/icon-72x72.png b/deps/npm/docs/public/icons/icon-72x72.png new file mode 100644 index 0000000000000000000000000000000000000000..f4ccb61f49c6eb08342a70aebc346bc46a1748b7 GIT binary patch literal 610 zcmeAS@N?(olHy`uVBq!ia0vp^9w5xY1|&n@ZgvM!oCO|{#S9GGLLkg|>2BR01_mY( zPZ!6Kid%1Q@6S3EAi`Ggzj1Q+FNUVo3mz=k*TDZUddIF`22I`FTzyJgUT)pGWvf%W zp04cLP!`wT<=>BJEzIbh5Z&`ruf{_4`3tn`^QBEc>jm+vY}etRcSAEd`gQnbP6Y-=kV7V%b$I=?>U(9@nd3W|J+AwAX*Znl z(CXVgL-xr2bMc=ltNfN{PB?o>Ve-xSF@3*QitH8RdbjIn*k#STY|XpX-#hP|xN}lv z&+)tLCGx#_ajqYfeypsHf6{EM{B^SDcgC-W5|cmvdG~UCxISBe5+l@3i08r9<7O`S zyO!hg&f2$3-K`rBT&>7q;Outrk6y4j!}W&Q<`bSFeQ_#Dne3U%{r zC+JA5G0)NHYumO&eTiIsF;=5w&vfrchL4bP0l+XkKL{0xO literal 0 HcmV?d00001 diff --git a/deps/npm/docs/public/icons/icon-96x96.png b/deps/npm/docs/public/icons/icon-96x96.png new file mode 100644 index 0000000000000000000000000000000000000000..739a5fe5379e124bfeacf15b341d9b01d270ea12 GIT binary patch literal 712 zcmeAS@N?(olHy`uVBq!ia0vp^2_VeD1|%QND7OGooCO|{#S9GGLLkg|>2BR01_q`o zPZ!6Kid%2*p7uKIAad+u*jwQprAv1dy`8;7=wj~=rfaPVyFT^0-09xCL@6%dL)3*w zej-aVw=O$wIl1a!=*v$0t^fa3=9qo z3=Kfio-<=XG5;OLwzef^HgnEC`CP})bpF|FCaq@?=Q399m1E({clu<0z~<+zKfllV zR^Gcib@|)e%3C*2y2x$c_GD?$#MLt;xfAcVU12=4#A>IR{p!UVx2dUKZvHz_u%6-9 zlh++lx-ZMDW_pOUeVdm*eY&p0S?z{O)zXZ_NXd(@vw1dbVgd#MD$wl7+y1+>K;&lf?zriPHyT>bn=xVW$B+ApZ7em}7cVY~)=^s}+aTxg`p=y@ zkyU&Wf2+2p7ui}%$G?Be+u*`5efr0A$G>`W&wro$*XiK3y3HFH8iWrVJ$k+Trpng) zXU;RDT22vff+a)jiCbc#ZQC}4T*|v`d3dw2dc*6TJ9m6bD_-#P{@I^m5A=0n*R1aN zEj72jJ%wReVpMf)=E=-|$Bwz}sVHCgfbqbcE%)~5JzTfCr=Ee#h&JshQ8|V zK6&l!`>SfBEwL;@ls%Ha6RNs`_jGUzdL1*6O~`zwaJ+SRC{@ zJmvcN?}EnV4}z-mU(Qk~zI}hD`u+cMM*mBM=N|a{Cnx!+T@nj8IWRaVgOdUSFm+5S ZvSWxTHCJm9H+l>T2~Sr)mvv4FO#tLDAngDE literal 0 HcmV?d00001 diff --git a/deps/npm/docs/public/index.html b/deps/npm/docs/public/index.html new file mode 100644 index 00000000000000..cab38416ba2291 --- /dev/null +++ b/deps/npm/docs/public/index.html @@ -0,0 +1,125 @@ +npm cli | npm cli documentation

npm cli _
The intelligent package manager for the Node Javascript Platform. Install stuff and get coding!
npm cli _
The intelligent package manager for the Node Javascript Platform. Install stuff and get coding!
npm cli _
The intelligent package manager for the Node Javascript Platform. Install stuff and get coding!

The current stable version of npm is available on GitHub.

To upgrade, run: npm install npm@latest -g

\ No newline at end of file diff --git a/deps/npm/docs/public/static/d/2215187023.json b/deps/npm/docs/public/static/d/2215187023.json new file mode 100644 index 00000000000000..c26e85bd6966e2 --- /dev/null +++ b/deps/npm/docs/public/static/d/2215187023.json @@ -0,0 +1 @@ +{"data":{"allMarkdownRemark":{"nodes":[{"fields":{"slug":"/using-npm/semver"},"frontmatter":{"description":null,"section":null,"title":""}},{"fields":{"slug":"/cli-commands/npm-adduser"},"frontmatter":{"description":null,"section":null,"title":""}},{"fields":{"slug":"/cli-commands/npm-dist-tag"},"frontmatter":{"description":null,"section":null,"title":""}},{"fields":{"slug":"/cli-commands/npm-explore"},"frontmatter":{"description":null,"section":null,"title":""}},{"fields":{"slug":"/using-npm/config"},"frontmatter":{"description":"More than you probably want to know about npm configuration","section":"using-npm","title":"config"}},{"fields":{"slug":"/using-npm/developers"},"frontmatter":{"description":"Developer Guide","section":"using-npm","title":"developers"}},{"fields":{"slug":"/using-npm/disputes"},"frontmatter":{"description":"Handling Module Name Disputes","section":"using-npm","title":"disputes"}},{"fields":{"slug":"/configuring-npm/folders"},"frontmatter":{"description":"Folder Structures Used by npm","section":"configuring-npm","title":"folders"}},{"fields":{"slug":"/configuring-npm/install"},"frontmatter":{"description":"Download and install node and npm","section":"configuring-npm","title":"install"}},{"fields":{"slug":"/cli-commands/npm"},"frontmatter":{"description":"javascript package manager","section":"cli-commands","title":"npm"}},{"fields":{"slug":"/cli-commands/npm-access"},"frontmatter":{"description":"Set access level on published packages","section":"cli-commands","title":"npm-access"}},{"fields":{"slug":"/cli-commands/npm-audit"},"frontmatter":{"description":"Run a security audit","section":"cli-commands","title":"npm-audit"}},{"fields":{"slug":"/cli-commands/npm-bin"},"frontmatter":{"description":"Display npm bin folder","section":"cli-commands","title":"npm-bin"}},{"fields":{"slug":"/cli-commands/npm-bugs"},"frontmatter":{"description":"Bugs for a package in a web browser maybe","section":"cli-commands","title":"npm-bugs"}},{"fields":{"slug":"/cli-commands/npm-build"},"frontmatter":{"description":"Build a package","section":"cli-commands","title":"npm-build"}},{"fields":{"slug":"/cli-commands/npm-bundle"},"frontmatter":{"description":"REMOVED","section":"cli-commands","title":"npm-bundle"}},{"fields":{"slug":"/cli-commands/npm-cache"},"frontmatter":{"description":"Manipulates packages cache","section":"cli-commands","title":"npm-cache"}},{"fields":{"slug":"/cli-commands/npm-ci"},"frontmatter":{"description":"Install a project with a clean slate","section":"cli-commands","title":"npm-ci"}},{"fields":{"slug":"/cli-commands/npm-completion"},"frontmatter":{"description":"Tab Completion for npm","section":"cli-commands","title":"npm-completion"}},{"fields":{"slug":"/cli-commands/npm-config"},"frontmatter":{"description":"Manage the npm configuration files","section":"cli-commands","title":"npm-config"}},{"fields":{"slug":"/cli-commands/npm-dedupe"},"frontmatter":{"description":"Reduce duplication","section":"cli-commands","title":"npm-dedupe"}},{"fields":{"slug":"/cli-commands/npm-deprecate"},"frontmatter":{"description":"Deprecate a version of a package","section":"cli-commands","title":"npm-deprecate"}},{"fields":{"slug":"/cli-commands/npm-docs"},"frontmatter":{"description":"Docs for a package in a web browser maybe","section":"cli-commands","title":"npm-docs"}},{"fields":{"slug":"/cli-commands/npm-doctor"},"frontmatter":{"description":"Check your environments","section":"cli-commands","title":"npm-doctor"}},{"fields":{"slug":"/cli-commands/npm-edit"},"frontmatter":{"description":"Edit an installed package","section":"cli-commands","title":"npm-edit"}},{"fields":{"slug":"/cli-commands/npm-fund"},"frontmatter":{"description":"Retrieve funding information","section":"cli-commands","title":"npm-fund"}},{"fields":{"slug":"/cli-commands/npm-help"},"frontmatter":{"description":"Get help on npm","section":"cli-commands","title":"npm-help"}},{"fields":{"slug":"/cli-commands/npm-help-search"},"frontmatter":{"description":"Search npm help documentation","section":"cli-commands","title":"npm-help-search"}},{"fields":{"slug":"/cli-commands/npm-hook"},"frontmatter":{"description":"Manage registry hooks","section":"cli-commands","title":"npm-hook"}},{"fields":{"slug":"/cli-commands/npm-init"},"frontmatter":{"description":"create a package.json file","section":"cli-commands","title":"npm-init"}},{"fields":{"slug":"/cli-commands/npm-install"},"frontmatter":{"description":"Install a package","section":"cli-commands","title":"npm-install"}},{"fields":{"slug":"/cli-commands/npm-install-ci-test"},"frontmatter":{"description":"Install a project with a clean slate and run tests","section":"cli-commands","title":"npm-install-ci-test"}},{"fields":{"slug":"/cli-commands/npm-install-test"},"frontmatter":{"description":"Install package(s) and run tests","section":"cli-commands","title":"npm-install-test"}},{"fields":{"slug":"/cli-commands/npm-link"},"frontmatter":{"description":"Symlink a package folder","section":"cli-commands","title":"npm-link"}},{"fields":{"slug":"/cli-commands/npm-logout"},"frontmatter":{"description":"Log out of the registry","section":"cli-commands","title":"npm-logout"}},{"fields":{"slug":"/cli-commands/npm-ls"},"frontmatter":{"description":"List installed packages","section":"cli-commands","title":"npm-ls"}},{"fields":{"slug":"/cli-commands/npm-org"},"frontmatter":{"description":"Manage orgs","section":"cli-commands","title":"npm-org"}},{"fields":{"slug":"/cli-commands/npm-outdated"},"frontmatter":{"description":"Check for outdated packages","section":"cli-commands","title":"npm-outdated"}},{"fields":{"slug":"/cli-commands/npm-owner"},"frontmatter":{"description":"Manage package owners","section":"cli-commands","title":"npm-owner"}},{"fields":{"slug":"/cli-commands/npm-pack"},"frontmatter":{"description":"Create a tarball from a package","section":"cli-commands","title":"npm-pack"}},{"fields":{"slug":"/cli-commands/npm-ping"},"frontmatter":{"description":"Ping npm registry","section":"cli-commands","title":"npm-ping"}},{"fields":{"slug":"/cli-commands/npm-prefix"},"frontmatter":{"description":"Display prefix","section":"cli-commands","title":"npm-prefix"}},{"fields":{"slug":"/cli-commands/npm-profile"},"frontmatter":{"description":"Change settings on your registry profile","section":"cli-commands","title":"npm-profile"}},{"fields":{"slug":"/cli-commands/npm-prune"},"frontmatter":{"description":"Remove extraneous packages","section":"cli-commands","title":"npm-prune"}},{"fields":{"slug":"/cli-commands/npm-publish"},"frontmatter":{"description":"Publish a package","section":"cli-commands","title":"npm-publish"}},{"fields":{"slug":"/cli-commands/npm-rebuild"},"frontmatter":{"description":"Rebuild a package","section":"cli-commands","title":"npm-rebuild"}},{"fields":{"slug":"/cli-commands/npm-repo"},"frontmatter":{"description":"Open package repository page in the browser","section":"cli-commands","title":"npm-repo"}},{"fields":{"slug":"/cli-commands/npm-restart"},"frontmatter":{"description":"Restart a package","section":"cli-commands","title":"npm-restart"}},{"fields":{"slug":"/cli-commands/npm-root"},"frontmatter":{"description":"Display npm root","section":"cli-commands","title":"npm-root"}},{"fields":{"slug":"/cli-commands/npm-run-script"},"frontmatter":{"description":"Run arbitrary package scripts","section":"cli-commands","title":"npm-run-script"}},{"fields":{"slug":"/cli-commands/npm-search"},"frontmatter":{"description":"Search for packages","section":"cli-commands","title":"npm-search"}},{"fields":{"slug":"/cli-commands/npm-shrinkwrap"},"frontmatter":{"description":"Lock down dependency versions for publication","section":"cli-commands","title":"npm-shrinkwrap"}},{"fields":{"slug":"/cli-commands/npm-star"},"frontmatter":{"description":"Mark your favorite packages","section":"cli-commands","title":"npm-star"}},{"fields":{"slug":"/cli-commands/npm-stars"},"frontmatter":{"description":"View packages marked as favorites","section":"cli-commands","title":"npm-stars"}},{"fields":{"slug":"/cli-commands/npm-start"},"frontmatter":{"description":"Start a package","section":"cli-commands","title":"npm-start"}},{"fields":{"slug":"/cli-commands/npm-stop"},"frontmatter":{"description":"Stop a package","section":"cli-commands","title":"npm-stop"}},{"fields":{"slug":"/cli-commands/npm-team"},"frontmatter":{"description":"Manage organization teams and team memberships","section":"cli-commands","title":"npm-team"}},{"fields":{"slug":"/cli-commands/npm-test"},"frontmatter":{"description":"Test a package","section":"cli-commands","title":"npm-test"}},{"fields":{"slug":"/cli-commands/npm-token"},"frontmatter":{"description":"Manage your authentication tokens","section":"cli-commands","title":"npm-token"}},{"fields":{"slug":"/cli-commands/npm-uninstall"},"frontmatter":{"description":"Remove a package","section":"cli-commands","title":"npm-uninstall"}},{"fields":{"slug":"/cli-commands/npm-unpublish"},"frontmatter":{"description":"Remove a package from the registry","section":"cli-commands","title":"npm-unpublish"}},{"fields":{"slug":"/cli-commands/npm-update"},"frontmatter":{"description":"Update a package","section":"cli-commands","title":"npm-update"}},{"fields":{"slug":"/cli-commands/npm-version"},"frontmatter":{"description":"Bump a package version","section":"cli-commands","title":"npm-version"}},{"fields":{"slug":"/cli-commands/npm-view"},"frontmatter":{"description":"View registry info","section":"cli-commands","title":"npm-view"}},{"fields":{"slug":"/cli-commands/npm-whoami"},"frontmatter":{"description":"Display npm username","section":"cli-commands","title":"npm-whoami"}},{"fields":{"slug":"/configuring-npm/npmrc"},"frontmatter":{"description":"The npm config files","section":"configuring-npm","title":"npmrc"}},{"fields":{"slug":"/using-npm/orgs"},"frontmatter":{"description":"Working with Teams & Orgs","section":"using-npm","title":"orgs"}},{"fields":{"slug":"/configuring-npm/package-lock-json"},"frontmatter":{"description":"A manifestation of the manifest","section":"configuring-npm","title":"package-lock.json"}},{"fields":{"slug":"/configuring-npm/package-locks"},"frontmatter":{"description":"An explanation of npm lockfiles","section":"configuring-npm","title":"package-locks"}},{"fields":{"slug":"/configuring-npm/package-json"},"frontmatter":{"description":"Specifics of npm's package.json handling","section":"configuring-npm","title":"package.json"}},{"fields":{"slug":"/using-npm/registry"},"frontmatter":{"description":"The JavaScript Package Registry","section":"using-npm","title":"registry"}},{"fields":{"slug":"/using-npm/removal"},"frontmatter":{"description":"Cleaning the Slate","section":"using-npm","title":"removal"}},{"fields":{"slug":"/using-npm/scope"},"frontmatter":{"description":"Scoped packages","section":"using-npm","title":"scope"}},{"fields":{"slug":"/using-npm/scripts"},"frontmatter":{"description":"How npm handles the \"scripts\" field","section":"using-npm","title":"scripts"}},{"fields":{"slug":"/configuring-npm/shrinkwrap-json"},"frontmatter":{"description":"A publishable lockfile","section":"configuring-npm","title":"shrinkwrap.json"}}]}}} \ No newline at end of file diff --git a/deps/npm/docs/public/static/d/2417117884.json b/deps/npm/docs/public/static/d/2417117884.json new file mode 100644 index 00000000000000..a7412e7c9b4e80 --- /dev/null +++ b/deps/npm/docs/public/static/d/2417117884.json @@ -0,0 +1 @@ +{"data":{"site":{"siteMetadata":{"title":"npm cli documentation","description":"Documentation for the npm cli.","author":"@gatsbyjs"}}}} \ No newline at end of file diff --git a/deps/npm/docs/public/static/network-icon-f659855f70bb0e12addd96250807c241.svg b/deps/npm/docs/public/static/network-icon-f659855f70bb0e12addd96250807c241.svg new file mode 100644 index 00000000000000..d7ff6bfb1aee8b --- /dev/null +++ b/deps/npm/docs/public/static/network-icon-f659855f70bb0e12addd96250807c241.svg @@ -0,0 +1 @@ +network-icon \ No newline at end of file diff --git a/deps/npm/docs/public/styles.e93b5499b63484750fba.css b/deps/npm/docs/public/styles.e93b5499b63484750fba.css new file mode 100644 index 00000000000000..43ab98eaf07a2c --- /dev/null +++ b/deps/npm/docs/public/styles.e93b5499b63484750fba.css @@ -0,0 +1 @@ +code[class*=language-],pre[class*=language-]{color:#ccc;background:none;font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;font-size:1em;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-hyphens:none;-ms-hyphens:none;hyphens:none}pre[class*=language-]{padding:1em;margin:.5em 0;overflow:auto}:not(pre)>code[class*=language-],pre[class*=language-]{background:#2d2d2d}:not(pre)>code[class*=language-]{padding:.1em;border-radius:.3em;white-space:normal}.token.block-comment,.token.cdata,.token.comment,.token.doctype,.token.prolog{color:#999}.token.punctuation{color:#ccc}.token.attr-name,.token.deleted,.token.namespace,.token.tag{color:#e2777a}.token.function-name{color:#6196cc}.token.boolean,.token.function,.token.number{color:#f08d49}.token.class-name,.token.constant,.token.property,.token.symbol{color:#f8c555}.token.atrule,.token.builtin,.token.important,.token.keyword,.token.selector{color:#cc99cd}.token.attr-value,.token.char,.token.regex,.token.string,.token.variable{color:#7ec699}.token.entity,.token.operator,.token.url{color:#67cdcc}.token.bold,.token.important{font-weight:700}.token.italic{font-style:italic}.token.entity{cursor:help}.token.inserted{color:green}a,abbr,acronym,address,applet,article,aside,audio,b,big,blockquote,body,canvas,caption,center,cite,code,dd,del,details,dfn,div,dl,dt,em,embed,fieldset,figcaption,figure,footer,form,h1,h2,h3,h4,h5,h6,header,hgroup,html,i,iframe,img,ins,kbd,label,legend,li,mark,menu,nav,object,ol,output,p,pre,q,ruby,s,samp,section,small,span,strike,strong,sub,summary,sup,table,tbody,td,tfoot,th,thead,time,tr,tt,u,ul,var,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}body{line-height:1}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:after,blockquote:before,q:after,q:before{content:"";content:none}table{border-collapse:collapse;border-spacing:0}[hidden]{display:none}html{font-family:Poppins,sans-serif}*{box-sizing:border-box}li,p{font-size:15px;line-height:1.7;font-weight:300}p,ul{padding:10px 0}strong{font-weight:700;color:#c3f}li{list-style-type:disc;list-style-position:inside;padding:8px 0}.documentation h1{font-size:42px;font-weight:600;padding:30px 0 10px}.documentation h2{font-size:22px;font-weight:300}.documentation h3{color:#c3f;font-size:22px;padding:30px 0 5px;font-weight:500}.documentation h4{font-weight:600;padding:20px 0 5px}.documentation p{display:inline-block}:not(pre)>code[class*=language-],pre[class*=language-]{border-radius:4px;background-color:#413844;font-size:13px}:not(pre)>code[class*=language-text]{background-color:rgba(204,139,216,.1);color:#413844;padding:2px 6px;border-radius:0;font-size:14px;font-weight:700;border-radius:1px;display:inline-block}.documentation a,a>code[class*=language-text]{color:#fb3b49;font-weight:600}p>code[class*=language-text]{display:inline-block}.documentation h1:before{content:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' viewBox='0 0 27 26'%3E%3Cdefs%3E%3ClinearGradient id='a' x1='18.13' x2='25.6' y1='13.48' y2='13.48' gradientUnits='userSpaceOnUse'%3E%3Cstop offset='0' stop-color='%23fb8817'/%3E%3Cstop offset='.37' stop-color='%23fb8719'/%3E%3Cstop offset='.51' stop-color='%23fa8420'/%3E%3Cstop offset='.61' stop-color='%23f9802c'/%3E%3Cstop offset='.69' stop-color='%23f7793d'/%3E%3Cstop offset='.76' stop-color='%23f47053'/%3E%3Cstop offset='.82' stop-color='%23f1656e'/%3E%3Cstop offset='.87' stop-color='%23ed578f'/%3E%3Cstop offset='.92' stop-color='%23e948b5'/%3E%3Cstop offset='.97' stop-color='%23e437de'/%3E%3Cstop offset='1' stop-color='%23e02aff'/%3E%3C/linearGradient%3E%3ClinearGradient id='b' x1='17.89' x2='25.84' y1='13.48' y2='13.48' gradientUnits='userSpaceOnUse'%3E%3Cstop offset='0' stop-color='%23fb8817'/%3E%3Cstop offset='1' stop-color='%23e02aff'/%3E%3C/linearGradient%3E%3ClinearGradient id='c' x1='1' x2='18.69' y1='17.84' y2='17.84' xlink:href='%23a'/%3E%3ClinearGradient id='d' x1='.76' x2='18.93' y1='17.84' y2='17.84' xlink:href='%23b'/%3E%3ClinearGradient id='e' x1='1' x2='20.48' y1='7.33' y2='7.33' xlink:href='%23a'/%3E%3ClinearGradient id='f' x1='.76' x2='20.72' y1='7.33' y2='7.33' xlink:href='%23b'/%3E%3C/defs%3E%3Cpath fill='url(%23a)' stroke='url(%23b)' stroke-miterlimit='10' stroke-width='.48' d='M18.53 24.24a.28.28 0 01-.34-.41L25 14.06l-5-11a.28.28 0 11.5-.23L25.58 14a.28.28 0 010 .28l-6.91 9.9a.28.28 0 01-.14.06z'/%3E%3Cpath fill='url(%23c)' stroke='url(%23d)' stroke-miterlimit='10' stroke-width='.48' d='M18.53 24.24a.28.28 0 01-.14 0l-12-1.15a.28.28 0 01-.23-.09L1 11.81a.28.28 0 11.5-.23l5.07 11L18 23.68 13 13a.28.28 0 11.5-.23l5.12 11.12a.28.28 0 01-.09.35z'/%3E%3Cpath fill='url(%23e)' stroke='url(%23f)' stroke-miterlimit='10' stroke-width='.48' d='M13.4 13.12a.25.25 0 01-.14 0L1.25 12a.28.28 0 01-.2-.44L8 1.64a.28.28 0 01.25-.12l12 1.18a.28.28 0 01.2.44L13.51 13a.25.25 0 01-.11.12z'/%3E%3C/svg%3E");position:relative;display:inline-block;padding-right:8px;top:3px;width:28px}.active-sidebar-link{background-color:#ffebff}.active-navbar-link{border-bottom:3px solid #c3f}.header-link-class{margin-left:-24px}.disabled-body{overflow:hidden} \ No newline at end of file diff --git a/deps/npm/docs/public/using-npm/config/index.html b/deps/npm/docs/public/using-npm/config/index.html new file mode 100644 index 00000000000000..90b88a641b48ae --- /dev/null +++ b/deps/npm/docs/public/using-npm/config/index.html @@ -0,0 +1,1158 @@ +

config

+

More than you probably want to know about npm configuration

+

Description

+

npm gets its configuration values from the following sources, sorted by priority:

+

Command Line Flags

+

Putting --foo bar on the command line sets the foo configuration +parameter to "bar". A -- argument tells the cli parser to stop +reading flags. Using --flag without specifying any value will set +the value to true.

+

Example: --flag1 --flag2 will set both configuration parameters +to true, while --flag1 --flag2 bar will set flag1 to true, +and flag2 to bar. Finally, --flag1 --flag2 -- bar will set +both configuration parameters to true, and the bar is taken +as a command argument.

+

Environment Variables

+

Any environment variables that start with npm_config_ will be +interpreted as a configuration parameter. For example, putting +npm_config_foo=bar in your environment will set the foo +configuration parameter to bar. Any environment configurations that +are not given a value will be given the value of true. Config +values are case-insensitive, so NPM_CONFIG_FOO=bar will work the +same. However, please note that inside scripts +npm will set its own environment variables and Node will prefer +those lowercase versions over any uppercase ones that you might set. +For details see this issue.

+

Notice that you need to use underscores instead of dashes, so --allow-same-version +would become npm_config_allow_same_version=true.

+

npmrc Files

+

The four relevant files are:

+
    +
  • per-project configuration file (/path/to/my/project/.npmrc)
  • +
  • per-user configuration file (defaults to $HOME/.npmrc; configurable via CLI +option --userconfig or environment variable $NPM_CONFIG_USERCONFIG)
  • +
  • global configuration file (defaults to $PREFIX/etc/npmrc; configurable via +CLI option --globalconfig or environment variable $NPM_CONFIG_GLOBALCONFIG)
  • +
  • npm's built-in configuration file (/path/to/npm/npmrc)
  • +
+

See npmrc for more details.

+

Default Configs

+

Run npm config ls -l to see a set of configuration parameters that are +internal to npm, and are defaults if nothing else is specified.

+

Shorthands and Other CLI Niceties

+

The following shorthands are parsed on the command-line:

+
    +
  • -v: --version
  • +
  • -h, -?, --help, -H: --usage
  • +
  • -s, --silent: --loglevel silent
  • +
  • -q, --quiet: --loglevel warn
  • +
  • -d: --loglevel info
  • +
  • -dd, --verbose: --loglevel verbose
  • +
  • -ddd: --loglevel silly
  • +
  • -g: --global
  • +
  • -C: --prefix
  • +
  • -l: --long
  • +
  • -m: --message
  • +
  • -p, --porcelain: --parseable
  • +
  • -reg: --registry
  • +
  • -f: --force
  • +
  • -desc: --description
  • +
  • -S: --save
  • +
  • -P: --save-prod
  • +
  • -D: --save-dev
  • +
  • -O: --save-optional
  • +
  • -B: --save-bundle
  • +
  • -E: --save-exact
  • +
  • -y: --yes
  • +
  • -n: --yes false
  • +
  • ll and la commands: ls --long
  • +
+

If the specified configuration param resolves unambiguously to a known +configuration parameter, then it is expanded to that configuration +parameter. For example:

+
npm ls --par
+# same as:
+npm ls --parseable
+

If multiple single-character shorthands are strung together, and the +resulting combination is unambiguously not some other configuration +param, then it is expanded to its various component pieces. For +example:

+
npm ls -gpld
+# same as:
+npm ls --global --parseable --long --loglevel info
+

Per-Package Config Settings

+

When running scripts (see scripts) the package.json "config" +keys are overwritten in the environment if there is a config param of +<name>[@<version>]:<key>. For example, if the package.json has +this:

+
{ "name" : "foo"
+, "config" : { "port" : "8080" }
+, "scripts" : { "start" : "node server.js" } }
+

and the server.js is this:

+
http.createServer(...).listen(process.env.npm_package_config_port)
+

then the user could change the behavior by doing:

+
npm config set foo:port 80
+

See package.json for more information.

+

Config Settings

+

access

+
    +
  • Default: restricted
  • +
  • Type: Access
  • +
+

When publishing scoped packages, the access level defaults to restricted. If +you want your scoped package to be publicly viewable (and installable) set +--access=public. The only valid values for access are public and +restricted. Unscoped packages always have an access level of public.

+

allow-same-version

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Prevents throwing an error when npm version is used to set the new version +to the same value as the current version.

+

always-auth

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Force npm to always require authentication when accessing the registry, +even for GET requests.

+

also

+
    +
  • Default: null
  • +
  • Type: String
  • +
+

When "dev" or "development" and running local npm shrinkwrap, +npm outdated, or npm update, is an alias for --dev.

+

audit

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

When "true" submit audit reports alongside npm install runs to the default +registry and all registries configured for scopes. See the documentation +for npm audit for details on what is submitted.

+

audit-level

+
    +
  • Default: "low"
  • +
  • Type: 'low', 'moderate', 'high', 'critical'
  • +
+

The minimum level of vulnerability for npm audit to exit with +a non-zero exit code.

+

auth-type

+
    +
  • Default: 'legacy'
  • +
  • Type: 'legacy', 'sso', 'saml', 'oauth'
  • +
+

What authentication strategy to use with adduser/login.

+

before

+
    +
  • Alias: enjoy-by
  • +
  • Default: null
  • +
  • Type: Date
  • +
+

If passed to npm install, will rebuild the npm tree such that only versions +that were available on or before the --before time get installed. +If there's no versions available for the current set of direct dependencies, the +command will error.

+

If the requested version is a dist-tag and the given tag does not pass the +--before filter, the most recent version less than or equal to that tag will +be used. For example, foo@latest might install foo@1.2 even though latest +is 2.0.

+ +
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

Tells npm to create symlinks (or .cmd shims on Windows) for package +executables.

+

Set to false to have it not do this. This can be used to work around +the fact that some file systems don't support symlinks, even on +ostensibly Unix systems.

+

browser

+
    +
  • Default: OS X: "open", Windows: "start", Others: "xdg-open"
  • +
  • Type: String
  • +
+

The browser that is called by the npm docs command to open websites.

+

ca

+
    +
  • Default: The npm CA certificate
  • +
  • Type: String, Array or null
  • +
+

The Certificate Authority signing certificate that is trusted for SSL +connections to the registry. Values should be in PEM format (Windows calls it "Base-64 encoded X.509 (.CER)") with newlines +replaced by the string "\n". For example:

+
ca="-----BEGIN CERTIFICATE-----\nXXXX\nXXXX\n-----END CERTIFICATE-----"
+

Set to null to only allow "known" registrars, or to a specific CA cert +to trust only that specific signing authority.

+

Multiple CAs can be trusted by specifying an array of certificates:

+
ca[]="..."
+ca[]="..."
+

See also the strict-ssl config.

+

cafile

+
    +
  • Default: null
  • +
  • Type: path
  • +
+

A path to a file containing one or multiple Certificate Authority signing +certificates. Similar to the ca setting, but allows for multiple CA's, as +well as for the CA information to be stored in a file on disk.

+

cache

+
    +
  • Default: Windows: %AppData%\npm-cache, Posix: ~/.npm
  • +
  • Type: path
  • +
+

The location of npm's cache directory. See npm cache

+

cache-lock-stale

+
    +
  • Default: 60000 (1 minute)
  • +
  • Type: Number
  • +
+

The number of ms before cache folder lockfiles are considered stale.

+

cache-lock-retries

+
    +
  • Default: 10
  • +
  • Type: Number
  • +
+

Number of times to retry to acquire a lock on cache folder lockfiles.

+

cache-lock-wait

+
    +
  • Default: 10000 (10 seconds)
  • +
  • Type: Number
  • +
+

Number of ms to wait for cache lock files to expire.

+

cache-max

+
    +
  • Default: Infinity
  • +
  • Type: Number
  • +
+

DEPRECATED: This option has been deprecated in favor of --prefer-online.

+

--cache-max=0 is an alias for --prefer-online.

+

cache-min

+
    +
  • Default: 10
  • +
  • Type: Number
  • +
+

DEPRECATED: This option has been deprecated in favor of --prefer-offline.

+

--cache-min=9999 (or bigger) is an alias for --prefer-offline.

+

cert

+
    +
  • Default: null
  • +
  • Type: String
  • +
+

A client certificate to pass when accessing the registry. Values should be in +PEM format (Windows calls it "Base-64 encoded X.509 (.CER)") with newlines replaced by the string "\n". For example:

+
cert="-----BEGIN CERTIFICATE-----\nXXXX\nXXXX\n-----END CERTIFICATE-----"
+

It is not the path to a certificate file (and there is no "certfile" option).

+

cidr

+
    +
  • Default: null
  • +
  • Type: String, Array, null
  • +
+

This is a list of CIDR address to be used when configuring limited access tokens with the npm token create command.

+

color

+
    +
  • Default: true
  • +
  • Type: Boolean or "always"
  • +
+

If false, never shows colors. If "always" then always shows colors. +If true, then only prints color codes for tty file descriptors.

+

This option can also be changed using the environment: colors are +disabled when the environment variable NO_COLOR is set to any value.

+

depth

+
    +
  • Default: Infinity
  • +
  • Type: Number
  • +
+

The depth to go when recursing directories for npm ls, +npm cache ls, and npm outdated.

+

For npm outdated, a setting of Infinity will be treated as 0 +since that gives more useful information. To show the outdated status +of all packages and dependents, use a large integer value, +e.g., npm outdated --depth 9999

+

description

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

Show the description in npm search

+

dev

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Install dev-dependencies along with packages.

+

dry-run

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Indicates that you don't want npm to make any changes and that it should +only report what it would have done. This can be passed into any of the +commands that modify your local installation, eg, install, update, +dedupe, uninstall. This is NOT currently honored by some network related +commands, eg dist-tags, owner, etc.

+

editor

+
    +
  • Default: EDITOR environment variable if set, or "vi" on Posix, +or "notepad" on Windows.
  • +
  • Type: path
  • +
+

The command to run for npm edit or npm config edit.

+

engine-strict

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

If set to true, then npm will stubbornly refuse to install (or even +consider installing) any package that claims to not be compatible with +the current Node.js version.

+

force

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Makes various commands more forceful.

+
    +
  • lifecycle script failure does not block progress.
  • +
  • publishing clobbers previously published versions.
  • +
  • skips cache when requesting from the registry.
  • +
  • prevents checks against clobbering non-npm files.
  • +
+

format-package-lock

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

Format package-lock.json or npm-shrinkwrap.json as a human readable file.

+

fetch-retries

+
    +
  • Default: 2
  • +
  • Type: Number
  • +
+

The "retries" config for the retry module to use when fetching +packages from the registry.

+

fetch-retry-factor

+
    +
  • Default: 10
  • +
  • Type: Number
  • +
+

The "factor" config for the retry module to use when fetching +packages.

+

fetch-retry-mintimeout

+
    +
  • Default: 10000 (10 seconds)
  • +
  • Type: Number
  • +
+

The "minTimeout" config for the retry module to use when fetching +packages.

+

fetch-retry-maxtimeout

+
    +
  • Default: 60000 (1 minute)
  • +
  • Type: Number
  • +
+

The "maxTimeout" config for the retry module to use when fetching +packages.

+

fund

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

When "true" displays the message at the end of each npm install +aknowledging the number of dependencies looking for funding. +See npm fund for details.

+

git

+
    +
  • Default: "git"
  • +
  • Type: String
  • +
+

The command to use for git commands. If git is installed on the +computer, but is not in the PATH, then set this to the full path to +the git binary.

+

git-tag-version

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

Tag the commit when using the npm version command.

+

commit-hooks

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

Run git commit hooks when using the npm version command.

+

global

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Operates in "global" mode, so that packages are installed into the +prefix folder instead of the current working directory. See +folders for more on the differences in behavior.

+
    +
  • packages are installed into the {prefix}/lib/node_modules folder, instead of the +current working directory.
  • +
  • bin files are linked to {prefix}/bin
  • +
  • man pages are linked to {prefix}/share/man
  • +
+

globalconfig

+
    +
  • Default: {prefix}/etc/npmrc
  • +
  • Type: path
  • +
+

The config file to read for global config options.

+

global-style

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Causes npm to install the package into your local node_modules folder with +the same layout it uses with the global node_modules folder. Only your +direct dependencies will show in node_modules and everything they depend +on will be flattened in their node_modules folders. This obviously will +eliminate some deduping. If used with legacy-bundling, legacy-bundling will be +preferred.

+

group

+
    +
  • Default: GID of the current process
  • +
  • Type: String or Number
  • +
+

The group to use when running package scripts in global mode as the root +user.

+

heading

+
    +
  • Default: "npm"
  • +
  • Type: String
  • +
+

The string that starts all the debugging log output.

+

https-proxy

+
    +
  • Default: null
  • +
  • Type: url
  • +
+

A proxy to use for outgoing https requests. If the HTTPS_PROXY or +https_proxy or HTTP_PROXY or http_proxy environment variables are set, +proxy settings will be honored by the underlying request library.

+

if-present

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

If true, npm will not exit with an error code when run-script is invoked for +a script that isn't defined in the scripts section of package.json. This +option can be used when it's desirable to optionally run a script when it's +present and fail if the script fails. This is useful, for example, when running +scripts that may only apply for some builds in an otherwise generic CI setup.

+

ignore-prepublish

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

If true, npm will not run prepublish scripts.

+

ignore-scripts

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

If true, npm does not run scripts specified in package.json files.

+

init-module

+
    +
  • Default: ~/.npm-init.js
  • +
  • Type: path
  • +
+

A module that will be loaded by the npm init command. See the +documentation for the +init-package-json module +for more information, or npm init.

+

init-author-name

+
    +
  • Default: ""
  • +
  • Type: String
  • +
+

The value npm init should use by default for the package author's name.

+

init-author-email

+
    +
  • Default: ""
  • +
  • Type: String
  • +
+

The value npm init should use by default for the package author's email.

+

init-author-url

+
    +
  • Default: ""
  • +
  • Type: String
  • +
+

The value npm init should use by default for the package author's homepage.

+

init-license

+
    +
  • Default: "ISC"
  • +
  • Type: String
  • +
+

The value npm init should use by default for the package license.

+

init-version

+
    +
  • Default: "1.0.0"
  • +
  • Type: semver
  • +
+

The value that npm init should use by default for the package +version number, if not already set in package.json.

+

json

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Whether or not to output JSON data, rather than the normal output.

+

This feature is currently experimental, and the output data structures for many +commands is either not implemented in JSON yet, or subject to change. Only the +output from npm ls --json and npm search --json are currently valid.

+

key

+
    +
  • Default: null
  • +
  • Type: String
  • +
+

A client key to pass when accessing the registry. Values should be in PEM +format with newlines replaced by the string "\n". For example:

+
key="-----BEGIN PRIVATE KEY-----\nXXXX\nXXXX\n-----END PRIVATE KEY-----"
+

It is not the path to a key file (and there is no "keyfile" option).

+

legacy-bundling

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Causes npm to install the package such that versions of npm prior to 1.4, +such as the one included with node 0.8, can install the package. This +eliminates all automatic deduping. If used with global-style this option +will be preferred.

+ +
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

If true, then local installs will link if there is a suitable globally +installed package.

+

Note that this means that local installs can cause things to be +installed into the global space at the same time. The link is only done +if one of the two conditions are met:

+
    +
  • The package is not already installed globally, or
  • +
  • the globally installed version is identical to the version that is +being installed locally.
  • +
+

local-address

+
    +
  • Default: undefined
  • +
  • Type: IP Address
  • +
+

The IP address of the local interface to use when making connections +to the npm registry. Must be IPv4 in versions of Node prior to 0.12.

+

loglevel

+
    +
  • Default: "notice"
  • +
  • Type: String
  • +
  • Values: "silent", "error", "warn", "notice", "http", "timing", "info", +"verbose", "silly"
  • +
+

What level of logs to report. On failure, all logs are written to +npm-debug.log in the current working directory.

+

Any logs of a higher level than the setting are shown. The default is "notice".

+

logstream

+
    +
  • Default: process.stderr
  • +
  • Type: Stream
  • +
+

This is the stream that is passed to the +npmlog module at run time.

+

It cannot be set from the command line, but if you are using npm +programmatically, you may wish to send logs to somewhere other than +stderr.

+

If the color config is set to true, then this stream will receive +colored output if it is a TTY.

+

logs-max

+
    +
  • Default: 10
  • +
  • Type: Number
  • +
+

The maximum number of log files to store.

+

long

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Show extended information in npm ls and npm search.

+

maxsockets

+
    +
  • Default: 50
  • +
  • Type: Number
  • +
+

The maximum number of connections to use per origin (protocol/host/port +combination). Passed to the http Agent used to make the request.

+

message

+
    +
  • Default: "%s"
  • +
  • Type: String
  • +
+

Commit message which is used by npm version when creating version commit.

+

Any "%s" in the message will be replaced with the version number.

+

metrics-registry

+ +

The registry you want to send cli metrics to if send-metrics is true.

+

node-options

+
    +
  • Default: null
  • +
  • Type: String
  • +
+

Options to pass through to Node.js via the NODE_OPTIONS environment +variable. This does not impact how npm itself is executed but it does +impact how lifecycle scripts are called.

+

node-version

+
    +
  • Default: process.version
  • +
  • Type: semver or false
  • +
+

The node version to use when checking a package's engines map.

+

noproxy

+
    +
  • Default: null
  • +
  • Type: String or Array
  • +
+

A comma-separated string or an array of domain extensions that a proxy should not be used for.

+

offline

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Force offline mode: no network requests will be done during install. To allow +the CLI to fill in missing cache data, see --prefer-offline.

+

onload-script

+
    +
  • Default: false
  • +
  • Type: path
  • +
+

A node module to require() when npm loads. Useful for programmatic +usage.

+

only

+
    +
  • Default: null
  • +
  • Type: String
  • +
+

When "dev" or "development" and running local npm install without any +arguments, only devDependencies (and their dependencies) are installed.

+

When "dev" or "development" and running local npm ls, npm outdated, or +npm update, is an alias for --dev.

+

When "prod" or "production" and running local npm install without any +arguments, only non-devDependencies (and their dependencies) are +installed.

+

When "prod" or "production" and running local npm ls, npm outdated, or +npm update, is an alias for --production.

+

optional

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

Attempt to install packages in the optionalDependencies object. Note +that if these packages fail to install, the overall installation +process is not aborted.

+

otp

+
    +
  • Default: null
  • +
  • Type: Number
  • +
+

This is a one-time password from a two-factor authenticator. It's needed +when publishing or changing package permissions with npm access.

+

package-lock

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

If set to false, then ignore package-lock.json files when installing. This +will also prevent writing package-lock.json if save is true.

+

When package package-locks are disabled, automatic pruning of extraneous +modules will also be disabled. To remove extraneous modules with +package-locks disabled use npm prune.

+

This option is an alias for --shrinkwrap.

+

package-lock-only

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

If set to true, it will update only the package-lock.json, +instead of checking node_modules and downloading dependencies.

+

parseable

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Output parseable results from commands that write to +standard output. For npm search, this will be tab-separated table format.

+

prefer-offline

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

If true, staleness checks for cached data will be bypassed, but missing data +will be requested from the server. To force full offline mode, use --offline.

+

This option is effectively equivalent to --cache-min=9999999.

+

prefer-online

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

If true, staleness checks for cached data will be forced, making the CLI look +for updates immediately even for fresh package data.

+

prefix

+
    +
  • Default: see folders
  • +
  • Type: path
  • +
+

The location to install global items. If set on the command line, then +it forces non-global commands to run in the specified folder.

+

preid

+
    +
  • Default: ""
  • +
  • Type: String
  • +
+

The "prerelease identifier" to use as a prefix for the "prerelease" part of a +semver. Like the rc in 1.2.0-rc.8.

+

production

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Set to true to run in "production" mode.

+
    +
  1. devDependencies are not installed at the topmost level when running +local npm install without any arguments.
  2. +
  3. Set the NODE_ENV="production" for lifecycle scripts.
  4. +
+

progress

+
    +
  • Default: true, unless TRAVIS or CI env vars set.
  • +
  • Type: Boolean
  • +
+

When set to true, npm will display a progress bar during time intensive +operations, if process.stderr is a TTY.

+

Set to false to suppress the progress bar.

+

proxy

+
    +
  • Default: null
  • +
  • Type: url
  • +
+

A proxy to use for outgoing http requests. If the HTTP_PROXY or +http_proxy environment variables are set, proxy settings will be +honored by the underlying request library.

+

read-only

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

This is used to mark a token as unable to publish when configuring limited access tokens with the npm token create command.

+

rebuild-bundle

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

Rebuild bundled dependencies after installation.

+

registry

+ +

The base URL of the npm package registry.

+

rollback

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

Remove failed installs.

+

save

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

Save installed packages to a package.json file as dependencies.

+

When used with the npm rm command, it removes it from the dependencies +object.

+

Only works if there is already a package.json file present.

+

save-bundle

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

If a package would be saved at install time by the use of --save, +--save-dev, or --save-optional, then also put it in the +bundleDependencies list.

+

When used with the npm rm command, it removes it from the +bundledDependencies list.

+

save-prod

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Makes sure that a package will be saved into dependencies specifically. This +is useful if a package already exists in devDependencies or +optionalDependencies, but you want to move it to be a production dep. This is +also the default behavior if --save is true, and neither --save-dev or +--save-optional are true.

+

save-dev

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Save installed packages to a package.json file as devDependencies.

+

When used with the npm rm command, it removes it from the +devDependencies object.

+

Only works if there is already a package.json file present.

+

save-exact

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Dependencies saved to package.json using --save, --save-dev or +--save-optional will be configured with an exact version rather than +using npm's default semver range operator.

+

save-optional

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Save installed packages to a package.json file as +optionalDependencies.

+

When used with the npm rm command, it removes it from the +devDependencies object.

+

Only works if there is already a package.json file present.

+

save-prefix

+
    +
  • Default: '^'
  • +
  • Type: String
  • +
+

Configure how versions of packages installed to a package.json file via +--save or --save-dev get prefixed.

+

For example if a package has version 1.2.3, by default its version is +set to ^1.2.3 which allows minor upgrades for that package, but after +npm config set save-prefix='~' it would be set to ~1.2.3 which only allows +patch upgrades.

+

scope

+
    +
  • Default: the scope of the current project, if any, or ""
  • +
  • Type: String
  • +
+

Associate an operation with a scope for a scoped registry. Useful when logging +in to a private registry for the first time: +npm login --scope=@organization --registry=registry.organization.com, which +will cause @organization to be mapped to the registry for future installation +of packages specified according to the pattern @organization/package.

+

script-shell

+
    +
  • Default: null
  • +
  • Type: path
  • +
+

The shell to use for scripts run with the npm run command.

+

scripts-prepend-node-path

+
    +
  • Default: "warn-only"
  • +
  • Type: Boolean, "auto" or "warn-only"
  • +
+

If set to true, add the directory in which the current node executable +resides to the PATH environment variable when running scripts, +even if that means that npm will invoke a different node executable than +the one which it is running.

+

If set to false, never modify PATH with that.

+

If set to "warn-only", never modify PATH but print a warning if npm thinks +that you may want to run it with true, e.g. because the node executable +in the PATH is not the one npm was invoked with.

+

If set to auto, only add that directory to the PATH environment variable +if the node executable with which npm was invoked and the one that is found +first on the PATH are different.

+

searchexclude

+
    +
  • Default: ""
  • +
  • Type: String
  • +
+

Space-separated options that limit the results from search.

+

searchopts

+
    +
  • Default: ""
  • +
  • Type: String
  • +
+

Space-separated options that are always passed to search.

+

searchlimit

+
    +
  • Default: 20
  • +
  • Type: Number
  • +
+

Number of items to limit search results to. Will not apply at all to legacy +searches.

+

searchstaleness

+
    +
  • Default: 900 (15 minutes)
  • +
  • Type: Number
  • +
+

The age of the cache, in seconds, before another registry request is made if +using legacy search endpoint.

+

send-metrics

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

If true, success/failure metrics will be reported to the registry stored in +metrics-registry. These requests contain the number of successful and +failing runs of the npm CLI and the time period overwhich those counts were +gathered. No identifying information is included in these requests.

+

shell

+
    +
  • Default: SHELL environment variable, or "bash" on Posix, or "cmd" on +Windows
  • +
  • Type: path
  • +
+

The shell to run for the npm explore command.

+

shrinkwrap

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

If set to false, then ignore npm-shrinkwrap.json files when installing. This +will also prevent writing npm-shrinkwrap.json if save is true.

+

This option is an alias for --package-lock.

+

sign-git-commit

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

If set to true, then the npm version command will commit the new package +version using -S to add a signature.

+

Note that git requires you to have set up GPG keys in your git configs +for this to work properly.

+

sign-git-tag

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

If set to true, then the npm version command will tag the version +using -s to add a signature.

+

Note that git requires you to have set up GPG keys in your git configs +for this to work properly.

+

sso-poll-frequency

+
    +
  • Default: 500
  • +
  • Type: Number
  • +
+

When used with SSO-enabled auth-types, configures how regularly the registry +should be polled while the user is completing authentication.

+

sso-type

+
    +
  • Default: 'oauth'
  • +
  • Type: 'oauth', 'saml', or null
  • +
+

If --auth-type=sso, the type of SSO type to use.

+

strict-ssl

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

Whether or not to do SSL key validation when making requests to the +registry via https.

+

See also the ca config.

+

tag

+
    +
  • Default: latest
  • +
  • Type: String
  • +
+

If you ask npm to install a package and don't tell it a specific version, then +it will install the specified tag.

+

Also the tag that is added to the package@version specified by the npm +tag command, if no explicit tag is given.

+

tag-version-prefix

+
    +
  • Default: "v"
  • +
  • Type: String
  • +
+

If set, alters the prefix used when tagging a new version when performing a +version increment using npm-version. To remove the prefix altogether, set it +to the empty string: "".

+

Because other tools may rely on the convention that npm version tags look like +v1.0.0, only use this property if it is absolutely necessary. In +particular, use care when overriding this setting for public packages.

+

timing

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

If true, writes an npm-debug log to _logs and timing information to +_timing.json, both in your cache. _timing.json is a newline delimited +list of JSON objects. You can quickly view it with this +json command line: +json -g < ~/.npm/_timing.json.

+

tmp

+
    +
  • Default: TMPDIR environment variable, or "/tmp"
  • +
  • Type: path
  • +
+

Where to store temporary files and folders. All temp files are deleted +on success, but left behind on failure for forensic purposes.

+

unicode

+
    +
  • Default: false on windows, true on mac/unix systems with a unicode locale
  • +
  • Type: Boolean
  • +
+

When set to true, npm uses unicode characters in the tree output. When +false, it uses ascii characters to draw trees.

+

unsafe-perm

+
    +
  • Default: false if running as root, true otherwise
  • +
  • Type: Boolean
  • +
+

Set to true to suppress the UID/GID switching when running package +scripts. If set explicitly to false, then installing as a non-root user +will fail.

+

update-notifier

+
    +
  • Default: true
  • +
  • Type: Boolean
  • +
+

Set to false to suppress the update notification when using an older +version of npm than the latest.

+

usage

+
    +
  • Default: false
  • +
  • Type: Boolean
  • +
+

Set to show short usage output (like the -H output) +instead of complete help when doing npm help.

+

user

+
    +
  • Default: "nobody"
  • +
  • Type: String or Number
  • +
+

The UID to set to when running package scripts as root.

+

userconfig

+
    +
  • Default: ~/.npmrc
  • +
  • Type: path
  • +
+

The location of user-level configuration settings.

+

umask

+
    +
  • Default: 022
  • +
  • Type: Octal numeric string in range 0000..0777 (0..511)
  • +
+

The "umask" value to use when setting the file creation mode on files +and folders.

+

Folders and executables are given a mode which is 0777 masked against +this value. Other files are given a mode which is 0666 masked against +this value. Thus, the defaults are 0755 and 0644 respectively.

+

user-agent

+
    +
  • Default: node/{process.version} {process.platform} {process.arch}
  • +
  • Type: String
  • +
+

Sets a User-Agent to the request header

+

version

+
    +
  • Default: false
  • +
  • Type: boolean
  • +
+

If true, output the npm version and exit successfully.

+

Only relevant when specified explicitly on the command line.

+

versions

+
    +
  • Default: false
  • +
  • Type: boolean
  • +
+

If true, output the npm version as well as node's process.versions map, and +exit successfully.

+

Only relevant when specified explicitly on the command line.

+

viewer

+
    +
  • Default: "man" on Posix, "browser" on Windows
  • +
  • Type: path
  • +
+

The program to use to view help content.

+

Set to "browser" to view html help content in the default web browser.

+

See also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/using-npm/developers/index.html b/deps/npm/docs/public/using-npm/developers/index.html new file mode 100644 index 00000000000000..c1a93d97d44cb2 --- /dev/null +++ b/deps/npm/docs/public/using-npm/developers/index.html @@ -0,0 +1,256 @@ +

developers

+

Developer Guide

+

Description

+

So, you've decided to use npm to develop (and maybe publish/deploy) +your project.

+

Fantastic!

+

There are a few things that you need to do above the simple steps +that your users will do to install your program.

+

About These Documents

+

These are man pages. If you install npm, you should be able to +then do man npm-thing to get the documentation on a particular +topic, or npm help thing to see the same information.

+

What is a package

+

A package is:

+
    +
  • a) a folder containing a program described by a package.json file
  • +
  • b) a gzipped tarball containing (a)
  • +
  • c) a url that resolves to (b)
  • +
  • d) a <name>@<version> that is published on the registry with (c)
  • +
  • e) a <name>@<tag> that points to (d)
  • +
  • f) a <name> that has a "latest" tag satisfying (e)
  • +
  • g) a git url that, when cloned, results in (a).
  • +
+

Even if you never publish your package, you can still get a lot of +benefits of using npm if you just want to write a node program (a), and +perhaps if you also want to be able to easily install it elsewhere +after packing it up into a tarball (b).

+

Git urls can be of the form:

+
git://github.com/user/project.git#commit-ish
+git+ssh://user@hostname:project.git#commit-ish
+git+http://user@hostname/project/blah.git#commit-ish
+git+https://user@hostname/project/blah.git#commit-ish
+

The commit-ish can be any tag, sha, or branch which can be supplied as +an argument to git checkout. The default is master.

+

The package.json File

+

You need to have a package.json file in the root of your project to do +much of anything with npm. That is basically the whole interface.

+

See package.json for details about what goes in that file. At the very +least, you need:

+
    +
  • +

    name: +This should be a string that identifies your project. Please do not +use the name to specify that it runs on node, or is in JavaScript. +You can use the "engines" field to explicitly state the versions of +node (or whatever else) that your program requires, and it's pretty +well assumed that it's JavaScript.

    +

    It does not necessarily need to match your github repository name.

    +

    So, node-foo and bar-js are bad names. foo or bar are better.

    +
  • +
  • version: +A semver-compatible version.
  • +
  • engines: +Specify the versions of node (or whatever else) that your program +runs on. The node API changes a lot, and there may be bugs or new +functionality that you depend on. Be explicit.
  • +
  • author: +Take some credit.
  • +
  • scripts: +If you have a special compilation or installation script, then you +should put it in the scripts object. You should definitely have at +least a basic smoke-test command as the "scripts.test" field. +See scripts.
  • +
  • main: +If you have a single module that serves as the entry point to your +program (like what the "foo" package gives you at require("foo")), +then you need to specify that in the "main" field.
  • +
  • directories: +This is an object mapping names to folders. The best ones to include are +"lib" and "doc", but if you use "man" to specify a folder full of man pages, +they'll get installed just like these ones.
  • +
+

You can use npm init in the root of your package in order to get you +started with a pretty basic package.json file. See npm init for +more info.

+

Keeping files out of your package

+

Use a .npmignore file to keep stuff out of your package. If there's +no .npmignore file, but there is a .gitignore file, then npm will +ignore the stuff matched by the .gitignore file. If you want to +include something that is excluded by your .gitignore file, you can +create an empty .npmignore file to override it. Like git, npm looks +for .npmignore and .gitignore files in all subdirectories of your +package, not only the root directory.

+

.npmignore files follow the same pattern rules +as .gitignore files:

+
    +
  • Blank lines or lines starting with # are ignored.
  • +
  • Standard glob patterns work.
  • +
  • You can end patterns with a forward slash / to specify a directory.
  • +
  • You can negate a pattern by starting it with an exclamation point !.
  • +
+

By default, the following paths and files are ignored, so there's no +need to add them to .npmignore explicitly:

+
    +
  • .*.swp
  • +
  • ._*
  • +
  • .DS_Store
  • +
  • .git
  • +
  • .hg
  • +
  • .npmrc
  • +
  • .lock-wscript
  • +
  • .svn
  • +
  • .wafpickle-*
  • +
  • config.gypi
  • +
  • CVS
  • +
  • npm-debug.log
  • +
+

Additionally, everything in node_modules is ignored, except for +bundled dependencies. npm automatically handles this for you, so don't +bother adding node_modules to .npmignore.

+

The following paths and files are never ignored, so adding them to +.npmignore is pointless:

+
    +
  • package.json
  • +
  • README (and its variants)
  • +
  • CHANGELOG (and its variants)
  • +
  • LICENSE / LICENCE
  • +
+

If, given the structure of your project, you find .npmignore to be a +maintenance headache, you might instead try populating the files +property of package.json, which is an array of file or directory names +that should be included in your package. Sometimes a whitelist is easier +to manage than a blacklist.

+

Testing whether your .npmignore or files config works

+

If you want to double check that your package will include only the files +you intend it to when published, you can run the npm pack command locally +which will generate a tarball in the working directory, the same way it +does for publishing.

+ +

npm link is designed to install a development package and see the +changes in real time without having to keep re-installing it. (You do +need to either re-link or npm rebuild -g to update compiled packages, +of course.)

+

More info at npm link.

+

Before Publishing: Make Sure Your Package Installs and Works

+

This is important.

+

If you can not install it locally, you'll have +problems trying to publish it. Or, worse yet, you'll be able to +publish it, but you'll be publishing a broken or pointless package. +So don't do that.

+

In the root of your package, do this:

+
npm install . -g
+

That'll show you that it's working. If you'd rather just create a symlink +package that points to your working directory, then do this:

+
npm link
+

Use npm ls -g to see if it's there.

+

To test a local install, go into some other folder, and then do:

+
cd ../some-other-folder
+npm install ../my-package
+

to install it locally into the node_modules folder in that other place.

+

Then go into the node-repl, and try using require("my-thing") to +bring in your module's main module.

+

Create a User Account

+

Create a user with the adduser command. It works like this:

+
npm adduser
+

and then follow the prompts.

+

This is documented better in npm adduser.

+

Publish your package

+

This part's easy. In the root of your folder, do this:

+
npm publish
+

You can give publish a url to a tarball, or a filename of a tarball, +or a path to a folder.

+

Note that pretty much everything in that folder will be exposed +by default. So, if you have secret stuff in there, use a +.npmignore file to list out the globs to ignore, or publish +from a fresh checkout.

+

Brag about it

+

Send emails, write blogs, blab in IRC.

+

Tell the world how easy it is to install your program!

+

See also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/using-npm/disputes/index.html b/deps/npm/docs/public/using-npm/disputes/index.html new file mode 100644 index 00000000000000..facb5d7c51f957 --- /dev/null +++ b/deps/npm/docs/public/using-npm/disputes/index.html @@ -0,0 +1,189 @@ +

disputes

+

Handling Module Name Disputes

+

This document describes the steps that you should take to resolve module name +disputes with other npm publishers. It also describes special steps you should +take about names you think infringe your trademarks.

+

This document is a clarification of the acceptable behavior outlined in the +npm Code of Conduct, and nothing in +this document should be interpreted to contradict any aspect of the npm Code of +Conduct.

+

TL;DR

+
    +
  1. Get the author email with npm owner ls <pkgname>
  2. +
  3. Email the author, CC support@npmjs.com
  4. +
  5. After a few weeks, if there's no resolution, we'll sort it out.
  6. +
+

Don't squat on package names. Publish code or move out of the way.

+

Description

+

There sometimes arise cases where a user publishes a module, and then later, +some other user wants to use that name. Here are some common ways that happens +(each of these is based on actual events.)

+
    +
  1. Alice writes a JavaScript module foo, which is not node-specific. Alice +doesn't use node at all. Yusuf wants to use foo in node, so he wraps it in +an npm module. Some time later, Alice starts using node, and wants to take +over management of her program.
  2. +
  3. Yusuf writes an npm module foo, and publishes it. Perhaps much later, Alice +finds a bug in foo, and fixes it. She sends a pull request to Yusuf, but +Yusuf doesn't have the time to deal with it, because he has a new job and a +new baby and is focused on his new Erlang project, and kind of not involved +with node any more. Alice would like to publish a new foo, but can't, +because the name is taken.
  4. +
  5. Yusuf writes a 10-line flow-control library, and calls it foo, and +publishes it to the npm registry. Being a simple little thing, it never +really has to be updated. Alice works for Foo Inc, the makers of the +critically acclaimed and widely-marketed foo JavaScript toolkit framework. +They publish it to npm as foojs, but people are routinely confused when +npm install foo is some different thing.
  6. +
  7. Yusuf writes a parser for the widely-known foo file format, because he +needs it for work. Then, he gets a new job, and never updates the prototype. +Later on, Alice writes a much more complete foo parser, but can't publish, +because Yusuf's foo is in the way.
  8. +
  9. npm owner ls foo. This will tell Alice the email address of the owner +(Yusuf).
  10. +
  11. Alice emails Yusuf, explaining the situation as respectfully as possible, +and what she would like to do with the module name. She adds the npm support +staff support@npmjs.com to the CC list of the email. Mention in the email +that Yusuf can run npm owner add alice foo to add Alice as an owner of the +foo package.
  12. +
  13. After a reasonable amount of time, if Yusuf has not responded, or if Yusuf +and Alice can't come to any sort of resolution, email support +support@npmjs.com and we'll sort it out. ("Reasonable" is usually at least +4 weeks.)
  14. +
+

Reasoning

+

In almost every case so far, the parties involved have been able to reach an +amicable resolution without any major intervention. Most people really do want +to be reasonable, and are probably not even aware that they're in your way.

+

Module ecosystems are most vibrant and powerful when they are as self-directed +as possible. If an admin one day deletes something you had worked on, then that +is going to make most people quite upset, regardless of the justification. When +humans solve their problems by talking to other humans with respect, everyone +has the chance to end up feeling good about the interaction.

+

Exceptions

+

Some things are not allowed, and will be removed without discussion if they are +brought to the attention of the npm registry admins, including but not limited +to:

+
    +
  1. Malware (that is, a package designed to exploit or harm the machine on which +it is installed).
  2. +
  3. Violations of copyright or licenses (for example, cloning an MIT-licensed +program, and then removing or changing the copyright and license statement).
  4. +
  5. Illegal content.
  6. +
  7. "Squatting" on a package name that you plan to use, but aren't actually +using. Sorry, I don't care how great the name is, or how perfect a fit it is +for the thing that someday might happen. If someone wants to use it today, +and you're just taking up space with an empty tarball, you're going to be +evicted.
  8. +
  9. Putting empty packages in the registry. Packages must have SOME +functionality. It can be silly, but it can't be nothing. (See also: +squatting.)
  10. +
  11. Doing weird things with the registry, like using it as your own personal +application database or otherwise putting non-packagey things into it.
  12. +
  13. Other things forbidden by the npm +Code of Conduct such as hateful +language, pornographic content, or harassment.
  14. +
+

If you see bad behavior like this, please report it to abuse@npmjs.com right +away. You are never expected to resolve abusive behavior on your own. We are +here to help.

+

Trademarkss

+

If you think another npm publisher is infringing your trademark, such as by +using a confusingly similar package name, email abuse@npmjs.com with a link to +the package or user account on https://www.npmjs.com/. +Attach a copy of your trademark registration certificate.

+

If we see that the package's publisher is intentionally misleading others by +misusing your registered mark without permission, we will transfer the package +name to you. Otherwise, we will contact the package publisher and ask them to +clear up any confusion with changes to their package's README file or +metadata.

+

Changes

+

This is a living document and may be updated from time to time. Please refer to +the git history for this document +to view the changes.

+

License

+

Copyright (C) npm, Inc., All rights reserved

+

This document may be reused under a Creative Commons Attribution-ShareAlike +License.

+

See also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/using-npm/orgs/index.html b/deps/npm/docs/public/using-npm/orgs/index.html new file mode 100644 index 00000000000000..72fedfb33fcfba --- /dev/null +++ b/deps/npm/docs/public/using-npm/orgs/index.html @@ -0,0 +1,141 @@ +

orgs

+

Working with Teams & Orgs

+

Description

+

There are three levels of org users:

+
    +
  1. Super admin, controls billing & adding people to the org.
  2. +
  3. Team admin, manages team membership & package access.
  4. +
  5. Developer, works on packages they are given access to.
  6. +
+

The super admin is the only person who can add users to the org because it impacts the monthly bill. The super admin will use the website to manage membership. Every org has a developers team that all users are automatically added to.

+

The team admin is the person who manages team creation, team membership, and package access for teams. The team admin grants package access to teams, not individuals.

+

The developer will be able to access packages based on the teams they are on. Access is either read-write or read-only.

+

There are two main commands:

+
    +
  1. npm team see npm team for more details
  2. +
  3. npm access see npm access for more details
  4. +
+

Team Admins create teams

+
    +
  • Check who you’ve added to your org:
  • +
+
npm team ls <org>:developers
+
    +
  • Each org is automatically given a developers team, so you can see the whole list of team members in your org. This team automatically gets read-write access to all packages, but you can change that with the access command.
  • +
  • Create a new team:
  • +
+
npm team create <org:team>
+
    +
  • Add members to that team:
  • +
+
npm team add <org:team> <user>
+

Publish a package and adjust package access

+
    +
  • In package directory, run
  • +
+
npm init --scope=<org>
+

to scope it for your org & publish as usual

+
    +
  • Grant access:
  • +
+
npm access grant <read-only|read-write> <org:team> [<package>]
+
    +
  • Revoke access:
  • +
+
npm access revoke <org:team> [<package>]
+

Monitor your package access

+
    +
  • See what org packages a team member can access:
  • +
+
npm access ls-packages <org> <user>
+
    +
  • See packages available to a specific team:
  • +
+
npm access ls-packages <org:team>
+
    +
  • Check which teams are collaborating on a package:
  • +
+
npm access ls-collaborators <pkg>
+

See also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/using-npm/registry/index.html b/deps/npm/docs/public/using-npm/registry/index.html new file mode 100644 index 00000000000000..d6bdb097a6cc67 --- /dev/null +++ b/deps/npm/docs/public/using-npm/registry/index.html @@ -0,0 +1,153 @@ +

registry

+

The JavaScript Package Registry

+

Description

+

To resolve packages by name and version, npm talks to a registry website +that implements the CommonJS Package Registry specification for reading +package info.

+

npm is configured to use npm, Inc.'s public registry at +https://registry.npmjs.org by default. Use of the npm public registry is +subject to terms of use available at https://www.npmjs.com/policies/terms.

+

You can configure npm to use any compatible registry you like, and even run +your own registry. Use of someone else's registry may be governed by their +terms of use.

+

npm's package registry implementation supports several +write APIs as well, to allow for publishing packages and managing user +account information.

+

The npm public registry is powered by a CouchDB database, +of which there is a public mirror at +https://skimdb.npmjs.com/registry. The code for the couchapp is +available at https://github.com/npm/npm-registry-couchapp.

+

The registry URL used is determined by the scope of the package (see +scope. If no scope is specified, the default registry is used, which is +supplied by the registry config parameter. See npm config, +npmrc, and config for more on managing npm's configuration.

+

Does npm send any information about me back to the registry?

+

Yes.

+

When making requests of the registry npm adds two headers with information +about your environment:

+
    +
  • Npm-Scope – If your project is scoped, this header will contain its +scope. In the future npm hopes to build registry features that use this +information to allow you to customize your experience for your +organization.
  • +
  • Npm-In-CI – Set to "true" if npm believes this install is running in a +continuous integration environment, "false" otherwise. This is detected by +looking for the following environment variables: CI, TDDIUM, +JENKINS_URL, bamboo.buildKey. If you'd like to learn more you may find +the original PR +interesting. +This is used to gather better metrics on how npm is used by humans, versus +build farms.
  • +
+

The npm registry does not try to correlate the information in these headers +with any authenticated accounts that may be used in the same requests.

+

Can I run my own private registry?

+

Yes!

+

The easiest way is to replicate the couch database, and use the same (or +similar) design doc to implement the APIs.

+

If you set up continuous replication from the official CouchDB, and then +set your internal CouchDB as the registry config, then you'll be able +to read any published packages, in addition to your private ones, and by +default will only publish internally.

+

If you then want to publish a package for the whole world to see, you can +simply override the --registry option for that publish command.

+

I don't want my package published in the official registry. It's private.

+

Set "private": true in your package.json to prevent it from being +published at all, or +"publishConfig":{"registry":"http://my-internal-registry.local"} +to force it to be published only to your internal registry.

+

See package.json for more info on what goes in the package.json file.

+

Will you replicate from my registry into the public one?

+

No. If you want things to be public, then publish them into the public +registry using npm. What little security there is would be for nought +otherwise.

+

Do I have to use couchdb to build a registry that npm can talk to?

+

No, but it's way easier. Basically, yes, you do, or you have to +effectively implement the entire CouchDB API anyway.

+

Is there a website or something to see package docs and such?

+

Yes, head over to https://www.npmjs.com/

+

See also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/using-npm/removal/index.html b/deps/npm/docs/public/using-npm/removal/index.html new file mode 100644 index 00000000000000..d75978c0b72b08 --- /dev/null +++ b/deps/npm/docs/public/using-npm/removal/index.html @@ -0,0 +1,113 @@ +

removal

+

Cleaning the Slate

+

Synopsis

+

So sad to see you go.

+
sudo npm uninstall npm -g
+

Or, if that fails, get the npm source code, and do:

+
sudo make uninstall
+

More Severe Uninstalling

+

Usually, the above instructions are sufficient. That will remove +npm, but leave behind anything you've installed.

+

If that doesn't work, or if you require more drastic measures, +continue reading.

+

Note that this is only necessary for globally-installed packages. Local +installs are completely contained within a project's node_modules +folder. Delete that folder, and everything is gone less a package's +install script is particularly ill-behaved).

+

This assumes that you installed node and npm in the default place. If +you configured node with a different --prefix, or installed npm with a +different prefix setting, then adjust the paths accordingly, replacing +/usr/local with your install prefix.

+

To remove everything npm-related manually:

+
rm -rf /usr/local/{lib/node{,/.npm,_modules},bin,share/man}/npm*
+

If you installed things with npm, then your best bet is to uninstall +them with npm first, and then install them again once you have a +proper install. This can help find any symlinks that are lying +around:

+
ls -laF /usr/local/{lib/node{,/.npm},bin,share/man} | grep npm
+

Prior to version 0.3, npm used shim files for executables and node +modules. To track those down, you can do the following:

+
find /usr/local/{lib/node,bin} -exec grep -l npm \{\} \; ;
+

(This is also in the README file.)

+

See also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/using-npm/scope/index.html b/deps/npm/docs/public/using-npm/scope/index.html new file mode 100644 index 00000000000000..ab6ddaac128813 --- /dev/null +++ b/deps/npm/docs/public/using-npm/scope/index.html @@ -0,0 +1,156 @@ +

scope

+

Scoped packages

+

Description

+

All npm packages have a name. Some package names also have a scope. A scope +follows the usual rules for package names (URL-safe characters, no leading dots +or underscores). When used in package names, scopes are preceded by an @ symbol +and followed by a slash, e.g.

+
@somescope/somepackagename
+

Scopes are a way of grouping related packages together, and also affect a few +things about the way npm treats the package.

+

Each npm user/organization has their own scope, and only you can add packages +in your scope. This means you don't have to worry about someone taking your +package name ahead of you. Thus it is also a good way to signal official packages +for organizations.

+

Scoped packages can be published and installed as of npm@2 and are supported +by the primary npm registry. Unscoped packages can depend on scoped packages and +vice versa. The npm client is backwards-compatible with unscoped registries, +so it can be used to work with scoped and unscoped registries at the same time.

+

Installing scoped packages

+

Scoped packages are installed to a sub-folder of the regular installation +folder, e.g. if your other packages are installed in node_modules/packagename, +scoped modules will be installed in node_modules/@myorg/packagename. The scope +folder (@myorg) is simply the name of the scope preceded by an @ symbol, and can +contain any number of scoped packages.

+

A scoped package is installed by referencing it by name, preceded by an +@ symbol, in npm install:

+
npm install @myorg/mypackage
+

Or in package.json:

+
"dependencies": {
+  "@myorg/mypackage": "^1.3.0"
+}
+

Note that if the @ symbol is omitted, in either case, npm will instead attempt to +install from GitHub; see npm install.

+

Requiring scoped packages

+

Because scoped packages are installed into a scope folder, you have to +include the name of the scope when requiring them in your code, e.g.

+
require('@myorg/mypackage')
+

There is nothing special about the way Node treats scope folders. This +simply requires the mypackage module in the folder named @myorg.

+

Publishing scoped packages

+

Scoped packages can be published from the CLI as of npm@2 and can be +published to any registry that supports them, including the primary npm +registry.

+

(As of 2015-04-19, and with npm 2.0 or better, the primary npm registry +does support scoped packages.)

+

If you wish, you may associate a scope with a registry; see below.

+

Publishing public scoped packages to the primary npm registry

+

To publish a public scoped package, you must specify --access public with +the initial publication. This will publish the package and set access +to public as if you had run npm access public after publishing.

+

Publishing private scoped packages to the npm registry

+

To publish a private scoped package to the npm registry, you must have +an npm Private Modules +account.

+

You can then publish the module with npm publish or npm publish +--access restricted, and it will be present in the npm registry, with +restricted access. You can then change the access permissions, if +desired, with npm access or on the npmjs.com website.

+

Associating a scope with a registry

+

Scopes can be associated with a separate registry. This allows you to +seamlessly use a mix of packages from the primary npm registry and one or more +private registries, such as npm Enterprise.

+

You can associate a scope with a registry at login, e.g.

+
npm login --registry=http://reg.example.com --scope=@myco
+

Scopes have a many-to-one relationship with registries: one registry can +host multiple scopes, but a scope only ever points to one registry.

+

You can also associate a scope with a registry using npm config:

+
npm config set @myco:registry http://reg.example.com
+

Once a scope is associated with a registry, any npm install for a package +with that scope will request packages from that registry instead. Any +npm publish for a package name that contains the scope will be published to +that registry instead.

+

See also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/using-npm/scripts/index.html b/deps/npm/docs/public/using-npm/scripts/index.html new file mode 100644 index 00000000000000..f08811cc7d268b --- /dev/null +++ b/deps/npm/docs/public/using-npm/scripts/index.html @@ -0,0 +1,300 @@ +

scripts

+

How npm handles the "scripts" field

+

Description

+

npm supports the "scripts" property of the package.json file, for the +following scripts:

+
    +
  • prepublish (as of npm@5, prepublish is deprecated. Use prepare for build steps and prepublishOnly for upload-only.): +Run BEFORE the package is packed and published, as well as on local npm +install without any arguments. (See below)
  • +
  • prepare: +Run both BEFORE the package is packed and published, on local npm +install without any arguments, and when installing git dependencies (See +below). This is run AFTER prepublish, but BEFORE prepublishOnly.
  • +
  • prepublishOnly: +Run BEFORE the package is prepared and packed, ONLY on npm publish. (See +below.)
  • +
  • prepack: +run BEFORE a tarball is packed (on npm pack, npm publish, and when +installing git dependencies)
  • +
  • postpack: +Run AFTER the tarball has been generated and moved to its final destination.
  • +
  • publish, postpublish: +Run AFTER the package is published.
  • +
  • preinstall: +Run BEFORE the package is installed
  • +
  • install, postinstall: +Run AFTER the package is installed.
  • +
  • preuninstall, uninstall: +Run BEFORE the package is uninstalled.
  • +
  • postuninstall: +Run AFTER the package is uninstalled.
  • +
  • preversion: +Run BEFORE bumping the package version.
  • +
  • version: +Run AFTER bumping the package version, but BEFORE commit.
  • +
  • postversion: +Run AFTER bumping the package version, and AFTER commit.
  • +
  • pretest, test, posttest: +Run by the npm test command.
  • +
  • prestop, stop, poststop: +Run by the npm stop command.
  • +
  • prestart, start, poststart: +Run by the npm start command.
  • +
  • prerestart, restart, postrestart: +Run by the npm restart command. Note: npm restart will run the +stop and start scripts if no restart script is provided.
  • +
  • preshrinkwrap, shrinkwrap, postshrinkwrap: +Run by the npm shrinkwrap command.
  • +
+

Additionally, arbitrary scripts can be executed by running npm +run-script <stage>. Pre and post commands with matching +names will be run for those as well (e.g. premyscript, myscript, +postmyscript). Scripts from dependencies can be run with +npm explore <pkg> -- npm run <stage>.

+

Prepublish and Prepare

+

Deprecation Note

+

Since npm@1.1.71, the npm CLI has run the prepublish script for both npm +publish and npm install, because it's a convenient way to prepare a package +for use (some common use cases are described in the section below). It has +also turned out to be, in practice, very +confusing. As of npm@4.0.0, a new +event has been introduced, prepare, that preserves this existing behavior. A +new event, prepublishOnly has been added as a transitional strategy to +allow users to avoid the confusing behavior of existing npm versions and only +run on npm publish (for instance, running the tests one last time to ensure +they're in good shape).

+

See https://github.com/npm/npm/issues/10074 for a much lengthier +justification, with further reading, for this change.

+

Use Cases

+

If you need to perform operations on your package before it is used, in a way +that is not dependent on the operating system or architecture of the +target system, use a prepublish script. This includes +tasks such as:

+
    +
  • Compiling CoffeeScript source code into JavaScript.
  • +
  • Creating minified versions of JavaScript source code.
  • +
  • Fetching remote resources that your package will use.
  • +
+

The advantage of doing these things at prepublish time is that they can be done once, in a +single place, thus reducing complexity and variability. +Additionally, this means that:

+
    +
  • You can depend on coffee-script as a devDependency, and thus +your users don't need to have it installed.
  • +
  • You don't need to include minifiers in your package, reducing +the size for your users.
  • +
  • You don't need to rely on your users having curl or wget or +other system tools on the target machines.
  • +
+

Default Values

+

npm will default some script values based on package contents.

+
    +
  • +

    "start": "node server.js":

    +

    If there is a server.js file in the root of your package, then npm +will default the start command to node server.js.

    +
  • +
  • +

    "install": "node-gyp rebuild":

    +

    If there is a binding.gyp file in the root of your package and you +haven't defined your own install or preinstall scripts, npm will +default the install command to compile using node-gyp.

    +
  • +
+

User

+

If npm was invoked with root privileges, then it will change the uid +to the user account or uid specified by the user config, which +defaults to nobody. Set the unsafe-perm flag to run scripts with +root privileges.

+

Environment

+

Package scripts run in an environment where many pieces of information +are made available regarding the setup of npm and the current state of +the process.

+

path

+

If you depend on modules that define executable scripts, like test +suites, then those executables will be added to the PATH for +executing the scripts. So, if your package.json has this:

+
{ "name" : "foo"
+, "dependencies" : { "bar" : "0.1.x" }
+, "scripts": { "start" : "bar ./test" } }
+

then you could run npm start to execute the bar script, which is +exported into the node_modules/.bin directory on npm install.

+

package.json vars

+

The package.json fields are tacked onto the npm_package_ prefix. So, +for instance, if you had {"name":"foo", "version":"1.2.5"} in your +package.json file, then your package scripts would have the +npm_package_name environment variable set to "foo", and the +npm_package_version set to "1.2.5". You can access these variables +in your code with process.env.npm_package_name and +process.env.npm_package_version, and so on for other fields.

+

configuration

+

Configuration parameters are put in the environment with the +npm_config_ prefix. For instance, you can view the effective root +config by checking the npm_config_root environment variable.

+

Special: package.json "config" object

+

The package.json "config" keys are overwritten in the environment if +there is a config param of <name>[@<version>]:<key>. For example, +if the package.json has this:

+
{ "name" : "foo"
+, "config" : { "port" : "8080" }
+, "scripts" : { "start" : "node server.js" } }
+

and the server.js is this:

+
http.createServer(...).listen(process.env.npm_package_config_port)
+

then the user could change the behavior by doing:

+
  npm config set foo:port 80
+

current lifecycle event

+

Lastly, the npm_lifecycle_event environment variable is set to +whichever stage of the cycle is being executed. So, you could have a +single script used for different parts of the process which switches +based on what's currently happening.

+

Objects are flattened following this format, so if you had +{"scripts":{"install":"foo.js"}} in your package.json, then you'd +see this in the script:

+
process.env.npm_package_scripts_install === "foo.js"
+

Examples

+

For example, if your package.json contains this:

+
{ "scripts" :
+  { "install" : "scripts/install.js"
+  , "postinstall" : "scripts/install.js"
+  , "uninstall" : "scripts/uninstall.js"
+  }
+}
+

then scripts/install.js will be called for the install +and post-install stages of the lifecycle, and scripts/uninstall.js +will be called when the package is uninstalled. Since +scripts/install.js is running for two different phases, it would +be wise in this case to look at the npm_lifecycle_event environment +variable.

+

If you want to run a make command, you can do so. This works just +fine:

+
{ "scripts" :
+  { "preinstall" : "./configure"
+  , "install" : "make && make install"
+  , "test" : "make test"
+  }
+}
+

Exiting

+

Scripts are run by passing the line as a script argument to sh.

+

If the script exits with a code other than 0, then this will abort the +process.

+

Note that these script files don't have to be nodejs or even +javascript programs. They just have to be some kind of executable +file.

+

Hook Scripts

+

If you want to run a specific script at a specific lifecycle event for +ALL packages, then you can use a hook script.

+

Place an executable file at node_modules/.hooks/{eventname}, and +it'll get run for all packages when they are going through that point +in the package lifecycle for any packages installed in that root.

+

Hook scripts are run exactly the same way as package.json scripts. +That is, they are in a separate child process, with the env described +above.

+

Best Practices

+
    +
  • Don't exit with a non-zero error code unless you really mean it. +Except for uninstall scripts, this will cause the npm action to +fail, and potentially be rolled back. If the failure is minor or +only will prevent some optional features, then it's better to just +print a warning and exit successfully.
  • +
  • Try not to use scripts to do what npm can do for you. Read through +package.json to see all the things that you can specify and enable +by simply describing your package appropriately. In general, this +will lead to a more robust and consistent state.
  • +
  • Inspect the env to determine where to put things. For instance, if +the npm_config_binroot environment variable is set to /home/user/bin, then +don't try to install executables into /usr/local/bin. The user +probably set it up that way for a reason.
  • +
  • Don't prefix your script commands with "sudo". If root permissions +are required for some reason, then it'll fail with that error, and +the user will sudo the npm command in question.
  • +
  • Don't use install. Use a .gyp file for compilation, and prepublish +for anything else. You should almost never have to explicitly set a +preinstall or install script. If you are doing this, please consider if +there is another option. The only valid use of install or preinstall +scripts is for compilation which must be done on the target architecture.
  • +
+

See Also

+

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/docs/public/using-npm/semver/index.html b/deps/npm/docs/public/using-npm/semver/index.html new file mode 100644 index 00000000000000..d1bd745a08ea89 --- /dev/null +++ b/deps/npm/docs/public/using-npm/semver/index.html @@ -0,0 +1,432 @@ +

semver(7) -- The semantic versioner for npm

+

Install

+
npm install --save semver
+

Usage

+

As a node module:

+
const semver = require('semver')
+
+semver.valid('1.2.3') // '1.2.3'
+semver.valid('a.b.c') // null
+semver.clean('  =v1.2.3   ') // '1.2.3'
+semver.satisfies('1.2.3', '1.x || >=2.5.0 || 5.0.0 - 7.2.3') // true
+semver.gt('1.2.3', '9.8.7') // false
+semver.lt('1.2.3', '9.8.7') // true
+semver.minVersion('>=1.0.0') // '1.0.0'
+semver.valid(semver.coerce('v2')) // '2.0.0'
+semver.valid(semver.coerce('42.6.7.9.3-alpha')) // '42.6.7'
+

As a command-line utility:

+
$ semver -h
+
+A JavaScript implementation of the https://semver.org/ specification
+Copyright Isaac Z. Schlueter
+
+Usage: semver [options] <version> [<version> [...]]
+Prints valid versions sorted by SemVer precedence
+
+Options:
+-r --range <range>
+        Print versions that match the specified range.
+
+-i --increment [<level>]
+        Increment a version by the specified level.  Level can
+        be one of: major, minor, patch, premajor, preminor,
+        prepatch, or prerelease.  Default level is 'patch'.
+        Only one version may be specified.
+
+--preid <identifier>
+        Identifier to be used to prefix premajor, preminor,
+        prepatch or prerelease version increments.
+
+-l --loose
+        Interpret versions and ranges loosely
+
+-p --include-prerelease
+        Always include prerelease versions in range matching
+
+-c --coerce
+        Coerce a string into SemVer if possible
+        (does not imply --loose)
+
+Program exits successfully if any valid version satisfies
+all supplied ranges, and prints all satisfying versions.
+
+If no satisfying versions are found, then exits failure.
+
+Versions are printed in ascending order, so supplying
+multiple versions to the utility will just sort them.
+

Versions

+

A "version" is described by the v2.0.0 specification found at +https://semver.org/.

+

A leading "=" or "v" character is stripped off and ignored.

+

Ranges

+

A version range is a set of comparators which specify versions +that satisfy the range.

+

A comparator is composed of an operator and a version. The set +of primitive operators is:

+
    +
  • < Less than
  • +
  • <= Less than or equal to
  • +
  • > Greater than
  • +
  • >= Greater than or equal to
  • +
  • = Equal. If no operator is specified, then equality is assumed, +so this operator is optional, but MAY be included.
  • +
+

For example, the comparator >=1.2.7 would match the versions +1.2.7, 1.2.8, 2.5.3, and 1.3.9, but not the versions 1.2.6 +or 1.1.0.

+

Comparators can be joined by whitespace to form a comparator set, +which is satisfied by the intersection of all of the comparators +it includes.

+

A range is composed of one or more comparator sets, joined by ||. A +version matches a range if and only if every comparator in at least +one of the ||-separated comparator sets is satisfied by the version.

+

For example, the range >=1.2.7 <1.3.0 would match the versions +1.2.7, 1.2.8, and 1.2.99, but not the versions 1.2.6, 1.3.0, +or 1.1.0.

+

The range 1.2.7 || >=1.2.9 <2.0.0 would match the versions 1.2.7, +1.2.9, and 1.4.6, but not the versions 1.2.8 or 2.0.0.

+

Prerelease Tags

+

If a version has a prerelease tag (for example, 1.2.3-alpha.3) then +it will only be allowed to satisfy comparator sets if at least one +comparator with the same [major, minor, patch] tuple also has a +prerelease tag.

+

For example, the range >1.2.3-alpha.3 would be allowed to match the +version 1.2.3-alpha.7, but it would not be satisfied by +3.4.5-alpha.9, even though 3.4.5-alpha.9 is technically "greater +than" 1.2.3-alpha.3 according to the SemVer sort rules. The version +range only accepts prerelease tags on the 1.2.3 version. The +version 3.4.5 would satisfy the range, because it does not have a +prerelease flag, and 3.4.5 is greater than 1.2.3-alpha.7.

+

The purpose for this behavior is twofold. First, prerelease versions +frequently are updated very quickly, and contain many breaking changes +that are (by the author's design) not yet fit for public consumption. +Therefore, by default, they are excluded from range matching +semantics.

+

Second, a user who has opted into using a prerelease version has +clearly indicated the intent to use that specific set of +alpha/beta/rc versions. By including a prerelease tag in the range, +the user is indicating that they are aware of the risk. However, it +is still not appropriate to assume that they have opted into taking a +similar risk on the next set of prerelease versions.

+

Note that this behavior can be suppressed (treating all prerelease +versions as if they were normal versions, for the purpose of range +matching) by setting the includePrerelease flag on the options +object to any +functions that do +range matching.

+

Prerelease Identifiers

+

The method .inc takes an additional identifier string argument that +will append the value of the string as a prerelease identifier:

+
semver.inc('1.2.3', 'prerelease', 'beta')
+// '1.2.4-beta.0'
+

command-line example:

+
$ semver 1.2.3 -i prerelease --preid beta
+1.2.4-beta.0
+

Which then can be used to increment further:

+
$ semver 1.2.4-beta.0 -i prerelease
+1.2.4-beta.1
+

Advanced Range Syntax

+

Advanced range syntax desugars to primitive comparators in +deterministic ways.

+

Advanced ranges may be combined in the same way as primitive +comparators using white space or ||.

+

Hyphen Ranges X.Y.Z - A.B.C

+

Specifies an inclusive set.

+
    +
  • 1.2.3 - 2.3.4 := >=1.2.3 <=2.3.4
  • +
+

If a partial version is provided as the first version in the inclusive +range, then the missing pieces are replaced with zeroes.

+
    +
  • 1.2 - 2.3.4 := >=1.2.0 <=2.3.4
  • +
+

If a partial version is provided as the second version in the +inclusive range, then all versions that start with the supplied parts +of the tuple are accepted, but nothing that would be greater than the +provided tuple parts.

+
    +
  • 1.2.3 - 2.3 := >=1.2.3 <2.4.0
  • +
  • 1.2.3 - 2 := >=1.2.3 <3.0.0
  • +
+

X-Ranges 1.2.x 1.X 1.2.* *

+

Any of X, x, or * may be used to "stand in" for one of the +numeric values in the [major, minor, patch] tuple.

+
    +
  • * := >=0.0.0 (Any version satisfies)
  • +
  • 1.x := >=1.0.0 <2.0.0 (Matching major version)
  • +
  • 1.2.x := >=1.2.0 <1.3.0 (Matching major and minor versions)
  • +
+

A partial version range is treated as an X-Range, so the special +character is in fact optional.

+
    +
  • "" (empty string) := * := >=0.0.0
  • +
  • 1 := 1.x.x := >=1.0.0 <2.0.0
  • +
  • 1.2 := 1.2.x := >=1.2.0 <1.3.0
  • +
+

Tilde Ranges ~1.2.3 ~1.2 ~1

+

Allows patch-level changes if a minor version is specified on the +comparator. Allows minor-level changes if not.

+
    +
  • ~1.2.3 := >=1.2.3 <1.(2+1).0 := >=1.2.3 <1.3.0
  • +
  • ~1.2 := >=1.2.0 <1.(2+1).0 := >=1.2.0 <1.3.0 (Same as 1.2.x)
  • +
  • ~1 := >=1.0.0 <(1+1).0.0 := >=1.0.0 <2.0.0 (Same as 1.x)
  • +
  • ~0.2.3 := >=0.2.3 <0.(2+1).0 := >=0.2.3 <0.3.0
  • +
  • ~0.2 := >=0.2.0 <0.(2+1).0 := >=0.2.0 <0.3.0 (Same as 0.2.x)
  • +
  • ~0 := >=0.0.0 <(0+1).0.0 := >=0.0.0 <1.0.0 (Same as 0.x)
  • +
  • ~1.2.3-beta.2 := >=1.2.3-beta.2 <1.3.0 Note that prereleases in +the 1.2.3 version will be allowed, if they are greater than or +equal to beta.2. So, 1.2.3-beta.4 would be allowed, but +1.2.4-beta.2 would not, because it is a prerelease of a +different [major, minor, patch] tuple.
  • +
+

Caret Ranges ^1.2.3 ^0.2.5 ^0.0.4

+

Allows changes that do not modify the left-most non-zero digit in the +[major, minor, patch] tuple. In other words, this allows patch and +minor updates for versions 1.0.0 and above, patch updates for +versions 0.X >=0.1.0, and no updates for versions 0.0.X.

+

Many authors treat a 0.x version as if the x were the major +"breaking-change" indicator.

+

Caret ranges are ideal when an author may make breaking changes +between 0.2.4 and 0.3.0 releases, which is a common practice. +However, it presumes that there will not be breaking changes between +0.2.4 and 0.2.5. It allows for changes that are presumed to be +additive (but non-breaking), according to commonly observed practices.

+
    +
  • ^1.2.3 := >=1.2.3 <2.0.0
  • +
  • ^0.2.3 := >=0.2.3 <0.3.0
  • +
  • ^0.0.3 := >=0.0.3 <0.0.4
  • +
  • ^1.2.3-beta.2 := >=1.2.3-beta.2 <2.0.0 Note that prereleases in +the 1.2.3 version will be allowed, if they are greater than or +equal to beta.2. So, 1.2.3-beta.4 would be allowed, but +1.2.4-beta.2 would not, because it is a prerelease of a +different [major, minor, patch] tuple.
  • +
  • ^0.0.3-beta := >=0.0.3-beta <0.0.4 Note that prereleases in the +0.0.3 version only will be allowed, if they are greater than or +equal to beta. So, 0.0.3-pr.2 would be allowed.
  • +
+

When parsing caret ranges, a missing patch value desugars to the +number 0, but will allow flexibility within that value, even if the +major and minor versions are both 0.

+
    +
  • ^1.2.x := >=1.2.0 <2.0.0
  • +
  • ^0.0.x := >=0.0.0 <0.1.0
  • +
  • ^0.0 := >=0.0.0 <0.1.0
  • +
+

A missing minor and patch values will desugar to zero, but also +allow flexibility within those values, even if the major version is +zero.

+
    +
  • ^1.x := >=1.0.0 <2.0.0
  • +
  • ^0.x := >=0.0.0 <1.0.0
  • +
+

Range Grammar

+

Putting all this together, here is a Backus-Naur grammar for ranges, +for the benefit of parser authors:

+
range-set  ::= range ( logical-or range ) *
+logical-or ::= ( ' ' ) * '||' ( ' ' ) *
+range      ::= hyphen | simple ( ' ' simple ) * | ''
+hyphen     ::= partial ' - ' partial
+simple     ::= primitive | partial | tilde | caret
+primitive  ::= ( '<' | '>' | '>=' | '<=' | '=' ) partial
+partial    ::= xr ( '.' xr ( '.' xr qualifier ? )? )?
+xr         ::= 'x' | 'X' | '*' | nr
+nr         ::= '0' | ['1'-'9'] ( ['0'-'9'] ) *
+tilde      ::= '~' partial
+caret      ::= '^' partial
+qualifier  ::= ( '-' pre )? ( '+' build )?
+pre        ::= parts
+build      ::= parts
+parts      ::= part ( '.' part ) *
+part       ::= nr | [-0-9A-Za-z]+
+

Functions

+

All methods and classes take a final options object argument. All +options in this object are false by default. The options supported +are:

+
    +
  • loose Be more forgiving about not-quite-valid semver strings. +(Any resulting output will always be 100% strict compliant, of +course.) For backwards compatibility reasons, if the options +argument is a boolean value instead of an object, it is interpreted +to be the loose param.
  • +
  • includePrerelease Set to suppress the default +behavior of +excluding prerelease tagged versions from ranges unless they are +explicitly opted into.
  • +
+

Strict-mode Comparators and Ranges will be strict about the SemVer +strings that they parse.

+
    +
  • valid(v): Return the parsed version, or null if it's not valid.
  • +
  • +

    inc(v, release): Return the version incremented by the release +type (major, premajor, minor, preminor, patch, +prepatch, or prerelease), or null if it's not valid

    +
      +
    • premajor in one call will bump the version up to the next major +version and down to a prerelease of that major version. +preminor, and prepatch work the same way.
    • +
    • If called from a non-prerelease version, the prerelease will work the +same as prepatch. It increments the patch version, then makes a +prerelease. If the input version is already a prerelease it simply +increments it.
    • +
    +
  • +
  • prerelease(v): Returns an array of prerelease components, or null +if none exist. Example: prerelease('1.2.3-alpha.1') -> ['alpha', 1]
  • +
  • major(v): Return the major version number.
  • +
  • minor(v): Return the minor version number.
  • +
  • patch(v): Return the patch version number.
  • +
  • intersects(r1, r2, loose): Return true if the two supplied ranges +or comparators intersect.
  • +
  • parse(v): Attempt to parse a string as a semantic version, returning either +a SemVer object or null.
  • +
+

Comparison

+
    +
  • gt(v1, v2): v1 > v2
  • +
  • gte(v1, v2): v1 >= v2
  • +
  • lt(v1, v2): v1 < v2
  • +
  • lte(v1, v2): v1 <= v2
  • +
  • eq(v1, v2): v1 == v2 This is true if they're logically equivalent, +even if they're not the exact same string. You already know how to +compare strings.
  • +
  • neq(v1, v2): v1 != v2 The opposite of eq.
  • +
  • cmp(v1, comparator, v2): Pass in a comparison string, and it'll call +the corresponding function above. "===" and "!==" do simple +string comparison, but are included for completeness. Throws if an +invalid comparison string is provided.
  • +
  • compare(v1, v2): Return 0 if v1 == v2, or 1 if v1 is greater, or -1 if +v2 is greater. Sorts in ascending order if passed to Array.sort().
  • +
  • rcompare(v1, v2): The reverse of compare. Sorts an array of versions +in descending order when passed to Array.sort().
  • +
  • diff(v1, v2): Returns difference between two versions by the release type +(major, premajor, minor, preminor, patch, prepatch, or prerelease), +or null if the versions are the same.
  • +
+

Comparators

+
    +
  • intersects(comparator): Return true if the comparators intersect
  • +
+

Ranges

+
    +
  • validRange(range): Return the valid range or null if it's not valid
  • +
  • satisfies(version, range): Return true if the version satisfies the +range.
  • +
  • maxSatisfying(versions, range): Return the highest version in the list +that satisfies the range, or null if none of them do.
  • +
  • minSatisfying(versions, range): Return the lowest version in the list +that satisfies the range, or null if none of them do.
  • +
  • minVersion(range): Return the lowest version that can possibly match +the given range.
  • +
  • gtr(version, range): Return true if version is greater than all the +versions possible in the range.
  • +
  • ltr(version, range): Return true if version is less than all the +versions possible in the range.
  • +
  • outside(version, range, hilo): Return true if the version is outside +the bounds of the range in either the high or low direction. The +hilo argument must be either the string '>' or '<'. (This is +the function called by gtr and ltr.)
  • +
  • intersects(range): Return true if any of the ranges comparators intersect
  • +
+

Note that, since ranges may be non-contiguous, a version might not be +greater than a range, less than a range, or satisfy a range! For +example, the range 1.2 <1.2.9 || >2.0.0 would have a hole from 1.2.9 +until 2.0.0, so the version 1.2.10 would not be greater than the +range (because 2.0.1 satisfies, which is higher), nor less than the +range (since 1.2.8 satisfies, which is lower), and it also does not +satisfy the range.

+

If you want to know if a version satisfies or does not satisfy a +range, use the satisfies(version, range) function.

+

Coercion

+
    +
  • coerce(version): Coerces a string to semver if possible
  • +
+

This aims to provide a very forgiving translation of a non-semver string to +semver. It looks for the first digit in a string, and consumes all +remaining characters which satisfy at least a partial semver (e.g., 1, +1.2, 1.2.3) up to the max permitted length (256 characters). Longer +versions are simply truncated (4.6.3.9.2-alpha2 becomes 4.6.3). All +surrounding text is simply ignored (v3.4 replaces v3.3.1 becomes +3.4.0). Only text which lacks digits will fail coercion (version one +is not valid). The maximum length for any semver component considered for +coercion is 16 characters; longer components will be ignored +(10000000000000000.4.7.4 becomes 4.7.4). The maximum value for any +semver component is Number.MAX_SAFE_INTEGER || (2**53 - 1); higher value +components are invalid (9999999999999999.4.7.4 is likely invalid).

👀 Found a typo? Let us know!

The current stable version of npm is here. To upgrade, run: npm install npm@latest -g

To report bugs or submit feature requests for the docs, please post here. Submit npm issues here.

\ No newline at end of file diff --git a/deps/npm/lib/fund.js b/deps/npm/lib/fund.js index 4981e461596c07..00954c844d7981 100644 --- a/deps/npm/lib/fund.js +++ b/deps/npm/lib/fund.js @@ -14,7 +14,7 @@ const readShrinkwrap = require('./install/read-shrinkwrap.js') const mutateIntoLogicalTree = require('./install/mutate-into-logical-tree.js') const output = require('./utils/output.js') const openUrl = require('./utils/open-url.js') -const { getFundingInfo, validFundingUrl } = require('./utils/funding.js') +const { getFundingInfo, retrieveFunding, validFundingUrl } = require('./utils/funding.js') const FundConfig = figgyPudding({ browser: {}, // used by ./utils/open-url @@ -132,7 +132,7 @@ function printHuman (fundingInfo, opts) { function openFundingUrl (packageName, cb) { function getUrlAndOpen (packageMetadata) { const { funding } = packageMetadata - const { type, url } = funding || {} + const { type, url } = retrieveFunding(funding) || {} const noFundingError = new Error(`No funding method available for: ${packageName}`) noFundingError.code = 'ENOFUND' diff --git a/deps/npm/lib/install/deps.js b/deps/npm/lib/install/deps.js index dfe30b6c0f38c0..3d8b333c64441c 100644 --- a/deps/npm/lib/install/deps.js +++ b/deps/npm/lib/install/deps.js @@ -203,10 +203,15 @@ function removeObsoleteDep (child, log) { function packageRelativePath (tree) { if (!tree) return '' var requested = tree.package._requested || {} - var isLocal = requested.type === 'directory' || requested.type === 'file' - return isLocal ? requested.fetchSpec - : (tree.isLink || tree.isInLink) && !preserveSymlinks() ? tree.realpath - : tree.path + if (requested.type === 'directory') { + return requested.fetchSpec + } else if (requested.type === 'file') { + return path.dirname(requested.fetchSpec) + } else if ((tree.isLink || tree.isInLink) && !preserveSymlinks()) { + return tree.realpath + } else { + return tree.path + } } function matchingDep (tree, name) { diff --git a/deps/npm/lib/install/read-shrinkwrap.js b/deps/npm/lib/install/read-shrinkwrap.js index 70746780111275..1d9fb99c1d8078 100644 --- a/deps/npm/lib/install/read-shrinkwrap.js +++ b/deps/npm/lib/install/read-shrinkwrap.js @@ -19,8 +19,7 @@ function readShrinkwrap (child, next) { maybeReadFile('npm-shrinkwrap.json', child), // Don't read non-root lockfiles child.isTop && maybeReadFile('package-lock.json', child), - child.isTop && maybeReadFile('package.json', child), - (shrinkwrap, lockfile, pkgJson) => { + (shrinkwrap, lockfile) => { if (shrinkwrap && lockfile) { log.warn('read-shrinkwrap', 'Ignoring package-lock.json because there is already an npm-shrinkwrap.json. Please use only one of the two.') } diff --git a/deps/npm/lib/utils/error-message.js b/deps/npm/lib/utils/error-message.js index 5ddfb37682a2e6..12f304d1e894ac 100644 --- a/deps/npm/lib/utils/error-message.js +++ b/deps/npm/lib/utils/error-message.js @@ -280,8 +280,9 @@ function errorMessage (er) { case 'EEXIST': short.push(['', er.message]) - short.push(['', 'File exists: ' + er.path]) - detail.push(['', 'Move it away, and try again.']) + short.push(['', 'File exists: ' + (er.dest || er.path)]) + detail.push(['', 'Remove the existing file and try again, or run npm']) + detail.push(['', 'with --force to overwrite files recklessly.']) break case 'ENEEDAUTH': diff --git a/deps/npm/lib/utils/funding.js b/deps/npm/lib/utils/funding.js index dce40147642c5f..c3d06b10899638 100644 --- a/deps/npm/lib/utils/funding.js +++ b/deps/npm/lib/utils/funding.js @@ -3,8 +3,18 @@ const URL = require('url').URL exports.getFundingInfo = getFundingInfo +exports.retrieveFunding = retrieveFunding exports.validFundingUrl = validFundingUrl +// supports both object funding and string shorthand +function retrieveFunding (funding) { + return typeof funding === 'string' + ? { + url: funding + } + : funding +} + // Is the value of a `funding` property of a `package.json` // a valid type+url for `npm fund` to display? function validFundingUrl (funding) { @@ -60,14 +70,6 @@ function getFundingInfo (idealTree, opts) { ) } - function retrieveFunding (funding) { - return typeof funding === 'string' - ? { - url: funding - } - : funding - } - function getFundingDependencies (tree) { const deps = tree && tree.dependencies if (!deps) return empty() diff --git a/deps/npm/lib/version.js b/deps/npm/lib/version.js index 0f1e97aedd4038..a8c2a648c74736 100644 --- a/deps/npm/lib/version.js +++ b/deps/npm/lib/version.js @@ -256,7 +256,7 @@ function checkGit (localData, cb) { statGitFolder(function (er) { var doGit = !er && npm.config.get('git-tag-version') if (!doGit) { - if (er) log.verbose('version', 'error checking for .git', er) + if (er && npm.config.get('git-tag-version')) log.verbose('version', 'error checking for .git', er) log.verbose('version', 'not tagging in git') return cb(null, false) } diff --git a/deps/npm/man/man1/npm-README.1 b/deps/npm/man/man1/npm-README.1 index c2535cc28a1a51..d3028ee37bfd02 100644 --- a/deps/npm/man/man1/npm-README.1 +++ b/deps/npm/man/man1/npm-README.1 @@ -1,4 +1,4 @@ -.TH "NPM" "1" "November 2019" "" "" +.TH "NPM" "1" "December 2019" "" "" .SH "NAME" \fBnpm\fR \- a JavaScript package manager .P diff --git a/deps/npm/man/man1/npm-access.1 b/deps/npm/man/man1/npm-access.1 index ac6274bacdb066..a08b24798002e3 100644 --- a/deps/npm/man/man1/npm-access.1 +++ b/deps/npm/man/man1/npm-access.1 @@ -1,4 +1,4 @@ -.TH "NPM\-ACCESS" "1" "November 2019" "" "" +.TH "NPM\-ACCESS" "1" "December 2019" "" "" .SH "NAME" \fBnpm-access\fR \- Set access level on published packages .SS Synopsis diff --git a/deps/npm/man/man1/npm-adduser.1 b/deps/npm/man/man1/npm-adduser.1 index 89cda8029790e5..f2f9557dcc7d13 100644 --- a/deps/npm/man/man1/npm-adduser.1 +++ b/deps/npm/man/man1/npm-adduser.1 @@ -1,4 +1,4 @@ -.TH "NPM\-ADDUSER" "1" "November 2019" "" "" +.TH "NPM\-ADDUSER" "1" "December 2019" "" "" .SH "NAME" \fBnpm-adduser\fR \- Add a registry user account .SS Synopsis diff --git a/deps/npm/man/man1/npm-audit.1 b/deps/npm/man/man1/npm-audit.1 index 50e61c60d1748e..1536217ad0a109 100644 --- a/deps/npm/man/man1/npm-audit.1 +++ b/deps/npm/man/man1/npm-audit.1 @@ -1,4 +1,4 @@ -.TH "NPM\-AUDIT" "1" "November 2019" "" "" +.TH "NPM\-AUDIT" "1" "December 2019" "" "" .SH "NAME" \fBnpm-audit\fR \- Run a security audit .SS Synopsis diff --git a/deps/npm/man/man1/npm-bin.1 b/deps/npm/man/man1/npm-bin.1 index 8a925ee708ee5d..1045b8a057a38f 100644 --- a/deps/npm/man/man1/npm-bin.1 +++ b/deps/npm/man/man1/npm-bin.1 @@ -1,4 +1,4 @@ -.TH "NPM\-BIN" "1" "November 2019" "" "" +.TH "NPM\-BIN" "1" "December 2019" "" "" .SH "NAME" \fBnpm-bin\fR \- Display npm bin folder .SS Synopsis diff --git a/deps/npm/man/man1/npm-bugs.1 b/deps/npm/man/man1/npm-bugs.1 index 953d83bc78ac68..26cf705225edbf 100644 --- a/deps/npm/man/man1/npm-bugs.1 +++ b/deps/npm/man/man1/npm-bugs.1 @@ -1,4 +1,4 @@ -.TH "NPM\-BUGS" "1" "November 2019" "" "" +.TH "NPM\-BUGS" "1" "December 2019" "" "" .SH "NAME" \fBnpm-bugs\fR \- Bugs for a package in a web browser maybe .SS Synopsis diff --git a/deps/npm/man/man1/npm-build.1 b/deps/npm/man/man1/npm-build.1 index 7ea03625729cd2..ccee0f7c094fdb 100644 --- a/deps/npm/man/man1/npm-build.1 +++ b/deps/npm/man/man1/npm-build.1 @@ -1,4 +1,4 @@ -.TH "NPM\-BUILD" "1" "November 2019" "" "" +.TH "NPM\-BUILD" "1" "December 2019" "" "" .SH "NAME" \fBnpm-build\fR \- Build a package .SS Synopsis diff --git a/deps/npm/man/man1/npm-bundle.1 b/deps/npm/man/man1/npm-bundle.1 index 8c911b2d570f3e..936659595a8e3c 100644 --- a/deps/npm/man/man1/npm-bundle.1 +++ b/deps/npm/man/man1/npm-bundle.1 @@ -1,4 +1,4 @@ -.TH "NPM\-BUNDLE" "1" "November 2019" "" "" +.TH "NPM\-BUNDLE" "1" "December 2019" "" "" .SH "NAME" \fBnpm-bundle\fR \- REMOVED .SS Description diff --git a/deps/npm/man/man1/npm-cache.1 b/deps/npm/man/man1/npm-cache.1 index 5740233250a513..da2a65f513b4ef 100644 --- a/deps/npm/man/man1/npm-cache.1 +++ b/deps/npm/man/man1/npm-cache.1 @@ -1,4 +1,4 @@ -.TH "NPM\-CACHE" "1" "November 2019" "" "" +.TH "NPM\-CACHE" "1" "December 2019" "" "" .SH "NAME" \fBnpm-cache\fR \- Manipulates packages cache .SS Synopsis diff --git a/deps/npm/man/man1/npm-ci.1 b/deps/npm/man/man1/npm-ci.1 index adad70234939f4..75cc55041a9c1f 100644 --- a/deps/npm/man/man1/npm-ci.1 +++ b/deps/npm/man/man1/npm-ci.1 @@ -1,4 +1,4 @@ -.TH "NPM\-CI" "1" "November 2019" "" "" +.TH "NPM\-CI" "1" "December 2019" "" "" .SH "NAME" \fBnpm-ci\fR \- Install a project with a clean slate .SS Synopsis diff --git a/deps/npm/man/man1/npm-completion.1 b/deps/npm/man/man1/npm-completion.1 index ce6654a0c93a63..b267ffe8387016 100644 --- a/deps/npm/man/man1/npm-completion.1 +++ b/deps/npm/man/man1/npm-completion.1 @@ -1,4 +1,4 @@ -.TH "NPM\-COMPLETION" "1" "November 2019" "" "" +.TH "NPM\-COMPLETION" "1" "December 2019" "" "" .SH "NAME" \fBnpm-completion\fR \- Tab Completion for npm .SS Synopsis diff --git a/deps/npm/man/man1/npm-config.1 b/deps/npm/man/man1/npm-config.1 index 423f7f258b67d0..1300519368339f 100644 --- a/deps/npm/man/man1/npm-config.1 +++ b/deps/npm/man/man1/npm-config.1 @@ -1,4 +1,4 @@ -.TH "NPM\-CONFIG" "1" "November 2019" "" "" +.TH "NPM\-CONFIG" "1" "December 2019" "" "" .SH "NAME" \fBnpm-config\fR \- Manage the npm configuration files .SS Synopsis diff --git a/deps/npm/man/man1/npm-dedupe.1 b/deps/npm/man/man1/npm-dedupe.1 index f4b0e6fd56c281..ef7c109d770f98 100644 --- a/deps/npm/man/man1/npm-dedupe.1 +++ b/deps/npm/man/man1/npm-dedupe.1 @@ -1,4 +1,4 @@ -.TH "NPM\-DEDUPE" "1" "November 2019" "" "" +.TH "NPM\-DEDUPE" "1" "December 2019" "" "" .SH "NAME" \fBnpm-dedupe\fR \- Reduce duplication .SS Synopsis diff --git a/deps/npm/man/man1/npm-deprecate.1 b/deps/npm/man/man1/npm-deprecate.1 index cfbe9dcf2be5f6..ccbb03b550a3b4 100644 --- a/deps/npm/man/man1/npm-deprecate.1 +++ b/deps/npm/man/man1/npm-deprecate.1 @@ -1,4 +1,4 @@ -.TH "NPM\-DEPRECATE" "1" "November 2019" "" "" +.TH "NPM\-DEPRECATE" "1" "December 2019" "" "" .SH "NAME" \fBnpm-deprecate\fR \- Deprecate a version of a package .SS Synopsis diff --git a/deps/npm/man/man1/npm-dist-tag.1 b/deps/npm/man/man1/npm-dist-tag.1 index 211c02dbac9a24..50896edfd10561 100644 --- a/deps/npm/man/man1/npm-dist-tag.1 +++ b/deps/npm/man/man1/npm-dist-tag.1 @@ -1,4 +1,4 @@ -.TH "NPM\-DIST\-TAG" "1" "November 2019" "" "" +.TH "NPM\-DIST\-TAG" "1" "December 2019" "" "" .SH "NAME" \fBnpm-dist-tag\fR \- Modify package distribution tags .SS Synopsis diff --git a/deps/npm/man/man1/npm-docs.1 b/deps/npm/man/man1/npm-docs.1 index 7adbedd9a0f019..c4c80b2396e515 100644 --- a/deps/npm/man/man1/npm-docs.1 +++ b/deps/npm/man/man1/npm-docs.1 @@ -1,4 +1,4 @@ -.TH "NPM\-DOCS" "1" "November 2019" "" "" +.TH "NPM\-DOCS" "1" "December 2019" "" "" .SH "NAME" \fBnpm-docs\fR \- Docs for a package in a web browser maybe .SS Synopsis diff --git a/deps/npm/man/man1/npm-doctor.1 b/deps/npm/man/man1/npm-doctor.1 index 52ccfb0c4cb52c..d92053da430b90 100644 --- a/deps/npm/man/man1/npm-doctor.1 +++ b/deps/npm/man/man1/npm-doctor.1 @@ -1,4 +1,4 @@ -.TH "NPM\-DOCTOR" "1" "November 2019" "" "" +.TH "NPM\-DOCTOR" "1" "December 2019" "" "" .SH "NAME" \fBnpm-doctor\fR \- Check your environments .SS Synopsis diff --git a/deps/npm/man/man1/npm-edit.1 b/deps/npm/man/man1/npm-edit.1 index 36abc611f88c6a..e76ae46c7af092 100644 --- a/deps/npm/man/man1/npm-edit.1 +++ b/deps/npm/man/man1/npm-edit.1 @@ -1,4 +1,4 @@ -.TH "NPM\-EDIT" "1" "November 2019" "" "" +.TH "NPM\-EDIT" "1" "December 2019" "" "" .SH "NAME" \fBnpm-edit\fR \- Edit an installed package .SS Synopsis diff --git a/deps/npm/man/man1/npm-explore.1 b/deps/npm/man/man1/npm-explore.1 index 5b27fcf9b76bef..bf34d050ed4dca 100644 --- a/deps/npm/man/man1/npm-explore.1 +++ b/deps/npm/man/man1/npm-explore.1 @@ -1,4 +1,4 @@ -.TH "NPM\-EXPLORE" "1" "November 2019" "" "" +.TH "NPM\-EXPLORE" "1" "December 2019" "" "" .SH "NAME" \fBnpm-explore\fR \- Browse an installed package .SS Synopsis diff --git a/deps/npm/man/man1/npm-fund.1 b/deps/npm/man/man1/npm-fund.1 index 83280693f2794b..170d93753f56ca 100644 --- a/deps/npm/man/man1/npm-fund.1 +++ b/deps/npm/man/man1/npm-fund.1 @@ -1,4 +1,4 @@ -.TH "NPM\-FUND" "1" "November 2019" "" "" +.TH "NPM\-FUND" "1" "December 2019" "" "" .SH "NAME" \fBnpm-fund\fR \- Retrieve funding information .SS Synopsis diff --git a/deps/npm/man/man1/npm-help-search.1 b/deps/npm/man/man1/npm-help-search.1 index 01400fe1528523..fcf4b863541cb4 100644 --- a/deps/npm/man/man1/npm-help-search.1 +++ b/deps/npm/man/man1/npm-help-search.1 @@ -1,4 +1,4 @@ -.TH "NPM\-HELP\-SEARCH" "1" "November 2019" "" "" +.TH "NPM\-HELP\-SEARCH" "1" "December 2019" "" "" .SH "NAME" \fBnpm-help-search\fR \- Search npm help documentation .SS Synopsis diff --git a/deps/npm/man/man1/npm-help.1 b/deps/npm/man/man1/npm-help.1 index f5331a6ac72e83..2fd749f88d1ade 100644 --- a/deps/npm/man/man1/npm-help.1 +++ b/deps/npm/man/man1/npm-help.1 @@ -1,4 +1,4 @@ -.TH "NPM\-HELP" "1" "November 2019" "" "" +.TH "NPM\-HELP" "1" "December 2019" "" "" .SH "NAME" \fBnpm-help\fR \- Get help on npm .SS Synopsis diff --git a/deps/npm/man/man1/npm-hook.1 b/deps/npm/man/man1/npm-hook.1 index 521f44f01ad2a8..dbc6f8b898644a 100644 --- a/deps/npm/man/man1/npm-hook.1 +++ b/deps/npm/man/man1/npm-hook.1 @@ -1,4 +1,4 @@ -.TH "NPM\-HOOK" "1" "November 2019" "" "" +.TH "NPM\-HOOK" "1" "December 2019" "" "" .SH "NAME" \fBnpm-hook\fR \- Manage registry hooks .SS Synopsis diff --git a/deps/npm/man/man1/npm-init.1 b/deps/npm/man/man1/npm-init.1 index d0bf42286e182e..bdd4ab126fa26f 100644 --- a/deps/npm/man/man1/npm-init.1 +++ b/deps/npm/man/man1/npm-init.1 @@ -1,4 +1,4 @@ -.TH "NPM\-INIT" "1" "November 2019" "" "" +.TH "NPM\-INIT" "1" "December 2019" "" "" .SH "NAME" \fBnpm-init\fR \- create a package\.json file .SS Synopsis diff --git a/deps/npm/man/man1/npm-install-ci-test.1 b/deps/npm/man/man1/npm-install-ci-test.1 index 8ac6535034ea1c..487de9cbe4ee45 100644 --- a/deps/npm/man/man1/npm-install-ci-test.1 +++ b/deps/npm/man/man1/npm-install-ci-test.1 @@ -1,4 +1,4 @@ -.TH "NPM" "" "November 2019" "" "" +.TH "NPM" "" "December 2019" "" "" .SH "NAME" \fBnpm\fR .SS Synopsis diff --git a/deps/npm/man/man1/npm-install-test.1 b/deps/npm/man/man1/npm-install-test.1 index 470d20f3574047..0b5915cd2ed5c7 100644 --- a/deps/npm/man/man1/npm-install-test.1 +++ b/deps/npm/man/man1/npm-install-test.1 @@ -1,4 +1,4 @@ -.TH "NPM" "" "November 2019" "" "" +.TH "NPM" "" "December 2019" "" "" .SH "NAME" \fBnpm\fR .SS Synopsis diff --git a/deps/npm/man/man1/npm-install.1 b/deps/npm/man/man1/npm-install.1 index c3ab9dc7740435..ba9e8cc12dcfa1 100644 --- a/deps/npm/man/man1/npm-install.1 +++ b/deps/npm/man/man1/npm-install.1 @@ -1,4 +1,4 @@ -.TH "NPM\-INSTALL" "1" "November 2019" "" "" +.TH "NPM\-INSTALL" "1" "December 2019" "" "" .SH "NAME" \fBnpm-install\fR \- Install a package .SS Synopsis diff --git a/deps/npm/man/man1/npm-link.1 b/deps/npm/man/man1/npm-link.1 index 3485c817455caf..9120d99ebfac26 100644 --- a/deps/npm/man/man1/npm-link.1 +++ b/deps/npm/man/man1/npm-link.1 @@ -1,4 +1,4 @@ -.TH "NPM\-LINK" "1" "November 2019" "" "" +.TH "NPM\-LINK" "1" "December 2019" "" "" .SH "NAME" \fBnpm-link\fR \- Symlink a package folder .SS Synopsis diff --git a/deps/npm/man/man1/npm-logout.1 b/deps/npm/man/man1/npm-logout.1 index 997668379c100a..1469659def9e49 100644 --- a/deps/npm/man/man1/npm-logout.1 +++ b/deps/npm/man/man1/npm-logout.1 @@ -1,4 +1,4 @@ -.TH "NPM\-LOGOUT" "1" "November 2019" "" "" +.TH "NPM\-LOGOUT" "1" "December 2019" "" "" .SH "NAME" \fBnpm-logout\fR \- Log out of the registry .SS Synopsis diff --git a/deps/npm/man/man1/npm-ls.1 b/deps/npm/man/man1/npm-ls.1 index c6d035446ff2cc..fc46b3ad787e65 100644 --- a/deps/npm/man/man1/npm-ls.1 +++ b/deps/npm/man/man1/npm-ls.1 @@ -1,4 +1,4 @@ -.TH "NPM\-LS" "1" "November 2019" "" "" +.TH "NPM\-LS" "1" "December 2019" "" "" .SH "NAME" \fBnpm-ls\fR \- List installed packages .SS Synopsis @@ -22,7 +22,7 @@ For example, running \fBnpm ls promzard\fP in npm's source tree will show: .P .RS 2 .nf - npm@6\.13\.1 /path/to/npm + npm@6\.13\.4 /path/to/npm └─┬ init\-package\-json@0\.0\.4 └── promzard@0\.1\.5 .fi diff --git a/deps/npm/man/man1/npm-org.1 b/deps/npm/man/man1/npm-org.1 index d3e7cb74f5bc30..bb0f44eee8110a 100644 --- a/deps/npm/man/man1/npm-org.1 +++ b/deps/npm/man/man1/npm-org.1 @@ -1,4 +1,4 @@ -.TH "NPM\-ORG" "1" "November 2019" "" "" +.TH "NPM\-ORG" "1" "December 2019" "" "" .SH "NAME" \fBnpm-org\fR \- Manage orgs .SS Synopsis diff --git a/deps/npm/man/man1/npm-outdated.1 b/deps/npm/man/man1/npm-outdated.1 index 681b457d8d611c..c180c6f1c378a7 100644 --- a/deps/npm/man/man1/npm-outdated.1 +++ b/deps/npm/man/man1/npm-outdated.1 @@ -1,4 +1,4 @@ -.TH "NPM\-OUTDATED" "1" "November 2019" "" "" +.TH "NPM\-OUTDATED" "1" "December 2019" "" "" .SH "NAME" \fBnpm-outdated\fR \- Check for outdated packages .SS Synopsis diff --git a/deps/npm/man/man1/npm-owner.1 b/deps/npm/man/man1/npm-owner.1 index 343fcc3ea3f67e..609562e7aa105c 100644 --- a/deps/npm/man/man1/npm-owner.1 +++ b/deps/npm/man/man1/npm-owner.1 @@ -1,4 +1,4 @@ -.TH "NPM\-OWNER" "1" "November 2019" "" "" +.TH "NPM\-OWNER" "1" "December 2019" "" "" .SH "NAME" \fBnpm-owner\fR \- Manage package owners .SS Synopsis diff --git a/deps/npm/man/man1/npm-pack.1 b/deps/npm/man/man1/npm-pack.1 index 9b8feaaa67f864..73d12bbab94fdb 100644 --- a/deps/npm/man/man1/npm-pack.1 +++ b/deps/npm/man/man1/npm-pack.1 @@ -1,4 +1,4 @@ -.TH "NPM\-PACK" "1" "November 2019" "" "" +.TH "NPM\-PACK" "1" "December 2019" "" "" .SH "NAME" \fBnpm-pack\fR \- Create a tarball from a package .SS Synopsis diff --git a/deps/npm/man/man1/npm-ping.1 b/deps/npm/man/man1/npm-ping.1 index dda31466bffe25..f555c4f6e2ba0d 100644 --- a/deps/npm/man/man1/npm-ping.1 +++ b/deps/npm/man/man1/npm-ping.1 @@ -1,4 +1,4 @@ -.TH "NPM\-PING" "1" "November 2019" "" "" +.TH "NPM\-PING" "1" "December 2019" "" "" .SH "NAME" \fBnpm-ping\fR \- Ping npm registry .SS Synopsis diff --git a/deps/npm/man/man1/npm-prefix.1 b/deps/npm/man/man1/npm-prefix.1 index 04d7c00ecfd983..d4fe8fb2ef74e3 100644 --- a/deps/npm/man/man1/npm-prefix.1 +++ b/deps/npm/man/man1/npm-prefix.1 @@ -1,4 +1,4 @@ -.TH "NPM\-PREFIX" "1" "November 2019" "" "" +.TH "NPM\-PREFIX" "1" "December 2019" "" "" .SH "NAME" \fBnpm-prefix\fR \- Display prefix .SS Synopsis diff --git a/deps/npm/man/man1/npm-prune.1 b/deps/npm/man/man1/npm-prune.1 index 58ccd7b3852cdc..15cdbc2d69fa45 100644 --- a/deps/npm/man/man1/npm-prune.1 +++ b/deps/npm/man/man1/npm-prune.1 @@ -1,4 +1,4 @@ -.TH "NPM\-PRUNE" "1" "November 2019" "" "" +.TH "NPM\-PRUNE" "1" "December 2019" "" "" .SH "NAME" \fBnpm-prune\fR \- Remove extraneous packages .SS Synopsis diff --git a/deps/npm/man/man1/npm-publish.1 b/deps/npm/man/man1/npm-publish.1 index 45de41045e180f..63a08a5f19bd0a 100644 --- a/deps/npm/man/man1/npm-publish.1 +++ b/deps/npm/man/man1/npm-publish.1 @@ -1,4 +1,4 @@ -.TH "NPM\-PUBLISH" "1" "November 2019" "" "" +.TH "NPM\-PUBLISH" "1" "December 2019" "" "" .SH "NAME" \fBnpm-publish\fR \- Publish a package .SS Synopsis diff --git a/deps/npm/man/man1/npm-rebuild.1 b/deps/npm/man/man1/npm-rebuild.1 index 49674eca385994..367766f81f5484 100644 --- a/deps/npm/man/man1/npm-rebuild.1 +++ b/deps/npm/man/man1/npm-rebuild.1 @@ -1,4 +1,4 @@ -.TH "NPM\-REBUILD" "1" "November 2019" "" "" +.TH "NPM\-REBUILD" "1" "December 2019" "" "" .SH "NAME" \fBnpm-rebuild\fR \- Rebuild a package .SS Synopsis diff --git a/deps/npm/man/man1/npm-repo.1 b/deps/npm/man/man1/npm-repo.1 index 597292b8d43e6e..aa72275dfe730b 100644 --- a/deps/npm/man/man1/npm-repo.1 +++ b/deps/npm/man/man1/npm-repo.1 @@ -1,4 +1,4 @@ -.TH "NPM\-REPO" "1" "November 2019" "" "" +.TH "NPM\-REPO" "1" "December 2019" "" "" .SH "NAME" \fBnpm-repo\fR \- Open package repository page in the browser .SS Synopsis diff --git a/deps/npm/man/man1/npm-restart.1 b/deps/npm/man/man1/npm-restart.1 index 9d566ef0c26ffe..a10b578c2d18c8 100644 --- a/deps/npm/man/man1/npm-restart.1 +++ b/deps/npm/man/man1/npm-restart.1 @@ -1,4 +1,4 @@ -.TH "NPM\-RESTART" "1" "November 2019" "" "" +.TH "NPM\-RESTART" "1" "December 2019" "" "" .SH "NAME" \fBnpm-restart\fR \- Restart a package .SS Synopsis diff --git a/deps/npm/man/man1/npm-root.1 b/deps/npm/man/man1/npm-root.1 index f86181ef7c5635..f670fd7edd226c 100644 --- a/deps/npm/man/man1/npm-root.1 +++ b/deps/npm/man/man1/npm-root.1 @@ -1,4 +1,4 @@ -.TH "NPM\-ROOT" "1" "November 2019" "" "" +.TH "NPM\-ROOT" "1" "December 2019" "" "" .SH "NAME" \fBnpm-root\fR \- Display npm root .SS Synopsis diff --git a/deps/npm/man/man1/npm-run-script.1 b/deps/npm/man/man1/npm-run-script.1 index 22c9f95306a9a9..d618c879456894 100644 --- a/deps/npm/man/man1/npm-run-script.1 +++ b/deps/npm/man/man1/npm-run-script.1 @@ -1,4 +1,4 @@ -.TH "NPM\-RUN\-SCRIPT" "1" "November 2019" "" "" +.TH "NPM\-RUN\-SCRIPT" "1" "December 2019" "" "" .SH "NAME" \fBnpm-run-script\fR \- Run arbitrary package scripts .SS Synopsis diff --git a/deps/npm/man/man1/npm-search.1 b/deps/npm/man/man1/npm-search.1 index b792f39e813ff1..3fc442642c14f0 100644 --- a/deps/npm/man/man1/npm-search.1 +++ b/deps/npm/man/man1/npm-search.1 @@ -1,4 +1,4 @@ -.TH "NPM\-SEARCH" "1" "November 2019" "" "" +.TH "NPM\-SEARCH" "1" "December 2019" "" "" .SH "NAME" \fBnpm-search\fR \- Search for packages .SS Synopsis diff --git a/deps/npm/man/man1/npm-shrinkwrap.1 b/deps/npm/man/man1/npm-shrinkwrap.1 index 33286dc895f391..70e8924d67b5ac 100644 --- a/deps/npm/man/man1/npm-shrinkwrap.1 +++ b/deps/npm/man/man1/npm-shrinkwrap.1 @@ -1,4 +1,4 @@ -.TH "NPM\-SHRINKWRAP" "1" "November 2019" "" "" +.TH "NPM\-SHRINKWRAP" "1" "December 2019" "" "" .SH "NAME" \fBnpm-shrinkwrap\fR \- Lock down dependency versions for publication .SS Synopsis diff --git a/deps/npm/man/man1/npm-star.1 b/deps/npm/man/man1/npm-star.1 index 4ad11a7efbcdf0..e5ba538f9ce361 100644 --- a/deps/npm/man/man1/npm-star.1 +++ b/deps/npm/man/man1/npm-star.1 @@ -1,4 +1,4 @@ -.TH "NPM\-STAR" "1" "November 2019" "" "" +.TH "NPM\-STAR" "1" "December 2019" "" "" .SH "NAME" \fBnpm-star\fR \- Mark your favorite packages .SS Synopsis diff --git a/deps/npm/man/man1/npm-stars.1 b/deps/npm/man/man1/npm-stars.1 index 2c7b6f243098a2..e2d447fee790fe 100644 --- a/deps/npm/man/man1/npm-stars.1 +++ b/deps/npm/man/man1/npm-stars.1 @@ -1,4 +1,4 @@ -.TH "NPM\-STARS" "1" "November 2019" "" "" +.TH "NPM\-STARS" "1" "December 2019" "" "" .SH "NAME" \fBnpm-stars\fR \- View packages marked as favorites .SS Synopsis diff --git a/deps/npm/man/man1/npm-start.1 b/deps/npm/man/man1/npm-start.1 index e83e6800f7d01a..7768a9bc9eea78 100644 --- a/deps/npm/man/man1/npm-start.1 +++ b/deps/npm/man/man1/npm-start.1 @@ -1,4 +1,4 @@ -.TH "NPM\-START" "1" "November 2019" "" "" +.TH "NPM\-START" "1" "December 2019" "" "" .SH "NAME" \fBnpm-start\fR \- Start a package .SS Synopsis diff --git a/deps/npm/man/man1/npm-stop.1 b/deps/npm/man/man1/npm-stop.1 index d3b612b08adffb..d81ba646e033b5 100644 --- a/deps/npm/man/man1/npm-stop.1 +++ b/deps/npm/man/man1/npm-stop.1 @@ -1,4 +1,4 @@ -.TH "NPM\-STOP" "1" "November 2019" "" "" +.TH "NPM\-STOP" "1" "December 2019" "" "" .SH "NAME" \fBnpm-stop\fR \- Stop a package .SS Synopsis diff --git a/deps/npm/man/man1/npm-team.1 b/deps/npm/man/man1/npm-team.1 index ca7f0beb1fafb2..d7194d5c8c2b83 100644 --- a/deps/npm/man/man1/npm-team.1 +++ b/deps/npm/man/man1/npm-team.1 @@ -1,4 +1,4 @@ -.TH "NPM\-TEAM" "1" "November 2019" "" "" +.TH "NPM\-TEAM" "1" "December 2019" "" "" .SH "NAME" \fBnpm-team\fR \- Manage organization teams and team memberships .SS Synopsis diff --git a/deps/npm/man/man1/npm-test.1 b/deps/npm/man/man1/npm-test.1 index bd18fedb505bfd..e68297858b4c4f 100644 --- a/deps/npm/man/man1/npm-test.1 +++ b/deps/npm/man/man1/npm-test.1 @@ -1,4 +1,4 @@ -.TH "NPM\-TEST" "1" "November 2019" "" "" +.TH "NPM\-TEST" "1" "December 2019" "" "" .SH "NAME" \fBnpm-test\fR \- Test a package .SS Synopsis diff --git a/deps/npm/man/man1/npm-uninstall.1 b/deps/npm/man/man1/npm-uninstall.1 index 35523df7a17d5f..7e5a6feab701c1 100644 --- a/deps/npm/man/man1/npm-uninstall.1 +++ b/deps/npm/man/man1/npm-uninstall.1 @@ -1,4 +1,4 @@ -.TH "NPM\-UNINSTALL" "1" "November 2019" "" "" +.TH "NPM\-UNINSTALL" "1" "December 2019" "" "" .SH "NAME" \fBnpm-uninstall\fR \- Remove a package .SS Synopsis diff --git a/deps/npm/man/man1/npm-unpublish.1 b/deps/npm/man/man1/npm-unpublish.1 index f0ce9fa92db2ca..2cfa8071372e95 100644 --- a/deps/npm/man/man1/npm-unpublish.1 +++ b/deps/npm/man/man1/npm-unpublish.1 @@ -1,4 +1,4 @@ -.TH "NPM\-UNPUBLISH" "1" "November 2019" "" "" +.TH "NPM\-UNPUBLISH" "1" "December 2019" "" "" .SH "NAME" \fBnpm-unpublish\fR \- Remove a package from the registry .SS Synopsis diff --git a/deps/npm/man/man1/npm-update.1 b/deps/npm/man/man1/npm-update.1 index 2ebe4a29456c04..dd61226c352498 100644 --- a/deps/npm/man/man1/npm-update.1 +++ b/deps/npm/man/man1/npm-update.1 @@ -1,4 +1,4 @@ -.TH "NPM\-UPDATE" "1" "November 2019" "" "" +.TH "NPM\-UPDATE" "1" "December 2019" "" "" .SH "NAME" \fBnpm-update\fR \- Update a package .SS Synopsis diff --git a/deps/npm/man/man1/npm-version.1 b/deps/npm/man/man1/npm-version.1 index df14c7f67e88fa..f87f182c8d3809 100644 --- a/deps/npm/man/man1/npm-version.1 +++ b/deps/npm/man/man1/npm-version.1 @@ -1,4 +1,4 @@ -.TH "NPM\-VERSION" "1" "November 2019" "" "" +.TH "NPM\-VERSION" "1" "December 2019" "" "" .SH "NAME" \fBnpm-version\fR \- Bump a package version .SS Synopsis diff --git a/deps/npm/man/man1/npm-view.1 b/deps/npm/man/man1/npm-view.1 index 72d41b9cf18d0d..ee47347e5c10ee 100644 --- a/deps/npm/man/man1/npm-view.1 +++ b/deps/npm/man/man1/npm-view.1 @@ -1,4 +1,4 @@ -.TH "NPM\-VIEW" "1" "November 2019" "" "" +.TH "NPM\-VIEW" "1" "December 2019" "" "" .SH "NAME" \fBnpm-view\fR \- View registry info .SS Synopsis diff --git a/deps/npm/man/man1/npm-whoami.1 b/deps/npm/man/man1/npm-whoami.1 index 40c627e8c44f11..4958d4cc2d8fd1 100644 --- a/deps/npm/man/man1/npm-whoami.1 +++ b/deps/npm/man/man1/npm-whoami.1 @@ -1,4 +1,4 @@ -.TH "NPM\-WHOAMI" "1" "November 2019" "" "" +.TH "NPM\-WHOAMI" "1" "December 2019" "" "" .SH "NAME" \fBnpm-whoami\fR \- Display npm username .SS Synopsis diff --git a/deps/npm/man/man1/npm.1 b/deps/npm/man/man1/npm.1 index 6ef81e031837b0..44859cc22e3123 100644 --- a/deps/npm/man/man1/npm.1 +++ b/deps/npm/man/man1/npm.1 @@ -1,4 +1,4 @@ -.TH "NPM" "1" "November 2019" "" "" +.TH "NPM" "1" "December 2019" "" "" .SH "NAME" \fBnpm\fR \- javascript package manager .SS Synopsis @@ -10,7 +10,7 @@ npm [args] .RE .SS Version .P -6\.13\.1 +6\.13\.4 .SS Description .P npm is the package manager for the Node JavaScript platform\. It puts diff --git a/deps/npm/man/man5/install.5 b/deps/npm/man/man5/install.5 index d14b649fe75e72..f01da284796b41 100644 --- a/deps/npm/man/man5/install.5 +++ b/deps/npm/man/man5/install.5 @@ -1,4 +1,4 @@ -.TH "INSTALL" "5" "November 2019" "" "" +.TH "INSTALL" "5" "December 2019" "" "" .SH "NAME" \fBinstall\fR \- Download and Install npm .SS Description diff --git a/deps/npm/man/man5/npmrc.5 b/deps/npm/man/man5/npmrc.5 index d11cb449c019ef..73a298cf626343 100644 --- a/deps/npm/man/man5/npmrc.5 +++ b/deps/npm/man/man5/npmrc.5 @@ -1,4 +1,4 @@ -.TH "NPMRC" "5" "November 2019" "" "" +.TH "NPMRC" "5" "December 2019" "" "" .SH "NAME" \fBnpmrc\fR \- The npm config files .SS Description diff --git a/deps/npm/man/man5/package-json.5 b/deps/npm/man/man5/package-json.5 index 01350c641035e1..c278ee7acfc99c 100644 --- a/deps/npm/man/man5/package-json.5 +++ b/deps/npm/man/man5/package-json.5 @@ -1,4 +1,4 @@ -.TH "PACKAGE\.JSON" "5" "November 2019" "" "" +.TH "PACKAGE\.JSON" "5" "December 2019" "" "" .SH "NAME" \fBpackage.json\fR \- Specifics of npm's package\.json handling .SS Description diff --git a/deps/npm/man/man5/package-lock-json.5 b/deps/npm/man/man5/package-lock-json.5 index 36dbbc402341d5..5f190bf08c852d 100644 --- a/deps/npm/man/man5/package-lock-json.5 +++ b/deps/npm/man/man5/package-lock-json.5 @@ -1,4 +1,4 @@ -.TH "PACKAGE\-LOCK\.JSON" "5" "November 2019" "" "" +.TH "PACKAGE\-LOCK\.JSON" "5" "December 2019" "" "" .SH "NAME" \fBpackage-lock.json\fR \- A manifestation of the manifest .SS Description diff --git a/deps/npm/man/man5/package-locks.5 b/deps/npm/man/man5/package-locks.5 index ea2e51fc69714c..0c8af6163305a9 100644 --- a/deps/npm/man/man5/package-locks.5 +++ b/deps/npm/man/man5/package-locks.5 @@ -1,4 +1,4 @@ -.TH "PACKAGE\-LOCKS" "5" "November 2019" "" "" +.TH "PACKAGE\-LOCKS" "5" "December 2019" "" "" .SH "NAME" \fBpackage-locks\fR \- An explanation of npm lockfiles .SS Description diff --git a/deps/npm/man/man5/shrinkwrap-json.5 b/deps/npm/man/man5/shrinkwrap-json.5 index 5c1e05f8b7816d..22b517dbbbaf41 100644 --- a/deps/npm/man/man5/shrinkwrap-json.5 +++ b/deps/npm/man/man5/shrinkwrap-json.5 @@ -1,4 +1,4 @@ -.TH "NPM\-SHRINKWRAP\.JSON" "5" "November 2019" "" "" +.TH "NPM\-SHRINKWRAP\.JSON" "5" "December 2019" "" "" .SH "NAME" \fBnpm-shrinkwrap.json\fR \- A publishable lockfile .SS Description diff --git a/deps/npm/man/man7/developers.7 b/deps/npm/man/man7/developers.7 index 2f24215d26b19f..60fe6234cffd09 100644 --- a/deps/npm/man/man7/developers.7 +++ b/deps/npm/man/man7/developers.7 @@ -1,4 +1,4 @@ -.TH "DEVELOPERS" "7" "November 2019" "" "" +.TH "DEVELOPERS" "7" "December 2019" "" "" .SH "NAME" \fBdevelopers\fR \- Developer Guide .SS Description diff --git a/deps/npm/man/man7/disputes.7 b/deps/npm/man/man7/disputes.7 index c815d206351fbd..53cf2464a9ea8c 100644 --- a/deps/npm/man/man7/disputes.7 +++ b/deps/npm/man/man7/disputes.7 @@ -1,4 +1,4 @@ -.TH "DISPUTES" "7" "November 2019" "" "" +.TH "DISPUTES" "7" "December 2019" "" "" .SH "NAME" \fBdisputes\fR \- Handling Module Name Disputes .P diff --git a/deps/npm/man/man7/orgs.7 b/deps/npm/man/man7/orgs.7 index 2c52a2db466960..bd3adcaa5eca12 100644 --- a/deps/npm/man/man7/orgs.7 +++ b/deps/npm/man/man7/orgs.7 @@ -1,4 +1,4 @@ -.TH "ORGS" "7" "November 2019" "" "" +.TH "ORGS" "7" "December 2019" "" "" .SH "NAME" \fBorgs\fR \- Working with Teams & Orgs .SS Description diff --git a/deps/npm/man/man7/registry.7 b/deps/npm/man/man7/registry.7 index bbb5e802bfb826..c21d6d6e617817 100644 --- a/deps/npm/man/man7/registry.7 +++ b/deps/npm/man/man7/registry.7 @@ -1,4 +1,4 @@ -.TH "REGISTRY" "7" "November 2019" "" "" +.TH "REGISTRY" "7" "December 2019" "" "" .SH "NAME" \fBregistry\fR \- The JavaScript Package Registry .SS Description diff --git a/deps/npm/man/man7/removal.7 b/deps/npm/man/man7/removal.7 index a4df8b446127b2..0a08017f0dcd2b 100644 --- a/deps/npm/man/man7/removal.7 +++ b/deps/npm/man/man7/removal.7 @@ -1,4 +1,4 @@ -.TH "REMOVAL" "7" "November 2019" "" "" +.TH "REMOVAL" "7" "December 2019" "" "" .SH "NAME" \fBremoval\fR \- Cleaning the Slate .SS Synopsis diff --git a/deps/npm/man/man7/scope.7 b/deps/npm/man/man7/scope.7 index ffe5570ae87b33..933e2e23c77430 100644 --- a/deps/npm/man/man7/scope.7 +++ b/deps/npm/man/man7/scope.7 @@ -1,4 +1,4 @@ -.TH "SCOPE" "7" "November 2019" "" "" +.TH "SCOPE" "7" "December 2019" "" "" .SH "NAME" \fBscope\fR \- Scoped packages .SS Description diff --git a/deps/npm/man/man7/scripts.7 b/deps/npm/man/man7/scripts.7 index 7517c5997585fd..a6756a376c59bd 100644 --- a/deps/npm/man/man7/scripts.7 +++ b/deps/npm/man/man7/scripts.7 @@ -1,4 +1,4 @@ -.TH "SCRIPTS" "7" "November 2019" "" "" +.TH "SCRIPTS" "7" "December 2019" "" "" .SH "NAME" \fBscripts\fR \- How npm handles the "scripts" field .SS Description diff --git a/deps/npm/man/man7/semver.7 b/deps/npm/man/man7/semver.7 index b65c475f6eb67e..23d513d4238b28 100644 --- a/deps/npm/man/man7/semver.7 +++ b/deps/npm/man/man7/semver.7 @@ -1,4 +1,4 @@ -.TH "SEMVER" "7" "November 2019" "" "" +.TH "SEMVER" "7" "December 2019" "" "" .SH "NAME" \fBsemver\fR \- The semantic versioner for npm .SH Install diff --git a/deps/npm/node_modules/bin-links/CHANGELOG.md b/deps/npm/node_modules/bin-links/CHANGELOG.md index e5293027887bb3..697e3c53559b40 100644 --- a/deps/npm/node_modules/bin-links/CHANGELOG.md +++ b/deps/npm/node_modules/bin-links/CHANGELOG.md @@ -2,6 +2,36 @@ All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines. + +## [1.1.6](https://github.com/npm/bin-links/compare/v1.1.5...v1.1.6) (2019-12-11) + + +### Bug Fixes + +* prevent improper clobbering of man/bin links ([642cd18](https://github.com/npm/bin-links/commit/642cd18)), closes [#11](https://github.com/npm/bin-links/issues/11) [#12](https://github.com/npm/bin-links/issues/12) + + + + +## [1.1.5](https://github.com/npm/bin-links/compare/v1.1.4...v1.1.5) (2019-12-10) + + +### Bug Fixes + +* don't filter out ./ man references ([b3cfd2e](https://github.com/npm/bin-links/commit/b3cfd2e)) + + + + +## [1.1.4](https://github.com/npm/bin-links/compare/v1.1.3...v1.1.4) (2019-12-09) + + +### Bug Fixes + +* sanitize and validate bin and man link targets ([25a34f9](https://github.com/npm/bin-links/commit/25a34f9)) + + + ## [1.1.3](https://github.com/npm/bin-links/compare/v1.1.2...v1.1.3) (2019-08-14) diff --git a/deps/npm/node_modules/bin-links/index.js b/deps/npm/node_modules/bin-links/index.js index 5f867554752231..4f6d3c055c02ee 100644 --- a/deps/npm/node_modules/bin-links/index.js +++ b/deps/npm/node_modules/bin-links/index.js @@ -3,18 +3,22 @@ const path = require('path') const fs = require('graceful-fs') const BB = require('bluebird') -const linkIfExists = BB.promisify(require('gentle-fs').linkIfExists) -const cmdShimIfExists = BB.promisify(require('cmd-shim').ifExists) +const gentleFs = require('gentle-fs') +const linkIfExists = BB.promisify(gentleFs.linkIfExists) +const gentleFsBinLink = BB.promisify(gentleFs.binLink) const open = BB.promisify(fs.open) const close = BB.promisify(fs.close) const read = BB.promisify(fs.read, {multiArgs: true}) const chmod = BB.promisify(fs.chmod) const readFile = BB.promisify(fs.readFile) const writeFileAtomic = BB.promisify(require('write-file-atomic')) +const normalize = require('npm-normalize-package-bin') module.exports = BB.promisify(binLinks) function binLinks (pkg, folder, global, opts, cb) { + pkg = normalize(pkg) + // if it's global, and folder is in {prefix}/node_modules, // then bins are in {prefix}/bin // otherwise, then bins are in folder/../.bin @@ -39,9 +43,9 @@ function isHashbangFile (file) { return read(fileHandle, Buffer.alloc(2), 0, 2, 0).spread((_, buf) => { if (!hasHashbang(buf)) return [] return read(fileHandle, Buffer.alloc(2048), 0, 2048, 0) - }).spread((_, buf) => buf && hasCR(buf), () => false) + }).spread((_, buf) => buf && hasCR(buf), /* istanbul ignore next */ () => false) .finally(() => close(fileHandle)) - }).catch(() => false) + }).catch(/* istanbul ignore next */ () => false) } function hasHashbang (buf) { @@ -77,6 +81,12 @@ function linkBins (pkg, folder, parent, gtop, opts) { var dest = path.resolve(binRoot, bin) var src = path.resolve(folder, pkg.bin[bin]) + /* istanbul ignore if - that unpossible */ + if (src.indexOf(folder) !== 0) { + throw new Error('invalid bin entry for package ' + + pkg._id + '. key=' + bin + ', value=' + pkg.bin[bin]) + } + return linkBin(src, dest, linkOpts).then(() => { // bins should always be executable. // XXX skip chmod on windows? @@ -100,6 +110,7 @@ function linkBins (pkg, folder, parent, gtop, opts) { opts.log.showProgress() } }).catch(err => { + /* istanbul ignore next */ if (err.code === 'ENOENT' && opts.ignoreScripts) return throw err }) @@ -107,11 +118,11 @@ function linkBins (pkg, folder, parent, gtop, opts) { } function linkBin (from, to, opts) { - if (process.platform !== 'win32') { - return linkIfExists(from, to, opts) - } else { - return cmdShimIfExists(from, to) + // do not clobber global bins + if (opts.globalBin && to.indexOf(opts.globalBin) === 0) { + opts.clobberLinkGently = true } + return gentleFsBinLink(from, to, opts) } function linkMans (pkg, folder, parent, gtop, opts) { @@ -123,15 +134,22 @@ function linkMans (pkg, folder, parent, gtop, opts) { // make sure that the mans are unique. // otherwise, if there are dupes, it'll fail with EEXIST var set = pkg.man.reduce(function (acc, man) { - acc[path.basename(man)] = man + if (typeof man !== 'string') { + return acc + } + const cleanMan = path.join('/', man).replace(/\\|:/g, '/').substr(1) + acc[path.basename(man)] = cleanMan return acc }, {}) var manpages = pkg.man.filter(function (man) { - return set[path.basename(man)] === man + if (typeof man !== 'string') { + return false + } + const cleanMan = path.join('/', man).replace(/\\|:/g, '/').substr(1) + return set[path.basename(man)] === cleanMan }) return BB.map(manpages, man => { - if (typeof man !== 'string') return opts.log.silly('linkMans', 'preparing to link', man) var parseMan = man.match(/(.*\.([0-9]+)(\.gz)?)$/) if (!parseMan) { @@ -146,8 +164,19 @@ function linkMans (pkg, folder, parent, gtop, opts) { var sxn = parseMan[2] var bn = path.basename(stem) var manSrc = path.resolve(folder, man) + /* istanbul ignore if - that unpossible */ + if (manSrc.indexOf(folder) !== 0) { + throw new Error('invalid man entry for package ' + + pkg._id + '. man=' + manSrc) + } + var manDest = path.join(manRoot, 'man' + sxn, bn) + // man pages should always be clobbering gently, because they are + // only installed for top-level global packages, so never destroy + // a link if it doesn't point into the folder we're linking + opts.clobberLinkGently = true + return linkIfExists(manSrc, manDest, getLinkOpts(opts, gtop && folder)) }) } diff --git a/deps/npm/node_modules/bin-links/package.json b/deps/npm/node_modules/bin-links/package.json index e14be1e6926dfa..a4d2c02226e5f1 100644 --- a/deps/npm/node_modules/bin-links/package.json +++ b/deps/npm/node_modules/bin-links/package.json @@ -1,19 +1,19 @@ { - "_from": "bin-links@1.1.3", - "_id": "bin-links@1.1.3", + "_from": "bin-links@1.1.6", + "_id": "bin-links@1.1.6", "_inBundle": false, - "_integrity": "sha512-TEwmH4PHU/D009stP+fkkazMJgkBNCv60z01lQ/Mn8E6+ThHoD03svMnBVuCowwXo2nP2qKyKZxKxp58OHRzxw==", + "_integrity": "sha512-b5rV3uVyrlrJWLI3mawUUf5t2f9mCEQm/TqT5zNj6DPYhYDZaNp0AYaYd/CVASkSEklayNDLliZHVdo2J3niPw==", "_location": "/bin-links", "_phantomChildren": {}, "_requested": { "type": "version", "registry": true, - "raw": "bin-links@1.1.3", + "raw": "bin-links@1.1.6", "name": "bin-links", "escapedName": "bin-links", - "rawSpec": "1.1.3", + "rawSpec": "1.1.6", "saveSpec": null, - "fetchSpec": "1.1.3" + "fetchSpec": "1.1.6" }, "_requiredBy": [ "#USER", @@ -21,9 +21,9 @@ "/libcipm", "/libnpm" ], - "_resolved": "https://registry.npmjs.org/bin-links/-/bin-links-1.1.3.tgz", - "_shasum": "702fd59552703727313bc624bdbc4c0d3431c2ca", - "_spec": "bin-links@1.1.3", + "_resolved": "https://registry.npmjs.org/bin-links/-/bin-links-1.1.6.tgz", + "_shasum": "30d33e810829305e5e61b90cfcb9a3a4f65eb516", + "_spec": "bin-links@1.1.6", "_where": "/Users/isaacs/dev/npm/cli", "author": { "name": "Mike Sherov" @@ -35,8 +35,9 @@ "dependencies": { "bluebird": "^3.5.3", "cmd-shim": "^3.0.0", - "gentle-fs": "^2.0.1", + "gentle-fs": "^2.3.0", "graceful-fs": "^4.1.15", + "npm-normalize-package-bin": "^1.0.0", "write-file-atomic": "^2.3.0" }, "deprecated": false, @@ -69,12 +70,12 @@ }, "scripts": { "postrelease": "npm publish && git push --follow-tags", + "posttest": "standard", "prerelease": "npm t", - "pretest": "standard", "release": "standard-version -s", - "test": "tap -J --nyc-arg=--all --coverage test/*.js", + "test": "tap -J --nyc-arg=--all --coverage test/*.js --100", "update-coc": "weallbehave -o . && git add CODE_OF_CONDUCT.md && git commit -m 'docs(coc): updated CODE_OF_CONDUCT.md'", "update-contrib": "weallcontribute -o . && git add CONTRIBUTING.md && git commit -m 'docs(contributing): updated CONTRIBUTING.md'" }, - "version": "1.1.3" + "version": "1.1.6" } diff --git a/deps/npm/node_modules/gentle-fs/CHANGELOG.md b/deps/npm/node_modules/gentle-fs/CHANGELOG.md index 38fc91cba587d9..50dfcd74c99f1c 100644 --- a/deps/npm/node_modules/gentle-fs/CHANGELOG.md +++ b/deps/npm/node_modules/gentle-fs/CHANGELOG.md @@ -2,6 +2,16 @@ All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines. + +# [2.3.0](https://github.com/npm/gentle-fs/compare/v2.2.1...v2.3.0) (2019-12-11) + + +### Features + +* add option to gently create bin links/shims ([a929196](https://github.com/npm/gentle-fs/commit/a929196)) + + + ## [2.2.1](https://github.com/npm/gentle-fs/compare/v2.2.0...v2.2.1) (2019-08-15) diff --git a/deps/npm/node_modules/gentle-fs/index.js b/deps/npm/node_modules/gentle-fs/index.js index 9807ed9d8580be..4aeda1c846bf2b 100644 --- a/deps/npm/node_modules/gentle-fs/index.js +++ b/deps/npm/node_modules/gentle-fs/index.js @@ -3,10 +3,12 @@ const rm = require('./lib/rm.js') const link = require('./lib/link.js') const mkdir = require('./lib/mkdir.js') +const binLink = require('./lib/bin-link.js') exports = module.exports = { rm: rm, link: link.link, linkIfExists: link.linkIfExists, - mkdir: mkdir + mkdir: mkdir, + binLink: binLink } diff --git a/deps/npm/node_modules/gentle-fs/lib/bin-link.js b/deps/npm/node_modules/gentle-fs/lib/bin-link.js new file mode 100644 index 00000000000000..104c5b6c935c88 --- /dev/null +++ b/deps/npm/node_modules/gentle-fs/lib/bin-link.js @@ -0,0 +1,96 @@ +'use strict' +// calls linkIfExists on unix, or cmdShimIfExists on Windows +// reads the cmd shim to ensure it's where we need it to be in the case of +// top level global packages + +const readCmdShim = require('read-cmd-shim') +const cmdShim = require('cmd-shim') +const {linkIfExists} = require('./link.js') + +const binLink = (from, to, opts, cb) => { + // just for testing + const platform = opts._FAKE_PLATFORM_ || process.platform + if (platform !== 'win32') { + return linkIfExists(from, to, opts, cb) + } + + if (!opts.clobberLinkGently || + opts.force === true || + !opts.gently || + typeof opts.gently !== 'string') { + // easy, just go ahead and delete anything in the way + return cmdShim.ifExists(from, to, cb) + } + + // read all three shim targets + // if any exist, and are not a shim to our gently folder, then + // exit with a simulated EEXIST error. + + const shimFiles = [ + to, + to + '.cmd', + to + '.ps1' + ] + + // call this once we've checked all three, if we're good + const done = () => cmdShim.ifExists(from, to, cb) + const then = times(3, done, cb) + shimFiles.forEach(to => isClobberable(from, to, opts, then)) +} + +const times = (n, ok, cb) => { + let errState = null + return er => { + if (!errState) { + if (er) { + cb(errState = er) + } else if (--n === 0) { + ok() + } + } + } +} + +const isClobberable = (from, to, opts, cb) => { + readCmdShim(to, (er, target) => { + // either going to get an error, or the target of where this + // cmd shim points. + // shim, not in opts.gently: simulate EEXIST + // not a shim: simulate EEXIST + // ENOENT: fine, move forward + // shim in opts.gently: fine + if (er) { + switch (er.code) { + case 'ENOENT': + // totally fine, nothing there to clobber + return cb() + case 'ENOTASHIM': + // something is there, and it's not one of ours + return cb(simulateEEXIST(from, to)) + default: + // would probably fail this way later anyway + // can't read the file, likely can't write it either + return cb(er) + } + } + // no error, check the target + if (target.indexOf(opts.gently) !== 0) { + return cb(simulateEEXIST(from, to)) + } + // ok! it's one of ours. + return cb() + }) +} + +const simulateEEXIST = (from, to) => { + // simulate the EEXIST we'd get from fs.symlink to the file + const err = new Error('EEXIST: file already exists, cmd shim \'' + + from + '\' -> \'' + to + '\'') + + err.code = 'EEXIST' + err.path = from + err.dest = to + return err +} + +module.exports = binLink diff --git a/deps/npm/node_modules/gentle-fs/lib/link.js b/deps/npm/node_modules/gentle-fs/lib/link.js index 4623e7e82cf882..7cdfef4ca95d39 100644 --- a/deps/npm/node_modules/gentle-fs/lib/link.js +++ b/deps/npm/node_modules/gentle-fs/lib/link.js @@ -14,15 +14,22 @@ exports = module.exports = { } function linkIfExists (from, to, opts, cb) { + opts.currentIsLink = false + opts.currentExists = false fs.stat(from, function (er) { if (er) return cb() fs.readlink(to, function (er, fromOnDisk) { + if (!er || er.code !== 'ENOENT') { + opts.currentExists = true + } // if the link already exists and matches what we would do, // we don't need to do anything if (!er) { + opts.currentIsLink = true var toDir = path.dirname(to) var absoluteFrom = path.resolve(toDir, from) var absoluteFromOnDisk = path.resolve(toDir, fromOnDisk) + opts.currentTarget = absoluteFromOnDisk if (absoluteFrom === absoluteFromOnDisk) return cb() } link(from, to, opts, cb) @@ -58,7 +65,7 @@ function link (from, to, opts, cb) { const tasks = [ [ensureFromIsNotSource, absTarget, to], [fs, 'stat', absTarget], - [rm, to, opts], + [clobberLinkGently, from, to, opts], [mkdir, path.dirname(to)], [fs, 'symlink', target, to, 'junction'] ] @@ -72,3 +79,48 @@ function link (from, to, opts, cb) { }) } } + +exports._clobberLinkGently = clobberLinkGently +function clobberLinkGently (from, to, opts, cb) { + if (opts.currentExists === false) { + // nothing to clobber! + opts.log.silly('gently link', 'link does not already exist', { + link: to, + target: from + }) + return cb() + } + + if (!opts.clobberLinkGently || + opts.force === true || + !opts.gently || + typeof opts.gently !== 'string') { + opts.log.silly('gently link', 'deleting existing link forcefully', { + link: to, + target: from, + force: opts.force, + gently: opts.gently, + clobberLinkGently: opts.clobberLinkGently + }) + return rm(to, opts, cb) + } + + if (!opts.currentIsLink) { + opts.log.verbose('gently link', 'cannot remove, not a link', to) + // don't delete. it'll fail with EEXIST when it tries to symlink. + return cb() + } + + if (opts.currentTarget.indexOf(opts.gently) === 0) { + opts.log.silly('gently link', 'delete existing link', to) + return rm(to, opts, cb) + } else { + opts.log.verbose('gently link', 'refusing to delete existing link', { + link: to, + currentTarget: opts.currentTarget, + newTarget: from, + gently: opts.gently + }) + return cb() + } +} diff --git a/deps/npm/node_modules/gentle-fs/package.json b/deps/npm/node_modules/gentle-fs/package.json index bf4867c08d328a..d162899757b0f7 100644 --- a/deps/npm/node_modules/gentle-fs/package.json +++ b/deps/npm/node_modules/gentle-fs/package.json @@ -1,28 +1,28 @@ { - "_from": "gentle-fs@2.2.1", - "_id": "gentle-fs@2.2.1", + "_from": "gentle-fs@2.3.0", + "_id": "gentle-fs@2.3.0", "_inBundle": false, - "_integrity": "sha512-e7dRgUM5fsS+7wm2oggZpgcRx6sEvJHXujPH5RzgQ1ziQY4+HuVBYsnUzJwJ+C7mjOJN27DjiFy1TaL+TNltow==", + "_integrity": "sha512-3k2CgAmPxuz7S6nKK+AqFE2AdM1QuwqKLPKzIET3VRwK++3q96MsNFobScDjlCrq97ZJ8y5R725MOlm6ffUCjg==", "_location": "/gentle-fs", "_phantomChildren": {}, "_requested": { "type": "version", "registry": true, - "raw": "gentle-fs@2.2.1", + "raw": "gentle-fs@2.3.0", "name": "gentle-fs", "escapedName": "gentle-fs", - "rawSpec": "2.2.1", + "rawSpec": "2.3.0", "saveSpec": null, - "fetchSpec": "2.2.1" + "fetchSpec": "2.3.0" }, "_requiredBy": [ "#USER", "/", "/bin-links" ], - "_resolved": "https://registry.npmjs.org/gentle-fs/-/gentle-fs-2.2.1.tgz", - "_shasum": "1f38df4b4ead685566257201fd526de401ebb215", - "_spec": "gentle-fs@2.2.1", + "_resolved": "https://registry.npmjs.org/gentle-fs/-/gentle-fs-2.3.0.tgz", + "_shasum": "13538db5029400f98684be4894e8a7d8f0d1ea7f", + "_spec": "gentle-fs@2.3.0", "_where": "/Users/isaacs/dev/npm/cli", "author": { "name": "Mike Sherov" @@ -34,6 +34,7 @@ "dependencies": { "aproba": "^1.1.2", "chownr": "^1.1.2", + "cmd-shim": "^3.0.3", "fs-vacuum": "^1.2.10", "graceful-fs": "^4.1.11", "iferr": "^0.1.5", @@ -74,12 +75,12 @@ }, "scripts": { "postrelease": "npm publish && git push --follow-tags", + "posttest": "standard", "prerelease": "npm t", - "pretest": "standard", "release": "standard-version -s", - "test": "tap -J --nyc-arg=--all --coverage test/*.js test/**/*.js", + "test": "tap -J --nyc-arg=--all --coverage test", "update-coc": "weallbehave -o . && git add CODE_OF_CONDUCT.md && git commit -m 'docs(coc): updated CODE_OF_CONDUCT.md'", "update-contrib": "weallcontribute -o . && git add CONTRIBUTING.md && git commit -m 'docs(contributing): updated CONTRIBUTING.md'" }, - "version": "2.2.1" + "version": "2.3.0" } diff --git a/deps/npm/node_modules/json-schema/README.md b/deps/npm/node_modules/json-schema/README.md index 4de0124476e98c..78b81d39683251 100644 --- a/deps/npm/node_modules/json-schema/README.md +++ b/deps/npm/node_modules/json-schema/README.md @@ -1,5 +1,5 @@ JSON Schema is a repository for the JSON Schema specification, reference schemas and a CommonJS implementation of JSON Schema (not the only JavaScript implementation of JSON Schema, JSV is another excellent JavaScript validator). -Code is licensed under the AFL or BSD license as part of the Persevere +Code is licensed under the AFL or BSD license as part of the Persevere project which is administered under the Dojo foundation, and all contributions require a Dojo CLA. \ No newline at end of file diff --git a/deps/npm/node_modules/json-schema/draft-00/hyper-schema b/deps/npm/node_modules/json-schema/draft-00/hyper-schema index de80b918b671c7..36a85ccd244926 100644 --- a/deps/npm/node_modules/json-schema/draft-00/hyper-schema +++ b/deps/npm/node_modules/json-schema/draft-00/hyper-schema @@ -8,61 +8,61 @@ "items" : {"$ref" : "http://json-schema.org/draft-00/links#"}, "optional" : true }, - + "fragmentResolution" : { "type" : "string", "optional" : true, "default" : "dot-delimited" }, - + "root" : { "type" : "boolean", "optional" : true, "default" : false }, - + "readonly" : { "type" : "boolean", "optional" : true, "default" : false }, - + "pathStart" : { "type" : "string", "optional" : true, "format" : "uri" }, - + "mediaType" : { "type" : "string", "optional" : true, "format" : "media-type" }, - + "alternate" : { "type" : "array", "items" : {"$ref" : "#"}, "optional" : true } }, - + "links" : [ { "href" : "{$ref}", "rel" : "full" }, - + { "href" : "{$schema}", "rel" : "describedby" }, - + { "href" : "{id}", "rel" : "self" } ], - + "fragmentResolution" : "dot-delimited", "extends" : {"$ref" : "http://json-schema.org/draft-00/schema#"} } \ No newline at end of file diff --git a/deps/npm/node_modules/json-schema/draft-00/json-ref b/deps/npm/node_modules/json-schema/draft-00/json-ref index 3a872a71c973dc..5d1f76b6a694a4 100644 --- a/deps/npm/node_modules/json-schema/draft-00/json-ref +++ b/deps/npm/node_modules/json-schema/draft-00/json-ref @@ -1,26 +1,26 @@ { "$schema" : "http://json-schema.org/draft-00/hyper-schema#", "id" : "http://json-schema.org/draft-00/json-ref#", - + "items" : {"$ref" : "#"}, "additionalProperties" : {"$ref" : "#"}, - + "links" : [ { "href" : "{$ref}", "rel" : "full" }, - + { "href" : "{$schema}", "rel" : "describedby" }, - + { "href" : "{id}", "rel" : "self" } ], - + "fragmentResolution" : "dot-delimited" } \ No newline at end of file diff --git a/deps/npm/node_modules/json-schema/draft-00/links b/deps/npm/node_modules/json-schema/draft-00/links index 8a5e7807250cf9..cbef326dd3de5b 100644 --- a/deps/npm/node_modules/json-schema/draft-00/links +++ b/deps/npm/node_modules/json-schema/draft-00/links @@ -2,28 +2,28 @@ "$schema" : "http://json-schema.org/draft-00/hyper-schema#", "id" : "http://json-schema.org/draft-00/links#", "type" : "object", - + "properties" : { "href" : { "type" : "string" }, - + "rel" : { "type" : "string" }, - + "method" : { "type" : "string", "default" : "GET", "optional" : true }, - + "enctype" : { "type" : "string", "requires" : "method", "optional" : true }, - + "properties" : { "type" : "object", "additionalProperties" : {"$ref" : "http://json-schema.org/draft-00/hyper-schema#"}, diff --git a/deps/npm/node_modules/json-schema/draft-00/schema b/deps/npm/node_modules/json-schema/draft-00/schema index 9aa2fbc57a4054..d452b023ee484a 100644 --- a/deps/npm/node_modules/json-schema/draft-00/schema +++ b/deps/npm/node_modules/json-schema/draft-00/schema @@ -2,7 +2,7 @@ "$schema" : "http://json-schema.org/draft-00/hyper-schema#", "id" : "http://json-schema.org/draft-00/schema#", "type" : "object", - + "properties" : { "type" : { "type" : ["string", "array"], @@ -12,136 +12,136 @@ "optional" : true, "default" : "any" }, - + "properties" : { "type" : "object", "additionalProperties" : {"$ref" : "#"}, "optional" : true, "default" : {} }, - + "items" : { "type" : [{"$ref" : "#"}, "array"], "items" : {"$ref" : "#"}, "optional" : true, "default" : {} }, - + "optional" : { "type" : "boolean", "optional" : true, "default" : false }, - + "additionalProperties" : { "type" : [{"$ref" : "#"}, "boolean"], "optional" : true, "default" : {} }, - + "requires" : { "type" : ["string", {"$ref" : "#"}], "optional" : true }, - + "minimum" : { "type" : "number", "optional" : true }, - + "maximum" : { "type" : "number", "optional" : true }, - + "minimumCanEqual" : { "type" : "boolean", "optional" : true, "requires" : "minimum", "default" : true }, - + "maximumCanEqual" : { "type" : "boolean", "optional" : true, "requires" : "maximum", "default" : true }, - + "minItems" : { "type" : "integer", "optional" : true, "minimum" : 0, "default" : 0 }, - + "maxItems" : { "type" : "integer", "optional" : true, "minimum" : 0 }, - + "pattern" : { "type" : "string", "optional" : true, "format" : "regex" }, - + "minLength" : { "type" : "integer", "optional" : true, "minimum" : 0, "default" : 0 }, - + "maxLength" : { "type" : "integer", "optional" : true }, - + "enum" : { "type" : "array", "optional" : true, "minItems" : 1 }, - + "title" : { "type" : "string", "optional" : true }, - + "description" : { "type" : "string", "optional" : true }, - + "format" : { "type" : "string", "optional" : true }, - + "contentEncoding" : { "type" : "string", "optional" : true }, - + "default" : { "type" : "any", "optional" : true }, - + "maxDecimal" : { "type" : "integer", "optional" : true, "minimum" : 0 }, - + "disallow" : { "type" : ["string", "array"], "items" : {"type" : "string"}, "optional" : true }, - + "extends" : { "type" : [{"$ref" : "#"}, "array"], "items" : {"$ref" : "#"}, @@ -149,7 +149,7 @@ "default" : {} } }, - + "optional" : true, "default" : {} } \ No newline at end of file diff --git a/deps/npm/node_modules/json-schema/draft-01/hyper-schema b/deps/npm/node_modules/json-schema/draft-01/hyper-schema index 3f6c6cc2c012df..b0fb5e157ef9bd 100644 --- a/deps/npm/node_modules/json-schema/draft-01/hyper-schema +++ b/deps/npm/node_modules/json-schema/draft-01/hyper-schema @@ -8,61 +8,61 @@ "items" : {"$ref" : "http://json-schema.org/draft-01/links#"}, "optional" : true }, - + "fragmentResolution" : { "type" : "string", "optional" : true, "default" : "dot-delimited" }, - + "root" : { "type" : "boolean", "optional" : true, "default" : false }, - + "readonly" : { "type" : "boolean", "optional" : true, "default" : false }, - + "pathStart" : { "type" : "string", "optional" : true, "format" : "uri" }, - + "mediaType" : { "type" : "string", "optional" : true, "format" : "media-type" }, - + "alternate" : { "type" : "array", "items" : {"$ref" : "#"}, "optional" : true } }, - + "links" : [ { "href" : "{$ref}", "rel" : "full" }, - + { "href" : "{$schema}", "rel" : "describedby" }, - + { "href" : "{id}", "rel" : "self" } ], - + "fragmentResolution" : "dot-delimited", "extends" : {"$ref" : "http://json-schema.org/draft-01/schema#"} } \ No newline at end of file diff --git a/deps/npm/node_modules/json-schema/draft-01/json-ref b/deps/npm/node_modules/json-schema/draft-01/json-ref index 4d26174ef17ad9..cbac1ba2e53286 100644 --- a/deps/npm/node_modules/json-schema/draft-01/json-ref +++ b/deps/npm/node_modules/json-schema/draft-01/json-ref @@ -1,26 +1,26 @@ { "$schema" : "http://json-schema.org/draft-01/hyper-schema#", "id" : "http://json-schema.org/draft-01/json-ref#", - + "items" : {"$ref" : "#"}, "additionalProperties" : {"$ref" : "#"}, - + "links" : [ { "href" : "{$ref}", "rel" : "full" }, - + { "href" : "{$schema}", "rel" : "describedby" }, - + { "href" : "{id}", "rel" : "self" } ], - + "fragmentResolution" : "dot-delimited" } \ No newline at end of file diff --git a/deps/npm/node_modules/json-schema/draft-01/links b/deps/npm/node_modules/json-schema/draft-01/links index 52430a5d94ac75..ebc7b7b58b1326 100644 --- a/deps/npm/node_modules/json-schema/draft-01/links +++ b/deps/npm/node_modules/json-schema/draft-01/links @@ -2,28 +2,28 @@ "$schema" : "http://json-schema.org/draft-01/hyper-schema#", "id" : "http://json-schema.org/draft-01/links#", "type" : "object", - + "properties" : { "href" : { "type" : "string" }, - + "rel" : { "type" : "string" }, - + "method" : { "type" : "string", "default" : "GET", "optional" : true }, - + "enctype" : { "type" : "string", "requires" : "method", "optional" : true }, - + "properties" : { "type" : "object", "additionalProperties" : {"$ref" : "http://json-schema.org/draft-01/hyper-schema#"}, diff --git a/deps/npm/node_modules/json-schema/draft-01/schema b/deps/npm/node_modules/json-schema/draft-01/schema index 7a208e680e631b..a0f3801f840cca 100644 --- a/deps/npm/node_modules/json-schema/draft-01/schema +++ b/deps/npm/node_modules/json-schema/draft-01/schema @@ -2,7 +2,7 @@ "$schema" : "http://json-schema.org/draft-01/hyper-schema#", "id" : "http://json-schema.org/draft-01/schema#", "type" : "object", - + "properties" : { "type" : { "type" : ["string", "array"], @@ -12,136 +12,136 @@ "optional" : true, "default" : "any" }, - + "properties" : { "type" : "object", "additionalProperties" : {"$ref" : "#"}, "optional" : true, "default" : {} }, - + "items" : { "type" : [{"$ref" : "#"}, "array"], "items" : {"$ref" : "#"}, "optional" : true, "default" : {} }, - + "optional" : { "type" : "boolean", "optional" : true, "default" : false }, - + "additionalProperties" : { "type" : [{"$ref" : "#"}, "boolean"], "optional" : true, "default" : {} }, - + "requires" : { "type" : ["string", {"$ref" : "#"}], "optional" : true }, - + "minimum" : { "type" : "number", "optional" : true }, - + "maximum" : { "type" : "number", "optional" : true }, - + "minimumCanEqual" : { "type" : "boolean", "optional" : true, "requires" : "minimum", "default" : true }, - + "maximumCanEqual" : { "type" : "boolean", "optional" : true, "requires" : "maximum", "default" : true }, - + "minItems" : { "type" : "integer", "optional" : true, "minimum" : 0, "default" : 0 }, - + "maxItems" : { "type" : "integer", "optional" : true, "minimum" : 0 }, - + "pattern" : { "type" : "string", "optional" : true, "format" : "regex" }, - + "minLength" : { "type" : "integer", "optional" : true, "minimum" : 0, "default" : 0 }, - + "maxLength" : { "type" : "integer", "optional" : true }, - + "enum" : { "type" : "array", "optional" : true, "minItems" : 1 }, - + "title" : { "type" : "string", "optional" : true }, - + "description" : { "type" : "string", "optional" : true }, - + "format" : { "type" : "string", "optional" : true }, - + "contentEncoding" : { "type" : "string", "optional" : true }, - + "default" : { "type" : "any", "optional" : true }, - + "maxDecimal" : { "type" : "integer", "optional" : true, "minimum" : 0 }, - + "disallow" : { "type" : ["string", "array"], "items" : {"type" : "string"}, "optional" : true }, - + "extends" : { "type" : [{"$ref" : "#"}, "array"], "items" : {"$ref" : "#"}, @@ -149,7 +149,7 @@ "default" : {} } }, - + "optional" : true, "default" : {} } \ No newline at end of file diff --git a/deps/npm/node_modules/json-schema/draft-02/hyper-schema b/deps/npm/node_modules/json-schema/draft-02/hyper-schema index 4ec1b7569137c3..0771e2b31e8eef 100644 --- a/deps/npm/node_modules/json-schema/draft-02/hyper-schema +++ b/deps/npm/node_modules/json-schema/draft-02/hyper-schema @@ -8,61 +8,61 @@ "items" : {"$ref" : "http://json-schema.org/draft-02/links#"}, "optional" : true }, - + "fragmentResolution" : { "type" : "string", "optional" : true, "default" : "slash-delimited" }, - + "root" : { "type" : "boolean", "optional" : true, "default" : false }, - + "readonly" : { "type" : "boolean", "optional" : true, "default" : false }, - + "pathStart" : { "type" : "string", "optional" : true, "format" : "uri" }, - + "mediaType" : { "type" : "string", "optional" : true, "format" : "media-type" }, - + "alternate" : { "type" : "array", "items" : {"$ref" : "#"}, "optional" : true } }, - + "links" : [ { "href" : "{$ref}", "rel" : "full" }, - + { "href" : "{$schema}", "rel" : "describedby" }, - + { "href" : "{id}", "rel" : "self" } ], - + "fragmentResolution" : "slash-delimited", "extends" : {"$ref" : "http://json-schema.org/draft-02/schema#"} } \ No newline at end of file diff --git a/deps/npm/node_modules/json-schema/draft-02/json-ref b/deps/npm/node_modules/json-schema/draft-02/json-ref index 6526c394556665..1a6c56d04b665a 100644 --- a/deps/npm/node_modules/json-schema/draft-02/json-ref +++ b/deps/npm/node_modules/json-schema/draft-02/json-ref @@ -1,26 +1,26 @@ { "$schema" : "http://json-schema.org/draft-02/hyper-schema#", "id" : "http://json-schema.org/draft-02/json-ref#", - + "items" : {"$ref" : "#"}, "additionalProperties" : {"$ref" : "#"}, - + "links" : [ { "href" : "{$ref}", "rel" : "full" }, - + { "href" : "{$schema}", "rel" : "describedby" }, - + { "href" : "{id}", "rel" : "self" } ], - + "fragmentResolution" : "dot-delimited" } \ No newline at end of file diff --git a/deps/npm/node_modules/json-schema/draft-02/links b/deps/npm/node_modules/json-schema/draft-02/links index 1b176178a2c333..dacc53a1a4adb6 100644 --- a/deps/npm/node_modules/json-schema/draft-02/links +++ b/deps/npm/node_modules/json-schema/draft-02/links @@ -2,30 +2,30 @@ "$schema" : "http://json-schema.org/draft-02/hyper-schema#", "id" : "http://json-schema.org/draft-02/links#", "type" : "object", - + "properties" : { "href" : { "type" : "string" }, - + "rel" : { "type" : "string" }, - + "targetSchema" : {"$ref" : "http://json-schema.org/draft-02/hyper-schema#"}, - + "method" : { "type" : "string", "default" : "GET", "optional" : true }, - + "enctype" : { "type" : "string", "requires" : "method", "optional" : true }, - + "properties" : { "type" : "object", "additionalProperties" : {"$ref" : "http://json-schema.org/draft-02/hyper-schema#"}, diff --git a/deps/npm/node_modules/json-schema/draft-02/schema b/deps/npm/node_modules/json-schema/draft-02/schema index 61b8de15483962..a4998abea2065e 100644 --- a/deps/npm/node_modules/json-schema/draft-02/schema +++ b/deps/npm/node_modules/json-schema/draft-02/schema @@ -2,7 +2,7 @@ "$schema" : "http://json-schema.org/draft-02/hyper-schema#", "id" : "http://json-schema.org/draft-02/schema#", "type" : "object", - + "properties" : { "type" : { "type" : ["string", "array"], @@ -13,131 +13,131 @@ "uniqueItems" : true, "default" : "any" }, - + "properties" : { "type" : "object", "additionalProperties" : {"$ref" : "#"}, "optional" : true, "default" : {} }, - + "items" : { "type" : [{"$ref" : "#"}, "array"], "items" : {"$ref" : "#"}, "optional" : true, "default" : {} }, - + "optional" : { "type" : "boolean", "optional" : true, "default" : false }, - + "additionalProperties" : { "type" : [{"$ref" : "#"}, "boolean"], "optional" : true, "default" : {} }, - + "requires" : { "type" : ["string", {"$ref" : "#"}], "optional" : true }, - + "minimum" : { "type" : "number", "optional" : true }, - + "maximum" : { "type" : "number", "optional" : true }, - + "minimumCanEqual" : { "type" : "boolean", "optional" : true, "requires" : "minimum", "default" : true }, - + "maximumCanEqual" : { "type" : "boolean", "optional" : true, "requires" : "maximum", "default" : true }, - + "minItems" : { "type" : "integer", "optional" : true, "minimum" : 0, "default" : 0 }, - + "maxItems" : { "type" : "integer", "optional" : true, "minimum" : 0 }, - + "uniqueItems" : { "type" : "boolean", "optional" : true, "default" : false }, - + "pattern" : { "type" : "string", "optional" : true, "format" : "regex" }, - + "minLength" : { "type" : "integer", "optional" : true, "minimum" : 0, "default" : 0 }, - + "maxLength" : { "type" : "integer", "optional" : true }, - + "enum" : { "type" : "array", "optional" : true, "minItems" : 1, "uniqueItems" : true }, - + "title" : { "type" : "string", "optional" : true }, - + "description" : { "type" : "string", "optional" : true }, - + "format" : { "type" : "string", "optional" : true }, - + "contentEncoding" : { "type" : "string", "optional" : true }, - + "default" : { "type" : "any", "optional" : true }, - + "divisibleBy" : { "type" : "number", "minimum" : 0, @@ -145,14 +145,14 @@ "optional" : true, "default" : 1 }, - + "disallow" : { "type" : ["string", "array"], "items" : {"type" : "string"}, "optional" : true, "uniqueItems" : true }, - + "extends" : { "type" : [{"$ref" : "#"}, "array"], "items" : {"$ref" : "#"}, @@ -160,7 +160,7 @@ "default" : {} } }, - + "optional" : true, "default" : {} } \ No newline at end of file diff --git a/deps/npm/node_modules/json-schema/draft-03/examples/calendar b/deps/npm/node_modules/json-schema/draft-03/examples/calendar index 463cfb314b6431..d8fb5335f081b4 100644 --- a/deps/npm/node_modules/json-schema/draft-03/examples/calendar +++ b/deps/npm/node_modules/json-schema/draft-03/examples/calendar @@ -12,12 +12,12 @@ "type":"string", "required":true }, - "location" : { - "type" : "string" + "location" : { + "type" : "string" }, "url" : { - "type" : "string", - "format" : "url" + "type" : "string", + "format" : "url" }, "dtend" : { "format" : "date-time", @@ -47,7 +47,3 @@ "geo" : { "$ref" : "http://json-schema.org/draft-03/geo" } } } - - - - diff --git a/deps/npm/node_modules/json-schema/draft-03/examples/interfaces b/deps/npm/node_modules/json-schema/draft-03/examples/interfaces index 288a19856b7263..84ebf83a993f6d 100644 --- a/deps/npm/node_modules/json-schema/draft-03/examples/interfaces +++ b/deps/npm/node_modules/json-schema/draft-03/examples/interfaces @@ -6,18 +6,18 @@ "type":"object", "description":"This defines the set of methods available to the class instances", "additionalProperties":{ - "type":"object", - "description":"The definition of the method", - "properties":{ - "parameters":{ - "type":"array", - "description":"The set of parameters that should be passed to the method when it is called", - "items":{"$ref":"#"}, - "required": true - }, - "returns":{"$ref":"#"} - } + "type":"object", + "description":"The definition of the method", + "properties":{ + "parameters":{ + "type":"array", + "description":"The set of parameters that should be passed to the method when it is called", + "items":{"$ref":"#"}, + "required": true + }, + "returns":{"$ref":"#"} + } } - } + } } } diff --git a/deps/npm/node_modules/json-schema/draft-03/json-ref b/deps/npm/node_modules/json-schema/draft-03/json-ref index 7e491a8e882347..388476323a08ab 100644 --- a/deps/npm/node_modules/json-schema/draft-03/json-ref +++ b/deps/npm/node_modules/json-schema/draft-03/json-ref @@ -1,26 +1,26 @@ { "$schema" : "http://json-schema.org/draft-03/hyper-schema#", "id" : "http://json-schema.org/draft-03/json-ref#", - + "additionalItems" : {"$ref" : "#"}, "additionalProperties" : {"$ref" : "#"}, - + "links" : [ { "href" : "{id}", "rel" : "self" }, - + { "href" : "{$ref}", "rel" : "full" }, - + { "href" : "{$schema}", "rel" : "describedby" } ], - + "fragmentResolution" : "dot-delimited" } \ No newline at end of file diff --git a/deps/npm/node_modules/json-schema/draft-03/links b/deps/npm/node_modules/json-schema/draft-03/links index 6b0a85a6295b25..3dbcdba73cc4e8 100644 --- a/deps/npm/node_modules/json-schema/draft-03/links +++ b/deps/npm/node_modules/json-schema/draft-03/links @@ -2,31 +2,31 @@ "$schema" : "http://json-schema.org/draft-03/hyper-schema#", "id" : "http://json-schema.org/draft-03/links#", "type" : "object", - + "properties" : { "href" : { "type" : "string", "required" : true, "format" : "link-description-object-template" }, - + "rel" : { "type" : "string", "required" : true }, - + "targetSchema" : {"$ref" : "http://json-schema.org/draft-03/hyper-schema#"}, - + "method" : { "type" : "string", "default" : "GET" }, - + "enctype" : { "type" : "string", "requires" : "method" }, - + "properties" : { "type" : "object", "additionalProperties" : {"$ref" : "http://json-schema.org/draft-03/hyper-schema#"} diff --git a/deps/npm/node_modules/json-schema/draft-03/schema b/deps/npm/node_modules/json-schema/draft-03/schema index 55ae47d808c0ab..361456d8a7e89e 100644 --- a/deps/npm/node_modules/json-schema/draft-03/schema +++ b/deps/npm/node_modules/json-schema/draft-03/schema @@ -2,7 +2,7 @@ "$schema" : "http://json-schema.org/draft-03/schema#", "id" : "http://json-schema.org/draft-03/schema#", "type" : "object", - + "properties" : { "type" : { "type" : ["string", "array"], @@ -12,40 +12,40 @@ "uniqueItems" : true, "default" : "any" }, - + "properties" : { "type" : "object", "additionalProperties" : {"$ref" : "#"}, "default" : {} }, - + "patternProperties" : { "type" : "object", "additionalProperties" : {"$ref" : "#"}, "default" : {} }, - + "additionalProperties" : { "type" : [{"$ref" : "#"}, "boolean"], "default" : {} }, - + "items" : { "type" : [{"$ref" : "#"}, "array"], "items" : {"$ref" : "#"}, "default" : {} }, - + "additionalItems" : { "type" : [{"$ref" : "#"}, "boolean"], "default" : {} }, - + "required" : { "type" : "boolean", "default" : false }, - + "dependencies" : { "type" : "object", "additionalProperties" : { @@ -56,85 +56,85 @@ }, "default" : {} }, - + "minimum" : { "type" : "number" }, - + "maximum" : { "type" : "number" }, - + "exclusiveMinimum" : { "type" : "boolean", "default" : false }, - + "exclusiveMaximum" : { "type" : "boolean", "default" : false }, - + "minItems" : { "type" : "integer", "minimum" : 0, "default" : 0 }, - + "maxItems" : { "type" : "integer", "minimum" : 0 }, - + "uniqueItems" : { "type" : "boolean", "default" : false }, - + "pattern" : { "type" : "string", "format" : "regex" }, - + "minLength" : { "type" : "integer", "minimum" : 0, "default" : 0 }, - + "maxLength" : { "type" : "integer" }, - + "enum" : { "type" : "array", "minItems" : 1, "uniqueItems" : true }, - + "default" : { "type" : "any" }, - + "title" : { "type" : "string" }, - + "description" : { "type" : "string" }, - + "format" : { "type" : "string" }, - + "divisibleBy" : { "type" : "number", "minimum" : 0, "exclusiveMinimum" : true, "default" : 1 }, - + "disallow" : { "type" : ["string", "array"], "items" : { @@ -142,33 +142,33 @@ }, "uniqueItems" : true }, - + "extends" : { "type" : [{"$ref" : "#"}, "array"], "items" : {"$ref" : "#"}, "default" : {} }, - + "id" : { "type" : "string", "format" : "uri" }, - + "$ref" : { "type" : "string", "format" : "uri" }, - + "$schema" : { "type" : "string", "format" : "uri" } }, - + "dependencies" : { "exclusiveMinimum" : "minimum", "exclusiveMaximum" : "maximum" }, - + "default" : {} } \ No newline at end of file diff --git a/deps/npm/node_modules/json-schema/draft-04/links b/deps/npm/node_modules/json-schema/draft-04/links index de272cc4513d0a..7cf7c92c20965c 100644 --- a/deps/npm/node_modules/json-schema/draft-04/links +++ b/deps/npm/node_modules/json-schema/draft-04/links @@ -2,7 +2,7 @@ "$schema" : "http://json-schema.org/draft-04/hyper-schema#", "id" : "http://json-schema.org/draft-04/links#", "type" : "object", - + "properties" : { "rel" : { "type" : "string" @@ -15,26 +15,26 @@ "template" : { "type" : "string" }, - + "targetSchema" : {"$ref" : "http://json-schema.org/draft-04/hyper-schema#"}, - + "method" : { "type" : "string", "default" : "GET" }, - + "enctype" : { "type" : "string" }, - + "properties" : { "type" : "object", "additionalProperties" : {"$ref" : "http://json-schema.org/draft-04/hyper-schema#"} } }, - + "required" : ["rel", "href"], - + "dependencies" : { "enctype" : "method" } diff --git a/deps/npm/node_modules/json-schema/draft-04/schema b/deps/npm/node_modules/json-schema/draft-04/schema index 598951e57d2eb7..e9c90699fda128 100644 --- a/deps/npm/node_modules/json-schema/draft-04/schema +++ b/deps/npm/node_modules/json-schema/draft-04/schema @@ -2,7 +2,7 @@ "$schema" : "http://json-schema.org/draft-04/schema#", "id" : "http://json-schema.org/draft-04/schema#", "type" : "object", - + "properties" : { "type" : { "type" : [ @@ -10,19 +10,19 @@ "id" : "#simple-type", "type" : "string", "enum" : ["object", "array", "string", "number", "boolean", "null", "any"] - }, + }, "array" ], "items" : { "type" : [ - {"$ref" : "#simple-type"}, + {"$ref" : "#simple-type"}, {"$ref" : "#"} ] }, "uniqueItems" : true, "default" : "any" }, - + "disallow" : { "type" : ["string", "array"], "items" : { @@ -30,7 +30,7 @@ }, "uniqueItems" : true }, - + "extends" : { "type" : [{"$ref" : "#"}, "array"], "items" : {"$ref" : "#"}, @@ -42,108 +42,108 @@ "minItems" : 1, "uniqueItems" : true }, - + "minimum" : { "type" : "number" }, - + "maximum" : { "type" : "number" }, - + "exclusiveMinimum" : { "type" : "boolean", "default" : false }, - + "exclusiveMaximum" : { "type" : "boolean", "default" : false }, - + "divisibleBy" : { "type" : "number", "minimum" : 0, "exclusiveMinimum" : true, "default" : 1 }, - + "minLength" : { "type" : "integer", "minimum" : 0, "default" : 0 }, - + "maxLength" : { "type" : "integer" }, - + "pattern" : { "type" : "string" }, - + "items" : { "type" : [{"$ref" : "#"}, "array"], "items" : {"$ref" : "#"}, "default" : {} }, - + "additionalItems" : { "type" : [{"$ref" : "#"}, "boolean"], "default" : {} }, - + "minItems" : { "type" : "integer", "minimum" : 0, "default" : 0 }, - + "maxItems" : { "type" : "integer", "minimum" : 0 }, - + "uniqueItems" : { "type" : "boolean", "default" : false }, - + "properties" : { "type" : "object", "additionalProperties" : {"$ref" : "#"}, "default" : {} }, - + "patternProperties" : { "type" : "object", "additionalProperties" : {"$ref" : "#"}, "default" : {} }, - + "additionalProperties" : { "type" : [{"$ref" : "#"}, "boolean"], "default" : {} }, - + "minProperties" : { "type" : "integer", "minimum" : 0, "default" : 0 }, - + "maxProperties" : { "type" : "integer", "minimum" : 0 }, - + "required" : { "type" : "array", "items" : { "type" : "string" } }, - + "dependencies" : { "type" : "object", "additionalProperties" : { @@ -154,36 +154,36 @@ }, "default" : {} }, - + "id" : { "type" : "string" }, - + "$ref" : { "type" : "string" }, - + "$schema" : { "type" : "string" }, - + "title" : { "type" : "string" }, - + "description" : { "type" : "string" }, - + "default" : { "type" : "any" } }, - + "dependencies" : { "exclusiveMinimum" : "minimum", "exclusiveMaximum" : "maximum" }, - + "default" : {} } \ No newline at end of file diff --git a/deps/npm/node_modules/json-schema/draft-zyp-json-schema-03.xml b/deps/npm/node_modules/json-schema/draft-zyp-json-schema-03.xml index c28f40dcd6ee44..1cf715910b5a83 100644 --- a/deps/npm/node_modules/json-schema/draft-zyp-json-schema-03.xml +++ b/deps/npm/node_modules/json-schema/draft-zyp-json-schema-03.xml @@ -24,7 +24,7 @@ A JSON Media Type for Describing the Structure and Meaning of JSON Documents - + SitePen (USA)
@@ -37,7 +37,7 @@ kris@sitepen.com
- +
@@ -48,7 +48,7 @@ gary.court@gmail.com
- + Internet Engineering Task Force JSON @@ -58,59 +58,59 @@ Notation Hyper Schema Hypermedia - + - JSON (JavaScript Object Notation) Schema defines the media type "application/schema+json", - a JSON based format for defining - the structure of JSON data. JSON Schema provides a contract for what JSON - data is required for a given application and how to interact with it. JSON - Schema is intended to define validation, documentation, hyperlink - navigation, and interaction control of JSON data. + JSON (JavaScript Object Notation) Schema defines the media type "application/schema+json", + a JSON based format for defining + the structure of JSON data. JSON Schema provides a contract for what JSON + data is required for a given application and how to interact with it. JSON + Schema is intended to define validation, documentation, hyperlink + navigation, and interaction control of JSON data.
- +
- JSON (JavaScript Object Notation) Schema is a JSON media type for defining - the structure of JSON data. JSON Schema provides a contract for what JSON - data is required for a given application and how to interact with it. JSON - Schema is intended to define validation, documentation, hyperlink - navigation, and interaction control of JSON data. + JSON (JavaScript Object Notation) Schema is a JSON media type for defining + the structure of JSON data. JSON Schema provides a contract for what JSON + data is required for a given application and how to interact with it. JSON + Schema is intended to define validation, documentation, hyperlink + navigation, and interaction control of JSON data.
- +
- - - The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", + + The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in RFC 2119.
- + - +
- JSON Schema defines the media type "application/schema+json" for + JSON Schema defines the media type "application/schema+json" for describing the structure of other - JSON documents. JSON Schema is JSON-based and includes facilities + JSON documents. JSON Schema is JSON-based and includes facilities for describing the structure of JSON documents in terms of allowable values, descriptions, and interpreting relations with other resources. - JSON Schema format is organized into several separate definitions. The first - definition is the core schema specification. This definition is primary + JSON Schema format is organized into several separate definitions. The first + definition is the core schema specification. This definition is primary concerned with describing a JSON structure and specifying valid elements in the structure. The second definition is the Hyper Schema specification which is intended define elements in a structure that can be interpreted as hyperlinks. - Hyper Schema builds on JSON Schema to describe the hyperlink structure of + Hyper Schema builds on JSON Schema to describe the hyperlink structure of other JSON documents and elements of interaction. This allows user agents to be able to successfully navigate JSON documents based on their schemas. @@ -118,12 +118,12 @@ Cumulatively JSON Schema acts as a meta-document that can be used to define the required type and constraints on property values, as well as define the meaning of the property values for the purpose of describing a resource and determining hyperlinks - within the representation. + within the representation.
An example JSON Schema that describes products might look like: - - This schema defines the properties of the instance JSON documents, + This schema defines the properties of the instance JSON documents, the required properties (id, name, and price), as well as an optional property (tags). This also defines the link relations of the instance JSON documents.
- +
- For this specification, schema will be used to denote a JSON Schema - definition, and an instance refers to a JSON value that the schema + For this specification, schema will be used to denote a JSON Schema + definition, and an instance refers to a JSON value that the schema will be describing and validating.
- +
The JSON Schema media type does not attempt to dictate the structure of JSON @@ -194,7 +194,7 @@ This specification is protocol agnostic. The underlying protocol (such as HTTP) should sufficiently define the semantics of the client-server interface, the retrieval of resource - representations linked to by JSON representations, and modification of + representations linked to by JSON representations, and modification of those resources. The goal of this format is to sufficiently describe JSON structures such that one can utilize existing information available in existing JSON @@ -203,7 +203,7 @@
- +
JSON Schema instances are correlated to their schema by the "describedby" @@ -217,22 +217,22 @@ representation and messages may retain the self-descriptive characteristic, avoiding the need for out-of-band information about instance data. Two approaches are recommended for declaring the - relation to the schema that describes the meaning of a JSON instance's (or collection + relation to the schema that describes the meaning of a JSON instance's (or collection of instances) structure. A MIME type parameter named "profile" or a relation of "describedby" (which could be defined by a Link header) may be used: - +
-
- + or if the content is being transferred by a protocol (such as HTTP) that provides headers, a Link header can be used: - +
; rel="describedby" ]]>
- - Instances MAY specify multiple schemas, to indicate all the schemas that - are applicable to the data, and the data SHOULD be valid by all the schemas. - The instance data MAY have multiple schemas - that it is defined by (the instance data SHOULD be valid for those schemas). - Or if the document is a collection of instances, the collection MAY contain - instances from different schemas. When collections contain heterogeneous - instances, the "pathStart" attribute MAY be specified in the - schema to disambiguate which schema should be applied for each item in the + + Instances MAY specify multiple schemas, to indicate all the schemas that + are applicable to the data, and the data SHOULD be valid by all the schemas. + The instance data MAY have multiple schemas + that it is defined by (the instance data SHOULD be valid for those schemas). + Or if the document is a collection of instances, the collection MAY contain + instances from different schemas. When collections contain heterogeneous + instances, the "pathStart" attribute MAY be specified in the + schema to disambiguate which schema should be applied for each item in the collection. However, ultimately, the mechanism for referencing a schema is up to the media type of the instance documents (if they choose to specify that schemas can be referenced).
- +
- JSON Schemas can themselves be described using JSON Schemas. + JSON Schemas can themselves be described using JSON Schemas. A self-describing JSON Schema for the core JSON Schema can - be found at http://json-schema.org/schema for the latest version or - http://json-schema.org/draft-03/schema for the draft-03 version. The hyper schema - self-description can be found at http://json-schema.org/hyper-schema + be found at http://json-schema.org/schema for the latest version or + http://json-schema.org/draft-03/schema for the draft-03 version. The hyper schema + self-description can be found at http://json-schema.org/hyper-schema or http://json-schema.org/draft-03/hyper-schema. All schemas used within a protocol with media type definitions SHOULD include a MIME parameter that refers to the self-descriptive hyper schema or another schema that extends this hyper schema: - +
- @@ -277,15 +277,15 @@ Content-Type: application/json;
- +
- A JSON Schema is a JSON Object that defines various attributes + A JSON Schema is a JSON Object that defines various attributes (including usage and valid values) of a JSON value. JSON Schema has recursive capabilities; there are a number of elements in the structure that allow for nested JSON Schemas. - +
An example JSON Schema definition could look like: @@ -307,15 +307,15 @@ Content-Type: application/json; ]]>
- + A JSON Schema object may have any of the following properties, called schema attributes (all attributes are optional): - +
- This attribute defines what the primitive type or the schema of the instance MUST be in order to validate. + This attribute defines what the primitive type or the schema of the instance MUST be in order to validate. This attribute can take one of two forms: @@ -332,19 +332,19 @@ Content-Type: application/json; Value MUST be null. Note this is mainly for purpose of being able use union types to define nullability. If this type is not included in a union, null values are not allowed (the primitives listed above do not allow nulls on their own). Value MAY be of any type including null. - - If the property is not defined or is not in this list, then any type of value is acceptable. - Other type values MAY be used for custom purposes, but minimal validators of the specification + + If the property is not defined or is not in this list, then any type of value is acceptable. + Other type values MAY be used for custom purposes, but minimal validators of the specification implementation can allow any instance value on unknown type values. - + An array of two or more simple type definitions. Each item in the array MUST be a simple type definition or a schema. - The instance value is valid if it is of the same type as one of the simple type definitions, or valid by one of the schemas, in the array. + The instance value is valid if it is of the same type as one of the simple type definitions, or valid by one of the schemas, in the array. - +
For example, a schema that defines if an instance can be a string or a number would be: @@ -355,38 +355,38 @@ Content-Type: application/json; ]]>
- +
This attribute is an object with property definitions that define the valid values of instance object property values. When the instance value is an object, the property values of the instance object MUST conform to the property definitions in this object. In this object, each property definition's value MUST be a schema, and the property's name MUST be the name of the instance property that it defines. The instance property value MUST be valid according to the schema from the property definition. Properties are considered unordered, the order of the instance properties MAY be in any order.
- +
This attribute is an object that defines the schema for a set of property names of an object instance. The name of each property of this attribute's object is a regular expression pattern in the ECMA 262/Perl 5 format, while the value is a schema. If the pattern matches the name of a property on the instance object, the value of the instance's property MUST be valid against the pattern name's schema value.
- +
This attribute defines a schema for all properties that are not explicitly defined in an object type definition. If specified, the value MUST be a schema or a boolean. If false is provided, no additional properties are allowed beyond the properties defined in the schema. The default value is an empty schema which allows any value for additional properties.
- +
This attribute defines the allowed items in an instance array, and MUST be a schema or an array of schemas. The default value is an empty schema which allows any value for items in the instance array. When this attribute value is a schema and the instance value is an array, then all the items in the array MUST be valid according to the schema. When this attribute value is an array of schemas and the instance value is an array, each position in the instance array MUST conform to the schema in the corresponding position for this array. This called tuple typing. When tuple typing is used, additional items are allowed, disallowed, or constrained by the "additionalItems" attribute using the same rules as "additionalProperties" for objects.
- +
This provides a definition for additional items in an array instance when tuple definitions of the items is provided. This can be false to indicate additional items in the array are not allowed, or it can be a schema that defines the schema of the additional items.
- +
This attribute indicates if the instance must have a value, and not be undefined. This is false by default, making the instance optional.
- +
This attribute is an object that defines the requirements of a property on an instance object. If an object instance has a property with the same name as a property in this attribute's object, then the instance must be valid against the attribute's property value (hereafter referred to as the "dependency value"). The dependency value can take one of two forms: - + If the dependency value is a string, then the instance object MUST have a property with the same name as the dependency value. @@ -398,36 +398,36 @@ Content-Type: application/json;
- +
This attribute defines the minimum value of the instance property when the type of the instance value is a number.
- +
This attribute defines the maximum value of the instance property when the type of the instance value is a number.
- +
This attribute indicates if the value of the instance (if the instance is a number) can not equal the number defined by the "minimum" attribute. This is false by default, meaning the instance value can be greater then or equal to the minimum value.
- +
This attribute indicates if the value of the instance (if the instance is a number) can not equal the number defined by the "maximum" attribute. This is false by default, meaning the instance value can be less then or equal to the maximum value.
- +
This attribute defines the minimum number of values in an array when the array is the instance value.
- +
This attribute defines the maximum number of values in an array when the array is the instance value.
- +
This attribute indicates that all items in an array instance MUST be unique (contains no two identical values). Two instance are consider equal if they are both of the same type and: - + are null; or are booleans/numbers/strings and have the same value; or @@ -436,41 +436,41 @@ Content-Type: application/json;
- +
When the instance value is a string, this provides a regular expression that a string instance MUST match in order to be valid. Regular expressions SHOULD follow the regular expression specification from ECMA 262/Perl 5
- +
When the instance value is a string, this defines the minimum length of the string.
- +
When the instance value is a string, this defines the maximum length of the string.
- +
This provides an enumeration of all possible values that are valid for the instance property. This MUST be an array, and each item in the array represents a possible value for the instance value. If this attribute is defined, the instance value MUST be one of the values in the array in order for the schema to be valid. Comparison of enum values uses the same algorithm as defined in "uniqueItems".
- +
This attribute defines the default value of the instance when the instance is undefined.
- +
This attribute is a string that provides a short description of the instance property.
- +
This attribute is a string that provides a full description of the of purpose the instance property.
- +
This property defines the type of data, content type, or microformat to be expected in the instance property values. A format attribute MAY be one of the values listed below, and if so, SHOULD adhere to the semantics describing for the format. A format SHOULD only be used to give meaning to primitive types (string, integer, number, or boolean). Validators MAY (but are not required to) validate that the instance values conform to a format. - + The following formats are predefined: - + This SHOULD be a date in ISO 8601 format of YYYY-MM-DDThh:mm:ssZ in UTC time. This is the recommended form of date/timestamp. This SHOULD be a date in the format of YYYY-MM-DD. It is recommended that you use the "date-time" format instead of "date" unless you need to transfer only the date part. @@ -487,18 +487,18 @@ Content-Type: application/json; This SHOULD be a host-name. - + Additional custom formats MAY be created. These custom formats MAY be expressed as an URI, and this URI MAY reference a schema of that format.
- +
This attribute defines what value the number instance must be divisible by with no remainder (the result of the division must be an integer.) The value of this attribute SHOULD NOT be 0.
- +
This attribute takes the same values as the "type" attribute, however if the instance matches the type or if this value is an array and the instance matches any type or schema in the array, then this instance is not valid.
- +
The value of this property MUST be another schema which will provide a base schema which the current schema will inherit from. The inheritance rules are such that any instance that is valid according to the current schema MUST be valid according to the referenced schema. This MAY also be an array, in which case, the instance MUST be valid for all the schemas in the array. A schema that extends another schema MAY define additional attributes, constrain existing attributes, or add other constraints. @@ -506,7 +506,7 @@ Content-Type: application/json; instance against all constraints in the extending schema as well as the extended schema(s). More optimized implementations that merge schemas are possible, but are not required. Some examples of using "extends": - +
- +
- +
This attribute defines the current URI of this schema (this attribute is @@ -553,28 +553,28 @@ Content-Type: application/json; is also used to construct relative references such as for $ref.
- +
- This attribute defines a URI of a schema that contains the full representation of this schema. - When a validator encounters this attribute, it SHOULD replace the current schema with the schema referenced by the value's URI (if known and available) and re-validate the instance. + This attribute defines a URI of a schema that contains the full representation of this schema. + When a validator encounters this attribute, it SHOULD replace the current schema with the schema referenced by the value's URI (if known and available) and re-validate the instance. This URI MAY be relative or absolute, and relative URIs SHOULD be resolved against the URI of the current schema.
- +
- This attribute defines a URI of a JSON Schema that is the schema of the current schema. + This attribute defines a URI of a JSON Schema that is the schema of the current schema. When this attribute is defined, a validator SHOULD use the schema referenced by the value's URI (if known and available) when resolving Hyper Schemalinks. - + - A validator MAY use this attribute's value to determine which version of JSON Schema the current schema is written in, and provide the appropriate validation features and behavior. + A validator MAY use this attribute's value to determine which version of JSON Schema the current schema is written in, and provide the appropriate validation features and behavior. Therefore, it is RECOMMENDED that all schema authors include this attribute in their schemas to prevent conflicts with future JSON Schema specification changes.
- +
The following attributes are specified in addition to those @@ -586,28 +586,28 @@ Content-Type: application/json; essentially describes plain JSON (no constraints on the structures). Addition of attributes provides additive information for user agents. - +
- The value of the links property MUST be an array, where each item + The value of the links property MUST be an array, where each item in the array is a link description object which describes the link relations of the instances. - +
- A link description object is used to describe link relations. In - the context of a schema, it defines the link relations of the + A link description object is used to describe link relations. In + the context of a schema, it defines the link relations of the instances of the schema, and can be parameterized by the instance values. The link description format can be used on its own in regular (non-schema documents), and use of this format can be declared by referencing the normative link description - schema as the the schema for the data structure that uses the - links. The URI of the normative link description schema is: + schema as the the schema for the data structure that uses the + links. The URI of the normative link description schema is: http://json-schema.org/links (latest version) or http://json-schema.org/draft-03/links (draft-03 version). - +
The value of the "href" link description property @@ -615,19 +615,19 @@ Content-Type: application/json; of the instance property SHOULD be resolved as a URI-Reference per RFC 3986 and MAY be a relative URI. The base URI to be used for relative resolution SHOULD be the URI used to retrieve the instance object (not the schema) - when used within a schema. Also, when links are used within a schema, the URI - SHOULD be parametrized by the property values of the instance + when used within a schema. Also, when links are used within a schema, the URI + SHOULD be parametrized by the property values of the instance object, if property values exist for the corresponding variables in the template (otherwise they MAY be provided from alternate sources, like user input). - + Instance property values SHOULD be substituted into the URIs where matching braces ('{', '}') are found surrounding zero or more characters, creating an expanded URI. Instance property value substitutions are resolved by using the text between the braces to denote the property name - from the instance to get the value to substitute. - + from the instance to get the value to substitute. +
For example, if an href value is defined: @@ -637,7 +637,7 @@ http://somesite.com/{id} Then it would be resolved by replace the value of the "id" property value from the instance object.
- +
If the value of the "id" property was "45", the expanded URI would be: @@ -646,23 +646,23 @@ http://somesite.com/45 ]]>
- - If matching braces are found with the string "@" (no quotes) between the braces, then the + + If matching braces are found with the string "@" (no quotes) between the braces, then the actual instance value SHOULD be used to replace the braces, rather than a property value. - This should only be used in situations where the instance is a scalar (string, + This should only be used in situations where the instance is a scalar (string, boolean, or number), and not for objects or arrays.
- +
- The value of the "rel" property indicates the name of the + The value of the "rel" property indicates the name of the relation to the target resource. The relation to the target SHOULD be interpreted as specifically from the instance object that the schema (or sub-schema) applies to, not just the top level resource that contains the object within its hierarchy. If a resource JSON representation contains a sub object with a property interpreted as a link, that sub-object holds the relation with the target. A relation to target from the top level resource MUST be indicated with the schema describing the top level JSON representation. - + Relationship definitions SHOULD NOT be media type dependent, and users are encouraged to utilize existing accepted relation definitions, including those in existing relation registries (see RFC 4287). However, we define these relations here for clarity of normative interpretation within the context of JSON hyper schema defined relations: - + If the relation value is "self", when this property is encountered in @@ -670,15 +670,15 @@ http://somesite.com/45 treated as a full representation of the target resource identified by the specified URI. - + This indicates that the target of the link is the full representation for the instance object. The object that contains this link possibly may not be the full representation. - + This indicates the target of the link is the schema for the instance object. This MAY be used to specifically denote the schemas of objects within a JSON object hierarchy, facilitating polymorphic type data structures. - + This relation indicates that the target of the link SHOULD be treated as the root or the body of the representation for the @@ -688,7 +688,7 @@ http://somesite.com/45 - + The following relations are applicable for schemas (the schema as the "from" resource in the relation): @@ -697,7 +697,7 @@ http://somesite.com/45 This indicates a target to use for creating new instances of a schema. This link definition SHOULD be a submission link with a non-safe method (like POST). - +
For example, if a schema is defined: @@ -718,7 +718,7 @@ http://somesite.com/45 ]]>
- +
And if a collection of instance resource's JSON representation was retrieved: @@ -742,37 +742,37 @@ GET /Resource/ The "children" collection would be located at "/Resource/?upId=thing".
- +
This property value is a schema that defines the expected structure of the JSON representation of the target of the link.
- +
- The following properties also apply to link definition objects, and - provide functionality analogous to HTML forms, in providing a + The following properties also apply to link definition objects, and + provide functionality analogous to HTML forms, in providing a means for submitting extra (often user supplied) information to send to a server. - +
- This attribute defines which method can be used to access the target resource. - In an HTTP environment, this would be "GET" or "POST" (other HTTP methods - such as "PUT" and "DELETE" have semantics that are clearly implied by - accessed resources, and do not need to be defined here). + This attribute defines which method can be used to access the target resource. + In an HTTP environment, this would be "GET" or "POST" (other HTTP methods + such as "PUT" and "DELETE" have semantics that are clearly implied by + accessed resources, and do not need to be defined here). This defaults to "GET".
- +
If present, this property indicates a query media type format that the server - supports for querying or posting to the collection of instances at the target - resource. The query can be + supports for querying or posting to the collection of instances at the target + resource. The query can be suffixed to the target URI to query the collection with property-based constraints on the resources that SHOULD be returned from the server or used to post data to the resource (depending on the method). - +
For example, with the following schema: @@ -793,7 +793,7 @@ GET /Resource/ This indicates that the client can query the server for instances that have a specific name.
- +
For example: @@ -803,23 +803,23 @@ GET /Resource/
- If no enctype or method is specified, only the single URI specified by - the href property is defined. If the method is POST, "application/json" is + If no enctype or method is specified, only the single URI specified by + the href property is defined. If the method is POST, "application/json" is the default media type.
- +
This attribute contains a schema which defines the acceptable structure of the submitted - request (for a GET request, this schema would define the properties for the query string + request (for a GET request, this schema would define the properties for the query string and for a POST request, this would define the body).
- +
This property indicates the fragment resolution protocol to use for @@ -829,12 +829,12 @@ GET /Resource/ protocol is "slash-delimited", which is defined below. Other fragment resolution protocols MAY be used, but are not defined in this document. - + The fragment identifier is based on RFC 2396, Sec 5, and defines the mechanism for resolving references to entities within a document. - +
With the slash-delimited fragment resolution protocol, the fragment @@ -852,15 +852,15 @@ GET /Resource/ item in array the array with the index defined by the next property reference token (which MUST be a number). The target is successively updated for each property reference token, until the entire fragment has - been traversed. + been traversed. - + - Property names SHOULD be URI-encoded. In particular, any "/" in a - property name MUST be encoded to avoid being interpreted as a property + Property names SHOULD be URI-encoded. In particular, any "/" in a + property name MUST be encoded to avoid being interpreted as a property delimiter. - +
For example, for the following JSON representation: @@ -879,7 +879,7 @@ GET /Resource/ ]]>
- +
The following fragment identifiers would be resolved: @@ -889,10 +889,10 @@ fragment identifier resolution # self, the root of the resource itself #/foo the object referred to by the foo property #/foo/another%20prop the object referred to by the "another prop" - property of the object referred to by the + property of the object referred to by the "foo" property #/foo/another%20prop/baz the string referred to by the value of "baz" - property of the "another prop" property of + property of the "another prop" property of the object referred to by the "foo" property #/foo/anArray/0 the first object in the "anArray" array ]]> @@ -900,61 +900,61 @@ fragment identifier resolution
- +
- The dot-delimited fragment resolution protocol is the same as - slash-delimited fragment resolution protocol except that the "." character - (\x2E) is used as the delimiter between property names (instead of "/") and + The dot-delimited fragment resolution protocol is the same as + slash-delimited fragment resolution protocol except that the "." character + (\x2E) is used as the delimiter between property names (instead of "/") and the path does not need to start with a ".". For example, #.foo and #foo are a valid fragment identifiers for referencing the value of the foo propery.
- +
This attribute indicates that the instance property SHOULD NOT be changed. Attempts by a user agent to modify the value of this property are expected to be rejected by a server.
- +
If the instance property value is a string, this attribute defines that the string SHOULD be interpreted as binary data and decoded using the encoding named by this schema property. RFC 2045, Sec 6.1 lists the possible values for this property.
- +
- This attribute is a URI that defines what the instance's URI MUST start with in order to validate. - The value of the "pathStart" attribute MUST be resolved as per RFC 3986, Sec 5, + This attribute is a URI that defines what the instance's URI MUST start with in order to validate. + The value of the "pathStart" attribute MUST be resolved as per RFC 3986, Sec 5, and is relative to the instance's URI. - + - When multiple schemas have been referenced for an instance, the user agent - can determine if this schema is applicable for a particular instance by + When multiple schemas have been referenced for an instance, the user agent + can determine if this schema is applicable for a particular instance by determining if the URI of the instance begins with the the value of the "pathStart" - attribute. If the URI of the instance does not start with this URI, - or if another schema specifies a starting URI that is longer and also matches the - instance, this schema SHOULD NOT be applied to the instance. Any schema - that does not have a pathStart attribute SHOULD be considered applicable + attribute. If the URI of the instance does not start with this URI, + or if another schema specifies a starting URI that is longer and also matches the + instance, this schema SHOULD NOT be applied to the instance. Any schema + that does not have a pathStart attribute SHOULD be considered applicable to all the instances for which it is referenced.
- +
This attribute defines the media type of the instance representations that this schema is defining.
- +
- This specification is a sub-type of the JSON format, and - consequently the security considerations are generally the same as RFC 4627. + This specification is a sub-type of the JSON format, and + consequently the security considerations are generally the same as RFC 4627. However, an additional issue is that when link relation of "self" - is used to denote a full representation of an object, the user agent + is used to denote a full representation of an object, the user agent SHOULD NOT consider the representation to be the authoritative representation of the resource denoted by the target URI if the target URI is not - equivalent to or a sub-path of the the URI used to request the resource + equivalent to or a sub-path of the the URI used to request the resource representation which contains the target URI with the "self" link. - +
For example, if a hyper schema was defined: @@ -968,7 +968,7 @@ fragment identifier resolution ]]>
- +
And a resource was requested from somesite.com: @@ -1005,22 +1005,22 @@ Content-Type: application/json; profile=/schema-for-this-data
- +
The proposed MIME media type for JSON Schema is "application/schema+json". Type name: application Subtype name: schema+json Required parameters: profile - The value of the profile parameter SHOULD be a URI (relative or absolute) that - refers to the schema used to define the structure of this structure (the + The value of the profile parameter SHOULD be a URI (relative or absolute) that + refers to the schema used to define the structure of this structure (the meta-schema). Normally the value would be http://json-schema.org/draft-03/hyper-schema, but it is allowable to use other schemas that extend the hyper schema's meta- schema. Optional parameters: pretty The value of the pretty parameter MAY be true or false to indicate if additional whitespace has been included to make the JSON representation easier to read. - +
This registry is maintained by IANA per RFC 4287 and this specification adds @@ -1032,7 +1032,7 @@ Content-Type: application/json; profile=/schema-for-this-data
- + @@ -1080,7 +1080,7 @@ Content-Type: application/json; profile=/schema-for-this-data Added "$ref" and "$schema" attributes. - + Replaced "maxDecimal" attribute with "divisibleBy" attribute. @@ -1090,13 +1090,13 @@ Content-Type: application/json; profile=/schema-for-this-data Added "targetSchema" attribute to link description object. - + Fixed category and updates from template. - + Initial draft. @@ -1105,7 +1105,7 @@ Content-Type: application/json; profile=/schema-for-this-data - +
diff --git a/deps/npm/node_modules/json-schema/draft-zyp-json-schema-04.xml b/deps/npm/node_modules/json-schema/draft-zyp-json-schema-04.xml index f9c1ea5a0c00a2..22fb3290df1472 100644 --- a/deps/npm/node_modules/json-schema/draft-zyp-json-schema-04.xml +++ b/deps/npm/node_modules/json-schema/draft-zyp-json-schema-04.xml @@ -23,7 +23,7 @@ A JSON Media Type for Describing the Structure and Meaning of JSON Documents - + SitePen (USA)
@@ -36,7 +36,7 @@ kris@sitepen.com
- +
@@ -47,7 +47,7 @@ gary.court@gmail.com
- + Internet Engineering Task Force JSON @@ -57,48 +57,48 @@ Notation Hyper Schema Hypermedia - + - JSON (JavaScript Object Notation) Schema defines the media type "application/schema+json", - a JSON based format for defining the structure of JSON data. JSON Schema provides a contract for what JSON - data is required for a given application and how to interact with it. JSON - Schema is intended to define validation, documentation, hyperlink - navigation, and interaction control of JSON data. + JSON (JavaScript Object Notation) Schema defines the media type "application/schema+json", + a JSON based format for defining the structure of JSON data. JSON Schema provides a contract for what JSON + data is required for a given application and how to interact with it. JSON + Schema is intended to define validation, documentation, hyperlink + navigation, and interaction control of JSON data.
- +
- JSON (JavaScript Object Notation) Schema is a JSON media type for defining - the structure of JSON data. JSON Schema provides a contract for what JSON - data is required for a given application and how to interact with it. JSON - Schema is intended to define validation, documentation, hyperlink - navigation, and interaction control of JSON data. + JSON (JavaScript Object Notation) Schema is a JSON media type for defining + the structure of JSON data. JSON Schema provides a contract for what JSON + data is required for a given application and how to interact with it. JSON + Schema is intended to define validation, documentation, hyperlink + navigation, and interaction control of JSON data.
- +
- - - The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", + + The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in RFC 2119. - + - The terms "JSON", "JSON text", "JSON value", "member", "element", "object", - "array", "number", "string", "boolean", "true", "false", and "null" in this + The terms "JSON", "JSON text", "JSON value", "member", "element", "object", + "array", "number", "string", "boolean", "true", "false", and "null" in this document are to be interpreted as defined in RFC 4627. - + This specification also uses the following defined terms: - + A JSON Schema object. Equivalent to "JSON value" as defined in RFC 4627. @@ -108,35 +108,35 @@
- +
- JSON Schema defines the media type "application/schema+json" for - describing the structure of JSON text. JSON Schemas are also written in JSON and includes facilities + JSON Schema defines the media type "application/schema+json" for + describing the structure of JSON text. JSON Schemas are also written in JSON and includes facilities for describing the structure of JSON in terms of allowable values, descriptions, and interpreting relations with other resources. - This document is organized into several separate definitions. The first - definition is the core schema specification. This definition is primary + This document is organized into several separate definitions. The first + definition is the core schema specification. This definition is primary concerned with describing a JSON structure and specifying valid elements in the structure. The second definition is the Hyper Schema specification which is intended to define elements in a structure that can be interpreted as hyperlinks. - Hyper Schema builds on JSON Schema to describe the hyperlink structure of + Hyper Schema builds on JSON Schema to describe the hyperlink structure of JSON values. This allows user agents to be able to successfully navigate documents containing JSON based on their schemas. - Cumulatively JSON Schema acts as meta-JSON that can be used to define the + Cumulatively JSON Schema acts as meta-JSON that can be used to define the required type and constraints on JSON values, as well as define the meaning of the JSON values for the purpose of describing a resource and determining - hyperlinks within the representation. + hyperlinks within the representation.
An example JSON Schema that describes products might look like: - - This schema defines the properties of the instance, + This schema defines the properties of the instance, the required properties (id, name, and price), as well as an optional property (tags). This also defines the link relations of the instance.
- +
The JSON Schema media type does not attempt to dictate the structure of JSON @@ -195,7 +195,7 @@ This specification is protocol agnostic. The underlying protocol (such as HTTP) should sufficiently define the semantics of the client-server interface, the retrieval of resource - representations linked to by JSON representations, and modification of + representations linked to by JSON representations, and modification of those resources. The goal of this format is to sufficiently describe JSON structures such that one can utilize existing information available in existing JSON @@ -204,35 +204,35 @@
- +
JSON values are correlated to their schema by the "describedby" relation, where the schema is the target of the relation. JSON values MUST be of the "application/json" media type or - any other subtype. Consequently, dictating how a JSON value should + any other subtype. Consequently, dictating how a JSON value should specify the relation to the schema is beyond the normative scope of this document since this document specifically defines the JSON Schema media type, and no other. It is RECOMMNENDED that JSON values specify their schema so that user agents can interpret the instance and retain the self-descriptive characteristics. This avoides the need for out-of-band information about instance data. Two approaches are recommended for declaring the - relation to the schema that describes the meaning of a JSON instance's (or collection + relation to the schema that describes the meaning of a JSON instance's (or collection of instances) structure. A MIME type parameter named "profile" or a relation of "describedby" (which could be specified by a Link header) may be used: - +
-
- + or if the content is being transferred by a protocol (such as HTTP) that provides headers, a Link header can be used: - +
; rel="describedby" ]]>
- - Instances MAY specify multiple schemas, to indicate all the schemas that - are applicable to the data, and the data SHOULD be valid by all the schemas. - The instance data MAY have multiple schemas - that it is described by (the instance data SHOULD be valid for those schemas). - Or if the document is a collection of instances, the collection MAY contain - instances from different schemas. The mechanism for referencing a schema is - determined by the media type of the instance (if it provides a method for + + Instances MAY specify multiple schemas, to indicate all the schemas that + are applicable to the data, and the data SHOULD be valid by all the schemas. + The instance data MAY have multiple schemas + that it is described by (the instance data SHOULD be valid for those schemas). + Or if the document is a collection of instances, the collection MAY contain + instances from different schemas. The mechanism for referencing a schema is + determined by the media type of the instance (if it provides a method for referencing schemas).
- +
- JSON Schemas can themselves be described using JSON Schemas. + JSON Schemas can themselves be described using JSON Schemas. A self-describing JSON Schema for the core JSON Schema can - be found at http://json-schema.org/schema for the latest version or - http://json-schema.org/draft-04/schema for the draft-04 version. The hyper schema - self-description can be found at http://json-schema.org/hyper-schema + be found at http://json-schema.org/schema for the latest version or + http://json-schema.org/draft-04/schema for the draft-04 version. The hyper schema + self-description can be found at http://json-schema.org/hyper-schema or http://json-schema.org/draft-04/hyper-schema. All schemas used within a protocol with a media type specified SHOULD include a MIME parameter that refers to the self-descriptive hyper schema or another schema that extends this hyper schema: - +
- @@ -273,15 +273,15 @@ Content-Type: application/json;
- +
- A JSON Schema is a JSON object that defines various attributes + A JSON Schema is a JSON object that defines various attributes (including usage and valid values) of a JSON value. JSON Schema has recursive capabilities; there are a number of elements in the structure that allow for nested JSON Schemas. - +
An example JSON Schema could look like: @@ -305,17 +305,17 @@ Content-Type: application/json; ]]>
- + A JSON Schema object MAY have any of the following optional properties: - + - +
- This attribute defines what the primitive type or the schema of the instance MUST be in order to validate. + This attribute defines what the primitive type or the schema of the instance MUST be in order to validate. This attribute can take one of two forms: @@ -332,16 +332,16 @@ Content-Type: application/json; Instance MAY be of any type, including null. - + An array of one or more simple or schema types. - The instance value is valid if it is of the same type as one of the simple types, or valid by one of the schemas, in the array. + The instance value is valid if it is of the same type as one of the simple types, or valid by one of the schemas, in the array. - - If this attribute is not specified, then all value types are accepted. + + If this attribute is not specified, then all value types are accepted. - +
For example, a schema that defines if an instance can be a string or a number would be: @@ -352,37 +352,37 @@ Content-Type: application/json; ]]>
- +
This attribute is an object with properties that specify the schemas for the properties of the instance object. - In this attribute's object, each property value MUST be a schema. + In this attribute's object, each property value MUST be a schema. When the instance value is an object, the value of the instance's properties MUST be valid according to the schemas with the same property names specified in this attribute. Objects are unordered, so therefore the order of the instance properties or attribute properties MUST NOT determine validation success.
- +
- This attribute is an object that defines the schema for a set of property names of an object instance. - The name of each property of this attribute's object is a regular expression pattern in the ECMA 262/Perl 5 format, while the value is a schema. + This attribute is an object that defines the schema for a set of property names of an object instance. + The name of each property of this attribute's object is a regular expression pattern in the ECMA 262/Perl 5 format, while the value is a schema. If the pattern matches the name of a property on the instance object, the value of the instance's property MUST be valid against the pattern name's schema value.
- +
- This attribute specifies how any instance property that is not explicitly defined by either the "properties" or "patternProperties" attributes (hereafter referred to as "additional properties") is handled. If specified, the value MUST be a schema or a boolean. + This attribute specifies how any instance property that is not explicitly defined by either the "properties" or "patternProperties" attributes (hereafter referred to as "additional properties") is handled. If specified, the value MUST be a schema or a boolean. If a schema is provided, then all additional properties MUST be valid according to the schema. If false is provided, then no additional properties are allowed. The default value is an empty schema, which allows any value for additional properties.
- +
This attribute provides the allowed items in an array instance. If specified, this attribute MUST be a schema or an array of schemas. When this attribute value is a schema and the instance value is an array, then all the items in the array MUST be valid according to the schema. When this attribute value is an array of schemas and the instance value is an array, each position in the instance array MUST be valid according to the schema in the corresponding position for this array. This called tuple typing. When tuple typing is used, additional items are allowed, disallowed, or constrained by the "additionalItems" attribute the same way as "additionalProperties" for objects is.
- +
This attribute specifies how any item in the array instance that is not explicitly defined by "items" (hereafter referred to as "additional items") is handled. If specified, the value MUST be a schema or a boolean. If a schema is provided: @@ -395,16 +395,16 @@ Content-Type: application/json; If false is provided, then any additional items in the array are not allowed. The default value is an empty schema, which allows any value for additional items.
- +
This attribute is an array of strings that defines all the property names that must exist on the object instance.
- +
This attribute is an object that specifies the requirements of a property on an object instance. If an object instance has a property with the same name as a property in this attribute's object, then the instance must be valid against the attribute's property value (hereafter referred to as the "dependency value"). The dependency value can take one of two forms: - + If the dependency value is a string, then the instance object MUST have a property with the same name as the dependency value. @@ -416,44 +416,44 @@ Content-Type: application/json;
- +
This attribute defines the minimum value of the instance property when the type of the instance value is a number.
- +
This attribute defines the maximum value of the instance property when the type of the instance value is a number.
- +
This attribute indicates if the value of the instance (if the instance is a number) can not equal the number defined by the "minimum" attribute. This is false by default, meaning the instance value can be greater then or equal to the minimum value.
- +
This attribute indicates if the value of the instance (if the instance is a number) can not equal the number defined by the "maximum" attribute. This is false by default, meaning the instance value can be less then or equal to the maximum value.
- +
This attribute defines the minimum number of values in an array when the array is the instance value.
- +
This attribute defines the maximum number of values in an array when the array is the instance value.
- +
This attribute defines the minimum number of properties required on an object instance.
- +
This attribute defines the maximum number of properties the object instance can have.
- +
This attribute indicates that all items in an array instance MUST be unique (contains no two identical values). Two instance are consider equal if they are both of the same type and: - + are null; or are booleans/numbers/strings and have the same value; or @@ -462,43 +462,43 @@ Content-Type: application/json;
- +
When the instance value is a string, this provides a regular expression that a string instance MUST match in order to be valid. Regular expressions SHOULD follow the regular expression specification from ECMA 262/Perl 5
- +
When the instance value is a string, this defines the minimum length of the string.
- +
When the instance value is a string, this defines the maximum length of the string.
- +
This provides an enumeration of all possible values that are valid for the instance property. This MUST be an array, and each item in the array represents a possible value for the instance value. If this attribute is defined, the instance value MUST be one of the values in the array in order for the schema to be valid. Comparison of enum values uses the same algorithm as defined in "uniqueItems".
- +
This attribute defines the default value of the instance when the instance is undefined.
- +
This attribute is a string that provides a short description of the instance property.
- +
This attribute is a string that provides a full description of the of purpose the instance property.
- +
This attribute defines what value the number instance must be divisible by with no remainder (the result of the division must be an integer.) The value of this attribute SHOULD NOT be 0.
- +
This attribute takes the same values as the "type" attribute, however if the instance matches the type or if this value is an array and the instance matches any type or schema in the array, then this instance is not valid.
- +
The value of this property MUST be another schema which will provide a base schema which the current schema will inherit from. The inheritance rules are such that any instance that is valid according to the current schema MUST be valid according to the referenced schema. This MAY also be an array, in which case, the instance MUST be valid for all the schemas in the array. A schema that extends another schema MAY define additional attributes, constrain existing attributes, or add other constraints. @@ -506,7 +506,7 @@ Content-Type: application/json; instance against all constraints in the extending schema as well as the extended schema(s). More optimized implementations that merge schemas are possible, but are not required. Some examples of using "extends": - +
- +
- +
This attribute defines the current URI of this schema (this attribute is @@ -553,28 +553,28 @@ Content-Type: application/json; is also used to construct relative references such as for $ref.
- +
- This attribute defines a URI of a schema that contains the full representation of this schema. - When a validator encounters this attribute, it SHOULD replace the current schema with the schema referenced by the value's URI (if known and available) and re-validate the instance. + This attribute defines a URI of a schema that contains the full representation of this schema. + When a validator encounters this attribute, it SHOULD replace the current schema with the schema referenced by the value's URI (if known and available) and re-validate the instance. This URI MAY be relative or absolute, and relative URIs SHOULD be resolved against the URI of the current schema.
- +
- This attribute defines a URI of a JSON Schema that is the schema of the current schema. + This attribute defines a URI of a JSON Schema that is the schema of the current schema. When this attribute is defined, a validator SHOULD use the schema referenced by the value's URI (if known and available) when resolving Hyper Schemalinks. - + - A validator MAY use this attribute's value to determine which version of JSON Schema the current schema is written in, and provide the appropriate validation features and behavior. + A validator MAY use this attribute's value to determine which version of JSON Schema the current schema is written in, and provide the appropriate validation features and behavior. Therefore, it is RECOMMENDED that all schema authors include this attribute in their schemas to prevent conflicts with future JSON Schema specification changes.
- +
The following attributes are specified in addition to those @@ -586,30 +586,30 @@ Content-Type: application/json; essentially describes plain JSON (no constraints on the structures). Addition of attributes provides additive information for user agents. - +
- The value of the links property MUST be an array, where each item + The value of the links property MUST be an array, where each item in the array is a link description object which describes the link relations of the instances. - + - +
- A link description object is used to describe link relations. In - the context of a schema, it defines the link relations of the + A link description object is used to describe link relations. In + the context of a schema, it defines the link relations of the instances of the schema, and can be parameterized by the instance - values. The link description format can be used without JSON Schema, + values. The link description format can be used without JSON Schema, and use of this format can be declared by referencing the normative link description - schema as the the schema for the data structure that uses the - links. The URI of the normative link description schema is: + schema as the the schema for the data structure that uses the + links. The URI of the normative link description schema is: http://json-schema.org/links (latest version) or http://json-schema.org/draft-04/links (draft-04 version). - +
The value of the "href" link description property @@ -617,19 +617,19 @@ Content-Type: application/json; of the instance property SHOULD be resolved as a URI-Reference per RFC 3986 and MAY be a relative URI. The base URI to be used for relative resolution SHOULD be the URI used to retrieve the instance object (not the schema) - when used within a schema. Also, when links are used within a schema, the URI - SHOULD be parametrized by the property values of the instance + when used within a schema. Also, when links are used within a schema, the URI + SHOULD be parametrized by the property values of the instance object, if property values exist for the corresponding variables in the template (otherwise they MAY be provided from alternate sources, like user input). - + Instance property values SHOULD be substituted into the URIs where matching braces ('{', '}') are found surrounding zero or more characters, creating an expanded URI. Instance property value substitutions are resolved by using the text between the braces to denote the property name - from the instance to get the value to substitute. - + from the instance to get the value to substitute. +
For example, if an href value is defined: @@ -639,7 +639,7 @@ http://somesite.com/{id} Then it would be resolved by replace the value of the "id" property value from the instance object.
- +
If the value of the "id" property was "45", the expanded URI would be: @@ -648,23 +648,23 @@ http://somesite.com/45 ]]>
- - If matching braces are found with the string "@" (no quotes) between the braces, then the + + If matching braces are found with the string "@" (no quotes) between the braces, then the actual instance value SHOULD be used to replace the braces, rather than a property value. - This should only be used in situations where the instance is a scalar (string, + This should only be used in situations where the instance is a scalar (string, boolean, or number), and not for objects or arrays.
- +
- The value of the "rel" property indicates the name of the + The value of the "rel" property indicates the name of the relation to the target resource. The relation to the target SHOULD be interpreted as specifically from the instance object that the schema (or sub-schema) applies to, not just the top level resource that contains the object within its hierarchy. If a resource JSON representation contains a sub object with a property interpreted as a link, that sub-object holds the relation with the target. A relation to target from the top level resource MUST be indicated with the schema describing the top level JSON representation. - + Relationship definitions SHOULD NOT be media type dependent, and users are encouraged to utilize existing accepted relation definitions, including those in existing relation registries (see RFC 4287). However, we define these relations here for clarity of normative interpretation within the context of JSON hyper schema defined relations: - + If the relation value is "self", when this property is encountered in @@ -672,15 +672,15 @@ http://somesite.com/45 treated as a full representation of the target resource identified by the specified URI. - + This indicates that the target of the link is the full representation for the instance object. The object that contains this link possibly may not be the full representation. - + This indicates the target of the link is the schema for the instance object. This MAY be used to specifically denote the schemas of objects within a JSON object hierarchy, facilitating polymorphic type data structures. - + This relation indicates that the target of the link SHOULD be treated as the root or the body of the representation for the @@ -690,7 +690,7 @@ http://somesite.com/45 - + The following relations are applicable for schemas (the schema as the "from" resource in the relation): @@ -699,7 +699,7 @@ http://somesite.com/45 This indicates a target to use for creating new instances of a schema. This link definition SHOULD be a submission link with a non-safe method (like POST). - +
For example, if a schema is defined: @@ -720,7 +720,7 @@ http://somesite.com/45 ]]>
- +
And if a collection of instance resource's JSON representation was retrieved: @@ -744,41 +744,41 @@ GET /Resource/ The "children" collection would be located at "/Resource/?upId=thing".
- +
This property value is a string that defines the templating language used in the "href" attribute. If no templating language is defined, then the default Link Description Object templating langauge is used.
- +
This property value is a schema that defines the expected structure of the JSON representation of the target of the link.
- +
- The following properties also apply to link definition objects, and - provide functionality analogous to HTML forms, in providing a + The following properties also apply to link definition objects, and + provide functionality analogous to HTML forms, in providing a means for submitting extra (often user supplied) information to send to a server. - +
- This attribute defines which method can be used to access the target resource. - In an HTTP environment, this would be "GET" or "POST" (other HTTP methods - such as "PUT" and "DELETE" have semantics that are clearly implied by - accessed resources, and do not need to be defined here). + This attribute defines which method can be used to access the target resource. + In an HTTP environment, this would be "GET" or "POST" (other HTTP methods + such as "PUT" and "DELETE" have semantics that are clearly implied by + accessed resources, and do not need to be defined here). This defaults to "GET".
- +
If present, this property indicates a query media type format that the server - supports for querying or posting to the collection of instances at the target - resource. The query can be + supports for querying or posting to the collection of instances at the target + resource. The query can be suffixed to the target URI to query the collection with property-based constraints on the resources that SHOULD be returned from the server or used to post data to the resource (depending on the method). - +
For example, with the following schema: @@ -799,7 +799,7 @@ GET /Resource/ This indicates that the client can query the server for instances that have a specific name.
- +
For example: @@ -809,23 +809,23 @@ GET /Resource/
- If no enctype or method is specified, only the single URI specified by - the href property is defined. If the method is POST, "application/json" is + If no enctype or method is specified, only the single URI specified by + the href property is defined. If the method is POST, "application/json" is the default media type.
- +
This attribute contains a schema which defines the acceptable structure of the submitted - request (for a GET request, this schema would define the properties for the query string + request (for a GET request, this schema would define the properties for the query string and for a POST request, this would define the body).
- +
This property indicates the fragment resolution protocol to use for @@ -835,62 +835,62 @@ GET /Resource/ protocol is "json-pointer", which is defined below. Other fragment resolution protocols MAY be used, but are not defined in this document. - + The fragment identifier is based on RFC 3986, Sec 5, and defines the mechanism for resolving references to entities within a document. - +
The "json-pointer" fragment resolution protocol uses a JSON Pointer to resolve fragment identifiers in URIs within instance representations.
- + - +
This attribute indicates that the instance value SHOULD NOT be changed. Attempts by a user agent to modify the value of this property are expected to be rejected by a server.
- +
If the instance property value is a string, this attribute defines that the string SHOULD be interpreted as binary data and decoded using the encoding named by this schema property. RFC 2045, Sec 6.1 lists the possible values for this property.
- +
- This attribute is a URI that defines what the instance's URI MUST start with in order to validate. - The value of the "pathStart" attribute MUST be resolved as per RFC 3986, Sec 5, + This attribute is a URI that defines what the instance's URI MUST start with in order to validate. + The value of the "pathStart" attribute MUST be resolved as per RFC 3986, Sec 5, and is relative to the instance's URI. - + - When multiple schemas have been referenced for an instance, the user agent - can determine if this schema is applicable for a particular instance by + When multiple schemas have been referenced for an instance, the user agent + can determine if this schema is applicable for a particular instance by determining if the URI of the instance begins with the the value of the "pathStart" - attribute. If the URI of the instance does not start with this URI, - or if another schema specifies a starting URI that is longer and also matches the - instance, this schema SHOULD NOT be applied to the instance. Any schema - that does not have a pathStart attribute SHOULD be considered applicable + attribute. If the URI of the instance does not start with this URI, + or if another schema specifies a starting URI that is longer and also matches the + instance, this schema SHOULD NOT be applied to the instance. Any schema + that does not have a pathStart attribute SHOULD be considered applicable to all the instances for which it is referenced.
- +
This attribute defines the media type of the instance representations that this schema is defining.
- +
- This specification is a sub-type of the JSON format, and - consequently the security considerations are generally the same as RFC 4627. + This specification is a sub-type of the JSON format, and + consequently the security considerations are generally the same as RFC 4627. However, an additional issue is that when link relation of "self" - is used to denote a full representation of an object, the user agent + is used to denote a full representation of an object, the user agent SHOULD NOT consider the representation to be the authoritative representation of the resource denoted by the target URI if the target URI is not - equivalent to or a sub-path of the the URI used to request the resource + equivalent to or a sub-path of the the URI used to request the resource representation which contains the target URI with the "self" link. - +
For example, if a hyper schema was defined: @@ -904,7 +904,7 @@ GET /Resource/ ]]>
- +
And a resource was requested from somesite.com: @@ -941,22 +941,22 @@ Content-Type: application/json; profile=/schema-for-this-data
- +
The proposed MIME media type for JSON Schema is "application/schema+json". Type name: application Subtype name: schema+json Required parameters: profile - The value of the profile parameter SHOULD be a URI (relative or absolute) that - refers to the schema used to define the structure of this structure (the + The value of the profile parameter SHOULD be a URI (relative or absolute) that + refers to the schema used to define the structure of this structure (the meta-schema). Normally the value would be http://json-schema.org/draft-04/hyper-schema, but it is allowable to use other schemas that extend the hyper schema's meta- schema. Optional parameters: pretty The value of the pretty parameter MAY be true or false to indicate if additional whitespace has been included to make the JSON representation easier to read. - +
This registry is maintained by IANA per RFC 4287 and this specification adds @@ -968,7 +968,7 @@ Content-Type: application/json; profile=/schema-for-this-data
- + @@ -1019,7 +1019,7 @@ Content-Type: application/json; profile=/schema-for-this-data Improved wording of many sections.
- + Added example and verbiage to "extends" attribute. @@ -1043,7 +1043,7 @@ Content-Type: application/json; profile=/schema-for-this-data Added "$ref" and "$schema" attributes. - + Replaced "maxDecimal" attribute with "divisibleBy" attribute. @@ -1053,13 +1053,13 @@ Content-Type: application/json; profile=/schema-for-this-data Added "targetSchema" attribute to link description object. - + Fixed category and updates from template. - + Initial draft. diff --git a/deps/npm/node_modules/json-schema/lib/links.js b/deps/npm/node_modules/json-schema/lib/links.js index 2f450ff61d2976..2ef3f9fb7d0afe 100644 --- a/deps/npm/node_modules/json-schema/lib/links.js +++ b/deps/npm/node_modules/json-schema/lib/links.js @@ -1,4 +1,4 @@ -/** +/** * JSON Schema link handler * Copyright (c) 2007 Kris Zyp SitePen (www.sitepen.com) * Licensed under the MIT (MIT-LICENSE.txt) license. @@ -25,11 +25,11 @@ exports.getLink = function(relation, instance, schema){ // gets the URI of the link for the given relation based on the instance and schema // for example: // getLink( - // "brother", - // {"brother_id":33}, + // "brother", + // {"brother_id":33}, // {links:[{rel:"brother", href:"Brother/{brother_id}"}]}) -> // "Brother/33" - var links = schema.__linkTemplates; + var links = schema.__linkTemplates; if(!links){ links = {}; var schemaLinks = schema.links; diff --git a/deps/npm/node_modules/json-schema/lib/validate.js b/deps/npm/node_modules/json-schema/lib/validate.js index 4d0b537941e3cc..4b6108800aafb5 100644 --- a/deps/npm/node_modules/json-schema/lib/validate.js +++ b/deps/npm/node_modules/json-schema/lib/validate.js @@ -207,8 +207,8 @@ var validate = exports._validate = function(/*Any*/instance,/*Object*/schema,/*O if(typeof instance != 'object' || instance instanceof Array){ errors.push({property:path,message:"an object is required"}); } - - for(var i in objTypeDef){ + + for(var i in objTypeDef){ if(objTypeDef.hasOwnProperty(i)){ var value = instance[i]; // skip _not_ specified properties diff --git a/deps/npm/node_modules/npm-bundled/index.js b/deps/npm/node_modules/npm-bundled/index.js index bde0acd164b7d1..197a1bcb99a153 100644 --- a/deps/npm/node_modules/npm-bundled/index.js +++ b/deps/npm/node_modules/npm-bundled/index.js @@ -10,6 +10,9 @@ const fs = require('fs') const path = require('path') const EE = require('events').EventEmitter +// we don't care about the package bins, but we share a pj cache +// with other modules that DO care about it, so keep it nice. +const normalizePackageBin = require('npm-normalize-package-bin') class BundleWalker extends EE { constructor (opt) { @@ -84,7 +87,7 @@ class BundleWalker extends EE { onPackageJson (pj, data) { try { - this.package = JSON.parse(data + '') + this.package = normalizePackageBin(JSON.parse(data + '')) } catch (er) { return this.done() } @@ -92,17 +95,22 @@ class BundleWalker extends EE { this.onPackage(this.package) } + allDepsBundled (pkg) { + return Object.keys(pkg.dependencies || {}).concat( + Object.keys(pkg.optionalDependencies || {})) + } + onPackage (pkg) { // all deps are bundled if we got here as a child. // otherwise, only bundle bundledDeps // Get a unique-ified array with a short-lived Set - const bdRaw = this.parent - ? Object.keys(pkg.dependencies || {}).concat( - Object.keys(pkg.optionalDependencies || {})) + const bdRaw = this.parent ? this.allDepsBundled(pkg) : pkg.bundleDependencies || pkg.bundledDependencies || [] const bd = Array.from(new Set( - Array.isArray(bdRaw) ? bdRaw : Object.keys(bdRaw))) + Array.isArray(bdRaw) ? bdRaw + : bdRaw === true ? this.allDepsBundled(pkg) + : Object.keys(bdRaw))) if (!bd.length) return this.done() diff --git a/deps/npm/node_modules/npm-bundled/package.json b/deps/npm/node_modules/npm-bundled/package.json index 48297374004536..18c578a5cb72da 100644 --- a/deps/npm/node_modules/npm-bundled/package.json +++ b/deps/npm/node_modules/npm-bundled/package.json @@ -1,8 +1,8 @@ { "_from": "npm-bundled@^1.0.1", - "_id": "npm-bundled@1.0.6", + "_id": "npm-bundled@1.1.1", "_inBundle": false, - "_integrity": "sha512-8/JCaftHwbd//k6y2rEWp6k1wxVfpFzB6t1p825+cUb7Ym2XQfhwIC5KwhrvzZRJu+LtDE585zVaS32+CGtf0g==", + "_integrity": "sha512-gqkfgGePhTpAEgUsGEgcq1rqPXA+tv/aVBlgEzfXwA1yiUJF7xtEt3CtVwOjNYQOVknDk0F20w58Fnm3EtG0fA==", "_location": "/npm-bundled", "_phantomChildren": {}, "_requested": { @@ -18,10 +18,10 @@ "_requiredBy": [ "/npm-packlist" ], - "_resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-1.0.6.tgz", - "_shasum": "e7ba9aadcef962bb61248f91721cd932b3fe6bdd", + "_resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-1.1.1.tgz", + "_shasum": "1edd570865a94cdb1bc8220775e29466c9fb234b", "_spec": "npm-bundled@^1.0.1", - "_where": "/Users/aeschright/code/npm-release/node_modules/npm-packlist", + "_where": "/Users/isaacs/dev/npm/cli/node_modules/npm-packlist", "author": { "name": "Isaac Z. Schlueter", "email": "i@izs.me", @@ -31,6 +31,9 @@ "url": "https://github.com/npm/npm-bundled/issues" }, "bundleDependencies": false, + "dependencies": { + "npm-normalize-package-bin": "^1.0.1" + }, "deprecated": false, "description": "list things in node_modules that are bundledDependencies, or transitive dependencies thereof", "devDependencies": { @@ -56,5 +59,5 @@ "preversion": "npm test", "test": "tap test/*.js -J --100" }, - "version": "1.0.6" + "version": "1.1.1" } diff --git a/deps/npm/node_modules/npm-normalize-package-bin/.github/settings.yml b/deps/npm/node_modules/npm-normalize-package-bin/.github/settings.yml new file mode 100644 index 00000000000000..4aaa0dd57e4ad0 --- /dev/null +++ b/deps/npm/node_modules/npm-normalize-package-bin/.github/settings.yml @@ -0,0 +1,2 @@ +--- +_extends: 'open-source-project-boilerplate' diff --git a/deps/npm/node_modules/npm-normalize-package-bin/.npmignore b/deps/npm/node_modules/npm-normalize-package-bin/.npmignore new file mode 100644 index 00000000000000..3870bd5bb72079 --- /dev/null +++ b/deps/npm/node_modules/npm-normalize-package-bin/.npmignore @@ -0,0 +1,24 @@ +# ignore most things, include some others +/* +/.* + +!bin/ +!lib/ +!docs/ +!package.json +!package-lock.json +!README.md +!CONTRIBUTING.md +!LICENSE +!CHANGELOG.md +!example/ +!scripts/ +!tap-snapshots/ +!test/ +!.github/ +!.travis.yml +!.gitignore +!.gitattributes +!coverage-map.js +!map.js +!index.js diff --git a/deps/npm/node_modules/npm-normalize-package-bin/LICENSE b/deps/npm/node_modules/npm-normalize-package-bin/LICENSE new file mode 100644 index 00000000000000..19cec97b184683 --- /dev/null +++ b/deps/npm/node_modules/npm-normalize-package-bin/LICENSE @@ -0,0 +1,15 @@ +The ISC License + +Copyright (c) npm, Inc. + +Permission to use, copy, modify, and/or distribute this software for any +purpose with or without fee is hereby granted, provided that the above +copyright notice and this permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR +IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. diff --git a/deps/npm/node_modules/npm-normalize-package-bin/README.md b/deps/npm/node_modules/npm-normalize-package-bin/README.md new file mode 100644 index 00000000000000..65ba316a0d97ee --- /dev/null +++ b/deps/npm/node_modules/npm-normalize-package-bin/README.md @@ -0,0 +1,14 @@ +# npm-normalize-package-bin + +Turn any flavor of allowable package.json bin into a normalized object. + +## API + +```js +const normalize = require('npm-normalize-package-bin') +const pkg = {name: 'foo', bin: 'bar'} +console.log(normalize(pkg)) // {name:'foo', bin:{foo: 'bar'}} +``` + +Also strips out weird dots and slashes to prevent accidental and/or +malicious bad behavior when the package is installed. diff --git a/deps/npm/node_modules/npm-normalize-package-bin/index.js b/deps/npm/node_modules/npm-normalize-package-bin/index.js new file mode 100644 index 00000000000000..5a738ff82e1e3a --- /dev/null +++ b/deps/npm/node_modules/npm-normalize-package-bin/index.js @@ -0,0 +1,60 @@ +// pass in a manifest with a 'bin' field here, and it'll turn it +// into a properly santized bin object +const {join, basename} = require('path') + +const normalize = pkg => + !pkg.bin ? removeBin(pkg) + : typeof pkg.bin === 'string' ? normalizeString(pkg) + : Array.isArray(pkg.bin) ? normalizeArray(pkg) + : typeof pkg.bin === 'object' ? normalizeObject(pkg) + : removeBin(pkg) + +const normalizeString = pkg => { + if (!pkg.name) + return removeBin(pkg) + pkg.bin = { [pkg.name]: pkg.bin } + return normalizeObject(pkg) +} + +const normalizeArray = pkg => { + pkg.bin = pkg.bin.reduce((acc, k) => { + acc[basename(k)] = k + return acc + }, {}) + return normalizeObject(pkg) +} + +const removeBin = pkg => { + delete pkg.bin + return pkg +} + +const normalizeObject = pkg => { + const orig = pkg.bin + const clean = {} + let hasBins = false + Object.keys(orig).forEach(binKey => { + const base = join('/', basename(binKey.replace(/\\|:/g, '/'))).substr(1) + + if (typeof orig[binKey] !== 'string' || !base) + return + + const binTarget = join('/', orig[binKey]) + .replace(/\\/g, '/').substr(1) + + if (!binTarget) + return + + clean[base] = binTarget + hasBins = true + }) + + if (hasBins) + pkg.bin = clean + else + delete pkg.bin + + return pkg +} + +module.exports = normalize diff --git a/deps/npm/node_modules/npm-normalize-package-bin/package-lock.json b/deps/npm/node_modules/npm-normalize-package-bin/package-lock.json new file mode 100644 index 00000000000000..0d3390d4eee636 --- /dev/null +++ b/deps/npm/node_modules/npm-normalize-package-bin/package-lock.json @@ -0,0 +1,3529 @@ +{ + "name": "npm-normalize-package-bin", + "version": "1.0.1", + "lockfileVersion": 1, + "requires": true, + "dependencies": { + "@babel/code-frame": { + "version": "7.5.5", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.5.5.tgz", + "integrity": "sha512-27d4lZoomVyo51VegxI20xZPuSHusqbQag/ztrBC7wegWoQ1nLREPVSKSW8byhTlzTKyNE4ifaTA6lCp7JjpFw==", + "dev": true, + "requires": { + "@babel/highlight": "^7.0.0" + } + }, + "@babel/generator": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.7.4.tgz", + "integrity": "sha512-m5qo2WgdOJeyYngKImbkyQrnUN1mPceaG5BV+G0E3gWsa4l/jCSryWJdM2x8OuGAOyh+3d5pVYfZWCiNFtynxg==", + "dev": true, + "requires": { + "@babel/types": "^7.7.4", + "jsesc": "^2.5.1", + "lodash": "^4.17.13", + "source-map": "^0.5.0" + }, + "dependencies": { + "source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", + "dev": true + } + } + }, + "@babel/helper-function-name": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.7.4.tgz", + "integrity": "sha512-AnkGIdiBhEuiwdoMnKm7jfPfqItZhgRaZfMg1XX3bS25INOnLPjPG1Ppnajh8eqgt5kPJnfqrRHqFqmjKDZLzQ==", + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "^7.7.4", + "@babel/template": "^7.7.4", + "@babel/types": "^7.7.4" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.7.4.tgz", + "integrity": "sha512-QTGKEdCkjgzgfJ3bAyRwF4yyT3pg+vDgan8DSivq1eS0gwi+KGKE5x8kRcbeFTb/673mkO5SN1IZfmCfA5o+EA==", + "dev": true, + "requires": { + "@babel/types": "^7.7.4" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.7.4.tgz", + "integrity": "sha512-guAg1SXFcVr04Guk9eq0S4/rWS++sbmyqosJzVs8+1fH5NI+ZcmkaSkc7dmtAFbHFva6yRJnjW3yAcGxjueDug==", + "dev": true, + "requires": { + "@babel/types": "^7.7.4" + } + }, + "@babel/highlight": { + "version": "7.5.0", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.5.0.tgz", + "integrity": "sha512-7dV4eu9gBxoM0dAnj/BCFDW9LFU0zvTrkq0ugM7pnHEgguOEeOz1so2ZghEdzviYzQEED0r4EAgpsBChKy1TRQ==", + "dev": true, + "requires": { + "chalk": "^2.0.0", + "esutils": "^2.0.2", + "js-tokens": "^4.0.0" + } + }, + "@babel/parser": { + "version": "7.7.5", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.7.5.tgz", + "integrity": "sha512-KNlOe9+/nk4i29g0VXgl8PEXIRms5xKLJeuZ6UptN0fHv+jDiriG+y94X6qAgWTR0h3KaoM1wK5G5h7MHFRSig==", + "dev": true + }, + "@babel/runtime": { + "version": "7.7.6", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.7.6.tgz", + "integrity": "sha512-BWAJxpNVa0QlE5gZdWjSxXtemZyZ9RmrmVozxt3NUXeZhVIJ5ANyqmMc0JDrivBZyxUuQvFxlvH4OWWOogGfUw==", + "dev": true, + "requires": { + "regenerator-runtime": "^0.13.2" + } + }, + "@babel/template": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.7.4.tgz", + "integrity": "sha512-qUzihgVPguAzXCK7WXw8pqs6cEwi54s3E+HrejlkuWO6ivMKx9hZl3Y2fSXp9i5HgyWmj7RKP+ulaYnKM4yYxw==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.0.0", + "@babel/parser": "^7.7.4", + "@babel/types": "^7.7.4" + } + }, + "@babel/traverse": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.7.4.tgz", + "integrity": "sha512-P1L58hQyupn8+ezVA2z5KBm4/Zr4lCC8dwKCMYzsa5jFMDMQAzaBNy9W5VjB+KAmBjb40U7a/H6ao+Xo+9saIw==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.5.5", + "@babel/generator": "^7.7.4", + "@babel/helper-function-name": "^7.7.4", + "@babel/helper-split-export-declaration": "^7.7.4", + "@babel/parser": "^7.7.4", + "@babel/types": "^7.7.4", + "debug": "^4.1.0", + "globals": "^11.1.0", + "lodash": "^4.17.13" + } + }, + "@babel/types": { + "version": "7.7.4", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.7.4.tgz", + "integrity": "sha512-cz5Ji23KCi4T+YIE/BolWosrJuSmoZeN1EFnRtBwF+KKLi8GG/Z2c2hOJJeCXPk4mwk4QFvTmwIodJowXgttRA==", + "dev": true, + "requires": { + "esutils": "^2.0.2", + "lodash": "^4.17.13", + "to-fast-properties": "^2.0.0" + } + }, + "ajv": { + "version": "6.10.2", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.2.tgz", + "integrity": "sha512-TXtUUEYHuaTEbLZWIKUr5pmBuhDLy+8KYtPYdcV8qC+pOZL+NKqYwvWSRrVXHn+ZmRRAu8vJTAznH7Oag6RVRw==", + "dev": true, + "requires": { + "fast-deep-equal": "^2.0.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + } + }, + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", + "dev": true + }, + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "anymatch": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz", + "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==", + "dev": true, + "requires": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + } + }, + "append-transform": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/append-transform/-/append-transform-1.0.0.tgz", + "integrity": "sha512-P009oYkeHyU742iSZJzZZywj4QRJdnTWffaKuJQLablCZ1uz6/cW4yaRgcDaoQ+uwOxxnt0gRUcwfsNP2ri0gw==", + "dev": true, + "requires": { + "default-require-extensions": "^2.0.0" + } + }, + "archy": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/archy/-/archy-1.0.0.tgz", + "integrity": "sha1-+cjBN1fMHde8N5rHeyxipcKGjEA=", + "dev": true + }, + "arg": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.2.tgz", + "integrity": "sha512-+ytCkGcBtHZ3V2r2Z06AncYO8jz46UEamcspGoU8lHcEbpn6J77QK0vdWvChsclg/tM5XIJC5tnjmPp7Eq6Obg==", + "dev": true + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "dev": true, + "requires": { + "sprintf-js": "~1.0.2" + } + }, + "asn1": { + "version": "0.2.4", + "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", + "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", + "dev": true, + "requires": { + "safer-buffer": "~2.1.0" + } + }, + "assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true + }, + "async-hook-domain": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/async-hook-domain/-/async-hook-domain-1.1.3.tgz", + "integrity": "sha512-ZovMxSbADV3+biB7oR1GL5lGyptI24alp0LWHlmz1OFc5oL47pz3EiIF6nXOkDW7yLqih4NtsiYduzdDW0i+Wg==", + "dev": true, + "requires": { + "source-map-support": "^0.5.11" + } + }, + "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.7.0", + "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", + "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", + "dev": true + }, + "aws4": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.9.0.tgz", + "integrity": "sha512-Uvq6hVe90D0B2WEnUqtdgY1bATGz3mw33nH9Y+dmA+w5DHvUmBgkr5rM/KCHpCsiFNRUfokW/szpPPgMK2hm4A==", + "dev": true + }, + "balanced-match": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", + "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", + "dev": true + }, + "bcrypt-pbkdf": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", + "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", + "dev": true, + "requires": { + "tweetnacl": "^0.14.3" + } + }, + "binary-extensions": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.0.0.tgz", + "integrity": "sha512-Phlt0plgpIIBOGTT/ehfFnbNlfsDEiqmzE2KRXoX1bLIlir4X/MR+zSyBEkL05ffWgnRSf/DXv+WrUAVr93/ow==", + "dev": true + }, + "bind-obj-methods": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/bind-obj-methods/-/bind-obj-methods-2.0.0.tgz", + "integrity": "sha512-3/qRXczDi2Cdbz6jE+W3IflJOutRVica8frpBn14de1mBOkzDo+6tY33kNhvkw54Kn3PzRRD2VnGbGPcTAk4sw==", + "dev": true + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "braces": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", + "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", + "dev": true, + "requires": { + "fill-range": "^7.0.1" + } + }, + "browser-process-hrtime": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz", + "integrity": "sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow==", + "dev": true + }, + "buffer-from": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", + "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", + "dev": true + }, + "caching-transform": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/caching-transform/-/caching-transform-3.0.2.tgz", + "integrity": "sha512-Mtgcv3lh3U0zRii/6qVgQODdPA4G3zhG+jtbCWj39RXuUFTMzH0vcdMtaJS1jPowd+It2Pqr6y3NJMQqOqCE2w==", + "dev": true, + "requires": { + "hasha": "^3.0.0", + "make-dir": "^2.0.0", + "package-hash": "^3.0.0", + "write-file-atomic": "^2.4.2" + }, + "dependencies": { + "write-file-atomic": { + "version": "2.4.3", + "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.4.3.tgz", + "integrity": "sha512-GaETH5wwsX+GcnzhPgKcKjJ6M2Cq3/iZp1WyY/X1CSqrW+jVNM9Y7D8EC2sM4ZG/V8wZlSniJnCKWPmBYAucRQ==", + "dev": true, + "requires": { + "graceful-fs": "^4.1.11", + "imurmurhash": "^0.1.4", + "signal-exit": "^3.0.2" + } + } + } + }, + "camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", + "dev": true + }, + "caseless": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", + "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", + "dev": true + }, + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "chokidar": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.3.0.tgz", + "integrity": "sha512-dGmKLDdT3Gdl7fBUe8XK+gAtGmzy5Fn0XkkWQuYxGIgWVPPse2CxFA5mtrlD0TOHaHjEUqkWNyP1XdHoJES/4A==", + "dev": true, + "requires": { + "anymatch": "~3.1.1", + "braces": "~3.0.2", + "fsevents": "~2.1.1", + "glob-parent": "~5.1.0", + "is-binary-path": "~2.1.0", + "is-glob": "~4.0.1", + "normalize-path": "~3.0.0", + "readdirp": "~3.2.0" + } + }, + "cliui": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-4.1.0.tgz", + "integrity": "sha512-4FG+RSG9DL7uEwRUZXZn3SS34DiDPfzP0VOiEwtUWlE+AR2EIg+hSyvrIgUUfhdgR/UkAeW2QHgeP+hWrXs7jQ==", + "dev": true, + "requires": { + "string-width": "^2.1.1", + "strip-ansi": "^4.0.0", + "wrap-ansi": "^2.0.0" + } + }, + "code-point-at": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", + "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", + "dev": true + }, + "color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "requires": { + "color-name": "1.1.3" + } + }, + "color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", + "dev": true + }, + "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 + }, + "combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "dev": true, + "requires": { + "delayed-stream": "~1.0.0" + } + }, + "commander": { + "version": "2.20.3", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", + "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", + "dev": true, + "optional": true + }, + "commondir": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", + "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", + "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=", + "dev": true + }, + "convert-source-map": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.7.0.tgz", + "integrity": "sha512-4FJkXzKXEDB1snCFZlLP4gpC3JILicCpGbzG9f9G7tGqGCzETQ2hWPrcinA9oU4wtf2biUaEH5065UnMeR33oA==", + "dev": true, + "requires": { + "safe-buffer": "~5.1.1" + }, + "dependencies": { + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "dev": true + } + } + }, + "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=", + "dev": true + }, + "coveralls": { + "version": "3.0.9", + "resolved": "https://registry.npmjs.org/coveralls/-/coveralls-3.0.9.tgz", + "integrity": "sha512-nNBg3B1+4iDox5A5zqHKzUTiwl2ey4k2o0NEcVZYvl+GOSJdKBj4AJGKLv6h3SvWch7tABHePAQOSZWM9E2hMg==", + "dev": true, + "requires": { + "js-yaml": "^3.13.1", + "lcov-parse": "^1.0.0", + "log-driver": "^1.2.7", + "minimist": "^1.2.0", + "request": "^2.88.0" + } + }, + "cp-file": { + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/cp-file/-/cp-file-6.2.0.tgz", + "integrity": "sha512-fmvV4caBnofhPe8kOcitBwSn2f39QLjnAnGq3gO9dfd75mUytzKNZB1hde6QHunW2Rt+OwuBOMc3i1tNElbszA==", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "make-dir": "^2.0.0", + "nested-error-stacks": "^2.0.0", + "pify": "^4.0.1", + "safe-buffer": "^5.0.1" + } + }, + "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.0.1", + "which": "^1.2.9" + }, + "dependencies": { + "which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + } + } + }, + "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" + } + }, + "debug": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", + "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", + "dev": true, + "requires": { + "ms": "^2.1.1" + } + }, + "decamelize": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", + "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", + "dev": true + }, + "default-require-extensions": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/default-require-extensions/-/default-require-extensions-2.0.0.tgz", + "integrity": "sha1-9fj7sYp9bVCyH2QfZJ67Uiz+JPc=", + "dev": true, + "requires": { + "strip-bom": "^3.0.0" + } + }, + "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 + }, + "diff": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.1.tgz", + "integrity": "sha512-s2+XdvhPCOF01LRQBC8hf4vhbVmI2CGS5aZnxLJlT5FtdhPCDFq80q++zK2KlrVorVDdL5BOGZ/VfLrVtYNF+Q==", + "dev": true + }, + "diff-frag": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/diff-frag/-/diff-frag-1.0.1.tgz", + "integrity": "sha512-6/v2PC/6UTGcWPPetb9acL8foberUg/CtPdALeJUdD1B/weHNvzftoo00gYznqHGRhHEbykUGzqfG9RWOSr5yw==", + "dev": true + }, + "ecc-jsbn": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", + "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", + "dev": true, + "requires": { + "jsbn": "~0.1.0", + "safer-buffer": "^2.1.0" + } + }, + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", + "dev": true + }, + "error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "dev": true, + "requires": { + "is-arrayish": "^0.2.1" + } + }, + "es6-error": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/es6-error/-/es6-error-4.1.1.tgz", + "integrity": "sha512-Um/+FxMr9CISWh0bi5Zv0iOD+4cFh5qLeks1qhAopKVAJw3drgKbKySikp7wGhDL0HPeaja0P5ULZrxLkniUVg==", + "dev": true + }, + "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 + }, + "esm": { + "version": "3.2.25", + "resolved": "https://registry.npmjs.org/esm/-/esm-3.2.25.tgz", + "integrity": "sha512-U1suiZ2oDVWv4zPO56S0NcR5QriEahGtdN2OR6FiOG4WJvcjBVFB0qI4+eKoWFH483PKGuLuu6V8Z4T5g63UVA==", + "dev": true + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "dev": true + }, + "esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true + }, + "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 + }, + "extend": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", + "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", + "dev": true + }, + "extsprintf": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", + "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", + "dev": true + }, + "fast-deep-equal": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", + "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", + "dev": true + }, + "fast-json-stable-stringify": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", + "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", + "dev": true + }, + "fill-range": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", + "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", + "dev": true, + "requires": { + "to-regex-range": "^5.0.1" + } + }, + "find-cache-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", + "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", + "dev": true, + "requires": { + "commondir": "^1.0.1", + "make-dir": "^2.0.0", + "pkg-dir": "^3.0.0" + } + }, + "find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "dev": true, + "requires": { + "locate-path": "^3.0.0" + } + }, + "findit": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/findit/-/findit-2.0.0.tgz", + "integrity": "sha1-ZQnwEmr0wXhVHPqZOU4DLhOk1W4=", + "dev": true + }, + "flow-parser": { + "version": "0.113.0", + "resolved": "https://registry.npmjs.org/flow-parser/-/flow-parser-0.113.0.tgz", + "integrity": "sha512-+hRyEB1sVLNMTMniDdM1JIS8BJ3HUL7IFIJaxX+t/JUy0GNYdI0Tg1QLx8DJmOF8HeoCrUDcREpnDAc/pPta3w==", + "dev": true + }, + "flow-remove-types": { + "version": "2.113.0", + "resolved": "https://registry.npmjs.org/flow-remove-types/-/flow-remove-types-2.113.0.tgz", + "integrity": "sha512-Rp4hN/JlGmUjNxXuBXr6Or+MgDH9xKc+ZiUSRzl/fbpiH9RaCPAQKsgVEYNPcIE26q6RpAuMQfvzR0jQfuwUZQ==", + "dev": true, + "requires": { + "flow-parser": "^0.113.0", + "pirates": "^3.0.2", + "vlq": "^0.2.1" + } + }, + "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", + "signal-exit": "^3.0.0" + } + }, + "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.3.3", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", + "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", + "dev": true, + "requires": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.6", + "mime-types": "^2.1.12" + } + }, + "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=", + "dev": true + }, + "fsevents": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.2.tgz", + "integrity": "sha512-R4wDiBwZ0KzpgOWetKDug1FZcYhqYnUYKtfZYt4mD5SBz76q0KR4Q9o7GIPamsVPGmW3EYPPJ0dOOjvx32ldZA==", + "dev": true, + "optional": true + }, + "function-loop": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/function-loop/-/function-loop-1.0.2.tgz", + "integrity": "sha512-Iw4MzMfS3udk/rqxTiDDCllhGwlOrsr50zViTOO/W6lS/9y6B1J0BD2VZzrnWUYBJsl3aeqjgR5v7bWWhZSYbA==", + "dev": true + }, + "get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", + "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", + "dev": true + }, + "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" + } + }, + "glob": { + "version": "7.1.6", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", + "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "glob-parent": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.0.tgz", + "integrity": "sha512-qjtRgnIVmOfnKUE3NJAQEdk+lKrxfw8t5ke7SXtfMTHcjsBfOfWXCQfdb30zfDoZQ2IRSIiidmjtbHZPZ++Ihw==", + "dev": true, + "requires": { + "is-glob": "^4.0.1" + } + }, + "globals": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", + "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", + "dev": true + }, + "graceful-fs": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.3.tgz", + "integrity": "sha512-a30VEBm4PEdx1dRB7MFK7BejejvCvBronbLjht+sHuGYj8PHs7M/5Z+rt5lw551vZ7yfTCj4Vuyy3mSJytDWRQ==", + "dev": true + }, + "handlebars": { + "version": "4.5.3", + "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.5.3.tgz", + "integrity": "sha512-3yPecJoJHK/4c6aZhSvxOyG4vJKDshV36VHp0iVCDVh7o9w2vwi3NSnL2MMPj3YdduqaBcu7cGbggJQM0br9xA==", + "dev": true, + "requires": { + "neo-async": "^2.6.0", + "optimist": "^0.6.1", + "source-map": "^0.6.1", + "uglify-js": "^3.1.4" + } + }, + "har-schema": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", + "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", + "dev": true + }, + "har-validator": { + "version": "5.1.3", + "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", + "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", + "dev": true, + "requires": { + "ajv": "^6.5.5", + "har-schema": "^2.0.0" + } + }, + "has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", + "dev": true + }, + "hasha": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/hasha/-/hasha-3.0.0.tgz", + "integrity": "sha1-UqMvq4Vp1BymmmH/GiFPjrfIvTk=", + "dev": true, + "requires": { + "is-stream": "^1.0.1" + } + }, + "hosted-git-info": { + "version": "2.8.5", + "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.5.tgz", + "integrity": "sha512-kssjab8CvdXfcXMXVcvsXum4Hwdq9XGtRD3TteMEvEbq0LXyiNQr6AprqKqfeaDXze7SxWvRxdpwE6ku7ikLkg==", + "dev": true + }, + "http-signature": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", + "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", + "dev": true, + "requires": { + "assert-plus": "^1.0.0", + "jsprim": "^1.2.2", + "sshpk": "^1.7.0" + } + }, + "imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", + "dev": true + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "dev": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true + }, + "is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", + "dev": true + }, + "is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", + "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "dev": true, + "requires": { + "binary-extensions": "^2.0.0" + } + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", + "dev": true + }, + "is-glob": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", + "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", + "dev": true, + "requires": { + "is-extglob": "^2.1.1" + } + }, + "is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "dev": true + }, + "is-stream": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", + "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", + "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=", + "dev": true, + "optional": true + }, + "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 + }, + "istanbul-lib-coverage": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.5.tgz", + "integrity": "sha512-8aXznuEPCJvGnMSRft4udDRDtb1V3pkQkMMI5LI+6HuQz5oQ4J2UFn1H82raA3qJtyOLkkwVqICBQkjnGtn5mA==", + "dev": true + }, + "istanbul-lib-hook": { + "version": "2.0.7", + "resolved": "https://registry.npmjs.org/istanbul-lib-hook/-/istanbul-lib-hook-2.0.7.tgz", + "integrity": "sha512-vrRztU9VRRFDyC+aklfLoeXyNdTfga2EI3udDGn4cZ6fpSXpHLV9X6CHvfoMCPtggg8zvDDmC4b9xfu0z6/llA==", + "dev": true, + "requires": { + "append-transform": "^1.0.0" + } + }, + "istanbul-lib-instrument": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-3.3.0.tgz", + "integrity": "sha512-5nnIN4vo5xQZHdXno/YDXJ0G+I3dAm4XgzfSVTPLQpj/zAV2dV6Juy0yaf10/zrJOJeHoN3fraFe+XRq2bFVZA==", + "dev": true, + "requires": { + "@babel/generator": "^7.4.0", + "@babel/parser": "^7.4.3", + "@babel/template": "^7.4.0", + "@babel/traverse": "^7.4.3", + "@babel/types": "^7.4.0", + "istanbul-lib-coverage": "^2.0.5", + "semver": "^6.0.0" + }, + "dependencies": { + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "istanbul-lib-processinfo": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/istanbul-lib-processinfo/-/istanbul-lib-processinfo-1.0.0.tgz", + "integrity": "sha512-FY0cPmWa4WoQNlvB8VOcafiRoB5nB+l2Pz2xGuXHRSy1KM8QFOYfz/rN+bGMCAeejrY3mrpF5oJHcN0s/garCg==", + "dev": true, + "requires": { + "archy": "^1.0.0", + "cross-spawn": "^6.0.5", + "istanbul-lib-coverage": "^2.0.3", + "rimraf": "^2.6.3", + "uuid": "^3.3.2" + }, + "dependencies": { + "cross-spawn": { + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", + "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", + "dev": true, + "requires": { + "nice-try": "^1.0.4", + "path-key": "^2.0.1", + "semver": "^5.5.0", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, + "which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + } + } + }, + "istanbul-lib-report": { + "version": "2.0.8", + "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-2.0.8.tgz", + "integrity": "sha512-fHBeG573EIihhAblwgxrSenp0Dby6tJMFR/HvlerBsrCTD5bkUuoNtn3gVh29ZCS824cGGBPn7Sg7cNk+2xUsQ==", + "dev": true, + "requires": { + "istanbul-lib-coverage": "^2.0.5", + "make-dir": "^2.1.0", + "supports-color": "^6.1.0" + }, + "dependencies": { + "supports-color": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.1.0.tgz", + "integrity": "sha512-qe1jfm1Mg7Nq/NSh6XE24gPXROEVsWHxC1LIx//XNlD9iw7YZQGjZNjYN7xGaEG6iKdA8EtNFW6R0gjnVXp+wQ==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "istanbul-lib-source-maps": { + "version": "3.0.6", + "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-3.0.6.tgz", + "integrity": "sha512-R47KzMtDJH6X4/YW9XTx+jrLnZnscW4VpNN+1PViSYTejLVPWv7oov+Duf8YQSPyVRUvueQqz1TcsC6mooZTXw==", + "dev": true, + "requires": { + "debug": "^4.1.1", + "istanbul-lib-coverage": "^2.0.5", + "make-dir": "^2.1.0", + "rimraf": "^2.6.3", + "source-map": "^0.6.1" + } + }, + "istanbul-reports": { + "version": "2.2.6", + "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-2.2.6.tgz", + "integrity": "sha512-SKi4rnMyLBKe0Jy2uUdx28h8oG7ph2PPuQPvIAh31d+Ci+lSiEu4C+h3oBPuJ9+mPKhOyW0M8gY4U5NM1WLeXA==", + "dev": true, + "requires": { + "handlebars": "^4.1.2" + } + }, + "jackspeak": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-1.4.0.tgz", + "integrity": "sha512-VDcSunT+wcccoG46FtzuBAyQKlzhHjli4q31e1fIHGOsRspqNUFjVzGb+7eIFDlTvqLygxapDHPHS0ouT2o/tw==", + "dev": true, + "requires": { + "cliui": "^4.1.0" + } + }, + "js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "dev": true + }, + "js-yaml": { + "version": "3.13.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", + "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", + "dev": true, + "requires": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + } + }, + "jsbn": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", + "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", + "dev": true + }, + "jsesc": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", + "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", + "dev": true + }, + "json-parse-better-errors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", + "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", + "dev": 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-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true + }, + "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 + }, + "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" + } + }, + "lcov-parse": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/lcov-parse/-/lcov-parse-1.0.0.tgz", + "integrity": "sha1-6w1GtUER68VhrLTECO+TY73I9+A=", + "dev": true + }, + "load-json-file": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", + "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^4.0.0", + "pify": "^3.0.0", + "strip-bom": "^3.0.0" + }, + "dependencies": { + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", + "dev": true + } + } + }, + "locate-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", + "dev": true, + "requires": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + } + }, + "lodash": { + "version": "4.17.15", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", + "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==", + "dev": true + }, + "lodash.flattendeep": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/lodash.flattendeep/-/lodash.flattendeep-4.4.0.tgz", + "integrity": "sha1-+wMJF/hqMTTlvJvsDWngAT3f7bI=", + "dev": true + }, + "log-driver": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/log-driver/-/log-driver-1.2.7.tgz", + "integrity": "sha512-U7KCmLdqsGHBLeWqYlFA0V0Sl6P08EE1ZrmA9cxjUE0WVqT9qnyVDPz1kzpFEP0jdJuFnasWIfSd7fsaNXkpbg==", + "dev": true + }, + "loose-envify": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", + "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", + "dev": true, + "requires": { + "js-tokens": "^3.0.0 || ^4.0.0" + } + }, + "lru-cache": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", + "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", + "dev": true, + "requires": { + "pseudomap": "^1.0.2", + "yallist": "^2.1.2" + } + }, + "make-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", + "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", + "dev": true, + "requires": { + "pify": "^4.0.1", + "semver": "^5.6.0" + } + }, + "make-error": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.5.tgz", + "integrity": "sha512-c3sIjNUow0+8swNwVpqoH4YCShKNFkMaw6oH1mNS2haDZQqkeZFlHS3dhoeEbKKmJB4vXpJucU6oH75aDYeE9g==", + "dev": true + }, + "merge-source-map": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/merge-source-map/-/merge-source-map-1.1.0.tgz", + "integrity": "sha512-Qkcp7P2ygktpMPh2mCQZaf3jhN6D3Z/qVZHSdWvQ+2Ef5HgRAPBO57A77+ENm0CPx2+1Ce/MYKi3ymqdfuqibw==", + "dev": true, + "requires": { + "source-map": "^0.6.1" + } + }, + "mime-db": { + "version": "1.42.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.42.0.tgz", + "integrity": "sha512-UbfJCR4UAVRNgMpfImz05smAXK7+c+ZntjaA26ANtkXLlOe947Aag5zdIcKQULAiF9Cq4WxBi9jUs5zkA84bYQ==", + "dev": true + }, + "mime-types": { + "version": "2.1.25", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.25.tgz", + "integrity": "sha512-5KhStqB5xpTAeGqKBAMgwaYMnQik7teQN4IAzC7npDv6kzeU6prfkR67bc87J1kWMPGkoaZSq1npmexMgkmEVg==", + "dev": true, + "requires": { + "mime-db": "1.42.0" + } + }, + "minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "dev": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", + "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", + "dev": true + }, + "minipass": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.1.1.tgz", + "integrity": "sha512-UFqVihv6PQgwj8/yTGvl9kPz7xIAY+R5z6XYjRInD3Gk3qx6QGSD6zEcpeG4Dy/lQnv1J6zv8ejV90hyYIKf3w==", + "dev": true, + "requires": { + "yallist": "^4.0.0" + }, + "dependencies": { + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + } + } + }, + "mkdirp": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", + "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", + "dev": true, + "requires": { + "minimist": "0.0.8" + }, + "dependencies": { + "minimist": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", + "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", + "dev": true + } + } + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "neo-async": { + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.1.tgz", + "integrity": "sha512-iyam8fBuCUpWeKPGpaNMetEocMt364qkCsfL9JuhjXX6dRnguRVOfk2GZaDpPjcOKiiXCPINZC1GczQ7iTq3Zw==", + "dev": true + }, + "nested-error-stacks": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/nested-error-stacks/-/nested-error-stacks-2.1.0.tgz", + "integrity": "sha512-AO81vsIO1k1sM4Zrd6Hu7regmJN1NSiAja10gc4bX3F0wd+9rQmcuHQaHVQCYIEC8iFXnE+mavh23GOt7wBgug==", + "dev": true + }, + "nice-try": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", + "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", + "dev": true + }, + "node-modules-regexp": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/node-modules-regexp/-/node-modules-regexp-1.0.0.tgz", + "integrity": "sha1-jZ2+KJZKSsVxLpExZCEHxx6Q7EA=", + "dev": true + }, + "normalize-package-data": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", + "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", + "dev": true, + "requires": { + "hosted-git-info": "^2.1.4", + "resolve": "^1.10.0", + "semver": "2 || 3 || 4 || 5", + "validate-npm-package-license": "^3.0.1" + } + }, + "normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", + "dev": true + }, + "number-is-nan": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", + "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", + "dev": true + }, + "nyc": { + "version": "14.1.1", + "resolved": "https://registry.npmjs.org/nyc/-/nyc-14.1.1.tgz", + "integrity": "sha512-OI0vm6ZGUnoGZv/tLdZ2esSVzDwUC88SNs+6JoSOMVxA+gKMB8Tk7jBwgemLx4O40lhhvZCVw1C+OYLOBOPXWw==", + "dev": true, + "requires": { + "archy": "^1.0.0", + "caching-transform": "^3.0.2", + "convert-source-map": "^1.6.0", + "cp-file": "^6.2.0", + "find-cache-dir": "^2.1.0", + "find-up": "^3.0.0", + "foreground-child": "^1.5.6", + "glob": "^7.1.3", + "istanbul-lib-coverage": "^2.0.5", + "istanbul-lib-hook": "^2.0.7", + "istanbul-lib-instrument": "^3.3.0", + "istanbul-lib-report": "^2.0.8", + "istanbul-lib-source-maps": "^3.0.6", + "istanbul-reports": "^2.2.4", + "js-yaml": "^3.13.1", + "make-dir": "^2.1.0", + "merge-source-map": "^1.1.0", + "resolve-from": "^4.0.0", + "rimraf": "^2.6.3", + "signal-exit": "^3.0.2", + "spawn-wrap": "^1.4.2", + "test-exclude": "^5.2.3", + "uuid": "^3.3.2", + "yargs": "^13.2.2", + "yargs-parser": "^13.0.0" + } + }, + "oauth-sign": { + "version": "0.9.0", + "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", + "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", + "dev": true + }, + "object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", + "dev": true + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "dev": true, + "requires": { + "wrappy": "1" + } + }, + "opener": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/opener/-/opener-1.5.1.tgz", + "integrity": "sha512-goYSy5c2UXE4Ra1xixabeVh1guIX/ZV/YokJksb6q2lubWu6UbvPQ20p542/sFIll1nl8JnCyK9oBaOcCWXwvA==", + "dev": true + }, + "optimist": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/optimist/-/optimist-0.6.1.tgz", + "integrity": "sha1-2j6nRob6IaGaERwybpDrFaAZZoY=", + "dev": true, + "requires": { + "minimist": "~0.0.1", + "wordwrap": "~0.0.2" + }, + "dependencies": { + "minimist": { + "version": "0.0.10", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.10.tgz", + "integrity": "sha1-3j+YVD2/lggr5IrRoMfNqDYwHc8=", + "dev": true + } + } + }, + "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 + }, + "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.1", + "resolved": "https://registry.npmjs.org/own-or-env/-/own-or-env-1.0.1.tgz", + "integrity": "sha512-y8qULRbRAlL6x2+M0vIe7jJbJx/kmUTzYonRAa2ayesR2qWLswninkVyeJe4x3IEXhdgoNodzjQRKAoEs6Fmrw==", + "dev": true, + "requires": { + "own-or": "^1.0.0" + } + }, + "p-limit": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.1.tgz", + "integrity": "sha512-85Tk+90UCVWvbDavCLKPOLC9vvY8OwEX/RtKF+/1OADJMVlFfEHOiMTPVyxg7mk/dKa+ipdHm0OUkTvCpMTuwg==", + "dev": true, + "requires": { + "p-try": "^2.0.0" + } + }, + "p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", + "dev": true, + "requires": { + "p-limit": "^2.0.0" + } + }, + "p-try": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", + "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", + "dev": true + }, + "package-hash": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/package-hash/-/package-hash-3.0.0.tgz", + "integrity": "sha512-lOtmukMDVvtkL84rJHI7dpTYq+0rli8N2wlnqUcBuDWCfVhRUfOmnR9SsoHFMLpACvEV60dX7rd0rFaYDZI+FA==", + "dev": true, + "requires": { + "graceful-fs": "^4.1.15", + "hasha": "^3.0.0", + "lodash.flattendeep": "^4.4.0", + "release-zalgo": "^1.0.0" + } + }, + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", + "dev": true, + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", + "dev": true + }, + "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=", + "dev": true + }, + "path-key": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", + "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", + "dev": true + }, + "path-parse": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", + "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", + "dev": true + }, + "path-type": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", + "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", + "dev": true, + "requires": { + "pify": "^3.0.0" + }, + "dependencies": { + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", + "dev": true + } + } + }, + "performance-now": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", + "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", + "dev": true + }, + "picomatch": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.1.1.tgz", + "integrity": "sha512-OYMyqkKzK7blWO/+XZYP6w8hH0LDvkBvdvKukti+7kqYFCiEAk+gI3DWnryapc0Dau05ugGTy0foQ6mqn4AHYA==", + "dev": true + }, + "pify": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", + "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==", + "dev": true + }, + "pirates": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/pirates/-/pirates-3.0.2.tgz", + "integrity": "sha512-c5CgUJq6H2k6MJz72Ak1F5sN9n9wlSlJyEnwvpm9/y3WB4E3pHBDT2c6PEiS1vyJvq2bUxUAIu0EGf8Cx4Ic7Q==", + "dev": true, + "requires": { + "node-modules-regexp": "^1.0.0" + } + }, + "pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", + "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", + "dev": true, + "requires": { + "find-up": "^3.0.0" + } + }, + "process-nextick-args": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", + "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", + "dev": true, + "optional": true + }, + "prop-types": { + "version": "15.7.2", + "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.7.2.tgz", + "integrity": "sha512-8QQikdH7//R2vurIJSutZ1smHYTcLpRWEOlHnzcWHmBYrOGUysKwSsrC89BCiFj3CbrfJ/nXFdJepOVrY1GCHQ==", + "dev": true, + "requires": { + "loose-envify": "^1.4.0", + "object-assign": "^4.1.1", + "react-is": "^16.8.1" + } + }, + "pseudomap": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", + "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", + "dev": true + }, + "psl": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/psl/-/psl-1.6.0.tgz", + "integrity": "sha512-SYKKmVel98NCOYXpkwUqZqh0ahZeeKfmisiLIcEZdsb+WbLv02g/dI5BUmZnIyOe7RzZtLax81nnb2HbvC2tzA==", + "dev": true + }, + "punycode": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", + "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", + "dev": true + }, + "qs": { + "version": "6.5.2", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", + "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", + "dev": true + }, + "react": { + "version": "16.12.0", + "resolved": "https://registry.npmjs.org/react/-/react-16.12.0.tgz", + "integrity": "sha512-fglqy3k5E+81pA8s+7K0/T3DBCF0ZDOher1elBFzF7O6arXJgzyu/FW+COxFvAWXJoJN9KIZbT2LXlukwphYTA==", + "dev": true, + "requires": { + "loose-envify": "^1.1.0", + "object-assign": "^4.1.1", + "prop-types": "^15.6.2" + } + }, + "react-is": { + "version": "16.12.0", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.12.0.tgz", + "integrity": "sha512-rPCkf/mWBtKc97aLL9/txD8DZdemK0vkA3JMLShjlJB3Pj3s+lpf1KaBzMfQrAmhMQB0n1cU/SUGgKKBCe837Q==", + "dev": true + }, + "read-pkg": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", + "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", + "dev": true, + "requires": { + "load-json-file": "^4.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^3.0.0" + } + }, + "read-pkg-up": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-4.0.0.tgz", + "integrity": "sha512-6etQSH7nJGsK0RbG/2TeDzZFa8shjQ1um+SwQQ5cwKy0dhSXdOncEhb1CPpvQG4h7FyOV6EB6YlV0yJvZQNAkA==", + "dev": true, + "requires": { + "find-up": "^3.0.0", + "read-pkg": "^3.0.0" + } + }, + "readable-stream": { + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", + "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", + "dev": true, + "optional": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + }, + "dependencies": { + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "dev": true, + "optional": true + } + } + }, + "readdirp": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.2.0.tgz", + "integrity": "sha512-crk4Qu3pmXwgxdSgGhgA/eXiJAPQiX4GMOZZMXnqKxHX7TaoL+3gQVo/WeuAiogr07DpnfjIMpXXa+PAIvwPGQ==", + "dev": true, + "requires": { + "picomatch": "^2.0.4" + } + }, + "regenerator-runtime": { + "version": "0.13.3", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.3.tgz", + "integrity": "sha512-naKIZz2GQ8JWh///G7L3X6LaQUAMp2lvb1rvwwsURe/VXwD6VMfr+/1NuNw3ag8v2kY1aQ/go5SNn79O9JU7yw==", + "dev": true + }, + "release-zalgo": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/release-zalgo/-/release-zalgo-1.0.0.tgz", + "integrity": "sha1-CXALflB0Mpc5Mw5TXFqQ+2eFFzA=", + "dev": true, + "requires": { + "es6-error": "^4.0.1" + } + }, + "request": { + "version": "2.88.0", + "resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz", + "integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==", + "dev": true, + "requires": { + "aws-sign2": "~0.7.0", + "aws4": "^1.8.0", + "caseless": "~0.12.0", + "combined-stream": "~1.0.6", + "extend": "~3.0.2", + "forever-agent": "~0.6.1", + "form-data": "~2.3.2", + "har-validator": "~5.1.0", + "http-signature": "~1.2.0", + "is-typedarray": "~1.0.0", + "isstream": "~0.1.2", + "json-stringify-safe": "~5.0.1", + "mime-types": "~2.1.19", + "oauth-sign": "~0.9.0", + "performance-now": "^2.1.0", + "qs": "~6.5.2", + "safe-buffer": "^5.1.2", + "tough-cookie": "~2.4.3", + "tunnel-agent": "^0.6.0", + "uuid": "^3.3.2" + } + }, + "require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", + "dev": true + }, + "require-main-filename": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", + "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", + "dev": true + }, + "resolve": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.13.1.tgz", + "integrity": "sha512-CxqObCX8K8YtAhOBRg+lrcdn+LK+WYOS8tSjqSFbjtrI5PnS63QPhZl4+yKfrU9tdsbMu9Anr/amegT87M9Z6w==", + "dev": true, + "requires": { + "path-parse": "^1.0.6" + } + }, + "resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true + }, + "rimraf": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", + "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", + "dev": true, + "requires": { + "glob": "^7.1.3" + } + }, + "safe-buffer": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.0.tgz", + "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==", + "dev": true + }, + "safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", + "dev": true + }, + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", + "dev": true + }, + "set-blocking": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", + "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", + "dev": true + }, + "shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", + "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", + "dev": true, + "requires": { + "shebang-regex": "^1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", + "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", + "dev": true + }, + "signal-exit": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", + "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", + "dev": true + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + }, + "source-map-support": { + "version": "0.5.16", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.16.tgz", + "integrity": "sha512-efyLRJDr68D9hBBNIPWFjhpFzURh+KJykQwvMyW5UiZzYwoF6l4YMMDIJJEyFWxWCqfyxLzz6tSfUFR+kXXsVQ==", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + } + }, + "spawn-wrap": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/spawn-wrap/-/spawn-wrap-1.4.3.tgz", + "integrity": "sha512-IgB8md0QW/+tWqcavuFgKYR/qIRvJkRLPJDFaoXtLLUaVcCDK0+HeFTkmQHj3eprcYhc+gOl0aEA1w7qZlYezw==", + "dev": true, + "requires": { + "foreground-child": "^1.5.6", + "mkdirp": "^0.5.0", + "os-homedir": "^1.0.1", + "rimraf": "^2.6.2", + "signal-exit": "^3.0.2", + "which": "^1.3.0" + }, + "dependencies": { + "which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + } + } + }, + "spdx-correct": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", + "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", + "dev": true, + "requires": { + "spdx-expression-parse": "^3.0.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-exceptions": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", + "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==", + "dev": true + }, + "spdx-expression-parse": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", + "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", + "dev": true, + "requires": { + "spdx-exceptions": "^2.1.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-license-ids": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz", + "integrity": "sha512-J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q==", + "dev": true + }, + "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.16.1", + "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", + "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", + "dev": true, + "requires": { + "asn1": "~0.2.3", + "assert-plus": "^1.0.0", + "bcrypt-pbkdf": "^1.0.0", + "dashdash": "^1.12.0", + "ecc-jsbn": "~0.1.1", + "getpass": "^0.1.1", + "jsbn": "~0.1.0", + "safer-buffer": "^2.0.2", + "tweetnacl": "~0.14.0" + } + }, + "stack-utils": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-1.0.2.tgz", + "integrity": "sha512-MTX+MeG5U994cazkjd/9KNAapsHnibjMLnfXodlkXw76JEea0UiNzrqidzo1emMwk7w5Qhc9jd4Bn9TBb1MFwA==", + "dev": true + }, + "string-width": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", + "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", + "dev": true, + "requires": { + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^4.0.0" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "dev": true, + "optional": true, + "requires": { + "safe-buffer": "~5.1.0" + }, + "dependencies": { + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "dev": true, + "optional": true + } + } + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + }, + "strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", + "dev": true + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + }, + "tap": { + "version": "14.10.2", + "resolved": "https://registry.npmjs.org/tap/-/tap-14.10.2.tgz", + "integrity": "sha512-JeUDsVrMFmR6b3p9hO9yIT/jibrK6LI7nFza5cqDGsxJyCp7yU3enRgS5nekuoAOzewbrU7P+9QDRDT01urROA==", + "dev": true, + "requires": { + "async-hook-domain": "^1.1.3", + "bind-obj-methods": "^2.0.0", + "browser-process-hrtime": "^1.0.0", + "chokidar": "^3.3.0", + "color-support": "^1.1.0", + "coveralls": "^3.0.8", + "diff": "^4.0.1", + "esm": "^3.2.25", + "findit": "^2.0.0", + "flow-remove-types": "^2.112.0", + "foreground-child": "^1.3.3", + "fs-exists-cached": "^1.0.0", + "function-loop": "^1.0.2", + "glob": "^7.1.6", + "import-jsx": "^3.0.0", + "ink": "^2.5.0", + "isexe": "^2.0.0", + "istanbul-lib-processinfo": "^1.0.0", + "jackspeak": "^1.4.0", + "minipass": "^3.1.1", + "mkdirp": "^0.5.1", + "nyc": "^14.1.1", + "opener": "^1.5.1", + "own-or": "^1.0.0", + "own-or-env": "^1.0.1", + "react": "^16.12.0", + "rimraf": "^2.7.1", + "signal-exit": "^3.0.0", + "source-map-support": "^0.5.16", + "stack-utils": "^1.0.2", + "tap-mocha-reporter": "^5.0.0", + "tap-parser": "^10.0.1", + "tap-yaml": "^1.0.0", + "tcompare": "^3.0.0", + "treport": "^1.0.0", + "trivial-deferred": "^1.0.1", + "ts-node": "^8.5.2", + "typescript": "^3.7.2", + "which": "^2.0.2", + "write-file-atomic": "^3.0.1", + "yaml": "^1.7.2", + "yapool": "^1.0.0" + }, + "dependencies": { + "@babel/code-frame": { + "version": "7.5.5", + "bundled": true, + "requires": { + "@babel/highlight": "^7.0.0" + } + }, + "@babel/core": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/code-frame": "^7.5.5", + "@babel/generator": "^7.7.4", + "@babel/helpers": "^7.7.4", + "@babel/parser": "^7.7.4", + "@babel/template": "^7.7.4", + "@babel/traverse": "^7.7.4", + "@babel/types": "^7.7.4", + "convert-source-map": "^1.7.0", + "debug": "^4.1.0", + "json5": "^2.1.0", + "lodash": "^4.17.13", + "resolve": "^1.3.2", + "semver": "^5.4.1", + "source-map": "^0.5.0" + }, + "dependencies": { + "@babel/generator": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/types": "^7.7.4", + "jsesc": "^2.5.1", + "lodash": "^4.17.13", + "source-map": "^0.5.0" + } + }, + "@babel/helper-function-name": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "^7.7.4", + "@babel/template": "^7.7.4", + "@babel/types": "^7.7.4" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/types": "^7.7.4" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/types": "^7.7.4" + } + }, + "@babel/parser": { + "version": "7.7.4", + "bundled": true, + "dev": true + }, + "@babel/template": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/code-frame": "^7.0.0", + "@babel/parser": "^7.7.4", + "@babel/types": "^7.7.4" + } + }, + "@babel/traverse": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/code-frame": "^7.5.5", + "@babel/generator": "^7.7.4", + "@babel/helper-function-name": "^7.7.4", + "@babel/helper-split-export-declaration": "^7.7.4", + "@babel/parser": "^7.7.4", + "@babel/types": "^7.7.4", + "debug": "^4.1.0", + "globals": "^11.1.0", + "lodash": "^4.17.13" + } + }, + "@babel/types": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "esutils": "^2.0.2", + "lodash": "^4.17.13", + "to-fast-properties": "^2.0.0" + } + }, + "convert-source-map": { + "version": "1.7.0", + "bundled": true, + "dev": true, + "requires": { + "safe-buffer": "~5.1.1" + } + }, + "debug": { + "version": "4.1.1", + "bundled": true, + "dev": true, + "requires": { + "ms": "^2.1.1" + } + }, + "ms": { + "version": "2.1.2", + "bundled": true, + "dev": true + }, + "safe-buffer": { + "version": "5.1.2", + "bundled": true, + "dev": true + }, + "source-map": { + "version": "0.5.7", + "bundled": true, + "dev": true + } + } + }, + "@babel/generator": { + "version": "7.7.2", + "bundled": true, + "requires": { + "@babel/types": "^7.7.2", + "jsesc": "^2.5.1", + "lodash": "^4.17.13", + "source-map": "^0.5.0" + }, + "dependencies": { + "source-map": { + "version": "0.5.7", + "bundled": true + } + } + }, + "@babel/helper-builder-react-jsx": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/types": "^7.7.4", + "esutils": "^2.0.0" + }, + "dependencies": { + "@babel/types": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "esutils": "^2.0.2", + "lodash": "^4.17.13", + "to-fast-properties": "^2.0.0" + } + } + } + }, + "@babel/helper-plugin-utils": { + "version": "7.0.0", + "bundled": true, + "dev": true + }, + "@babel/helpers": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/template": "^7.7.4", + "@babel/traverse": "^7.7.4", + "@babel/types": "^7.7.4" + }, + "dependencies": { + "@babel/generator": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/types": "^7.7.4", + "jsesc": "^2.5.1", + "lodash": "^4.17.13", + "source-map": "^0.5.0" + } + }, + "@babel/helper-function-name": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/helper-get-function-arity": "^7.7.4", + "@babel/template": "^7.7.4", + "@babel/types": "^7.7.4" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/types": "^7.7.4" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/types": "^7.7.4" + } + }, + "@babel/parser": { + "version": "7.7.4", + "bundled": true, + "dev": true + }, + "@babel/template": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/code-frame": "^7.0.0", + "@babel/parser": "^7.7.4", + "@babel/types": "^7.7.4" + } + }, + "@babel/traverse": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/code-frame": "^7.5.5", + "@babel/generator": "^7.7.4", + "@babel/helper-function-name": "^7.7.4", + "@babel/helper-split-export-declaration": "^7.7.4", + "@babel/parser": "^7.7.4", + "@babel/types": "^7.7.4", + "debug": "^4.1.0", + "globals": "^11.1.0", + "lodash": "^4.17.13" + } + }, + "@babel/types": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "esutils": "^2.0.2", + "lodash": "^4.17.13", + "to-fast-properties": "^2.0.0" + } + }, + "debug": { + "version": "4.1.1", + "bundled": true, + "dev": true, + "requires": { + "ms": "^2.1.1" + } + }, + "ms": { + "version": "2.1.2", + "bundled": true, + "dev": true + }, + "source-map": { + "version": "0.5.7", + "bundled": true, + "dev": true + } + } + }, + "@babel/highlight": { + "version": "7.5.0", + "bundled": true, + "requires": { + "chalk": "^2.0.0", + "esutils": "^2.0.2", + "js-tokens": "^4.0.0" + }, + "dependencies": { + "js-tokens": { + "version": "4.0.0", + "bundled": true + } + } + }, + "@babel/parser": { + "version": "7.7.3", + "bundled": true + }, + "@babel/plugin-proposal-object-rest-spread": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-syntax-object-rest-spread": "^7.7.4" + } + }, + "@babel/plugin-syntax-jsx": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0" + } + }, + "@babel/plugin-syntax-object-rest-spread": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0" + } + }, + "@babel/plugin-transform-destructuring": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0" + } + }, + "@babel/plugin-transform-react-jsx": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "@babel/helper-builder-react-jsx": "^7.7.4", + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-syntax-jsx": "^7.7.4" + } + }, + "@babel/runtime": { + "version": "7.7.4", + "bundled": true, + "dev": true, + "requires": { + "regenerator-runtime": "^0.13.2" + } + }, + "@babel/template": { + "version": "7.7.0", + "bundled": true, + "requires": { + "@babel/code-frame": "^7.0.0", + "@babel/parser": "^7.7.0", + "@babel/types": "^7.7.0" + } + }, + "@babel/types": { + "version": "7.7.2", + "bundled": true, + "requires": { + "esutils": "^2.0.2", + "lodash": "^4.17.13", + "to-fast-properties": "^2.0.0" + } + }, + "@types/color-name": { + "version": "1.1.1", + "bundled": true, + "dev": true + }, + "@types/prop-types": { + "version": "15.7.3", + "bundled": true, + "dev": true + }, + "@types/react": { + "version": "16.9.13", + "bundled": true, + "dev": true, + "requires": { + "@types/prop-types": "*", + "csstype": "^2.2.0" + } + }, + "ansi-escapes": { + "version": "4.3.0", + "bundled": true, + "dev": true, + "requires": { + "type-fest": "^0.8.1" + } + }, + "ansi-regex": { + "version": "2.1.1", + "bundled": true + }, + "ansi-styles": { + "version": "3.2.1", + "bundled": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "ansicolors": { + "version": "0.3.2", + "bundled": true, + "dev": true + }, + "arrify": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "astral-regex": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "auto-bind": { + "version": "2.1.1", + "bundled": true, + "dev": true, + "requires": { + "@types/react": "^16.8.12" + } + }, + "caller-callsite": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "callsites": "^2.0.0" + } + }, + "caller-path": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "caller-callsite": "^2.0.0" + } + }, + "callsites": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "cardinal": { + "version": "2.1.1", + "bundled": true, + "dev": true, + "requires": { + "ansicolors": "~0.3.2", + "redeyed": "~2.1.0" + } + }, + "chalk": { + "version": "2.4.2", + "bundled": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "ci-info": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "cli-cursor": { + "version": "2.1.0", + "bundled": true, + "dev": true, + "requires": { + "restore-cursor": "^2.0.0" + } + }, + "cli-truncate": { + "version": "1.1.0", + "bundled": true, + "dev": true, + "requires": { + "slice-ansi": "^1.0.0", + "string-width": "^2.0.0" + } + }, + "color-convert": { + "version": "1.9.3", + "bundled": true, + "requires": { + "color-name": "1.1.3" + } + }, + "color-name": { + "version": "1.1.3", + "bundled": true + }, + "csstype": { + "version": "2.6.7", + "bundled": true, + "dev": true + }, + "debug": { + "version": "2.6.9", + "bundled": true, + "requires": { + "ms": "2.0.0" + } + }, + "emoji-regex": { + "version": "7.0.3", + "bundled": true, + "dev": true + }, + "escape-string-regexp": { + "version": "1.0.5", + "bundled": true + }, + "esprima": { + "version": "4.0.1", + "bundled": true, + "dev": true + }, + "esutils": { + "version": "2.0.3", + "bundled": true + }, + "events-to-array": { + "version": "1.1.2", + "bundled": true, + "dev": true + }, + "globals": { + "version": "11.12.0", + "bundled": true, + "dev": true + }, + "has-flag": { + "version": "3.0.0", + "bundled": true + }, + "import-jsx": { + "version": "3.0.0", + "bundled": true, + "dev": true, + "requires": { + "@babel/core": "^7.5.5", + "@babel/plugin-proposal-object-rest-spread": "^7.5.5", + "@babel/plugin-transform-destructuring": "^7.5.0", + "@babel/plugin-transform-react-jsx": "^7.3.0", + "caller-path": "^2.0.0", + "resolve-from": "^3.0.0" + } + }, + "ink": { + "version": "2.5.0", + "bundled": true, + "dev": true, + "requires": { + "@types/react": "^16.8.6", + "ansi-escapes": "^4.2.1", + "arrify": "^1.0.1", + "auto-bind": "^2.0.0", + "chalk": "^2.4.1", + "cli-cursor": "^2.1.0", + "cli-truncate": "^1.1.0", + "is-ci": "^2.0.0", + "lodash.throttle": "^4.1.1", + "log-update": "^3.0.0", + "prop-types": "^15.6.2", + "react-reconciler": "^0.21.0", + "scheduler": "^0.15.0", + "signal-exit": "^3.0.2", + "slice-ansi": "^1.0.0", + "string-length": "^2.0.0", + "widest-line": "^2.0.0", + "wrap-ansi": "^5.0.0", + "yoga-layout-prebuilt": "^1.9.3" + } + }, + "is-ci": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "ci-info": "^2.0.0" + } + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "bundled": true, + "dev": true + }, + "js-tokens": { + "version": "3.0.2", + "bundled": true, + "dev": true + }, + "jsesc": { + "version": "2.5.2", + "bundled": true + }, + "json5": { + "version": "2.1.1", + "bundled": true, + "dev": true, + "requires": { + "minimist": "^1.2.0" + } + }, + "lodash": { + "version": "4.17.15", + "bundled": true + }, + "lodash.throttle": { + "version": "4.1.1", + "bundled": true, + "dev": true + }, + "log-update": { + "version": "3.3.0", + "bundled": true, + "dev": true, + "requires": { + "ansi-escapes": "^3.2.0", + "cli-cursor": "^2.1.0", + "wrap-ansi": "^5.0.0" + }, + "dependencies": { + "ansi-escapes": { + "version": "3.2.0", + "bundled": true, + "dev": true + } + } + }, + "loose-envify": { + "version": "1.4.0", + "bundled": true, + "dev": true, + "requires": { + "js-tokens": "^3.0.0 || ^4.0.0" + } + }, + "mimic-fn": { + "version": "1.2.0", + "bundled": true, + "dev": true + }, + "minimist": { + "version": "1.2.0", + "bundled": true, + "dev": true + }, + "minipass": { + "version": "3.1.1", + "bundled": true, + "dev": true, + "requires": { + "yallist": "^4.0.0" + }, + "dependencies": { + "yallist": { + "version": "4.0.0", + "bundled": true, + "dev": true + } + } + }, + "ms": { + "version": "2.0.0", + "bundled": true + }, + "object-assign": { + "version": "4.1.1", + "bundled": true, + "dev": true + }, + "onetime": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "requires": { + "mimic-fn": "^1.0.0" + } + }, + "path-parse": { + "version": "1.0.6", + "bundled": true, + "dev": true + }, + "prop-types": { + "version": "15.7.2", + "bundled": true, + "dev": true, + "requires": { + "loose-envify": "^1.4.0", + "object-assign": "^4.1.1", + "react-is": "^16.8.1" + } + }, + "punycode": { + "version": "2.1.1", + "bundled": true, + "dev": true + }, + "react-is": { + "version": "16.10.2", + "bundled": true, + "dev": true + }, + "react-reconciler": { + "version": "0.21.0", + "bundled": true, + "dev": true, + "requires": { + "loose-envify": "^1.1.0", + "object-assign": "^4.1.1", + "prop-types": "^15.6.2", + "scheduler": "^0.15.0" + } + }, + "redeyed": { + "version": "2.1.1", + "bundled": true, + "dev": true, + "requires": { + "esprima": "~4.0.0" + } + }, + "regenerator-runtime": { + "version": "0.13.3", + "bundled": true, + "dev": true + }, + "resolve": { + "version": "1.12.0", + "bundled": true, + "dev": true, + "requires": { + "path-parse": "^1.0.6" + } + }, + "resolve-from": { + "version": "3.0.0", + "bundled": true, + "dev": true + }, + "restore-cursor": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "onetime": "^2.0.0", + "signal-exit": "^3.0.2" + } + }, + "scheduler": { + "version": "0.15.0", + "bundled": true, + "dev": true, + "requires": { + "loose-envify": "^1.1.0", + "object-assign": "^4.1.1" + } + }, + "semver": { + "version": "5.7.1", + "bundled": true, + "dev": true + }, + "signal-exit": { + "version": "3.0.2", + "bundled": true, + "dev": true + }, + "slice-ansi": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "is-fullwidth-code-point": "^2.0.0" + } + }, + "source-map": { + "version": "0.6.1", + "bundled": true + }, + "string-length": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "requires": { + "astral-regex": "^1.0.0", + "strip-ansi": "^4.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "bundled": true, + "dev": true + }, + "strip-ansi": { + "version": "4.0.0", + "bundled": true, + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "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 + }, + "strip-ansi": { + "version": "4.0.0", + "bundled": true, + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "strip-ansi": { + "version": "3.0.1", + "bundled": true, + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "supports-color": { + "version": "5.5.0", + "bundled": true, + "requires": { + "has-flag": "^3.0.0" + } + }, + "tap-parser": { + "version": "10.0.1", + "bundled": true, + "dev": true, + "requires": { + "events-to-array": "^1.0.1", + "minipass": "^3.0.0", + "tap-yaml": "^1.0.0" + } + }, + "tap-yaml": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "yaml": "^1.5.0" + } + }, + "to-fast-properties": { + "version": "2.0.0", + "bundled": true + }, + "treport": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "requires": { + "cardinal": "^2.1.1", + "chalk": "^3.0.0", + "import-jsx": "^3.0.0", + "ink": "^2.5.0", + "ms": "^2.1.2", + "string-length": "^3.1.0", + "tap-parser": "^10.0.1", + "unicode-length": "^2.0.2" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "bundled": true, + "dev": true + }, + "ansi-styles": { + "version": "4.2.0", + "bundled": true, + "dev": true, + "requires": { + "@types/color-name": "^1.1.1", + "color-convert": "^2.0.1" + } + }, + "chalk": { + "version": "3.0.0", + "bundled": true, + "dev": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "color-convert": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "bundled": true, + "dev": true + }, + "has-flag": { + "version": "4.0.0", + "bundled": true, + "dev": true + }, + "ms": { + "version": "2.1.2", + "bundled": true, + "dev": true + }, + "string-length": { + "version": "3.1.0", + "bundled": true, + "dev": true, + "requires": { + "astral-regex": "^1.0.0", + "strip-ansi": "^5.2.0" + } + }, + "strip-ansi": { + "version": "5.2.0", + "bundled": true, + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + } + }, + "supports-color": { + "version": "7.1.0", + "bundled": true, + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } + }, + "unicode-length": { + "version": "2.0.2", + "bundled": true, + "dev": true, + "requires": { + "punycode": "^2.0.0", + "strip-ansi": "^3.0.1" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "bundled": true, + "dev": true + }, + "strip-ansi": { + "version": "3.0.1", + "bundled": true, + "dev": true, + "requires": { + "ansi-regex": "^2.0.0" + } + } + } + } + } + }, + "type-fest": { + "version": "0.8.1", + "bundled": true, + "dev": true + }, + "widest-line": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "requires": { + "string-width": "^2.1.1" + } + }, + "wrap-ansi": { + "version": "5.1.0", + "bundled": true, + "dev": true, + "requires": { + "ansi-styles": "^3.2.0", + "string-width": "^3.0.0", + "strip-ansi": "^5.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "bundled": true, + "dev": true + }, + "string-width": { + "version": "3.1.0", + "bundled": true, + "dev": true, + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + } + }, + "strip-ansi": { + "version": "5.2.0", + "bundled": true, + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + } + } + } + }, + "yaml": { + "version": "1.7.2", + "bundled": true, + "dev": true, + "requires": { + "@babel/runtime": "^7.6.3" + } + }, + "yoga-layout-prebuilt": { + "version": "1.9.3", + "bundled": true, + "dev": true + } + } + }, + "tap-mocha-reporter": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/tap-mocha-reporter/-/tap-mocha-reporter-5.0.0.tgz", + "integrity": "sha512-8HlAtdmYGlDZuW83QbF/dc46L7cN+AGhLZcanX3I9ILvxUAl+G2/mtucNPSXecTlG/4iP1hv6oMo0tMhkn3Tsw==", + "dev": true, + "requires": { + "color-support": "^1.1.0", + "debug": "^2.1.3", + "diff": "^1.3.2", + "escape-string-regexp": "^1.0.3", + "glob": "^7.0.5", + "readable-stream": "^2.1.5", + "tap-parser": "^10.0.0", + "tap-yaml": "^1.0.0", + "unicode-length": "^1.0.0" + }, + "dependencies": { + "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" + } + }, + "diff": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/diff/-/diff-1.4.0.tgz", + "integrity": "sha1-fyjS657nsVqX79ic5j3P2qPMur8=", + "dev": true + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true + } + } + }, + "tap-parser": { + "version": "10.0.1", + "resolved": "https://registry.npmjs.org/tap-parser/-/tap-parser-10.0.1.tgz", + "integrity": "sha512-qdT15H0DoJIi7zOqVXDn9X0gSM68JjNy1w3VemwTJlDnETjbi6SutnqmBfjDJAwkFS79NJ97gZKqie00ZCGmzg==", + "dev": true, + "requires": { + "events-to-array": "^1.0.1", + "minipass": "^3.0.0", + "tap-yaml": "^1.0.0" + } + }, + "tap-yaml": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/tap-yaml/-/tap-yaml-1.0.0.tgz", + "integrity": "sha512-Rxbx4EnrWkYk0/ztcm5u3/VznbyFJpyXO12dDBHKWiDVxy7O2Qw6MRrwO5H6Ww0U5YhRY/4C/VzWmFPhBQc4qQ==", + "dev": true, + "requires": { + "yaml": "^1.5.0" + } + }, + "tcompare": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/tcompare/-/tcompare-3.0.4.tgz", + "integrity": "sha512-Q3TitMVK59NyKgQyFh+857wTAUE329IzLDehuPgU4nF5e8g+EUQ+yUbjUy1/6ugiNnXztphT+NnqlCXolv9P3A==", + "dev": true, + "requires": { + "diff-frag": "^1.0.1" + } + }, + "test-exclude": { + "version": "5.2.3", + "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-5.2.3.tgz", + "integrity": "sha512-M+oxtseCFO3EDtAaGH7iiej3CBkzXqFMbzqYAACdzKui4eZA+pq3tZEwChvOdNfa7xxy8BfbmgJSIr43cC/+2g==", + "dev": true, + "requires": { + "glob": "^7.1.3", + "minimatch": "^3.0.4", + "read-pkg-up": "^4.0.0", + "require-main-filename": "^2.0.0" + } + }, + "to-fast-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", + "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", + "dev": true + }, + "to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "dev": true, + "requires": { + "is-number": "^7.0.0" + } + }, + "tough-cookie": { + "version": "2.4.3", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz", + "integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==", + "dev": true, + "requires": { + "psl": "^1.1.24", + "punycode": "^1.4.1" + }, + "dependencies": { + "punycode": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", + "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 + }, + "ts-node": { + "version": "8.5.4", + "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-8.5.4.tgz", + "integrity": "sha512-izbVCRV68EasEPQ8MSIGBNK9dc/4sYJJKYA+IarMQct1RtEot6Xp0bXuClsbUSnKpg50ho+aOAx8en5c+y4OFw==", + "dev": true, + "requires": { + "arg": "^4.1.0", + "diff": "^4.0.1", + "make-error": "^1.1.1", + "source-map-support": "^0.5.6", + "yn": "^3.0.0" + } + }, + "tunnel-agent": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", + "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", + "dev": true, + "requires": { + "safe-buffer": "^5.0.1" + } + }, + "tweetnacl": { + "version": "0.14.5", + "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", + "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", + "dev": true + }, + "typedarray-to-buffer": { + "version": "3.1.5", + "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", + "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", + "dev": true, + "requires": { + "is-typedarray": "^1.0.0" + } + }, + "typescript": { + "version": "3.7.3", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.7.3.tgz", + "integrity": "sha512-Mcr/Qk7hXqFBXMN7p7Lusj1ktCBydylfQM/FZCk5glCNQJrCUKPkMHdo9R0MTFWsC/4kPFvDS0fDPvukfCkFsw==", + "dev": true + }, + "uglify-js": { + "version": "3.7.2", + "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.7.2.tgz", + "integrity": "sha512-uhRwZcANNWVLrxLfNFEdltoPNhECUR3lc+UdJoG9CBpMcSnKyWA94tc3eAujB1GcMY5Uwq8ZMp4qWpxWYDQmaA==", + "dev": true, + "optional": true, + "requires": { + "commander": "~2.20.3", + "source-map": "~0.6.1" + } + }, + "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.3.2", + "strip-ansi": "^3.0.1" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "dev": true + }, + "punycode": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", + "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.0.0" + } + } + } + }, + "uri-js": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", + "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", + "dev": true, + "requires": { + "punycode": "^2.1.0" + } + }, + "util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", + "dev": true, + "optional": true + }, + "uuid": { + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.3.tgz", + "integrity": "sha512-pW0No1RGHgzlpHJO1nsVrHKpOEIxkGg1xB+v0ZmdNH5OAeAwzAVrCnI2/6Mtx+Uys6iaylxa+D3g4j63IKKjSQ==", + "dev": true + }, + "validate-npm-package-license": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", + "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", + "dev": true, + "requires": { + "spdx-correct": "^3.0.0", + "spdx-expression-parse": "^3.0.0" + } + }, + "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.2.0" + } + }, + "vlq": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/vlq/-/vlq-0.2.3.tgz", + "integrity": "sha512-DRibZL6DsNhIgYQ+wNdWDL2SL3bKPlVrRiBqV5yuMm++op8W4kGFtaQfCs4KEJn0wBZcHVHJ3eoywX8983k1ow==", + "dev": true + }, + "which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + }, + "which-module": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", + "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", + "dev": true + }, + "wordwrap": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.3.tgz", + "integrity": "sha1-o9XabNXAvAAI03I0u68b7WMFkQc=", + "dev": true + }, + "wrap-ansi": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", + "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", + "dev": true, + "requires": { + "string-width": "^1.0.1", + "strip-ansi": "^3.0.1" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", + "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", + "dev": true, + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "string-width": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", + "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", + "dev": true, + "requires": { + "code-point-at": "^1.0.0", + "is-fullwidth-code-point": "^1.0.0", + "strip-ansi": "^3.0.0" + } + }, + "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.0.0" + } + } + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", + "dev": true + }, + "write-file-atomic": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.1.tgz", + "integrity": "sha512-JPStrIyyVJ6oCSz/691fAjFtefZ6q+fP6tm+OS4Qw6o+TGQxNp1ziY2PgS+X/m0V8OWhZiO/m4xSj+Pr4RrZvw==", + "dev": true, + "requires": { + "imurmurhash": "^0.1.4", + "is-typedarray": "^1.0.0", + "signal-exit": "^3.0.2", + "typedarray-to-buffer": "^3.1.5" + } + }, + "y18n": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", + "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==", + "dev": true + }, + "yallist": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", + "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", + "dev": true + }, + "yaml": { + "version": "1.7.2", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.7.2.tgz", + "integrity": "sha512-qXROVp90sb83XtAoqE8bP9RwAkTTZbugRUTm5YeFCBfNRPEp2YzTeqWiz7m5OORHzEvrA/qcGS8hp/E+MMROYw==", + "dev": true, + "requires": { + "@babel/runtime": "^7.6.3" + } + }, + "yapool": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/yapool/-/yapool-1.0.0.tgz", + "integrity": "sha1-9pPymjFbUNmp2iZGp6ZkXJaYW2o=", + "dev": true + }, + "yargs": { + "version": "13.3.0", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.0.tgz", + "integrity": "sha512-2eehun/8ALW8TLoIl7MVaRUrg+yCnenu8B4kBlRxj3GJGDKU1Og7sMXPNm1BYyM1DOJmTZ4YeN/Nwxv+8XJsUA==", + "dev": true, + "requires": { + "cliui": "^5.0.0", + "find-up": "^3.0.0", + "get-caller-file": "^2.0.1", + "require-directory": "^2.1.1", + "require-main-filename": "^2.0.0", + "set-blocking": "^2.0.0", + "string-width": "^3.0.0", + "which-module": "^2.0.0", + "y18n": "^4.0.0", + "yargs-parser": "^13.1.1" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", + "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", + "dev": true + }, + "cliui": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", + "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", + "dev": true, + "requires": { + "string-width": "^3.1.0", + "strip-ansi": "^5.2.0", + "wrap-ansi": "^5.1.0" + } + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", + "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "dev": true, + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + } + }, + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "dev": true, + "requires": { + "ansi-regex": "^4.1.0" + } + }, + "wrap-ansi": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", + "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.0", + "string-width": "^3.0.0", + "strip-ansi": "^5.0.0" + } + } + } + }, + "yargs-parser": { + "version": "13.1.1", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.1.tgz", + "integrity": "sha512-oVAVsHz6uFrg3XQheFII8ESO2ssAf9luWuAd6Wexsu4F3OtIW0o8IribPXYrD4WC24LWtPrJlGy87y5udK+dxQ==", + "dev": true, + "requires": { + "camelcase": "^5.0.0", + "decamelize": "^1.2.0" + } + }, + "yn": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", + "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==", + "dev": true + } + } +} diff --git a/deps/npm/node_modules/npm-normalize-package-bin/package.json b/deps/npm/node_modules/npm-normalize-package-bin/package.json new file mode 100644 index 00000000000000..c0e548cc537bd0 --- /dev/null +++ b/deps/npm/node_modules/npm-normalize-package-bin/package.json @@ -0,0 +1,57 @@ +{ + "_from": "npm-normalize-package-bin@^1.0.0", + "_id": "npm-normalize-package-bin@1.0.1", + "_inBundle": false, + "_integrity": "sha512-EPfafl6JL5/rU+ot6P3gRSCpPDW5VmIzX959Ob1+ySFUuuYHWHekXpwdUZcKP5C+DS4GEtdJluwBjnsNDl+fSA==", + "_location": "/npm-normalize-package-bin", + "_phantomChildren": {}, + "_requested": { + "type": "range", + "registry": true, + "raw": "npm-normalize-package-bin@^1.0.0", + "name": "npm-normalize-package-bin", + "escapedName": "npm-normalize-package-bin", + "rawSpec": "^1.0.0", + "saveSpec": null, + "fetchSpec": "^1.0.0" + }, + "_requiredBy": [ + "/bin-links" + ], + "_resolved": "https://registry.npmjs.org/npm-normalize-package-bin/-/npm-normalize-package-bin-1.0.1.tgz", + "_shasum": "6e79a41f23fd235c0623218228da7d9c23b8f6e2", + "_spec": "npm-normalize-package-bin@^1.0.0", + "_where": "/Users/isaacs/dev/npm/cli/node_modules/bin-links", + "author": { + "name": "Isaac Z. Schlueter", + "email": "i@izs.me", + "url": "https://izs.me" + }, + "bugs": { + "url": "https://github.com/npm/npm-normalize-package-bin/issues" + }, + "bundleDependencies": false, + "deprecated": false, + "description": "Turn any flavor of allowable package.json bin into a normalized object", + "devDependencies": { + "tap": "^14.10.2" + }, + "homepage": "https://github.com/npm/npm-normalize-package-bin#readme", + "license": "ISC", + "name": "npm-normalize-package-bin", + "repository": { + "type": "git", + "url": "git+https://github.com/npm/npm-normalize-package-bin.git" + }, + "scripts": { + "postpublish": "git push origin --follow-tags", + "postversion": "npm publish", + "preversion": "npm test", + "snap": "tap", + "test": "tap" + }, + "tap": { + "check-coverage": true + }, + "version": "1.0.1" +} diff --git a/deps/npm/node_modules/npm-normalize-package-bin/test/array.js b/deps/npm/node_modules/npm-normalize-package-bin/test/array.js new file mode 100644 index 00000000000000..63dafa89137411 --- /dev/null +++ b/deps/npm/node_modules/npm-normalize-package-bin/test/array.js @@ -0,0 +1,37 @@ +const normalize = require('../') +const t = require('tap') + +t.test('benign array', async t => { + const pkg = { name: 'hello', version: 'world', bin: ['./x/y', 'y/z', './a'] } + const expect = { name: 'hello', version: 'world', bin: { + y: 'x/y', + z: 'y/z', + a: 'a', + } } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('conflicting array', async t => { + const pkg = { name: 'hello', version: 'world', bin: ['./x/y', 'z/y', './a'] } + const expect = { name: 'hello', version: 'world', bin: { + y: 'z/y', + a: 'a', + } } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('slashy array', async t => { + const pkg = { name: 'hello', version: 'world', bin: [ '/etc/passwd' ] } + const expect = { name: 'hello', version: 'world', bin: { passwd: 'etc/passwd' } } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('dotty array', async t => { + const pkg = { name: 'hello', version: 'world', bin: ['../../../../etc/passwd'] } + const expect = { name: 'hello', version: 'world', bin: { passwd: 'etc/passwd' } } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) diff --git a/deps/npm/node_modules/npm-normalize-package-bin/test/nobin.js b/deps/npm/node_modules/npm-normalize-package-bin/test/nobin.js new file mode 100644 index 00000000000000..536d7eb22f68a9 --- /dev/null +++ b/deps/npm/node_modules/npm-normalize-package-bin/test/nobin.js @@ -0,0 +1,35 @@ +const normalize = require('../') +const t = require('tap') + +// all of these just delete the bins, so expect the same value +const expect = { name: 'hello', version: 'world' } + +t.test('no bin in object', async t => { + const pkg = { name: 'hello', version: 'world' } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('empty string bin in object', async t => { + const pkg = { name: 'hello', version: 'world', bin: '' } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('false bin in object', async t => { + const pkg = { name: 'hello', version: 'world', bin: false } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('null bin in object', async t => { + const pkg = { name: 'hello', version: 'world', bin: null } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('number bin', async t => { + const pkg = { name: 'hello', version: 'world', bin: 42069 } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) diff --git a/deps/npm/node_modules/npm-normalize-package-bin/test/object.js b/deps/npm/node_modules/npm-normalize-package-bin/test/object.js new file mode 100644 index 00000000000000..00d23684fb75b6 --- /dev/null +++ b/deps/npm/node_modules/npm-normalize-package-bin/test/object.js @@ -0,0 +1,141 @@ +const normalize = require('../') +const t = require('tap') + +t.test('benign object', async t => { + // just clean up the ./ in the targets and remove anything weird + const pkg = { name: 'hello', version: 'world', bin: { + y: './x/y', + z: './y/z', + a: './a', + } } + const expect = { name: 'hello', version: 'world', bin: { + y: 'x/y', + z: 'y/z', + a: 'a', + } } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('empty and non-string targets', async t => { + // just clean up the ./ in the targets and remove anything weird + const pkg = { name: 'hello', version: 'world', bin: { + z: './././', + y: '', + './x': 'x.js', + re: /asdf/, + foo: { bar: 'baz' }, + false: false, + null: null, + array: [1,2,3], + func: function () {}, + } } + const expect = { name: 'hello', version: 'world', bin: { + x: 'x.js', + } } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('slashy object', async t => { + const pkg = { name: 'hello', version: 'world', bin: { + '/path/foo': '/etc/passwd', + 'bar': '/etc/passwd', + '/etc/glorb/baz': '/etc/passwd', + '/etc/passwd:/bin/usr/exec': '/etc/passwd', + } } + const expect = { + name: 'hello', + version: 'world', + bin: { + foo: 'etc/passwd', + bar: 'etc/passwd', + baz: 'etc/passwd', + exec: 'etc/passwd', + } + } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('dotty object', async t => { + const pkg = { + name: 'hello', + version: 'world', + bin: { + 'nodots': '../../../../etc/passwd', + '../../../../../../dots': '../../../../etc/passwd', + '.././../\\./..//C:\\./': 'this is removed', + '.././../\\./..//C:\\/': 'super safe programming language', + '.././../\\./..//C:\\x\\y\\z/': 'xyz', + } } + const expect = { name: 'hello', version: 'world', bin: { + nodots: 'etc/passwd', + dots: 'etc/passwd', + C: 'super safe programming language', + z: 'xyz', + } } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('weird object', async t => { + const pkg = { name: 'hello', version: 'world', bin: /asdf/ } + const expect = { name: 'hello', version: 'world' } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('oddball keys', async t => { + const pkg = { + bin: { + '~': 'target', + '£': 'target', + 'ζ': 'target', + 'ぎ': 'target', + '操': 'target', + '🎱': 'target', + '💎': 'target', + '💸': 'target', + '🦉': 'target', + 'сheck-dom': 'target', + 'Ωpm': 'target', + 'ζλ': 'target', + 'мга': 'target', + 'пше': 'target', + 'тзч': 'target', + 'тзь': 'target', + 'нфкт': 'target', + 'ссср': 'target', + '君の名は': 'target', + '君の名は': 'target', + } + } + + const expect = { + bin: { + '~': 'target', + '£': 'target', + 'ζ': 'target', + 'ぎ': 'target', + '操': 'target', + '🎱': 'target', + '💎': 'target', + '💸': 'target', + '🦉': 'target', + 'сheck-dom': 'target', + 'Ωpm': 'target', + 'ζλ': 'target', + 'мга': 'target', + 'пше': 'target', + 'тзч': 'target', + 'тзь': 'target', + 'нфкт': 'target', + 'ссср': 'target', + '君の名は': 'target', + }, + } + + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) diff --git a/deps/npm/node_modules/npm-normalize-package-bin/test/string.js b/deps/npm/node_modules/npm-normalize-package-bin/test/string.js new file mode 100644 index 00000000000000..b6de8f8f589b5c --- /dev/null +++ b/deps/npm/node_modules/npm-normalize-package-bin/test/string.js @@ -0,0 +1,37 @@ +const normalize = require('../') +const t = require('tap') + +t.test('benign string', async t => { + const pkg = { name: 'hello', version: 'world', bin: 'hello.js' } + const expect = { name: 'hello', version: 'world', bin: { hello: 'hello.js' } } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('slashy string', async t => { + const pkg = { name: 'hello', version: 'world', bin: '/etc/passwd' } + const expect = { name: 'hello', version: 'world', bin: { hello: 'etc/passwd' } } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('dotty string', async t => { + const pkg = { name: 'hello', version: 'world', bin: '../../../../etc/passwd' } + const expect = { name: 'hello', version: 'world', bin: { hello: 'etc/passwd' } } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('double path', async t => { + const pkg = { name: 'hello', version: 'world', bin: '/etc/passwd:/bin/usr/exec' } + const expect = { name: 'hello', version: 'world', bin: { hello: 'etc/passwd:/bin/usr/exec' } } + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) + +t.test('string with no name', async t => { + const pkg = { bin: 'foobar.js' } + const expect = {} + t.strictSame(normalize(pkg), expect) + t.strictSame(normalize(normalize(pkg)), expect, 'double sanitize ok') +}) diff --git a/deps/npm/node_modules/npm-packlist/index.js b/deps/npm/node_modules/npm-packlist/index.js index dd7706a4aee2a5..eaf14b86617514 100644 --- a/deps/npm/node_modules/npm-packlist/index.js +++ b/deps/npm/node_modules/npm-packlist/index.js @@ -17,6 +17,8 @@ const rootBuiltinRules = Symbol('root-builtin-rules') const packageNecessaryRules = Symbol('package-necessary-rules') const path = require('path') +const normalizePackageBin = require('npm-normalize-package-bin') + const defaultRules = [ '.npmignore', '.gitignore', @@ -176,12 +178,11 @@ const npmWalker = Class => class Walker extends Class { '!npm-shrinkwrap.json', '!@(readme|copying|license|licence|notice|changes|changelog|history){,.*[^~$]}' ] - if (pkg.bin) - if (typeof pkg.bin === "object") - for (const key in pkg.bin) - rules.push('!' + pkg.bin[key]) - else - rules.push('!' + pkg.bin) + if (pkg.bin) { + // always an object, because normalized already + for (const key in pkg.bin) + rules.push('!' + pkg.bin[key]) + } const data = rules.filter(f => f).join('\n') + '\n' super.onReadIgnoreFile(packageNecessaryRules, data, _=>_) @@ -216,7 +217,7 @@ const npmWalker = Class => class Walker extends Class { if (file === 'package.json') try { const ig = path.resolve(this.path, file) - this.onPackageJson(ig, JSON.parse(data), then) + this.onPackageJson(ig, normalizePackageBin(JSON.parse(data)), then) } catch (er) { // ignore package.json files that are not json then() diff --git a/deps/npm/node_modules/npm-packlist/package.json b/deps/npm/node_modules/npm-packlist/package.json index a8fabfa7f12405..c022dcef65b515 100644 --- a/deps/npm/node_modules/npm-packlist/package.json +++ b/deps/npm/node_modules/npm-packlist/package.json @@ -1,29 +1,29 @@ { - "_from": "npm-packlist@1.4.6", - "_id": "npm-packlist@1.4.6", + "_from": "npm-packlist@1.4.7", + "_id": "npm-packlist@1.4.7", "_inBundle": false, - "_integrity": "sha512-u65uQdb+qwtGvEJh/DgQgW1Xg7sqeNbmxYyrvlNznaVTjV3E5P6F/EFjM+BVHXl7JJlsdG8A64M0XI8FI/IOlg==", + "_integrity": "sha512-vAj7dIkp5NhieaGZxBJB8fF4R0078rqsmhJcAfXZ6O7JJhjhPK96n5Ry1oZcfLXgfun0GWTZPOxaEyqv8GBykQ==", "_location": "/npm-packlist", "_phantomChildren": {}, "_requested": { "type": "version", "registry": true, - "raw": "npm-packlist@1.4.6", + "raw": "npm-packlist@1.4.7", "name": "npm-packlist", "escapedName": "npm-packlist", - "rawSpec": "1.4.6", + "rawSpec": "1.4.7", "saveSpec": null, - "fetchSpec": "1.4.6" + "fetchSpec": "1.4.7" }, "_requiredBy": [ "#USER", "/", "/pacote" ], - "_resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-1.4.6.tgz", - "_shasum": "53ba3ed11f8523079f1457376dd379ee4ea42ff4", - "_spec": "npm-packlist@1.4.6", - "_where": "/Users/mperrotte/npminc/cli", + "_resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-1.4.7.tgz", + "_shasum": "9e954365a06b80b18111ea900945af4f88ed4848", + "_spec": "npm-packlist@1.4.7", + "_where": "/Users/isaacs/dev/npm/cli", "author": { "name": "Isaac Z. Schlueter", "email": "i@izs.me", @@ -54,6 +54,9 @@ "license": "ISC", "main": "index.js", "name": "npm-packlist", + "publishConfig": { + "tag": "legacy-v1" + }, "repository": { "type": "git", "url": "git+https://github.com/npm/npm-packlist.git" @@ -68,5 +71,5 @@ "tap": { "jobs": 1 }, - "version": "1.4.6" + "version": "1.4.7" } diff --git a/deps/npm/node_modules/pacote/CHANGELOG.md b/deps/npm/node_modules/pacote/CHANGELOG.md index 6896c4739ce532..722a9fa168876e 100644 --- a/deps/npm/node_modules/pacote/CHANGELOG.md +++ b/deps/npm/node_modules/pacote/CHANGELOG.md @@ -2,6 +2,26 @@ All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines. + +## [9.5.11](https://github.com/npm/pacote/compare/v9.5.10...v9.5.11) (2019-12-09) + + +### Bug Fixes + +* sanitize and normalize package bin field ([6f229f7](https://github.com/npm/pacote/commit/6f229f7)) + + + + +## [9.5.10](https://github.com/npm/pacote/compare/v9.5.9...v9.5.10) (2019-12-04) + + +### Bug Fixes + +* Do not drop perms in git when not root ([5f33040](https://github.com/npm/pacote/commit/5f33040)), closes [#23](https://github.com/npm/pacote/issues/23) + + + ## [9.5.9](https://github.com/npm/pacote/compare/v9.5.8...v9.5.9) (2019-10-29) diff --git a/deps/npm/node_modules/pacote/lib/fetchers/directory.js b/deps/npm/node_modules/pacote/lib/fetchers/directory.js index 3d4ec24c83f278..fc9c46cd3b7e9c 100644 --- a/deps/npm/node_modules/pacote/lib/fetchers/directory.js +++ b/deps/npm/node_modules/pacote/lib/fetchers/directory.js @@ -9,6 +9,7 @@ const readJson = require('../util/read-json') const path = require('path') const pipe = BB.promisify(require('mississippi').pipe) const through = require('mississippi').through +const normalizePackageBin = require('npm-normalize-package-bin') const readFileAsync = BB.promisify(require('fs').readFile) @@ -63,7 +64,7 @@ Fetcher.impl(fetchDirectory, { } else { return pkg } - }) + }).then(pkg => normalizePackageBin(pkg)) }, // As of npm@5, the npm installer doesn't pack + install directories: it just diff --git a/deps/npm/node_modules/pacote/lib/fetchers/git.js b/deps/npm/node_modules/pacote/lib/fetchers/git.js index 7913be81687912..a1579d1f943125 100644 --- a/deps/npm/node_modules/pacote/lib/fetchers/git.js +++ b/deps/npm/node_modules/pacote/lib/fetchers/git.js @@ -166,7 +166,7 @@ function withTmp (opts, cb) { } } -// Only certain whitelisted hosted gits support shallow cloning +// Only certain whitelisted hosted gits support shadow cloning const SHALLOW_HOSTS = new Set(['github', 'gist', 'gitlab', 'bitbucket']) function cloneRepo (spec, repo, resolvedRef, rawRef, tmp, opts) { const ref = resolvedRef ? resolvedRef.ref : rawRef diff --git a/deps/npm/node_modules/pacote/lib/finalize-manifest.js b/deps/npm/node_modules/pacote/lib/finalize-manifest.js index d1d0f4e563eed2..80b9cda73b6ee1 100644 --- a/deps/npm/node_modules/pacote/lib/finalize-manifest.js +++ b/deps/npm/node_modules/pacote/lib/finalize-manifest.js @@ -14,6 +14,7 @@ const pipe = BB.promisify(require('mississippi').pipe) const ssri = require('ssri') const tar = require('tar') const readJson = require('./util/read-json') +const normalizePackageBin = require('npm-normalize-package-bin') // `finalizeManifest` takes as input the various kinds of manifests that // manifest handlers ('lib/fetchers/*.js#manifest()') return, and makes sure @@ -105,17 +106,8 @@ function Manifest (pkg, fromTarball, fullMetadata) { this._shrinkwrap = pkg._shrinkwrap || fromTarball._shrinkwrap || null this.bin = pkg.bin || fromTarball.bin || null - if (this.bin && Array.isArray(this.bin)) { - // Code yanked from read-package-json. - const m = (pkg.directories && pkg.directories.bin) || '.' - this.bin = this.bin.reduce((acc, mf) => { - if (mf && mf.charAt(0) !== '.') { - const f = path.basename(mf) - acc[f] = path.join(m, mf) - } - return acc - }, {}) - } + // turn arrays and strings into a legit object, strip out bad stuff + normalizePackageBin(this) this._id = null diff --git a/deps/npm/node_modules/pacote/lib/util/git.js b/deps/npm/node_modules/pacote/lib/util/git.js index 7991833abed0e3..d2282bae15edad 100644 --- a/deps/npm/node_modules/pacote/lib/util/git.js +++ b/deps/npm/node_modules/pacote/lib/util/git.js @@ -234,14 +234,17 @@ function spawnGit (gitArgs, gitOpts, opts) { }) } +module.exports._mkOpts = mkOpts function mkOpts (_gitOpts, opts) { const gitOpts = { env: gitEnv() } - if (+opts.uid && !isNaN(opts.uid)) { + const isRoot = process.getuid && process.getuid() === 0 + // don't change child process uid/gid if not root + if (+opts.uid && !isNaN(opts.uid) && isRoot) { gitOpts.uid = +opts.uid } - if (+opts.gid && !isNaN(opts.gid)) { + if (+opts.gid && !isNaN(opts.gid) && isRoot) { gitOpts.gid = +opts.gid } Object.assign(gitOpts, _gitOpts) diff --git a/deps/npm/node_modules/pacote/package.json b/deps/npm/node_modules/pacote/package.json index a60ed752703539..1efb87c5838e68 100644 --- a/deps/npm/node_modules/pacote/package.json +++ b/deps/npm/node_modules/pacote/package.json @@ -1,8 +1,8 @@ { - "_from": "pacote@9.5.9", - "_id": "pacote@9.5.9", + "_from": "pacote@9.5.11", + "_id": "pacote@9.5.11", "_inBundle": false, - "_integrity": "sha512-S1nYW9ly+3btn3VmwRAk2LG3TEh8mkrFdY+psbnHSk8oPODbZ28uG0Z0d3yI0EpqcpLR6BukoVRf3H4IbGCkPQ==", + "_integrity": "sha512-DMDPvFKCjCg6zMS4IfzZyvT57O/bX8XGG00eEoy4K/S4Wj+qiN8KbnmKpsTvfS6OL9r5TAicxMKWbj1yV2Yh4g==", "_location": "/pacote", "_phantomChildren": { "safe-buffer": "5.1.2", @@ -11,12 +11,12 @@ "_requested": { "type": "version", "registry": true, - "raw": "pacote@9.5.9", + "raw": "pacote@9.5.11", "name": "pacote", "escapedName": "pacote", - "rawSpec": "9.5.9", + "rawSpec": "9.5.11", "saveSpec": null, - "fetchSpec": "9.5.9" + "fetchSpec": "9.5.11" }, "_requiredBy": [ "#USER", @@ -24,10 +24,10 @@ "/libcipm", "/libnpm" ], - "_resolved": "https://registry.npmjs.org/pacote/-/pacote-9.5.9.tgz", - "_shasum": "fa3a08629c9390b2b99769c55b2cc137e1a24df3", - "_spec": "pacote@9.5.9", - "_where": "/Users/ruyadorno/Documents/workspace/cli", + "_resolved": "https://registry.npmjs.org/pacote/-/pacote-9.5.11.tgz", + "_shasum": "524152077cb392c47b1fbe198aa28f778bef7ee1", + "_spec": "pacote@9.5.11", + "_where": "/Users/isaacs/dev/npm/cli", "author": { "name": "Kat Marchán", "email": "kzm@sykosomatic.org" @@ -61,6 +61,7 @@ "mississippi": "^3.0.0", "mkdirp": "^0.5.1", "normalize-package-data": "^2.4.0", + "npm-normalize-package-bin": "^1.0.0", "npm-package-arg": "^6.1.0", "npm-packlist": "^1.1.12", "npm-pick-manifest": "^3.0.0", @@ -105,6 +106,9 @@ "license": "MIT", "main": "index.js", "name": "pacote", + "publishConfig": { + "tag": "v9-legacy" + }, "repository": { "type": "git", "url": "git+https://github.com/npm/pacote.git" @@ -119,5 +123,5 @@ "update-coc": "weallbehave -o . && git add CODE_OF_CONDUCT.md && git commit -m 'docs(coc): updated CODE_OF_CONDUCT.md'", "update-contrib": "weallcontribute -o . && git add CONTRIBUTING.md && git commit -m 'docs(contributing): updated CONTRIBUTING.md'" }, - "version": "9.5.9" + "version": "9.5.11" } diff --git a/deps/npm/node_modules/read-package-json/CHANGELOG.md b/deps/npm/node_modules/read-package-json/CHANGELOG.md index b21f94d72792bc..e6f26e59d28ef8 100644 --- a/deps/npm/node_modules/read-package-json/CHANGELOG.md +++ b/deps/npm/node_modules/read-package-json/CHANGELOG.md @@ -2,6 +2,16 @@ All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines. + +## [2.1.1](https://github.com/npm/read-package-json/compare/v2.1.0...v2.1.1) (2019-12-09) + + +### Bug Fixes + +* normalize and sanitize pkg bin entries ([b8cb5fa](https://github.com/npm/read-package-json/commit/b8cb5fa)) + + + # [2.1.0](https://github.com/npm/read-package-json/compare/v2.0.13...v2.1.0) (2019-08-13) diff --git a/deps/npm/node_modules/read-package-json/package.json b/deps/npm/node_modules/read-package-json/package.json index 5c597498814bd3..7920e43589939a 100644 --- a/deps/npm/node_modules/read-package-json/package.json +++ b/deps/npm/node_modules/read-package-json/package.json @@ -1,19 +1,19 @@ { - "_from": "read-package-json@2.1.0", - "_id": "read-package-json@2.1.0", + "_from": "read-package-json@2.1.1", + "_id": "read-package-json@2.1.1", "_inBundle": false, - "_integrity": "sha512-KLhu8M1ZZNkMcrq1+0UJbR8Dii8KZUqB0Sha4mOx/bknfKI/fyrQVrG/YIt2UOtG667sD8+ee4EXMM91W9dC+A==", + "_integrity": "sha512-dAiqGtVc/q5doFz6096CcnXhpYk0ZN8dEKVkGLU0CsASt8SrgF6SF7OTKAYubfvFhWaqofl+Y8HK19GR8jwW+A==", "_location": "/read-package-json", "_phantomChildren": {}, "_requested": { "type": "version", "registry": true, - "raw": "read-package-json@2.1.0", + "raw": "read-package-json@2.1.1", "name": "read-package-json", "escapedName": "read-package-json", - "rawSpec": "2.1.0", + "rawSpec": "2.1.1", "saveSpec": null, - "fetchSpec": "2.1.0" + "fetchSpec": "2.1.1" }, "_requiredBy": [ "#USER", @@ -24,9 +24,9 @@ "/read-installed", "/read-package-tree" ], - "_resolved": "https://registry.npmjs.org/read-package-json/-/read-package-json-2.1.0.tgz", - "_shasum": "e3d42e6c35ea5ae820d9a03ab0c7291217fc51d5", - "_spec": "read-package-json@2.1.0", + "_resolved": "https://registry.npmjs.org/read-package-json/-/read-package-json-2.1.1.tgz", + "_shasum": "16aa66c59e7d4dad6288f179dd9295fd59bb98f1", + "_spec": "read-package-json@2.1.1", "_where": "/Users/isaacs/dev/npm/cli", "author": { "name": "Isaac Z. Schlueter", @@ -42,7 +42,7 @@ "graceful-fs": "^4.1.2", "json-parse-better-errors": "^1.0.1", "normalize-package-data": "^2.0.0", - "slash": "^1.0.0" + "npm-normalize-package-bin": "^1.0.0" }, "deprecated": false, "description": "The thing npm uses to read package.json files with semantics and defaults and validation", @@ -72,5 +72,5 @@ "release": "standard-version -s", "test": "tap --nyc-arg=--all --coverage test/*.js" }, - "version": "2.1.0" + "version": "2.1.1" } diff --git a/deps/npm/node_modules/read-package-json/read-json.js b/deps/npm/node_modules/read-package-json/read-json.js index 9f8f81bd1cadac..03da84762eb293 100644 --- a/deps/npm/node_modules/read-package-json/read-json.js +++ b/deps/npm/node_modules/read-package-json/read-json.js @@ -11,7 +11,7 @@ var glob = require('glob') var normalizeData = require('normalize-package-data') var safeJSON = require('json-parse-better-errors') var util = require('util') -var slash = require('slash') +var normalizePackageBin = require('npm-normalize-package-bin') module.exports = readJson @@ -301,7 +301,7 @@ function mans_ (file, data, mans, cb) { } function bins (file, data, cb) { - if (Array.isArray(data.bin)) return bins_(file, data, data.bin, cb) + data = normalizePackageBin(data) var m = data.directories && data.directories.bin if (data.bin || !m) return cb(null, data) @@ -318,11 +318,11 @@ function bins_ (file, data, bins, cb) { data.bin = bins.reduce(function (acc, mf) { if (mf && mf.charAt(0) !== '.') { var f = path.basename(mf) - acc[f] = slash(path.join(m, mf)) + acc[f] = path.join(m, mf) } return acc }, {}) - return cb(null, data) + return cb(null, normalizePackageBin(data)) } function bundleDependencies (file, data, cb) { @@ -403,6 +403,7 @@ function checkBinReferences_ (file, data, warn, cb) { keys.forEach(function (key) { var dirName = path.dirname(file) var relName = data.bin[key] + /* istanbul ignore if - impossible, bins have been normalized */ if (typeof relName !== 'string') { var msg = 'Bin filename for ' + key + ' is not a string: ' + util.inspect(relName) diff --git a/deps/npm/node_modules/slash/index.js b/deps/npm/node_modules/slash/index.js deleted file mode 100644 index b946a0841a01f4..00000000000000 --- a/deps/npm/node_modules/slash/index.js +++ /dev/null @@ -1,11 +0,0 @@ -'use strict'; -module.exports = function (str) { - var isExtendedLengthPath = /^\\\\\?\\/.test(str); - var hasNonAscii = /[^\x00-\x80]+/.test(str); - - if (isExtendedLengthPath || hasNonAscii) { - return str; - } - - return str.replace(/\\/g, '/'); -}; diff --git a/deps/npm/node_modules/slash/package.json b/deps/npm/node_modules/slash/package.json deleted file mode 100644 index bedd2680902b42..00000000000000 --- a/deps/npm/node_modules/slash/package.json +++ /dev/null @@ -1,65 +0,0 @@ -{ - "_from": "slash@^1.0.0", - "_id": "slash@1.0.0", - "_inBundle": false, - "_integrity": "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=", - "_location": "/slash", - "_phantomChildren": {}, - "_requested": { - "type": "range", - "registry": true, - "raw": "slash@^1.0.0", - "name": "slash", - "escapedName": "slash", - "rawSpec": "^1.0.0", - "saveSpec": null, - "fetchSpec": "^1.0.0" - }, - "_requiredBy": [ - "/read-package-json" - ], - "_resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz", - "_shasum": "c41f2f6c39fc16d1cd17ad4b5d896114ae470d55", - "_spec": "slash@^1.0.0", - "_where": "/Users/rebecca/code/npm/node_modules/read-package-json", - "author": { - "name": "Sindre Sorhus", - "email": "sindresorhus@gmail.com", - "url": "http://sindresorhus.com" - }, - "bugs": { - "url": "https://github.com/sindresorhus/slash/issues" - }, - "bundleDependencies": false, - "deprecated": false, - "description": "Convert Windows backslash paths to slash paths", - "devDependencies": { - "mocha": "*" - }, - "engines": { - "node": ">=0.10.0" - }, - "files": [ - "index.js" - ], - "homepage": "https://github.com/sindresorhus/slash#readme", - "keywords": [ - "path", - "seperator", - "sep", - "slash", - "backslash", - "windows", - "win" - ], - "license": "MIT", - "name": "slash", - "repository": { - "type": "git", - "url": "git+https://github.com/sindresorhus/slash.git" - }, - "scripts": { - "test": "mocha" - }, - "version": "1.0.0" -} diff --git a/deps/npm/node_modules/slash/readme.md b/deps/npm/node_modules/slash/readme.md deleted file mode 100644 index 15672f010e182f..00000000000000 --- a/deps/npm/node_modules/slash/readme.md +++ /dev/null @@ -1,44 +0,0 @@ -# slash [![Build Status](https://travis-ci.org/sindresorhus/slash.svg?branch=master)](https://travis-ci.org/sindresorhus/slash) - -> Convert Windows backslash paths to slash paths: `foo\\bar` ➔ `foo/bar` - -[Forward-slash paths can be used in Windows](http://superuser.com/a/176395/6877) as long as they're not extended-length paths and don't contain any non-ascii characters. - -This was created since the `path` methods in Node outputs `\\` paths on Windows. - - -## Install - -```sh -$ npm install --save slash -``` - - -## Usage - -```js -var path = require('path'); -var slash = require('slash'); - -var str = path.join('foo', 'bar'); -// Unix => foo/bar -// Windows => foo\\bar - -slash(str); -// Unix => foo/bar -// Windows => foo/bar -``` - - -## API - -### slash(path) - -Type: `string` - -Accepts a Windows backslash path and returns a slash path. - - -## License - -MIT © [Sindre Sorhus](http://sindresorhus.com) diff --git a/deps/npm/package.json b/deps/npm/package.json index 6fad0e829f1c54..d6c25dbca1457d 100644 --- a/deps/npm/package.json +++ b/deps/npm/package.json @@ -1,5 +1,5 @@ { - "version": "6.13.1", + "version": "6.13.4", "name": "npm", "description": "a package manager for JavaScript", "keywords": [ @@ -39,7 +39,7 @@ "ansistyles": "~0.1.3", "aproba": "^2.0.0", "archy": "~1.0.0", - "bin-links": "^1.1.3", + "bin-links": "^1.1.6", "bluebird": "^3.5.5", "byte-size": "^5.0.1", "cacache": "^12.0.3", @@ -59,7 +59,7 @@ "find-npm-prefix": "^1.0.2", "fs-vacuum": "~1.2.10", "fs-write-stream-atomic": "~1.0.10", - "gentle-fs": "^2.2.1", + "gentle-fs": "^2.3.0", "glob": "^7.1.4", "graceful-fs": "^4.2.3", "has-unicode": "~2.0.1", @@ -101,7 +101,7 @@ "npm-install-checks": "^3.0.2", "npm-lifecycle": "^3.1.4", "npm-package-arg": "^6.1.1", - "npm-packlist": "^1.4.6", + "npm-packlist": "^1.4.7", "npm-pick-manifest": "^3.0.2", "npm-profile": "^4.0.2", "npm-registry-fetch": "^4.0.2", @@ -110,7 +110,7 @@ "once": "~1.4.0", "opener": "^1.5.1", "osenv": "^0.1.5", - "pacote": "^9.5.9", + "pacote": "^9.5.11", "path-is-inside": "~1.0.2", "promise-inflight": "~1.0.1", "qrcode-terminal": "^0.12.0", @@ -119,7 +119,7 @@ "read": "~1.0.7", "read-cmd-shim": "^1.0.5", "read-installed": "~4.0.3", - "read-package-json": "^2.1.0", + "read-package-json": "^2.1.1", "read-package-tree": "^5.3.1", "readable-stream": "^3.4.0", "readdir-scoped-modules": "^1.1.0", diff --git a/deps/npm/scripts/install.sh b/deps/npm/scripts/install.sh index 4ed1062aa1308b..7f66151daea033 100755 --- a/deps/npm/scripts/install.sh +++ b/deps/npm/scripts/install.sh @@ -23,12 +23,14 @@ if [ "x$0" = "xsh" ]; then if [ $ret -eq 0 ]; then (exit 0) else + echo "Uninstalling npm-install-$$.sh" >&2 rm npm-install-$$.sh echo "Failed to download script" >&2 exit $ret fi sh npm-install-$$.sh ret=$? + echo "Uninstalling npm-install-$$.sh" >&2 rm npm-install-$$.sh exit $ret fi diff --git a/deps/npm/test/fixtures/config/userconfig-with-gc b/deps/npm/test/fixtures/config/userconfig-with-gc index b00d5195bd8361..cf774bb883d966 100644 --- a/deps/npm/test/fixtures/config/userconfig-with-gc +++ b/deps/npm/test/fixtures/config/userconfig-with-gc @@ -1,4 +1,4 @@ -globalconfig = /Users/claudiahdz/npm/cli/test/fixtures/config/globalconfig +globalconfig = /Users/isaacs/dev/npm/cli/test/fixtures/config/globalconfig email = i@izs.me env-thing = ${random_env_var} init.author.name = Isaac Z. Schlueter diff --git a/deps/npm/test/tap/bin-overwriting.js b/deps/npm/test/tap/bin-overwriting.js new file mode 100644 index 00000000000000..155d4abf520506 --- /dev/null +++ b/deps/npm/test/tap/bin-overwriting.js @@ -0,0 +1,107 @@ +const t = require('tap') +const common = require('../common-tap.js') +const pkg = common.pkg + +const { writeFileSync, readFileSync, readlink } = require('fs') +const readCmdShim = require('read-cmd-shim') +const path = require('path') +const readBinCb = process.platform === 'win32' ? readCmdShim : readlink +const readBin = bin => new Promise((resolve, reject) => { + readBinCb(bin, (er, target) => { + if (er) + reject(er) + else + resolve(path.resolve(pkg + '/global/bin', target)) + }) +}) + +// verify that we can't overwrite bins that we shouldn't be able to + +const mkdirp = require('mkdirp').sync + +process.env.npm_config_prefix = pkg + '/global' +process.env.npm_config_global = true + +const globalBin = process.platform === 'win32' + ? path.resolve(pkg, 'global') + : path.resolve(pkg, 'global/bin') + +const globalDir = process.platform === 'win32' + ? path.resolve(pkg, 'global/node_modules') + : path.resolve(pkg, 'global/lib/node_modules') + +const beep = path.resolve(globalBin, 'beep') +const firstBin = path.resolve(globalDir, 'first/first.js') +const secondBin = path.resolve(globalDir, 'second/second.js') + +t.test('setup', { bail: true }, t => { + // set up non-link bin in place + mkdirp(globalBin) + writeFileSync(beep, 'beep boop') + + // create first package + mkdirp(pkg + '/first') + writeFileSync(pkg + '/first/package.json', JSON.stringify({ + name: 'first', + version: '1.0.0', + bin: { beep: 'first.js' } + })) + writeFileSync(pkg + '/first/first.js', `#!/usr/bin/env node + console.log('first')`) + + // create second package + mkdirp(pkg + '/second') + writeFileSync(pkg + '/second/package.json', JSON.stringify({ + name: 'second', + version: '1.0.0', + bin: { beep: 'second.js' } + })) + writeFileSync(pkg + '/second/second.js', `#!/usr/bin/env node + console.log('second')`) + + // pack both to install globally + return common.npm(['pack'], { cwd: pkg + '/first' }) + .then(() => common.npm(['pack'], { cwd: pkg + '/second' })) +}) + +t.test('installing first fails, because pre-existing bin in place', t => { + return common.npm([ + 'install', + pkg + '/first/first-1.0.0.tgz' + ]).then(([code, stdout, stderr]) => { + t.notEqual(code, 0) + t.match(stderr, 'EEXIST') + t.equal(readFileSync(beep, 'utf8'), 'beep boop') + }) +}) + +t.test('installing first with --force succeeds', t => { + return common.npm([ + 'install', + pkg + '/first/first-1.0.0.tgz', + '--force' + ]).then(() => { + return t.resolveMatch(readBin(beep), firstBin, 'bin written to first.js') + }) +}) + +t.test('installing second fails, because bin links to other package', t => { + return common.npm([ + 'install', + pkg + '/second/second-1.0.0.tgz' + ]).then(([code, stdout, stderr]) => { + t.notEqual(code, 0) + t.match(stderr, 'EEXIST') + return t.resolveMatch(readBin(beep), firstBin, 'bin still linked to first') + }) +}) + +t.test('installing second with --force succeeds', t => { + return common.npm([ + 'install', + pkg + '/second/second-1.0.0.tgz', + '--force' + ]).then(() => { + return t.resolveMatch(readBin(beep), secondBin, 'bin written to second.js') + }) +}) diff --git a/deps/npm/test/tap/fund.js b/deps/npm/test/tap/fund.js index 364dc1b6f81795..97b414bf6e0173 100644 --- a/deps/npm/test/tap/fund.js +++ b/deps/npm/test/tap/fund.js @@ -14,6 +14,7 @@ const base = common.pkg const noFunding = path.join(base, 'no-funding-package') const maintainerOwnsAllDeps = path.join(base, 'maintainer-owns-all-deps') const nestedNoFundingPackages = path.join(base, 'nested-no-funding-packages') +const fundingStringShorthand = path.join(base, 'funding-string-shorthand') function getFixturePackage ({ name, version, dependencies, funding }, extras) { const getDeps = () => Object @@ -36,6 +37,13 @@ function getFixturePackage ({ name, version, dependencies, funding }, extras) { } const fixture = new Tacks(Dir({ + 'funding-string-shorthand': Dir({ + 'package.json': File({ + name: 'funding-string-shorthand', + version: '0.0.0', + funding: 'https://example.com/sponsor' + }) + }), 'no-funding-package': Dir({ 'package.json': File({ name: 'no-funding-package', @@ -253,6 +261,13 @@ testFundCmd({ opts: { cwd: maintainerOwnsAllDeps } }) +testFundCmd({ + title: 'fund using string shorthand', + assertionMsg: 'should open string-only url', + args: ['.', '--no-browser'], + opts: { cwd: fundingStringShorthand } +}) + testFundCmd({ title: 'fund using package argument with no browser, using --json option', assertionMsg: 'should open funding url', diff --git a/deps/npm/test/tap/install-dep-classification.js b/deps/npm/test/tap/install-dep-classification.js index 2775c367b0002d..257fc99fc123ff 100644 --- a/deps/npm/test/tap/install-dep-classification.js +++ b/deps/npm/test/tap/install-dep-classification.js @@ -23,18 +23,39 @@ const env = common.newEnv().extend({ npm_config_loglevel: 'error' }) +/** + * NOTE: Tarball Fixtures + * They contain package.json files with dependencies like the following: + * a-1.0.0.tgz: package/package.json + * { + * "name":"a", + * "version":"1.0.0", + * "dependencies":{ + * "b":"./b-1.0.0.tgz" + * } + * } + * example-1.0.0.tgz: package/package.json + * { + * "name":"example", + * "version":"1.0.0", + * "dependencies":{ + * "a":"./a-1.0.0.tgz", + * "b":"./b-1.0.0.tgz" + * } + * } + */ const fixture = new Tacks(Dir({ cache: Dir(), global: Dir(), tmp: Dir(), testdir: Dir({ 'a-1.0.0.tgz': File(Buffer.from( - '1f8b0800000000000003edcfc10e82300c0660ce3ec5d2b38e4eb71d789b' + - '010d41e358187890f0ee56493c71319218937d977feb9aa50daebab886f2' + - 'b0a43cc7ce671b4344abb558ab3f2934223b198b4a598bdcc707a38f9c5b' + - '0fb2668c83eb79946fff597611effc131378772528c0c11e6ed4c7b6f37c' + - '53122572a5a640be265fb514a198a0e43729f3f2f06a9043738779defd7a' + - '89244992e4630fd69e456800080000', + '1f8b0800000000000003edcfc10a83300c06e09df71492f35653567bf06d' + + 'a2067163b558b7c3c4775f54f0e4654c18837e973f4da0249eca1bd59cfa' + + '25d535b4eeb03344b4c6245bfd8946995d328b5a5b3bd55264464beebdc8' + + '9647e8a99355befd67b92559f34f0ce0e8ce9003c1099edc85a675f2d20a' + + '154aa762cfae6257361c201fa090994a8bf33c577dfd82713cfefa86288a' + + 'a2e8736f68a0ff4400080000', 'hex' )), 'b-1.0.0.tgz': File(Buffer.from( @@ -55,12 +76,12 @@ const fixture = new Tacks(Dir({ }) }), 'example-1.0.0.tgz': File(Buffer.from( - '1f8b0800000000000003ed8fc10ac2300c8677f62946cedaa5d8f5e0db64' + - '5b1853d795758a38f6ee4607e261370722f4bbfce5cb4f493c9527aa39f3' + - '73aa63e85cb23288688d4997fc136d304df6b945adad45e9c923375a72ed' + - '4596b884817a59e5db7fe65bd277fe0923386a190ec0376afd99610b57ee' + - '43d339715aa14231157b7615bbb2e100871148664a65b47b15d450dfa554' + - 'ccb2f890d3b4f9f57d9148241259e60112d8208a00080000', + '1f8b0800000000000003ed8fc10a83300c863def2924e7ada6587bf06daa' + + '06719bb55837c6c4775fa6307670a70963d0ef92f02584fcce94275353e2' + + '962a8ebeb3d1c620a2562a5ef34f64aae328cd344aa935f21e379962875b' + + '3fb2c6c50fa6e757bebdb364895ff54f18c19a962007ba99d69d09f670a5' + + 'de379d6527050a645391235b912d1bf2908f607826127398e762a8efbc53' + + 'ccae7873d3b4fb75ba402010087ce2014747c9d500080000', 'hex' )), optional: Dir({ diff --git a/deps/npm/test/tap/install-local-from-local.js b/deps/npm/test/tap/install-local-from-local.js new file mode 100644 index 00000000000000..ec53c74a39206f --- /dev/null +++ b/deps/npm/test/tap/install-local-from-local.js @@ -0,0 +1,94 @@ +'use strict' +var path = require('path') +var fs = require('graceful-fs') +var test = require('tap').test +var common = require('../common-tap.js') +var Tacks = require('tacks') +var Dir = Tacks.Dir +var File = Tacks.File + +var testdir = path.join(__dirname, path.basename(__filename, '.js')) +var cwd = path.join(testdir, '3') + +/** + * NOTE: Tarball Fixtures + * They contain package.json files with dependencies like the following: + * 1-1.0.0.tgz: package/package.json + * { + * "name":"1", + * "version":"1.0.0" + * } + * 2-1.0.0.tgz: package/package.json + * { + * "name":"2", + * "version":"1.0.0", + * "dependencies":{ + * "1":"file:../1/1-1.0.0.tgz" + * } + * } + */ +var fixture = new Tacks(Dir({ + '1': Dir({ + '1-1.0.0.tgz': File(Buffer.from( + '1f8b08000000000000032b484cce4e4c4fd52f80d07a59c5f9790c540606' + + '06066626260ad8c4c1c0d85c81c1d8d4ccc0d0d0cccc00a80ec830353103' + + 'd2d4760836505a5c925804740aa5e640bca200a78708a856ca4bcc4d55b2' + + '523254d2512a4b2d2acecccf03f1f40cf40c946ab906da79a360148c8251' + + '300a6804007849dfdf00080000', + 'hex' + )) + }), + '2': Dir({ + '2-1.0.0.tgz': File(Buffer.from( + '1f8b0800000000000003ed8f3d0e83300c8599394594b90d36840cdc2602' + + '17d19f80087468c5ddeb14a9135b91aa4af996e73c3f47f660eb8b6d291b' + + '565567dfbb646700c0682db6fc00ea5c24456900d118e01c17a52e58f75e' + + '648bd94f76e455befd67bd457cf44f78a64248676f242b21737908cf3b8d' + + 'beeb5d70508182d56d6820d790ab3bf2dc0a83ec62489dba2b554a6598e1' + + 'f13da1a6f62139b0a44bfaeb0b23914824b2c50b8b5b623100080000', + 'hex' + )) + }), + '3': Dir({ + 'package.json': File({ + name: '3', + version: '1.0.0', + dependencies: { + '2': '../2/2-1.0.0.tgz' + } + }) + }) +})) + +function setup () { + fixture.create(testdir) +} + +function cleanup () { + fixture.remove(testdir) +} + +test('setup', function (t) { + cleanup() + setup() + t.end() +}) + +test('installing local package with local dependency', function (t) { + common.npm( + ['install'], + {cwd: cwd}, + function (er, code, stdout, stderr) { + t.is(code, 0, 'no error code') + t.is(stderr, '', 'no error output') + t.ok(fs.existsSync(path.join(cwd, 'node_modules', '2')), 'installed direct dep') + t.ok(fs.existsSync(path.join(cwd, 'node_modules', '1')), 'installed indirect dep') + t.end() + } + ) +}) + +test('cleanup', function (t) { + cleanup() + t.end() +}) diff --git a/deps/npm/test/tap/utils.funding.js b/deps/npm/test/tap/utils.funding.js index 51b89e5f8d340c..709762eacb7bb2 100644 --- a/deps/npm/test/tap/utils.funding.js +++ b/deps/npm/test/tap/utils.funding.js @@ -1,7 +1,7 @@ 'use strict' const { test } = require('tap') -const { getFundingInfo } = require('../../lib/utils/funding') +const { retrieveFunding, getFundingInfo } = require('../../lib/utils/funding') test('empty tree', (t) => { t.deepEqual( @@ -545,3 +545,70 @@ test('handle different versions', (t) => { ) t.end() }) + +test('retrieve funding info from valid objects', (t) => { + t.deepEqual( + retrieveFunding({ + url: 'http://example.com', + type: 'Foo' + }), + { + url: 'http://example.com', + type: 'Foo' + }, + 'should return standard object fields' + ) + t.deepEqual( + retrieveFunding({ + extra: 'Foo', + url: 'http://example.com', + type: 'Foo' + }), + { + extra: 'Foo', + url: 'http://example.com', + type: 'Foo' + }, + 'should leave untouched extra fields' + ) + t.deepEqual( + retrieveFunding({ + url: 'http://example.com' + }), + { + url: 'http://example.com' + }, + 'should accept url-only objects' + ) + t.end() +}) + +test('retrieve funding info from invalid objects', (t) => { + t.deepEqual( + retrieveFunding({}), + {}, + 'should passthrough empty objects' + ) + t.deepEqual( + retrieveFunding(), + undefined, + 'should not care about undefined' + ) + t.deepEqual( + retrieveFunding(), + null, + 'should not care about null' + ) + t.end() +}) + +test('retrieve funding info string shorthand', (t) => { + t.deepEqual( + retrieveFunding('http://example.com'), + { + url: 'http://example.com' + }, + 'should accept string shorthand' + ) + t.end() +})