├── .eslintrc.js ├── .gitignore ├── .vscode ├── launch.json ├── settings.json └── tasks.json ├── .vscodeignore ├── CHANGELOG.md ├── LICENSE ├── README.md ├── images ├── demo.gif ├── git-prefix-button.gif ├── icon.png ├── prefix-commit.svg └── prefix-commit_light.svg ├── package-lock.json ├── package.json ├── src ├── api │ └── git.d.ts ├── extension.ts └── test │ ├── runTest.ts │ └── suite │ ├── extension.test.ts │ └── index.ts ├── tsconfig.json └── vsc-extension-quickstart.md /.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { 3 | browser: true, 4 | es2021: true 5 | }, 6 | extends: [ 7 | 'eslint:recommended', 8 | 'plugin:@typescript-eslint/recommended' 9 | ], 10 | parser: '@typescript-eslint/parser', 11 | parserOptions: { 12 | ecmaVersion: 'latest', 13 | sourceType: 'module' 14 | }, 15 | plugins: [ 16 | '@typescript-eslint' 17 | ], 18 | rules: { 19 | } 20 | } 21 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | out 2 | node_modules 3 | .vscode-test/ 4 | *.vsix 5 | -------------------------------------------------------------------------------- /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | // A launch configuration that compiles the extension and then opens it inside a new window 2 | // Use IntelliSense to learn about possible attributes. 3 | // Hover to view descriptions of existing attributes. 4 | // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 5 | { 6 | "version": "0.2.0", 7 | "configurations": [{ 8 | "name": "Run Extension", 9 | "type": "extensionHost", 10 | "request": "launch", 11 | "runtimeExecutable": "${execPath}", 12 | "args": [ 13 | "--extensionDevelopmentPath=${workspaceFolder}" 14 | ], 15 | "outFiles": [ 16 | "${workspaceFolder}/out/**/*.js" 17 | ], 18 | "preLaunchTask": "npm: watch" 19 | }, 20 | { 21 | "name": "Extension Tests", 22 | "type": "extensionHost", 23 | "request": "launch", 24 | "runtimeExecutable": "${execPath}", 25 | "args": [ 26 | "--extensionDevelopmentPath=${workspaceFolder}", 27 | "--extensionTestsPath=${workspaceFolder}/out/test" 28 | ], 29 | "outFiles": [ 30 | "${workspaceFolder}/out/test/**/*.js" 31 | ], 32 | "preLaunchTask": "npm: watch" 33 | } 34 | ] 35 | } 36 | -------------------------------------------------------------------------------- /.vscode/settings.json: -------------------------------------------------------------------------------- 1 | // Place your settings in this file to overwrite default and user settings. 2 | { 3 | "files.exclude": { 4 | "out": false // set this to true to hide the "out" folder with the compiled JS files 5 | }, 6 | "search.exclude": { 7 | "out": true // set this to false to include "out" folder in search results 8 | }, 9 | // Turn off tsc task auto detection since we have the necessary tasks as npm scripts 10 | "typescript.tsc.autoDetect": "off", 11 | "editor.tabSize": 2, 12 | "editor.insertSpaces": true 13 | } -------------------------------------------------------------------------------- /.vscode/tasks.json: -------------------------------------------------------------------------------- 1 | // See https://go.microsoft.com/fwlink/?LinkId=733558 2 | // for the documentation about the tasks.json format 3 | { 4 | "version": "2.0.0", 5 | "tasks": [ 6 | { 7 | "type": "npm", 8 | "script": "watch", 9 | "problemMatcher": "$tsc-watch", 10 | "isBackground": true, 11 | "presentation": { 12 | "reveal": "never" 13 | }, 14 | "group": { 15 | "kind": "build", 16 | "isDefault": true 17 | } 18 | } 19 | ] 20 | } 21 | -------------------------------------------------------------------------------- /.vscodeignore: -------------------------------------------------------------------------------- 1 | .vscode/** 2 | .vscode-test/** 3 | out/test/** 4 | src/** 5 | .gitignore 6 | vsc-extension-quickstart.md 7 | **/tsconfig.json 8 | **/tslint.json 9 | **/*.map 10 | **/*.ts -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # Change Log 2 | 3 | All notable changes to the "git-prefix" extension will be documented in this file. 4 | 5 | ### 1.3.2 (2023-10-02) 6 | - Added folder and parentFolder replacement tokens. 7 | 8 | ### 1.3.1 (2022-12-10) 9 | - Fix finding rootUri when multiple repositories are open. 10 | 11 | ### 1.3.0 (2021-12-07) 12 | - Added Is Suffix setting to append to end of commit message 13 | 14 | ### 1.2.1 (2021-05-08) 15 | - Update dependencies 16 | 17 | ### 1.2.0 (2019-12-01) 18 | - Added option to use a function return expression in the replacment string for more complex cases. 19 | 20 | ### 1.1.0 (2019-05-23) 21 | - Added button to run Git Prefix Commit Message command against current repository 22 | 23 | ### 1.0.0 (2019-04-11) 24 | 25 | - Took out of Preview 26 | - Updated readme with demo 27 | 28 | ## 0.0.1 (2019-03-31) 29 | 30 | - Initial release -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2019 Samuel Meyers 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 | # Git Prefix 2 | 3 | ## New in 1.3.0 4 | Setting `Is Suffix` appends at end of commit message. 5 | 6 | ## Features 7 | Button to run `Git Prefix Commit Message` command: 8 | 9 | ![Use button](images/git-prefix-button.gif) 10 | 11 | Insert a value from the current branch name into the Source Control Git Message box. 12 | 13 | 14 | ![Demo Git Prefix](images/demo.gif) 15 | 16 | 17 | ## Usage 18 | 19 | - Open the Command Palette `Ctrl+Shift+P` (`Cmd+Shift+P` on macOS) 20 | - Type `Git Prefix Commit Message` and hit `return` 21 | - The matching branch pattern is prefixed in the Git Message box 22 | 23 | ## Extension Settings 24 | 25 | This extension contributes the following settings using JavaScript regular expression syntax: 26 | 27 | * `gitPrefix.pattern`: Regular expression pattern to match in the branch name. Default matches 28 | entire branch name. 29 | > Tip: Match a ticket in a branch created by Jira using a pattern such as: `.*(TEST-\d+).*` 30 | 31 | 32 | * `gitPrefix.isSuffix`: Suffix expression instead of prefixing it. Default is `false`. 33 | * `gitPrefix.patternIgnoreCase`: Ignore case in pattern. Default is `false`. 34 | * `gitPrefix.replacementIsFunction`: If true, the replacement string is a function return expression where parameters (p1, p2, p3, etc.) correspond to the matching patterns $1, $2, $3, etc.. Default is false. 35 | > Example : p1 + (p3 ? \`(${p2}): ${p4.replace(/-/g, ' ')}\` : p2.replace(/-/g, ' ')) 36 | * `gitPrefix.replacement`: Regular expression replacement string to place into commit message. Default is `"[$1] "`. 37 | 38 | ## Replacement Tokens 39 | 40 | There's a few replacement tokens the extension provides in order to let your messages be a little bit more fluid. 41 | 42 | * `$folder`: the folder name of the root of the repository that is currently active 43 | * `$parentFolder`: the folder name of the parent folder of the root of the repository that is currently active 44 | 45 | These can be used in the `gitPrefix.replacement` value. 46 | > Example : `"[$parentFolder/$folder/$1] "` 47 | 48 | **Happy Committing!** 49 | -------------------------------------------------------------------------------- /images/demo.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/srmeyers/git-prefix/a0a5f7eeb5ae3f1855776da3b5870c4baa357fe5/images/demo.gif -------------------------------------------------------------------------------- /images/git-prefix-button.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/srmeyers/git-prefix/a0a5f7eeb5ae3f1855776da3b5870c4baa357fe5/images/git-prefix-button.gif -------------------------------------------------------------------------------- /images/icon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/srmeyers/git-prefix/a0a5f7eeb5ae3f1855776da3b5870c4baa357fe5/images/icon.png -------------------------------------------------------------------------------- /images/prefix-commit.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /images/prefix-commit_light.svg: -------------------------------------------------------------------------------- 1 | 2 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "git-prefix", 3 | "version": "1.3.2", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "git-prefix", 9 | "version": "1.3.2", 10 | "license": "MIT", 11 | "devDependencies": { 12 | "@types/glob": "^7.1.3", 13 | "@types/mocha": "^8.2.2", 14 | "@types/node": "^15.0.2", 15 | "@types/vscode": "^1.32.0", 16 | "@typescript-eslint/eslint-plugin": "^6.7.4", 17 | "@typescript-eslint/parser": "^6.7.4", 18 | "@vscode/test-electron": "^1.6.2", 19 | "eslint": "^8.50.0", 20 | "glob": "^7.1.7", 21 | "typescript": "^4.8.4" 22 | }, 23 | "engines": { 24 | "vscode": "^1.32.0" 25 | } 26 | }, 27 | "node_modules/@aashutoshrathi/word-wrap": { 28 | "version": "1.2.6", 29 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", 30 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", 31 | "dev": true, 32 | "engines": { 33 | "node": ">=0.10.0" 34 | } 35 | }, 36 | "node_modules/@eslint-community/eslint-utils": { 37 | "version": "4.4.0", 38 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 39 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 40 | "dev": true, 41 | "dependencies": { 42 | "eslint-visitor-keys": "^3.3.0" 43 | }, 44 | "engines": { 45 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 46 | }, 47 | "peerDependencies": { 48 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 49 | } 50 | }, 51 | "node_modules/@eslint-community/regexpp": { 52 | "version": "4.9.1", 53 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.9.1.tgz", 54 | "integrity": "sha512-Y27x+MBLjXa+0JWDhykM3+JE+il3kHKAEqabfEWq3SDhZjLYb6/BHL/JKFnH3fe207JaXkyDo685Oc2Glt6ifA==", 55 | "dev": true, 56 | "engines": { 57 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 58 | } 59 | }, 60 | "node_modules/@eslint/eslintrc": { 61 | "version": "2.1.2", 62 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.2.tgz", 63 | "integrity": "sha512-+wvgpDsrB1YqAMdEUCcnTlpfVBH7Vqn6A/NT3D8WVXFIaKMlErPIZT3oCIAVCOtarRpMtelZLqJeU3t7WY6X6g==", 64 | "dev": true, 65 | "dependencies": { 66 | "ajv": "^6.12.4", 67 | "debug": "^4.3.2", 68 | "espree": "^9.6.0", 69 | "globals": "^13.19.0", 70 | "ignore": "^5.2.0", 71 | "import-fresh": "^3.2.1", 72 | "js-yaml": "^4.1.0", 73 | "minimatch": "^3.1.2", 74 | "strip-json-comments": "^3.1.1" 75 | }, 76 | "engines": { 77 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 78 | }, 79 | "funding": { 80 | "url": "https://opencollective.com/eslint" 81 | } 82 | }, 83 | "node_modules/@eslint/js": { 84 | "version": "8.50.0", 85 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.50.0.tgz", 86 | "integrity": "sha512-NCC3zz2+nvYd+Ckfh87rA47zfu2QsQpvc6k1yzTk+b9KzRj0wkGa8LSoGOXN6Zv4lRf/EIoZ80biDh9HOI+RNQ==", 87 | "dev": true, 88 | "engines": { 89 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 90 | } 91 | }, 92 | "node_modules/@humanwhocodes/config-array": { 93 | "version": "0.11.11", 94 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.11.tgz", 95 | "integrity": "sha512-N2brEuAadi0CcdeMXUkhbZB84eskAc8MEX1By6qEchoVywSgXPIjou4rYsl0V3Hj0ZnuGycGCjdNgockbzeWNA==", 96 | "dev": true, 97 | "dependencies": { 98 | "@humanwhocodes/object-schema": "^1.2.1", 99 | "debug": "^4.1.1", 100 | "minimatch": "^3.0.5" 101 | }, 102 | "engines": { 103 | "node": ">=10.10.0" 104 | } 105 | }, 106 | "node_modules/@humanwhocodes/module-importer": { 107 | "version": "1.0.1", 108 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 109 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 110 | "dev": true, 111 | "engines": { 112 | "node": ">=12.22" 113 | }, 114 | "funding": { 115 | "type": "github", 116 | "url": "https://github.com/sponsors/nzakas" 117 | } 118 | }, 119 | "node_modules/@humanwhocodes/object-schema": { 120 | "version": "1.2.1", 121 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 122 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 123 | "dev": true 124 | }, 125 | "node_modules/@nodelib/fs.scandir": { 126 | "version": "2.1.5", 127 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 128 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 129 | "dev": true, 130 | "dependencies": { 131 | "@nodelib/fs.stat": "2.0.5", 132 | "run-parallel": "^1.1.9" 133 | }, 134 | "engines": { 135 | "node": ">= 8" 136 | } 137 | }, 138 | "node_modules/@nodelib/fs.stat": { 139 | "version": "2.0.5", 140 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 141 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 142 | "dev": true, 143 | "engines": { 144 | "node": ">= 8" 145 | } 146 | }, 147 | "node_modules/@nodelib/fs.walk": { 148 | "version": "1.2.8", 149 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 150 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 151 | "dev": true, 152 | "dependencies": { 153 | "@nodelib/fs.scandir": "2.1.5", 154 | "fastq": "^1.6.0" 155 | }, 156 | "engines": { 157 | "node": ">= 8" 158 | } 159 | }, 160 | "node_modules/@tootallnate/once": { 161 | "version": "1.1.2", 162 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 163 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", 164 | "dev": true, 165 | "engines": { 166 | "node": ">= 6" 167 | } 168 | }, 169 | "node_modules/@types/glob": { 170 | "version": "7.2.0", 171 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.2.0.tgz", 172 | "integrity": "sha512-ZUxbzKl0IfJILTS6t7ip5fQQM/J3TJYubDm3nMbgubNNYS62eXeUpoLUC8/7fJNiFYHTrGPQn7hspDUzIHX3UA==", 173 | "dev": true, 174 | "dependencies": { 175 | "@types/minimatch": "*", 176 | "@types/node": "*" 177 | } 178 | }, 179 | "node_modules/@types/json-schema": { 180 | "version": "7.0.13", 181 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.13.tgz", 182 | "integrity": "sha512-RbSSoHliUbnXj3ny0CNFOoxrIDV6SUGyStHsvDqosw6CkdPV8TtWGlfecuK4ToyMEAql6pzNxgCFKanovUzlgQ==", 183 | "dev": true 184 | }, 185 | "node_modules/@types/minimatch": { 186 | "version": "5.1.2", 187 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-5.1.2.tgz", 188 | "integrity": "sha512-K0VQKziLUWkVKiRVrx4a40iPaxTUefQmjtkQofBkYRcoaaL/8rhwDWww9qWbrgicNOgnpIsMxyNIUM4+n6dUIA==", 189 | "dev": true 190 | }, 191 | "node_modules/@types/mocha": { 192 | "version": "8.2.3", 193 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-8.2.3.tgz", 194 | "integrity": "sha512-ekGvFhFgrc2zYQoX4JeZPmVzZxw6Dtllga7iGHzfbYIYkAMUx/sAFP2GdFpLff+vdHXu5fl7WX9AT+TtqYcsyw==", 195 | "dev": true 196 | }, 197 | "node_modules/@types/node": { 198 | "version": "15.14.9", 199 | "resolved": "https://registry.npmjs.org/@types/node/-/node-15.14.9.tgz", 200 | "integrity": "sha512-qjd88DrCxupx/kJD5yQgZdcYKZKSIGBVDIBE1/LTGcNm3d2Np/jxojkdePDdfnBHJc5W7vSMpbJ1aB7p/Py69A==", 201 | "dev": true 202 | }, 203 | "node_modules/@types/semver": { 204 | "version": "7.5.3", 205 | "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.3.tgz", 206 | "integrity": "sha512-OxepLK9EuNEIPxWNME+C6WwbRAOOI2o2BaQEGzz5Lu2e4Z5eDnEo+/aVEDMIXywoJitJ7xWd641wrGLZdtwRyw==", 207 | "dev": true 208 | }, 209 | "node_modules/@types/vscode": { 210 | "version": "1.74.0", 211 | "resolved": "https://registry.npmjs.org/@types/vscode/-/vscode-1.74.0.tgz", 212 | "integrity": "sha512-LyeCIU3jb9d38w0MXFwta9r0Jx23ugujkAxdwLTNCyspdZTKUc43t7ppPbCiPoQ/Ivd/pnDFZrb4hWd45wrsgA==", 213 | "dev": true 214 | }, 215 | "node_modules/@typescript-eslint/eslint-plugin": { 216 | "version": "6.7.4", 217 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.7.4.tgz", 218 | "integrity": "sha512-DAbgDXwtX+pDkAHwiGhqP3zWUGpW49B7eqmgpPtg+BKJXwdct79ut9+ifqOFPJGClGKSHXn2PTBatCnldJRUoA==", 219 | "dev": true, 220 | "dependencies": { 221 | "@eslint-community/regexpp": "^4.5.1", 222 | "@typescript-eslint/scope-manager": "6.7.4", 223 | "@typescript-eslint/type-utils": "6.7.4", 224 | "@typescript-eslint/utils": "6.7.4", 225 | "@typescript-eslint/visitor-keys": "6.7.4", 226 | "debug": "^4.3.4", 227 | "graphemer": "^1.4.0", 228 | "ignore": "^5.2.4", 229 | "natural-compare": "^1.4.0", 230 | "semver": "^7.5.4", 231 | "ts-api-utils": "^1.0.1" 232 | }, 233 | "engines": { 234 | "node": "^16.0.0 || >=18.0.0" 235 | }, 236 | "funding": { 237 | "type": "opencollective", 238 | "url": "https://opencollective.com/typescript-eslint" 239 | }, 240 | "peerDependencies": { 241 | "@typescript-eslint/parser": "^6.0.0 || ^6.0.0-alpha", 242 | "eslint": "^7.0.0 || ^8.0.0" 243 | }, 244 | "peerDependenciesMeta": { 245 | "typescript": { 246 | "optional": true 247 | } 248 | } 249 | }, 250 | "node_modules/@typescript-eslint/parser": { 251 | "version": "6.7.4", 252 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.7.4.tgz", 253 | "integrity": "sha512-I5zVZFY+cw4IMZUeNCU7Sh2PO5O57F7Lr0uyhgCJmhN/BuTlnc55KxPonR4+EM3GBdfiCyGZye6DgMjtubQkmA==", 254 | "dev": true, 255 | "dependencies": { 256 | "@typescript-eslint/scope-manager": "6.7.4", 257 | "@typescript-eslint/types": "6.7.4", 258 | "@typescript-eslint/typescript-estree": "6.7.4", 259 | "@typescript-eslint/visitor-keys": "6.7.4", 260 | "debug": "^4.3.4" 261 | }, 262 | "engines": { 263 | "node": "^16.0.0 || >=18.0.0" 264 | }, 265 | "funding": { 266 | "type": "opencollective", 267 | "url": "https://opencollective.com/typescript-eslint" 268 | }, 269 | "peerDependencies": { 270 | "eslint": "^7.0.0 || ^8.0.0" 271 | }, 272 | "peerDependenciesMeta": { 273 | "typescript": { 274 | "optional": true 275 | } 276 | } 277 | }, 278 | "node_modules/@typescript-eslint/scope-manager": { 279 | "version": "6.7.4", 280 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.7.4.tgz", 281 | "integrity": "sha512-SdGqSLUPTXAXi7c3Ob7peAGVnmMoGzZ361VswK2Mqf8UOYcODiYvs8rs5ILqEdfvX1lE7wEZbLyELCW+Yrql1A==", 282 | "dev": true, 283 | "dependencies": { 284 | "@typescript-eslint/types": "6.7.4", 285 | "@typescript-eslint/visitor-keys": "6.7.4" 286 | }, 287 | "engines": { 288 | "node": "^16.0.0 || >=18.0.0" 289 | }, 290 | "funding": { 291 | "type": "opencollective", 292 | "url": "https://opencollective.com/typescript-eslint" 293 | } 294 | }, 295 | "node_modules/@typescript-eslint/type-utils": { 296 | "version": "6.7.4", 297 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.7.4.tgz", 298 | "integrity": "sha512-n+g3zi1QzpcAdHFP9KQF+rEFxMb2KxtnJGID3teA/nxKHOVi3ylKovaqEzGBbVY2pBttU6z85gp0D00ufLzViQ==", 299 | "dev": true, 300 | "dependencies": { 301 | "@typescript-eslint/typescript-estree": "6.7.4", 302 | "@typescript-eslint/utils": "6.7.4", 303 | "debug": "^4.3.4", 304 | "ts-api-utils": "^1.0.1" 305 | }, 306 | "engines": { 307 | "node": "^16.0.0 || >=18.0.0" 308 | }, 309 | "funding": { 310 | "type": "opencollective", 311 | "url": "https://opencollective.com/typescript-eslint" 312 | }, 313 | "peerDependencies": { 314 | "eslint": "^7.0.0 || ^8.0.0" 315 | }, 316 | "peerDependenciesMeta": { 317 | "typescript": { 318 | "optional": true 319 | } 320 | } 321 | }, 322 | "node_modules/@typescript-eslint/types": { 323 | "version": "6.7.4", 324 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.7.4.tgz", 325 | "integrity": "sha512-o9XWK2FLW6eSS/0r/tgjAGsYasLAnOWg7hvZ/dGYSSNjCh+49k5ocPN8OmG5aZcSJ8pclSOyVKP2x03Sj+RrCA==", 326 | "dev": true, 327 | "engines": { 328 | "node": "^16.0.0 || >=18.0.0" 329 | }, 330 | "funding": { 331 | "type": "opencollective", 332 | "url": "https://opencollective.com/typescript-eslint" 333 | } 334 | }, 335 | "node_modules/@typescript-eslint/typescript-estree": { 336 | "version": "6.7.4", 337 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.7.4.tgz", 338 | "integrity": "sha512-ty8b5qHKatlNYd9vmpHooQz3Vki3gG+3PchmtsA4TgrZBKWHNjWfkQid7K7xQogBqqc7/BhGazxMD5vr6Ha+iQ==", 339 | "dev": true, 340 | "dependencies": { 341 | "@typescript-eslint/types": "6.7.4", 342 | "@typescript-eslint/visitor-keys": "6.7.4", 343 | "debug": "^4.3.4", 344 | "globby": "^11.1.0", 345 | "is-glob": "^4.0.3", 346 | "semver": "^7.5.4", 347 | "ts-api-utils": "^1.0.1" 348 | }, 349 | "engines": { 350 | "node": "^16.0.0 || >=18.0.0" 351 | }, 352 | "funding": { 353 | "type": "opencollective", 354 | "url": "https://opencollective.com/typescript-eslint" 355 | }, 356 | "peerDependenciesMeta": { 357 | "typescript": { 358 | "optional": true 359 | } 360 | } 361 | }, 362 | "node_modules/@typescript-eslint/utils": { 363 | "version": "6.7.4", 364 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.7.4.tgz", 365 | "integrity": "sha512-PRQAs+HUn85Qdk+khAxsVV+oULy3VkbH3hQ8hxLRJXWBEd7iI+GbQxH5SEUSH7kbEoTp6oT1bOwyga24ELALTA==", 366 | "dev": true, 367 | "dependencies": { 368 | "@eslint-community/eslint-utils": "^4.4.0", 369 | "@types/json-schema": "^7.0.12", 370 | "@types/semver": "^7.5.0", 371 | "@typescript-eslint/scope-manager": "6.7.4", 372 | "@typescript-eslint/types": "6.7.4", 373 | "@typescript-eslint/typescript-estree": "6.7.4", 374 | "semver": "^7.5.4" 375 | }, 376 | "engines": { 377 | "node": "^16.0.0 || >=18.0.0" 378 | }, 379 | "funding": { 380 | "type": "opencollective", 381 | "url": "https://opencollective.com/typescript-eslint" 382 | }, 383 | "peerDependencies": { 384 | "eslint": "^7.0.0 || ^8.0.0" 385 | } 386 | }, 387 | "node_modules/@typescript-eslint/visitor-keys": { 388 | "version": "6.7.4", 389 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.7.4.tgz", 390 | "integrity": "sha512-pOW37DUhlTZbvph50x5zZCkFn3xzwkGtNoJHzIM3svpiSkJzwOYr/kVBaXmf+RAQiUDs1AHEZVNPg6UJCJpwRA==", 391 | "dev": true, 392 | "dependencies": { 393 | "@typescript-eslint/types": "6.7.4", 394 | "eslint-visitor-keys": "^3.4.1" 395 | }, 396 | "engines": { 397 | "node": "^16.0.0 || >=18.0.0" 398 | }, 399 | "funding": { 400 | "type": "opencollective", 401 | "url": "https://opencollective.com/typescript-eslint" 402 | } 403 | }, 404 | "node_modules/@vscode/test-electron": { 405 | "version": "1.6.2", 406 | "resolved": "https://registry.npmjs.org/@vscode/test-electron/-/test-electron-1.6.2.tgz", 407 | "integrity": "sha512-W01ajJEMx6223Y7J5yaajGjVs1QfW3YGkkOJHVKfAMEqNB1ZHN9wCcViehv5ZwVSSJnjhu6lYEYgwBdHtCxqhQ==", 408 | "dev": true, 409 | "dependencies": { 410 | "http-proxy-agent": "^4.0.1", 411 | "https-proxy-agent": "^5.0.0", 412 | "rimraf": "^3.0.2", 413 | "unzipper": "^0.10.11" 414 | }, 415 | "engines": { 416 | "node": ">=8.9.3" 417 | } 418 | }, 419 | "node_modules/acorn": { 420 | "version": "8.10.0", 421 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.10.0.tgz", 422 | "integrity": "sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==", 423 | "dev": true, 424 | "bin": { 425 | "acorn": "bin/acorn" 426 | }, 427 | "engines": { 428 | "node": ">=0.4.0" 429 | } 430 | }, 431 | "node_modules/acorn-jsx": { 432 | "version": "5.3.2", 433 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 434 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 435 | "dev": true, 436 | "peerDependencies": { 437 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 438 | } 439 | }, 440 | "node_modules/agent-base": { 441 | "version": "6.0.2", 442 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 443 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 444 | "dev": true, 445 | "dependencies": { 446 | "debug": "4" 447 | }, 448 | "engines": { 449 | "node": ">= 6.0.0" 450 | } 451 | }, 452 | "node_modules/ajv": { 453 | "version": "6.12.6", 454 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 455 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 456 | "dev": true, 457 | "dependencies": { 458 | "fast-deep-equal": "^3.1.1", 459 | "fast-json-stable-stringify": "^2.0.0", 460 | "json-schema-traverse": "^0.4.1", 461 | "uri-js": "^4.2.2" 462 | }, 463 | "funding": { 464 | "type": "github", 465 | "url": "https://github.com/sponsors/epoberezkin" 466 | } 467 | }, 468 | "node_modules/ansi-regex": { 469 | "version": "5.0.1", 470 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 471 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 472 | "dev": true, 473 | "engines": { 474 | "node": ">=8" 475 | } 476 | }, 477 | "node_modules/ansi-styles": { 478 | "version": "4.3.0", 479 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 480 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 481 | "dev": true, 482 | "dependencies": { 483 | "color-convert": "^2.0.1" 484 | }, 485 | "engines": { 486 | "node": ">=8" 487 | }, 488 | "funding": { 489 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 490 | } 491 | }, 492 | "node_modules/argparse": { 493 | "version": "2.0.1", 494 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 495 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 496 | "dev": true 497 | }, 498 | "node_modules/array-union": { 499 | "version": "2.1.0", 500 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 501 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 502 | "dev": true, 503 | "engines": { 504 | "node": ">=8" 505 | } 506 | }, 507 | "node_modules/balanced-match": { 508 | "version": "1.0.2", 509 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 510 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 511 | "dev": true 512 | }, 513 | "node_modules/big-integer": { 514 | "version": "1.6.51", 515 | "resolved": "https://registry.npmjs.org/big-integer/-/big-integer-1.6.51.tgz", 516 | "integrity": "sha512-GPEid2Y9QU1Exl1rpO9B2IPJGHPSupF5GnVIP0blYvNOMer2bTvSWs1jGOUg04hTmu67nmLsQ9TBo1puaotBHg==", 517 | "dev": true, 518 | "engines": { 519 | "node": ">=0.6" 520 | } 521 | }, 522 | "node_modules/binary": { 523 | "version": "0.3.0", 524 | "resolved": "https://registry.npmjs.org/binary/-/binary-0.3.0.tgz", 525 | "integrity": "sha512-D4H1y5KYwpJgK8wk1Cue5LLPgmwHKYSChkbspQg5JtVuR5ulGckxfR62H3AE9UDkdMC8yyXlqYihuz3Aqg2XZg==", 526 | "dev": true, 527 | "dependencies": { 528 | "buffers": "~0.1.1", 529 | "chainsaw": "~0.1.0" 530 | }, 531 | "engines": { 532 | "node": "*" 533 | } 534 | }, 535 | "node_modules/bluebird": { 536 | "version": "3.4.7", 537 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.4.7.tgz", 538 | "integrity": "sha512-iD3898SR7sWVRHbiQv+sHUtHnMvC1o3nW5rAcqnq3uOn07DSAppZYUkIGslDz6gXC7HfunPe7YVBgoEJASPcHA==", 539 | "dev": true 540 | }, 541 | "node_modules/brace-expansion": { 542 | "version": "1.1.11", 543 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 544 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 545 | "dev": true, 546 | "dependencies": { 547 | "balanced-match": "^1.0.0", 548 | "concat-map": "0.0.1" 549 | } 550 | }, 551 | "node_modules/braces": { 552 | "version": "3.0.2", 553 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 554 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 555 | "dev": true, 556 | "dependencies": { 557 | "fill-range": "^7.0.1" 558 | }, 559 | "engines": { 560 | "node": ">=8" 561 | } 562 | }, 563 | "node_modules/buffer-indexof-polyfill": { 564 | "version": "1.0.2", 565 | "resolved": "https://registry.npmjs.org/buffer-indexof-polyfill/-/buffer-indexof-polyfill-1.0.2.tgz", 566 | "integrity": "sha512-I7wzHwA3t1/lwXQh+A5PbNvJxgfo5r3xulgpYDB5zckTu/Z9oUK9biouBKQUjEqzaz3HnAT6TYoovmE+GqSf7A==", 567 | "dev": true, 568 | "engines": { 569 | "node": ">=0.10" 570 | } 571 | }, 572 | "node_modules/buffers": { 573 | "version": "0.1.1", 574 | "resolved": "https://registry.npmjs.org/buffers/-/buffers-0.1.1.tgz", 575 | "integrity": "sha512-9q/rDEGSb/Qsvv2qvzIzdluL5k7AaJOTrw23z9reQthrbF7is4CtlT0DXyO1oei2DCp4uojjzQ7igaSHp1kAEQ==", 576 | "dev": true, 577 | "engines": { 578 | "node": ">=0.2.0" 579 | } 580 | }, 581 | "node_modules/callsites": { 582 | "version": "3.1.0", 583 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 584 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 585 | "dev": true, 586 | "engines": { 587 | "node": ">=6" 588 | } 589 | }, 590 | "node_modules/chainsaw": { 591 | "version": "0.1.0", 592 | "resolved": "https://registry.npmjs.org/chainsaw/-/chainsaw-0.1.0.tgz", 593 | "integrity": "sha512-75kWfWt6MEKNC8xYXIdRpDehRYY/tNSgwKaJq+dbbDcxORuVrrQ+SEHoWsniVn9XPYfP4gmdWIeDk/4YNp1rNQ==", 594 | "dev": true, 595 | "dependencies": { 596 | "traverse": ">=0.3.0 <0.4" 597 | }, 598 | "engines": { 599 | "node": "*" 600 | } 601 | }, 602 | "node_modules/chalk": { 603 | "version": "4.1.2", 604 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 605 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 606 | "dev": true, 607 | "dependencies": { 608 | "ansi-styles": "^4.1.0", 609 | "supports-color": "^7.1.0" 610 | }, 611 | "engines": { 612 | "node": ">=10" 613 | }, 614 | "funding": { 615 | "url": "https://github.com/chalk/chalk?sponsor=1" 616 | } 617 | }, 618 | "node_modules/color-convert": { 619 | "version": "2.0.1", 620 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 621 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 622 | "dev": true, 623 | "dependencies": { 624 | "color-name": "~1.1.4" 625 | }, 626 | "engines": { 627 | "node": ">=7.0.0" 628 | } 629 | }, 630 | "node_modules/color-name": { 631 | "version": "1.1.4", 632 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 633 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 634 | "dev": true 635 | }, 636 | "node_modules/concat-map": { 637 | "version": "0.0.1", 638 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 639 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 640 | "dev": true 641 | }, 642 | "node_modules/core-util-is": { 643 | "version": "1.0.3", 644 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", 645 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", 646 | "dev": true 647 | }, 648 | "node_modules/cross-spawn": { 649 | "version": "7.0.3", 650 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 651 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 652 | "dev": true, 653 | "dependencies": { 654 | "path-key": "^3.1.0", 655 | "shebang-command": "^2.0.0", 656 | "which": "^2.0.1" 657 | }, 658 | "engines": { 659 | "node": ">= 8" 660 | } 661 | }, 662 | "node_modules/debug": { 663 | "version": "4.3.4", 664 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 665 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 666 | "dev": true, 667 | "dependencies": { 668 | "ms": "2.1.2" 669 | }, 670 | "engines": { 671 | "node": ">=6.0" 672 | }, 673 | "peerDependenciesMeta": { 674 | "supports-color": { 675 | "optional": true 676 | } 677 | } 678 | }, 679 | "node_modules/deep-is": { 680 | "version": "0.1.4", 681 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 682 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 683 | "dev": true 684 | }, 685 | "node_modules/dir-glob": { 686 | "version": "3.0.1", 687 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 688 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 689 | "dev": true, 690 | "dependencies": { 691 | "path-type": "^4.0.0" 692 | }, 693 | "engines": { 694 | "node": ">=8" 695 | } 696 | }, 697 | "node_modules/doctrine": { 698 | "version": "3.0.0", 699 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 700 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 701 | "dev": true, 702 | "dependencies": { 703 | "esutils": "^2.0.2" 704 | }, 705 | "engines": { 706 | "node": ">=6.0.0" 707 | } 708 | }, 709 | "node_modules/duplexer2": { 710 | "version": "0.1.4", 711 | "resolved": "https://registry.npmjs.org/duplexer2/-/duplexer2-0.1.4.tgz", 712 | "integrity": "sha512-asLFVfWWtJ90ZyOUHMqk7/S2w2guQKxUI2itj3d92ADHhxUSbCMGi1f1cBcJ7xM1To+pE/Khbwo1yuNbMEPKeA==", 713 | "dev": true, 714 | "dependencies": { 715 | "readable-stream": "^2.0.2" 716 | } 717 | }, 718 | "node_modules/escape-string-regexp": { 719 | "version": "4.0.0", 720 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 721 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 722 | "dev": true, 723 | "engines": { 724 | "node": ">=10" 725 | }, 726 | "funding": { 727 | "url": "https://github.com/sponsors/sindresorhus" 728 | } 729 | }, 730 | "node_modules/eslint": { 731 | "version": "8.50.0", 732 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.50.0.tgz", 733 | "integrity": "sha512-FOnOGSuFuFLv/Sa+FDVRZl4GGVAAFFi8LecRsI5a1tMO5HIE8nCm4ivAlzt4dT3ol/PaaGC0rJEEXQmHJBGoOg==", 734 | "dev": true, 735 | "dependencies": { 736 | "@eslint-community/eslint-utils": "^4.2.0", 737 | "@eslint-community/regexpp": "^4.6.1", 738 | "@eslint/eslintrc": "^2.1.2", 739 | "@eslint/js": "8.50.0", 740 | "@humanwhocodes/config-array": "^0.11.11", 741 | "@humanwhocodes/module-importer": "^1.0.1", 742 | "@nodelib/fs.walk": "^1.2.8", 743 | "ajv": "^6.12.4", 744 | "chalk": "^4.0.0", 745 | "cross-spawn": "^7.0.2", 746 | "debug": "^4.3.2", 747 | "doctrine": "^3.0.0", 748 | "escape-string-regexp": "^4.0.0", 749 | "eslint-scope": "^7.2.2", 750 | "eslint-visitor-keys": "^3.4.3", 751 | "espree": "^9.6.1", 752 | "esquery": "^1.4.2", 753 | "esutils": "^2.0.2", 754 | "fast-deep-equal": "^3.1.3", 755 | "file-entry-cache": "^6.0.1", 756 | "find-up": "^5.0.0", 757 | "glob-parent": "^6.0.2", 758 | "globals": "^13.19.0", 759 | "graphemer": "^1.4.0", 760 | "ignore": "^5.2.0", 761 | "imurmurhash": "^0.1.4", 762 | "is-glob": "^4.0.0", 763 | "is-path-inside": "^3.0.3", 764 | "js-yaml": "^4.1.0", 765 | "json-stable-stringify-without-jsonify": "^1.0.1", 766 | "levn": "^0.4.1", 767 | "lodash.merge": "^4.6.2", 768 | "minimatch": "^3.1.2", 769 | "natural-compare": "^1.4.0", 770 | "optionator": "^0.9.3", 771 | "strip-ansi": "^6.0.1", 772 | "text-table": "^0.2.0" 773 | }, 774 | "bin": { 775 | "eslint": "bin/eslint.js" 776 | }, 777 | "engines": { 778 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 779 | }, 780 | "funding": { 781 | "url": "https://opencollective.com/eslint" 782 | } 783 | }, 784 | "node_modules/eslint-scope": { 785 | "version": "7.2.2", 786 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 787 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 788 | "dev": true, 789 | "dependencies": { 790 | "esrecurse": "^4.3.0", 791 | "estraverse": "^5.2.0" 792 | }, 793 | "engines": { 794 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 795 | }, 796 | "funding": { 797 | "url": "https://opencollective.com/eslint" 798 | } 799 | }, 800 | "node_modules/eslint-visitor-keys": { 801 | "version": "3.4.3", 802 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 803 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 804 | "dev": true, 805 | "engines": { 806 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 807 | }, 808 | "funding": { 809 | "url": "https://opencollective.com/eslint" 810 | } 811 | }, 812 | "node_modules/espree": { 813 | "version": "9.6.1", 814 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 815 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 816 | "dev": true, 817 | "dependencies": { 818 | "acorn": "^8.9.0", 819 | "acorn-jsx": "^5.3.2", 820 | "eslint-visitor-keys": "^3.4.1" 821 | }, 822 | "engines": { 823 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 824 | }, 825 | "funding": { 826 | "url": "https://opencollective.com/eslint" 827 | } 828 | }, 829 | "node_modules/esquery": { 830 | "version": "1.5.0", 831 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 832 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 833 | "dev": true, 834 | "dependencies": { 835 | "estraverse": "^5.1.0" 836 | }, 837 | "engines": { 838 | "node": ">=0.10" 839 | } 840 | }, 841 | "node_modules/esrecurse": { 842 | "version": "4.3.0", 843 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 844 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 845 | "dev": true, 846 | "dependencies": { 847 | "estraverse": "^5.2.0" 848 | }, 849 | "engines": { 850 | "node": ">=4.0" 851 | } 852 | }, 853 | "node_modules/estraverse": { 854 | "version": "5.3.0", 855 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 856 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 857 | "dev": true, 858 | "engines": { 859 | "node": ">=4.0" 860 | } 861 | }, 862 | "node_modules/esutils": { 863 | "version": "2.0.3", 864 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 865 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 866 | "dev": true, 867 | "engines": { 868 | "node": ">=0.10.0" 869 | } 870 | }, 871 | "node_modules/fast-deep-equal": { 872 | "version": "3.1.3", 873 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 874 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 875 | "dev": true 876 | }, 877 | "node_modules/fast-glob": { 878 | "version": "3.3.1", 879 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.1.tgz", 880 | "integrity": "sha512-kNFPyjhh5cKjrUltxs+wFx+ZkbRaxxmZ+X0ZU31SOsxCEtP9VPgtq2teZw1DebupL5GmDaNQ6yKMMVcM41iqDg==", 881 | "dev": true, 882 | "dependencies": { 883 | "@nodelib/fs.stat": "^2.0.2", 884 | "@nodelib/fs.walk": "^1.2.3", 885 | "glob-parent": "^5.1.2", 886 | "merge2": "^1.3.0", 887 | "micromatch": "^4.0.4" 888 | }, 889 | "engines": { 890 | "node": ">=8.6.0" 891 | } 892 | }, 893 | "node_modules/fast-glob/node_modules/glob-parent": { 894 | "version": "5.1.2", 895 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 896 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 897 | "dev": true, 898 | "dependencies": { 899 | "is-glob": "^4.0.1" 900 | }, 901 | "engines": { 902 | "node": ">= 6" 903 | } 904 | }, 905 | "node_modules/fast-json-stable-stringify": { 906 | "version": "2.1.0", 907 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 908 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 909 | "dev": true 910 | }, 911 | "node_modules/fast-levenshtein": { 912 | "version": "2.0.6", 913 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 914 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 915 | "dev": true 916 | }, 917 | "node_modules/fastq": { 918 | "version": "1.15.0", 919 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz", 920 | "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==", 921 | "dev": true, 922 | "dependencies": { 923 | "reusify": "^1.0.4" 924 | } 925 | }, 926 | "node_modules/file-entry-cache": { 927 | "version": "6.0.1", 928 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 929 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 930 | "dev": true, 931 | "dependencies": { 932 | "flat-cache": "^3.0.4" 933 | }, 934 | "engines": { 935 | "node": "^10.12.0 || >=12.0.0" 936 | } 937 | }, 938 | "node_modules/fill-range": { 939 | "version": "7.0.1", 940 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 941 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 942 | "dev": true, 943 | "dependencies": { 944 | "to-regex-range": "^5.0.1" 945 | }, 946 | "engines": { 947 | "node": ">=8" 948 | } 949 | }, 950 | "node_modules/find-up": { 951 | "version": "5.0.0", 952 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 953 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 954 | "dev": true, 955 | "dependencies": { 956 | "locate-path": "^6.0.0", 957 | "path-exists": "^4.0.0" 958 | }, 959 | "engines": { 960 | "node": ">=10" 961 | }, 962 | "funding": { 963 | "url": "https://github.com/sponsors/sindresorhus" 964 | } 965 | }, 966 | "node_modules/flat-cache": { 967 | "version": "3.1.0", 968 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.1.0.tgz", 969 | "integrity": "sha512-OHx4Qwrrt0E4jEIcI5/Xb+f+QmJYNj2rrK8wiIdQOIrB9WrrJL8cjZvXdXuBTkkEwEqLycb5BeZDV1o2i9bTew==", 970 | "dev": true, 971 | "dependencies": { 972 | "flatted": "^3.2.7", 973 | "keyv": "^4.5.3", 974 | "rimraf": "^3.0.2" 975 | }, 976 | "engines": { 977 | "node": ">=12.0.0" 978 | } 979 | }, 980 | "node_modules/flatted": { 981 | "version": "3.2.9", 982 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.9.tgz", 983 | "integrity": "sha512-36yxDn5H7OFZQla0/jFJmbIKTdZAQHngCedGxiMmpNfEZM0sdEeT+WczLQrjK6D7o2aiyLYDnkw0R3JK0Qv1RQ==", 984 | "dev": true 985 | }, 986 | "node_modules/fs.realpath": { 987 | "version": "1.0.0", 988 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 989 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 990 | "dev": true 991 | }, 992 | "node_modules/fstream": { 993 | "version": "1.0.12", 994 | "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.12.tgz", 995 | "integrity": "sha512-WvJ193OHa0GHPEL+AycEJgxvBEwyfRkN1vhjca23OaPVMCaLCXTd5qAu82AjTcgP1UJmytkOKb63Ypde7raDIg==", 996 | "dev": true, 997 | "dependencies": { 998 | "graceful-fs": "^4.1.2", 999 | "inherits": "~2.0.0", 1000 | "mkdirp": ">=0.5 0", 1001 | "rimraf": "2" 1002 | }, 1003 | "engines": { 1004 | "node": ">=0.6" 1005 | } 1006 | }, 1007 | "node_modules/fstream/node_modules/rimraf": { 1008 | "version": "2.7.1", 1009 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 1010 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 1011 | "dev": true, 1012 | "dependencies": { 1013 | "glob": "^7.1.3" 1014 | }, 1015 | "bin": { 1016 | "rimraf": "bin.js" 1017 | } 1018 | }, 1019 | "node_modules/glob": { 1020 | "version": "7.2.3", 1021 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 1022 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 1023 | "dev": true, 1024 | "dependencies": { 1025 | "fs.realpath": "^1.0.0", 1026 | "inflight": "^1.0.4", 1027 | "inherits": "2", 1028 | "minimatch": "^3.1.1", 1029 | "once": "^1.3.0", 1030 | "path-is-absolute": "^1.0.0" 1031 | }, 1032 | "engines": { 1033 | "node": "*" 1034 | }, 1035 | "funding": { 1036 | "url": "https://github.com/sponsors/isaacs" 1037 | } 1038 | }, 1039 | "node_modules/glob-parent": { 1040 | "version": "6.0.2", 1041 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 1042 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 1043 | "dev": true, 1044 | "dependencies": { 1045 | "is-glob": "^4.0.3" 1046 | }, 1047 | "engines": { 1048 | "node": ">=10.13.0" 1049 | } 1050 | }, 1051 | "node_modules/globals": { 1052 | "version": "13.22.0", 1053 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.22.0.tgz", 1054 | "integrity": "sha512-H1Ddc/PbZHTDVJSnj8kWptIRSD6AM3pK+mKytuIVF4uoBV7rshFlhhvA58ceJ5wp3Er58w6zj7bykMpYXt3ETw==", 1055 | "dev": true, 1056 | "dependencies": { 1057 | "type-fest": "^0.20.2" 1058 | }, 1059 | "engines": { 1060 | "node": ">=8" 1061 | }, 1062 | "funding": { 1063 | "url": "https://github.com/sponsors/sindresorhus" 1064 | } 1065 | }, 1066 | "node_modules/globby": { 1067 | "version": "11.1.0", 1068 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 1069 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 1070 | "dev": true, 1071 | "dependencies": { 1072 | "array-union": "^2.1.0", 1073 | "dir-glob": "^3.0.1", 1074 | "fast-glob": "^3.2.9", 1075 | "ignore": "^5.2.0", 1076 | "merge2": "^1.4.1", 1077 | "slash": "^3.0.0" 1078 | }, 1079 | "engines": { 1080 | "node": ">=10" 1081 | }, 1082 | "funding": { 1083 | "url": "https://github.com/sponsors/sindresorhus" 1084 | } 1085 | }, 1086 | "node_modules/graceful-fs": { 1087 | "version": "4.2.10", 1088 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", 1089 | "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==", 1090 | "dev": true 1091 | }, 1092 | "node_modules/graphemer": { 1093 | "version": "1.4.0", 1094 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 1095 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 1096 | "dev": true 1097 | }, 1098 | "node_modules/has-flag": { 1099 | "version": "4.0.0", 1100 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1101 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1102 | "dev": true, 1103 | "engines": { 1104 | "node": ">=8" 1105 | } 1106 | }, 1107 | "node_modules/http-proxy-agent": { 1108 | "version": "4.0.1", 1109 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 1110 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 1111 | "dev": true, 1112 | "dependencies": { 1113 | "@tootallnate/once": "1", 1114 | "agent-base": "6", 1115 | "debug": "4" 1116 | }, 1117 | "engines": { 1118 | "node": ">= 6" 1119 | } 1120 | }, 1121 | "node_modules/https-proxy-agent": { 1122 | "version": "5.0.1", 1123 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", 1124 | "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", 1125 | "dev": true, 1126 | "dependencies": { 1127 | "agent-base": "6", 1128 | "debug": "4" 1129 | }, 1130 | "engines": { 1131 | "node": ">= 6" 1132 | } 1133 | }, 1134 | "node_modules/ignore": { 1135 | "version": "5.2.4", 1136 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", 1137 | "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", 1138 | "dev": true, 1139 | "engines": { 1140 | "node": ">= 4" 1141 | } 1142 | }, 1143 | "node_modules/import-fresh": { 1144 | "version": "3.3.0", 1145 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1146 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1147 | "dev": true, 1148 | "dependencies": { 1149 | "parent-module": "^1.0.0", 1150 | "resolve-from": "^4.0.0" 1151 | }, 1152 | "engines": { 1153 | "node": ">=6" 1154 | }, 1155 | "funding": { 1156 | "url": "https://github.com/sponsors/sindresorhus" 1157 | } 1158 | }, 1159 | "node_modules/imurmurhash": { 1160 | "version": "0.1.4", 1161 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1162 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 1163 | "dev": true, 1164 | "engines": { 1165 | "node": ">=0.8.19" 1166 | } 1167 | }, 1168 | "node_modules/inflight": { 1169 | "version": "1.0.6", 1170 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1171 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1172 | "dev": true, 1173 | "dependencies": { 1174 | "once": "^1.3.0", 1175 | "wrappy": "1" 1176 | } 1177 | }, 1178 | "node_modules/inherits": { 1179 | "version": "2.0.4", 1180 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1181 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1182 | "dev": true 1183 | }, 1184 | "node_modules/is-extglob": { 1185 | "version": "2.1.1", 1186 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1187 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1188 | "dev": true, 1189 | "engines": { 1190 | "node": ">=0.10.0" 1191 | } 1192 | }, 1193 | "node_modules/is-glob": { 1194 | "version": "4.0.3", 1195 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1196 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1197 | "dev": true, 1198 | "dependencies": { 1199 | "is-extglob": "^2.1.1" 1200 | }, 1201 | "engines": { 1202 | "node": ">=0.10.0" 1203 | } 1204 | }, 1205 | "node_modules/is-number": { 1206 | "version": "7.0.0", 1207 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1208 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1209 | "dev": true, 1210 | "engines": { 1211 | "node": ">=0.12.0" 1212 | } 1213 | }, 1214 | "node_modules/is-path-inside": { 1215 | "version": "3.0.3", 1216 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 1217 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 1218 | "dev": true, 1219 | "engines": { 1220 | "node": ">=8" 1221 | } 1222 | }, 1223 | "node_modules/isarray": { 1224 | "version": "1.0.0", 1225 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1226 | "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==", 1227 | "dev": true 1228 | }, 1229 | "node_modules/isexe": { 1230 | "version": "2.0.0", 1231 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1232 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 1233 | "dev": true 1234 | }, 1235 | "node_modules/js-yaml": { 1236 | "version": "4.1.0", 1237 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1238 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1239 | "dev": true, 1240 | "dependencies": { 1241 | "argparse": "^2.0.1" 1242 | }, 1243 | "bin": { 1244 | "js-yaml": "bin/js-yaml.js" 1245 | } 1246 | }, 1247 | "node_modules/json-buffer": { 1248 | "version": "3.0.1", 1249 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 1250 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 1251 | "dev": true 1252 | }, 1253 | "node_modules/json-schema-traverse": { 1254 | "version": "0.4.1", 1255 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1256 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1257 | "dev": true 1258 | }, 1259 | "node_modules/json-stable-stringify-without-jsonify": { 1260 | "version": "1.0.1", 1261 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1262 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 1263 | "dev": true 1264 | }, 1265 | "node_modules/keyv": { 1266 | "version": "4.5.3", 1267 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.3.tgz", 1268 | "integrity": "sha512-QCiSav9WaX1PgETJ+SpNnx2PRRapJ/oRSXM4VO5OGYGSjrxbKPVFVhB3l2OCbLCk329N8qyAtsJjSjvVBWzEug==", 1269 | "dev": true, 1270 | "dependencies": { 1271 | "json-buffer": "3.0.1" 1272 | } 1273 | }, 1274 | "node_modules/levn": { 1275 | "version": "0.4.1", 1276 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1277 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1278 | "dev": true, 1279 | "dependencies": { 1280 | "prelude-ls": "^1.2.1", 1281 | "type-check": "~0.4.0" 1282 | }, 1283 | "engines": { 1284 | "node": ">= 0.8.0" 1285 | } 1286 | }, 1287 | "node_modules/listenercount": { 1288 | "version": "1.0.1", 1289 | "resolved": "https://registry.npmjs.org/listenercount/-/listenercount-1.0.1.tgz", 1290 | "integrity": "sha512-3mk/Zag0+IJxeDrxSgaDPy4zZ3w05PRZeJNnlWhzFz5OkX49J4krc+A8X2d2M69vGMBEX0uyl8M+W+8gH+kBqQ==", 1291 | "dev": true 1292 | }, 1293 | "node_modules/locate-path": { 1294 | "version": "6.0.0", 1295 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1296 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1297 | "dev": true, 1298 | "dependencies": { 1299 | "p-locate": "^5.0.0" 1300 | }, 1301 | "engines": { 1302 | "node": ">=10" 1303 | }, 1304 | "funding": { 1305 | "url": "https://github.com/sponsors/sindresorhus" 1306 | } 1307 | }, 1308 | "node_modules/lodash.merge": { 1309 | "version": "4.6.2", 1310 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1311 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1312 | "dev": true 1313 | }, 1314 | "node_modules/lru-cache": { 1315 | "version": "6.0.0", 1316 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1317 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1318 | "dev": true, 1319 | "dependencies": { 1320 | "yallist": "^4.0.0" 1321 | }, 1322 | "engines": { 1323 | "node": ">=10" 1324 | } 1325 | }, 1326 | "node_modules/merge2": { 1327 | "version": "1.4.1", 1328 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 1329 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 1330 | "dev": true, 1331 | "engines": { 1332 | "node": ">= 8" 1333 | } 1334 | }, 1335 | "node_modules/micromatch": { 1336 | "version": "4.0.5", 1337 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 1338 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 1339 | "dev": true, 1340 | "dependencies": { 1341 | "braces": "^3.0.2", 1342 | "picomatch": "^2.3.1" 1343 | }, 1344 | "engines": { 1345 | "node": ">=8.6" 1346 | } 1347 | }, 1348 | "node_modules/minimatch": { 1349 | "version": "3.1.2", 1350 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1351 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1352 | "dev": true, 1353 | "dependencies": { 1354 | "brace-expansion": "^1.1.7" 1355 | }, 1356 | "engines": { 1357 | "node": "*" 1358 | } 1359 | }, 1360 | "node_modules/minimist": { 1361 | "version": "1.2.7", 1362 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.7.tgz", 1363 | "integrity": "sha512-bzfL1YUZsP41gmu/qjrEk0Q6i2ix/cVeAhbCbqH9u3zYutS1cLg00qhrD0M2MVdCcx4Sc0UpP2eBWo9rotpq6g==", 1364 | "dev": true, 1365 | "funding": { 1366 | "url": "https://github.com/sponsors/ljharb" 1367 | } 1368 | }, 1369 | "node_modules/mkdirp": { 1370 | "version": "0.5.6", 1371 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", 1372 | "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", 1373 | "dev": true, 1374 | "dependencies": { 1375 | "minimist": "^1.2.6" 1376 | }, 1377 | "bin": { 1378 | "mkdirp": "bin/cmd.js" 1379 | } 1380 | }, 1381 | "node_modules/ms": { 1382 | "version": "2.1.2", 1383 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1384 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1385 | "dev": true 1386 | }, 1387 | "node_modules/natural-compare": { 1388 | "version": "1.4.0", 1389 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1390 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 1391 | "dev": true 1392 | }, 1393 | "node_modules/once": { 1394 | "version": "1.4.0", 1395 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1396 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1397 | "dev": true, 1398 | "dependencies": { 1399 | "wrappy": "1" 1400 | } 1401 | }, 1402 | "node_modules/optionator": { 1403 | "version": "0.9.3", 1404 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", 1405 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", 1406 | "dev": true, 1407 | "dependencies": { 1408 | "@aashutoshrathi/word-wrap": "^1.2.3", 1409 | "deep-is": "^0.1.3", 1410 | "fast-levenshtein": "^2.0.6", 1411 | "levn": "^0.4.1", 1412 | "prelude-ls": "^1.2.1", 1413 | "type-check": "^0.4.0" 1414 | }, 1415 | "engines": { 1416 | "node": ">= 0.8.0" 1417 | } 1418 | }, 1419 | "node_modules/p-limit": { 1420 | "version": "3.1.0", 1421 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1422 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1423 | "dev": true, 1424 | "dependencies": { 1425 | "yocto-queue": "^0.1.0" 1426 | }, 1427 | "engines": { 1428 | "node": ">=10" 1429 | }, 1430 | "funding": { 1431 | "url": "https://github.com/sponsors/sindresorhus" 1432 | } 1433 | }, 1434 | "node_modules/p-locate": { 1435 | "version": "5.0.0", 1436 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1437 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1438 | "dev": true, 1439 | "dependencies": { 1440 | "p-limit": "^3.0.2" 1441 | }, 1442 | "engines": { 1443 | "node": ">=10" 1444 | }, 1445 | "funding": { 1446 | "url": "https://github.com/sponsors/sindresorhus" 1447 | } 1448 | }, 1449 | "node_modules/parent-module": { 1450 | "version": "1.0.1", 1451 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1452 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1453 | "dev": true, 1454 | "dependencies": { 1455 | "callsites": "^3.0.0" 1456 | }, 1457 | "engines": { 1458 | "node": ">=6" 1459 | } 1460 | }, 1461 | "node_modules/path-exists": { 1462 | "version": "4.0.0", 1463 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1464 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1465 | "dev": true, 1466 | "engines": { 1467 | "node": ">=8" 1468 | } 1469 | }, 1470 | "node_modules/path-is-absolute": { 1471 | "version": "1.0.1", 1472 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1473 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1474 | "dev": true, 1475 | "engines": { 1476 | "node": ">=0.10.0" 1477 | } 1478 | }, 1479 | "node_modules/path-key": { 1480 | "version": "3.1.1", 1481 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1482 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1483 | "dev": true, 1484 | "engines": { 1485 | "node": ">=8" 1486 | } 1487 | }, 1488 | "node_modules/path-type": { 1489 | "version": "4.0.0", 1490 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 1491 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 1492 | "dev": true, 1493 | "engines": { 1494 | "node": ">=8" 1495 | } 1496 | }, 1497 | "node_modules/picomatch": { 1498 | "version": "2.3.1", 1499 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1500 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1501 | "dev": true, 1502 | "engines": { 1503 | "node": ">=8.6" 1504 | }, 1505 | "funding": { 1506 | "url": "https://github.com/sponsors/jonschlinkert" 1507 | } 1508 | }, 1509 | "node_modules/prelude-ls": { 1510 | "version": "1.2.1", 1511 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1512 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1513 | "dev": true, 1514 | "engines": { 1515 | "node": ">= 0.8.0" 1516 | } 1517 | }, 1518 | "node_modules/process-nextick-args": { 1519 | "version": "2.0.1", 1520 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 1521 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 1522 | "dev": true 1523 | }, 1524 | "node_modules/punycode": { 1525 | "version": "2.3.0", 1526 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", 1527 | "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==", 1528 | "dev": true, 1529 | "engines": { 1530 | "node": ">=6" 1531 | } 1532 | }, 1533 | "node_modules/queue-microtask": { 1534 | "version": "1.2.3", 1535 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 1536 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 1537 | "dev": true, 1538 | "funding": [ 1539 | { 1540 | "type": "github", 1541 | "url": "https://github.com/sponsors/feross" 1542 | }, 1543 | { 1544 | "type": "patreon", 1545 | "url": "https://www.patreon.com/feross" 1546 | }, 1547 | { 1548 | "type": "consulting", 1549 | "url": "https://feross.org/support" 1550 | } 1551 | ] 1552 | }, 1553 | "node_modules/readable-stream": { 1554 | "version": "2.3.7", 1555 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 1556 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 1557 | "dev": true, 1558 | "dependencies": { 1559 | "core-util-is": "~1.0.0", 1560 | "inherits": "~2.0.3", 1561 | "isarray": "~1.0.0", 1562 | "process-nextick-args": "~2.0.0", 1563 | "safe-buffer": "~5.1.1", 1564 | "string_decoder": "~1.1.1", 1565 | "util-deprecate": "~1.0.1" 1566 | } 1567 | }, 1568 | "node_modules/resolve-from": { 1569 | "version": "4.0.0", 1570 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1571 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1572 | "dev": true, 1573 | "engines": { 1574 | "node": ">=4" 1575 | } 1576 | }, 1577 | "node_modules/reusify": { 1578 | "version": "1.0.4", 1579 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 1580 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 1581 | "dev": true, 1582 | "engines": { 1583 | "iojs": ">=1.0.0", 1584 | "node": ">=0.10.0" 1585 | } 1586 | }, 1587 | "node_modules/rimraf": { 1588 | "version": "3.0.2", 1589 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1590 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1591 | "dev": true, 1592 | "dependencies": { 1593 | "glob": "^7.1.3" 1594 | }, 1595 | "bin": { 1596 | "rimraf": "bin.js" 1597 | }, 1598 | "funding": { 1599 | "url": "https://github.com/sponsors/isaacs" 1600 | } 1601 | }, 1602 | "node_modules/run-parallel": { 1603 | "version": "1.2.0", 1604 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 1605 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 1606 | "dev": true, 1607 | "funding": [ 1608 | { 1609 | "type": "github", 1610 | "url": "https://github.com/sponsors/feross" 1611 | }, 1612 | { 1613 | "type": "patreon", 1614 | "url": "https://www.patreon.com/feross" 1615 | }, 1616 | { 1617 | "type": "consulting", 1618 | "url": "https://feross.org/support" 1619 | } 1620 | ], 1621 | "dependencies": { 1622 | "queue-microtask": "^1.2.2" 1623 | } 1624 | }, 1625 | "node_modules/safe-buffer": { 1626 | "version": "5.1.2", 1627 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1628 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1629 | "dev": true 1630 | }, 1631 | "node_modules/semver": { 1632 | "version": "7.5.4", 1633 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", 1634 | "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", 1635 | "dev": true, 1636 | "dependencies": { 1637 | "lru-cache": "^6.0.0" 1638 | }, 1639 | "bin": { 1640 | "semver": "bin/semver.js" 1641 | }, 1642 | "engines": { 1643 | "node": ">=10" 1644 | } 1645 | }, 1646 | "node_modules/setimmediate": { 1647 | "version": "1.0.5", 1648 | "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", 1649 | "integrity": "sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA==", 1650 | "dev": true 1651 | }, 1652 | "node_modules/shebang-command": { 1653 | "version": "2.0.0", 1654 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1655 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1656 | "dev": true, 1657 | "dependencies": { 1658 | "shebang-regex": "^3.0.0" 1659 | }, 1660 | "engines": { 1661 | "node": ">=8" 1662 | } 1663 | }, 1664 | "node_modules/shebang-regex": { 1665 | "version": "3.0.0", 1666 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1667 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1668 | "dev": true, 1669 | "engines": { 1670 | "node": ">=8" 1671 | } 1672 | }, 1673 | "node_modules/slash": { 1674 | "version": "3.0.0", 1675 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 1676 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 1677 | "dev": true, 1678 | "engines": { 1679 | "node": ">=8" 1680 | } 1681 | }, 1682 | "node_modules/string_decoder": { 1683 | "version": "1.1.1", 1684 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 1685 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1686 | "dev": true, 1687 | "dependencies": { 1688 | "safe-buffer": "~5.1.0" 1689 | } 1690 | }, 1691 | "node_modules/strip-ansi": { 1692 | "version": "6.0.1", 1693 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1694 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1695 | "dev": true, 1696 | "dependencies": { 1697 | "ansi-regex": "^5.0.1" 1698 | }, 1699 | "engines": { 1700 | "node": ">=8" 1701 | } 1702 | }, 1703 | "node_modules/strip-json-comments": { 1704 | "version": "3.1.1", 1705 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1706 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1707 | "dev": true, 1708 | "engines": { 1709 | "node": ">=8" 1710 | }, 1711 | "funding": { 1712 | "url": "https://github.com/sponsors/sindresorhus" 1713 | } 1714 | }, 1715 | "node_modules/supports-color": { 1716 | "version": "7.2.0", 1717 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1718 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1719 | "dev": true, 1720 | "dependencies": { 1721 | "has-flag": "^4.0.0" 1722 | }, 1723 | "engines": { 1724 | "node": ">=8" 1725 | } 1726 | }, 1727 | "node_modules/text-table": { 1728 | "version": "0.2.0", 1729 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1730 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 1731 | "dev": true 1732 | }, 1733 | "node_modules/to-regex-range": { 1734 | "version": "5.0.1", 1735 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1736 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1737 | "dev": true, 1738 | "dependencies": { 1739 | "is-number": "^7.0.0" 1740 | }, 1741 | "engines": { 1742 | "node": ">=8.0" 1743 | } 1744 | }, 1745 | "node_modules/traverse": { 1746 | "version": "0.3.9", 1747 | "resolved": "https://registry.npmjs.org/traverse/-/traverse-0.3.9.tgz", 1748 | "integrity": "sha512-iawgk0hLP3SxGKDfnDJf8wTz4p2qImnyihM5Hh/sGvQ3K37dPi/w8sRhdNIxYA1TwFwc5mDhIJq+O0RsvXBKdQ==", 1749 | "dev": true, 1750 | "engines": { 1751 | "node": "*" 1752 | } 1753 | }, 1754 | "node_modules/ts-api-utils": { 1755 | "version": "1.0.3", 1756 | "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.0.3.tgz", 1757 | "integrity": "sha512-wNMeqtMz5NtwpT/UZGY5alT+VoKdSsOOP/kqHFcUW1P/VRhH2wJ48+DN2WwUliNbQ976ETwDL0Ifd2VVvgonvg==", 1758 | "dev": true, 1759 | "engines": { 1760 | "node": ">=16.13.0" 1761 | }, 1762 | "peerDependencies": { 1763 | "typescript": ">=4.2.0" 1764 | } 1765 | }, 1766 | "node_modules/type-check": { 1767 | "version": "0.4.0", 1768 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1769 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1770 | "dev": true, 1771 | "dependencies": { 1772 | "prelude-ls": "^1.2.1" 1773 | }, 1774 | "engines": { 1775 | "node": ">= 0.8.0" 1776 | } 1777 | }, 1778 | "node_modules/type-fest": { 1779 | "version": "0.20.2", 1780 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1781 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 1782 | "dev": true, 1783 | "engines": { 1784 | "node": ">=10" 1785 | }, 1786 | "funding": { 1787 | "url": "https://github.com/sponsors/sindresorhus" 1788 | } 1789 | }, 1790 | "node_modules/typescript": { 1791 | "version": "4.9.4", 1792 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.4.tgz", 1793 | "integrity": "sha512-Uz+dTXYzxXXbsFpM86Wh3dKCxrQqUcVMxwU54orwlJjOpO3ao8L7j5lH+dWfTwgCwIuM9GQ2kvVotzYJMXTBZg==", 1794 | "dev": true, 1795 | "bin": { 1796 | "tsc": "bin/tsc", 1797 | "tsserver": "bin/tsserver" 1798 | }, 1799 | "engines": { 1800 | "node": ">=4.2.0" 1801 | } 1802 | }, 1803 | "node_modules/unzipper": { 1804 | "version": "0.10.11", 1805 | "resolved": "https://registry.npmjs.org/unzipper/-/unzipper-0.10.11.tgz", 1806 | "integrity": "sha512-+BrAq2oFqWod5IESRjL3S8baohbevGcVA+teAIOYWM3pDVdseogqbzhhvvmiyQrUNKFUnDMtELW3X8ykbyDCJw==", 1807 | "dev": true, 1808 | "dependencies": { 1809 | "big-integer": "^1.6.17", 1810 | "binary": "~0.3.0", 1811 | "bluebird": "~3.4.1", 1812 | "buffer-indexof-polyfill": "~1.0.0", 1813 | "duplexer2": "~0.1.4", 1814 | "fstream": "^1.0.12", 1815 | "graceful-fs": "^4.2.2", 1816 | "listenercount": "~1.0.1", 1817 | "readable-stream": "~2.3.6", 1818 | "setimmediate": "~1.0.4" 1819 | } 1820 | }, 1821 | "node_modules/uri-js": { 1822 | "version": "4.4.1", 1823 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1824 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1825 | "dev": true, 1826 | "dependencies": { 1827 | "punycode": "^2.1.0" 1828 | } 1829 | }, 1830 | "node_modules/util-deprecate": { 1831 | "version": "1.0.2", 1832 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1833 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", 1834 | "dev": true 1835 | }, 1836 | "node_modules/which": { 1837 | "version": "2.0.2", 1838 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1839 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1840 | "dev": true, 1841 | "dependencies": { 1842 | "isexe": "^2.0.0" 1843 | }, 1844 | "bin": { 1845 | "node-which": "bin/node-which" 1846 | }, 1847 | "engines": { 1848 | "node": ">= 8" 1849 | } 1850 | }, 1851 | "node_modules/wrappy": { 1852 | "version": "1.0.2", 1853 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1854 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 1855 | "dev": true 1856 | }, 1857 | "node_modules/yallist": { 1858 | "version": "4.0.0", 1859 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1860 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1861 | "dev": true 1862 | }, 1863 | "node_modules/yocto-queue": { 1864 | "version": "0.1.0", 1865 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1866 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1867 | "dev": true, 1868 | "engines": { 1869 | "node": ">=10" 1870 | }, 1871 | "funding": { 1872 | "url": "https://github.com/sponsors/sindresorhus" 1873 | } 1874 | } 1875 | }, 1876 | "dependencies": { 1877 | "@aashutoshrathi/word-wrap": { 1878 | "version": "1.2.6", 1879 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", 1880 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", 1881 | "dev": true 1882 | }, 1883 | "@eslint-community/eslint-utils": { 1884 | "version": "4.4.0", 1885 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 1886 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 1887 | "dev": true, 1888 | "requires": { 1889 | "eslint-visitor-keys": "^3.3.0" 1890 | } 1891 | }, 1892 | "@eslint-community/regexpp": { 1893 | "version": "4.9.1", 1894 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.9.1.tgz", 1895 | "integrity": "sha512-Y27x+MBLjXa+0JWDhykM3+JE+il3kHKAEqabfEWq3SDhZjLYb6/BHL/JKFnH3fe207JaXkyDo685Oc2Glt6ifA==", 1896 | "dev": true 1897 | }, 1898 | "@eslint/eslintrc": { 1899 | "version": "2.1.2", 1900 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.2.tgz", 1901 | "integrity": "sha512-+wvgpDsrB1YqAMdEUCcnTlpfVBH7Vqn6A/NT3D8WVXFIaKMlErPIZT3oCIAVCOtarRpMtelZLqJeU3t7WY6X6g==", 1902 | "dev": true, 1903 | "requires": { 1904 | "ajv": "^6.12.4", 1905 | "debug": "^4.3.2", 1906 | "espree": "^9.6.0", 1907 | "globals": "^13.19.0", 1908 | "ignore": "^5.2.0", 1909 | "import-fresh": "^3.2.1", 1910 | "js-yaml": "^4.1.0", 1911 | "minimatch": "^3.1.2", 1912 | "strip-json-comments": "^3.1.1" 1913 | } 1914 | }, 1915 | "@eslint/js": { 1916 | "version": "8.50.0", 1917 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.50.0.tgz", 1918 | "integrity": "sha512-NCC3zz2+nvYd+Ckfh87rA47zfu2QsQpvc6k1yzTk+b9KzRj0wkGa8LSoGOXN6Zv4lRf/EIoZ80biDh9HOI+RNQ==", 1919 | "dev": true 1920 | }, 1921 | "@humanwhocodes/config-array": { 1922 | "version": "0.11.11", 1923 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.11.tgz", 1924 | "integrity": "sha512-N2brEuAadi0CcdeMXUkhbZB84eskAc8MEX1By6qEchoVywSgXPIjou4rYsl0V3Hj0ZnuGycGCjdNgockbzeWNA==", 1925 | "dev": true, 1926 | "requires": { 1927 | "@humanwhocodes/object-schema": "^1.2.1", 1928 | "debug": "^4.1.1", 1929 | "minimatch": "^3.0.5" 1930 | } 1931 | }, 1932 | "@humanwhocodes/module-importer": { 1933 | "version": "1.0.1", 1934 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 1935 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 1936 | "dev": true 1937 | }, 1938 | "@humanwhocodes/object-schema": { 1939 | "version": "1.2.1", 1940 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 1941 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 1942 | "dev": true 1943 | }, 1944 | "@nodelib/fs.scandir": { 1945 | "version": "2.1.5", 1946 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 1947 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 1948 | "dev": true, 1949 | "requires": { 1950 | "@nodelib/fs.stat": "2.0.5", 1951 | "run-parallel": "^1.1.9" 1952 | } 1953 | }, 1954 | "@nodelib/fs.stat": { 1955 | "version": "2.0.5", 1956 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 1957 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 1958 | "dev": true 1959 | }, 1960 | "@nodelib/fs.walk": { 1961 | "version": "1.2.8", 1962 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 1963 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 1964 | "dev": true, 1965 | "requires": { 1966 | "@nodelib/fs.scandir": "2.1.5", 1967 | "fastq": "^1.6.0" 1968 | } 1969 | }, 1970 | "@tootallnate/once": { 1971 | "version": "1.1.2", 1972 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 1973 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", 1974 | "dev": true 1975 | }, 1976 | "@types/glob": { 1977 | "version": "7.2.0", 1978 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.2.0.tgz", 1979 | "integrity": "sha512-ZUxbzKl0IfJILTS6t7ip5fQQM/J3TJYubDm3nMbgubNNYS62eXeUpoLUC8/7fJNiFYHTrGPQn7hspDUzIHX3UA==", 1980 | "dev": true, 1981 | "requires": { 1982 | "@types/minimatch": "*", 1983 | "@types/node": "*" 1984 | } 1985 | }, 1986 | "@types/json-schema": { 1987 | "version": "7.0.13", 1988 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.13.tgz", 1989 | "integrity": "sha512-RbSSoHliUbnXj3ny0CNFOoxrIDV6SUGyStHsvDqosw6CkdPV8TtWGlfecuK4ToyMEAql6pzNxgCFKanovUzlgQ==", 1990 | "dev": true 1991 | }, 1992 | "@types/minimatch": { 1993 | "version": "5.1.2", 1994 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-5.1.2.tgz", 1995 | "integrity": "sha512-K0VQKziLUWkVKiRVrx4a40iPaxTUefQmjtkQofBkYRcoaaL/8rhwDWww9qWbrgicNOgnpIsMxyNIUM4+n6dUIA==", 1996 | "dev": true 1997 | }, 1998 | "@types/mocha": { 1999 | "version": "8.2.3", 2000 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-8.2.3.tgz", 2001 | "integrity": "sha512-ekGvFhFgrc2zYQoX4JeZPmVzZxw6Dtllga7iGHzfbYIYkAMUx/sAFP2GdFpLff+vdHXu5fl7WX9AT+TtqYcsyw==", 2002 | "dev": true 2003 | }, 2004 | "@types/node": { 2005 | "version": "15.14.9", 2006 | "resolved": "https://registry.npmjs.org/@types/node/-/node-15.14.9.tgz", 2007 | "integrity": "sha512-qjd88DrCxupx/kJD5yQgZdcYKZKSIGBVDIBE1/LTGcNm3d2Np/jxojkdePDdfnBHJc5W7vSMpbJ1aB7p/Py69A==", 2008 | "dev": true 2009 | }, 2010 | "@types/semver": { 2011 | "version": "7.5.3", 2012 | "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.3.tgz", 2013 | "integrity": "sha512-OxepLK9EuNEIPxWNME+C6WwbRAOOI2o2BaQEGzz5Lu2e4Z5eDnEo+/aVEDMIXywoJitJ7xWd641wrGLZdtwRyw==", 2014 | "dev": true 2015 | }, 2016 | "@types/vscode": { 2017 | "version": "1.74.0", 2018 | "resolved": "https://registry.npmjs.org/@types/vscode/-/vscode-1.74.0.tgz", 2019 | "integrity": "sha512-LyeCIU3jb9d38w0MXFwta9r0Jx23ugujkAxdwLTNCyspdZTKUc43t7ppPbCiPoQ/Ivd/pnDFZrb4hWd45wrsgA==", 2020 | "dev": true 2021 | }, 2022 | "@typescript-eslint/eslint-plugin": { 2023 | "version": "6.7.4", 2024 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.7.4.tgz", 2025 | "integrity": "sha512-DAbgDXwtX+pDkAHwiGhqP3zWUGpW49B7eqmgpPtg+BKJXwdct79ut9+ifqOFPJGClGKSHXn2PTBatCnldJRUoA==", 2026 | "dev": true, 2027 | "requires": { 2028 | "@eslint-community/regexpp": "^4.5.1", 2029 | "@typescript-eslint/scope-manager": "6.7.4", 2030 | "@typescript-eslint/type-utils": "6.7.4", 2031 | "@typescript-eslint/utils": "6.7.4", 2032 | "@typescript-eslint/visitor-keys": "6.7.4", 2033 | "debug": "^4.3.4", 2034 | "graphemer": "^1.4.0", 2035 | "ignore": "^5.2.4", 2036 | "natural-compare": "^1.4.0", 2037 | "semver": "^7.5.4", 2038 | "ts-api-utils": "^1.0.1" 2039 | } 2040 | }, 2041 | "@typescript-eslint/parser": { 2042 | "version": "6.7.4", 2043 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.7.4.tgz", 2044 | "integrity": "sha512-I5zVZFY+cw4IMZUeNCU7Sh2PO5O57F7Lr0uyhgCJmhN/BuTlnc55KxPonR4+EM3GBdfiCyGZye6DgMjtubQkmA==", 2045 | "dev": true, 2046 | "requires": { 2047 | "@typescript-eslint/scope-manager": "6.7.4", 2048 | "@typescript-eslint/types": "6.7.4", 2049 | "@typescript-eslint/typescript-estree": "6.7.4", 2050 | "@typescript-eslint/visitor-keys": "6.7.4", 2051 | "debug": "^4.3.4" 2052 | } 2053 | }, 2054 | "@typescript-eslint/scope-manager": { 2055 | "version": "6.7.4", 2056 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.7.4.tgz", 2057 | "integrity": "sha512-SdGqSLUPTXAXi7c3Ob7peAGVnmMoGzZ361VswK2Mqf8UOYcODiYvs8rs5ILqEdfvX1lE7wEZbLyELCW+Yrql1A==", 2058 | "dev": true, 2059 | "requires": { 2060 | "@typescript-eslint/types": "6.7.4", 2061 | "@typescript-eslint/visitor-keys": "6.7.4" 2062 | } 2063 | }, 2064 | "@typescript-eslint/type-utils": { 2065 | "version": "6.7.4", 2066 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.7.4.tgz", 2067 | "integrity": "sha512-n+g3zi1QzpcAdHFP9KQF+rEFxMb2KxtnJGID3teA/nxKHOVi3ylKovaqEzGBbVY2pBttU6z85gp0D00ufLzViQ==", 2068 | "dev": true, 2069 | "requires": { 2070 | "@typescript-eslint/typescript-estree": "6.7.4", 2071 | "@typescript-eslint/utils": "6.7.4", 2072 | "debug": "^4.3.4", 2073 | "ts-api-utils": "^1.0.1" 2074 | } 2075 | }, 2076 | "@typescript-eslint/types": { 2077 | "version": "6.7.4", 2078 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.7.4.tgz", 2079 | "integrity": "sha512-o9XWK2FLW6eSS/0r/tgjAGsYasLAnOWg7hvZ/dGYSSNjCh+49k5ocPN8OmG5aZcSJ8pclSOyVKP2x03Sj+RrCA==", 2080 | "dev": true 2081 | }, 2082 | "@typescript-eslint/typescript-estree": { 2083 | "version": "6.7.4", 2084 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.7.4.tgz", 2085 | "integrity": "sha512-ty8b5qHKatlNYd9vmpHooQz3Vki3gG+3PchmtsA4TgrZBKWHNjWfkQid7K7xQogBqqc7/BhGazxMD5vr6Ha+iQ==", 2086 | "dev": true, 2087 | "requires": { 2088 | "@typescript-eslint/types": "6.7.4", 2089 | "@typescript-eslint/visitor-keys": "6.7.4", 2090 | "debug": "^4.3.4", 2091 | "globby": "^11.1.0", 2092 | "is-glob": "^4.0.3", 2093 | "semver": "^7.5.4", 2094 | "ts-api-utils": "^1.0.1" 2095 | } 2096 | }, 2097 | "@typescript-eslint/utils": { 2098 | "version": "6.7.4", 2099 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.7.4.tgz", 2100 | "integrity": "sha512-PRQAs+HUn85Qdk+khAxsVV+oULy3VkbH3hQ8hxLRJXWBEd7iI+GbQxH5SEUSH7kbEoTp6oT1bOwyga24ELALTA==", 2101 | "dev": true, 2102 | "requires": { 2103 | "@eslint-community/eslint-utils": "^4.4.0", 2104 | "@types/json-schema": "^7.0.12", 2105 | "@types/semver": "^7.5.0", 2106 | "@typescript-eslint/scope-manager": "6.7.4", 2107 | "@typescript-eslint/types": "6.7.4", 2108 | "@typescript-eslint/typescript-estree": "6.7.4", 2109 | "semver": "^7.5.4" 2110 | } 2111 | }, 2112 | "@typescript-eslint/visitor-keys": { 2113 | "version": "6.7.4", 2114 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.7.4.tgz", 2115 | "integrity": "sha512-pOW37DUhlTZbvph50x5zZCkFn3xzwkGtNoJHzIM3svpiSkJzwOYr/kVBaXmf+RAQiUDs1AHEZVNPg6UJCJpwRA==", 2116 | "dev": true, 2117 | "requires": { 2118 | "@typescript-eslint/types": "6.7.4", 2119 | "eslint-visitor-keys": "^3.4.1" 2120 | } 2121 | }, 2122 | "@vscode/test-electron": { 2123 | "version": "1.6.2", 2124 | "resolved": "https://registry.npmjs.org/@vscode/test-electron/-/test-electron-1.6.2.tgz", 2125 | "integrity": "sha512-W01ajJEMx6223Y7J5yaajGjVs1QfW3YGkkOJHVKfAMEqNB1ZHN9wCcViehv5ZwVSSJnjhu6lYEYgwBdHtCxqhQ==", 2126 | "dev": true, 2127 | "requires": { 2128 | "http-proxy-agent": "^4.0.1", 2129 | "https-proxy-agent": "^5.0.0", 2130 | "rimraf": "^3.0.2", 2131 | "unzipper": "^0.10.11" 2132 | } 2133 | }, 2134 | "acorn": { 2135 | "version": "8.10.0", 2136 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.10.0.tgz", 2137 | "integrity": "sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==", 2138 | "dev": true 2139 | }, 2140 | "acorn-jsx": { 2141 | "version": "5.3.2", 2142 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 2143 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 2144 | "dev": true, 2145 | "requires": {} 2146 | }, 2147 | "agent-base": { 2148 | "version": "6.0.2", 2149 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 2150 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 2151 | "dev": true, 2152 | "requires": { 2153 | "debug": "4" 2154 | } 2155 | }, 2156 | "ajv": { 2157 | "version": "6.12.6", 2158 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 2159 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 2160 | "dev": true, 2161 | "requires": { 2162 | "fast-deep-equal": "^3.1.1", 2163 | "fast-json-stable-stringify": "^2.0.0", 2164 | "json-schema-traverse": "^0.4.1", 2165 | "uri-js": "^4.2.2" 2166 | } 2167 | }, 2168 | "ansi-regex": { 2169 | "version": "5.0.1", 2170 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2171 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2172 | "dev": true 2173 | }, 2174 | "ansi-styles": { 2175 | "version": "4.3.0", 2176 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2177 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2178 | "dev": true, 2179 | "requires": { 2180 | "color-convert": "^2.0.1" 2181 | } 2182 | }, 2183 | "argparse": { 2184 | "version": "2.0.1", 2185 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 2186 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 2187 | "dev": true 2188 | }, 2189 | "array-union": { 2190 | "version": "2.1.0", 2191 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 2192 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 2193 | "dev": true 2194 | }, 2195 | "balanced-match": { 2196 | "version": "1.0.2", 2197 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2198 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 2199 | "dev": true 2200 | }, 2201 | "big-integer": { 2202 | "version": "1.6.51", 2203 | "resolved": "https://registry.npmjs.org/big-integer/-/big-integer-1.6.51.tgz", 2204 | "integrity": "sha512-GPEid2Y9QU1Exl1rpO9B2IPJGHPSupF5GnVIP0blYvNOMer2bTvSWs1jGOUg04hTmu67nmLsQ9TBo1puaotBHg==", 2205 | "dev": true 2206 | }, 2207 | "binary": { 2208 | "version": "0.3.0", 2209 | "resolved": "https://registry.npmjs.org/binary/-/binary-0.3.0.tgz", 2210 | "integrity": "sha512-D4H1y5KYwpJgK8wk1Cue5LLPgmwHKYSChkbspQg5JtVuR5ulGckxfR62H3AE9UDkdMC8yyXlqYihuz3Aqg2XZg==", 2211 | "dev": true, 2212 | "requires": { 2213 | "buffers": "~0.1.1", 2214 | "chainsaw": "~0.1.0" 2215 | } 2216 | }, 2217 | "bluebird": { 2218 | "version": "3.4.7", 2219 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.4.7.tgz", 2220 | "integrity": "sha512-iD3898SR7sWVRHbiQv+sHUtHnMvC1o3nW5rAcqnq3uOn07DSAppZYUkIGslDz6gXC7HfunPe7YVBgoEJASPcHA==", 2221 | "dev": true 2222 | }, 2223 | "brace-expansion": { 2224 | "version": "1.1.11", 2225 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2226 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2227 | "dev": true, 2228 | "requires": { 2229 | "balanced-match": "^1.0.0", 2230 | "concat-map": "0.0.1" 2231 | } 2232 | }, 2233 | "braces": { 2234 | "version": "3.0.2", 2235 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 2236 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 2237 | "dev": true, 2238 | "requires": { 2239 | "fill-range": "^7.0.1" 2240 | } 2241 | }, 2242 | "buffer-indexof-polyfill": { 2243 | "version": "1.0.2", 2244 | "resolved": "https://registry.npmjs.org/buffer-indexof-polyfill/-/buffer-indexof-polyfill-1.0.2.tgz", 2245 | "integrity": "sha512-I7wzHwA3t1/lwXQh+A5PbNvJxgfo5r3xulgpYDB5zckTu/Z9oUK9biouBKQUjEqzaz3HnAT6TYoovmE+GqSf7A==", 2246 | "dev": true 2247 | }, 2248 | "buffers": { 2249 | "version": "0.1.1", 2250 | "resolved": "https://registry.npmjs.org/buffers/-/buffers-0.1.1.tgz", 2251 | "integrity": "sha512-9q/rDEGSb/Qsvv2qvzIzdluL5k7AaJOTrw23z9reQthrbF7is4CtlT0DXyO1oei2DCp4uojjzQ7igaSHp1kAEQ==", 2252 | "dev": true 2253 | }, 2254 | "callsites": { 2255 | "version": "3.1.0", 2256 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 2257 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 2258 | "dev": true 2259 | }, 2260 | "chainsaw": { 2261 | "version": "0.1.0", 2262 | "resolved": "https://registry.npmjs.org/chainsaw/-/chainsaw-0.1.0.tgz", 2263 | "integrity": "sha512-75kWfWt6MEKNC8xYXIdRpDehRYY/tNSgwKaJq+dbbDcxORuVrrQ+SEHoWsniVn9XPYfP4gmdWIeDk/4YNp1rNQ==", 2264 | "dev": true, 2265 | "requires": { 2266 | "traverse": ">=0.3.0 <0.4" 2267 | } 2268 | }, 2269 | "chalk": { 2270 | "version": "4.1.2", 2271 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2272 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2273 | "dev": true, 2274 | "requires": { 2275 | "ansi-styles": "^4.1.0", 2276 | "supports-color": "^7.1.0" 2277 | } 2278 | }, 2279 | "color-convert": { 2280 | "version": "2.0.1", 2281 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2282 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2283 | "dev": true, 2284 | "requires": { 2285 | "color-name": "~1.1.4" 2286 | } 2287 | }, 2288 | "color-name": { 2289 | "version": "1.1.4", 2290 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2291 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2292 | "dev": true 2293 | }, 2294 | "concat-map": { 2295 | "version": "0.0.1", 2296 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2297 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 2298 | "dev": true 2299 | }, 2300 | "core-util-is": { 2301 | "version": "1.0.3", 2302 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", 2303 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", 2304 | "dev": true 2305 | }, 2306 | "cross-spawn": { 2307 | "version": "7.0.3", 2308 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 2309 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 2310 | "dev": true, 2311 | "requires": { 2312 | "path-key": "^3.1.0", 2313 | "shebang-command": "^2.0.0", 2314 | "which": "^2.0.1" 2315 | } 2316 | }, 2317 | "debug": { 2318 | "version": "4.3.4", 2319 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2320 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2321 | "dev": true, 2322 | "requires": { 2323 | "ms": "2.1.2" 2324 | } 2325 | }, 2326 | "deep-is": { 2327 | "version": "0.1.4", 2328 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 2329 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 2330 | "dev": true 2331 | }, 2332 | "dir-glob": { 2333 | "version": "3.0.1", 2334 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 2335 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 2336 | "dev": true, 2337 | "requires": { 2338 | "path-type": "^4.0.0" 2339 | } 2340 | }, 2341 | "doctrine": { 2342 | "version": "3.0.0", 2343 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 2344 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 2345 | "dev": true, 2346 | "requires": { 2347 | "esutils": "^2.0.2" 2348 | } 2349 | }, 2350 | "duplexer2": { 2351 | "version": "0.1.4", 2352 | "resolved": "https://registry.npmjs.org/duplexer2/-/duplexer2-0.1.4.tgz", 2353 | "integrity": "sha512-asLFVfWWtJ90ZyOUHMqk7/S2w2guQKxUI2itj3d92ADHhxUSbCMGi1f1cBcJ7xM1To+pE/Khbwo1yuNbMEPKeA==", 2354 | "dev": true, 2355 | "requires": { 2356 | "readable-stream": "^2.0.2" 2357 | } 2358 | }, 2359 | "escape-string-regexp": { 2360 | "version": "4.0.0", 2361 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2362 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2363 | "dev": true 2364 | }, 2365 | "eslint": { 2366 | "version": "8.50.0", 2367 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.50.0.tgz", 2368 | "integrity": "sha512-FOnOGSuFuFLv/Sa+FDVRZl4GGVAAFFi8LecRsI5a1tMO5HIE8nCm4ivAlzt4dT3ol/PaaGC0rJEEXQmHJBGoOg==", 2369 | "dev": true, 2370 | "requires": { 2371 | "@eslint-community/eslint-utils": "^4.2.0", 2372 | "@eslint-community/regexpp": "^4.6.1", 2373 | "@eslint/eslintrc": "^2.1.2", 2374 | "@eslint/js": "8.50.0", 2375 | "@humanwhocodes/config-array": "^0.11.11", 2376 | "@humanwhocodes/module-importer": "^1.0.1", 2377 | "@nodelib/fs.walk": "^1.2.8", 2378 | "ajv": "^6.12.4", 2379 | "chalk": "^4.0.0", 2380 | "cross-spawn": "^7.0.2", 2381 | "debug": "^4.3.2", 2382 | "doctrine": "^3.0.0", 2383 | "escape-string-regexp": "^4.0.0", 2384 | "eslint-scope": "^7.2.2", 2385 | "eslint-visitor-keys": "^3.4.3", 2386 | "espree": "^9.6.1", 2387 | "esquery": "^1.4.2", 2388 | "esutils": "^2.0.2", 2389 | "fast-deep-equal": "^3.1.3", 2390 | "file-entry-cache": "^6.0.1", 2391 | "find-up": "^5.0.0", 2392 | "glob-parent": "^6.0.2", 2393 | "globals": "^13.19.0", 2394 | "graphemer": "^1.4.0", 2395 | "ignore": "^5.2.0", 2396 | "imurmurhash": "^0.1.4", 2397 | "is-glob": "^4.0.0", 2398 | "is-path-inside": "^3.0.3", 2399 | "js-yaml": "^4.1.0", 2400 | "json-stable-stringify-without-jsonify": "^1.0.1", 2401 | "levn": "^0.4.1", 2402 | "lodash.merge": "^4.6.2", 2403 | "minimatch": "^3.1.2", 2404 | "natural-compare": "^1.4.0", 2405 | "optionator": "^0.9.3", 2406 | "strip-ansi": "^6.0.1", 2407 | "text-table": "^0.2.0" 2408 | } 2409 | }, 2410 | "eslint-scope": { 2411 | "version": "7.2.2", 2412 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 2413 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 2414 | "dev": true, 2415 | "requires": { 2416 | "esrecurse": "^4.3.0", 2417 | "estraverse": "^5.2.0" 2418 | } 2419 | }, 2420 | "eslint-visitor-keys": { 2421 | "version": "3.4.3", 2422 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 2423 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 2424 | "dev": true 2425 | }, 2426 | "espree": { 2427 | "version": "9.6.1", 2428 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 2429 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 2430 | "dev": true, 2431 | "requires": { 2432 | "acorn": "^8.9.0", 2433 | "acorn-jsx": "^5.3.2", 2434 | "eslint-visitor-keys": "^3.4.1" 2435 | } 2436 | }, 2437 | "esquery": { 2438 | "version": "1.5.0", 2439 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 2440 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 2441 | "dev": true, 2442 | "requires": { 2443 | "estraverse": "^5.1.0" 2444 | } 2445 | }, 2446 | "esrecurse": { 2447 | "version": "4.3.0", 2448 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2449 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2450 | "dev": true, 2451 | "requires": { 2452 | "estraverse": "^5.2.0" 2453 | } 2454 | }, 2455 | "estraverse": { 2456 | "version": "5.3.0", 2457 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 2458 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 2459 | "dev": true 2460 | }, 2461 | "esutils": { 2462 | "version": "2.0.3", 2463 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2464 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2465 | "dev": true 2466 | }, 2467 | "fast-deep-equal": { 2468 | "version": "3.1.3", 2469 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2470 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2471 | "dev": true 2472 | }, 2473 | "fast-glob": { 2474 | "version": "3.3.1", 2475 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.1.tgz", 2476 | "integrity": "sha512-kNFPyjhh5cKjrUltxs+wFx+ZkbRaxxmZ+X0ZU31SOsxCEtP9VPgtq2teZw1DebupL5GmDaNQ6yKMMVcM41iqDg==", 2477 | "dev": true, 2478 | "requires": { 2479 | "@nodelib/fs.stat": "^2.0.2", 2480 | "@nodelib/fs.walk": "^1.2.3", 2481 | "glob-parent": "^5.1.2", 2482 | "merge2": "^1.3.0", 2483 | "micromatch": "^4.0.4" 2484 | }, 2485 | "dependencies": { 2486 | "glob-parent": { 2487 | "version": "5.1.2", 2488 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2489 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2490 | "dev": true, 2491 | "requires": { 2492 | "is-glob": "^4.0.1" 2493 | } 2494 | } 2495 | } 2496 | }, 2497 | "fast-json-stable-stringify": { 2498 | "version": "2.1.0", 2499 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 2500 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 2501 | "dev": true 2502 | }, 2503 | "fast-levenshtein": { 2504 | "version": "2.0.6", 2505 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2506 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 2507 | "dev": true 2508 | }, 2509 | "fastq": { 2510 | "version": "1.15.0", 2511 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz", 2512 | "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==", 2513 | "dev": true, 2514 | "requires": { 2515 | "reusify": "^1.0.4" 2516 | } 2517 | }, 2518 | "file-entry-cache": { 2519 | "version": "6.0.1", 2520 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 2521 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 2522 | "dev": true, 2523 | "requires": { 2524 | "flat-cache": "^3.0.4" 2525 | } 2526 | }, 2527 | "fill-range": { 2528 | "version": "7.0.1", 2529 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2530 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2531 | "dev": true, 2532 | "requires": { 2533 | "to-regex-range": "^5.0.1" 2534 | } 2535 | }, 2536 | "find-up": { 2537 | "version": "5.0.0", 2538 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2539 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2540 | "dev": true, 2541 | "requires": { 2542 | "locate-path": "^6.0.0", 2543 | "path-exists": "^4.0.0" 2544 | } 2545 | }, 2546 | "flat-cache": { 2547 | "version": "3.1.0", 2548 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.1.0.tgz", 2549 | "integrity": "sha512-OHx4Qwrrt0E4jEIcI5/Xb+f+QmJYNj2rrK8wiIdQOIrB9WrrJL8cjZvXdXuBTkkEwEqLycb5BeZDV1o2i9bTew==", 2550 | "dev": true, 2551 | "requires": { 2552 | "flatted": "^3.2.7", 2553 | "keyv": "^4.5.3", 2554 | "rimraf": "^3.0.2" 2555 | } 2556 | }, 2557 | "flatted": { 2558 | "version": "3.2.9", 2559 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.9.tgz", 2560 | "integrity": "sha512-36yxDn5H7OFZQla0/jFJmbIKTdZAQHngCedGxiMmpNfEZM0sdEeT+WczLQrjK6D7o2aiyLYDnkw0R3JK0Qv1RQ==", 2561 | "dev": true 2562 | }, 2563 | "fs.realpath": { 2564 | "version": "1.0.0", 2565 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2566 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 2567 | "dev": true 2568 | }, 2569 | "fstream": { 2570 | "version": "1.0.12", 2571 | "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.12.tgz", 2572 | "integrity": "sha512-WvJ193OHa0GHPEL+AycEJgxvBEwyfRkN1vhjca23OaPVMCaLCXTd5qAu82AjTcgP1UJmytkOKb63Ypde7raDIg==", 2573 | "dev": true, 2574 | "requires": { 2575 | "graceful-fs": "^4.1.2", 2576 | "inherits": "~2.0.0", 2577 | "mkdirp": ">=0.5 0", 2578 | "rimraf": "2" 2579 | }, 2580 | "dependencies": { 2581 | "rimraf": { 2582 | "version": "2.7.1", 2583 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 2584 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 2585 | "dev": true, 2586 | "requires": { 2587 | "glob": "^7.1.3" 2588 | } 2589 | } 2590 | } 2591 | }, 2592 | "glob": { 2593 | "version": "7.2.3", 2594 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2595 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2596 | "dev": true, 2597 | "requires": { 2598 | "fs.realpath": "^1.0.0", 2599 | "inflight": "^1.0.4", 2600 | "inherits": "2", 2601 | "minimatch": "^3.1.1", 2602 | "once": "^1.3.0", 2603 | "path-is-absolute": "^1.0.0" 2604 | } 2605 | }, 2606 | "glob-parent": { 2607 | "version": "6.0.2", 2608 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 2609 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 2610 | "dev": true, 2611 | "requires": { 2612 | "is-glob": "^4.0.3" 2613 | } 2614 | }, 2615 | "globals": { 2616 | "version": "13.22.0", 2617 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.22.0.tgz", 2618 | "integrity": "sha512-H1Ddc/PbZHTDVJSnj8kWptIRSD6AM3pK+mKytuIVF4uoBV7rshFlhhvA58ceJ5wp3Er58w6zj7bykMpYXt3ETw==", 2619 | "dev": true, 2620 | "requires": { 2621 | "type-fest": "^0.20.2" 2622 | } 2623 | }, 2624 | "globby": { 2625 | "version": "11.1.0", 2626 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 2627 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 2628 | "dev": true, 2629 | "requires": { 2630 | "array-union": "^2.1.0", 2631 | "dir-glob": "^3.0.1", 2632 | "fast-glob": "^3.2.9", 2633 | "ignore": "^5.2.0", 2634 | "merge2": "^1.4.1", 2635 | "slash": "^3.0.0" 2636 | } 2637 | }, 2638 | "graceful-fs": { 2639 | "version": "4.2.10", 2640 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", 2641 | "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==", 2642 | "dev": true 2643 | }, 2644 | "graphemer": { 2645 | "version": "1.4.0", 2646 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 2647 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 2648 | "dev": true 2649 | }, 2650 | "has-flag": { 2651 | "version": "4.0.0", 2652 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2653 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2654 | "dev": true 2655 | }, 2656 | "http-proxy-agent": { 2657 | "version": "4.0.1", 2658 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 2659 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 2660 | "dev": true, 2661 | "requires": { 2662 | "@tootallnate/once": "1", 2663 | "agent-base": "6", 2664 | "debug": "4" 2665 | } 2666 | }, 2667 | "https-proxy-agent": { 2668 | "version": "5.0.1", 2669 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", 2670 | "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", 2671 | "dev": true, 2672 | "requires": { 2673 | "agent-base": "6", 2674 | "debug": "4" 2675 | } 2676 | }, 2677 | "ignore": { 2678 | "version": "5.2.4", 2679 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", 2680 | "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", 2681 | "dev": true 2682 | }, 2683 | "import-fresh": { 2684 | "version": "3.3.0", 2685 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2686 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2687 | "dev": true, 2688 | "requires": { 2689 | "parent-module": "^1.0.0", 2690 | "resolve-from": "^4.0.0" 2691 | } 2692 | }, 2693 | "imurmurhash": { 2694 | "version": "0.1.4", 2695 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2696 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 2697 | "dev": true 2698 | }, 2699 | "inflight": { 2700 | "version": "1.0.6", 2701 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2702 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 2703 | "dev": true, 2704 | "requires": { 2705 | "once": "^1.3.0", 2706 | "wrappy": "1" 2707 | } 2708 | }, 2709 | "inherits": { 2710 | "version": "2.0.4", 2711 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2712 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2713 | "dev": true 2714 | }, 2715 | "is-extglob": { 2716 | "version": "2.1.1", 2717 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2718 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2719 | "dev": true 2720 | }, 2721 | "is-glob": { 2722 | "version": "4.0.3", 2723 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2724 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2725 | "dev": true, 2726 | "requires": { 2727 | "is-extglob": "^2.1.1" 2728 | } 2729 | }, 2730 | "is-number": { 2731 | "version": "7.0.0", 2732 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2733 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2734 | "dev": true 2735 | }, 2736 | "is-path-inside": { 2737 | "version": "3.0.3", 2738 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 2739 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 2740 | "dev": true 2741 | }, 2742 | "isarray": { 2743 | "version": "1.0.0", 2744 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 2745 | "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==", 2746 | "dev": true 2747 | }, 2748 | "isexe": { 2749 | "version": "2.0.0", 2750 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2751 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2752 | "dev": true 2753 | }, 2754 | "js-yaml": { 2755 | "version": "4.1.0", 2756 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2757 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2758 | "dev": true, 2759 | "requires": { 2760 | "argparse": "^2.0.1" 2761 | } 2762 | }, 2763 | "json-buffer": { 2764 | "version": "3.0.1", 2765 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 2766 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 2767 | "dev": true 2768 | }, 2769 | "json-schema-traverse": { 2770 | "version": "0.4.1", 2771 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2772 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2773 | "dev": true 2774 | }, 2775 | "json-stable-stringify-without-jsonify": { 2776 | "version": "1.0.1", 2777 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2778 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 2779 | "dev": true 2780 | }, 2781 | "keyv": { 2782 | "version": "4.5.3", 2783 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.3.tgz", 2784 | "integrity": "sha512-QCiSav9WaX1PgETJ+SpNnx2PRRapJ/oRSXM4VO5OGYGSjrxbKPVFVhB3l2OCbLCk329N8qyAtsJjSjvVBWzEug==", 2785 | "dev": true, 2786 | "requires": { 2787 | "json-buffer": "3.0.1" 2788 | } 2789 | }, 2790 | "levn": { 2791 | "version": "0.4.1", 2792 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2793 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2794 | "dev": true, 2795 | "requires": { 2796 | "prelude-ls": "^1.2.1", 2797 | "type-check": "~0.4.0" 2798 | } 2799 | }, 2800 | "listenercount": { 2801 | "version": "1.0.1", 2802 | "resolved": "https://registry.npmjs.org/listenercount/-/listenercount-1.0.1.tgz", 2803 | "integrity": "sha512-3mk/Zag0+IJxeDrxSgaDPy4zZ3w05PRZeJNnlWhzFz5OkX49J4krc+A8X2d2M69vGMBEX0uyl8M+W+8gH+kBqQ==", 2804 | "dev": true 2805 | }, 2806 | "locate-path": { 2807 | "version": "6.0.0", 2808 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2809 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2810 | "dev": true, 2811 | "requires": { 2812 | "p-locate": "^5.0.0" 2813 | } 2814 | }, 2815 | "lodash.merge": { 2816 | "version": "4.6.2", 2817 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2818 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2819 | "dev": true 2820 | }, 2821 | "lru-cache": { 2822 | "version": "6.0.0", 2823 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2824 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2825 | "dev": true, 2826 | "requires": { 2827 | "yallist": "^4.0.0" 2828 | } 2829 | }, 2830 | "merge2": { 2831 | "version": "1.4.1", 2832 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 2833 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 2834 | "dev": true 2835 | }, 2836 | "micromatch": { 2837 | "version": "4.0.5", 2838 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 2839 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 2840 | "dev": true, 2841 | "requires": { 2842 | "braces": "^3.0.2", 2843 | "picomatch": "^2.3.1" 2844 | } 2845 | }, 2846 | "minimatch": { 2847 | "version": "3.1.2", 2848 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2849 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2850 | "dev": true, 2851 | "requires": { 2852 | "brace-expansion": "^1.1.7" 2853 | } 2854 | }, 2855 | "minimist": { 2856 | "version": "1.2.7", 2857 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.7.tgz", 2858 | "integrity": "sha512-bzfL1YUZsP41gmu/qjrEk0Q6i2ix/cVeAhbCbqH9u3zYutS1cLg00qhrD0M2MVdCcx4Sc0UpP2eBWo9rotpq6g==", 2859 | "dev": true 2860 | }, 2861 | "mkdirp": { 2862 | "version": "0.5.6", 2863 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", 2864 | "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", 2865 | "dev": true, 2866 | "requires": { 2867 | "minimist": "^1.2.6" 2868 | } 2869 | }, 2870 | "ms": { 2871 | "version": "2.1.2", 2872 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2873 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2874 | "dev": true 2875 | }, 2876 | "natural-compare": { 2877 | "version": "1.4.0", 2878 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2879 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 2880 | "dev": true 2881 | }, 2882 | "once": { 2883 | "version": "1.4.0", 2884 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2885 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2886 | "dev": true, 2887 | "requires": { 2888 | "wrappy": "1" 2889 | } 2890 | }, 2891 | "optionator": { 2892 | "version": "0.9.3", 2893 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", 2894 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", 2895 | "dev": true, 2896 | "requires": { 2897 | "@aashutoshrathi/word-wrap": "^1.2.3", 2898 | "deep-is": "^0.1.3", 2899 | "fast-levenshtein": "^2.0.6", 2900 | "levn": "^0.4.1", 2901 | "prelude-ls": "^1.2.1", 2902 | "type-check": "^0.4.0" 2903 | } 2904 | }, 2905 | "p-limit": { 2906 | "version": "3.1.0", 2907 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2908 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2909 | "dev": true, 2910 | "requires": { 2911 | "yocto-queue": "^0.1.0" 2912 | } 2913 | }, 2914 | "p-locate": { 2915 | "version": "5.0.0", 2916 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2917 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2918 | "dev": true, 2919 | "requires": { 2920 | "p-limit": "^3.0.2" 2921 | } 2922 | }, 2923 | "parent-module": { 2924 | "version": "1.0.1", 2925 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2926 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2927 | "dev": true, 2928 | "requires": { 2929 | "callsites": "^3.0.0" 2930 | } 2931 | }, 2932 | "path-exists": { 2933 | "version": "4.0.0", 2934 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2935 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2936 | "dev": true 2937 | }, 2938 | "path-is-absolute": { 2939 | "version": "1.0.1", 2940 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2941 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 2942 | "dev": true 2943 | }, 2944 | "path-key": { 2945 | "version": "3.1.1", 2946 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2947 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2948 | "dev": true 2949 | }, 2950 | "path-type": { 2951 | "version": "4.0.0", 2952 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 2953 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 2954 | "dev": true 2955 | }, 2956 | "picomatch": { 2957 | "version": "2.3.1", 2958 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2959 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2960 | "dev": true 2961 | }, 2962 | "prelude-ls": { 2963 | "version": "1.2.1", 2964 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2965 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2966 | "dev": true 2967 | }, 2968 | "process-nextick-args": { 2969 | "version": "2.0.1", 2970 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 2971 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 2972 | "dev": true 2973 | }, 2974 | "punycode": { 2975 | "version": "2.3.0", 2976 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", 2977 | "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==", 2978 | "dev": true 2979 | }, 2980 | "queue-microtask": { 2981 | "version": "1.2.3", 2982 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2983 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2984 | "dev": true 2985 | }, 2986 | "readable-stream": { 2987 | "version": "2.3.7", 2988 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 2989 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 2990 | "dev": true, 2991 | "requires": { 2992 | "core-util-is": "~1.0.0", 2993 | "inherits": "~2.0.3", 2994 | "isarray": "~1.0.0", 2995 | "process-nextick-args": "~2.0.0", 2996 | "safe-buffer": "~5.1.1", 2997 | "string_decoder": "~1.1.1", 2998 | "util-deprecate": "~1.0.1" 2999 | } 3000 | }, 3001 | "resolve-from": { 3002 | "version": "4.0.0", 3003 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 3004 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 3005 | "dev": true 3006 | }, 3007 | "reusify": { 3008 | "version": "1.0.4", 3009 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 3010 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 3011 | "dev": true 3012 | }, 3013 | "rimraf": { 3014 | "version": "3.0.2", 3015 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 3016 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 3017 | "dev": true, 3018 | "requires": { 3019 | "glob": "^7.1.3" 3020 | } 3021 | }, 3022 | "run-parallel": { 3023 | "version": "1.2.0", 3024 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 3025 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 3026 | "dev": true, 3027 | "requires": { 3028 | "queue-microtask": "^1.2.2" 3029 | } 3030 | }, 3031 | "safe-buffer": { 3032 | "version": "5.1.2", 3033 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 3034 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 3035 | "dev": true 3036 | }, 3037 | "semver": { 3038 | "version": "7.5.4", 3039 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", 3040 | "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", 3041 | "dev": true, 3042 | "requires": { 3043 | "lru-cache": "^6.0.0" 3044 | } 3045 | }, 3046 | "setimmediate": { 3047 | "version": "1.0.5", 3048 | "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", 3049 | "integrity": "sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA==", 3050 | "dev": true 3051 | }, 3052 | "shebang-command": { 3053 | "version": "2.0.0", 3054 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3055 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3056 | "dev": true, 3057 | "requires": { 3058 | "shebang-regex": "^3.0.0" 3059 | } 3060 | }, 3061 | "shebang-regex": { 3062 | "version": "3.0.0", 3063 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3064 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3065 | "dev": true 3066 | }, 3067 | "slash": { 3068 | "version": "3.0.0", 3069 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 3070 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 3071 | "dev": true 3072 | }, 3073 | "string_decoder": { 3074 | "version": "1.1.1", 3075 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 3076 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 3077 | "dev": true, 3078 | "requires": { 3079 | "safe-buffer": "~5.1.0" 3080 | } 3081 | }, 3082 | "strip-ansi": { 3083 | "version": "6.0.1", 3084 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3085 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3086 | "dev": true, 3087 | "requires": { 3088 | "ansi-regex": "^5.0.1" 3089 | } 3090 | }, 3091 | "strip-json-comments": { 3092 | "version": "3.1.1", 3093 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3094 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3095 | "dev": true 3096 | }, 3097 | "supports-color": { 3098 | "version": "7.2.0", 3099 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 3100 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 3101 | "dev": true, 3102 | "requires": { 3103 | "has-flag": "^4.0.0" 3104 | } 3105 | }, 3106 | "text-table": { 3107 | "version": "0.2.0", 3108 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3109 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 3110 | "dev": true 3111 | }, 3112 | "to-regex-range": { 3113 | "version": "5.0.1", 3114 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3115 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3116 | "dev": true, 3117 | "requires": { 3118 | "is-number": "^7.0.0" 3119 | } 3120 | }, 3121 | "traverse": { 3122 | "version": "0.3.9", 3123 | "resolved": "https://registry.npmjs.org/traverse/-/traverse-0.3.9.tgz", 3124 | "integrity": "sha512-iawgk0hLP3SxGKDfnDJf8wTz4p2qImnyihM5Hh/sGvQ3K37dPi/w8sRhdNIxYA1TwFwc5mDhIJq+O0RsvXBKdQ==", 3125 | "dev": true 3126 | }, 3127 | "ts-api-utils": { 3128 | "version": "1.0.3", 3129 | "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.0.3.tgz", 3130 | "integrity": "sha512-wNMeqtMz5NtwpT/UZGY5alT+VoKdSsOOP/kqHFcUW1P/VRhH2wJ48+DN2WwUliNbQ976ETwDL0Ifd2VVvgonvg==", 3131 | "dev": true, 3132 | "requires": {} 3133 | }, 3134 | "type-check": { 3135 | "version": "0.4.0", 3136 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3137 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3138 | "dev": true, 3139 | "requires": { 3140 | "prelude-ls": "^1.2.1" 3141 | } 3142 | }, 3143 | "type-fest": { 3144 | "version": "0.20.2", 3145 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 3146 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 3147 | "dev": true 3148 | }, 3149 | "typescript": { 3150 | "version": "4.9.4", 3151 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.4.tgz", 3152 | "integrity": "sha512-Uz+dTXYzxXXbsFpM86Wh3dKCxrQqUcVMxwU54orwlJjOpO3ao8L7j5lH+dWfTwgCwIuM9GQ2kvVotzYJMXTBZg==", 3153 | "dev": true 3154 | }, 3155 | "unzipper": { 3156 | "version": "0.10.11", 3157 | "resolved": "https://registry.npmjs.org/unzipper/-/unzipper-0.10.11.tgz", 3158 | "integrity": "sha512-+BrAq2oFqWod5IESRjL3S8baohbevGcVA+teAIOYWM3pDVdseogqbzhhvvmiyQrUNKFUnDMtELW3X8ykbyDCJw==", 3159 | "dev": true, 3160 | "requires": { 3161 | "big-integer": "^1.6.17", 3162 | "binary": "~0.3.0", 3163 | "bluebird": "~3.4.1", 3164 | "buffer-indexof-polyfill": "~1.0.0", 3165 | "duplexer2": "~0.1.4", 3166 | "fstream": "^1.0.12", 3167 | "graceful-fs": "^4.2.2", 3168 | "listenercount": "~1.0.1", 3169 | "readable-stream": "~2.3.6", 3170 | "setimmediate": "~1.0.4" 3171 | } 3172 | }, 3173 | "uri-js": { 3174 | "version": "4.4.1", 3175 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 3176 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 3177 | "dev": true, 3178 | "requires": { 3179 | "punycode": "^2.1.0" 3180 | } 3181 | }, 3182 | "util-deprecate": { 3183 | "version": "1.0.2", 3184 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3185 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", 3186 | "dev": true 3187 | }, 3188 | "which": { 3189 | "version": "2.0.2", 3190 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3191 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3192 | "dev": true, 3193 | "requires": { 3194 | "isexe": "^2.0.0" 3195 | } 3196 | }, 3197 | "wrappy": { 3198 | "version": "1.0.2", 3199 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3200 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3201 | "dev": true 3202 | }, 3203 | "yallist": { 3204 | "version": "4.0.0", 3205 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3206 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3207 | "dev": true 3208 | }, 3209 | "yocto-queue": { 3210 | "version": "0.1.0", 3211 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3212 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3213 | "dev": true 3214 | } 3215 | } 3216 | } 3217 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "git-prefix", 3 | "displayName": "Git Prefix", 4 | "description": "Prefix commit message with value in branch name.", 5 | "version": "1.3.2", 6 | "publisher": "srmeyers", 7 | "author": { 8 | "name": "Samuel Meyers" 9 | }, 10 | "license": "MIT", 11 | "homepage": "https://github.com/srmeyers/git-prefix/blob/master/README.md", 12 | "bugs": { 13 | "url": "https://github.com/srmeyers/git-prefix/issues" 14 | }, 15 | "repository": { 16 | "type": "git", 17 | "url": "https://github.com/srmeyers/git-prefix.git" 18 | }, 19 | "engines": { 20 | "vscode": "^1.32.0" 21 | }, 22 | "categories": [ 23 | "Other" 24 | ], 25 | "icon": "images/icon.png", 26 | "preview": false, 27 | "galleryBanner": { 28 | "color": "#f0efe7", 29 | "theme": "light" 30 | }, 31 | "keywords": [ 32 | "git" 33 | ], 34 | "activationEvents": [ 35 | "onCommand:gitPrefix.setMessage" 36 | ], 37 | "main": "./out/extension.js", 38 | "contributes": { 39 | "configuration": { 40 | "type": "object", 41 | "title": "GitPrefix", 42 | "properties": { 43 | "gitPrefix.pattern": { 44 | "type": "string", 45 | "default": "(.*)", 46 | "description": "A regular expression to extract from branch name. Should match entire branch." 47 | }, 48 | "gitPrefix.patternIgnoreCase": { 49 | "type": "boolean", 50 | "default": false, 51 | "description": "Ignore case in pattern." 52 | }, 53 | "gitPrefix.replacementIsFunction": { 54 | "type": "boolean", 55 | "default": false, 56 | "description": "Replacement string is a function return expression with parameters (p1, p2, p3...) matching patterns." 57 | }, 58 | "gitPrefix.replacement": { 59 | "type": "string", 60 | "default": "[$1] ", 61 | "description": "Content to place in commit message." 62 | }, 63 | "gitPrefix.isSuffix": { 64 | "type": "boolean", 65 | "default": false, 66 | "description": "Suffix the pattern instead of prefix" 67 | } 68 | } 69 | }, 70 | "commands": [ 71 | { 72 | "command": "gitPrefix.setMessage", 73 | "title": "Git Prefix Commit Message", 74 | "icon": { 75 | "dark": "images/prefix-commit.svg", 76 | "light": "images/prefix-commit_light.svg" 77 | } 78 | } 79 | ], 80 | "menus": { 81 | "scm/title": [ 82 | { 83 | "command": "gitPrefix.setMessage", 84 | "when": "scmProvider == git", 85 | "group": "navigation" 86 | } 87 | ] 88 | } 89 | }, 90 | "scripts": { 91 | "vscode:prepublish": "npm run compile", 92 | "compile": "tsc -p ./", 93 | "watch": "tsc -watch -p ./", 94 | "pretest": "npm run compile", 95 | "test": "node ./out/test/runTest.js", 96 | "lint": "eslint . --ext .ts" 97 | }, 98 | "devDependencies": { 99 | "@types/glob": "^7.1.3", 100 | "@types/mocha": "^8.2.2", 101 | "@types/node": "^15.0.2", 102 | "@types/vscode": "^1.32.0", 103 | "@typescript-eslint/eslint-plugin": "^6.7.4", 104 | "@typescript-eslint/parser": "^6.7.4", 105 | "@vscode/test-electron": "^1.6.2", 106 | "eslint": "^8.50.0", 107 | "glob": "^7.1.7", 108 | "typescript": "^4.8.4" 109 | } 110 | } 111 | -------------------------------------------------------------------------------- /src/api/git.d.ts: -------------------------------------------------------------------------------- 1 | /* --------------------------------------------------------------------------------------------- 2 | * Copyright (c) Microsoft Corporation. All rights reserved. 3 | * Licensed under the MIT License. See License.txt in the project root for license information. 4 | *-------------------------------------------------------------------------------------------- */ 5 | 6 | import { Uri, Event } from 'vscode' 7 | 8 | export interface Git { 9 | readonly path: string; 10 | } 11 | 12 | export interface InputBox { 13 | value: string; 14 | } 15 | 16 | export const enum RefType { 17 | Head, 18 | RemoteHead, 19 | Tag 20 | } 21 | 22 | export interface Ref { 23 | readonly type: RefType; 24 | readonly name?: string; 25 | readonly commit?: string; 26 | readonly remote?: string; 27 | } 28 | 29 | export interface UpstreamRef { 30 | readonly remote: string; 31 | readonly name: string; 32 | } 33 | 34 | export interface Branch extends Ref { 35 | readonly upstream?: UpstreamRef; 36 | readonly ahead?: number; 37 | readonly behind?: number; 38 | } 39 | 40 | export interface Commit { 41 | readonly hash: string; 42 | readonly message: string; 43 | readonly parents: string[]; 44 | readonly authorEmail?: string | undefined; 45 | } 46 | 47 | export interface Submodule { 48 | readonly name: string; 49 | readonly path: string; 50 | readonly url: string; 51 | } 52 | 53 | export interface Remote { 54 | readonly name: string; 55 | readonly fetchUrl?: string; 56 | readonly pushUrl?: string; 57 | readonly isReadOnly: boolean; 58 | } 59 | 60 | export const enum Status { 61 | INDEX_MODIFIED, 62 | INDEX_ADDED, 63 | INDEX_DELETED, 64 | INDEX_RENAMED, 65 | INDEX_COPIED, 66 | 67 | MODIFIED, 68 | DELETED, 69 | UNTRACKED, 70 | IGNORED, 71 | INTENT_TO_ADD, 72 | 73 | ADDED_BY_US, 74 | ADDED_BY_THEM, 75 | DELETED_BY_US, 76 | DELETED_BY_THEM, 77 | BOTH_ADDED, 78 | BOTH_DELETED, 79 | BOTH_MODIFIED 80 | } 81 | 82 | export interface Change { 83 | 84 | /** 85 | * Returns either `originalUri` or `renameUri`, depending 86 | * on whether this change is a rename change. When 87 | * in doubt always use `uri` over the other two alternatives. 88 | */ 89 | readonly uri: Uri; 90 | readonly originalUri: Uri; 91 | readonly renameUri: Uri | undefined; 92 | readonly status: Status; 93 | } 94 | 95 | export interface RepositoryState { 96 | readonly HEAD: Branch | undefined; 97 | readonly refs: Ref[]; 98 | readonly remotes: Remote[]; 99 | readonly submodules: Submodule[]; 100 | readonly rebaseCommit: Commit | undefined; 101 | 102 | readonly mergeChanges: Change[]; 103 | readonly indexChanges: Change[]; 104 | readonly workingTreeChanges: Change[]; 105 | 106 | readonly onDidChange: Event; 107 | } 108 | 109 | export interface RepositoryUIState { 110 | readonly selected: boolean; 111 | readonly onDidChange: Event; 112 | } 113 | 114 | /** 115 | * Log options. 116 | */ 117 | export interface LogOptions { 118 | /** Max number of log entries to retrieve. If not specified, the default is 32. */ 119 | readonly maxEntries?: number; 120 | } 121 | 122 | export interface Repository { 123 | 124 | readonly rootUri: Uri; 125 | readonly inputBox: InputBox; 126 | readonly state: RepositoryState; 127 | readonly ui: RepositoryUIState; 128 | 129 | getConfigs(): Promise<{ key: string; value: string; }[]>; 130 | getConfig(key: string): Promise; 131 | setConfig(key: string, value: string): Promise; 132 | getGlobalConfig(key: string): Promise; 133 | 134 | getObjectDetails(treeish: string, path: string): Promise<{ mode: string, object: string, size: number }>; 135 | detectObjectType(object: string): Promise<{ mimetype: string, encoding?: string }>; 136 | buffer(ref: string, path: string): Promise; 137 | show(ref: string, path: string): Promise; 138 | getCommit(ref: string): Promise; 139 | 140 | clean(paths: string[]): Promise; 141 | 142 | apply(patch: string, reverse?: boolean): Promise; 143 | diff(cached?: boolean): Promise; 144 | diffWithHEAD(): Promise; 145 | diffWithHEAD(path: string): Promise; 146 | diffWith(ref: string): Promise; 147 | diffWith(ref: string, path: string): Promise; 148 | diffIndexWithHEAD(): Promise; 149 | diffIndexWithHEAD(path: string): Promise; 150 | diffIndexWith(ref: string): Promise; 151 | diffIndexWith(ref: string, path: string): Promise; 152 | diffBlobs(object1: string, object2: string): Promise; 153 | diffBetween(ref1: string, ref2: string): Promise; 154 | diffBetween(ref1: string, ref2: string, path: string): Promise; 155 | 156 | hashObject(data: string): Promise; 157 | 158 | createBranch(name: string, checkout: boolean, ref?: string): Promise; 159 | deleteBranch(name: string, force?: boolean): Promise; 160 | getBranch(name: string): Promise; 161 | setBranchUpstream(name: string, upstream: string): Promise; 162 | 163 | getMergeBase(ref1: string, ref2: string): Promise; 164 | 165 | status(): Promise; 166 | checkout(treeish: string): Promise; 167 | 168 | addRemote(name: string, url: string): Promise; 169 | removeRemote(name: string): Promise; 170 | 171 | fetch(remote?: string, ref?: string, depth?: number): Promise; 172 | pull(unshallow?: boolean): Promise; 173 | push(remoteName?: string, branchName?: string, setUpstream?: boolean): Promise; 174 | 175 | blame(path: string): Promise; 176 | log(options?: LogOptions): Promise; 177 | } 178 | 179 | export interface API { 180 | readonly git: Git; 181 | readonly repositories: Repository[]; 182 | readonly onDidOpenRepository: Event; 183 | readonly onDidCloseRepository: Event; 184 | } 185 | 186 | export interface GitExtension { 187 | 188 | readonly enabled: boolean; 189 | readonly onDidChangeEnablement: Event; 190 | 191 | /** 192 | * Returns a specific API version. 193 | * 194 | * Throws error if git extension is disabled. You can listed to the 195 | * [GitExtension.onDidChangeEnablement](#GitExtension.onDidChangeEnablement) event 196 | * to know when the extension becomes enabled/disabled. 197 | * 198 | * @param version Version number. 199 | * @returns API instance 200 | */ 201 | getAPI(version: 1): API; 202 | } 203 | 204 | export const enum GitErrorCodes { 205 | BadConfigFile = 'BadConfigFile', 206 | AuthenticationFailed = 'AuthenticationFailed', 207 | NoUserNameConfigured = 'NoUserNameConfigured', 208 | NoUserEmailConfigured = 'NoUserEmailConfigured', 209 | NoRemoteRepositorySpecified = 'NoRemoteRepositorySpecified', 210 | NotAGitRepository = 'NotAGitRepository', 211 | NotAtRepositoryRoot = 'NotAtRepositoryRoot', 212 | Conflict = 'Conflict', 213 | StashConflict = 'StashConflict', 214 | UnmergedChanges = 'UnmergedChanges', 215 | PushRejected = 'PushRejected', 216 | RemoteConnectionError = 'RemoteConnectionError', 217 | DirtyWorkTree = 'DirtyWorkTree', 218 | CantOpenResource = 'CantOpenResource', 219 | GitNotFound = 'GitNotFound', 220 | CantCreatePipe = 'CantCreatePipe', 221 | CantAccessRemote = 'CantAccessRemote', 222 | RepositoryNotFound = 'RepositoryNotFound', 223 | RepositoryIsLocked = 'RepositoryIsLocked', 224 | BranchNotFullyMerged = 'BranchNotFullyMerged', 225 | NoRemoteReference = 'NoRemoteReference', 226 | InvalidBranchName = 'InvalidBranchName', 227 | BranchAlreadyExists = 'BranchAlreadyExists', 228 | NoLocalChanges = 'NoLocalChanges', 229 | NoStashFound = 'NoStashFound', 230 | LocalChangesOverwritten = 'LocalChangesOverwritten', 231 | NoUpstreamBranch = 'NoUpstreamBranch', 232 | IsInSubmodule = 'IsInSubmodule', 233 | WrongCase = 'WrongCase', 234 | CantLockRef = 'CantLockRef', 235 | CantRebaseMultipleBranches = 'CantRebaseMultipleBranches', 236 | PatchDoesNotApply = 'PatchDoesNotApply', 237 | NoPathFound = 'NoPathFound' 238 | } 239 | -------------------------------------------------------------------------------- /src/extension.ts: -------------------------------------------------------------------------------- 1 | import * as vscode from 'vscode' 2 | import { GitExtension, Repository } from './api/git' 3 | 4 | export function activate (context: vscode.ExtensionContext) { 5 | const disposable = vscode.commands.registerCommand('gitPrefix.setMessage', async (uri?) => { 6 | const git = getGitExtension() 7 | 8 | if (!git) { 9 | vscode.window.showErrorMessage('Unable to load Git Extension') 10 | return 11 | } 12 | 13 | vscode.commands.executeCommand('workbench.view.scm') 14 | 15 | if (uri) { 16 | const selectedRepository = git.repositories.find(repository => { 17 | return repository.rootUri.path === uri.rootUri.path 18 | }) 19 | 20 | if (selectedRepository) { 21 | await prefixCommit(selectedRepository) 22 | } 23 | } else { 24 | for (const repo of git.repositories) { 25 | await prefixCommit(repo) 26 | } 27 | } 28 | }) 29 | 30 | context.subscriptions.push(disposable) 31 | } 32 | 33 | async function prefixCommit (repository: Repository) { 34 | const { isSuffix, pattern = '(.*)', patternIgnoreCase } = vscode.workspace.getConfiguration('gitPrefix') 35 | 36 | const branchRegEx = new RegExp(pattern, patternIgnoreCase ? 'i' : '') 37 | const branchName = (repository.state.HEAD && repository.state.HEAD.name) || '' 38 | 39 | if (branchRegEx.test(branchName)) { 40 | const ticket = getTicket(repository, branchName, branchRegEx) 41 | const currentMessage = repository.inputBox.value.split(ticket).join(''); 42 | 43 | repository.inputBox.value = isSuffix ? `${currentMessage}${ticket}` : `${ticket}${currentMessage}` 44 | vscode.commands.executeCommand("list.focusFirst"); 45 | vscode.commands.executeCommand("list.select"); 46 | } else { 47 | const message = `Pattern ${pattern} not found in branch ${branchName}` 48 | const editPattern = 'Edit Pattern' 49 | const result = await vscode.window.showErrorMessage(message, { modal: false }, editPattern) 50 | if (result === editPattern) { 51 | vscode.commands.executeCommand('workbench.action.openSettings') 52 | vscode.commands.executeCommand('settings.action.clearSearchResults') 53 | } 54 | } 55 | } 56 | 57 | function getTicket(repository: Repository, branchName: string, branchRegEx: RegExp) { 58 | const { replacement = '[$1] ', replacementIsFunction } = vscode.workspace.getConfiguration('gitPrefix') 59 | const _replacement = replaceTokensInReplacement(repository, replacement); 60 | 61 | if (replacementIsFunction) { 62 | return branchName.replace( 63 | branchRegEx, 64 | // eslint-disable-next-line @typescript-eslint/no-explicit-any 65 | (_substring: string, ...args: any[]) => 66 | Function( 67 | ...(Array(args.length).fill(1).map((x, y) => `p${x + y}`)), // Build args 'p1', 'p2', 'p3'.... 68 | `return ${_replacement}` 69 | )(...args) 70 | ) 71 | } 72 | 73 | return branchName.replace(branchRegEx, _replacement) 74 | } 75 | 76 | function replaceTokensInReplacement(repository: Repository, replacement: string) { 77 | const tokens = { 78 | folder: repository.rootUri.path.split('/').slice(-1)[0], 79 | parentFolder: repository.rootUri.path.split('/').slice(-2,-1)[0], 80 | } 81 | 82 | return Object.entries(tokens).reduce((acc, [key, value]) => 83 | acc.replace(`$${key}`, value) 84 | , replacement); 85 | } 86 | 87 | function getGitExtension () { 88 | const vscodeGit = vscode.extensions.getExtension('vscode.git') 89 | const gitExtension = vscodeGit && vscodeGit.exports 90 | return gitExtension && gitExtension.getAPI(1) 91 | } 92 | 93 | export function deactivate () { 94 | // called when extension is deactivated 95 | } 96 | -------------------------------------------------------------------------------- /src/test/runTest.ts: -------------------------------------------------------------------------------- 1 | import * as path from 'path' 2 | 3 | import { runTests } from '@vscode/test-electron' 4 | 5 | async function main () { 6 | try { 7 | // The folder containing the Extension Manifest package.json 8 | // Passed to `--extensionDevelopmentPath` 9 | const extensionDevelopmentPath = path.resolve(__dirname, '../../') 10 | 11 | // The path to the extension test script 12 | // Passed to --extensionTestsPath 13 | const extensionTestsPath = path.resolve(__dirname, './suite/index') 14 | 15 | // Download VS Code, unzip it and run the integration test 16 | await runTests({ extensionDevelopmentPath, extensionTestsPath }) 17 | } catch (err) { 18 | console.error('Failed to run tests') 19 | process.exit(1) 20 | } 21 | } 22 | 23 | main() 24 | -------------------------------------------------------------------------------- /src/test/suite/extension.test.ts: -------------------------------------------------------------------------------- 1 | /* eslint-disable no-undef */ 2 | import * as assert from 'assert' 3 | 4 | // You can import and use all API from the 'vscode' module 5 | // as well as import your extension to test it 6 | import * as vscode from 'vscode' 7 | // import * as myExtension from '../../extension'; 8 | 9 | suite('Extension Test Suite', () => { 10 | vscode.window.showInformationMessage('Start all tests.') 11 | 12 | test('Sample test', () => { 13 | assert.equal([1, 2, 3].indexOf(5), -1) 14 | assert.equal([1, 2, 3].indexOf(0), -1) 15 | }) 16 | }) 17 | -------------------------------------------------------------------------------- /src/test/suite/index.ts: -------------------------------------------------------------------------------- 1 | import * as path from 'path' 2 | import * as Mocha from 'mocha' 3 | import * as glob from 'glob' 4 | 5 | export function run (): Promise { 6 | // Create the mocha test 7 | const mocha = new Mocha({ 8 | ui: 'tdd' 9 | }) 10 | 11 | const testsRoot = path.resolve(__dirname, '..') 12 | 13 | return new Promise((resolve, reject) => { 14 | glob('**/**.test.js', { cwd: testsRoot }, (err, files) => { 15 | if (err) { 16 | return reject(err) 17 | } 18 | 19 | // Add files to the test suite 20 | files.forEach(f => mocha.addFile(path.resolve(testsRoot, f))) 21 | 22 | try { 23 | // Run the mocha test 24 | mocha.run(failures => { 25 | if (failures > 0) { 26 | reject(new Error(`${failures} tests failed.`)) 27 | } else { 28 | resolve() 29 | } 30 | }) 31 | } catch (err) { 32 | console.error(err) 33 | reject(err) 34 | } 35 | }) 36 | }) 37 | } 38 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "target": "es6", 5 | "outDir": "out", 6 | "lib": [ 7 | "es6" 8 | ], 9 | "sourceMap": true, 10 | "rootDir": "src", 11 | "strict": true /* enable all strict type-checking options */ 12 | /* Additional Checks */ 13 | // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ 14 | // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ 15 | // "noUnusedParameters": true, /* Report errors on unused parameters. */ 16 | }, 17 | "exclude": [ 18 | "node_modules", 19 | ".vscode-test" 20 | ] 21 | } 22 | -------------------------------------------------------------------------------- /vsc-extension-quickstart.md: -------------------------------------------------------------------------------- 1 | # Welcome to your VS Code Extension 2 | 3 | ## What's in the folder 4 | 5 | * This folder contains all of the files necessary for your extension. 6 | * `package.json` - this is the manifest file in which you declare your extension and command. 7 | * The sample plugin registers a command and defines its title and command name. With this information VS Code can show the command in the command palette. It doesn’t yet need to load the plugin. 8 | * `src/extension.ts` - this is the main file where you will provide the implementation of your command. 9 | * The file exports one function, `activate`, which is called the very first time your extension is activated (in this case by executing the command). Inside the `activate` function we call `registerCommand`. 10 | * We pass the function containing the implementation of the command as the second parameter to `registerCommand`. 11 | 12 | ## Get up and running straight away 13 | 14 | * Press `F5` to open a new window with your extension loaded. 15 | * Run your command from the command palette by pressing (`Ctrl+Shift+P` or `Cmd+Shift+P` on Mac) and typing `Hello World`. 16 | * Set breakpoints in your code inside `src/extension.ts` to debug your extension. 17 | * Find output from your extension in the debug console. 18 | 19 | ## Make changes 20 | 21 | * You can relaunch the extension from the debug toolbar after changing code in `src/extension.ts`. 22 | * You can also reload (`Ctrl+R` or `Cmd+R` on Mac) the VS Code window with your extension to load your changes. 23 | 24 | ## Explore the API 25 | 26 | * You can open the full set of our API when you open the file `node_modules/vscode/vscode.d.ts`. 27 | 28 | ## Run tests 29 | 30 | * Open the debug viewlet (`Ctrl+Shift+D` or `Cmd+Shift+D` on Mac) and from the launch configuration dropdown pick `Extension Tests`. 31 | * Press `F5` to run the tests in a new window with your extension loaded. 32 | * See the output of the test result in the debug console. 33 | * Make changes to `test/extension.test.ts` or create new test files inside the `test` folder. 34 | * By convention, the test runner will only consider files matching the name pattern `**.test.ts`. 35 | * You can create folders inside the `test` folder to structure your tests any way you want. 36 | --------------------------------------------------------------------------------