├── .eslintignore ├── .eslintrc.json ├── .gitignore ├── Exercises.ru.md ├── Exercises ├── 1-pipe.js ├── 1-pipe.test ├── 2-compose.js └── 2-compose.test ├── JavaScript ├── 1-superposition.js ├── 2-composition.js ├── 3-arguments.js ├── 4-multiple.js ├── 5-loop.js ├── 6-recursive.js ├── 7-compose-async.js └── 8-compose-proto.js ├── LICENSE ├── README.md ├── knowledge.map ├── package-lock.json └── package.json /.eslintignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | -------------------------------------------------------------------------------- /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "env": { 3 | "browser": true, 4 | "es6": true, 5 | "node": true 6 | }, 7 | "extends": "eslint:recommended", 8 | "parserOptions": { 9 | "ecmaVersion": 2018 10 | }, 11 | "rules": { 12 | "indent": [ 13 | "error", 14 | 2 15 | ], 16 | "linebreak-style": [ 17 | "error", 18 | "unix" 19 | ], 20 | "quotes": [ 21 | "error", 22 | "single" 23 | ], 24 | "semi": [ 25 | "error", 26 | "always" 27 | ], 28 | "no-console": "off", 29 | "no-loop-func": [ 30 | "error" 31 | ], 32 | "block-spacing": [ 33 | "error", 34 | "always" 35 | ], 36 | "camelcase": [ 37 | "error" 38 | ], 39 | "eqeqeq": [ 40 | "error", 41 | "always" 42 | ], 43 | "strict": [ 44 | "error", 45 | "global" 46 | ], 47 | "brace-style": [ 48 | "error", 49 | "1tbs", 50 | { 51 | "allowSingleLine": true 52 | } 53 | ], 54 | "comma-style": [ 55 | "error", 56 | "last" 57 | ], 58 | "comma-spacing": [ 59 | "error", 60 | { 61 | "before": false, 62 | "after": true 63 | } 64 | ], 65 | "eol-last": [ 66 | "error" 67 | ], 68 | "func-call-spacing": [ 69 | "error", 70 | "never" 71 | ], 72 | "key-spacing": [ 73 | "error", 74 | { 75 | "beforeColon": false, 76 | "afterColon": true, 77 | "mode": "minimum" 78 | } 79 | ], 80 | "keyword-spacing": [ 81 | "error", 82 | { 83 | "before": true, 84 | "after": true, 85 | "overrides": { 86 | "function": { 87 | "after": false 88 | } 89 | } 90 | } 91 | ], 92 | "max-len": [ 93 | "error", 94 | { 95 | "code": 80, 96 | "ignoreUrls": true 97 | } 98 | ], 99 | "max-nested-callbacks": [ 100 | "error", 101 | { 102 | "max": 7 103 | } 104 | ], 105 | "new-cap": [ 106 | "error", 107 | { 108 | "newIsCap": true, 109 | "capIsNew": false, 110 | "properties": true 111 | } 112 | ], 113 | "new-parens": [ 114 | "error" 115 | ], 116 | "no-trailing-spaces": [ 117 | "error" 118 | ], 119 | "no-unneeded-ternary": [ 120 | "error" 121 | ], 122 | "no-whitespace-before-property": [ 123 | "error" 124 | ], 125 | "object-curly-spacing": [ 126 | "error", 127 | "always" 128 | ], 129 | "operator-assignment": [ 130 | "error", 131 | "always" 132 | ], 133 | "operator-linebreak": [ 134 | "error", 135 | "after" 136 | ], 137 | "semi-spacing": [ 138 | "error", 139 | { 140 | "before": false, 141 | "after": true 142 | } 143 | ], 144 | "space-before-blocks": [ 145 | "error", 146 | "always" 147 | ], 148 | "space-before-function-paren": [ 149 | "error", 150 | { 151 | "anonymous": "always", 152 | "named": "never", 153 | "asyncArrow": "always" 154 | } 155 | ], 156 | "space-in-parens": [ 157 | "error", 158 | "never" 159 | ], 160 | "space-infix-ops": [ 161 | "error" 162 | ], 163 | "space-unary-ops": [ 164 | "error", 165 | { 166 | "words": true, 167 | "nonwords": false, 168 | "overrides": { 169 | "typeof": false 170 | } 171 | } 172 | ], 173 | "no-unreachable": [ 174 | "error" 175 | ], 176 | "no-global-assign": [ 177 | "error" 178 | ], 179 | "no-self-compare": [ 180 | "error" 181 | ], 182 | "no-unmodified-loop-condition": [ 183 | "error" 184 | ], 185 | "no-constant-condition": [ 186 | "error", 187 | { 188 | "checkLoops": false 189 | } 190 | ], 191 | "no-console": [ 192 | "off" 193 | ], 194 | "no-useless-concat": [ 195 | "error" 196 | ], 197 | "no-useless-escape": [ 198 | "error" 199 | ], 200 | "no-shadow-restricted-names": [ 201 | "error" 202 | ], 203 | "no-use-before-define": [ 204 | "error", 205 | { 206 | "functions": false 207 | } 208 | ], 209 | "arrow-parens": [ 210 | "error", 211 | "as-needed" 212 | ], 213 | "arrow-body-style": [ 214 | "error", 215 | "as-needed" 216 | ], 217 | "arrow-spacing": [ 218 | "error" 219 | ], 220 | "no-confusing-arrow": [ 221 | "error", 222 | { 223 | "allowParens": true 224 | } 225 | ], 226 | "no-useless-computed-key": [ 227 | "error" 228 | ], 229 | "no-useless-rename": [ 230 | "error" 231 | ], 232 | "no-var": [ 233 | "error" 234 | ], 235 | "object-shorthand": [ 236 | "error", 237 | "always" 238 | ], 239 | "prefer-arrow-callback": [ 240 | "error" 241 | ], 242 | "prefer-const": [ 243 | "error" 244 | ], 245 | "prefer-numeric-literals": [ 246 | "error" 247 | ], 248 | "prefer-rest-params": [ 249 | "error" 250 | ], 251 | "prefer-spread": [ 252 | "error" 253 | ], 254 | "rest-spread-spacing": [ 255 | "error", 256 | "never" 257 | ], 258 | "template-curly-spacing": [ 259 | "error", 260 | "never" 261 | ] 262 | }, 263 | "overrides": [ 264 | { 265 | "files": ["1-let.js"], 266 | "rules": { 267 | "prefer-const": "off" 268 | } 269 | } 270 | ] 271 | } -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | *.log 3 | .DS_Store 4 | -------------------------------------------------------------------------------- /Exercises.ru.md: -------------------------------------------------------------------------------- 1 | # Композиция 2 | 3 | 1. Напишите функцию `pipe`, композирующую передаваемые в нее аргументы слева 4 | направо. `const pipe = (...fns) => x => ...` А если хоть один из аргументов 5 | окажется не функционального типа, то `pipe` должен выбросить ошибку. 6 | Например, если у нас есть три функции: 7 | ```js 8 | const inc = x => ++x; 9 | const twice = x => x * 2; 10 | const cube = x => x ** 3; 11 | ``` 12 | И нам нужно скомпозировать их так `const f = pipe(inc, twice, cube);` 13 | то при вызове `const x = f(5);` нужно ожидать, что `x` примет значение `1728`. 14 | А если мы скомпозируем `const f = pipe(inc, inc);` то при вызове 15 | `const x = f(7);` значение `x` будет `9`. Но если мы передадим не функцию в 16 | `pipe`, например: `const f = pipe(inc, 7, cube);` то, не дожидаясь вызова `f`, 17 | сразу получим ошибку. 18 | 19 | 2. Реализуйте композицию функций справа налево (без использования рекурсии), 20 | которая будет подавлять ошибки, если композируемые функции будут их бросать, 21 | то, исполнение функции завершается с `undefined`, а на ошибки можно будет 22 | подписаться через `f.on('error', e => { ... });`. 23 | -------------------------------------------------------------------------------- /Exercises/1-pipe.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const pipe = (...fns) => { 4 | if (!fns.every(fn => typeof fn === 'function')) 5 | throw new Error('Not all arguments are functions'); 6 | return x => fns.reduce((value, fn) => fn(value), x); 7 | }; 8 | 9 | module.exports = { pipe }; 10 | -------------------------------------------------------------------------------- /Exercises/1-pipe.test: -------------------------------------------------------------------------------- 1 | ({ 2 | name: 'pipe', 3 | length: [150, 300], 4 | test: pipe => { 5 | const inc = x => ++x; 6 | const twice = x => x * 2; 7 | const cube = x => x ** 3; 8 | { 9 | const f = pipe(inc, twice, cube); 10 | const x = f(5); 11 | if (x !== 1728) throw new Error(`Expected 1728 instead of ${x}`); 12 | } 13 | { 14 | const f = pipe(inc, inc); 15 | const x = f(7); 16 | if (x !== 9) throw new Error(`Expected 9 instead of ${x}`); 17 | } 18 | { 19 | let catched = false; 20 | try { 21 | pipe(7, 3); 22 | } catch (err) { 23 | catched = true; 24 | } 25 | if (!catched) throw new Error(`Function pipe should throw`); 26 | } 27 | } 28 | }) 29 | -------------------------------------------------------------------------------- /Exercises/2-compose.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const compose = (...fns) => { 4 | fns.reverse(); 5 | const f = x => { 6 | try { 7 | return fns.reduce((acc, val) => val(acc), x); 8 | } catch (e) { 9 | f.emit('error', e); 10 | } 11 | }; 12 | f.subs = {}; 13 | f.on = (e, fn, s = f.subs[e]) => (s ? s.push(fn) : f.subs[e] = [fn]); 14 | f.emit = (even, data, s = f.subs[even]) => s.forEach(g => g(data)); 15 | return f; 16 | }; 17 | 18 | module.exports = { compose }; 19 | -------------------------------------------------------------------------------- /Exercises/2-compose.test: -------------------------------------------------------------------------------- 1 | ({ 2 | name: 'compose', 3 | length: [300, 600], 4 | test: compose => { 5 | const inc = x => ++x; 6 | const twice = x => x * 2; 7 | const cube = x => x ** 3; 8 | const fail = x => { 9 | throw new Error(`Function fail(${x})`); 10 | }; 11 | { 12 | const f = compose(inc, twice, cube); 13 | f.on('error', error => { 14 | throw new Error('Unexpected error'); 15 | }); 16 | let x; 17 | try { 18 | x = f(5); 19 | } catch (error) { 20 | throw new Error(`Unexpected throw`); 21 | } 22 | if (x !== 251) { 23 | throw new Error(`Expected 251 instead of ${x}`); 24 | } 25 | } 26 | { 27 | let errorDetected = false; 28 | const f = compose(inc, twice, fail, cube); 29 | f.on('error', error => { 30 | errorDetected = true; 31 | }); 32 | let x; 33 | try { 34 | x = f(5); 35 | } catch (error) { 36 | throw new Error(`Unexpected throw`); 37 | } 38 | if (!errorDetected) { 39 | throw new Error(`Expected error event is not received`); 40 | } 41 | if (x !== undefined) { 42 | throw new Error(`Expected undefined instead of ${x}`); 43 | } 44 | } 45 | } 46 | }) 47 | -------------------------------------------------------------------------------- /JavaScript/1-superposition.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const { log: ln } = Math; 4 | const pow = Math.pow; 5 | const sqrt = Math.sqrt; 6 | const inc = x => ++x; 7 | const add = (a, b) => a + b; 8 | const mul = (a, b) => a * b; 9 | const div = (a, b) => a / b; 10 | const log = (base, n) => ln(n) / ln(base); 11 | const iff = (e, x1, x2) => (e ? x1 : x2); 12 | const loop = (from, to, fn) => { 13 | for (let i = from; i <= to; i++) fn(i); 14 | }; 15 | 16 | const expr1 = pow(5 * 8, 2) + ((sqrt(20) + 1) / log(2, 7)); 17 | console.log(expr1); 18 | 19 | const expr2 = add( 20 | pow(mul(5, 8), 2), div(inc(sqrt(20)), log(2, 7)) 21 | ); 22 | console.log(expr2); 23 | 24 | const expr3 = add(iff(5 > 3, 10, 7), div(1, 2)); 25 | console.log(expr3); 26 | 27 | console.log('Loop from 5 to 10'); 28 | loop(5, 10, console.log); 29 | 30 | console.log('Loop from 5 to 10, write < 8'); 31 | loop(5, 10, x => iff(x < 8, console.log, () => {})(x)); 32 | -------------------------------------------------------------------------------- /JavaScript/2-composition.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const compose = (f, g) => x => f(g(x)); 4 | 5 | // Usage 6 | 7 | const upperFirst = word => word.charAt(0).toUpperCase() + word.slice(1); 8 | const upperCapital = s => s.split(' ').map(upperFirst).join(' '); 9 | const lower = s => s.toLowerCase(); 10 | 11 | const capitalize = compose(upperCapital, lower); 12 | 13 | const s = 'MARCUS AURELIUS'; 14 | console.log(s); 15 | console.log(`lower('${s}') = '${lower(s)}'`); 16 | console.log(`upperCapital('${s}') = '${upperCapital(s)}'`); 17 | console.log(`capitalize('${s}') = '${capitalize(s)}'`); 18 | -------------------------------------------------------------------------------- /JavaScript/3-arguments.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const compose = (f, g) => (...args) => f(g(...args)); 4 | const pipe = (f, g) => (...args) => g(f(...args)); 5 | 6 | // Usage 7 | 8 | const upperFirst = word => word.charAt(0).toUpperCase() + word.slice(1); 9 | const upperCapital = s => s.split(' ').map(upperFirst).join(' '); 10 | const lower = s => s.toLowerCase(); 11 | 12 | const s = 'MARCUS AURELIUS'; 13 | console.log(s); 14 | console.log(`lower('${s}') = '${lower(s)}'`); 15 | console.log(`upperCapital('${s}') = '${upperCapital(s)}'`); 16 | 17 | { 18 | console.log('Use compose'); 19 | const capitalize = compose(upperCapital, lower); 20 | console.log(`capitalize('${s}') = '${capitalize(s)}'`); 21 | } 22 | { 23 | console.log('Use pipe'); 24 | const capitalize = pipe(lower, upperCapital); 25 | console.log(`capitalize('${s}') = '${capitalize(s)}'`); 26 | } 27 | -------------------------------------------------------------------------------- /JavaScript/4-multiple.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const compose = (...fns) => x => fns.reduceRight((v, f) => f(v), x); 4 | const pipe = (...fns) => x => fns.reduce((v, f) => f(v), x); 5 | 6 | // Usage 7 | 8 | const upperFirst = word => word.charAt(0).toUpperCase() + word.slice(1); 9 | const upperCapital = s => s.split(' ').map(upperFirst).join(' '); 10 | const lower = s => s.toLowerCase(); 11 | const trim = s => s.trim(); 12 | 13 | const s = ' MARCUS AURELIUS '; 14 | console.log(s); 15 | console.log(`lower('${s}') = '${lower(s)}'`); 16 | console.log(`upperCapital('${s}') = '${upperCapital(s)}'`); 17 | 18 | { 19 | console.log('Use compose'); 20 | const capitalize = compose(upperCapital, lower, trim); 21 | console.log(`capitalize('${s}') = '${capitalize(s)}'`); 22 | } 23 | { 24 | console.log('Use pipe'); 25 | const capitalize = pipe(trim, lower, upperCapital); 26 | console.log(`capitalize('${s}') = '${capitalize(s)}'`); 27 | } 28 | -------------------------------------------------------------------------------- /JavaScript/5-loop.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const compose = (...fns) => x => { 4 | if (fns.length === 0) return x; 5 | const last = fns.length - 1; 6 | let res = x; 7 | for (let i = last; i >= 0; i--) { 8 | res = fns[i](res); 9 | } 10 | return res; 11 | }; 12 | 13 | const pipe = (...fns) => x => { 14 | if (fns.length === 0) return x; 15 | let res = x; 16 | for (let i = 0; i < fns.length; i++) { 17 | res = fns[i](res); 18 | } 19 | return res; 20 | }; 21 | 22 | // Usage 23 | 24 | const upperFirst = word => word.charAt(0).toUpperCase() + word.slice(1); 25 | const upperCapital = s => s.split(' ').map(upperFirst).join(' '); 26 | const lower = s => s.toLowerCase(); 27 | const trim = s => s.trim(); 28 | 29 | const s = ' MARCUS AURELIUS '; 30 | console.log(s); 31 | console.log(`lower('${s}') = '${lower(s)}'`); 32 | console.log(`upperCapital('${s}') = '${upperCapital(s)}'`); 33 | 34 | { 35 | console.log('Use compose'); 36 | const capitalize = compose(upperCapital, lower, trim); 37 | console.log(`capitalize('${s}') = '${capitalize(s)}'`); 38 | } 39 | { 40 | console.log('Use pipe'); 41 | const capitalize = pipe(trim, lower, upperCapital); 42 | console.log(`capitalize('${s}') = '${capitalize(s)}'`); 43 | } 44 | -------------------------------------------------------------------------------- /JavaScript/6-recursive.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const compose = (...fns) => x => { 4 | if (fns.length === 0) return x; 5 | const fn = fns.pop(); 6 | const res = fn(x); 7 | if (fns.length === 0) return res; 8 | return compose(...fns)(res); 9 | }; 10 | 11 | const pipe = (...fns) => x => { 12 | if (fns.length === 0) return x; 13 | const fn = fns.shift(); 14 | const res = fn(x); 15 | if (fns.length === 0) return res; 16 | return pipe(...fns)(res); 17 | }; 18 | 19 | // Usage 20 | 21 | const upperFirst = word => word.charAt(0).toUpperCase() + word.slice(1); 22 | const upperCapital = s => s.split(' ').map(upperFirst).join(' '); 23 | const lower = s => s.toLowerCase(); 24 | const trim = s => s.trim(); 25 | 26 | const s = ' MARCUS AURELIUS '; 27 | console.log(s); 28 | console.log(`lower('${s}') = '${lower(s)}'`); 29 | console.log(`upperCapital('${s}') = '${upperCapital(s)}'`); 30 | 31 | { 32 | console.log('Use compose'); 33 | const capitalize = compose(upperCapital, lower, trim); 34 | console.log(`capitalize('${s}') = '${capitalize(s)}'`); 35 | } 36 | { 37 | console.log('Use pipe'); 38 | const capitalize = pipe(trim, lower, upperCapital); 39 | console.log(`capitalize('${s}') = '${capitalize(s)}'`); 40 | } 41 | -------------------------------------------------------------------------------- /JavaScript/7-compose-async.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const fs = require('fs'); 4 | 5 | const reduceAsync = (items, performer, done, initialValue) => { 6 | const nseted = initialValue === undefined; 7 | let counter = nseted ? 1 : 0; 8 | let previous = nseted ? items[0] : initialValue; 9 | let current = nseted ? items[1] : items[0]; 10 | 11 | const response = (err, data) => { 12 | if (!err && counter !== items.length - 1) { 13 | counter++; 14 | previous = data; 15 | current = items[counter]; 16 | performer(previous, current, response, counter, items); 17 | } else if (done) { 18 | done(err, data); 19 | } 20 | }; 21 | 22 | performer(previous, current, response, counter, items); 23 | }; 24 | 25 | const last = arr => arr[arr.length - 1]; 26 | 27 | // funcs - array of parametrs for functions 28 | // args - array of functions 29 | // args[i] - function 30 | // args[-1] - done(err, data) 31 | // 32 | const composeAsync = (funcs, ...args) => ( 33 | () => reduceAsync( 34 | args.slice(0, -1), 35 | (params, fn, done) => fn(...[].concat(params).concat(done)), 36 | last(args), 37 | funcs 38 | ) 39 | ); 40 | 41 | // Usage 42 | 43 | const randomize = max => Math.floor((Math.random() * max)); 44 | 45 | const wrapAsync = callback => setTimeout(callback, randomize(1000)); 46 | 47 | const read = (file, charset, callback) => { 48 | console.dir({ read: { file, callback } }); 49 | fs.readFile(file, charset, callback); 50 | }; 51 | 52 | const parse = (data, callback) => { 53 | console.dir({ parse: { data, callback } }); 54 | wrapAsync(() => { 55 | callback(null, ['Data has been', 'processed!']); 56 | }); 57 | }; 58 | 59 | const preprocess = (data1, data2, callback) => { 60 | console.dir({ preprocess: { data1, data2, callback } }); 61 | wrapAsync(() => { 62 | callback(null, data1 + ' ' + data2); 63 | }); 64 | }; 65 | 66 | const cf1 = composeAsync( 67 | ['config.txt', 'utf8'], 68 | read, 69 | parse, 70 | preprocess, 71 | (err, data) => { 72 | if (!err) console.log(data); 73 | } 74 | ); 75 | 76 | cf1(); 77 | -------------------------------------------------------------------------------- /JavaScript/8-compose-proto.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const { EventEmitter } = require('events'); 4 | 5 | function AddOnlySet(it) { 6 | this.set = new Set(it); 7 | this.emitter = new EventEmitter(); 8 | this.size = it.length; 9 | } 10 | 11 | AddOnlySet.prototype.add = function (value) { 12 | this.set.add(value); 13 | this.size = this.set.size; 14 | this.emitter.emit('add', value); 15 | }; 16 | 17 | AddOnlySet.prototype.on = function (name, listener) { 18 | this.emitter.on(name, listener); 19 | }; 20 | 21 | AddOnlySet.prototype.toString = function () { 22 | return [...this.set.values()].join(); 23 | }; 24 | 25 | // Usage 26 | 27 | const s1 = new AddOnlySet(['uno', 'due']); 28 | s1.on('add', value => console.log(`Added "${value}"`)); 29 | s1.add('tre'); 30 | console.dir({ result: s1.toString() }); 31 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2017-2019 How.Programming.Works contributors 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, 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, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ## Композиция функций 2 | 3 | [![Композиция функций (pipe, compose) в JavaScript](https://img.youtube.com/vi/xS9FicVrOTI/0.jpg)](https://www.youtube.com/watch?v=xS9FicVrOTI) 4 | -------------------------------------------------------------------------------- /knowledge.map: -------------------------------------------------------------------------------- 1 | { 2 | dependencies: ['Function'] 3 | } 4 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "example", 3 | "version": "1.0.1", 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 | "requires": { 12 | "@babel/highlight": "^7.0.0" 13 | } 14 | }, 15 | "@babel/highlight": { 16 | "version": "7.5.0", 17 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.5.0.tgz", 18 | "integrity": "sha512-7dV4eu9gBxoM0dAnj/BCFDW9LFU0zvTrkq0ugM7pnHEgguOEeOz1so2ZghEdzviYzQEED0r4EAgpsBChKy1TRQ==", 19 | "requires": { 20 | "chalk": "^2.0.0", 21 | "esutils": "^2.0.2", 22 | "js-tokens": "^4.0.0" 23 | } 24 | }, 25 | "@metarhia/common": { 26 | "version": "1.5.0", 27 | "resolved": "https://registry.npmjs.org/@metarhia/common/-/common-1.5.0.tgz", 28 | "integrity": "sha512-hIiMPmIfDgyTl7Brn7qdAL2EqnsEoXqFUkfeMX5dQUGVjs+HO1NUR3J/KtUWeRuTNiiVQNeNtjB5j7dlZSsAqw==" 29 | }, 30 | "acorn": { 31 | "version": "7.1.0", 32 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.0.tgz", 33 | "integrity": "sha512-kL5CuoXA/dgxlBbVrflsflzQ3PAas7RYZB52NOm/6839iVYJgKMJ3cQJD+t2i5+qFa8h3MDpEOJiS64E8JLnSQ==" 34 | }, 35 | "acorn-jsx": { 36 | "version": "5.1.0", 37 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.1.0.tgz", 38 | "integrity": "sha512-tMUqwBWfLFbJbizRmEcWSLw6HnFzfdJs2sOJEOwwtVPMoH/0Ay+E703oZz78VSXZiiDcZrQ5XKjPIUQixhmgVw==" 39 | }, 40 | "ajv": { 41 | "version": "6.10.2", 42 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.2.tgz", 43 | "integrity": "sha512-TXtUUEYHuaTEbLZWIKUr5pmBuhDLy+8KYtPYdcV8qC+pOZL+NKqYwvWSRrVXHn+ZmRRAu8vJTAznH7Oag6RVRw==", 44 | "requires": { 45 | "fast-deep-equal": "^2.0.1", 46 | "fast-json-stable-stringify": "^2.0.0", 47 | "json-schema-traverse": "^0.4.1", 48 | "uri-js": "^4.2.2" 49 | } 50 | }, 51 | "ansi-escapes": { 52 | "version": "4.3.0", 53 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.0.tgz", 54 | "integrity": "sha512-EiYhwo0v255HUL6eDyuLrXEkTi7WwVCLAw+SeOQ7M7qdun1z1pum4DEm/nuqIVbPvi9RPPc9k9LbyBv6H0DwVg==", 55 | "requires": { 56 | "type-fest": "^0.8.1" 57 | } 58 | }, 59 | "ansi-regex": { 60 | "version": "5.0.0", 61 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 62 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==" 63 | }, 64 | "ansi-styles": { 65 | "version": "3.2.1", 66 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 67 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 68 | "requires": { 69 | "color-convert": "^1.9.0" 70 | } 71 | }, 72 | "argparse": { 73 | "version": "1.0.10", 74 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 75 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 76 | "requires": { 77 | "sprintf-js": "~1.0.2" 78 | } 79 | }, 80 | "astral-regex": { 81 | "version": "1.0.0", 82 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 83 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==" 84 | }, 85 | "balanced-match": { 86 | "version": "1.0.0", 87 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 88 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 89 | }, 90 | "brace-expansion": { 91 | "version": "1.1.11", 92 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 93 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 94 | "requires": { 95 | "balanced-match": "^1.0.0", 96 | "concat-map": "0.0.1" 97 | } 98 | }, 99 | "callsites": { 100 | "version": "3.1.0", 101 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 102 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==" 103 | }, 104 | "chalk": { 105 | "version": "2.4.2", 106 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 107 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 108 | "requires": { 109 | "ansi-styles": "^3.2.1", 110 | "escape-string-regexp": "^1.0.5", 111 | "supports-color": "^5.3.0" 112 | } 113 | }, 114 | "chardet": { 115 | "version": "0.7.0", 116 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 117 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==" 118 | }, 119 | "cli-cursor": { 120 | "version": "3.1.0", 121 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 122 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 123 | "requires": { 124 | "restore-cursor": "^3.1.0" 125 | } 126 | }, 127 | "cli-width": { 128 | "version": "2.2.0", 129 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 130 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=" 131 | }, 132 | "color-convert": { 133 | "version": "1.9.3", 134 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 135 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 136 | "requires": { 137 | "color-name": "1.1.3" 138 | } 139 | }, 140 | "color-name": { 141 | "version": "1.1.3", 142 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 143 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 144 | }, 145 | "concat-map": { 146 | "version": "0.0.1", 147 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 148 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 149 | }, 150 | "concolor": { 151 | "version": "0.1.13", 152 | "resolved": "https://registry.npmjs.org/concolor/-/concolor-0.1.13.tgz", 153 | "integrity": "sha512-Xazqi7pwBpyP6rQbdANg3hGAlHRSRuhFFXHGQIgWSS7i7Xj7E3BLS9okFpIWvas3UXNkAYLXJa+mNn1zO9DUew==" 154 | }, 155 | "cross-spawn": { 156 | "version": "6.0.5", 157 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 158 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 159 | "requires": { 160 | "nice-try": "^1.0.4", 161 | "path-key": "^2.0.1", 162 | "semver": "^5.5.0", 163 | "shebang-command": "^1.2.0", 164 | "which": "^1.2.9" 165 | }, 166 | "dependencies": { 167 | "semver": { 168 | "version": "5.7.1", 169 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 170 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 171 | } 172 | } 173 | }, 174 | "debug": { 175 | "version": "4.1.1", 176 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 177 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 178 | "requires": { 179 | "ms": "^2.1.1" 180 | } 181 | }, 182 | "deep-is": { 183 | "version": "0.1.3", 184 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 185 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=" 186 | }, 187 | "doctrine": { 188 | "version": "3.0.0", 189 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 190 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 191 | "requires": { 192 | "esutils": "^2.0.2" 193 | } 194 | }, 195 | "emoji-regex": { 196 | "version": "8.0.0", 197 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 198 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 199 | }, 200 | "escape-string-regexp": { 201 | "version": "1.0.5", 202 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 203 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" 204 | }, 205 | "eslint": { 206 | "version": "6.6.0", 207 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.6.0.tgz", 208 | "integrity": "sha512-PpEBq7b6qY/qrOmpYQ/jTMDYfuQMELR4g4WI1M/NaSDDD/bdcMb+dj4Hgks7p41kW2caXsPsEZAEAyAgjVVC0g==", 209 | "requires": { 210 | "@babel/code-frame": "^7.0.0", 211 | "ajv": "^6.10.0", 212 | "chalk": "^2.1.0", 213 | "cross-spawn": "^6.0.5", 214 | "debug": "^4.0.1", 215 | "doctrine": "^3.0.0", 216 | "eslint-scope": "^5.0.0", 217 | "eslint-utils": "^1.4.3", 218 | "eslint-visitor-keys": "^1.1.0", 219 | "espree": "^6.1.2", 220 | "esquery": "^1.0.1", 221 | "esutils": "^2.0.2", 222 | "file-entry-cache": "^5.0.1", 223 | "functional-red-black-tree": "^1.0.1", 224 | "glob-parent": "^5.0.0", 225 | "globals": "^11.7.0", 226 | "ignore": "^4.0.6", 227 | "import-fresh": "^3.0.0", 228 | "imurmurhash": "^0.1.4", 229 | "inquirer": "^7.0.0", 230 | "is-glob": "^4.0.0", 231 | "js-yaml": "^3.13.1", 232 | "json-stable-stringify-without-jsonify": "^1.0.1", 233 | "levn": "^0.3.0", 234 | "lodash": "^4.17.14", 235 | "minimatch": "^3.0.4", 236 | "mkdirp": "^0.5.1", 237 | "natural-compare": "^1.4.0", 238 | "optionator": "^0.8.2", 239 | "progress": "^2.0.0", 240 | "regexpp": "^2.0.1", 241 | "semver": "^6.1.2", 242 | "strip-ansi": "^5.2.0", 243 | "strip-json-comments": "^3.0.1", 244 | "table": "^5.2.3", 245 | "text-table": "^0.2.0", 246 | "v8-compile-cache": "^2.0.3" 247 | } 248 | }, 249 | "eslint-scope": { 250 | "version": "5.0.0", 251 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.0.0.tgz", 252 | "integrity": "sha512-oYrhJW7S0bxAFDvWqzvMPRm6pcgcnWc4QnofCAqRTRfQC0JcwenzGglTtsLyIuuWFfkqDG9vz67cnttSd53djw==", 253 | "requires": { 254 | "esrecurse": "^4.1.0", 255 | "estraverse": "^4.1.1" 256 | } 257 | }, 258 | "eslint-utils": { 259 | "version": "1.4.3", 260 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz", 261 | "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==", 262 | "requires": { 263 | "eslint-visitor-keys": "^1.1.0" 264 | } 265 | }, 266 | "eslint-visitor-keys": { 267 | "version": "1.1.0", 268 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz", 269 | "integrity": "sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A==" 270 | }, 271 | "espree": { 272 | "version": "6.1.2", 273 | "resolved": "https://registry.npmjs.org/espree/-/espree-6.1.2.tgz", 274 | "integrity": "sha512-2iUPuuPP+yW1PZaMSDM9eyVf8D5P0Hi8h83YtZ5bPc/zHYjII5khoixIUTMO794NOY8F/ThF1Bo8ncZILarUTA==", 275 | "requires": { 276 | "acorn": "^7.1.0", 277 | "acorn-jsx": "^5.1.0", 278 | "eslint-visitor-keys": "^1.1.0" 279 | } 280 | }, 281 | "esprima": { 282 | "version": "4.0.1", 283 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 284 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" 285 | }, 286 | "esquery": { 287 | "version": "1.0.1", 288 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 289 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 290 | "requires": { 291 | "estraverse": "^4.0.0" 292 | } 293 | }, 294 | "esrecurse": { 295 | "version": "4.2.1", 296 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 297 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 298 | "requires": { 299 | "estraverse": "^4.1.0" 300 | } 301 | }, 302 | "estraverse": { 303 | "version": "4.3.0", 304 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 305 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==" 306 | }, 307 | "esutils": { 308 | "version": "2.0.3", 309 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 310 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==" 311 | }, 312 | "external-editor": { 313 | "version": "3.1.0", 314 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 315 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 316 | "requires": { 317 | "chardet": "^0.7.0", 318 | "iconv-lite": "^0.4.24", 319 | "tmp": "^0.0.33" 320 | } 321 | }, 322 | "fast-deep-equal": { 323 | "version": "2.0.1", 324 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 325 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=" 326 | }, 327 | "fast-json-stable-stringify": { 328 | "version": "2.0.0", 329 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 330 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=" 331 | }, 332 | "fast-levenshtein": { 333 | "version": "2.0.6", 334 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 335 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=" 336 | }, 337 | "figures": { 338 | "version": "3.1.0", 339 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.1.0.tgz", 340 | "integrity": "sha512-ravh8VRXqHuMvZt/d8GblBeqDMkdJMBdv/2KntFH+ra5MXkO7nxNKpzQ3n6QD/2da1kH0aWmNISdvhM7gl2gVg==", 341 | "requires": { 342 | "escape-string-regexp": "^1.0.5" 343 | } 344 | }, 345 | "file-entry-cache": { 346 | "version": "5.0.1", 347 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 348 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 349 | "requires": { 350 | "flat-cache": "^2.0.1" 351 | } 352 | }, 353 | "flat-cache": { 354 | "version": "2.0.1", 355 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 356 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 357 | "requires": { 358 | "flatted": "^2.0.0", 359 | "rimraf": "2.6.3", 360 | "write": "1.0.3" 361 | } 362 | }, 363 | "flatted": { 364 | "version": "2.0.1", 365 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.1.tgz", 366 | "integrity": "sha512-a1hQMktqW9Nmqr5aktAux3JMNqaucxGcjtjWnZLHX7yyPCmlSV3M54nGYbqT8K+0GhF3NBgmJCc3ma+WOgX8Jg==" 367 | }, 368 | "fs.realpath": { 369 | "version": "1.0.0", 370 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 371 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 372 | }, 373 | "functional-red-black-tree": { 374 | "version": "1.0.1", 375 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 376 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=" 377 | }, 378 | "glob": { 379 | "version": "7.1.6", 380 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 381 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 382 | "requires": { 383 | "fs.realpath": "^1.0.0", 384 | "inflight": "^1.0.4", 385 | "inherits": "2", 386 | "minimatch": "^3.0.4", 387 | "once": "^1.3.0", 388 | "path-is-absolute": "^1.0.0" 389 | } 390 | }, 391 | "glob-parent": { 392 | "version": "5.1.0", 393 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.0.tgz", 394 | "integrity": "sha512-qjtRgnIVmOfnKUE3NJAQEdk+lKrxfw8t5ke7SXtfMTHcjsBfOfWXCQfdb30zfDoZQ2IRSIiidmjtbHZPZ++Ihw==", 395 | "requires": { 396 | "is-glob": "^4.0.1" 397 | } 398 | }, 399 | "globals": { 400 | "version": "11.12.0", 401 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 402 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==" 403 | }, 404 | "has-flag": { 405 | "version": "3.0.0", 406 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 407 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 408 | }, 409 | "hpw": { 410 | "version": "0.1.9", 411 | "resolved": "https://registry.npmjs.org/hpw/-/hpw-0.1.9.tgz", 412 | "integrity": "sha512-ce9MEdtxbR1du5/gJlXXy44H1WPaDFCgY52MPIpExhXlkht36ppiG/zE1CktcJGV6/5fK8lQbtPQr+Tu2LwocA==", 413 | "requires": { 414 | "concolor": "^0.1.12", 415 | "metasync": "^0.3.31" 416 | } 417 | }, 418 | "iconv-lite": { 419 | "version": "0.4.24", 420 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 421 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 422 | "requires": { 423 | "safer-buffer": ">= 2.1.2 < 3" 424 | } 425 | }, 426 | "ignore": { 427 | "version": "4.0.6", 428 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 429 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==" 430 | }, 431 | "import-fresh": { 432 | "version": "3.2.1", 433 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", 434 | "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", 435 | "requires": { 436 | "parent-module": "^1.0.0", 437 | "resolve-from": "^4.0.0" 438 | } 439 | }, 440 | "imurmurhash": { 441 | "version": "0.1.4", 442 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 443 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=" 444 | }, 445 | "inflight": { 446 | "version": "1.0.6", 447 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 448 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 449 | "requires": { 450 | "once": "^1.3.0", 451 | "wrappy": "1" 452 | } 453 | }, 454 | "inherits": { 455 | "version": "2.0.4", 456 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 457 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 458 | }, 459 | "inquirer": { 460 | "version": "7.0.0", 461 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.0.0.tgz", 462 | "integrity": "sha512-rSdC7zelHdRQFkWnhsMu2+2SO41mpv2oF2zy4tMhmiLWkcKbOAs87fWAJhVXttKVwhdZvymvnuM95EyEXg2/tQ==", 463 | "requires": { 464 | "ansi-escapes": "^4.2.1", 465 | "chalk": "^2.4.2", 466 | "cli-cursor": "^3.1.0", 467 | "cli-width": "^2.0.0", 468 | "external-editor": "^3.0.3", 469 | "figures": "^3.0.0", 470 | "lodash": "^4.17.15", 471 | "mute-stream": "0.0.8", 472 | "run-async": "^2.2.0", 473 | "rxjs": "^6.4.0", 474 | "string-width": "^4.1.0", 475 | "strip-ansi": "^5.1.0", 476 | "through": "^2.3.6" 477 | } 478 | }, 479 | "is-extglob": { 480 | "version": "2.1.1", 481 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 482 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=" 483 | }, 484 | "is-fullwidth-code-point": { 485 | "version": "3.0.0", 486 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 487 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" 488 | }, 489 | "is-glob": { 490 | "version": "4.0.1", 491 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 492 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 493 | "requires": { 494 | "is-extglob": "^2.1.1" 495 | } 496 | }, 497 | "is-promise": { 498 | "version": "2.1.0", 499 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 500 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=" 501 | }, 502 | "isexe": { 503 | "version": "2.0.0", 504 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 505 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 506 | }, 507 | "js-tokens": { 508 | "version": "4.0.0", 509 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 510 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 511 | }, 512 | "js-yaml": { 513 | "version": "3.13.1", 514 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 515 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 516 | "requires": { 517 | "argparse": "^1.0.7", 518 | "esprima": "^4.0.0" 519 | } 520 | }, 521 | "json-schema-traverse": { 522 | "version": "0.4.1", 523 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 524 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==" 525 | }, 526 | "json-stable-stringify-without-jsonify": { 527 | "version": "1.0.1", 528 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 529 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=" 530 | }, 531 | "levn": { 532 | "version": "0.3.0", 533 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 534 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 535 | "requires": { 536 | "prelude-ls": "~1.1.2", 537 | "type-check": "~0.3.2" 538 | } 539 | }, 540 | "lodash": { 541 | "version": "4.17.15", 542 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", 543 | "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==" 544 | }, 545 | "metasync": { 546 | "version": "0.3.31", 547 | "resolved": "https://registry.npmjs.org/metasync/-/metasync-0.3.31.tgz", 548 | "integrity": "sha512-ydkv/FHFLWK65EHjFwmEq9vQXIci/L8w9dG3a+DWLRfW4yRy3n4BAXag/pZBAF+UHXvbrOXnfJ0V/IF8MXOLtA==", 549 | "requires": { 550 | "@metarhia/common": "^1.0.0" 551 | } 552 | }, 553 | "mimic-fn": { 554 | "version": "2.1.0", 555 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 556 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==" 557 | }, 558 | "minimatch": { 559 | "version": "3.0.4", 560 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 561 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 562 | "requires": { 563 | "brace-expansion": "^1.1.7" 564 | } 565 | }, 566 | "minimist": { 567 | "version": "0.0.8", 568 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 569 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" 570 | }, 571 | "mkdirp": { 572 | "version": "0.5.1", 573 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 574 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 575 | "requires": { 576 | "minimist": "0.0.8" 577 | } 578 | }, 579 | "ms": { 580 | "version": "2.1.2", 581 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 582 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 583 | }, 584 | "mute-stream": { 585 | "version": "0.0.8", 586 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 587 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==" 588 | }, 589 | "natural-compare": { 590 | "version": "1.4.0", 591 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 592 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=" 593 | }, 594 | "nice-try": { 595 | "version": "1.0.5", 596 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 597 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==" 598 | }, 599 | "once": { 600 | "version": "1.4.0", 601 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 602 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 603 | "requires": { 604 | "wrappy": "1" 605 | } 606 | }, 607 | "onetime": { 608 | "version": "5.1.0", 609 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", 610 | "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", 611 | "requires": { 612 | "mimic-fn": "^2.1.0" 613 | } 614 | }, 615 | "optionator": { 616 | "version": "0.8.3", 617 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", 618 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", 619 | "requires": { 620 | "deep-is": "~0.1.3", 621 | "fast-levenshtein": "~2.0.6", 622 | "levn": "~0.3.0", 623 | "prelude-ls": "~1.1.2", 624 | "type-check": "~0.3.2", 625 | "word-wrap": "~1.2.3" 626 | } 627 | }, 628 | "os-tmpdir": { 629 | "version": "1.0.2", 630 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 631 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 632 | }, 633 | "parent-module": { 634 | "version": "1.0.1", 635 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 636 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 637 | "requires": { 638 | "callsites": "^3.0.0" 639 | } 640 | }, 641 | "path-is-absolute": { 642 | "version": "1.0.1", 643 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 644 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 645 | }, 646 | "path-key": { 647 | "version": "2.0.1", 648 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 649 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=" 650 | }, 651 | "prelude-ls": { 652 | "version": "1.1.2", 653 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 654 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=" 655 | }, 656 | "progress": { 657 | "version": "2.0.3", 658 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 659 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==" 660 | }, 661 | "punycode": { 662 | "version": "2.1.1", 663 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 664 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" 665 | }, 666 | "regexpp": { 667 | "version": "2.0.1", 668 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 669 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==" 670 | }, 671 | "resolve-from": { 672 | "version": "4.0.0", 673 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 674 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==" 675 | }, 676 | "restore-cursor": { 677 | "version": "3.1.0", 678 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 679 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 680 | "requires": { 681 | "onetime": "^5.1.0", 682 | "signal-exit": "^3.0.2" 683 | } 684 | }, 685 | "rimraf": { 686 | "version": "2.6.3", 687 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 688 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 689 | "requires": { 690 | "glob": "^7.1.3" 691 | } 692 | }, 693 | "run-async": { 694 | "version": "2.3.0", 695 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 696 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 697 | "requires": { 698 | "is-promise": "^2.1.0" 699 | } 700 | }, 701 | "rxjs": { 702 | "version": "6.5.3", 703 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.3.tgz", 704 | "integrity": "sha512-wuYsAYYFdWTAnAaPoKGNhfpWwKZbJW+HgAJ+mImp+Epl7BG8oNWBCTyRM8gba9k4lk8BgWdoYm21Mo/RYhhbgA==", 705 | "requires": { 706 | "tslib": "^1.9.0" 707 | } 708 | }, 709 | "safer-buffer": { 710 | "version": "2.1.2", 711 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 712 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 713 | }, 714 | "semver": { 715 | "version": "6.3.0", 716 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 717 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" 718 | }, 719 | "shebang-command": { 720 | "version": "1.2.0", 721 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 722 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 723 | "requires": { 724 | "shebang-regex": "^1.0.0" 725 | } 726 | }, 727 | "shebang-regex": { 728 | "version": "1.0.0", 729 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 730 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=" 731 | }, 732 | "signal-exit": { 733 | "version": "3.0.2", 734 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 735 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" 736 | }, 737 | "slice-ansi": { 738 | "version": "2.1.0", 739 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 740 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 741 | "requires": { 742 | "ansi-styles": "^3.2.0", 743 | "astral-regex": "^1.0.0", 744 | "is-fullwidth-code-point": "^2.0.0" 745 | }, 746 | "dependencies": { 747 | "is-fullwidth-code-point": { 748 | "version": "2.0.0", 749 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 750 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 751 | } 752 | } 753 | }, 754 | "sprintf-js": { 755 | "version": "1.0.3", 756 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 757 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=" 758 | }, 759 | "string-width": { 760 | "version": "4.2.0", 761 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 762 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 763 | "requires": { 764 | "emoji-regex": "^8.0.0", 765 | "is-fullwidth-code-point": "^3.0.0", 766 | "strip-ansi": "^6.0.0" 767 | }, 768 | "dependencies": { 769 | "strip-ansi": { 770 | "version": "6.0.0", 771 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 772 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 773 | "requires": { 774 | "ansi-regex": "^5.0.0" 775 | } 776 | } 777 | } 778 | }, 779 | "strip-ansi": { 780 | "version": "5.2.0", 781 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 782 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 783 | "requires": { 784 | "ansi-regex": "^4.1.0" 785 | }, 786 | "dependencies": { 787 | "ansi-regex": { 788 | "version": "4.1.0", 789 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 790 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==" 791 | } 792 | } 793 | }, 794 | "strip-json-comments": { 795 | "version": "3.0.1", 796 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.0.1.tgz", 797 | "integrity": "sha512-VTyMAUfdm047mwKl+u79WIdrZxtFtn+nBxHeb844XBQ9uMNTuTHdx2hc5RiAJYqwTj3wc/xe5HLSdJSkJ+WfZw==" 798 | }, 799 | "supports-color": { 800 | "version": "5.5.0", 801 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 802 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 803 | "requires": { 804 | "has-flag": "^3.0.0" 805 | } 806 | }, 807 | "table": { 808 | "version": "5.4.6", 809 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 810 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 811 | "requires": { 812 | "ajv": "^6.10.2", 813 | "lodash": "^4.17.14", 814 | "slice-ansi": "^2.1.0", 815 | "string-width": "^3.0.0" 816 | }, 817 | "dependencies": { 818 | "emoji-regex": { 819 | "version": "7.0.3", 820 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 821 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" 822 | }, 823 | "is-fullwidth-code-point": { 824 | "version": "2.0.0", 825 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 826 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 827 | }, 828 | "string-width": { 829 | "version": "3.1.0", 830 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 831 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 832 | "requires": { 833 | "emoji-regex": "^7.0.1", 834 | "is-fullwidth-code-point": "^2.0.0", 835 | "strip-ansi": "^5.1.0" 836 | } 837 | } 838 | } 839 | }, 840 | "text-table": { 841 | "version": "0.2.0", 842 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 843 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=" 844 | }, 845 | "through": { 846 | "version": "2.3.8", 847 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 848 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" 849 | }, 850 | "tmp": { 851 | "version": "0.0.33", 852 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 853 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 854 | "requires": { 855 | "os-tmpdir": "~1.0.2" 856 | } 857 | }, 858 | "tslib": { 859 | "version": "1.10.0", 860 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", 861 | "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==" 862 | }, 863 | "type-check": { 864 | "version": "0.3.2", 865 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 866 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 867 | "requires": { 868 | "prelude-ls": "~1.1.2" 869 | } 870 | }, 871 | "type-fest": { 872 | "version": "0.8.1", 873 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 874 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==" 875 | }, 876 | "uri-js": { 877 | "version": "4.2.2", 878 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 879 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 880 | "requires": { 881 | "punycode": "^2.1.0" 882 | } 883 | }, 884 | "v8-compile-cache": { 885 | "version": "2.1.0", 886 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.0.tgz", 887 | "integrity": "sha512-usZBT3PW+LOjM25wbqIlZwPeJV+3OSz3M1k1Ws8snlW39dZyYL9lOGC5FgPVHfk0jKmjiDV8Z0mIbVQPiwFs7g==" 888 | }, 889 | "which": { 890 | "version": "1.3.1", 891 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 892 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 893 | "requires": { 894 | "isexe": "^2.0.0" 895 | } 896 | }, 897 | "word-wrap": { 898 | "version": "1.2.3", 899 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 900 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==" 901 | }, 902 | "wrappy": { 903 | "version": "1.0.2", 904 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 905 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 906 | }, 907 | "write": { 908 | "version": "1.0.3", 909 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 910 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 911 | "requires": { 912 | "mkdirp": "^0.5.1" 913 | } 914 | } 915 | } 916 | } 917 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "example", 3 | "private": true, 4 | "version": "1.0.1", 5 | "author": "Timur Shemsedinov ", 6 | "license": "MIT", 7 | "scripts": { 8 | "test": "eslint ./Exercises; hpw" 9 | }, 10 | "dependencies": { 11 | "eslint": "^6.4.0", 12 | "hpw": "^0.1.8" 13 | } 14 | } 15 | --------------------------------------------------------------------------------