├── .editorconfig ├── .eslintignore ├── .eslintrc.json ├── .gitignore ├── .npmignore ├── LICENSE ├── README.md ├── cache.js ├── export.mjs ├── import.mjs ├── import.sh ├── lib ├── submodule1.js ├── submodule2.js └── submodule3.js ├── main.js ├── package-lock.json ├── package.json └── test ├── all.js ├── names.js └── submodules.js /.editorconfig: -------------------------------------------------------------------------------- 1 | # http://editorconfig.org 2 | root = true 3 | 4 | [*] 5 | end_of_line = lf 6 | charset = utf-8 7 | insert_final_newline = true 8 | trim_trailing_whitespace = true 9 | 10 | [{*.js,*.mjs,*.ts,*.json,*.yml}] 11 | indent_size = 2 12 | indent_style = space 13 | -------------------------------------------------------------------------------- /.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": 2020 10 | }, 11 | "globals": { 12 | "BigInt": true 13 | }, 14 | "rules": { 15 | "indent": [ 16 | "error", 17 | 2 18 | ], 19 | "linebreak-style": [ 20 | "error", 21 | "unix" 22 | ], 23 | "quotes": [ 24 | "error", 25 | "single" 26 | ], 27 | "semi": [ 28 | "error", 29 | "always" 30 | ], 31 | "no-loop-func": [ 32 | "error" 33 | ], 34 | "block-spacing": [ 35 | "error", 36 | "always" 37 | ], 38 | "camelcase": [ 39 | "error" 40 | ], 41 | "eqeqeq": [ 42 | "error", 43 | "always" 44 | ], 45 | "strict": [ 46 | "error", 47 | "global" 48 | ], 49 | "brace-style": [ 50 | "error", 51 | "1tbs", 52 | { 53 | "allowSingleLine": true 54 | } 55 | ], 56 | "comma-style": [ 57 | "error", 58 | "last" 59 | ], 60 | "comma-spacing": [ 61 | "error", 62 | { 63 | "before": false, 64 | "after": true 65 | } 66 | ], 67 | "eol-last": [ 68 | "error" 69 | ], 70 | "func-call-spacing": [ 71 | "error", 72 | "never" 73 | ], 74 | "key-spacing": [ 75 | "error", 76 | { 77 | "beforeColon": false, 78 | "afterColon": true, 79 | "mode": "minimum" 80 | } 81 | ], 82 | "keyword-spacing": [ 83 | "error", 84 | { 85 | "before": true, 86 | "after": true, 87 | "overrides": { 88 | "function": { 89 | "after": false 90 | } 91 | } 92 | } 93 | ], 94 | "max-len": [ 95 | "error", 96 | { 97 | "code": 80, 98 | "ignoreUrls": true 99 | } 100 | ], 101 | "max-nested-callbacks": [ 102 | "error", 103 | { 104 | "max": 7 105 | } 106 | ], 107 | "new-cap": [ 108 | "error", 109 | { 110 | "newIsCap": true, 111 | "capIsNew": false, 112 | "properties": true 113 | } 114 | ], 115 | "new-parens": [ 116 | "error" 117 | ], 118 | "no-lonely-if": [ 119 | "error" 120 | ], 121 | "no-trailing-spaces": [ 122 | "error" 123 | ], 124 | "no-unneeded-ternary": [ 125 | "error" 126 | ], 127 | "no-whitespace-before-property": [ 128 | "error" 129 | ], 130 | "object-curly-spacing": [ 131 | "error", 132 | "always" 133 | ], 134 | "operator-assignment": [ 135 | "error", 136 | "always" 137 | ], 138 | "operator-linebreak": [ 139 | "error", 140 | "after" 141 | ], 142 | "semi-spacing": [ 143 | "error", 144 | { 145 | "before": false, 146 | "after": true 147 | } 148 | ], 149 | "space-before-blocks": [ 150 | "error", 151 | "always" 152 | ], 153 | "space-before-function-paren": [ 154 | "error", 155 | { 156 | "anonymous": "never", 157 | "named": "never", 158 | "asyncArrow": "always" 159 | } 160 | ], 161 | "space-in-parens": [ 162 | "error", 163 | "never" 164 | ], 165 | "space-infix-ops": [ 166 | "error" 167 | ], 168 | "space-unary-ops": [ 169 | "error", 170 | { 171 | "words": true, 172 | "nonwords": false, 173 | "overrides": { 174 | "typeof": false 175 | } 176 | } 177 | ], 178 | "no-unreachable": [ 179 | "error" 180 | ], 181 | "no-global-assign": [ 182 | "error" 183 | ], 184 | "no-self-compare": [ 185 | "error" 186 | ], 187 | "no-unmodified-loop-condition": [ 188 | "error" 189 | ], 190 | "no-constant-condition": [ 191 | "error", 192 | { 193 | "checkLoops": false 194 | } 195 | ], 196 | "no-console": [ 197 | "off" 198 | ], 199 | "no-useless-concat": [ 200 | "error" 201 | ], 202 | "no-useless-escape": [ 203 | "error" 204 | ], 205 | "no-shadow-restricted-names": [ 206 | "error" 207 | ], 208 | "no-use-before-define": [ 209 | "error", 210 | { 211 | "functions": false 212 | } 213 | ], 214 | "arrow-parens": [ 215 | "error", 216 | "as-needed" 217 | ], 218 | "arrow-body-style": [ 219 | "error", 220 | "as-needed" 221 | ], 222 | "arrow-spacing": [ 223 | "error" 224 | ], 225 | "no-confusing-arrow": [ 226 | "error", 227 | { 228 | "allowParens": true 229 | } 230 | ], 231 | "no-useless-computed-key": [ 232 | "error" 233 | ], 234 | "no-useless-rename": [ 235 | "error" 236 | ], 237 | "no-var": [ 238 | "error" 239 | ], 240 | "object-shorthand": [ 241 | "error", 242 | "always" 243 | ], 244 | "prefer-arrow-callback": [ 245 | "error" 246 | ], 247 | "prefer-const": [ 248 | "error" 249 | ], 250 | "prefer-numeric-literals": [ 251 | "error" 252 | ], 253 | "prefer-rest-params": [ 254 | "error" 255 | ], 256 | "prefer-spread": [ 257 | "error" 258 | ], 259 | "rest-spread-spacing": [ 260 | "error", 261 | "never" 262 | ], 263 | "template-curly-spacing": [ 264 | "error", 265 | "never" 266 | ] 267 | } 268 | } 269 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | *.log 3 | .DS_Store 4 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | *.log 3 | .DS_Store 4 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2017-2022 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 | # Example Node.js project 2 | 3 | [Задать вопрос](https://github.com/HowProgrammingWorks/LiveQA/discussions/categories/q-a) 4 | 5 | [![Модули, слои, структура проекта, песочницы](https://img.youtube.com/vi/O7A9chb573E/0.jpg)](https://www.youtube.com/watch?v=O7A9chb573E) 6 | -------------------------------------------------------------------------------- /cache.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const lib1 = require('./main.js'); 4 | const libPath = require.resolve('./main.js'); 5 | console.dir({ libPath }); 6 | delete require.cache[libPath]; 7 | const lib2 = require('./main.js'); 8 | 9 | if (lib1 === lib2) { 10 | console.log('Cache not reloaded'); 11 | } else { 12 | console.log('Cache reloaded'); 13 | } 14 | -------------------------------------------------------------------------------- /export.mjs: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const field = 'value'; 4 | const func = () => {}; 5 | 6 | export { field, func }; 7 | -------------------------------------------------------------------------------- /import.mjs: -------------------------------------------------------------------------------- 1 | import { field, func } from './export.mjs'; 2 | 3 | console.dir({ require }); 4 | 5 | console.log({ field, func }); 6 | -------------------------------------------------------------------------------- /import.sh: -------------------------------------------------------------------------------- 1 | node --experimental-modules import.mjs 2 | -------------------------------------------------------------------------------- /lib/submodule1.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const method11 = () => 11; 4 | const method12 = () => 12; 5 | 6 | module.exports = { method11, method12 }; 7 | -------------------------------------------------------------------------------- /lib/submodule2.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const method21 = () => 21; 4 | const method22 = () => 22; 5 | const method23 = () => 23; 6 | 7 | module.exports = { method21, method22, method23 }; 8 | -------------------------------------------------------------------------------- /lib/submodule3.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const method31 = () => 31; 4 | const method32 = () => 32; 5 | 6 | module.exports = { method31, method32 }; 7 | -------------------------------------------------------------------------------- /main.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const lib = {}; 4 | ['submodule1', 'submodule2', 'submodule3'].forEach(name => { 5 | const sub = require(`./lib/${name}.js`); 6 | Object.assign(lib, sub); 7 | }); 8 | 9 | console.log('We combined submodules:'); 10 | console.log(Object.keys(lib).join(', ')); 11 | 12 | module.exports = lib; 13 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "example", 3 | "version": "0.1.5", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@eslint/eslintrc": { 8 | "version": "1.2.1", 9 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.2.1.tgz", 10 | "integrity": "sha512-bxvbYnBPN1Gibwyp6NrpnFzA3YtRL3BBAyEAFVIpNTm2Rn4Vy87GA5M4aSn3InRrlsbX5N0GW7XIx+U4SAEKdQ==", 11 | "dev": true, 12 | "requires": { 13 | "ajv": "^6.12.4", 14 | "debug": "^4.3.2", 15 | "espree": "^9.3.1", 16 | "globals": "^13.9.0", 17 | "ignore": "^5.2.0", 18 | "import-fresh": "^3.2.1", 19 | "js-yaml": "^4.1.0", 20 | "minimatch": "^3.0.4", 21 | "strip-json-comments": "^3.1.1" 22 | } 23 | }, 24 | "@humanwhocodes/config-array": { 25 | "version": "0.9.5", 26 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.9.5.tgz", 27 | "integrity": "sha512-ObyMyWxZiCu/yTisA7uzx81s40xR2fD5Cg/2Kq7G02ajkNubJf6BopgDTmDyc3U7sXpNKM8cYOw7s7Tyr+DnCw==", 28 | "dev": true, 29 | "requires": { 30 | "@humanwhocodes/object-schema": "^1.2.1", 31 | "debug": "^4.1.1", 32 | "minimatch": "^3.0.4" 33 | } 34 | }, 35 | "@humanwhocodes/object-schema": { 36 | "version": "1.2.1", 37 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 38 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 39 | "dev": true 40 | }, 41 | "@metarhia/common": { 42 | "version": "2.2.0", 43 | "resolved": "https://registry.npmjs.org/@metarhia/common/-/common-2.2.0.tgz", 44 | "integrity": "sha512-yAq1FPk2ayLAlj3QGOCSjpN5yWYLD3zLtJWkBRjQUlastAlrLzEMzTmbjLCGzz+lwZSwvSNsGHBsO0C42IO8CQ==" 45 | }, 46 | "acorn": { 47 | "version": "8.7.0", 48 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.0.tgz", 49 | "integrity": "sha512-V/LGr1APy+PXIwKebEWrkZPwoeoF+w1jiOBUmuxuiUIaOHtob8Qc9BTrYo7VuI5fR8tqsy+buA2WFooR5olqvQ==", 50 | "dev": true 51 | }, 52 | "acorn-jsx": { 53 | "version": "5.3.2", 54 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 55 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 56 | "dev": true 57 | }, 58 | "ajv": { 59 | "version": "6.12.6", 60 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 61 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 62 | "dev": true, 63 | "requires": { 64 | "fast-deep-equal": "^3.1.1", 65 | "fast-json-stable-stringify": "^2.0.0", 66 | "json-schema-traverse": "^0.4.1", 67 | "uri-js": "^4.2.2" 68 | } 69 | }, 70 | "ansi-regex": { 71 | "version": "5.0.1", 72 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 73 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 74 | "dev": true 75 | }, 76 | "ansi-styles": { 77 | "version": "4.3.0", 78 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 79 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 80 | "dev": true, 81 | "requires": { 82 | "color-convert": "^2.0.1" 83 | } 84 | }, 85 | "argparse": { 86 | "version": "2.0.1", 87 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 88 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 89 | "dev": true 90 | }, 91 | "balanced-match": { 92 | "version": "1.0.2", 93 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 94 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 95 | "dev": true 96 | }, 97 | "brace-expansion": { 98 | "version": "1.1.11", 99 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 100 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 101 | "dev": true, 102 | "requires": { 103 | "balanced-match": "^1.0.0", 104 | "concat-map": "0.0.1" 105 | } 106 | }, 107 | "callsites": { 108 | "version": "3.1.0", 109 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 110 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 111 | "dev": true 112 | }, 113 | "camelcase": { 114 | "version": "5.3.1", 115 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 116 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 117 | "dev": true 118 | }, 119 | "chalk": { 120 | "version": "4.1.2", 121 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 122 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 123 | "dev": true, 124 | "requires": { 125 | "ansi-styles": "^4.1.0", 126 | "supports-color": "^7.1.0" 127 | } 128 | }, 129 | "cliui": { 130 | "version": "6.0.0", 131 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-6.0.0.tgz", 132 | "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==", 133 | "dev": true, 134 | "requires": { 135 | "string-width": "^4.2.0", 136 | "strip-ansi": "^6.0.0", 137 | "wrap-ansi": "^6.2.0" 138 | } 139 | }, 140 | "color-convert": { 141 | "version": "2.0.1", 142 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 143 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 144 | "dev": true, 145 | "requires": { 146 | "color-name": "~1.1.4" 147 | } 148 | }, 149 | "color-name": { 150 | "version": "1.1.4", 151 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 152 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 153 | "dev": true 154 | }, 155 | "color-support": { 156 | "version": "1.1.3", 157 | "resolved": "https://registry.npmjs.org/color-support/-/color-support-1.1.3.tgz", 158 | "integrity": "sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg==", 159 | "dev": true 160 | }, 161 | "concat-map": { 162 | "version": "0.0.1", 163 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 164 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 165 | "dev": true 166 | }, 167 | "cross-spawn": { 168 | "version": "7.0.3", 169 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 170 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 171 | "dev": true, 172 | "requires": { 173 | "path-key": "^3.1.0", 174 | "shebang-command": "^2.0.0", 175 | "which": "^2.0.1" 176 | } 177 | }, 178 | "debug": { 179 | "version": "4.3.4", 180 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 181 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 182 | "dev": true, 183 | "requires": { 184 | "ms": "2.1.2" 185 | } 186 | }, 187 | "decamelize": { 188 | "version": "1.2.0", 189 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 190 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 191 | "dev": true 192 | }, 193 | "deep-is": { 194 | "version": "0.1.4", 195 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 196 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 197 | "dev": true 198 | }, 199 | "diff": { 200 | "version": "4.0.2", 201 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 202 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 203 | "dev": true 204 | }, 205 | "doctrine": { 206 | "version": "3.0.0", 207 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 208 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 209 | "dev": true, 210 | "requires": { 211 | "esutils": "^2.0.2" 212 | } 213 | }, 214 | "emoji-regex": { 215 | "version": "8.0.0", 216 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 217 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 218 | "dev": true 219 | }, 220 | "escape-string-regexp": { 221 | "version": "4.0.0", 222 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 223 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 224 | "dev": true 225 | }, 226 | "eslint": { 227 | "version": "8.12.0", 228 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.12.0.tgz", 229 | "integrity": "sha512-it1oBL9alZg1S8UycLm5YDMAkIhtH6FtAzuZs6YvoGVldWjbS08BkAdb/ymP9LlAyq8koANu32U7Ib/w+UNh8Q==", 230 | "dev": true, 231 | "requires": { 232 | "@eslint/eslintrc": "^1.2.1", 233 | "@humanwhocodes/config-array": "^0.9.2", 234 | "ajv": "^6.10.0", 235 | "chalk": "^4.0.0", 236 | "cross-spawn": "^7.0.2", 237 | "debug": "^4.3.2", 238 | "doctrine": "^3.0.0", 239 | "escape-string-regexp": "^4.0.0", 240 | "eslint-scope": "^7.1.1", 241 | "eslint-utils": "^3.0.0", 242 | "eslint-visitor-keys": "^3.3.0", 243 | "espree": "^9.3.1", 244 | "esquery": "^1.4.0", 245 | "esutils": "^2.0.2", 246 | "fast-deep-equal": "^3.1.3", 247 | "file-entry-cache": "^6.0.1", 248 | "functional-red-black-tree": "^1.0.1", 249 | "glob-parent": "^6.0.1", 250 | "globals": "^13.6.0", 251 | "ignore": "^5.2.0", 252 | "import-fresh": "^3.0.0", 253 | "imurmurhash": "^0.1.4", 254 | "is-glob": "^4.0.0", 255 | "js-yaml": "^4.1.0", 256 | "json-stable-stringify-without-jsonify": "^1.0.1", 257 | "levn": "^0.4.1", 258 | "lodash.merge": "^4.6.2", 259 | "minimatch": "^3.0.4", 260 | "natural-compare": "^1.4.0", 261 | "optionator": "^0.9.1", 262 | "regexpp": "^3.2.0", 263 | "strip-ansi": "^6.0.1", 264 | "strip-json-comments": "^3.1.0", 265 | "text-table": "^0.2.0", 266 | "v8-compile-cache": "^2.0.3" 267 | } 268 | }, 269 | "eslint-scope": { 270 | "version": "7.1.1", 271 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.1.tgz", 272 | "integrity": "sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==", 273 | "dev": true, 274 | "requires": { 275 | "esrecurse": "^4.3.0", 276 | "estraverse": "^5.2.0" 277 | } 278 | }, 279 | "eslint-utils": { 280 | "version": "3.0.0", 281 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", 282 | "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", 283 | "dev": true, 284 | "requires": { 285 | "eslint-visitor-keys": "^2.0.0" 286 | }, 287 | "dependencies": { 288 | "eslint-visitor-keys": { 289 | "version": "2.1.0", 290 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 291 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 292 | "dev": true 293 | } 294 | } 295 | }, 296 | "eslint-visitor-keys": { 297 | "version": "3.3.0", 298 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz", 299 | "integrity": "sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==", 300 | "dev": true 301 | }, 302 | "espree": { 303 | "version": "9.3.1", 304 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.3.1.tgz", 305 | "integrity": "sha512-bvdyLmJMfwkV3NCRl5ZhJf22zBFo1y8bYh3VYb+bfzqNB4Je68P2sSuXyuFquzWLebHpNd2/d5uv7yoP9ISnGQ==", 306 | "dev": true, 307 | "requires": { 308 | "acorn": "^8.7.0", 309 | "acorn-jsx": "^5.3.1", 310 | "eslint-visitor-keys": "^3.3.0" 311 | } 312 | }, 313 | "esquery": { 314 | "version": "1.4.0", 315 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 316 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 317 | "dev": true, 318 | "requires": { 319 | "estraverse": "^5.1.0" 320 | } 321 | }, 322 | "esrecurse": { 323 | "version": "4.3.0", 324 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 325 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 326 | "dev": true, 327 | "requires": { 328 | "estraverse": "^5.2.0" 329 | } 330 | }, 331 | "estraverse": { 332 | "version": "5.3.0", 333 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 334 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 335 | "dev": true 336 | }, 337 | "esutils": { 338 | "version": "2.0.3", 339 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 340 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 341 | "dev": true 342 | }, 343 | "events-to-array": { 344 | "version": "1.1.2", 345 | "resolved": "https://registry.npmjs.org/events-to-array/-/events-to-array-1.1.2.tgz", 346 | "integrity": "sha1-LUH1Y+H+QA7Uli/hpNXGp1Od9/Y=", 347 | "dev": true 348 | }, 349 | "fast-deep-equal": { 350 | "version": "3.1.3", 351 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 352 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 353 | "dev": true 354 | }, 355 | "fast-json-stable-stringify": { 356 | "version": "2.1.0", 357 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 358 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 359 | "dev": true 360 | }, 361 | "fast-levenshtein": { 362 | "version": "2.0.6", 363 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 364 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 365 | "dev": true 366 | }, 367 | "file-entry-cache": { 368 | "version": "6.0.1", 369 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 370 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 371 | "dev": true, 372 | "requires": { 373 | "flat-cache": "^3.0.4" 374 | } 375 | }, 376 | "find-up": { 377 | "version": "4.1.0", 378 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 379 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 380 | "dev": true, 381 | "requires": { 382 | "locate-path": "^5.0.0", 383 | "path-exists": "^4.0.0" 384 | } 385 | }, 386 | "flat-cache": { 387 | "version": "3.0.4", 388 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 389 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 390 | "dev": true, 391 | "requires": { 392 | "flatted": "^3.1.0", 393 | "rimraf": "^3.0.2" 394 | } 395 | }, 396 | "flatted": { 397 | "version": "3.2.5", 398 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.5.tgz", 399 | "integrity": "sha512-WIWGi2L3DyTUvUrwRKgGi9TwxQMUEqPOPQBVi71R96jZXJdFskXEmf54BoZaS1kknGODoIGASGEzBUYdyMCBJg==", 400 | "dev": true 401 | }, 402 | "fs.realpath": { 403 | "version": "1.0.0", 404 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 405 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 406 | "dev": true 407 | }, 408 | "functional-red-black-tree": { 409 | "version": "1.0.1", 410 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 411 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 412 | "dev": true 413 | }, 414 | "get-caller-file": { 415 | "version": "2.0.5", 416 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 417 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 418 | "dev": true 419 | }, 420 | "glob": { 421 | "version": "7.2.0", 422 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 423 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 424 | "dev": true, 425 | "requires": { 426 | "fs.realpath": "^1.0.0", 427 | "inflight": "^1.0.4", 428 | "inherits": "2", 429 | "minimatch": "^3.0.4", 430 | "once": "^1.3.0", 431 | "path-is-absolute": "^1.0.0" 432 | } 433 | }, 434 | "glob-parent": { 435 | "version": "6.0.2", 436 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 437 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 438 | "dev": true, 439 | "requires": { 440 | "is-glob": "^4.0.3" 441 | } 442 | }, 443 | "globals": { 444 | "version": "13.13.0", 445 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.13.0.tgz", 446 | "integrity": "sha512-EQ7Q18AJlPwp3vUDL4mKA0KXrXyNIQyWon6T6XQiBQF0XHvRsiCSrWmmeATpUzdJN2HhWZU6Pdl0a9zdep5p6A==", 447 | "dev": true, 448 | "requires": { 449 | "type-fest": "^0.20.2" 450 | } 451 | }, 452 | "has-flag": { 453 | "version": "4.0.0", 454 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 455 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 456 | "dev": true 457 | }, 458 | "ignore": { 459 | "version": "5.2.0", 460 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.0.tgz", 461 | "integrity": "sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ==", 462 | "dev": true 463 | }, 464 | "import-fresh": { 465 | "version": "3.3.0", 466 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 467 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 468 | "dev": true, 469 | "requires": { 470 | "parent-module": "^1.0.0", 471 | "resolve-from": "^4.0.0" 472 | } 473 | }, 474 | "imurmurhash": { 475 | "version": "0.1.4", 476 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 477 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 478 | "dev": true 479 | }, 480 | "inflight": { 481 | "version": "1.0.6", 482 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 483 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 484 | "dev": true, 485 | "requires": { 486 | "once": "^1.3.0", 487 | "wrappy": "1" 488 | } 489 | }, 490 | "inherits": { 491 | "version": "2.0.4", 492 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 493 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 494 | "dev": true 495 | }, 496 | "is-extglob": { 497 | "version": "2.1.1", 498 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 499 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 500 | "dev": true 501 | }, 502 | "is-fullwidth-code-point": { 503 | "version": "3.0.0", 504 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 505 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 506 | "dev": true 507 | }, 508 | "is-glob": { 509 | "version": "4.0.3", 510 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 511 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 512 | "dev": true, 513 | "requires": { 514 | "is-extglob": "^2.1.1" 515 | } 516 | }, 517 | "isexe": { 518 | "version": "2.0.0", 519 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 520 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 521 | "dev": true 522 | }, 523 | "js-yaml": { 524 | "version": "4.1.0", 525 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 526 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 527 | "dev": true, 528 | "requires": { 529 | "argparse": "^2.0.1" 530 | } 531 | }, 532 | "json-schema-traverse": { 533 | "version": "0.4.1", 534 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 535 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 536 | "dev": true 537 | }, 538 | "json-stable-stringify-without-jsonify": { 539 | "version": "1.0.1", 540 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 541 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 542 | "dev": true 543 | }, 544 | "levn": { 545 | "version": "0.4.1", 546 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 547 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 548 | "dev": true, 549 | "requires": { 550 | "prelude-ls": "^1.2.1", 551 | "type-check": "~0.4.0" 552 | } 553 | }, 554 | "locate-path": { 555 | "version": "5.0.0", 556 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 557 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 558 | "dev": true, 559 | "requires": { 560 | "p-locate": "^4.1.0" 561 | } 562 | }, 563 | "lodash.merge": { 564 | "version": "4.6.2", 565 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 566 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 567 | "dev": true 568 | }, 569 | "metasync": { 570 | "version": "0.3.32", 571 | "resolved": "https://registry.npmjs.org/metasync/-/metasync-0.3.32.tgz", 572 | "integrity": "sha512-E+NeMCXhp7oUtTipm2KM4Eq+Fp5ZK5AiezIt0FZX5Vu4mxcaexcmQZ6Z48j/w2SzVoLqX94vcwGXPqeV9r8APA==", 573 | "requires": { 574 | "@metarhia/common": "^2.1.0" 575 | } 576 | }, 577 | "metatests": { 578 | "version": "0.8.2", 579 | "resolved": "https://registry.npmjs.org/metatests/-/metatests-0.8.2.tgz", 580 | "integrity": "sha512-nGutK6VdLy2YD7N6TGsjof78tcemN9QURzAN2VaMp5qo3G8u/m+jpMxYl84SGrWpuyCTVy+CxmVBhVB+hBT3oQ==", 581 | "dev": true, 582 | "requires": { 583 | "@metarhia/common": "^2.2.0", 584 | "tap-mocha-reporter": "^5.0.3", 585 | "tap-yaml": "^1.0.0", 586 | "yaml": "^1.10.2", 587 | "yargs": "^15.4.1" 588 | } 589 | }, 590 | "minimatch": { 591 | "version": "3.1.2", 592 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 593 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 594 | "dev": true, 595 | "requires": { 596 | "brace-expansion": "^1.1.7" 597 | } 598 | }, 599 | "minipass": { 600 | "version": "3.1.6", 601 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.1.6.tgz", 602 | "integrity": "sha512-rty5kpw9/z8SX9dmxblFA6edItUmwJgMeYDZRrwlIVN27i8gysGbznJwUggw2V/FVqFSDdWy040ZPS811DYAqQ==", 603 | "dev": true, 604 | "requires": { 605 | "yallist": "^4.0.0" 606 | } 607 | }, 608 | "ms": { 609 | "version": "2.1.2", 610 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 611 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 612 | "dev": true 613 | }, 614 | "natural-compare": { 615 | "version": "1.4.0", 616 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 617 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 618 | "dev": true 619 | }, 620 | "once": { 621 | "version": "1.4.0", 622 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 623 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 624 | "dev": true, 625 | "requires": { 626 | "wrappy": "1" 627 | } 628 | }, 629 | "optionator": { 630 | "version": "0.9.1", 631 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 632 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 633 | "dev": true, 634 | "requires": { 635 | "deep-is": "^0.1.3", 636 | "fast-levenshtein": "^2.0.6", 637 | "levn": "^0.4.1", 638 | "prelude-ls": "^1.2.1", 639 | "type-check": "^0.4.0", 640 | "word-wrap": "^1.2.3" 641 | } 642 | }, 643 | "p-limit": { 644 | "version": "2.3.0", 645 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 646 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 647 | "dev": true, 648 | "requires": { 649 | "p-try": "^2.0.0" 650 | } 651 | }, 652 | "p-locate": { 653 | "version": "4.1.0", 654 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 655 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 656 | "dev": true, 657 | "requires": { 658 | "p-limit": "^2.2.0" 659 | } 660 | }, 661 | "p-try": { 662 | "version": "2.2.0", 663 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 664 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 665 | "dev": true 666 | }, 667 | "parent-module": { 668 | "version": "1.0.1", 669 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 670 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 671 | "dev": true, 672 | "requires": { 673 | "callsites": "^3.0.0" 674 | } 675 | }, 676 | "path-exists": { 677 | "version": "4.0.0", 678 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 679 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 680 | "dev": true 681 | }, 682 | "path-is-absolute": { 683 | "version": "1.0.1", 684 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 685 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 686 | "dev": true 687 | }, 688 | "path-key": { 689 | "version": "3.1.1", 690 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 691 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 692 | "dev": true 693 | }, 694 | "prelude-ls": { 695 | "version": "1.2.1", 696 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 697 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 698 | "dev": true 699 | }, 700 | "punycode": { 701 | "version": "2.1.1", 702 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 703 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 704 | "dev": true 705 | }, 706 | "regexpp": { 707 | "version": "3.2.0", 708 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 709 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 710 | "dev": true 711 | }, 712 | "require-directory": { 713 | "version": "2.1.1", 714 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 715 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 716 | "dev": true 717 | }, 718 | "require-main-filename": { 719 | "version": "2.0.0", 720 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 721 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 722 | "dev": true 723 | }, 724 | "resolve-from": { 725 | "version": "4.0.0", 726 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 727 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 728 | "dev": true 729 | }, 730 | "rimraf": { 731 | "version": "3.0.2", 732 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 733 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 734 | "dev": true, 735 | "requires": { 736 | "glob": "^7.1.3" 737 | } 738 | }, 739 | "set-blocking": { 740 | "version": "2.0.0", 741 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 742 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 743 | "dev": true 744 | }, 745 | "shebang-command": { 746 | "version": "2.0.0", 747 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 748 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 749 | "dev": true, 750 | "requires": { 751 | "shebang-regex": "^3.0.0" 752 | } 753 | }, 754 | "shebang-regex": { 755 | "version": "3.0.0", 756 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 757 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 758 | "dev": true 759 | }, 760 | "string-width": { 761 | "version": "4.2.3", 762 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 763 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 764 | "dev": true, 765 | "requires": { 766 | "emoji-regex": "^8.0.0", 767 | "is-fullwidth-code-point": "^3.0.0", 768 | "strip-ansi": "^6.0.1" 769 | } 770 | }, 771 | "strip-ansi": { 772 | "version": "6.0.1", 773 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 774 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 775 | "dev": true, 776 | "requires": { 777 | "ansi-regex": "^5.0.1" 778 | } 779 | }, 780 | "strip-json-comments": { 781 | "version": "3.1.1", 782 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 783 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 784 | "dev": true 785 | }, 786 | "supports-color": { 787 | "version": "7.2.0", 788 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 789 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 790 | "dev": true, 791 | "requires": { 792 | "has-flag": "^4.0.0" 793 | } 794 | }, 795 | "tap-mocha-reporter": { 796 | "version": "5.0.3", 797 | "resolved": "https://registry.npmjs.org/tap-mocha-reporter/-/tap-mocha-reporter-5.0.3.tgz", 798 | "integrity": "sha512-6zlGkaV4J+XMRFkN0X+yuw6xHbE9jyCZ3WUKfw4KxMyRGOpYSRuuQTRJyWX88WWuLdVTuFbxzwXhXuS2XE6o0g==", 799 | "dev": true, 800 | "requires": { 801 | "color-support": "^1.1.0", 802 | "debug": "^4.1.1", 803 | "diff": "^4.0.1", 804 | "escape-string-regexp": "^2.0.0", 805 | "glob": "^7.0.5", 806 | "tap-parser": "^11.0.0", 807 | "tap-yaml": "^1.0.0", 808 | "unicode-length": "^2.0.2" 809 | }, 810 | "dependencies": { 811 | "escape-string-regexp": { 812 | "version": "2.0.0", 813 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", 814 | "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", 815 | "dev": true 816 | } 817 | } 818 | }, 819 | "tap-parser": { 820 | "version": "11.0.1", 821 | "resolved": "https://registry.npmjs.org/tap-parser/-/tap-parser-11.0.1.tgz", 822 | "integrity": "sha512-5ow0oyFOnXVSALYdidMX94u0GEjIlgc/BPFYLx0yRh9hb8+cFGNJqJzDJlUqbLOwx8+NBrIbxCWkIQi7555c0w==", 823 | "dev": true, 824 | "requires": { 825 | "events-to-array": "^1.0.1", 826 | "minipass": "^3.1.6", 827 | "tap-yaml": "^1.0.0" 828 | } 829 | }, 830 | "tap-yaml": { 831 | "version": "1.0.0", 832 | "resolved": "https://registry.npmjs.org/tap-yaml/-/tap-yaml-1.0.0.tgz", 833 | "integrity": "sha512-Rxbx4EnrWkYk0/ztcm5u3/VznbyFJpyXO12dDBHKWiDVxy7O2Qw6MRrwO5H6Ww0U5YhRY/4C/VzWmFPhBQc4qQ==", 834 | "dev": true, 835 | "requires": { 836 | "yaml": "^1.5.0" 837 | } 838 | }, 839 | "text-table": { 840 | "version": "0.2.0", 841 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 842 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 843 | "dev": true 844 | }, 845 | "type-check": { 846 | "version": "0.4.0", 847 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 848 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 849 | "dev": true, 850 | "requires": { 851 | "prelude-ls": "^1.2.1" 852 | } 853 | }, 854 | "type-fest": { 855 | "version": "0.20.2", 856 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 857 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 858 | "dev": true 859 | }, 860 | "unicode-length": { 861 | "version": "2.0.2", 862 | "resolved": "https://registry.npmjs.org/unicode-length/-/unicode-length-2.0.2.tgz", 863 | "integrity": "sha512-Ph/j1VbS3/r77nhoY2WU0GWGjVYOHL3xpKp0y/Eq2e5r0mT/6b649vm7KFO6RdAdrZkYLdxphYVgvODxPB+Ebg==", 864 | "dev": true, 865 | "requires": { 866 | "punycode": "^2.0.0", 867 | "strip-ansi": "^3.0.1" 868 | }, 869 | "dependencies": { 870 | "ansi-regex": { 871 | "version": "2.1.1", 872 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 873 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 874 | "dev": true 875 | }, 876 | "strip-ansi": { 877 | "version": "3.0.1", 878 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 879 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 880 | "dev": true, 881 | "requires": { 882 | "ansi-regex": "^2.0.0" 883 | } 884 | } 885 | } 886 | }, 887 | "uri-js": { 888 | "version": "4.4.1", 889 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 890 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 891 | "dev": true, 892 | "requires": { 893 | "punycode": "^2.1.0" 894 | } 895 | }, 896 | "v8-compile-cache": { 897 | "version": "2.3.0", 898 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 899 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 900 | "dev": true 901 | }, 902 | "which": { 903 | "version": "2.0.2", 904 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 905 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 906 | "dev": true, 907 | "requires": { 908 | "isexe": "^2.0.0" 909 | } 910 | }, 911 | "which-module": { 912 | "version": "2.0.0", 913 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 914 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", 915 | "dev": true 916 | }, 917 | "word-wrap": { 918 | "version": "1.2.3", 919 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 920 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 921 | "dev": true 922 | }, 923 | "wrap-ansi": { 924 | "version": "6.2.0", 925 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", 926 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 927 | "dev": true, 928 | "requires": { 929 | "ansi-styles": "^4.0.0", 930 | "string-width": "^4.1.0", 931 | "strip-ansi": "^6.0.0" 932 | } 933 | }, 934 | "wrappy": { 935 | "version": "1.0.2", 936 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 937 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 938 | "dev": true 939 | }, 940 | "y18n": { 941 | "version": "4.0.3", 942 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.3.tgz", 943 | "integrity": "sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ==", 944 | "dev": true 945 | }, 946 | "yallist": { 947 | "version": "4.0.0", 948 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 949 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 950 | "dev": true 951 | }, 952 | "yaml": { 953 | "version": "1.10.2", 954 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz", 955 | "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==", 956 | "dev": true 957 | }, 958 | "yargs": { 959 | "version": "15.4.1", 960 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-15.4.1.tgz", 961 | "integrity": "sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A==", 962 | "dev": true, 963 | "requires": { 964 | "cliui": "^6.0.0", 965 | "decamelize": "^1.2.0", 966 | "find-up": "^4.1.0", 967 | "get-caller-file": "^2.0.1", 968 | "require-directory": "^2.1.1", 969 | "require-main-filename": "^2.0.0", 970 | "set-blocking": "^2.0.0", 971 | "string-width": "^4.2.0", 972 | "which-module": "^2.0.0", 973 | "y18n": "^4.0.0", 974 | "yargs-parser": "^18.1.2" 975 | } 976 | }, 977 | "yargs-parser": { 978 | "version": "18.1.3", 979 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.3.tgz", 980 | "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==", 981 | "dev": true, 982 | "requires": { 983 | "camelcase": "^5.0.0", 984 | "decamelize": "^1.2.0" 985 | } 986 | } 987 | } 988 | } 989 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "example", 3 | "version": "0.1.5", 4 | "description": "Example Node.js application", 5 | "main": "main.js", 6 | "scripts": { 7 | "lint": "eslint .", 8 | "test": "npm run lint && node test/all" 9 | }, 10 | "repository": { 11 | "type": "git", 12 | "url": "git+https://github.com/HowProgrammingWorks/Project.git" 13 | }, 14 | "author": "Timur Shemsedinov ", 15 | "license": "MIT", 16 | "bugs": { 17 | "url": "https://github.com/HowProgrammingWorks/Project/issues" 18 | }, 19 | "homepage": "https://github.com/HowProgrammingWorks/Project#readme", 20 | "dependencies": { 21 | "metasync": "^0.3.32" 22 | }, 23 | "devDependencies": { 24 | "eslint": "^8.12.0", 25 | "metatests": "^0.8.2" 26 | } 27 | } 28 | -------------------------------------------------------------------------------- /test/all.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | require('./names'); 4 | require('./submodules'); 5 | -------------------------------------------------------------------------------- /test/names.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const metatests = require('metatests'); 4 | const lib = require('..'); 5 | 6 | metatests.test('API exported count', test => { 7 | test.strictSame(Object.keys(lib).length, 7); 8 | test.end(); 9 | }); 10 | 11 | metatests.test('API exported types', test => { 12 | for (const key in lib) { 13 | const fn = lib[key]; 14 | test.strictSame(typeof fn, 'function'); 15 | } 16 | test.end(); 17 | }); 18 | -------------------------------------------------------------------------------- /test/submodules.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const metatests = require('metatests'); 4 | const lib = require('..'); 5 | 6 | metatests.test('submodules', test => { 7 | test.strictSame(lib.method11(), 11); 8 | test.strictSame(lib.method12(), 12); 9 | test.strictSame(lib.method21(), 21); 10 | test.strictSame(lib.method22(), 22); 11 | test.strictSame(lib.method23(), 23); 12 | test.strictSame(lib.method31(), 31); 13 | test.strictSame(lib.method32(), 32); 14 | test.end(); 15 | }); 16 | --------------------------------------------------------------------------------