├── .circleci └── config.yml ├── .eslintrc.json ├── .gitignore ├── LICENSE ├── README.md ├── mocha-multi.js ├── package-lock.json ├── package.json ├── test └── dummy-spec.js ├── verify └── verify.js /.circleci/config.yml: -------------------------------------------------------------------------------- 1 | version: 2.1 2 | workflows: 3 | workflow: 4 | jobs: 5 | - test 6 | jobs: 7 | test: 8 | docker: 9 | - image: cimg/node:lts 10 | steps: 11 | - checkout 12 | - run: npm ci 13 | - run: npm run ci 14 | -------------------------------------------------------------------------------- /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "plugins": ["node"], 3 | "extends": ["airbnb-base", "plugin:node/recommended"], 4 | "rules": { 5 | "global-require": 0, 6 | "import/no-dynamic-require": 0, 7 | "import/no-extraneous-dependencies": 0, 8 | "no-process-exit": 0, 9 | "no-underscore-dangle": 0, 10 | "no-unused-expressions": 0, 11 | "node/no-unpublished-require": 0, 12 | "operator-linebreak": [ "error", "after" ], 13 | "strict": 0 14 | }, 15 | "overrides": [ 16 | { 17 | "files": ["test/**"], 18 | "env": { 19 | "mocha": true 20 | } 21 | } 22 | ] 23 | } 24 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | lib-cov 2 | *.seed 3 | *.log 4 | *.csv 5 | *.dat 6 | *.out 7 | *.pid 8 | *.gz 9 | 10 | pids 11 | logs 12 | results 13 | 14 | npm-debug.log 15 | node_modules 16 | file.* 17 | .idea 18 | 19 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2013 Glen Mailer 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy of 6 | this software and associated documentation files (the "Software"), to deal in 7 | the Software without restriction, including without limitation the rights to 8 | use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of 9 | the Software, and to permit persons to whom the Software is furnished to do so, 10 | subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS 17 | FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR 18 | COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER 19 | IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 20 | CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 21 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | mocha-multi 2 | =========== 3 | 4 | A bit of a hack to get multiple reporters working with mocha 5 | 6 | [![Build Status](https://travis-ci.org/glenjamin/mocha-multi.svg?branch=master)](https://travis-ci.org/glenjamin/mocha-multi) 7 | [![NPM version](https://img.shields.io/npm/v/mocha-multi.svg)](https://www.npmjs.com/package/mocha-multi) 8 | 9 | Usage 10 | ----- 11 | 12 | npm install mocha-multi --save-dev 13 | mocha --reporter mocha-multi 14 | 15 | Choosing Reporters 16 | ------------------ 17 | 18 | For both methods below, the special value of `-` (hyphen) for destination uses normal stdout/stderr. 19 | 20 | ### With the `multi` Environment Variable 21 | 22 | Set the environment variable `multi` to whitespace-separated type=destination pairs. 23 | 24 | ```bash 25 | multi='dot=- xunit=file.xml doc=docs.html' mocha -R mocha-multi 26 | ``` 27 | 28 | ### With `--reporter-options` 29 | 30 | Pass `--reporter-options` with comma-separated type=destination pairs. 31 | 32 | ```bash 33 | mocha -R mocha-multi --reporter-options dot=-,xunit=file.xml,doc=docs.html 34 | ``` 35 | 36 | ### From a file 37 | 38 | Using either of the above methods, include a type=destination pair where the type is mocha-multi and the destination is a filename, e.g. `mocha-multi=mocha-multi-reporters.json` 39 | 40 | More reporters will be loaded from the named file, which must be valid JSON in the same data format described below for passing reporterOptions to Mocha programmatically. 41 | 42 | Using mocha-multi programmatically 43 | ---------------------------------- 44 | 45 | You may specify the desired reporters (and their options) by passing `reporterOptions` to the Mocha contructor. 46 | 47 | For example: the following config is the equivalent of setting `multi='spec=- Progress=/tmp/mocha-multi.Progress.out'`, with the addition of passing the `verbose: true` option to the Progress reporter. 48 | 49 | ```sh 50 | var reporterOptions = { 51 | Progress: { 52 | stdout: "/tmp/mocha-multi.Progress.out", 53 | options: { 54 | verbose: true 55 | } 56 | }, 57 | spec: "-" 58 | }; 59 | 60 | var mocha = new Mocha({ 61 | ui: "bdd" 62 | reporter: "mocha-multi", 63 | reporterOptions: reporterOptions 64 | }); 65 | mocha.addFile("test/dummy-spec.js"); 66 | mocha.run(function onRun(failures){ 67 | console.log(failures); 68 | }); 69 | ``` 70 | 71 | The options will be passed as the second argument to the reporter constructor. 72 | 73 | How it works 74 | ------------ 75 | 76 | A big hack that keeps changing the value of process.stdout and process.stderr whenever a reporter is doing its thing. 77 | 78 | Seriously? 79 | ---------- 80 | 81 | Yeah, Sorry! 82 | 83 | All the hacks 84 | ------------- 85 | 86 | This is very hacky, specifically: 87 | 88 | * The `process` and `console` objects get their internal state messed with 89 | * `process.exit` is hacked to wait for streams to finish writing 90 | * Only works if reporters queue writes synchronously in event handlers 91 | 92 | Could this be a bit less hacky? 93 | ------------------------------- 94 | 95 | * Now that https://github.com/mochajs/mocha/pull/1059 is released the process.exit hack could maybe be tidier 96 | 97 | * Having each reporter run in a child process would make it eaiser to capture their streams, but might lead to other issues 98 | 99 | TODO 100 | ---- 101 | 102 | * Add tests for coverage reports 103 | * Add tests which produce multiple reports at once 104 | * Add test for help text 105 | * Add test that uses --no-exit 106 | 107 | HISTORY 108 | ------- 109 | 110 | ### 1.0.0 (unreleased) 111 | 112 | The breaking changes are mostly around internals, and shouldn't affect most people. 113 | 114 | * BREAKING: MochaMulti.prototype.done removed, new MochaMulti(...).done now optional 115 | * BREAKING: new MochaMulti(...).options removed 116 | * BREAKING: Must run at least mocha@>=2.2.0 117 | * BREAKING: Must run at least node@>=6.0.0 118 | * Correctly set exit code when writing to files 119 | * Declare support for mocha@^4.0.0 120 | * Support running mocha without a run callback 121 | * Upgrade to ES2015+ via eslint-preset-airbnb-base (MochaMulti is an ES class) 122 | * Avoid patching stderr, now that mocha does not write to it 123 | -------------------------------------------------------------------------------- /mocha-multi.js: -------------------------------------------------------------------------------- 1 | const fs = require('fs'); 2 | const once = require('lodash.once'); 3 | const util = require('util'); 4 | const assign = require('object-assign'); 5 | const debug = require('debug')('mocha:multi'); 6 | const path = require('path'); 7 | const isString = require('is-string'); 8 | const mkdirp = require('mkdirp'); 9 | 10 | // Let mocha decide about tty early 11 | require('mocha/lib/reporters/base'); 12 | 13 | // Make sure we don't lose these! 14 | const { stdout } = process; 15 | 16 | function defineGetter(obj, prop, get, set) { 17 | Object.defineProperty(obj, prop, { get, set }); 18 | } 19 | const waitOn = fn => v => new Promise(resolve => fn(v, () => resolve())); 20 | const waitStream = waitOn((r, fn) => r.end(fn)); 21 | 22 | function awaitOnExit(waitFor) { 23 | if (!waitFor) { 24 | return; 25 | } 26 | const { exit } = process; 27 | process.exit = function mochaMultiExitPatch(...args) { 28 | const quit = exit.bind(this, ...args); 29 | if (process._exiting) { 30 | return quit(); 31 | } 32 | waitFor().then(quit); 33 | return undefined; 34 | }; 35 | } 36 | 37 | function identity(x) { 38 | return x; 39 | } 40 | 41 | const msgs = { 42 | no_definitions: 'reporter definitions should be set in ' + 43 | 'the `multi` shell variable\n' + 44 | "eg. `multi='dot=- xunit=file.xml' mocha`", 45 | invalid_definition: "'%s' is an invalid definition\n" + 46 | 'expected =', 47 | invalid_reporter: "Unable to find '%s' reporter", 48 | invalid_setup: "Invalid setup for reporter '%s' (%s)", 49 | invalid_outfile: "Invalid stdout filename for reporter '%s' (%s)", 50 | bad_file: "Missing or malformed options file '%s' -- Error: %s", 51 | }; 52 | function bombOut(id, ...args) { 53 | const newArgs = [`ERROR: ${msgs[id]}`, ...args]; 54 | process.stderr.write(`${util.format(...newArgs)}\n`); 55 | process.exit(1); 56 | } 57 | 58 | function parseReporter(definition) { 59 | const pair = definition.split('='); 60 | if (pair.length !== 2) { 61 | bombOut('invalid_definition', definition); 62 | } 63 | return pair; 64 | } 65 | 66 | function convertSetup(reporters) { 67 | let setup = []; 68 | Object.keys(reporters).forEach((reporter) => { 69 | if (reporter === 'mocha-multi') { 70 | debug('loading reporters from file %j', reporters[reporter]); 71 | try { 72 | setup = setup.concat(convertSetup(JSON.parse(fs.readFileSync(reporters[reporter])))); 73 | } catch (e) { 74 | bombOut('bad_file', reporters[reporter], e.message); 75 | } 76 | } else { 77 | const r = reporters[reporter]; 78 | debug('adding reporter %j %j', reporter, r); 79 | if (isString(r)) { 80 | setup.push([reporter, r, null]); 81 | } else if (typeof r !== 'object') { 82 | bombOut('invalid_setup', reporter, typeof r); 83 | } else { 84 | if (typeof r.stdout !== 'string') { bombOut('invalid_setup', reporter, typeof r); } 85 | setup.push([reporter, r.stdout, r.options]); 86 | } 87 | } 88 | }); 89 | return setup; 90 | } 91 | 92 | function parseSetup() { 93 | const reporterDefinition = process.env.multi || ''; 94 | const reporterDefs = reporterDefinition.trim().split(/\s/).filter(identity); 95 | if (!reporterDefs.length) { bombOut('no_definitions'); } 96 | debug('Got reporter defs: %j', reporterDefs); 97 | const reporters = {}; // const but not readonly 98 | reporterDefs.forEach((def) => { 99 | const [reporter, r] = parseReporter(def); 100 | reporters[reporter] = r; 101 | }); 102 | return convertSetup(reporters); 103 | } 104 | 105 | function resolveStream(destination) { 106 | if (destination === '-') { 107 | debug("Resolved stream '-' into stdout and stderr"); 108 | return null; 109 | } 110 | debug("Resolved stream '%s' into writeable file stream", destination); 111 | // Create directory if not existing 112 | const destinationDir = path.dirname(destination); 113 | if (!fs.existsSync(destinationDir)) { 114 | mkdirp.sync(destinationDir); 115 | } 116 | 117 | // Ensure we can write here 118 | fs.writeFileSync(destination, ''); 119 | return fs.createWriteStream(destination); 120 | } 121 | 122 | function safeRequire(module) { 123 | try { 124 | return require(module); 125 | } catch (err) { 126 | if (!/Cannot find/.exec(err.message)) { 127 | throw err; 128 | } 129 | return null; 130 | } 131 | } 132 | 133 | function resolveReporter(name) { 134 | // Cribbed from Mocha.prototype.reporter() 135 | const reporter = ( 136 | safeRequire(`mocha/lib/reporters/${name}`) || 137 | safeRequire(name) || 138 | safeRequire(path.resolve(process.cwd(), name)) || 139 | bombOut('invalid_reporter', name) 140 | ); 141 | debug("Resolved reporter '%s' into '%s'", name, util.inspect(reporter)); 142 | return reporter; 143 | } 144 | 145 | function withReplacedStdout(stream, func) { 146 | if (!stream) { 147 | return func(); 148 | } 149 | 150 | // The hackiest of hacks 151 | debug('Replacing stdout'); 152 | 153 | const stdoutGetter = Object.getOwnPropertyDescriptor(process, 'stdout').get; 154 | 155 | // eslint-disable-next-line no-console 156 | console._stdout = stream; 157 | defineGetter(process, 'stdout', () => stream); 158 | 159 | try { 160 | return func(); 161 | } finally { 162 | // eslint-disable-next-line no-console 163 | console._stdout = stdout; 164 | defineGetter(process, 'stdout', stdoutGetter); 165 | debug('stdout restored'); 166 | } 167 | } 168 | 169 | function createRunnerShim(runner, stream) { 170 | const shim = new (require('events').EventEmitter)(); 171 | 172 | function addDelegate(prop) { 173 | defineGetter(shim, prop, 174 | () => { 175 | const property = runner[prop]; 176 | if (typeof property === 'function') { 177 | return property.bind(runner); 178 | } 179 | return property; 180 | }, 181 | () => runner[prop]); 182 | } 183 | 184 | addDelegate('grepTotal'); 185 | addDelegate('suite'); 186 | addDelegate('total'); 187 | addDelegate('stats'); 188 | 189 | const delegatedEvents = {}; 190 | 191 | shim.on('newListener', (event) => { 192 | if (event in delegatedEvents) return; 193 | 194 | delegatedEvents[event] = true; 195 | debug("Shim: Delegating '%s'", event); 196 | 197 | runner.on(event, (...eventArgs) => { 198 | eventArgs.unshift(event); 199 | 200 | withReplacedStdout(stream, () => { 201 | shim.emit(...eventArgs); 202 | }); 203 | }); 204 | }); 205 | 206 | return shim; 207 | } 208 | 209 | function initReportersAndStreams(runner, setup, multiOptions) { 210 | return setup 211 | .map(([reporter, outstream, options]) => { 212 | debug("Initialising reporter '%s' to '%s' with options %j", reporter, outstream, options); 213 | 214 | const stream = resolveStream(outstream); 215 | const shim = createRunnerShim(runner, stream); 216 | 217 | debug("Shimming runner into reporter '%s' %j", reporter, options); 218 | 219 | return withReplacedStdout(stream, () => { 220 | const Reporter = resolveReporter(reporter); 221 | return { 222 | stream, 223 | reporter: new Reporter(shim, assign({}, multiOptions, { 224 | reporterOptions: options || {}, 225 | })), 226 | }; 227 | }); 228 | }); 229 | } 230 | 231 | function promiseProgress(items, fn) { 232 | let count = 0; 233 | fn(count); 234 | items.forEach(v => v.then(() => { 235 | count += 1; 236 | fn(count); 237 | })); 238 | return Promise.all(items); 239 | } 240 | 241 | 242 | /** 243 | * Override done to allow done processing for any reporters that have a done method. 244 | */ 245 | function done(failures, fn, reportersWithDone, waitFor = identity) { 246 | const count = reportersWithDone.length; 247 | const waitReporter = waitOn((r, f) => r.done(failures, f)); 248 | const progress = v => debug('Awaiting on %j reporters to invoke done callback.', count - v); 249 | promiseProgress(reportersWithDone.map(waitReporter), progress) 250 | .then(() => { 251 | debug('All reporters invoked done callback.'); 252 | }) 253 | .then(waitFor) 254 | .then(() => fn && fn(failures)); 255 | } 256 | 257 | function mochaMulti(runner, options) { 258 | // keep track of reporters that have a done method. 259 | const reporters = (options && options.reporterOptions); 260 | const setup = (() => { 261 | if (reporters && Object.keys(reporters).length > 0) { 262 | debug('options %j', options); 263 | return convertSetup(reporters); 264 | } 265 | return parseSetup(); 266 | })(); 267 | debug('setup %j', setup); 268 | // If the reporter possess a done() method register it so we can 269 | // wait for it to complete when done. 270 | const reportersAndStreams = initReportersAndStreams(runner, setup, options); 271 | const streams = reportersAndStreams 272 | .map(v => v.stream) 273 | .filter(identity); 274 | const reportersWithDone = reportersAndStreams 275 | .map(v => v.reporter) 276 | .filter(v => v.done); 277 | 278 | // we actually need to wait streams only if they are present 279 | const waitFor = streams.length > 0 ? 280 | once(() => Promise.all(streams.map(waitStream))) : 281 | undefined; 282 | 283 | awaitOnExit(waitFor); 284 | 285 | if (reportersWithDone.length > 0) { 286 | return { 287 | done: (failures, fn) => done(failures, fn, reportersWithDone, waitFor), 288 | }; 289 | } 290 | 291 | return {}; 292 | } 293 | 294 | class MochaMulti { 295 | constructor(runner, options) { 296 | Object.assign(this, mochaMulti(runner, options)); 297 | } 298 | } 299 | 300 | module.exports = MochaMulti; 301 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "mocha-multi", 3 | "version": "1.1.7", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.5.5", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.5.5.tgz", 10 | "integrity": "sha512-27d4lZoomVyo51VegxI20xZPuSHusqbQag/ztrBC7wegWoQ1nLREPVSKSW8byhTlzTKyNE4ifaTA6lCp7JjpFw==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.0.0" 14 | } 15 | }, 16 | "@babel/highlight": { 17 | "version": "7.5.0", 18 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.5.0.tgz", 19 | "integrity": "sha512-7dV4eu9gBxoM0dAnj/BCFDW9LFU0zvTrkq0ugM7pnHEgguOEeOz1so2ZghEdzviYzQEED0r4EAgpsBChKy1TRQ==", 20 | "dev": true, 21 | "requires": { 22 | "chalk": "^2.0.0", 23 | "esutils": "^2.0.2", 24 | "js-tokens": "^4.0.0" 25 | } 26 | }, 27 | "@ungap/promise-all-settled": { 28 | "version": "1.1.2", 29 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 30 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 31 | "dev": true 32 | }, 33 | "acorn": { 34 | "version": "6.3.0", 35 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.3.0.tgz", 36 | "integrity": "sha512-/czfa8BwS88b9gWQVhc8eknunSA2DoJpJyTQkhheIf5E48u1N0R4q/YxxsAeqRrmK9TQ/uYfgLDfZo91UlANIA==", 37 | "dev": true 38 | }, 39 | "acorn-jsx": { 40 | "version": "5.0.1", 41 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.1.tgz", 42 | "integrity": "sha512-HJ7CfNHrfJLlNTzIEUTj43LNWGkqpRLxm3YjAlcD0ACydk9XynzYsCBHxut+iqt+1aBXkx9UP/w/ZqMr13XIzg==", 43 | "dev": true 44 | }, 45 | "ajv": { 46 | "version": "6.10.2", 47 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.2.tgz", 48 | "integrity": "sha512-TXtUUEYHuaTEbLZWIKUr5pmBuhDLy+8KYtPYdcV8qC+pOZL+NKqYwvWSRrVXHn+ZmRRAu8vJTAznH7Oag6RVRw==", 49 | "dev": true, 50 | "requires": { 51 | "fast-deep-equal": "^2.0.1", 52 | "fast-json-stable-stringify": "^2.0.0", 53 | "json-schema-traverse": "^0.4.1", 54 | "uri-js": "^4.2.2" 55 | } 56 | }, 57 | "ansi-colors": { 58 | "version": "4.1.1", 59 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 60 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 61 | "dev": true 62 | }, 63 | "ansi-escapes": { 64 | "version": "4.2.1", 65 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.2.1.tgz", 66 | "integrity": "sha512-Cg3ymMAdN10wOk/VYfLV7KCQyv7EDirJ64500sU7n9UlmioEtDuU5Gd+hj73hXSU/ex7tHJSssmyftDdkMLO8Q==", 67 | "dev": true, 68 | "requires": { 69 | "type-fest": "^0.5.2" 70 | } 71 | }, 72 | "ansi-regex": { 73 | "version": "4.1.0", 74 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 75 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 76 | "dev": true 77 | }, 78 | "ansi-styles": { 79 | "version": "3.2.1", 80 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 81 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 82 | "dev": true, 83 | "requires": { 84 | "color-convert": "^1.9.0" 85 | } 86 | }, 87 | "anymatch": { 88 | "version": "3.1.2", 89 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 90 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 91 | "dev": true, 92 | "requires": { 93 | "normalize-path": "^3.0.0", 94 | "picomatch": "^2.0.4" 95 | } 96 | }, 97 | "argparse": { 98 | "version": "1.0.10", 99 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 100 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 101 | "dev": true, 102 | "requires": { 103 | "sprintf-js": "~1.0.2" 104 | } 105 | }, 106 | "array-includes": { 107 | "version": "3.0.3", 108 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.0.3.tgz", 109 | "integrity": "sha1-GEtI9i2S10UrsxsyMWXH+L0CJm0=", 110 | "dev": true, 111 | "requires": { 112 | "define-properties": "^1.1.2", 113 | "es-abstract": "^1.7.0" 114 | } 115 | }, 116 | "astral-regex": { 117 | "version": "1.0.0", 118 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 119 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 120 | "dev": true 121 | }, 122 | "async": { 123 | "version": "3.1.0", 124 | "resolved": "https://registry.npmjs.org/async/-/async-3.1.0.tgz", 125 | "integrity": "sha512-4vx/aaY6j/j3Lw3fbCHNWP0pPaTCew3F6F3hYyl/tHs/ndmV1q7NW9T5yuJ2XAGwdQrP+6Wu20x06U4APo/iQQ==", 126 | "dev": true 127 | }, 128 | "balanced-match": { 129 | "version": "1.0.0", 130 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 131 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 132 | "dev": true 133 | }, 134 | "binary-extensions": { 135 | "version": "2.2.0", 136 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 137 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 138 | "dev": true 139 | }, 140 | "brace-expansion": { 141 | "version": "1.1.11", 142 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 143 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 144 | "dev": true, 145 | "requires": { 146 | "balanced-match": "^1.0.0", 147 | "concat-map": "0.0.1" 148 | } 149 | }, 150 | "braces": { 151 | "version": "3.0.2", 152 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 153 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 154 | "dev": true, 155 | "requires": { 156 | "fill-range": "^7.0.1" 157 | } 158 | }, 159 | "browser-stdout": { 160 | "version": "1.3.1", 161 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 162 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 163 | "dev": true 164 | }, 165 | "callsites": { 166 | "version": "3.1.0", 167 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 168 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 169 | "dev": true 170 | }, 171 | "camelcase": { 172 | "version": "6.2.0", 173 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.2.0.tgz", 174 | "integrity": "sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg==", 175 | "dev": true 176 | }, 177 | "chalk": { 178 | "version": "2.4.2", 179 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 180 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 181 | "dev": true, 182 | "requires": { 183 | "ansi-styles": "^3.2.1", 184 | "escape-string-regexp": "^1.0.5", 185 | "supports-color": "^5.3.0" 186 | } 187 | }, 188 | "chardet": { 189 | "version": "0.7.0", 190 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 191 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 192 | "dev": true 193 | }, 194 | "chokidar": { 195 | "version": "3.5.2", 196 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz", 197 | "integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==", 198 | "dev": true, 199 | "requires": { 200 | "anymatch": "~3.1.2", 201 | "braces": "~3.0.2", 202 | "fsevents": "~2.3.2", 203 | "glob-parent": "~5.1.2", 204 | "is-binary-path": "~2.1.0", 205 | "is-glob": "~4.0.1", 206 | "normalize-path": "~3.0.0", 207 | "readdirp": "~3.6.0" 208 | } 209 | }, 210 | "cli-cursor": { 211 | "version": "3.1.0", 212 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 213 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 214 | "dev": true, 215 | "requires": { 216 | "restore-cursor": "^3.1.0" 217 | } 218 | }, 219 | "cli-width": { 220 | "version": "2.2.0", 221 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 222 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 223 | "dev": true 224 | }, 225 | "cliui": { 226 | "version": "7.0.4", 227 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 228 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 229 | "dev": true, 230 | "requires": { 231 | "string-width": "^4.2.0", 232 | "strip-ansi": "^6.0.0", 233 | "wrap-ansi": "^7.0.0" 234 | }, 235 | "dependencies": { 236 | "ansi-regex": { 237 | "version": "5.0.1", 238 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 239 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 240 | "dev": true 241 | }, 242 | "string-width": { 243 | "version": "4.2.3", 244 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 245 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 246 | "dev": true, 247 | "requires": { 248 | "emoji-regex": "^8.0.0", 249 | "is-fullwidth-code-point": "^3.0.0", 250 | "strip-ansi": "^6.0.1" 251 | } 252 | }, 253 | "strip-ansi": { 254 | "version": "6.0.1", 255 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 256 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 257 | "dev": true, 258 | "requires": { 259 | "ansi-regex": "^5.0.1" 260 | } 261 | } 262 | } 263 | }, 264 | "color-convert": { 265 | "version": "1.9.3", 266 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 267 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 268 | "dev": true, 269 | "requires": { 270 | "color-name": "1.1.3" 271 | } 272 | }, 273 | "color-name": { 274 | "version": "1.1.3", 275 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 276 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 277 | "dev": true 278 | }, 279 | "concat-map": { 280 | "version": "0.0.1", 281 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 282 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 283 | "dev": true 284 | }, 285 | "confusing-browser-globals": { 286 | "version": "1.0.8", 287 | "resolved": "https://registry.npmjs.org/confusing-browser-globals/-/confusing-browser-globals-1.0.8.tgz", 288 | "integrity": "sha512-lI7asCibVJ6Qd3FGU7mu4sfG4try4LX3+GVS+Gv8UlrEf2AeW57piecapnog2UHZSbcX/P/1UDWVaTsblowlZg==", 289 | "dev": true 290 | }, 291 | "contains-path": { 292 | "version": "0.1.0", 293 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 294 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 295 | "dev": true 296 | }, 297 | "cross-spawn": { 298 | "version": "6.0.5", 299 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 300 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 301 | "dev": true, 302 | "requires": { 303 | "nice-try": "^1.0.4", 304 | "path-key": "^2.0.1", 305 | "semver": "^5.5.0", 306 | "shebang-command": "^1.2.0", 307 | "which": "^1.2.9" 308 | } 309 | }, 310 | "debug": { 311 | "version": "4.1.1", 312 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 313 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 314 | "requires": { 315 | "ms": "^2.1.1" 316 | } 317 | }, 318 | "decamelize": { 319 | "version": "4.0.0", 320 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 321 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 322 | "dev": true 323 | }, 324 | "deep-is": { 325 | "version": "0.1.3", 326 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 327 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 328 | "dev": true 329 | }, 330 | "define-properties": { 331 | "version": "1.1.3", 332 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 333 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 334 | "dev": true, 335 | "requires": { 336 | "object-keys": "^1.0.12" 337 | } 338 | }, 339 | "diff": { 340 | "version": "5.0.0", 341 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 342 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 343 | "dev": true 344 | }, 345 | "doctrine": { 346 | "version": "3.0.0", 347 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 348 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 349 | "dev": true, 350 | "requires": { 351 | "esutils": "^2.0.2" 352 | } 353 | }, 354 | "emoji-regex": { 355 | "version": "8.0.0", 356 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 357 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 358 | "dev": true 359 | }, 360 | "error-ex": { 361 | "version": "1.3.2", 362 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 363 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 364 | "dev": true, 365 | "requires": { 366 | "is-arrayish": "^0.2.1" 367 | } 368 | }, 369 | "es-abstract": { 370 | "version": "1.13.0", 371 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz", 372 | "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==", 373 | "dev": true, 374 | "requires": { 375 | "es-to-primitive": "^1.2.0", 376 | "function-bind": "^1.1.1", 377 | "has": "^1.0.3", 378 | "is-callable": "^1.1.4", 379 | "is-regex": "^1.0.4", 380 | "object-keys": "^1.0.12" 381 | } 382 | }, 383 | "es-to-primitive": { 384 | "version": "1.2.0", 385 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 386 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 387 | "dev": true, 388 | "requires": { 389 | "is-callable": "^1.1.4", 390 | "is-date-object": "^1.0.1", 391 | "is-symbol": "^1.0.2" 392 | } 393 | }, 394 | "escalade": { 395 | "version": "3.1.1", 396 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 397 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 398 | "dev": true 399 | }, 400 | "escape-string-regexp": { 401 | "version": "1.0.5", 402 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 403 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 404 | "dev": true 405 | }, 406 | "eslint": { 407 | "version": "5.16.0", 408 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.16.0.tgz", 409 | "integrity": "sha512-S3Rz11i7c8AA5JPv7xAH+dOyq/Cu/VXHiHXBPOU1k/JAM5dXqQPt3qcrhpHSorXmrpu2g0gkIBVXAqCpzfoZIg==", 410 | "dev": true, 411 | "requires": { 412 | "@babel/code-frame": "^7.0.0", 413 | "ajv": "^6.9.1", 414 | "chalk": "^2.1.0", 415 | "cross-spawn": "^6.0.5", 416 | "debug": "^4.0.1", 417 | "doctrine": "^3.0.0", 418 | "eslint-scope": "^4.0.3", 419 | "eslint-utils": "^1.3.1", 420 | "eslint-visitor-keys": "^1.0.0", 421 | "espree": "^5.0.1", 422 | "esquery": "^1.0.1", 423 | "esutils": "^2.0.2", 424 | "file-entry-cache": "^5.0.1", 425 | "functional-red-black-tree": "^1.0.1", 426 | "glob": "^7.1.2", 427 | "globals": "^11.7.0", 428 | "ignore": "^4.0.6", 429 | "import-fresh": "^3.0.0", 430 | "imurmurhash": "^0.1.4", 431 | "inquirer": "^6.2.2", 432 | "js-yaml": "^3.13.0", 433 | "json-stable-stringify-without-jsonify": "^1.0.1", 434 | "levn": "^0.3.0", 435 | "lodash": "^4.17.11", 436 | "minimatch": "^3.0.4", 437 | "mkdirp": "^0.5.1", 438 | "natural-compare": "^1.4.0", 439 | "optionator": "^0.8.2", 440 | "path-is-inside": "^1.0.2", 441 | "progress": "^2.0.0", 442 | "regexpp": "^2.0.1", 443 | "semver": "^5.5.1", 444 | "strip-ansi": "^4.0.0", 445 | "strip-json-comments": "^2.0.1", 446 | "table": "^5.2.3", 447 | "text-table": "^0.2.0" 448 | }, 449 | "dependencies": { 450 | "mkdirp": { 451 | "version": "0.5.5", 452 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 453 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 454 | "dev": true, 455 | "requires": { 456 | "minimist": "^1.2.5" 457 | } 458 | } 459 | } 460 | }, 461 | "eslint-config-airbnb-base": { 462 | "version": "13.2.0", 463 | "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-13.2.0.tgz", 464 | "integrity": "sha512-1mg/7eoB4AUeB0X1c/ho4vb2gYkNH8Trr/EgCT/aGmKhhG+F6vF5s8+iRBlWAzFIAphxIdp3YfEKgEl0f9Xg+w==", 465 | "dev": true, 466 | "requires": { 467 | "confusing-browser-globals": "^1.0.5", 468 | "object.assign": "^4.1.0", 469 | "object.entries": "^1.1.0" 470 | } 471 | }, 472 | "eslint-import-resolver-node": { 473 | "version": "0.3.2", 474 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.2.tgz", 475 | "integrity": "sha512-sfmTqJfPSizWu4aymbPr4Iidp5yKm8yDkHp+Ir3YiTHiiDfxh69mOUsmiqW6RZ9zRXFaF64GtYmN7e+8GHBv6Q==", 476 | "dev": true, 477 | "requires": { 478 | "debug": "^2.6.9", 479 | "resolve": "^1.5.0" 480 | }, 481 | "dependencies": { 482 | "debug": { 483 | "version": "2.6.9", 484 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 485 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 486 | "dev": true, 487 | "requires": { 488 | "ms": "2.0.0" 489 | } 490 | }, 491 | "ms": { 492 | "version": "2.0.0", 493 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 494 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 495 | "dev": true 496 | } 497 | } 498 | }, 499 | "eslint-module-utils": { 500 | "version": "2.4.1", 501 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.4.1.tgz", 502 | "integrity": "sha512-H6DOj+ejw7Tesdgbfs4jeS4YMFrT8uI8xwd1gtQqXssaR0EQ26L+2O/w6wkYFy2MymON0fTwHmXBvvfLNZVZEw==", 503 | "dev": true, 504 | "requires": { 505 | "debug": "^2.6.8", 506 | "pkg-dir": "^2.0.0" 507 | }, 508 | "dependencies": { 509 | "debug": { 510 | "version": "2.6.9", 511 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 512 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 513 | "dev": true, 514 | "requires": { 515 | "ms": "2.0.0" 516 | } 517 | }, 518 | "ms": { 519 | "version": "2.0.0", 520 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 521 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 522 | "dev": true 523 | } 524 | } 525 | }, 526 | "eslint-plugin-es": { 527 | "version": "1.4.0", 528 | "resolved": "https://registry.npmjs.org/eslint-plugin-es/-/eslint-plugin-es-1.4.0.tgz", 529 | "integrity": "sha512-XfFmgFdIUDgvaRAlaXUkxrRg5JSADoRC8IkKLc/cISeR3yHVMefFHQZpcyXXEUUPHfy5DwviBcrfqlyqEwlQVw==", 530 | "dev": true, 531 | "requires": { 532 | "eslint-utils": "^1.3.0", 533 | "regexpp": "^2.0.1" 534 | } 535 | }, 536 | "eslint-plugin-import": { 537 | "version": "2.18.2", 538 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.18.2.tgz", 539 | "integrity": "sha512-5ohpsHAiUBRNaBWAF08izwUGlbrJoJJ+W9/TBwsGoR1MnlgfwMIKrFeSjWbt6moabiXW9xNvtFz+97KHRfI4HQ==", 540 | "dev": true, 541 | "requires": { 542 | "array-includes": "^3.0.3", 543 | "contains-path": "^0.1.0", 544 | "debug": "^2.6.9", 545 | "doctrine": "1.5.0", 546 | "eslint-import-resolver-node": "^0.3.2", 547 | "eslint-module-utils": "^2.4.0", 548 | "has": "^1.0.3", 549 | "minimatch": "^3.0.4", 550 | "object.values": "^1.1.0", 551 | "read-pkg-up": "^2.0.0", 552 | "resolve": "^1.11.0" 553 | }, 554 | "dependencies": { 555 | "debug": { 556 | "version": "2.6.9", 557 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 558 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 559 | "dev": true, 560 | "requires": { 561 | "ms": "2.0.0" 562 | } 563 | }, 564 | "doctrine": { 565 | "version": "1.5.0", 566 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 567 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 568 | "dev": true, 569 | "requires": { 570 | "esutils": "^2.0.2", 571 | "isarray": "^1.0.0" 572 | } 573 | }, 574 | "ms": { 575 | "version": "2.0.0", 576 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 577 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 578 | "dev": true 579 | } 580 | } 581 | }, 582 | "eslint-plugin-node": { 583 | "version": "9.1.0", 584 | "resolved": "https://registry.npmjs.org/eslint-plugin-node/-/eslint-plugin-node-9.1.0.tgz", 585 | "integrity": "sha512-ZwQYGm6EoV2cfLpE1wxJWsfnKUIXfM/KM09/TlorkukgCAwmkgajEJnPCmyzoFPQQkmvo5DrW/nyKutNIw36Mw==", 586 | "dev": true, 587 | "requires": { 588 | "eslint-plugin-es": "^1.4.0", 589 | "eslint-utils": "^1.3.1", 590 | "ignore": "^5.1.1", 591 | "minimatch": "^3.0.4", 592 | "resolve": "^1.10.1", 593 | "semver": "^6.1.0" 594 | }, 595 | "dependencies": { 596 | "ignore": { 597 | "version": "5.1.4", 598 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.1.4.tgz", 599 | "integrity": "sha512-MzbUSahkTW1u7JpKKjY7LCARd1fU5W2rLdxlM4kdkayuCwZImjkpluF9CM1aLewYJguPDqewLam18Y6AU69A8A==", 600 | "dev": true 601 | }, 602 | "semver": { 603 | "version": "6.3.0", 604 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 605 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 606 | "dev": true 607 | } 608 | } 609 | }, 610 | "eslint-scope": { 611 | "version": "4.0.3", 612 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.3.tgz", 613 | "integrity": "sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg==", 614 | "dev": true, 615 | "requires": { 616 | "esrecurse": "^4.1.0", 617 | "estraverse": "^4.1.1" 618 | } 619 | }, 620 | "eslint-utils": { 621 | "version": "1.4.0", 622 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.0.tgz", 623 | "integrity": "sha512-7ehnzPaP5IIEh1r1tkjuIrxqhNkzUJa9z3R92tLJdZIVdWaczEhr3EbhGtsMrVxi1KeR8qA7Off6SWc5WNQqyQ==", 624 | "dev": true, 625 | "requires": { 626 | "eslint-visitor-keys": "^1.0.0" 627 | } 628 | }, 629 | "eslint-visitor-keys": { 630 | "version": "1.1.0", 631 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz", 632 | "integrity": "sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A==", 633 | "dev": true 634 | }, 635 | "espree": { 636 | "version": "5.0.1", 637 | "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.1.tgz", 638 | "integrity": "sha512-qWAZcWh4XE/RwzLJejfcofscgMc9CamR6Tn1+XRXNzrvUSSbiAjGOI/fggztjIi7y9VLPqnICMIPiGyr8JaZ0A==", 639 | "dev": true, 640 | "requires": { 641 | "acorn": "^6.0.7", 642 | "acorn-jsx": "^5.0.0", 643 | "eslint-visitor-keys": "^1.0.0" 644 | } 645 | }, 646 | "esprima": { 647 | "version": "4.0.1", 648 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 649 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 650 | "dev": true 651 | }, 652 | "esquery": { 653 | "version": "1.0.1", 654 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 655 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 656 | "dev": true, 657 | "requires": { 658 | "estraverse": "^4.0.0" 659 | } 660 | }, 661 | "esrecurse": { 662 | "version": "4.2.1", 663 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 664 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 665 | "dev": true, 666 | "requires": { 667 | "estraverse": "^4.1.0" 668 | } 669 | }, 670 | "estraverse": { 671 | "version": "4.3.0", 672 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 673 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 674 | "dev": true 675 | }, 676 | "esutils": { 677 | "version": "2.0.3", 678 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 679 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 680 | "dev": true 681 | }, 682 | "external-editor": { 683 | "version": "3.1.0", 684 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 685 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 686 | "dev": true, 687 | "requires": { 688 | "chardet": "^0.7.0", 689 | "iconv-lite": "^0.4.24", 690 | "tmp": "^0.0.33" 691 | } 692 | }, 693 | "fast-deep-equal": { 694 | "version": "2.0.1", 695 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 696 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 697 | "dev": true 698 | }, 699 | "fast-json-stable-stringify": { 700 | "version": "2.0.0", 701 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 702 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 703 | "dev": true 704 | }, 705 | "fast-levenshtein": { 706 | "version": "2.0.6", 707 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 708 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 709 | "dev": true 710 | }, 711 | "figures": { 712 | "version": "3.0.0", 713 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.0.0.tgz", 714 | "integrity": "sha512-HKri+WoWoUgr83pehn/SIgLOMZ9nAWC6dcGj26RY2R4F50u4+RTUz0RCrUlOV3nKRAICW1UGzyb+kcX2qK1S/g==", 715 | "dev": true, 716 | "requires": { 717 | "escape-string-regexp": "^1.0.5" 718 | } 719 | }, 720 | "file-entry-cache": { 721 | "version": "5.0.1", 722 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 723 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 724 | "dev": true, 725 | "requires": { 726 | "flat-cache": "^2.0.1" 727 | } 728 | }, 729 | "fill-range": { 730 | "version": "7.0.1", 731 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 732 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 733 | "dev": true, 734 | "requires": { 735 | "to-regex-range": "^5.0.1" 736 | } 737 | }, 738 | "find-up": { 739 | "version": "2.1.0", 740 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 741 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 742 | "dev": true, 743 | "requires": { 744 | "locate-path": "^2.0.0" 745 | } 746 | }, 747 | "flat": { 748 | "version": "5.0.2", 749 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 750 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 751 | "dev": true 752 | }, 753 | "flat-cache": { 754 | "version": "2.0.1", 755 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 756 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 757 | "dev": true, 758 | "requires": { 759 | "flatted": "^2.0.0", 760 | "rimraf": "2.6.3", 761 | "write": "1.0.3" 762 | } 763 | }, 764 | "flatted": { 765 | "version": "2.0.1", 766 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.1.tgz", 767 | "integrity": "sha512-a1hQMktqW9Nmqr5aktAux3JMNqaucxGcjtjWnZLHX7yyPCmlSV3M54nGYbqT8K+0GhF3NBgmJCc3ma+WOgX8Jg==", 768 | "dev": true 769 | }, 770 | "fs.realpath": { 771 | "version": "1.0.0", 772 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 773 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 774 | "dev": true 775 | }, 776 | "fsevents": { 777 | "version": "2.3.2", 778 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 779 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 780 | "dev": true, 781 | "optional": true 782 | }, 783 | "function-bind": { 784 | "version": "1.1.1", 785 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 786 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 787 | "dev": true 788 | }, 789 | "functional-red-black-tree": { 790 | "version": "1.0.1", 791 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 792 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 793 | "dev": true 794 | }, 795 | "get-caller-file": { 796 | "version": "2.0.5", 797 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 798 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 799 | "dev": true 800 | }, 801 | "glob": { 802 | "version": "7.1.4", 803 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.4.tgz", 804 | "integrity": "sha512-hkLPepehmnKk41pUGm3sYxoFs/umurYfYJCerbXEyFIWcAzvpipAgVkBqqT9RBKMGjnq6kMuyYwha6csxbiM1A==", 805 | "dev": true, 806 | "requires": { 807 | "fs.realpath": "^1.0.0", 808 | "inflight": "^1.0.4", 809 | "inherits": "2", 810 | "minimatch": "^3.0.4", 811 | "once": "^1.3.0", 812 | "path-is-absolute": "^1.0.0" 813 | } 814 | }, 815 | "glob-parent": { 816 | "version": "5.1.2", 817 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 818 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 819 | "dev": true, 820 | "requires": { 821 | "is-glob": "^4.0.1" 822 | } 823 | }, 824 | "globals": { 825 | "version": "11.12.0", 826 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 827 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 828 | "dev": true 829 | }, 830 | "graceful-fs": { 831 | "version": "4.2.2", 832 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.2.tgz", 833 | "integrity": "sha512-IItsdsea19BoLC7ELy13q1iJFNmd7ofZH5+X/pJr90/nRoPEX0DJo1dHDbgtYWOhJhcCgMDTOw84RZ72q6lB+Q==", 834 | "dev": true 835 | }, 836 | "growl": { 837 | "version": "1.10.5", 838 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 839 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 840 | "dev": true 841 | }, 842 | "has": { 843 | "version": "1.0.3", 844 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 845 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 846 | "dev": true, 847 | "requires": { 848 | "function-bind": "^1.1.1" 849 | } 850 | }, 851 | "has-flag": { 852 | "version": "3.0.0", 853 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 854 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 855 | "dev": true 856 | }, 857 | "has-symbols": { 858 | "version": "1.0.0", 859 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 860 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", 861 | "dev": true 862 | }, 863 | "he": { 864 | "version": "1.2.0", 865 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 866 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 867 | "dev": true 868 | }, 869 | "hosted-git-info": { 870 | "version": "2.8.4", 871 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.4.tgz", 872 | "integrity": "sha512-pzXIvANXEFrc5oFFXRMkbLPQ2rXRoDERwDLyrcUxGhaZhgP54BBSl9Oheh7Vv0T090cszWBxPjkQQ5Sq1PbBRQ==", 873 | "dev": true 874 | }, 875 | "iconv-lite": { 876 | "version": "0.4.24", 877 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 878 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 879 | "dev": true, 880 | "requires": { 881 | "safer-buffer": ">= 2.1.2 < 3" 882 | } 883 | }, 884 | "ignore": { 885 | "version": "4.0.6", 886 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 887 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 888 | "dev": true 889 | }, 890 | "import-fresh": { 891 | "version": "3.1.0", 892 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.1.0.tgz", 893 | "integrity": "sha512-PpuksHKGt8rXfWEr9m9EHIpgyyaltBy8+eF6GJM0QCAxMgxCfucMF3mjecK2QsJr0amJW7gTqh5/wht0z2UhEQ==", 894 | "dev": true, 895 | "requires": { 896 | "parent-module": "^1.0.0", 897 | "resolve-from": "^4.0.0" 898 | } 899 | }, 900 | "imurmurhash": { 901 | "version": "0.1.4", 902 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 903 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 904 | "dev": true 905 | }, 906 | "inflight": { 907 | "version": "1.0.6", 908 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 909 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 910 | "dev": true, 911 | "requires": { 912 | "once": "^1.3.0", 913 | "wrappy": "1" 914 | } 915 | }, 916 | "inherits": { 917 | "version": "2.0.4", 918 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 919 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 920 | "dev": true 921 | }, 922 | "inquirer": { 923 | "version": "6.5.1", 924 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.5.1.tgz", 925 | "integrity": "sha512-uxNHBeQhRXIoHWTSNYUFhQVrHYFThIt6IVo2fFmSe8aBwdR3/w6b58hJpiL/fMukFkvGzjg+hSxFtwvVmKZmXw==", 926 | "dev": true, 927 | "requires": { 928 | "ansi-escapes": "^4.2.1", 929 | "chalk": "^2.4.2", 930 | "cli-cursor": "^3.1.0", 931 | "cli-width": "^2.0.0", 932 | "external-editor": "^3.0.3", 933 | "figures": "^3.0.0", 934 | "lodash": "^4.17.15", 935 | "mute-stream": "0.0.8", 936 | "run-async": "^2.2.0", 937 | "rxjs": "^6.4.0", 938 | "string-width": "^4.1.0", 939 | "strip-ansi": "^5.1.0", 940 | "through": "^2.3.6" 941 | }, 942 | "dependencies": { 943 | "strip-ansi": { 944 | "version": "5.2.0", 945 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 946 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 947 | "dev": true, 948 | "requires": { 949 | "ansi-regex": "^4.1.0" 950 | } 951 | } 952 | } 953 | }, 954 | "is-arrayish": { 955 | "version": "0.2.1", 956 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 957 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 958 | "dev": true 959 | }, 960 | "is-binary-path": { 961 | "version": "2.1.0", 962 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 963 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 964 | "dev": true, 965 | "requires": { 966 | "binary-extensions": "^2.0.0" 967 | } 968 | }, 969 | "is-callable": { 970 | "version": "1.1.4", 971 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 972 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", 973 | "dev": true 974 | }, 975 | "is-date-object": { 976 | "version": "1.0.1", 977 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 978 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 979 | "dev": true 980 | }, 981 | "is-extglob": { 982 | "version": "2.1.1", 983 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 984 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 985 | "dev": true 986 | }, 987 | "is-fullwidth-code-point": { 988 | "version": "3.0.0", 989 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 990 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 991 | "dev": true 992 | }, 993 | "is-glob": { 994 | "version": "4.0.3", 995 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 996 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 997 | "dev": true, 998 | "requires": { 999 | "is-extglob": "^2.1.1" 1000 | } 1001 | }, 1002 | "is-number": { 1003 | "version": "7.0.0", 1004 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1005 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1006 | "dev": true 1007 | }, 1008 | "is-plain-obj": { 1009 | "version": "2.1.0", 1010 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 1011 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 1012 | "dev": true 1013 | }, 1014 | "is-promise": { 1015 | "version": "2.1.0", 1016 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1017 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 1018 | "dev": true 1019 | }, 1020 | "is-regex": { 1021 | "version": "1.0.4", 1022 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 1023 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 1024 | "dev": true, 1025 | "requires": { 1026 | "has": "^1.0.1" 1027 | } 1028 | }, 1029 | "is-string": { 1030 | "version": "1.0.4", 1031 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.4.tgz", 1032 | "integrity": "sha1-zDqbaYV9Yh6WNyWiTK7shzuCbmQ=" 1033 | }, 1034 | "is-symbol": { 1035 | "version": "1.0.2", 1036 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 1037 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 1038 | "dev": true, 1039 | "requires": { 1040 | "has-symbols": "^1.0.0" 1041 | } 1042 | }, 1043 | "is-unicode-supported": { 1044 | "version": "0.1.0", 1045 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 1046 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 1047 | "dev": true 1048 | }, 1049 | "isarray": { 1050 | "version": "1.0.0", 1051 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1052 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1053 | "dev": true 1054 | }, 1055 | "isexe": { 1056 | "version": "2.0.0", 1057 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1058 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1059 | "dev": true 1060 | }, 1061 | "js-tokens": { 1062 | "version": "4.0.0", 1063 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1064 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1065 | "dev": true 1066 | }, 1067 | "js-yaml": { 1068 | "version": "3.13.1", 1069 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1070 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1071 | "dev": true, 1072 | "requires": { 1073 | "argparse": "^1.0.7", 1074 | "esprima": "^4.0.0" 1075 | } 1076 | }, 1077 | "json-parse-better-errors": { 1078 | "version": "1.0.2", 1079 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 1080 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", 1081 | "dev": true 1082 | }, 1083 | "json-schema-traverse": { 1084 | "version": "0.4.1", 1085 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1086 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1087 | "dev": true 1088 | }, 1089 | "json-stable-stringify-without-jsonify": { 1090 | "version": "1.0.1", 1091 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1092 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1093 | "dev": true 1094 | }, 1095 | "levn": { 1096 | "version": "0.3.0", 1097 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1098 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1099 | "dev": true, 1100 | "requires": { 1101 | "prelude-ls": "~1.1.2", 1102 | "type-check": "~0.3.2" 1103 | } 1104 | }, 1105 | "load-json-file": { 1106 | "version": "2.0.0", 1107 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 1108 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 1109 | "dev": true, 1110 | "requires": { 1111 | "graceful-fs": "^4.1.2", 1112 | "parse-json": "^2.2.0", 1113 | "pify": "^2.0.0", 1114 | "strip-bom": "^3.0.0" 1115 | } 1116 | }, 1117 | "locate-path": { 1118 | "version": "2.0.0", 1119 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 1120 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 1121 | "dev": true, 1122 | "requires": { 1123 | "p-locate": "^2.0.0", 1124 | "path-exists": "^3.0.0" 1125 | } 1126 | }, 1127 | "lodash": { 1128 | "version": "4.17.15", 1129 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", 1130 | "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==", 1131 | "dev": true 1132 | }, 1133 | "lodash.once": { 1134 | "version": "4.1.1", 1135 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 1136 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=" 1137 | }, 1138 | "log-symbols": { 1139 | "version": "4.1.0", 1140 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 1141 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 1142 | "dev": true, 1143 | "requires": { 1144 | "chalk": "^4.1.0", 1145 | "is-unicode-supported": "^0.1.0" 1146 | }, 1147 | "dependencies": { 1148 | "ansi-styles": { 1149 | "version": "4.3.0", 1150 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1151 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1152 | "dev": true, 1153 | "requires": { 1154 | "color-convert": "^2.0.1" 1155 | } 1156 | }, 1157 | "chalk": { 1158 | "version": "4.1.2", 1159 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 1160 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 1161 | "dev": true, 1162 | "requires": { 1163 | "ansi-styles": "^4.1.0", 1164 | "supports-color": "^7.1.0" 1165 | } 1166 | }, 1167 | "color-convert": { 1168 | "version": "2.0.1", 1169 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1170 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1171 | "dev": true, 1172 | "requires": { 1173 | "color-name": "~1.1.4" 1174 | } 1175 | }, 1176 | "color-name": { 1177 | "version": "1.1.4", 1178 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1179 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1180 | "dev": true 1181 | }, 1182 | "has-flag": { 1183 | "version": "4.0.0", 1184 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1185 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1186 | "dev": true 1187 | }, 1188 | "supports-color": { 1189 | "version": "7.2.0", 1190 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1191 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1192 | "dev": true, 1193 | "requires": { 1194 | "has-flag": "^4.0.0" 1195 | } 1196 | } 1197 | } 1198 | }, 1199 | "memorystream": { 1200 | "version": "0.3.1", 1201 | "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", 1202 | "integrity": "sha1-htcJCzDORV1j+64S3aUaR93K+bI=", 1203 | "dev": true 1204 | }, 1205 | "mimic-fn": { 1206 | "version": "2.1.0", 1207 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1208 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1209 | "dev": true 1210 | }, 1211 | "minimatch": { 1212 | "version": "3.0.4", 1213 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1214 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1215 | "dev": true, 1216 | "requires": { 1217 | "brace-expansion": "^1.1.7" 1218 | } 1219 | }, 1220 | "minimist": { 1221 | "version": "1.2.5", 1222 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1223 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1224 | "dev": true 1225 | }, 1226 | "mkdirp": { 1227 | "version": "1.0.4", 1228 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 1229 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==" 1230 | }, 1231 | "mocha": { 1232 | "version": "9.1.2", 1233 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-9.1.2.tgz", 1234 | "integrity": "sha512-ta3LtJ+63RIBP03VBjMGtSqbe6cWXRejF9SyM9Zyli1CKZJZ+vfCTj3oW24V7wAphMJdpOFLoMI3hjJ1LWbs0w==", 1235 | "dev": true, 1236 | "requires": { 1237 | "@ungap/promise-all-settled": "1.1.2", 1238 | "ansi-colors": "4.1.1", 1239 | "browser-stdout": "1.3.1", 1240 | "chokidar": "3.5.2", 1241 | "debug": "4.3.2", 1242 | "diff": "5.0.0", 1243 | "escape-string-regexp": "4.0.0", 1244 | "find-up": "5.0.0", 1245 | "glob": "7.1.7", 1246 | "growl": "1.10.5", 1247 | "he": "1.2.0", 1248 | "js-yaml": "4.1.0", 1249 | "log-symbols": "4.1.0", 1250 | "minimatch": "3.0.4", 1251 | "ms": "2.1.3", 1252 | "nanoid": "3.1.25", 1253 | "serialize-javascript": "6.0.0", 1254 | "strip-json-comments": "3.1.1", 1255 | "supports-color": "8.1.1", 1256 | "which": "2.0.2", 1257 | "workerpool": "6.1.5", 1258 | "yargs": "16.2.0", 1259 | "yargs-parser": "20.2.4", 1260 | "yargs-unparser": "2.0.0" 1261 | }, 1262 | "dependencies": { 1263 | "argparse": { 1264 | "version": "2.0.1", 1265 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 1266 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 1267 | "dev": true 1268 | }, 1269 | "debug": { 1270 | "version": "4.3.2", 1271 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 1272 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 1273 | "dev": true, 1274 | "requires": { 1275 | "ms": "2.1.2" 1276 | }, 1277 | "dependencies": { 1278 | "ms": { 1279 | "version": "2.1.2", 1280 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1281 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1282 | "dev": true 1283 | } 1284 | } 1285 | }, 1286 | "escape-string-regexp": { 1287 | "version": "4.0.0", 1288 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 1289 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 1290 | "dev": true 1291 | }, 1292 | "find-up": { 1293 | "version": "5.0.0", 1294 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1295 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1296 | "dev": true, 1297 | "requires": { 1298 | "locate-path": "^6.0.0", 1299 | "path-exists": "^4.0.0" 1300 | } 1301 | }, 1302 | "glob": { 1303 | "version": "7.1.7", 1304 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", 1305 | "integrity": "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==", 1306 | "dev": true, 1307 | "requires": { 1308 | "fs.realpath": "^1.0.0", 1309 | "inflight": "^1.0.4", 1310 | "inherits": "2", 1311 | "minimatch": "^3.0.4", 1312 | "once": "^1.3.0", 1313 | "path-is-absolute": "^1.0.0" 1314 | } 1315 | }, 1316 | "has-flag": { 1317 | "version": "4.0.0", 1318 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1319 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1320 | "dev": true 1321 | }, 1322 | "js-yaml": { 1323 | "version": "4.1.0", 1324 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1325 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1326 | "dev": true, 1327 | "requires": { 1328 | "argparse": "^2.0.1" 1329 | } 1330 | }, 1331 | "locate-path": { 1332 | "version": "6.0.0", 1333 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1334 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1335 | "dev": true, 1336 | "requires": { 1337 | "p-locate": "^5.0.0" 1338 | } 1339 | }, 1340 | "ms": { 1341 | "version": "2.1.3", 1342 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1343 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1344 | "dev": true 1345 | }, 1346 | "p-limit": { 1347 | "version": "3.1.0", 1348 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1349 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1350 | "dev": true, 1351 | "requires": { 1352 | "yocto-queue": "^0.1.0" 1353 | } 1354 | }, 1355 | "p-locate": { 1356 | "version": "5.0.0", 1357 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1358 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1359 | "dev": true, 1360 | "requires": { 1361 | "p-limit": "^3.0.2" 1362 | } 1363 | }, 1364 | "path-exists": { 1365 | "version": "4.0.0", 1366 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1367 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1368 | "dev": true 1369 | }, 1370 | "strip-json-comments": { 1371 | "version": "3.1.1", 1372 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1373 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1374 | "dev": true 1375 | }, 1376 | "supports-color": { 1377 | "version": "8.1.1", 1378 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 1379 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 1380 | "dev": true, 1381 | "requires": { 1382 | "has-flag": "^4.0.0" 1383 | } 1384 | }, 1385 | "which": { 1386 | "version": "2.0.2", 1387 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1388 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1389 | "dev": true, 1390 | "requires": { 1391 | "isexe": "^2.0.0" 1392 | } 1393 | } 1394 | } 1395 | }, 1396 | "ms": { 1397 | "version": "2.1.2", 1398 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1399 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1400 | }, 1401 | "mute-stream": { 1402 | "version": "0.0.8", 1403 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 1404 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", 1405 | "dev": true 1406 | }, 1407 | "nanoid": { 1408 | "version": "3.1.25", 1409 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.1.25.tgz", 1410 | "integrity": "sha512-rdwtIXaXCLFAQbnfqDRnI6jaRHp9fTcYBjtFKE8eezcZ7LuLjhUaQGNeMXf1HmRoCH32CLz6XwX0TtxEOS/A3Q==", 1411 | "dev": true 1412 | }, 1413 | "natural-compare": { 1414 | "version": "1.4.0", 1415 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1416 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1417 | "dev": true 1418 | }, 1419 | "nice-try": { 1420 | "version": "1.0.5", 1421 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1422 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1423 | "dev": true 1424 | }, 1425 | "normalize-package-data": { 1426 | "version": "2.5.0", 1427 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1428 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1429 | "dev": true, 1430 | "requires": { 1431 | "hosted-git-info": "^2.1.4", 1432 | "resolve": "^1.10.0", 1433 | "semver": "2 || 3 || 4 || 5", 1434 | "validate-npm-package-license": "^3.0.1" 1435 | } 1436 | }, 1437 | "normalize-path": { 1438 | "version": "3.0.0", 1439 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1440 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1441 | "dev": true 1442 | }, 1443 | "npm-run-all": { 1444 | "version": "4.1.5", 1445 | "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz", 1446 | "integrity": "sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==", 1447 | "dev": true, 1448 | "requires": { 1449 | "ansi-styles": "^3.2.1", 1450 | "chalk": "^2.4.1", 1451 | "cross-spawn": "^6.0.5", 1452 | "memorystream": "^0.3.1", 1453 | "minimatch": "^3.0.4", 1454 | "pidtree": "^0.3.0", 1455 | "read-pkg": "^3.0.0", 1456 | "shell-quote": "^1.6.1", 1457 | "string.prototype.padend": "^3.0.0" 1458 | }, 1459 | "dependencies": { 1460 | "load-json-file": { 1461 | "version": "4.0.0", 1462 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", 1463 | "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", 1464 | "dev": true, 1465 | "requires": { 1466 | "graceful-fs": "^4.1.2", 1467 | "parse-json": "^4.0.0", 1468 | "pify": "^3.0.0", 1469 | "strip-bom": "^3.0.0" 1470 | } 1471 | }, 1472 | "parse-json": { 1473 | "version": "4.0.0", 1474 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 1475 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", 1476 | "dev": true, 1477 | "requires": { 1478 | "error-ex": "^1.3.1", 1479 | "json-parse-better-errors": "^1.0.1" 1480 | } 1481 | }, 1482 | "path-type": { 1483 | "version": "3.0.0", 1484 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", 1485 | "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", 1486 | "dev": true, 1487 | "requires": { 1488 | "pify": "^3.0.0" 1489 | } 1490 | }, 1491 | "pify": { 1492 | "version": "3.0.0", 1493 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 1494 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 1495 | "dev": true 1496 | }, 1497 | "read-pkg": { 1498 | "version": "3.0.0", 1499 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", 1500 | "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", 1501 | "dev": true, 1502 | "requires": { 1503 | "load-json-file": "^4.0.0", 1504 | "normalize-package-data": "^2.3.2", 1505 | "path-type": "^3.0.0" 1506 | } 1507 | } 1508 | } 1509 | }, 1510 | "object-assign": { 1511 | "version": "4.1.1", 1512 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1513 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 1514 | }, 1515 | "object-keys": { 1516 | "version": "1.1.1", 1517 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1518 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1519 | "dev": true 1520 | }, 1521 | "object.assign": { 1522 | "version": "4.1.0", 1523 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1524 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1525 | "dev": true, 1526 | "requires": { 1527 | "define-properties": "^1.1.2", 1528 | "function-bind": "^1.1.1", 1529 | "has-symbols": "^1.0.0", 1530 | "object-keys": "^1.0.11" 1531 | } 1532 | }, 1533 | "object.entries": { 1534 | "version": "1.1.0", 1535 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.0.tgz", 1536 | "integrity": "sha512-l+H6EQ8qzGRxbkHOd5I/aHRhHDKoQXQ8g0BYt4uSweQU1/J6dZUOyWh9a2Vky35YCKjzmgxOzta2hH6kf9HuXA==", 1537 | "dev": true, 1538 | "requires": { 1539 | "define-properties": "^1.1.3", 1540 | "es-abstract": "^1.12.0", 1541 | "function-bind": "^1.1.1", 1542 | "has": "^1.0.3" 1543 | } 1544 | }, 1545 | "object.values": { 1546 | "version": "1.1.0", 1547 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.0.tgz", 1548 | "integrity": "sha512-8mf0nKLAoFX6VlNVdhGj31SVYpaNFtUnuoOXWyFEstsWRgU837AK+JYM0iAxwkSzGRbwn8cbFmgbyxj1j4VbXg==", 1549 | "dev": true, 1550 | "requires": { 1551 | "define-properties": "^1.1.3", 1552 | "es-abstract": "^1.12.0", 1553 | "function-bind": "^1.1.1", 1554 | "has": "^1.0.3" 1555 | } 1556 | }, 1557 | "once": { 1558 | "version": "1.4.0", 1559 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1560 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1561 | "dev": true, 1562 | "requires": { 1563 | "wrappy": "1" 1564 | } 1565 | }, 1566 | "onetime": { 1567 | "version": "5.1.0", 1568 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", 1569 | "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", 1570 | "dev": true, 1571 | "requires": { 1572 | "mimic-fn": "^2.1.0" 1573 | } 1574 | }, 1575 | "optionator": { 1576 | "version": "0.8.2", 1577 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 1578 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 1579 | "dev": true, 1580 | "requires": { 1581 | "deep-is": "~0.1.3", 1582 | "fast-levenshtein": "~2.0.4", 1583 | "levn": "~0.3.0", 1584 | "prelude-ls": "~1.1.2", 1585 | "type-check": "~0.3.2", 1586 | "wordwrap": "~1.0.0" 1587 | } 1588 | }, 1589 | "os-tmpdir": { 1590 | "version": "1.0.2", 1591 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1592 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1593 | "dev": true 1594 | }, 1595 | "p-limit": { 1596 | "version": "1.3.0", 1597 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 1598 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 1599 | "dev": true, 1600 | "requires": { 1601 | "p-try": "^1.0.0" 1602 | } 1603 | }, 1604 | "p-locate": { 1605 | "version": "2.0.0", 1606 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 1607 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 1608 | "dev": true, 1609 | "requires": { 1610 | "p-limit": "^1.1.0" 1611 | } 1612 | }, 1613 | "p-try": { 1614 | "version": "1.0.0", 1615 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 1616 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 1617 | "dev": true 1618 | }, 1619 | "parent-module": { 1620 | "version": "1.0.1", 1621 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1622 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1623 | "dev": true, 1624 | "requires": { 1625 | "callsites": "^3.0.0" 1626 | } 1627 | }, 1628 | "parse-json": { 1629 | "version": "2.2.0", 1630 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 1631 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 1632 | "dev": true, 1633 | "requires": { 1634 | "error-ex": "^1.2.0" 1635 | } 1636 | }, 1637 | "path-exists": { 1638 | "version": "3.0.0", 1639 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1640 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1641 | "dev": true 1642 | }, 1643 | "path-is-absolute": { 1644 | "version": "1.0.1", 1645 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1646 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1647 | "dev": true 1648 | }, 1649 | "path-is-inside": { 1650 | "version": "1.0.2", 1651 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 1652 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 1653 | "dev": true 1654 | }, 1655 | "path-key": { 1656 | "version": "2.0.1", 1657 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1658 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1659 | "dev": true 1660 | }, 1661 | "path-parse": { 1662 | "version": "1.0.6", 1663 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 1664 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 1665 | "dev": true 1666 | }, 1667 | "path-type": { 1668 | "version": "2.0.0", 1669 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 1670 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 1671 | "dev": true, 1672 | "requires": { 1673 | "pify": "^2.0.0" 1674 | } 1675 | }, 1676 | "picomatch": { 1677 | "version": "2.3.0", 1678 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 1679 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 1680 | "dev": true 1681 | }, 1682 | "pidtree": { 1683 | "version": "0.3.0", 1684 | "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.3.0.tgz", 1685 | "integrity": "sha512-9CT4NFlDcosssyg8KVFltgokyKZIFjoBxw8CTGy+5F38Y1eQWrt8tRayiUOXE+zVKQnYu5BR8JjCtvK3BcnBhg==", 1686 | "dev": true 1687 | }, 1688 | "pify": { 1689 | "version": "2.3.0", 1690 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1691 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1692 | "dev": true 1693 | }, 1694 | "pkg-dir": { 1695 | "version": "2.0.0", 1696 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", 1697 | "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", 1698 | "dev": true, 1699 | "requires": { 1700 | "find-up": "^2.1.0" 1701 | } 1702 | }, 1703 | "prelude-ls": { 1704 | "version": "1.1.2", 1705 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 1706 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 1707 | "dev": true 1708 | }, 1709 | "progress": { 1710 | "version": "2.0.3", 1711 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1712 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1713 | "dev": true 1714 | }, 1715 | "punycode": { 1716 | "version": "2.1.1", 1717 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1718 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1719 | "dev": true 1720 | }, 1721 | "q": { 1722 | "version": "1.5.1", 1723 | "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", 1724 | "integrity": "sha1-fjL3W0E4EpHQRhHxvxQQmsAGUdc=", 1725 | "dev": true 1726 | }, 1727 | "randombytes": { 1728 | "version": "2.1.0", 1729 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1730 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1731 | "dev": true, 1732 | "requires": { 1733 | "safe-buffer": "^5.1.0" 1734 | } 1735 | }, 1736 | "read-pkg": { 1737 | "version": "2.0.0", 1738 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 1739 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 1740 | "dev": true, 1741 | "requires": { 1742 | "load-json-file": "^2.0.0", 1743 | "normalize-package-data": "^2.3.2", 1744 | "path-type": "^2.0.0" 1745 | } 1746 | }, 1747 | "read-pkg-up": { 1748 | "version": "2.0.0", 1749 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 1750 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 1751 | "dev": true, 1752 | "requires": { 1753 | "find-up": "^2.0.0", 1754 | "read-pkg": "^2.0.0" 1755 | } 1756 | }, 1757 | "readdirp": { 1758 | "version": "3.6.0", 1759 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1760 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1761 | "dev": true, 1762 | "requires": { 1763 | "picomatch": "^2.2.1" 1764 | } 1765 | }, 1766 | "regexpp": { 1767 | "version": "2.0.1", 1768 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 1769 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 1770 | "dev": true 1771 | }, 1772 | "require-directory": { 1773 | "version": "2.1.1", 1774 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1775 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1776 | "dev": true 1777 | }, 1778 | "resolve": { 1779 | "version": "1.12.0", 1780 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.12.0.tgz", 1781 | "integrity": "sha512-B/dOmuoAik5bKcD6s6nXDCjzUKnaDvdkRyAk6rsmsKLipWj4797iothd7jmmUhWTfinVMU+wc56rYKsit2Qy4w==", 1782 | "dev": true, 1783 | "requires": { 1784 | "path-parse": "^1.0.6" 1785 | } 1786 | }, 1787 | "resolve-from": { 1788 | "version": "4.0.0", 1789 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1790 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1791 | "dev": true 1792 | }, 1793 | "restore-cursor": { 1794 | "version": "3.1.0", 1795 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 1796 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 1797 | "dev": true, 1798 | "requires": { 1799 | "onetime": "^5.1.0", 1800 | "signal-exit": "^3.0.2" 1801 | } 1802 | }, 1803 | "rimraf": { 1804 | "version": "2.6.3", 1805 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1806 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1807 | "dev": true, 1808 | "requires": { 1809 | "glob": "^7.1.3" 1810 | } 1811 | }, 1812 | "run-async": { 1813 | "version": "2.3.0", 1814 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 1815 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 1816 | "dev": true, 1817 | "requires": { 1818 | "is-promise": "^2.1.0" 1819 | } 1820 | }, 1821 | "rxjs": { 1822 | "version": "6.5.2", 1823 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.2.tgz", 1824 | "integrity": "sha512-HUb7j3kvb7p7eCUHE3FqjoDsC1xfZQ4AHFWfTKSpZ+sAhhz5X1WX0ZuUqWbzB2QhSLp3DoLUG+hMdEDKqWo2Zg==", 1825 | "dev": true, 1826 | "requires": { 1827 | "tslib": "^1.9.0" 1828 | } 1829 | }, 1830 | "safe-buffer": { 1831 | "version": "5.2.1", 1832 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1833 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1834 | "dev": true 1835 | }, 1836 | "safer-buffer": { 1837 | "version": "2.1.2", 1838 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1839 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1840 | "dev": true 1841 | }, 1842 | "semver": { 1843 | "version": "5.7.1", 1844 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1845 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1846 | "dev": true 1847 | }, 1848 | "serialize-javascript": { 1849 | "version": "6.0.0", 1850 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 1851 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 1852 | "dev": true, 1853 | "requires": { 1854 | "randombytes": "^2.1.0" 1855 | } 1856 | }, 1857 | "shebang-command": { 1858 | "version": "1.2.0", 1859 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1860 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1861 | "dev": true, 1862 | "requires": { 1863 | "shebang-regex": "^1.0.0" 1864 | } 1865 | }, 1866 | "shebang-regex": { 1867 | "version": "1.0.0", 1868 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1869 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1870 | "dev": true 1871 | }, 1872 | "shell-quote": { 1873 | "version": "1.7.1", 1874 | "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.7.1.tgz", 1875 | "integrity": "sha512-2kUqeAGnMAu6YrTPX4E3LfxacH9gKljzVjlkUeSqY0soGwK4KLl7TURXCem712tkhBCeeaFP9QK4dKn88s3Icg==", 1876 | "dev": true 1877 | }, 1878 | "should": { 1879 | "version": "13.2.3", 1880 | "resolved": "https://registry.npmjs.org/should/-/should-13.2.3.tgz", 1881 | "integrity": "sha512-ggLesLtu2xp+ZxI+ysJTmNjh2U0TsC+rQ/pfED9bUZZ4DKefP27D+7YJVVTvKsmjLpIi9jAa7itwDGkDDmt1GQ==", 1882 | "dev": true, 1883 | "requires": { 1884 | "should-equal": "^2.0.0", 1885 | "should-format": "^3.0.3", 1886 | "should-type": "^1.4.0", 1887 | "should-type-adaptors": "^1.0.1", 1888 | "should-util": "^1.0.0" 1889 | } 1890 | }, 1891 | "should-equal": { 1892 | "version": "2.0.0", 1893 | "resolved": "https://registry.npmjs.org/should-equal/-/should-equal-2.0.0.tgz", 1894 | "integrity": "sha512-ZP36TMrK9euEuWQYBig9W55WPC7uo37qzAEmbjHz4gfyuXrEUgF8cUvQVO+w+d3OMfPvSRQJ22lSm8MQJ43LTA==", 1895 | "dev": true, 1896 | "requires": { 1897 | "should-type": "^1.4.0" 1898 | } 1899 | }, 1900 | "should-format": { 1901 | "version": "3.0.3", 1902 | "resolved": "https://registry.npmjs.org/should-format/-/should-format-3.0.3.tgz", 1903 | "integrity": "sha1-m/yPdPo5IFxT04w01xcwPidxJPE=", 1904 | "dev": true, 1905 | "requires": { 1906 | "should-type": "^1.3.0", 1907 | "should-type-adaptors": "^1.0.1" 1908 | } 1909 | }, 1910 | "should-type": { 1911 | "version": "1.4.0", 1912 | "resolved": "https://registry.npmjs.org/should-type/-/should-type-1.4.0.tgz", 1913 | "integrity": "sha1-B1bYzoRt/QmEOmlHcZ36DUz/XPM=", 1914 | "dev": true 1915 | }, 1916 | "should-type-adaptors": { 1917 | "version": "1.1.0", 1918 | "resolved": "https://registry.npmjs.org/should-type-adaptors/-/should-type-adaptors-1.1.0.tgz", 1919 | "integrity": "sha512-JA4hdoLnN+kebEp2Vs8eBe9g7uy0zbRo+RMcU0EsNy+R+k049Ki+N5tT5Jagst2g7EAja+euFuoXFCa8vIklfA==", 1920 | "dev": true, 1921 | "requires": { 1922 | "should-type": "^1.3.0", 1923 | "should-util": "^1.0.0" 1924 | } 1925 | }, 1926 | "should-util": { 1927 | "version": "1.0.1", 1928 | "resolved": "https://registry.npmjs.org/should-util/-/should-util-1.0.1.tgz", 1929 | "integrity": "sha512-oXF8tfxx5cDk8r2kYqlkUJzZpDBqVY/II2WhvU0n9Y3XYvAYRmeaf1PvvIvTgPnv4KJ+ES5M0PyDq5Jp+Ygy2g==", 1930 | "dev": true 1931 | }, 1932 | "signal-exit": { 1933 | "version": "3.0.2", 1934 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1935 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 1936 | "dev": true 1937 | }, 1938 | "slice-ansi": { 1939 | "version": "2.1.0", 1940 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 1941 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 1942 | "dev": true, 1943 | "requires": { 1944 | "ansi-styles": "^3.2.0", 1945 | "astral-regex": "^1.0.0", 1946 | "is-fullwidth-code-point": "^2.0.0" 1947 | }, 1948 | "dependencies": { 1949 | "is-fullwidth-code-point": { 1950 | "version": "2.0.0", 1951 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1952 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1953 | "dev": true 1954 | } 1955 | } 1956 | }, 1957 | "spdx-correct": { 1958 | "version": "3.1.0", 1959 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", 1960 | "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", 1961 | "dev": true, 1962 | "requires": { 1963 | "spdx-expression-parse": "^3.0.0", 1964 | "spdx-license-ids": "^3.0.0" 1965 | } 1966 | }, 1967 | "spdx-exceptions": { 1968 | "version": "2.2.0", 1969 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", 1970 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==", 1971 | "dev": true 1972 | }, 1973 | "spdx-expression-parse": { 1974 | "version": "3.0.0", 1975 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", 1976 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", 1977 | "dev": true, 1978 | "requires": { 1979 | "spdx-exceptions": "^2.1.0", 1980 | "spdx-license-ids": "^3.0.0" 1981 | } 1982 | }, 1983 | "spdx-license-ids": { 1984 | "version": "3.0.5", 1985 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz", 1986 | "integrity": "sha512-J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q==", 1987 | "dev": true 1988 | }, 1989 | "sprintf-js": { 1990 | "version": "1.0.3", 1991 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1992 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1993 | "dev": true 1994 | }, 1995 | "string-width": { 1996 | "version": "4.1.0", 1997 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.1.0.tgz", 1998 | "integrity": "sha512-NrX+1dVVh+6Y9dnQ19pR0pP4FiEIlUvdTGn8pw6CKTNq5sgib2nIhmUNT5TAmhWmvKr3WcxBcP3E8nWezuipuQ==", 1999 | "dev": true, 2000 | "requires": { 2001 | "emoji-regex": "^8.0.0", 2002 | "is-fullwidth-code-point": "^3.0.0", 2003 | "strip-ansi": "^5.2.0" 2004 | }, 2005 | "dependencies": { 2006 | "strip-ansi": { 2007 | "version": "5.2.0", 2008 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2009 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2010 | "dev": true, 2011 | "requires": { 2012 | "ansi-regex": "^4.1.0" 2013 | } 2014 | } 2015 | } 2016 | }, 2017 | "string.prototype.padend": { 2018 | "version": "3.0.0", 2019 | "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.0.0.tgz", 2020 | "integrity": "sha1-86rvfBcZ8XDF6rHDK/eA2W4h8vA=", 2021 | "dev": true, 2022 | "requires": { 2023 | "define-properties": "^1.1.2", 2024 | "es-abstract": "^1.4.3", 2025 | "function-bind": "^1.0.2" 2026 | } 2027 | }, 2028 | "strip-ansi": { 2029 | "version": "4.0.0", 2030 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2031 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2032 | "dev": true, 2033 | "requires": { 2034 | "ansi-regex": "^3.0.0" 2035 | }, 2036 | "dependencies": { 2037 | "ansi-regex": { 2038 | "version": "3.0.0", 2039 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 2040 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 2041 | "dev": true 2042 | } 2043 | } 2044 | }, 2045 | "strip-bom": { 2046 | "version": "3.0.0", 2047 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2048 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 2049 | "dev": true 2050 | }, 2051 | "strip-json-comments": { 2052 | "version": "2.0.1", 2053 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2054 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 2055 | "dev": true 2056 | }, 2057 | "supports-color": { 2058 | "version": "5.5.0", 2059 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2060 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2061 | "dev": true, 2062 | "requires": { 2063 | "has-flag": "^3.0.0" 2064 | } 2065 | }, 2066 | "table": { 2067 | "version": "5.4.6", 2068 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 2069 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 2070 | "dev": true, 2071 | "requires": { 2072 | "ajv": "^6.10.2", 2073 | "lodash": "^4.17.14", 2074 | "slice-ansi": "^2.1.0", 2075 | "string-width": "^3.0.0" 2076 | }, 2077 | "dependencies": { 2078 | "emoji-regex": { 2079 | "version": "7.0.3", 2080 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 2081 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 2082 | "dev": true 2083 | }, 2084 | "is-fullwidth-code-point": { 2085 | "version": "2.0.0", 2086 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2087 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2088 | "dev": true 2089 | }, 2090 | "string-width": { 2091 | "version": "3.1.0", 2092 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2093 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2094 | "dev": true, 2095 | "requires": { 2096 | "emoji-regex": "^7.0.1", 2097 | "is-fullwidth-code-point": "^2.0.0", 2098 | "strip-ansi": "^5.1.0" 2099 | } 2100 | }, 2101 | "strip-ansi": { 2102 | "version": "5.2.0", 2103 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2104 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2105 | "dev": true, 2106 | "requires": { 2107 | "ansi-regex": "^4.1.0" 2108 | } 2109 | } 2110 | } 2111 | }, 2112 | "text-table": { 2113 | "version": "0.2.0", 2114 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2115 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2116 | "dev": true 2117 | }, 2118 | "through": { 2119 | "version": "2.3.8", 2120 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2121 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2122 | "dev": true 2123 | }, 2124 | "tmp": { 2125 | "version": "0.0.33", 2126 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 2127 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 2128 | "dev": true, 2129 | "requires": { 2130 | "os-tmpdir": "~1.0.2" 2131 | } 2132 | }, 2133 | "to-regex-range": { 2134 | "version": "5.0.1", 2135 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2136 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2137 | "dev": true, 2138 | "requires": { 2139 | "is-number": "^7.0.0" 2140 | } 2141 | }, 2142 | "tslib": { 2143 | "version": "1.10.0", 2144 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", 2145 | "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==", 2146 | "dev": true 2147 | }, 2148 | "type-check": { 2149 | "version": "0.3.2", 2150 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 2151 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 2152 | "dev": true, 2153 | "requires": { 2154 | "prelude-ls": "~1.1.2" 2155 | } 2156 | }, 2157 | "type-fest": { 2158 | "version": "0.5.2", 2159 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.5.2.tgz", 2160 | "integrity": "sha512-DWkS49EQKVX//Tbupb9TFa19c7+MK1XmzkrZUR8TAktmE/DizXoaoJV6TZ/tSIPXipqNiRI6CyAe7x69Jb6RSw==", 2161 | "dev": true 2162 | }, 2163 | "uri-js": { 2164 | "version": "4.2.2", 2165 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 2166 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 2167 | "dev": true, 2168 | "requires": { 2169 | "punycode": "^2.1.0" 2170 | } 2171 | }, 2172 | "validate-npm-package-license": { 2173 | "version": "3.0.4", 2174 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 2175 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 2176 | "dev": true, 2177 | "requires": { 2178 | "spdx-correct": "^3.0.0", 2179 | "spdx-expression-parse": "^3.0.0" 2180 | } 2181 | }, 2182 | "which": { 2183 | "version": "1.3.1", 2184 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2185 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2186 | "dev": true, 2187 | "requires": { 2188 | "isexe": "^2.0.0" 2189 | } 2190 | }, 2191 | "wordwrap": { 2192 | "version": "1.0.0", 2193 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 2194 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 2195 | "dev": true 2196 | }, 2197 | "workerpool": { 2198 | "version": "6.1.5", 2199 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.1.5.tgz", 2200 | "integrity": "sha512-XdKkCK0Zqc6w3iTxLckiuJ81tiD/o5rBE/m+nXpRCB+/Sq4DqkfXZ/x0jW02DG1tGsfUGXbTJyZDP+eu67haSw==", 2201 | "dev": true 2202 | }, 2203 | "wrap-ansi": { 2204 | "version": "7.0.0", 2205 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2206 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2207 | "dev": true, 2208 | "requires": { 2209 | "ansi-styles": "^4.0.0", 2210 | "string-width": "^4.1.0", 2211 | "strip-ansi": "^6.0.0" 2212 | }, 2213 | "dependencies": { 2214 | "ansi-regex": { 2215 | "version": "5.0.1", 2216 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2217 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2218 | "dev": true 2219 | }, 2220 | "ansi-styles": { 2221 | "version": "4.3.0", 2222 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2223 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2224 | "dev": true, 2225 | "requires": { 2226 | "color-convert": "^2.0.1" 2227 | } 2228 | }, 2229 | "color-convert": { 2230 | "version": "2.0.1", 2231 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2232 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2233 | "dev": true, 2234 | "requires": { 2235 | "color-name": "~1.1.4" 2236 | } 2237 | }, 2238 | "color-name": { 2239 | "version": "1.1.4", 2240 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2241 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2242 | "dev": true 2243 | }, 2244 | "strip-ansi": { 2245 | "version": "6.0.1", 2246 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2247 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2248 | "dev": true, 2249 | "requires": { 2250 | "ansi-regex": "^5.0.1" 2251 | } 2252 | } 2253 | } 2254 | }, 2255 | "wrappy": { 2256 | "version": "1.0.2", 2257 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2258 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2259 | "dev": true 2260 | }, 2261 | "write": { 2262 | "version": "1.0.3", 2263 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 2264 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 2265 | "dev": true, 2266 | "requires": { 2267 | "mkdirp": "^0.5.1" 2268 | }, 2269 | "dependencies": { 2270 | "mkdirp": { 2271 | "version": "0.5.5", 2272 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 2273 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 2274 | "dev": true, 2275 | "requires": { 2276 | "minimist": "^1.2.5" 2277 | } 2278 | } 2279 | } 2280 | }, 2281 | "y18n": { 2282 | "version": "5.0.8", 2283 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 2284 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 2285 | "dev": true 2286 | }, 2287 | "yargs": { 2288 | "version": "16.2.0", 2289 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 2290 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 2291 | "dev": true, 2292 | "requires": { 2293 | "cliui": "^7.0.2", 2294 | "escalade": "^3.1.1", 2295 | "get-caller-file": "^2.0.5", 2296 | "require-directory": "^2.1.1", 2297 | "string-width": "^4.2.0", 2298 | "y18n": "^5.0.5", 2299 | "yargs-parser": "^20.2.2" 2300 | }, 2301 | "dependencies": { 2302 | "ansi-regex": { 2303 | "version": "5.0.1", 2304 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2305 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2306 | "dev": true 2307 | }, 2308 | "string-width": { 2309 | "version": "4.2.3", 2310 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2311 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2312 | "dev": true, 2313 | "requires": { 2314 | "emoji-regex": "^8.0.0", 2315 | "is-fullwidth-code-point": "^3.0.0", 2316 | "strip-ansi": "^6.0.1" 2317 | } 2318 | }, 2319 | "strip-ansi": { 2320 | "version": "6.0.1", 2321 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2322 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2323 | "dev": true, 2324 | "requires": { 2325 | "ansi-regex": "^5.0.1" 2326 | } 2327 | } 2328 | } 2329 | }, 2330 | "yargs-parser": { 2331 | "version": "20.2.4", 2332 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 2333 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 2334 | "dev": true 2335 | }, 2336 | "yargs-unparser": { 2337 | "version": "2.0.0", 2338 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 2339 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 2340 | "dev": true, 2341 | "requires": { 2342 | "camelcase": "^6.0.0", 2343 | "decamelize": "^4.0.0", 2344 | "flat": "^5.0.2", 2345 | "is-plain-obj": "^2.1.0" 2346 | } 2347 | }, 2348 | "yocto-queue": { 2349 | "version": "0.1.0", 2350 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 2351 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 2352 | "dev": true 2353 | } 2354 | } 2355 | } 2356 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "mocha-multi", 3 | "version": "1.1.7", 4 | "description": "A bit of a hack to get multiple reporters working with mocha", 5 | "main": "mocha-multi.js", 6 | "scripts": { 7 | "test": "run-s lint verify:*", 8 | "ci": "run-s -c lint verify:*", 9 | "verify:node": "node ./verify.js", 10 | "verify:sh": "./verify all", 11 | "lint": "eslint . --max-warnings 0" 12 | }, 13 | "repository": { 14 | "type": "git", 15 | "url": "git://github.com/glenjamin/mocha-multi.git" 16 | }, 17 | "keywords": [ 18 | "mocha" 19 | ], 20 | "author": "Glen Mailer ", 21 | "license": "MIT", 22 | "bugs": { 23 | "url": "https://github.com/glenjamin/mocha-multi/issues" 24 | }, 25 | "homepage": "https://github.com/glenjamin/mocha-multi", 26 | "devDependencies": { 27 | "async": "^3.0.1", 28 | "chalk": "^2.4.2", 29 | "eslint": "^5.16.0", 30 | "eslint-config-airbnb-base": "^13.1.0", 31 | "eslint-plugin-import": "^2.17.3", 32 | "eslint-plugin-node": "^9.1.0", 33 | "mocha": "^9.0.0", 34 | "npm-run-all": "^4.1.5", 35 | "q": "^1.5.1", 36 | "should": "^13.2.3" 37 | }, 38 | "dependencies": { 39 | "debug": "^4.1.1", 40 | "is-string": "^1.0.4", 41 | "lodash.once": "^4.1.1", 42 | "mkdirp": "^1.0.4", 43 | "object-assign": "^4.1.1" 44 | }, 45 | "peerDependencies": { 46 | "mocha": ">=2.2.0 <7 || >=9" 47 | }, 48 | "engines": { 49 | "node": ">=6.0.0" 50 | } 51 | } 52 | -------------------------------------------------------------------------------- /test/dummy-spec.js: -------------------------------------------------------------------------------- 1 | describe('A test', () => { 2 | it("isn't really a test", () => { 3 | 1 + 1; 4 | }); 5 | it('is only here to create output', () => { 6 | 2 + 2; 7 | }); 8 | it('runs through and generates data', () => { 9 | throw new Error('to check that reporting is sorta working'); 10 | }); 11 | it('handles pending stuff as well'); 12 | }); 13 | -------------------------------------------------------------------------------- /verify: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | 3 | mocha_multi="mocha-multi.js" 4 | normal="\033[0m" 5 | 6 | function log { 7 | local color 8 | if [ "$2" = "info" ]; then 9 | color="" # normal 10 | elif [ "$2" = "fail" ]; then 11 | color="\033[01;31m" # red 12 | elif [ "$2" = "pass" ]; then 13 | color="\033[01;32m" # green 14 | else 15 | color="\033[01;30m" # grey 16 | fi 17 | echo -e "${color}VERIFY: $1${normal}" 1>&2 18 | } 19 | 20 | function normalise_timers { 21 | local file=$1 22 | cmd="sed -i'.bak' -e 's/[0-9]\{1,\}\(\.[0-9]\{1,\}\)\{0,1\}/0/g' '$file'" 23 | eval $cmd 24 | rm "$file.bak" 25 | } 26 | 27 | # pipe through cat to ensure istty = false, but capture exit code 28 | function eval_notty { 29 | log "Running formatter $1: $2" 30 | eval $2 | cat 31 | return ${PIPESTATUS[0]} 32 | } 33 | 34 | function compare { 35 | local reporter=$1 36 | 37 | log "Running comparison for $reporter" info 38 | 39 | local builtin_out=$(mktemp /tmp/mocha-multi.XXXXXXXXX) 40 | local multi_env_out=$(mktemp /tmp/mocha-multi.XXXXXXXXX) 41 | local multi_arg_out=$(mktemp /tmp/mocha-multi.XXXXXXXXX) 42 | local multi_file_in=$(mktemp /tmp/mocha-multi.XXXXXXXXX) 43 | local multi_file_out=$(mktemp /tmp/mocha-multi.XXXXXXXXX) 44 | 45 | local builtin_cmd="mocha -R $reporter &> $builtin_out" 46 | eval_notty "normally" "$builtin_cmd" 47 | local builtin_result=$? 48 | normalise_timers $builtin_out 49 | 50 | local multi_env_cmd="multi='$reporter=$multi_env_out' mocha -R $mocha_multi" 51 | eval_notty "via mocha-multi using environment variable" "$multi_env_cmd" 52 | local multi_env_result=$? 53 | normalise_timers $multi_env_out 54 | 55 | local multi_arg_cmd="mocha -R $mocha_multi --reporter-options '$reporter=$multi_arg_out'" 56 | eval_notty "via mocha-multi using --reporter-options" "$multi_arg_cmd" 57 | local multi_arg_result=$? 58 | normalise_timers $multi_arg_out 59 | 60 | echo "{\"$reporter\": \"$multi_file_out\"}" > "$multi_file_in" 61 | local multi_file_cmd="mocha -R $mocha_multi --reporter-options 'mocha-multi=$multi_file_in'" 62 | eval_notty "via mocha-multi using file" "$multi_file_cmd" 63 | local multi_file_result=$? 64 | normalise_timers $multi_file_out 65 | 66 | log "Comparing exit codes" 67 | 68 | if [ "$builtin_result" = "$multi_arg_result" -a "$builtin_result" = "$multi_env_result" -a "$builtin_result" = "$multi_file_result" ]; then 69 | log 'Codes match, hooray!' pass 70 | else 71 | log "Codes do not match" fail 72 | log "Result ${normal}$builtin_result" 73 | log "Result (env) ${normal}$multi_env_result" 74 | log "Result (arg) ${normal}$multi_arg_result" 75 | log "Result (file) ${normal}$multi_file_result" 76 | return 1 77 | fi 78 | 79 | log "Comparing output" 80 | 81 | local diff_cmd_env="diff -U1 -Lbuiltin -Lmulti $builtin_out $multi_env_out" 82 | log "Running $diff_cmd_env" 83 | local difference_env=$($diff_cmd_env) 84 | 85 | local diff_cmd_arg="diff -U1 -Lbuiltin -Lmulti $builtin_out $multi_arg_out" 86 | log "Running $diff_cmd_arg" 87 | local difference_arg=$($diff_cmd_arg) 88 | 89 | local diff_cmd_file="diff -U1 -Lbuiltin -Lmulti $builtin_out $multi_file_out" 90 | log "Running $diff_cmd_file" 91 | local difference_file=$($diff_cmd_file) 92 | 93 | rm "$builtin_out" "$multi_env_out" "$multi_arg_out" "$multi_file_out" "$multi_file_in" 94 | 95 | if [ "$difference_env" = "" -a "$difference_arg" = "" -a "$difference_file" = "" ]; then 96 | log 'Output matches, hooray!' pass 97 | return 0 98 | else 99 | log "Output does not match" fail 100 | log "Difference (env)\n${normal}$difference_env" 101 | log "Difference (arg)\n${normal}$difference_arg" 102 | log "Difference (file)\n${normal}$difference_file" 103 | return 1 104 | fi 105 | } 106 | 107 | badfilecheck="ERROR: Missing or malformed options file 'missing.json' -- Error: ENOENT: no such file or directory, open 'missing.json'" 108 | badfile=`mocha --reporter "$mocha_multi" --reporter-options mocha-multi=missing.json --recursive test 2>&1` 109 | log "$badfile" 110 | if [ "$badfile" != "$badfilecheck" ]; then 111 | log "Wrong error message trying to load missing options file" fail 112 | exit 1 113 | else 114 | log "Correct error message trying to load missing options file" pass 115 | fi 116 | 117 | if [ "$1" = "" ]; then 118 | log "No reporter chosen" 119 | exit 1 120 | fi 121 | 122 | if [ "$1" = "all" ]; then 123 | reporters=(\ 124 | dot doc spec json progress \ 125 | list tap landing xunit min \ 126 | json-stream markdown nyan\ 127 | ) 128 | result=0 129 | for reporter in ${reporters[@]}; do 130 | compare $reporter 131 | result=$(($result + $?)) 132 | done 133 | exit $result 134 | else 135 | compare $1 136 | fi 137 | -------------------------------------------------------------------------------- /verify.js: -------------------------------------------------------------------------------- 1 | const Mocha = require('mocha'); 2 | const should = require('should'); 3 | const fs = require('fs'); 4 | const debug = require('debug')('mocha:verify:multi'); 5 | const async = require('async'); 6 | const chalk = require('chalk'); 7 | 8 | const reporters = [ 9 | 'dot', 'doc', 'spec', 'json', 'progress', 10 | 'list', 'tap', 'landing', 'xunit', 'min', 11 | 'json-stream', 'markdown', 'nyan', 12 | ]; 13 | const now = new Date(); 14 | 15 | function tempName(reporter) { 16 | return `/tmp/mocha-multi.${reporter}.${+now}`; 17 | } 18 | 19 | const reportersWithOptions = [] 20 | .concat(reporters.map((reporter) => { 21 | const outFilename = tempName(`${reporter}-stdout`); 22 | const options = {}; 23 | options[reporter] = { 24 | stdout: outFilename, 25 | }; 26 | return { 27 | testName: `${reporter} (with options.stdout)`, 28 | outFilename, 29 | options, 30 | }; 31 | })) 32 | .concat(reporters.map((reporter) => { 33 | const outFilename = tempName(`${reporter}-str`); 34 | const options = {}; 35 | options[reporter] = outFilename; 36 | return { 37 | testName: `${reporter} (with options as string)`, 38 | outFilename, 39 | options, 40 | }; 41 | })); 42 | 43 | 44 | should(process.env.multi).not.be.ok; 45 | 46 | process.setMaxListeners(reportersWithOptions.length); 47 | 48 | async.eachSeries(reportersWithOptions, (reporter, next) => { 49 | debug('reporter %s', reporter.testName); 50 | debug('reporterOptions %j', reporter.options); 51 | const mocha = new Mocha({ 52 | ui: 'bdd', 53 | reporter: 'mocha-multi', 54 | reporterOptions: reporter.options, 55 | }); 56 | mocha.addFile('test/dummy-spec.js'); 57 | mocha.run(() => { 58 | debug('done running %j', reporter.testName); 59 | process.nextTick(next); 60 | }); 61 | }, () => { 62 | reportersWithOptions.forEach((reporter) => { 63 | fs.statSync.bind(fs, reporter.outFilename).should.not.throw(); 64 | fs.unlinkSync(reporter.outFilename); 65 | // eslint-disable-next-line no-console 66 | console.log(chalk.green('%s OK'), reporter.testName); 67 | }); 68 | }); 69 | --------------------------------------------------------------------------------