├── .eslintrc.json ├── .gitignore ├── .vscode ├── extensions.json ├── launch.json ├── settings.json └── tasks.json ├── .vscodeignore ├── CHANGELOG.md ├── LICENSE.md ├── README.md ├── docs └── images │ ├── demo.gif │ └── rubybook.png ├── package-lock.json ├── package.json ├── src ├── extension.ts ├── rubyBook.ts ├── rubyBookCommands.ts ├── rubyBookController.ts ├── rubyBookSerializer.ts ├── rubyKernel.ts └── test │ ├── runTest.ts │ └── suite │ ├── extension.test.ts │ └── index.ts ├── tsconfig.json ├── vsc-extension-quickstart.md └── webpack.config.js /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "root": true, 3 | "parser": "@typescript-eslint/parser", 4 | "parserOptions": { 5 | "ecmaVersion": 6, 6 | "sourceType": "module" 7 | }, 8 | "plugins": [ 9 | "@typescript-eslint" 10 | ], 11 | "rules": { 12 | "@typescript-eslint/naming-convention": "warn", 13 | "@typescript-eslint/semi": "warn", 14 | "curly": "warn", 15 | "eqeqeq": "warn", 16 | "no-throw-literal": "warn", 17 | "semi": "off" 18 | }, 19 | "ignorePatterns": [ 20 | "out", 21 | "dist", 22 | "**/*.d.ts" 23 | ] 24 | } 25 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | out 2 | dist 3 | node_modules 4 | .vscode-test/ 5 | *.vsix 6 | .DS_Store 7 | -------------------------------------------------------------------------------- /.vscode/extensions.json: -------------------------------------------------------------------------------- 1 | { 2 | // See http://go.microsoft.com/fwlink/?LinkId=827846 3 | // for the documentation about the extensions.json format 4 | "recommendations": ["dbaeumer.vscode-eslint", "amodio.tsl-problem-matcher"] 5 | } 6 | -------------------------------------------------------------------------------- /.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 | { 9 | "name": "Run Extension", 10 | "type": "extensionHost", 11 | "request": "launch", 12 | "args": [ 13 | "--extensionDevelopmentPath=${workspaceFolder}" 14 | ], 15 | "outFiles": [ 16 | "${workspaceFolder}/dist/**/*.js" 17 | ], 18 | "preLaunchTask": "${defaultBuildTask}" 19 | }, 20 | { 21 | "name": "Extension Tests", 22 | "type": "extensionHost", 23 | "request": "launch", 24 | "args": [ 25 | "--extensionDevelopmentPath=${workspaceFolder}", 26 | "--extensionTestsPath=${workspaceFolder}/out/test/suite/index" 27 | ], 28 | "outFiles": [ 29 | "${workspaceFolder}/out/**/*.js", 30 | "${workspaceFolder}/dist/**/*.js" 31 | ], 32 | "preLaunchTask": "tasks: watch-tests" 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 | "dist": false // set this to true to hide the "dist" folder with the compiled JS files 6 | }, 7 | "search.exclude": { 8 | "out": true, // set this to false to include "out" folder in search results 9 | "dist": true // set this to false to include "dist" folder in search results 10 | }, 11 | // Turn off tsc task auto detection since we have the necessary tasks as npm scripts 12 | "typescript.tsc.autoDetect": "off" 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": [ 10 | "$ts-webpack-watch", 11 | "$tslint-webpack-watch" 12 | ], 13 | "isBackground": true, 14 | "presentation": { 15 | "reveal": "never", 16 | "group": "watchers" 17 | }, 18 | "group": { 19 | "kind": "build", 20 | "isDefault": true 21 | } 22 | }, 23 | { 24 | "type": "npm", 25 | "script": "watch-tests", 26 | "problemMatcher": "$tsc-watch", 27 | "isBackground": true, 28 | "presentation": { 29 | "reveal": "never", 30 | "group": "watchers" 31 | }, 32 | "group": "build" 33 | }, 34 | { 35 | "label": "tasks: watch-tests", 36 | "dependsOn": [ 37 | "npm: watch", 38 | "npm: watch-tests" 39 | ], 40 | "problemMatcher": [] 41 | } 42 | ] 43 | } -------------------------------------------------------------------------------- /.vscodeignore: -------------------------------------------------------------------------------- 1 | .vscode/** 2 | .vscode-test/** 3 | out/** 4 | node_modules/** 5 | src/** 6 | .gitignore 7 | .yarnrc 8 | webpack.config.js 9 | vsc-extension-quickstart.md 10 | **/tsconfig.json 11 | **/.eslintrc.json 12 | **/*.map 13 | **/*.ts 14 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # Change Log 2 | 3 | All notable changes to the "ruby-book" extension will be documented in this file. 4 | 5 | ## [1.0.0] - 2022-05-30 6 | 7 | - Initial release 8 | 9 | ## [1.0.1] - 2022-05-30 10 | 11 | - Updated demo GIF 12 | 13 | ## [1.0.2] - 2022-06-10 14 | 15 | - Updated README.md 16 | -------------------------------------------------------------------------------- /LICENSE.md: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2022 Raj Shah 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 | # RubyBook 2 | 3 |

4 | 5 |

6 | 7 | RubyBook is a VSCode extension that provides a notebook interface for Ruby code. :notebook: 8 | 9 | This extension spawns a `pry` process in the background to allow users to create experiences with connected, executable Ruby cells and informational Markdown cells. :tada: 10 | 11 | ### Currently, this extension works for Mac and Linux systems only. 12 | 13 | ## Features 14 | 15 | - Run Ruby code within cells 16 | - Organize multiple cells in a file with data flowing from one cell to the next 17 | - Use Markdown to create human-readable cells documentating the code 18 | - Uses the power of pry to run code and maintain variables and results between multiple cells. 19 | 20 | \ 21 | ![RubyBook Demo](./docs/images/demo.gif) 22 | 23 | ## Requirements 24 | 25 | ### Mac or Linux system 26 | 27 | ### [ruby](https://www.ruby-lang.org/en/documentation/installation/) 28 | 29 | ### [pry](https://github.com/pry/pry) 30 | 31 | Note: The extension spawns a process by just running `pry`, so please make sure that `pry` is installed properly and added to the PATH. Easiest way to check is to run `pry` from terminal. 32 | 33 | ## Installation 34 | 35 | Search 'RubyBook' in the VSCode extensions tab 36 | 37 | RubyBook - [VSCode Extenstion URL](https://marketplace.visualstudio.com/items?itemName=rajshah11.ruby-book) 38 | 39 | [VSCode Extension Installation](https://code.visualstudio.com/docs/editor/extension-marketplace#_install-an-extension) 40 | 41 | ## How to use 42 | 43 | - Open or create a file with the extension `.rubybook` 44 | - Search for `RubyBook` in the VSCode command palette 45 | 46 | ## Extension Settings 47 | 48 | **No settings, as of now.** Configuration settings like execution timeouts, polling interval for output, etc. coming soon. Currently, the execution does not timeout and tries to run forever. The `pry` process is polled for output every 500 ms. 49 | 50 | ## Known Issues 51 | 52 | - The extension adopts a little hacky method to poll for completion of a code cell. It checks for the existence of the `pry` prompt (for ex., `[2] pry(main)> `) instead of gracefully inspecting Node.js I/O streams. 53 | - No configuration settings for execution timeouts or polling intervals. Note: You can stop execution of a command through the VSCode UI. 54 | - Window not focused on a newly created RubyBook. 55 | 56 | ## Feature Ideas 57 | 58 | - Short-term 59 | 60 | - Configuration settings 61 | - Add comments in the extension code 62 | - Add example `.rubybook` files 63 | - Add language icon 64 | 65 | - Medium-term 66 | 67 | - A custom renderer to colorize and pretty print output and errors for code execution cells 68 | 69 | - Long-term 70 | - Use an existing [Debbugger Adapter Protocol](https://microsoft.github.io/debug-adapter-protocol/) like [byebug-dap](https://gitlab.com/firelizzard/byebug-dap) or work on a new one to potentially add debugging support for the extension 71 | 72 | **If you have any issues, bugs or suggestions, please feel free to create a [Github issue](https://github.com/rajshah11/ruby-book/issues)** 73 | 74 | **If you are willing contribute, please start a discussion and feel free to create a [pull request](https://github.com/rajshah11/ruby-book/compare)** 75 | 76 | ## Release Notes 77 | 78 | ### 1.0.0 79 | 80 | Initial release of RubyBook :tada: 81 | -------------------------------------------------------------------------------- /docs/images/demo.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/rajshah11/ruby-book/f9907fe4e7699e698487c06d5df2b1ca24364bbe/docs/images/demo.gif -------------------------------------------------------------------------------- /docs/images/rubybook.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/rajshah11/ruby-book/f9907fe4e7699e698487c06d5df2b1ca24364bbe/docs/images/rubybook.png -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "ruby-book", 3 | "version": "1.0.2", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@discoveryjs/json-ext": { 8 | "version": "0.5.7", 9 | "resolved": "https://registry.npmjs.org/@discoveryjs/json-ext/-/json-ext-0.5.7.tgz", 10 | "integrity": "sha512-dBVuXR082gk3jsFp7Rd/JI4kytwGHecnCoTtXFb7DB6CNHp4rg5k1bhg0nWdLGLnOV71lmDzGQaLMy8iPLY0pw==", 11 | "dev": true 12 | }, 13 | "@eslint/eslintrc": { 14 | "version": "1.3.0", 15 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.3.0.tgz", 16 | "integrity": "sha512-UWW0TMTmk2d7hLcWD1/e2g5HDM/HQ3csaLSqXCfqwh4uNDuNqlaKWXmEsL4Cs41Z0KnILNvwbHAah3C2yt06kw==", 17 | "dev": true, 18 | "requires": { 19 | "ajv": "^6.12.4", 20 | "debug": "^4.3.2", 21 | "espree": "^9.3.2", 22 | "globals": "^13.15.0", 23 | "ignore": "^5.2.0", 24 | "import-fresh": "^3.2.1", 25 | "js-yaml": "^4.1.0", 26 | "minimatch": "^3.1.2", 27 | "strip-json-comments": "^3.1.1" 28 | } 29 | }, 30 | "@humanwhocodes/config-array": { 31 | "version": "0.9.5", 32 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.9.5.tgz", 33 | "integrity": "sha512-ObyMyWxZiCu/yTisA7uzx81s40xR2fD5Cg/2Kq7G02ajkNubJf6BopgDTmDyc3U7sXpNKM8cYOw7s7Tyr+DnCw==", 34 | "dev": true, 35 | "requires": { 36 | "@humanwhocodes/object-schema": "^1.2.1", 37 | "debug": "^4.1.1", 38 | "minimatch": "^3.0.4" 39 | } 40 | }, 41 | "@humanwhocodes/object-schema": { 42 | "version": "1.2.1", 43 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 44 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 45 | "dev": true 46 | }, 47 | "@nodelib/fs.scandir": { 48 | "version": "2.1.5", 49 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 50 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 51 | "dev": true, 52 | "requires": { 53 | "@nodelib/fs.stat": "2.0.5", 54 | "run-parallel": "^1.1.9" 55 | } 56 | }, 57 | "@nodelib/fs.stat": { 58 | "version": "2.0.5", 59 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 60 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 61 | "dev": true 62 | }, 63 | "@nodelib/fs.walk": { 64 | "version": "1.2.8", 65 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 66 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 67 | "dev": true, 68 | "requires": { 69 | "@nodelib/fs.scandir": "2.1.5", 70 | "fastq": "^1.6.0" 71 | } 72 | }, 73 | "@tootallnate/once": { 74 | "version": "1.1.2", 75 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 76 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", 77 | "dev": true 78 | }, 79 | "@types/eslint": { 80 | "version": "8.4.2", 81 | "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-8.4.2.tgz", 82 | "integrity": "sha512-Z1nseZON+GEnFjJc04sv4NSALGjhFwy6K0HXt7qsn5ArfAKtb63dXNJHf+1YW6IpOIYRBGUbu3GwJdj8DGnCjA==", 83 | "dev": true, 84 | "requires": { 85 | "@types/estree": "*", 86 | "@types/json-schema": "*" 87 | } 88 | }, 89 | "@types/eslint-scope": { 90 | "version": "3.7.3", 91 | "resolved": "https://registry.npmjs.org/@types/eslint-scope/-/eslint-scope-3.7.3.tgz", 92 | "integrity": "sha512-PB3ldyrcnAicT35TWPs5IcwKD8S333HMaa2VVv4+wdvebJkjWuW/xESoB8IwRcog8HYVYamb1g/R31Qv5Bx03g==", 93 | "dev": true, 94 | "requires": { 95 | "@types/eslint": "*", 96 | "@types/estree": "*" 97 | } 98 | }, 99 | "@types/estree": { 100 | "version": "0.0.51", 101 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.51.tgz", 102 | "integrity": "sha512-CuPgU6f3eT/XgKKPqKd/gLZV1Xmvf1a2R5POBOGQa6uv82xpls89HU5zKeVoyR8XzHd1RGNOlQlvUe3CFkjWNQ==", 103 | "dev": true 104 | }, 105 | "@types/glob": { 106 | "version": "7.2.0", 107 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.2.0.tgz", 108 | "integrity": "sha512-ZUxbzKl0IfJILTS6t7ip5fQQM/J3TJYubDm3nMbgubNNYS62eXeUpoLUC8/7fJNiFYHTrGPQn7hspDUzIHX3UA==", 109 | "dev": true, 110 | "requires": { 111 | "@types/minimatch": "*", 112 | "@types/node": "*" 113 | } 114 | }, 115 | "@types/json-schema": { 116 | "version": "7.0.11", 117 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz", 118 | "integrity": "sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==", 119 | "dev": true 120 | }, 121 | "@types/minimatch": { 122 | "version": "3.0.5", 123 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.5.tgz", 124 | "integrity": "sha512-Klz949h02Gz2uZCMGwDUSDS1YBlTdDDgbWHi+81l29tQALUtvz4rAYi5uoVhE5Lagoq6DeqAUlbrHvW/mXDgdQ==", 125 | "dev": true 126 | }, 127 | "@types/mocha": { 128 | "version": "9.1.1", 129 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-9.1.1.tgz", 130 | "integrity": "sha512-Z61JK7DKDtdKTWwLeElSEBcWGRLY8g95ic5FoQqI9CMx0ns/Ghep3B4DfcEimiKMvtamNVULVNKEsiwV3aQmXw==", 131 | "dev": true 132 | }, 133 | "@types/node": { 134 | "version": "14.18.18", 135 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.18.18.tgz", 136 | "integrity": "sha512-B9EoJFjhqcQ9OmQrNorItO+OwEOORNn3S31WuiHvZY/dm9ajkB7AKD/8toessEtHHNL+58jofbq7hMMY9v4yig==", 137 | "dev": true 138 | }, 139 | "@types/vscode": { 140 | "version": "1.67.0", 141 | "resolved": "https://registry.npmjs.org/@types/vscode/-/vscode-1.67.0.tgz", 142 | "integrity": "sha512-GH8BDf8cw9AC9080uneJfulhSa7KHSMI2s/CyKePXoGNos9J486w2V4YKoeNUqIEkW4hKoEAWp6/cXTwyGj47g==", 143 | "dev": true 144 | }, 145 | "@typescript-eslint/eslint-plugin": { 146 | "version": "5.26.0", 147 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.26.0.tgz", 148 | "integrity": "sha512-oGCmo0PqnRZZndr+KwvvAUvD3kNE4AfyoGCwOZpoCncSh4MVD06JTE8XQa2u9u+NX5CsyZMBTEc2C72zx38eYA==", 149 | "dev": true, 150 | "requires": { 151 | "@typescript-eslint/scope-manager": "5.26.0", 152 | "@typescript-eslint/type-utils": "5.26.0", 153 | "@typescript-eslint/utils": "5.26.0", 154 | "debug": "^4.3.4", 155 | "functional-red-black-tree": "^1.0.1", 156 | "ignore": "^5.2.0", 157 | "regexpp": "^3.2.0", 158 | "semver": "^7.3.7", 159 | "tsutils": "^3.21.0" 160 | } 161 | }, 162 | "@typescript-eslint/parser": { 163 | "version": "5.26.0", 164 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.26.0.tgz", 165 | "integrity": "sha512-n/IzU87ttzIdnAH5vQ4BBDnLPly7rC5VnjN3m0xBG82HK6rhRxnCb3w/GyWbNDghPd+NktJqB/wl6+YkzZ5T5Q==", 166 | "dev": true, 167 | "requires": { 168 | "@typescript-eslint/scope-manager": "5.26.0", 169 | "@typescript-eslint/types": "5.26.0", 170 | "@typescript-eslint/typescript-estree": "5.26.0", 171 | "debug": "^4.3.4" 172 | } 173 | }, 174 | "@typescript-eslint/scope-manager": { 175 | "version": "5.26.0", 176 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.26.0.tgz", 177 | "integrity": "sha512-gVzTJUESuTwiju/7NiTb4c5oqod8xt5GhMbExKsCTp6adU3mya6AGJ4Pl9xC7x2DX9UYFsjImC0mA62BCY22Iw==", 178 | "dev": true, 179 | "requires": { 180 | "@typescript-eslint/types": "5.26.0", 181 | "@typescript-eslint/visitor-keys": "5.26.0" 182 | } 183 | }, 184 | "@typescript-eslint/type-utils": { 185 | "version": "5.26.0", 186 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.26.0.tgz", 187 | "integrity": "sha512-7ccbUVWGLmcRDSA1+ADkDBl5fP87EJt0fnijsMFTVHXKGduYMgienC/i3QwoVhDADUAPoytgjbZbCOMj4TY55A==", 188 | "dev": true, 189 | "requires": { 190 | "@typescript-eslint/utils": "5.26.0", 191 | "debug": "^4.3.4", 192 | "tsutils": "^3.21.0" 193 | } 194 | }, 195 | "@typescript-eslint/types": { 196 | "version": "5.26.0", 197 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.26.0.tgz", 198 | "integrity": "sha512-8794JZFE1RN4XaExLWLI2oSXsVImNkl79PzTOOWt9h0UHROwJedNOD2IJyfL0NbddFllcktGIO2aOu10avQQyA==", 199 | "dev": true 200 | }, 201 | "@typescript-eslint/typescript-estree": { 202 | "version": "5.26.0", 203 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.26.0.tgz", 204 | "integrity": "sha512-EyGpw6eQDsfD6jIqmXP3rU5oHScZ51tL/cZgFbFBvWuCwrIptl+oueUZzSmLtxFuSOQ9vDcJIs+279gnJkfd1w==", 205 | "dev": true, 206 | "requires": { 207 | "@typescript-eslint/types": "5.26.0", 208 | "@typescript-eslint/visitor-keys": "5.26.0", 209 | "debug": "^4.3.4", 210 | "globby": "^11.1.0", 211 | "is-glob": "^4.0.3", 212 | "semver": "^7.3.7", 213 | "tsutils": "^3.21.0" 214 | } 215 | }, 216 | "@typescript-eslint/utils": { 217 | "version": "5.26.0", 218 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.26.0.tgz", 219 | "integrity": "sha512-PJFwcTq2Pt4AMOKfe3zQOdez6InIDOjUJJD3v3LyEtxHGVVRK3Vo7Dd923t/4M9hSH2q2CLvcTdxlLPjcIk3eg==", 220 | "dev": true, 221 | "requires": { 222 | "@types/json-schema": "^7.0.9", 223 | "@typescript-eslint/scope-manager": "5.26.0", 224 | "@typescript-eslint/types": "5.26.0", 225 | "@typescript-eslint/typescript-estree": "5.26.0", 226 | "eslint-scope": "^5.1.1", 227 | "eslint-utils": "^3.0.0" 228 | } 229 | }, 230 | "@typescript-eslint/visitor-keys": { 231 | "version": "5.26.0", 232 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.26.0.tgz", 233 | "integrity": "sha512-wei+ffqHanYDOQgg/fS6Hcar6wAWv0CUPQ3TZzOWd2BLfgP539rb49bwua8WRAs7R6kOSLn82rfEu2ro6Llt8Q==", 234 | "dev": true, 235 | "requires": { 236 | "@typescript-eslint/types": "5.26.0", 237 | "eslint-visitor-keys": "^3.3.0" 238 | } 239 | }, 240 | "@ungap/promise-all-settled": { 241 | "version": "1.1.2", 242 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 243 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 244 | "dev": true 245 | }, 246 | "@vscode/test-electron": { 247 | "version": "2.1.3", 248 | "resolved": "https://registry.npmjs.org/@vscode/test-electron/-/test-electron-2.1.3.tgz", 249 | "integrity": "sha512-ps/yJ/9ToUZtR1dHfWi1mDXtep1VoyyrmGKC3UnIbScToRQvbUjyy1VMqnMEW3EpMmC3g7+pyThIPtPyCLHyow==", 250 | "dev": true, 251 | "requires": { 252 | "http-proxy-agent": "^4.0.1", 253 | "https-proxy-agent": "^5.0.0", 254 | "rimraf": "^3.0.2", 255 | "unzipper": "^0.10.11" 256 | } 257 | }, 258 | "@webassemblyjs/ast": { 259 | "version": "1.11.1", 260 | "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.11.1.tgz", 261 | "integrity": "sha512-ukBh14qFLjxTQNTXocdyksN5QdM28S1CxHt2rdskFyL+xFV7VremuBLVbmCePj+URalXBENx/9Lm7lnhihtCSw==", 262 | "dev": true, 263 | "requires": { 264 | "@webassemblyjs/helper-numbers": "1.11.1", 265 | "@webassemblyjs/helper-wasm-bytecode": "1.11.1" 266 | } 267 | }, 268 | "@webassemblyjs/floating-point-hex-parser": { 269 | "version": "1.11.1", 270 | "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.1.tgz", 271 | "integrity": "sha512-iGRfyc5Bq+NnNuX8b5hwBrRjzf0ocrJPI6GWFodBFzmFnyvrQ83SHKhmilCU/8Jv67i4GJZBMhEzltxzcNagtQ==", 272 | "dev": true 273 | }, 274 | "@webassemblyjs/helper-api-error": { 275 | "version": "1.11.1", 276 | "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.1.tgz", 277 | "integrity": "sha512-RlhS8CBCXfRUR/cwo2ho9bkheSXG0+NwooXcc3PAILALf2QLdFyj7KGsKRbVc95hZnhnERon4kW/D3SZpp6Tcg==", 278 | "dev": true 279 | }, 280 | "@webassemblyjs/helper-buffer": { 281 | "version": "1.11.1", 282 | "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.11.1.tgz", 283 | "integrity": "sha512-gwikF65aDNeeXa8JxXa2BAk+REjSyhrNC9ZwdT0f8jc4dQQeDQ7G4m0f2QCLPJiMTTO6wfDmRmj/pW0PsUvIcA==", 284 | "dev": true 285 | }, 286 | "@webassemblyjs/helper-numbers": { 287 | "version": "1.11.1", 288 | "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.1.tgz", 289 | "integrity": "sha512-vDkbxiB8zfnPdNK9Rajcey5C0w+QJugEglN0of+kmO8l7lDb77AnlKYQF7aarZuCrv+l0UvqL+68gSDr3k9LPQ==", 290 | "dev": true, 291 | "requires": { 292 | "@webassemblyjs/floating-point-hex-parser": "1.11.1", 293 | "@webassemblyjs/helper-api-error": "1.11.1", 294 | "@xtuc/long": "4.2.2" 295 | } 296 | }, 297 | "@webassemblyjs/helper-wasm-bytecode": { 298 | "version": "1.11.1", 299 | "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.1.tgz", 300 | "integrity": "sha512-PvpoOGiJwXeTrSf/qfudJhwlvDQxFgelbMqtq52WWiXC6Xgg1IREdngmPN3bs4RoO83PnL/nFrxucXj1+BX62Q==", 301 | "dev": true 302 | }, 303 | "@webassemblyjs/helper-wasm-section": { 304 | "version": "1.11.1", 305 | "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.11.1.tgz", 306 | "integrity": "sha512-10P9No29rYX1j7F3EVPX3JvGPQPae+AomuSTPiF9eBQeChHI6iqjMIwR9JmOJXwpnn/oVGDk7I5IlskuMwU/pg==", 307 | "dev": true, 308 | "requires": { 309 | "@webassemblyjs/ast": "1.11.1", 310 | "@webassemblyjs/helper-buffer": "1.11.1", 311 | "@webassemblyjs/helper-wasm-bytecode": "1.11.1", 312 | "@webassemblyjs/wasm-gen": "1.11.1" 313 | } 314 | }, 315 | "@webassemblyjs/ieee754": { 316 | "version": "1.11.1", 317 | "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.11.1.tgz", 318 | "integrity": "sha512-hJ87QIPtAMKbFq6CGTkZYJivEwZDbQUgYd3qKSadTNOhVY7p+gfP6Sr0lLRVTaG1JjFj+r3YchoqRYxNH3M0GQ==", 319 | "dev": true, 320 | "requires": { 321 | "@xtuc/ieee754": "^1.2.0" 322 | } 323 | }, 324 | "@webassemblyjs/leb128": { 325 | "version": "1.11.1", 326 | "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.11.1.tgz", 327 | "integrity": "sha512-BJ2P0hNZ0u+Th1YZXJpzW6miwqQUGcIHT1G/sf72gLVD9DZ5AdYTqPNbHZh6K1M5VmKvFXwGSWZADz+qBWxeRw==", 328 | "dev": true, 329 | "requires": { 330 | "@xtuc/long": "4.2.2" 331 | } 332 | }, 333 | "@webassemblyjs/utf8": { 334 | "version": "1.11.1", 335 | "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.11.1.tgz", 336 | "integrity": "sha512-9kqcxAEdMhiwQkHpkNiorZzqpGrodQQ2IGrHHxCy+Ozng0ofyMA0lTqiLkVs1uzTRejX+/O0EOT7KxqVPuXosQ==", 337 | "dev": true 338 | }, 339 | "@webassemblyjs/wasm-edit": { 340 | "version": "1.11.1", 341 | "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.11.1.tgz", 342 | "integrity": "sha512-g+RsupUC1aTHfR8CDgnsVRVZFJqdkFHpsHMfJuWQzWU3tvnLC07UqHICfP+4XyL2tnr1amvl1Sdp06TnYCmVkA==", 343 | "dev": true, 344 | "requires": { 345 | "@webassemblyjs/ast": "1.11.1", 346 | "@webassemblyjs/helper-buffer": "1.11.1", 347 | "@webassemblyjs/helper-wasm-bytecode": "1.11.1", 348 | "@webassemblyjs/helper-wasm-section": "1.11.1", 349 | "@webassemblyjs/wasm-gen": "1.11.1", 350 | "@webassemblyjs/wasm-opt": "1.11.1", 351 | "@webassemblyjs/wasm-parser": "1.11.1", 352 | "@webassemblyjs/wast-printer": "1.11.1" 353 | } 354 | }, 355 | "@webassemblyjs/wasm-gen": { 356 | "version": "1.11.1", 357 | "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.11.1.tgz", 358 | "integrity": "sha512-F7QqKXwwNlMmsulj6+O7r4mmtAlCWfO/0HdgOxSklZfQcDu0TpLiD1mRt/zF25Bk59FIjEuGAIyn5ei4yMfLhA==", 359 | "dev": true, 360 | "requires": { 361 | "@webassemblyjs/ast": "1.11.1", 362 | "@webassemblyjs/helper-wasm-bytecode": "1.11.1", 363 | "@webassemblyjs/ieee754": "1.11.1", 364 | "@webassemblyjs/leb128": "1.11.1", 365 | "@webassemblyjs/utf8": "1.11.1" 366 | } 367 | }, 368 | "@webassemblyjs/wasm-opt": { 369 | "version": "1.11.1", 370 | "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.11.1.tgz", 371 | "integrity": "sha512-VqnkNqnZlU5EB64pp1l7hdm3hmQw7Vgqa0KF/KCNO9sIpI6Fk6brDEiX+iCOYrvMuBWDws0NkTOxYEb85XQHHw==", 372 | "dev": true, 373 | "requires": { 374 | "@webassemblyjs/ast": "1.11.1", 375 | "@webassemblyjs/helper-buffer": "1.11.1", 376 | "@webassemblyjs/wasm-gen": "1.11.1", 377 | "@webassemblyjs/wasm-parser": "1.11.1" 378 | } 379 | }, 380 | "@webassemblyjs/wasm-parser": { 381 | "version": "1.11.1", 382 | "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.11.1.tgz", 383 | "integrity": "sha512-rrBujw+dJu32gYB7/Lup6UhdkPx9S9SnobZzRVL7VcBH9Bt9bCBLEuX/YXOOtBsOZ4NQrRykKhffRWHvigQvOA==", 384 | "dev": true, 385 | "requires": { 386 | "@webassemblyjs/ast": "1.11.1", 387 | "@webassemblyjs/helper-api-error": "1.11.1", 388 | "@webassemblyjs/helper-wasm-bytecode": "1.11.1", 389 | "@webassemblyjs/ieee754": "1.11.1", 390 | "@webassemblyjs/leb128": "1.11.1", 391 | "@webassemblyjs/utf8": "1.11.1" 392 | } 393 | }, 394 | "@webassemblyjs/wast-printer": { 395 | "version": "1.11.1", 396 | "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.11.1.tgz", 397 | "integrity": "sha512-IQboUWM4eKzWW+N/jij2sRatKMh99QEelo3Eb2q0qXkvPRISAj8Qxtmw5itwqK+TTkBuUIE45AxYPToqPtL5gg==", 398 | "dev": true, 399 | "requires": { 400 | "@webassemblyjs/ast": "1.11.1", 401 | "@xtuc/long": "4.2.2" 402 | } 403 | }, 404 | "@webpack-cli/configtest": { 405 | "version": "1.1.1", 406 | "resolved": "https://registry.npmjs.org/@webpack-cli/configtest/-/configtest-1.1.1.tgz", 407 | "integrity": "sha512-1FBc1f9G4P/AxMqIgfZgeOTuRnwZMten8E7zap5zgpPInnCrP8D4Q81+4CWIch8i/Nf7nXjP0v6CjjbHOrXhKg==", 408 | "dev": true 409 | }, 410 | "@webpack-cli/info": { 411 | "version": "1.4.1", 412 | "resolved": "https://registry.npmjs.org/@webpack-cli/info/-/info-1.4.1.tgz", 413 | "integrity": "sha512-PKVGmazEq3oAo46Q63tpMr4HipI3OPfP7LiNOEJg963RMgT0rqheag28NCML0o3GIzA3DmxP1ZIAv9oTX1CUIA==", 414 | "dev": true, 415 | "requires": { 416 | "envinfo": "^7.7.3" 417 | } 418 | }, 419 | "@webpack-cli/serve": { 420 | "version": "1.6.1", 421 | "resolved": "https://registry.npmjs.org/@webpack-cli/serve/-/serve-1.6.1.tgz", 422 | "integrity": "sha512-gNGTiTrjEVQ0OcVnzsRSqTxaBSr+dmTfm+qJsCDluky8uhdLWep7Gcr62QsAKHTMxjCS/8nEITsmFAhfIx+QSw==", 423 | "dev": true 424 | }, 425 | "@xtuc/ieee754": { 426 | "version": "1.2.0", 427 | "resolved": "https://registry.npmjs.org/@xtuc/ieee754/-/ieee754-1.2.0.tgz", 428 | "integrity": "sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==", 429 | "dev": true 430 | }, 431 | "@xtuc/long": { 432 | "version": "4.2.2", 433 | "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz", 434 | "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==", 435 | "dev": true 436 | }, 437 | "acorn": { 438 | "version": "8.7.1", 439 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.1.tgz", 440 | "integrity": "sha512-Xx54uLJQZ19lKygFXOWsscKUbsBZW0CPykPhVQdhIeIwrbPmJzqeASDInc8nKBnp/JT6igTs82qPXz069H8I/A==", 441 | "dev": true 442 | }, 443 | "acorn-import-assertions": { 444 | "version": "1.8.0", 445 | "resolved": "https://registry.npmjs.org/acorn-import-assertions/-/acorn-import-assertions-1.8.0.tgz", 446 | "integrity": "sha512-m7VZ3jwz4eK6A4Vtt8Ew1/mNbP24u0FhdyfA7fSvnJR6LMdfOYnmuIrrJAgrYfYJ10F/otaHTtrtrtmHdMNzEw==", 447 | "dev": true 448 | }, 449 | "acorn-jsx": { 450 | "version": "5.3.2", 451 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 452 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 453 | "dev": true 454 | }, 455 | "agent-base": { 456 | "version": "6.0.2", 457 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 458 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 459 | "dev": true, 460 | "requires": { 461 | "debug": "4" 462 | } 463 | }, 464 | "ajv": { 465 | "version": "6.12.6", 466 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 467 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 468 | "dev": true, 469 | "requires": { 470 | "fast-deep-equal": "^3.1.1", 471 | "fast-json-stable-stringify": "^2.0.0", 472 | "json-schema-traverse": "^0.4.1", 473 | "uri-js": "^4.2.2" 474 | } 475 | }, 476 | "ajv-keywords": { 477 | "version": "3.5.2", 478 | "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.5.2.tgz", 479 | "integrity": "sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==", 480 | "dev": true 481 | }, 482 | "ansi-colors": { 483 | "version": "4.1.1", 484 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 485 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 486 | "dev": true 487 | }, 488 | "ansi-regex": { 489 | "version": "5.0.1", 490 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 491 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 492 | "dev": true 493 | }, 494 | "ansi-styles": { 495 | "version": "4.3.0", 496 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 497 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 498 | "dev": true, 499 | "requires": { 500 | "color-convert": "^2.0.1" 501 | } 502 | }, 503 | "anymatch": { 504 | "version": "3.1.2", 505 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 506 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 507 | "dev": true, 508 | "requires": { 509 | "normalize-path": "^3.0.0", 510 | "picomatch": "^2.0.4" 511 | } 512 | }, 513 | "argparse": { 514 | "version": "2.0.1", 515 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 516 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 517 | "dev": true 518 | }, 519 | "array-union": { 520 | "version": "2.1.0", 521 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 522 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 523 | "dev": true 524 | }, 525 | "async-wait-until": { 526 | "version": "2.0.12", 527 | "resolved": "https://registry.npmjs.org/async-wait-until/-/async-wait-until-2.0.12.tgz", 528 | "integrity": "sha512-SXy/vDs6UPJMG6YeEYOQ4ilA/JnGxk187KPGqFx9O+qVxsjkSl+jH+3P50qSNyMpEmDgr8qOFGOKCJckWb1i7A==" 529 | }, 530 | "balanced-match": { 531 | "version": "1.0.2", 532 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 533 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 534 | "dev": true 535 | }, 536 | "big-integer": { 537 | "version": "1.6.51", 538 | "resolved": "https://registry.npmjs.org/big-integer/-/big-integer-1.6.51.tgz", 539 | "integrity": "sha512-GPEid2Y9QU1Exl1rpO9B2IPJGHPSupF5GnVIP0blYvNOMer2bTvSWs1jGOUg04hTmu67nmLsQ9TBo1puaotBHg==", 540 | "dev": true 541 | }, 542 | "binary": { 543 | "version": "0.3.0", 544 | "resolved": "https://registry.npmjs.org/binary/-/binary-0.3.0.tgz", 545 | "integrity": "sha512-D4H1y5KYwpJgK8wk1Cue5LLPgmwHKYSChkbspQg5JtVuR5ulGckxfR62H3AE9UDkdMC8yyXlqYihuz3Aqg2XZg==", 546 | "dev": true, 547 | "requires": { 548 | "buffers": "~0.1.1", 549 | "chainsaw": "~0.1.0" 550 | } 551 | }, 552 | "binary-extensions": { 553 | "version": "2.2.0", 554 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 555 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 556 | "dev": true 557 | }, 558 | "bluebird": { 559 | "version": "3.4.7", 560 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.4.7.tgz", 561 | "integrity": "sha512-iD3898SR7sWVRHbiQv+sHUtHnMvC1o3nW5rAcqnq3uOn07DSAppZYUkIGslDz6gXC7HfunPe7YVBgoEJASPcHA==", 562 | "dev": true 563 | }, 564 | "brace-expansion": { 565 | "version": "1.1.11", 566 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 567 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 568 | "dev": true, 569 | "requires": { 570 | "balanced-match": "^1.0.0", 571 | "concat-map": "0.0.1" 572 | } 573 | }, 574 | "braces": { 575 | "version": "3.0.2", 576 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 577 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 578 | "dev": true, 579 | "requires": { 580 | "fill-range": "^7.0.1" 581 | } 582 | }, 583 | "browser-stdout": { 584 | "version": "1.3.1", 585 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 586 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 587 | "dev": true 588 | }, 589 | "browserslist": { 590 | "version": "4.20.3", 591 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.20.3.tgz", 592 | "integrity": "sha512-NBhymBQl1zM0Y5dQT/O+xiLP9/rzOIQdKM/eMJBAq7yBgaB6krIYLGejrwVYnSHZdqjscB1SPuAjHwxjvN6Wdg==", 593 | "dev": true, 594 | "requires": { 595 | "caniuse-lite": "^1.0.30001332", 596 | "electron-to-chromium": "^1.4.118", 597 | "escalade": "^3.1.1", 598 | "node-releases": "^2.0.3", 599 | "picocolors": "^1.0.0" 600 | } 601 | }, 602 | "buffer-from": { 603 | "version": "1.1.2", 604 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 605 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 606 | "dev": true 607 | }, 608 | "buffer-indexof-polyfill": { 609 | "version": "1.0.2", 610 | "resolved": "https://registry.npmjs.org/buffer-indexof-polyfill/-/buffer-indexof-polyfill-1.0.2.tgz", 611 | "integrity": "sha512-I7wzHwA3t1/lwXQh+A5PbNvJxgfo5r3xulgpYDB5zckTu/Z9oUK9biouBKQUjEqzaz3HnAT6TYoovmE+GqSf7A==", 612 | "dev": true 613 | }, 614 | "buffers": { 615 | "version": "0.1.1", 616 | "resolved": "https://registry.npmjs.org/buffers/-/buffers-0.1.1.tgz", 617 | "integrity": "sha512-9q/rDEGSb/Qsvv2qvzIzdluL5k7AaJOTrw23z9reQthrbF7is4CtlT0DXyO1oei2DCp4uojjzQ7igaSHp1kAEQ==", 618 | "dev": true 619 | }, 620 | "callsites": { 621 | "version": "3.1.0", 622 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 623 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 624 | "dev": true 625 | }, 626 | "camelcase": { 627 | "version": "6.3.0", 628 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 629 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 630 | "dev": true 631 | }, 632 | "caniuse-lite": { 633 | "version": "1.0.30001344", 634 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001344.tgz", 635 | "integrity": "sha512-0ZFjnlCaXNOAYcV7i+TtdKBp0L/3XEU2MF/x6Du1lrh+SRX4IfzIVL4HNJg5pB2PmFb8rszIGyOvsZnqqRoc2g==", 636 | "dev": true 637 | }, 638 | "chainsaw": { 639 | "version": "0.1.0", 640 | "resolved": "https://registry.npmjs.org/chainsaw/-/chainsaw-0.1.0.tgz", 641 | "integrity": "sha512-75kWfWt6MEKNC8xYXIdRpDehRYY/tNSgwKaJq+dbbDcxORuVrrQ+SEHoWsniVn9XPYfP4gmdWIeDk/4YNp1rNQ==", 642 | "dev": true, 643 | "requires": { 644 | "traverse": ">=0.3.0 <0.4" 645 | } 646 | }, 647 | "chalk": { 648 | "version": "4.1.2", 649 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 650 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 651 | "dev": true, 652 | "requires": { 653 | "ansi-styles": "^4.1.0", 654 | "supports-color": "^7.1.0" 655 | } 656 | }, 657 | "chokidar": { 658 | "version": "3.5.3", 659 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 660 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 661 | "dev": true, 662 | "requires": { 663 | "anymatch": "~3.1.2", 664 | "braces": "~3.0.2", 665 | "fsevents": "~2.3.2", 666 | "glob-parent": "~5.1.2", 667 | "is-binary-path": "~2.1.0", 668 | "is-glob": "~4.0.1", 669 | "normalize-path": "~3.0.0", 670 | "readdirp": "~3.6.0" 671 | } 672 | }, 673 | "chrome-trace-event": { 674 | "version": "1.0.3", 675 | "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.3.tgz", 676 | "integrity": "sha512-p3KULyQg4S7NIHixdwbGX+nFHkoBiA4YQmyWtjb8XngSKV124nJmRysgAeujbUVb15vh+RvFUfCPqU7rXk+hZg==", 677 | "dev": true 678 | }, 679 | "cliui": { 680 | "version": "7.0.4", 681 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 682 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 683 | "dev": true, 684 | "requires": { 685 | "string-width": "^4.2.0", 686 | "strip-ansi": "^6.0.0", 687 | "wrap-ansi": "^7.0.0" 688 | } 689 | }, 690 | "clone-deep": { 691 | "version": "4.0.1", 692 | "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-4.0.1.tgz", 693 | "integrity": "sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==", 694 | "dev": true, 695 | "requires": { 696 | "is-plain-object": "^2.0.4", 697 | "kind-of": "^6.0.2", 698 | "shallow-clone": "^3.0.0" 699 | } 700 | }, 701 | "color-convert": { 702 | "version": "2.0.1", 703 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 704 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 705 | "dev": true, 706 | "requires": { 707 | "color-name": "~1.1.4" 708 | } 709 | }, 710 | "color-name": { 711 | "version": "1.1.4", 712 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 713 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 714 | "dev": true 715 | }, 716 | "colorette": { 717 | "version": "2.0.16", 718 | "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.16.tgz", 719 | "integrity": "sha512-hUewv7oMjCp+wkBv5Rm0v87eJhq4woh5rSR+42YSQJKecCqgIqNkZ6lAlQms/BwHPJA5NKMRlpxPRv0n8HQW6g==", 720 | "dev": true 721 | }, 722 | "commander": { 723 | "version": "2.20.3", 724 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 725 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", 726 | "dev": true 727 | }, 728 | "concat-map": { 729 | "version": "0.0.1", 730 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 731 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 732 | "dev": true 733 | }, 734 | "core-util-is": { 735 | "version": "1.0.3", 736 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", 737 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", 738 | "dev": true 739 | }, 740 | "cross-spawn": { 741 | "version": "7.0.3", 742 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 743 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 744 | "dev": true, 745 | "requires": { 746 | "path-key": "^3.1.0", 747 | "shebang-command": "^2.0.0", 748 | "which": "^2.0.1" 749 | } 750 | }, 751 | "debug": { 752 | "version": "4.3.4", 753 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 754 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 755 | "dev": true, 756 | "requires": { 757 | "ms": "2.1.2" 758 | } 759 | }, 760 | "decamelize": { 761 | "version": "4.0.0", 762 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 763 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 764 | "dev": true 765 | }, 766 | "deep-is": { 767 | "version": "0.1.4", 768 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 769 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 770 | "dev": true 771 | }, 772 | "diff": { 773 | "version": "5.0.0", 774 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 775 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 776 | "dev": true 777 | }, 778 | "dir-glob": { 779 | "version": "3.0.1", 780 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 781 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 782 | "dev": true, 783 | "requires": { 784 | "path-type": "^4.0.0" 785 | } 786 | }, 787 | "doctrine": { 788 | "version": "3.0.0", 789 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 790 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 791 | "dev": true, 792 | "requires": { 793 | "esutils": "^2.0.2" 794 | } 795 | }, 796 | "duplexer2": { 797 | "version": "0.1.4", 798 | "resolved": "https://registry.npmjs.org/duplexer2/-/duplexer2-0.1.4.tgz", 799 | "integrity": "sha512-asLFVfWWtJ90ZyOUHMqk7/S2w2guQKxUI2itj3d92ADHhxUSbCMGi1f1cBcJ7xM1To+pE/Khbwo1yuNbMEPKeA==", 800 | "dev": true, 801 | "requires": { 802 | "readable-stream": "^2.0.2" 803 | } 804 | }, 805 | "electron-to-chromium": { 806 | "version": "1.4.141", 807 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.141.tgz", 808 | "integrity": "sha512-mfBcbqc0qc6RlxrsIgLG2wCqkiPAjEezHxGTu7p3dHHFOurH4EjS9rFZndX5axC8264rI1Pcbw8uQP39oZckeA==", 809 | "dev": true 810 | }, 811 | "emoji-regex": { 812 | "version": "8.0.0", 813 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 814 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 815 | "dev": true 816 | }, 817 | "enhanced-resolve": { 818 | "version": "5.9.3", 819 | "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.9.3.tgz", 820 | "integrity": "sha512-Bq9VSor+kjvW3f9/MiiR4eE3XYgOl7/rS8lnSxbRbF3kS0B2r+Y9w5krBWxZgDxASVZbdYrn5wT4j/Wb0J9qow==", 821 | "dev": true, 822 | "requires": { 823 | "graceful-fs": "^4.2.4", 824 | "tapable": "^2.2.0" 825 | } 826 | }, 827 | "envinfo": { 828 | "version": "7.8.1", 829 | "resolved": "https://registry.npmjs.org/envinfo/-/envinfo-7.8.1.tgz", 830 | "integrity": "sha512-/o+BXHmB7ocbHEAs6F2EnG0ogybVVUdkRunTT2glZU9XAaGmhqskrvKwqXuDfNjEO0LZKWdejEEpnq8aM0tOaw==", 831 | "dev": true 832 | }, 833 | "es-module-lexer": { 834 | "version": "0.9.3", 835 | "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-0.9.3.tgz", 836 | "integrity": "sha512-1HQ2M2sPtxwnvOvT1ZClHyQDiggdNjURWpY2we6aMKCQiUVxTmVs2UYPLIrD84sS+kMdUwfBSylbJPwNnBrnHQ==", 837 | "dev": true 838 | }, 839 | "escalade": { 840 | "version": "3.1.1", 841 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 842 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 843 | "dev": true 844 | }, 845 | "escape-string-regexp": { 846 | "version": "4.0.0", 847 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 848 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 849 | "dev": true 850 | }, 851 | "eslint": { 852 | "version": "8.16.0", 853 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.16.0.tgz", 854 | "integrity": "sha512-MBndsoXY/PeVTDJeWsYj7kLZ5hQpJOfMYLsF6LicLHQWbRDG19lK5jOix4DPl8yY4SUFcE3txy86OzFLWT+yoA==", 855 | "dev": true, 856 | "requires": { 857 | "@eslint/eslintrc": "^1.3.0", 858 | "@humanwhocodes/config-array": "^0.9.2", 859 | "ajv": "^6.10.0", 860 | "chalk": "^4.0.0", 861 | "cross-spawn": "^7.0.2", 862 | "debug": "^4.3.2", 863 | "doctrine": "^3.0.0", 864 | "escape-string-regexp": "^4.0.0", 865 | "eslint-scope": "^7.1.1", 866 | "eslint-utils": "^3.0.0", 867 | "eslint-visitor-keys": "^3.3.0", 868 | "espree": "^9.3.2", 869 | "esquery": "^1.4.0", 870 | "esutils": "^2.0.2", 871 | "fast-deep-equal": "^3.1.3", 872 | "file-entry-cache": "^6.0.1", 873 | "functional-red-black-tree": "^1.0.1", 874 | "glob-parent": "^6.0.1", 875 | "globals": "^13.15.0", 876 | "ignore": "^5.2.0", 877 | "import-fresh": "^3.0.0", 878 | "imurmurhash": "^0.1.4", 879 | "is-glob": "^4.0.0", 880 | "js-yaml": "^4.1.0", 881 | "json-stable-stringify-without-jsonify": "^1.0.1", 882 | "levn": "^0.4.1", 883 | "lodash.merge": "^4.6.2", 884 | "minimatch": "^3.1.2", 885 | "natural-compare": "^1.4.0", 886 | "optionator": "^0.9.1", 887 | "regexpp": "^3.2.0", 888 | "strip-ansi": "^6.0.1", 889 | "strip-json-comments": "^3.1.0", 890 | "text-table": "^0.2.0", 891 | "v8-compile-cache": "^2.0.3" 892 | }, 893 | "dependencies": { 894 | "eslint-scope": { 895 | "version": "7.1.1", 896 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.1.tgz", 897 | "integrity": "sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==", 898 | "dev": true, 899 | "requires": { 900 | "esrecurse": "^4.3.0", 901 | "estraverse": "^5.2.0" 902 | } 903 | }, 904 | "estraverse": { 905 | "version": "5.3.0", 906 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 907 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 908 | "dev": true 909 | }, 910 | "glob-parent": { 911 | "version": "6.0.2", 912 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 913 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 914 | "dev": true, 915 | "requires": { 916 | "is-glob": "^4.0.3" 917 | } 918 | } 919 | } 920 | }, 921 | "eslint-scope": { 922 | "version": "5.1.1", 923 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 924 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 925 | "dev": true, 926 | "requires": { 927 | "esrecurse": "^4.3.0", 928 | "estraverse": "^4.1.1" 929 | } 930 | }, 931 | "eslint-utils": { 932 | "version": "3.0.0", 933 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", 934 | "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", 935 | "dev": true, 936 | "requires": { 937 | "eslint-visitor-keys": "^2.0.0" 938 | }, 939 | "dependencies": { 940 | "eslint-visitor-keys": { 941 | "version": "2.1.0", 942 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 943 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 944 | "dev": true 945 | } 946 | } 947 | }, 948 | "eslint-visitor-keys": { 949 | "version": "3.3.0", 950 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz", 951 | "integrity": "sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==", 952 | "dev": true 953 | }, 954 | "espree": { 955 | "version": "9.3.2", 956 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.3.2.tgz", 957 | "integrity": "sha512-D211tC7ZwouTIuY5x9XnS0E9sWNChB7IYKX/Xp5eQj3nFXhqmiUDB9q27y76oFl8jTg3pXcQx/bpxMfs3CIZbA==", 958 | "dev": true, 959 | "requires": { 960 | "acorn": "^8.7.1", 961 | "acorn-jsx": "^5.3.2", 962 | "eslint-visitor-keys": "^3.3.0" 963 | } 964 | }, 965 | "esquery": { 966 | "version": "1.4.0", 967 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 968 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 969 | "dev": true, 970 | "requires": { 971 | "estraverse": "^5.1.0" 972 | }, 973 | "dependencies": { 974 | "estraverse": { 975 | "version": "5.3.0", 976 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 977 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 978 | "dev": true 979 | } 980 | } 981 | }, 982 | "esrecurse": { 983 | "version": "4.3.0", 984 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 985 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 986 | "dev": true, 987 | "requires": { 988 | "estraverse": "^5.2.0" 989 | }, 990 | "dependencies": { 991 | "estraverse": { 992 | "version": "5.3.0", 993 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 994 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 995 | "dev": true 996 | } 997 | } 998 | }, 999 | "estraverse": { 1000 | "version": "4.3.0", 1001 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 1002 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 1003 | "dev": true 1004 | }, 1005 | "esutils": { 1006 | "version": "2.0.3", 1007 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1008 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1009 | "dev": true 1010 | }, 1011 | "events": { 1012 | "version": "3.3.0", 1013 | "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", 1014 | "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==", 1015 | "dev": true 1016 | }, 1017 | "execa": { 1018 | "version": "5.1.1", 1019 | "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", 1020 | "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", 1021 | "dev": true, 1022 | "requires": { 1023 | "cross-spawn": "^7.0.3", 1024 | "get-stream": "^6.0.0", 1025 | "human-signals": "^2.1.0", 1026 | "is-stream": "^2.0.0", 1027 | "merge-stream": "^2.0.0", 1028 | "npm-run-path": "^4.0.1", 1029 | "onetime": "^5.1.2", 1030 | "signal-exit": "^3.0.3", 1031 | "strip-final-newline": "^2.0.0" 1032 | } 1033 | }, 1034 | "fast-deep-equal": { 1035 | "version": "3.1.3", 1036 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1037 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1038 | "dev": true 1039 | }, 1040 | "fast-glob": { 1041 | "version": "3.2.11", 1042 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.11.tgz", 1043 | "integrity": "sha512-xrO3+1bxSo3ZVHAnqzyuewYT6aMFHRAd4Kcs92MAonjwQZLsK9d0SF1IyQ3k5PoirxTW0Oe/RqFgMQ6TcNE5Ew==", 1044 | "dev": true, 1045 | "requires": { 1046 | "@nodelib/fs.stat": "^2.0.2", 1047 | "@nodelib/fs.walk": "^1.2.3", 1048 | "glob-parent": "^5.1.2", 1049 | "merge2": "^1.3.0", 1050 | "micromatch": "^4.0.4" 1051 | } 1052 | }, 1053 | "fast-json-stable-stringify": { 1054 | "version": "2.1.0", 1055 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1056 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1057 | "dev": true 1058 | }, 1059 | "fast-levenshtein": { 1060 | "version": "2.0.6", 1061 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1062 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 1063 | "dev": true 1064 | }, 1065 | "fastest-levenshtein": { 1066 | "version": "1.0.12", 1067 | "resolved": "https://registry.npmjs.org/fastest-levenshtein/-/fastest-levenshtein-1.0.12.tgz", 1068 | "integrity": "sha512-On2N+BpYJ15xIC974QNVuYGMOlEVt4s0EOI3wwMqOmK1fdDY+FN/zltPV8vosq4ad4c/gJ1KHScUn/6AWIgiow==", 1069 | "dev": true 1070 | }, 1071 | "fastq": { 1072 | "version": "1.13.0", 1073 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.13.0.tgz", 1074 | "integrity": "sha512-YpkpUnK8od0o1hmeSc7UUs/eB/vIPWJYjKck2QKIzAf71Vm1AAQ3EbuZB3g2JIy+pg+ERD0vqI79KyZiB2e2Nw==", 1075 | "dev": true, 1076 | "requires": { 1077 | "reusify": "^1.0.4" 1078 | } 1079 | }, 1080 | "file-entry-cache": { 1081 | "version": "6.0.1", 1082 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 1083 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 1084 | "dev": true, 1085 | "requires": { 1086 | "flat-cache": "^3.0.4" 1087 | } 1088 | }, 1089 | "fill-range": { 1090 | "version": "7.0.1", 1091 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1092 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1093 | "dev": true, 1094 | "requires": { 1095 | "to-regex-range": "^5.0.1" 1096 | } 1097 | }, 1098 | "find-up": { 1099 | "version": "5.0.0", 1100 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1101 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1102 | "dev": true, 1103 | "requires": { 1104 | "locate-path": "^6.0.0", 1105 | "path-exists": "^4.0.0" 1106 | } 1107 | }, 1108 | "flat": { 1109 | "version": "5.0.2", 1110 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 1111 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 1112 | "dev": true 1113 | }, 1114 | "flat-cache": { 1115 | "version": "3.0.4", 1116 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 1117 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 1118 | "dev": true, 1119 | "requires": { 1120 | "flatted": "^3.1.0", 1121 | "rimraf": "^3.0.2" 1122 | } 1123 | }, 1124 | "flatted": { 1125 | "version": "3.2.5", 1126 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.5.tgz", 1127 | "integrity": "sha512-WIWGi2L3DyTUvUrwRKgGi9TwxQMUEqPOPQBVi71R96jZXJdFskXEmf54BoZaS1kknGODoIGASGEzBUYdyMCBJg==", 1128 | "dev": true 1129 | }, 1130 | "fs.realpath": { 1131 | "version": "1.0.0", 1132 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1133 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1134 | "dev": true 1135 | }, 1136 | "fsevents": { 1137 | "version": "2.3.2", 1138 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1139 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1140 | "dev": true, 1141 | "optional": true 1142 | }, 1143 | "fstream": { 1144 | "version": "1.0.12", 1145 | "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.12.tgz", 1146 | "integrity": "sha512-WvJ193OHa0GHPEL+AycEJgxvBEwyfRkN1vhjca23OaPVMCaLCXTd5qAu82AjTcgP1UJmytkOKb63Ypde7raDIg==", 1147 | "dev": true, 1148 | "requires": { 1149 | "graceful-fs": "^4.1.2", 1150 | "inherits": "~2.0.0", 1151 | "mkdirp": ">=0.5 0", 1152 | "rimraf": "2" 1153 | }, 1154 | "dependencies": { 1155 | "glob": { 1156 | "version": "7.2.3", 1157 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 1158 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 1159 | "dev": true, 1160 | "requires": { 1161 | "fs.realpath": "^1.0.0", 1162 | "inflight": "^1.0.4", 1163 | "inherits": "2", 1164 | "minimatch": "^3.1.1", 1165 | "once": "^1.3.0", 1166 | "path-is-absolute": "^1.0.0" 1167 | } 1168 | }, 1169 | "rimraf": { 1170 | "version": "2.7.1", 1171 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 1172 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 1173 | "dev": true, 1174 | "requires": { 1175 | "glob": "^7.1.3" 1176 | } 1177 | } 1178 | } 1179 | }, 1180 | "function-bind": { 1181 | "version": "1.1.1", 1182 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1183 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1184 | "dev": true 1185 | }, 1186 | "functional-red-black-tree": { 1187 | "version": "1.0.1", 1188 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1189 | "integrity": "sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g==", 1190 | "dev": true 1191 | }, 1192 | "get-caller-file": { 1193 | "version": "2.0.5", 1194 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1195 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1196 | "dev": true 1197 | }, 1198 | "get-stream": { 1199 | "version": "6.0.1", 1200 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 1201 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 1202 | "dev": true 1203 | }, 1204 | "glob": { 1205 | "version": "8.0.3", 1206 | "resolved": "https://registry.npmjs.org/glob/-/glob-8.0.3.tgz", 1207 | "integrity": "sha512-ull455NHSHI/Y1FqGaaYFaLGkNMMJbavMrEGFXG/PGrg6y7sutWHUHrz6gy6WEBH6akM1M414dWKCNs+IhKdiQ==", 1208 | "dev": true, 1209 | "requires": { 1210 | "fs.realpath": "^1.0.0", 1211 | "inflight": "^1.0.4", 1212 | "inherits": "2", 1213 | "minimatch": "^5.0.1", 1214 | "once": "^1.3.0" 1215 | }, 1216 | "dependencies": { 1217 | "brace-expansion": { 1218 | "version": "2.0.1", 1219 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 1220 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 1221 | "dev": true, 1222 | "requires": { 1223 | "balanced-match": "^1.0.0" 1224 | } 1225 | }, 1226 | "minimatch": { 1227 | "version": "5.1.0", 1228 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.0.tgz", 1229 | "integrity": "sha512-9TPBGGak4nHfGZsPBohm9AWg6NoT7QTCehS3BIJABslyZbzxfV78QM2Y6+i741OPZIafFAaiiEMh5OyIrJPgtg==", 1230 | "dev": true, 1231 | "requires": { 1232 | "brace-expansion": "^2.0.1" 1233 | } 1234 | } 1235 | } 1236 | }, 1237 | "glob-parent": { 1238 | "version": "5.1.2", 1239 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1240 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1241 | "dev": true, 1242 | "requires": { 1243 | "is-glob": "^4.0.1" 1244 | } 1245 | }, 1246 | "glob-to-regexp": { 1247 | "version": "0.4.1", 1248 | "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz", 1249 | "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==", 1250 | "dev": true 1251 | }, 1252 | "globals": { 1253 | "version": "13.15.0", 1254 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.15.0.tgz", 1255 | "integrity": "sha512-bpzcOlgDhMG070Av0Vy5Owklpv1I6+j96GhUI7Rh7IzDCKLzboflLrrfqMu8NquDbiR4EOQk7XzJwqVJxicxog==", 1256 | "dev": true, 1257 | "requires": { 1258 | "type-fest": "^0.20.2" 1259 | } 1260 | }, 1261 | "globby": { 1262 | "version": "11.1.0", 1263 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 1264 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 1265 | "dev": true, 1266 | "requires": { 1267 | "array-union": "^2.1.0", 1268 | "dir-glob": "^3.0.1", 1269 | "fast-glob": "^3.2.9", 1270 | "ignore": "^5.2.0", 1271 | "merge2": "^1.4.1", 1272 | "slash": "^3.0.0" 1273 | } 1274 | }, 1275 | "graceful-fs": { 1276 | "version": "4.2.10", 1277 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", 1278 | "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==", 1279 | "dev": true 1280 | }, 1281 | "growl": { 1282 | "version": "1.10.5", 1283 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 1284 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 1285 | "dev": true 1286 | }, 1287 | "has": { 1288 | "version": "1.0.3", 1289 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1290 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1291 | "dev": true, 1292 | "requires": { 1293 | "function-bind": "^1.1.1" 1294 | } 1295 | }, 1296 | "has-flag": { 1297 | "version": "4.0.0", 1298 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1299 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1300 | "dev": true 1301 | }, 1302 | "he": { 1303 | "version": "1.2.0", 1304 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1305 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1306 | "dev": true 1307 | }, 1308 | "http-proxy-agent": { 1309 | "version": "4.0.1", 1310 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 1311 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 1312 | "dev": true, 1313 | "requires": { 1314 | "@tootallnate/once": "1", 1315 | "agent-base": "6", 1316 | "debug": "4" 1317 | } 1318 | }, 1319 | "https-proxy-agent": { 1320 | "version": "5.0.1", 1321 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", 1322 | "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", 1323 | "dev": true, 1324 | "requires": { 1325 | "agent-base": "6", 1326 | "debug": "4" 1327 | } 1328 | }, 1329 | "human-signals": { 1330 | "version": "2.1.0", 1331 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", 1332 | "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", 1333 | "dev": true 1334 | }, 1335 | "ignore": { 1336 | "version": "5.2.0", 1337 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.0.tgz", 1338 | "integrity": "sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ==", 1339 | "dev": true 1340 | }, 1341 | "import-fresh": { 1342 | "version": "3.3.0", 1343 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1344 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1345 | "dev": true, 1346 | "requires": { 1347 | "parent-module": "^1.0.0", 1348 | "resolve-from": "^4.0.0" 1349 | } 1350 | }, 1351 | "import-local": { 1352 | "version": "3.1.0", 1353 | "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz", 1354 | "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==", 1355 | "dev": true, 1356 | "requires": { 1357 | "pkg-dir": "^4.2.0", 1358 | "resolve-cwd": "^3.0.0" 1359 | } 1360 | }, 1361 | "imurmurhash": { 1362 | "version": "0.1.4", 1363 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1364 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1365 | "dev": true 1366 | }, 1367 | "inflight": { 1368 | "version": "1.0.6", 1369 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1370 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1371 | "dev": true, 1372 | "requires": { 1373 | "once": "^1.3.0", 1374 | "wrappy": "1" 1375 | } 1376 | }, 1377 | "inherits": { 1378 | "version": "2.0.4", 1379 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1380 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1381 | "dev": true 1382 | }, 1383 | "interpret": { 1384 | "version": "2.2.0", 1385 | "resolved": "https://registry.npmjs.org/interpret/-/interpret-2.2.0.tgz", 1386 | "integrity": "sha512-Ju0Bz/cEia55xDwUWEa8+olFpCiQoypjnQySseKtmjNrnps3P+xfpUmGr90T7yjlVJmOtybRvPXhKMbHr+fWnw==", 1387 | "dev": true 1388 | }, 1389 | "is-binary-path": { 1390 | "version": "2.1.0", 1391 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1392 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1393 | "dev": true, 1394 | "requires": { 1395 | "binary-extensions": "^2.0.0" 1396 | } 1397 | }, 1398 | "is-core-module": { 1399 | "version": "2.9.0", 1400 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.9.0.tgz", 1401 | "integrity": "sha512-+5FPy5PnwmO3lvfMb0AsoPaBG+5KHUI0wYFXOtYPnVVVspTFUuMZNfNaNVRt3FZadstu2c8x23vykRW/NBoU6A==", 1402 | "dev": true, 1403 | "requires": { 1404 | "has": "^1.0.3" 1405 | } 1406 | }, 1407 | "is-extglob": { 1408 | "version": "2.1.1", 1409 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1410 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1411 | "dev": true 1412 | }, 1413 | "is-fullwidth-code-point": { 1414 | "version": "3.0.0", 1415 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1416 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1417 | "dev": true 1418 | }, 1419 | "is-glob": { 1420 | "version": "4.0.3", 1421 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1422 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1423 | "dev": true, 1424 | "requires": { 1425 | "is-extglob": "^2.1.1" 1426 | } 1427 | }, 1428 | "is-number": { 1429 | "version": "7.0.0", 1430 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1431 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1432 | "dev": true 1433 | }, 1434 | "is-plain-obj": { 1435 | "version": "2.1.0", 1436 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 1437 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 1438 | "dev": true 1439 | }, 1440 | "is-plain-object": { 1441 | "version": "2.0.4", 1442 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", 1443 | "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", 1444 | "dev": true, 1445 | "requires": { 1446 | "isobject": "^3.0.1" 1447 | } 1448 | }, 1449 | "is-stream": { 1450 | "version": "2.0.1", 1451 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", 1452 | "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", 1453 | "dev": true 1454 | }, 1455 | "is-unicode-supported": { 1456 | "version": "0.1.0", 1457 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 1458 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 1459 | "dev": true 1460 | }, 1461 | "isarray": { 1462 | "version": "1.0.0", 1463 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1464 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1465 | "dev": true 1466 | }, 1467 | "isexe": { 1468 | "version": "2.0.0", 1469 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1470 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1471 | "dev": true 1472 | }, 1473 | "isobject": { 1474 | "version": "3.0.1", 1475 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", 1476 | "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", 1477 | "dev": true 1478 | }, 1479 | "jest-worker": { 1480 | "version": "27.5.1", 1481 | "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-27.5.1.tgz", 1482 | "integrity": "sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg==", 1483 | "dev": true, 1484 | "requires": { 1485 | "@types/node": "*", 1486 | "merge-stream": "^2.0.0", 1487 | "supports-color": "^8.0.0" 1488 | }, 1489 | "dependencies": { 1490 | "supports-color": { 1491 | "version": "8.1.1", 1492 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 1493 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 1494 | "dev": true, 1495 | "requires": { 1496 | "has-flag": "^4.0.0" 1497 | } 1498 | } 1499 | } 1500 | }, 1501 | "js-yaml": { 1502 | "version": "4.1.0", 1503 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1504 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1505 | "dev": true, 1506 | "requires": { 1507 | "argparse": "^2.0.1" 1508 | } 1509 | }, 1510 | "json-parse-even-better-errors": { 1511 | "version": "2.3.1", 1512 | "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", 1513 | "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", 1514 | "dev": true 1515 | }, 1516 | "json-schema-traverse": { 1517 | "version": "0.4.1", 1518 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1519 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1520 | "dev": true 1521 | }, 1522 | "json-stable-stringify-without-jsonify": { 1523 | "version": "1.0.1", 1524 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1525 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1526 | "dev": true 1527 | }, 1528 | "kind-of": { 1529 | "version": "6.0.3", 1530 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", 1531 | "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", 1532 | "dev": true 1533 | }, 1534 | "levn": { 1535 | "version": "0.4.1", 1536 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1537 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1538 | "dev": true, 1539 | "requires": { 1540 | "prelude-ls": "^1.2.1", 1541 | "type-check": "~0.4.0" 1542 | } 1543 | }, 1544 | "listenercount": { 1545 | "version": "1.0.1", 1546 | "resolved": "https://registry.npmjs.org/listenercount/-/listenercount-1.0.1.tgz", 1547 | "integrity": "sha1-hMinKrWcRyUyFIDJdeZQg0LnCTc=", 1548 | "dev": true 1549 | }, 1550 | "loader-runner": { 1551 | "version": "4.3.0", 1552 | "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-4.3.0.tgz", 1553 | "integrity": "sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg==", 1554 | "dev": true 1555 | }, 1556 | "locate-path": { 1557 | "version": "6.0.0", 1558 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1559 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1560 | "dev": true, 1561 | "requires": { 1562 | "p-locate": "^5.0.0" 1563 | } 1564 | }, 1565 | "lodash.merge": { 1566 | "version": "4.6.2", 1567 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1568 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1569 | "dev": true 1570 | }, 1571 | "lodash.sortby": { 1572 | "version": "4.7.0", 1573 | "resolved": "https://registry.npmjs.org/lodash.sortby/-/lodash.sortby-4.7.0.tgz", 1574 | "integrity": "sha1-7dFMgk4sycHgsKG0K7UhBRakJDg=", 1575 | "dev": true 1576 | }, 1577 | "log-symbols": { 1578 | "version": "4.1.0", 1579 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 1580 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 1581 | "dev": true, 1582 | "requires": { 1583 | "chalk": "^4.1.0", 1584 | "is-unicode-supported": "^0.1.0" 1585 | } 1586 | }, 1587 | "lru-cache": { 1588 | "version": "6.0.0", 1589 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1590 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1591 | "dev": true, 1592 | "requires": { 1593 | "yallist": "^4.0.0" 1594 | } 1595 | }, 1596 | "merge-stream": { 1597 | "version": "2.0.0", 1598 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 1599 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 1600 | "dev": true 1601 | }, 1602 | "merge2": { 1603 | "version": "1.4.1", 1604 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 1605 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 1606 | "dev": true 1607 | }, 1608 | "micromatch": { 1609 | "version": "4.0.5", 1610 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 1611 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 1612 | "dev": true, 1613 | "requires": { 1614 | "braces": "^3.0.2", 1615 | "picomatch": "^2.3.1" 1616 | } 1617 | }, 1618 | "mime-db": { 1619 | "version": "1.52.0", 1620 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 1621 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 1622 | "dev": true 1623 | }, 1624 | "mime-types": { 1625 | "version": "2.1.35", 1626 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 1627 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 1628 | "dev": true, 1629 | "requires": { 1630 | "mime-db": "1.52.0" 1631 | } 1632 | }, 1633 | "mimic-fn": { 1634 | "version": "2.1.0", 1635 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1636 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1637 | "dev": true 1638 | }, 1639 | "minimatch": { 1640 | "version": "3.1.2", 1641 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1642 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1643 | "dev": true, 1644 | "requires": { 1645 | "brace-expansion": "^1.1.7" 1646 | } 1647 | }, 1648 | "minimist": { 1649 | "version": "1.2.6", 1650 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz", 1651 | "integrity": "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==", 1652 | "dev": true 1653 | }, 1654 | "mkdirp": { 1655 | "version": "0.5.6", 1656 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", 1657 | "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", 1658 | "dev": true, 1659 | "requires": { 1660 | "minimist": "^1.2.6" 1661 | } 1662 | }, 1663 | "mocha": { 1664 | "version": "9.2.2", 1665 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-9.2.2.tgz", 1666 | "integrity": "sha512-L6XC3EdwT6YrIk0yXpavvLkn8h+EU+Y5UcCHKECyMbdUIxyMuZj4bX4U9e1nvnvUUvQVsV2VHQr5zLdcUkhW/g==", 1667 | "dev": true, 1668 | "requires": { 1669 | "@ungap/promise-all-settled": "1.1.2", 1670 | "ansi-colors": "4.1.1", 1671 | "browser-stdout": "1.3.1", 1672 | "chokidar": "3.5.3", 1673 | "debug": "4.3.3", 1674 | "diff": "5.0.0", 1675 | "escape-string-regexp": "4.0.0", 1676 | "find-up": "5.0.0", 1677 | "glob": "7.2.0", 1678 | "growl": "1.10.5", 1679 | "he": "1.2.0", 1680 | "js-yaml": "4.1.0", 1681 | "log-symbols": "4.1.0", 1682 | "minimatch": "4.2.1", 1683 | "ms": "2.1.3", 1684 | "nanoid": "3.3.1", 1685 | "serialize-javascript": "6.0.0", 1686 | "strip-json-comments": "3.1.1", 1687 | "supports-color": "8.1.1", 1688 | "which": "2.0.2", 1689 | "workerpool": "6.2.0", 1690 | "yargs": "16.2.0", 1691 | "yargs-parser": "20.2.4", 1692 | "yargs-unparser": "2.0.0" 1693 | }, 1694 | "dependencies": { 1695 | "debug": { 1696 | "version": "4.3.3", 1697 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", 1698 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", 1699 | "dev": true, 1700 | "requires": { 1701 | "ms": "2.1.2" 1702 | }, 1703 | "dependencies": { 1704 | "ms": { 1705 | "version": "2.1.2", 1706 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1707 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1708 | "dev": true 1709 | } 1710 | } 1711 | }, 1712 | "glob": { 1713 | "version": "7.2.0", 1714 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 1715 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 1716 | "dev": true, 1717 | "requires": { 1718 | "fs.realpath": "^1.0.0", 1719 | "inflight": "^1.0.4", 1720 | "inherits": "2", 1721 | "minimatch": "^3.0.4", 1722 | "once": "^1.3.0", 1723 | "path-is-absolute": "^1.0.0" 1724 | }, 1725 | "dependencies": { 1726 | "minimatch": { 1727 | "version": "3.1.2", 1728 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1729 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1730 | "dev": true, 1731 | "requires": { 1732 | "brace-expansion": "^1.1.7" 1733 | } 1734 | } 1735 | } 1736 | }, 1737 | "minimatch": { 1738 | "version": "4.2.1", 1739 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-4.2.1.tgz", 1740 | "integrity": "sha512-9Uq1ChtSZO+Mxa/CL1eGizn2vRn3MlLgzhT0Iz8zaY8NdvxvB0d5QdPFmCKf7JKA9Lerx5vRrnwO03jsSfGG9g==", 1741 | "dev": true, 1742 | "requires": { 1743 | "brace-expansion": "^1.1.7" 1744 | } 1745 | }, 1746 | "ms": { 1747 | "version": "2.1.3", 1748 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1749 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1750 | "dev": true 1751 | }, 1752 | "supports-color": { 1753 | "version": "8.1.1", 1754 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 1755 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 1756 | "dev": true, 1757 | "requires": { 1758 | "has-flag": "^4.0.0" 1759 | } 1760 | } 1761 | } 1762 | }, 1763 | "ms": { 1764 | "version": "2.1.2", 1765 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1766 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1767 | "dev": true 1768 | }, 1769 | "nanoid": { 1770 | "version": "3.3.1", 1771 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.1.tgz", 1772 | "integrity": "sha512-n6Vs/3KGyxPQd6uO0eH4Bv0ojGSUvuLlIHtC3Y0kEO23YRge8H9x1GCzLn28YX0H66pMkxuaeESFq4tKISKwdw==", 1773 | "dev": true 1774 | }, 1775 | "natural-compare": { 1776 | "version": "1.4.0", 1777 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1778 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1779 | "dev": true 1780 | }, 1781 | "neo-async": { 1782 | "version": "2.6.2", 1783 | "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz", 1784 | "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==", 1785 | "dev": true 1786 | }, 1787 | "node-releases": { 1788 | "version": "2.0.5", 1789 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.5.tgz", 1790 | "integrity": "sha512-U9h1NLROZTq9uE1SNffn6WuPDg8icmi3ns4rEl/oTfIle4iLjTliCzgTsbaIFMq/Xn078/lfY/BL0GWZ+psK4Q==", 1791 | "dev": true 1792 | }, 1793 | "normalize-path": { 1794 | "version": "3.0.0", 1795 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1796 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1797 | "dev": true 1798 | }, 1799 | "npm-run-path": { 1800 | "version": "4.0.1", 1801 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", 1802 | "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", 1803 | "dev": true, 1804 | "requires": { 1805 | "path-key": "^3.0.0" 1806 | } 1807 | }, 1808 | "once": { 1809 | "version": "1.4.0", 1810 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1811 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1812 | "dev": true, 1813 | "requires": { 1814 | "wrappy": "1" 1815 | } 1816 | }, 1817 | "onetime": { 1818 | "version": "5.1.2", 1819 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 1820 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 1821 | "dev": true, 1822 | "requires": { 1823 | "mimic-fn": "^2.1.0" 1824 | } 1825 | }, 1826 | "optionator": { 1827 | "version": "0.9.1", 1828 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1829 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1830 | "dev": true, 1831 | "requires": { 1832 | "deep-is": "^0.1.3", 1833 | "fast-levenshtein": "^2.0.6", 1834 | "levn": "^0.4.1", 1835 | "prelude-ls": "^1.2.1", 1836 | "type-check": "^0.4.0", 1837 | "word-wrap": "^1.2.3" 1838 | } 1839 | }, 1840 | "p-limit": { 1841 | "version": "3.1.0", 1842 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1843 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1844 | "dev": true, 1845 | "requires": { 1846 | "yocto-queue": "^0.1.0" 1847 | } 1848 | }, 1849 | "p-locate": { 1850 | "version": "5.0.0", 1851 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1852 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1853 | "dev": true, 1854 | "requires": { 1855 | "p-limit": "^3.0.2" 1856 | } 1857 | }, 1858 | "p-try": { 1859 | "version": "2.2.0", 1860 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1861 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 1862 | "dev": true 1863 | }, 1864 | "parent-module": { 1865 | "version": "1.0.1", 1866 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1867 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1868 | "dev": true, 1869 | "requires": { 1870 | "callsites": "^3.0.0" 1871 | } 1872 | }, 1873 | "path-exists": { 1874 | "version": "4.0.0", 1875 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1876 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1877 | "dev": true 1878 | }, 1879 | "path-is-absolute": { 1880 | "version": "1.0.1", 1881 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1882 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1883 | "dev": true 1884 | }, 1885 | "path-key": { 1886 | "version": "3.1.1", 1887 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1888 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1889 | "dev": true 1890 | }, 1891 | "path-parse": { 1892 | "version": "1.0.7", 1893 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1894 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1895 | "dev": true 1896 | }, 1897 | "path-type": { 1898 | "version": "4.0.0", 1899 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 1900 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 1901 | "dev": true 1902 | }, 1903 | "picocolors": { 1904 | "version": "1.0.0", 1905 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 1906 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 1907 | "dev": true 1908 | }, 1909 | "picomatch": { 1910 | "version": "2.3.1", 1911 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1912 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1913 | "dev": true 1914 | }, 1915 | "pkg-dir": { 1916 | "version": "4.2.0", 1917 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", 1918 | "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", 1919 | "dev": true, 1920 | "requires": { 1921 | "find-up": "^4.0.0" 1922 | }, 1923 | "dependencies": { 1924 | "find-up": { 1925 | "version": "4.1.0", 1926 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 1927 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 1928 | "dev": true, 1929 | "requires": { 1930 | "locate-path": "^5.0.0", 1931 | "path-exists": "^4.0.0" 1932 | } 1933 | }, 1934 | "locate-path": { 1935 | "version": "5.0.0", 1936 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 1937 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 1938 | "dev": true, 1939 | "requires": { 1940 | "p-locate": "^4.1.0" 1941 | } 1942 | }, 1943 | "p-limit": { 1944 | "version": "2.3.0", 1945 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 1946 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 1947 | "dev": true, 1948 | "requires": { 1949 | "p-try": "^2.0.0" 1950 | } 1951 | }, 1952 | "p-locate": { 1953 | "version": "4.1.0", 1954 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 1955 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 1956 | "dev": true, 1957 | "requires": { 1958 | "p-limit": "^2.2.0" 1959 | } 1960 | } 1961 | } 1962 | }, 1963 | "prelude-ls": { 1964 | "version": "1.2.1", 1965 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1966 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1967 | "dev": true 1968 | }, 1969 | "process-nextick-args": { 1970 | "version": "2.0.1", 1971 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 1972 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 1973 | "dev": true 1974 | }, 1975 | "punycode": { 1976 | "version": "2.1.1", 1977 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1978 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1979 | "dev": true 1980 | }, 1981 | "queue-microtask": { 1982 | "version": "1.2.3", 1983 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 1984 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 1985 | "dev": true 1986 | }, 1987 | "randombytes": { 1988 | "version": "2.1.0", 1989 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1990 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1991 | "dev": true, 1992 | "requires": { 1993 | "safe-buffer": "^5.1.0" 1994 | } 1995 | }, 1996 | "readable-stream": { 1997 | "version": "2.3.7", 1998 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 1999 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 2000 | "dev": true, 2001 | "requires": { 2002 | "core-util-is": "~1.0.0", 2003 | "inherits": "~2.0.3", 2004 | "isarray": "~1.0.0", 2005 | "process-nextick-args": "~2.0.0", 2006 | "safe-buffer": "~5.1.1", 2007 | "string_decoder": "~1.1.1", 2008 | "util-deprecate": "~1.0.1" 2009 | } 2010 | }, 2011 | "readdirp": { 2012 | "version": "3.6.0", 2013 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 2014 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 2015 | "dev": true, 2016 | "requires": { 2017 | "picomatch": "^2.2.1" 2018 | } 2019 | }, 2020 | "rechoir": { 2021 | "version": "0.7.1", 2022 | "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.7.1.tgz", 2023 | "integrity": "sha512-/njmZ8s1wVeR6pjTZ+0nCnv8SpZNRMT2D1RLOJQESlYFDBvwpTA4KWJpZ+sBJ4+vhjILRcK7JIFdGCdxEAAitg==", 2024 | "dev": true, 2025 | "requires": { 2026 | "resolve": "^1.9.0" 2027 | } 2028 | }, 2029 | "regexpp": { 2030 | "version": "3.2.0", 2031 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 2032 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 2033 | "dev": true 2034 | }, 2035 | "require-directory": { 2036 | "version": "2.1.1", 2037 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2038 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 2039 | "dev": true 2040 | }, 2041 | "resolve": { 2042 | "version": "1.22.0", 2043 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.0.tgz", 2044 | "integrity": "sha512-Hhtrw0nLeSrFQ7phPp4OOcVjLPIeMnRlr5mcnVuMe7M/7eBn98A3hmFRLoFo3DLZkivSYwhRUJTyPyWAk56WLw==", 2045 | "dev": true, 2046 | "requires": { 2047 | "is-core-module": "^2.8.1", 2048 | "path-parse": "^1.0.7", 2049 | "supports-preserve-symlinks-flag": "^1.0.0" 2050 | } 2051 | }, 2052 | "resolve-cwd": { 2053 | "version": "3.0.0", 2054 | "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", 2055 | "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==", 2056 | "dev": true, 2057 | "requires": { 2058 | "resolve-from": "^5.0.0" 2059 | }, 2060 | "dependencies": { 2061 | "resolve-from": { 2062 | "version": "5.0.0", 2063 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", 2064 | "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", 2065 | "dev": true 2066 | } 2067 | } 2068 | }, 2069 | "resolve-from": { 2070 | "version": "4.0.0", 2071 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2072 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2073 | "dev": true 2074 | }, 2075 | "reusify": { 2076 | "version": "1.0.4", 2077 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2078 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2079 | "dev": true 2080 | }, 2081 | "rimraf": { 2082 | "version": "3.0.2", 2083 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2084 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2085 | "dev": true, 2086 | "requires": { 2087 | "glob": "^7.1.3" 2088 | }, 2089 | "dependencies": { 2090 | "glob": { 2091 | "version": "7.2.3", 2092 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2093 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2094 | "dev": true, 2095 | "requires": { 2096 | "fs.realpath": "^1.0.0", 2097 | "inflight": "^1.0.4", 2098 | "inherits": "2", 2099 | "minimatch": "^3.1.1", 2100 | "once": "^1.3.0", 2101 | "path-is-absolute": "^1.0.0" 2102 | } 2103 | } 2104 | } 2105 | }, 2106 | "run-parallel": { 2107 | "version": "1.2.0", 2108 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2109 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2110 | "dev": true, 2111 | "requires": { 2112 | "queue-microtask": "^1.2.2" 2113 | } 2114 | }, 2115 | "safe-buffer": { 2116 | "version": "5.1.2", 2117 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2118 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 2119 | "dev": true 2120 | }, 2121 | "schema-utils": { 2122 | "version": "3.1.1", 2123 | "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.1.1.tgz", 2124 | "integrity": "sha512-Y5PQxS4ITlC+EahLuXaY86TXfR7Dc5lw294alXOq86JAHCihAIZfqv8nNCWvaEJvaC51uN9hbLGeV0cFBdH+Fw==", 2125 | "dev": true, 2126 | "requires": { 2127 | "@types/json-schema": "^7.0.8", 2128 | "ajv": "^6.12.5", 2129 | "ajv-keywords": "^3.5.2" 2130 | } 2131 | }, 2132 | "semver": { 2133 | "version": "7.3.7", 2134 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz", 2135 | "integrity": "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==", 2136 | "dev": true, 2137 | "requires": { 2138 | "lru-cache": "^6.0.0" 2139 | } 2140 | }, 2141 | "serialize-javascript": { 2142 | "version": "6.0.0", 2143 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 2144 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 2145 | "dev": true, 2146 | "requires": { 2147 | "randombytes": "^2.1.0" 2148 | } 2149 | }, 2150 | "setimmediate": { 2151 | "version": "1.0.5", 2152 | "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", 2153 | "integrity": "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU=", 2154 | "dev": true 2155 | }, 2156 | "shallow-clone": { 2157 | "version": "3.0.1", 2158 | "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-3.0.1.tgz", 2159 | "integrity": "sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA==", 2160 | "dev": true, 2161 | "requires": { 2162 | "kind-of": "^6.0.2" 2163 | } 2164 | }, 2165 | "shebang-command": { 2166 | "version": "2.0.0", 2167 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2168 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2169 | "dev": true, 2170 | "requires": { 2171 | "shebang-regex": "^3.0.0" 2172 | } 2173 | }, 2174 | "shebang-regex": { 2175 | "version": "3.0.0", 2176 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2177 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2178 | "dev": true 2179 | }, 2180 | "signal-exit": { 2181 | "version": "3.0.7", 2182 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 2183 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 2184 | "dev": true 2185 | }, 2186 | "slash": { 2187 | "version": "3.0.0", 2188 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 2189 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 2190 | "dev": true 2191 | }, 2192 | "source-map": { 2193 | "version": "0.6.1", 2194 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2195 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 2196 | "dev": true 2197 | }, 2198 | "source-map-support": { 2199 | "version": "0.5.21", 2200 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 2201 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 2202 | "dev": true, 2203 | "requires": { 2204 | "buffer-from": "^1.0.0", 2205 | "source-map": "^0.6.0" 2206 | } 2207 | }, 2208 | "string-width": { 2209 | "version": "4.2.3", 2210 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2211 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2212 | "dev": true, 2213 | "requires": { 2214 | "emoji-regex": "^8.0.0", 2215 | "is-fullwidth-code-point": "^3.0.0", 2216 | "strip-ansi": "^6.0.1" 2217 | } 2218 | }, 2219 | "string_decoder": { 2220 | "version": "1.1.1", 2221 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2222 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2223 | "dev": true, 2224 | "requires": { 2225 | "safe-buffer": "~5.1.0" 2226 | } 2227 | }, 2228 | "strip-ansi": { 2229 | "version": "6.0.1", 2230 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2231 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2232 | "dev": true, 2233 | "requires": { 2234 | "ansi-regex": "^5.0.1" 2235 | } 2236 | }, 2237 | "strip-final-newline": { 2238 | "version": "2.0.0", 2239 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", 2240 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", 2241 | "dev": true 2242 | }, 2243 | "strip-json-comments": { 2244 | "version": "3.1.1", 2245 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2246 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2247 | "dev": true 2248 | }, 2249 | "supports-color": { 2250 | "version": "7.2.0", 2251 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2252 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2253 | "dev": true, 2254 | "requires": { 2255 | "has-flag": "^4.0.0" 2256 | } 2257 | }, 2258 | "supports-preserve-symlinks-flag": { 2259 | "version": "1.0.0", 2260 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 2261 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 2262 | "dev": true 2263 | }, 2264 | "tapable": { 2265 | "version": "2.2.1", 2266 | "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.1.tgz", 2267 | "integrity": "sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==", 2268 | "dev": true 2269 | }, 2270 | "terser": { 2271 | "version": "5.13.1", 2272 | "resolved": "https://registry.npmjs.org/terser/-/terser-5.13.1.tgz", 2273 | "integrity": "sha512-hn4WKOfwnwbYfe48NgrQjqNOH9jzLqRcIfbYytOXCOv46LBfWr9bDS17MQqOi+BWGD0sJK3Sj5NC/gJjiojaoA==", 2274 | "dev": true, 2275 | "requires": { 2276 | "acorn": "^8.5.0", 2277 | "commander": "^2.20.0", 2278 | "source-map": "~0.8.0-beta.0", 2279 | "source-map-support": "~0.5.20" 2280 | }, 2281 | "dependencies": { 2282 | "source-map": { 2283 | "version": "0.8.0-beta.0", 2284 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.8.0-beta.0.tgz", 2285 | "integrity": "sha512-2ymg6oRBpebeZi9UUNsgQ89bhx01TcTkmNTGnNO88imTmbSgy4nfujrgVEFKWpMTEGA11EDkTt7mqObTPdigIA==", 2286 | "dev": true, 2287 | "requires": { 2288 | "whatwg-url": "^7.0.0" 2289 | } 2290 | } 2291 | } 2292 | }, 2293 | "terser-webpack-plugin": { 2294 | "version": "5.3.1", 2295 | "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.3.1.tgz", 2296 | "integrity": "sha512-GvlZdT6wPQKbDNW/GDQzZFg/j4vKU96yl2q6mcUkzKOgW4gwf1Z8cZToUCrz31XHlPWH8MVb1r2tFtdDtTGJ7g==", 2297 | "dev": true, 2298 | "requires": { 2299 | "jest-worker": "^27.4.5", 2300 | "schema-utils": "^3.1.1", 2301 | "serialize-javascript": "^6.0.0", 2302 | "source-map": "^0.6.1", 2303 | "terser": "^5.7.2" 2304 | } 2305 | }, 2306 | "text-table": { 2307 | "version": "0.2.0", 2308 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2309 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2310 | "dev": true 2311 | }, 2312 | "to-regex-range": { 2313 | "version": "5.0.1", 2314 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2315 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2316 | "dev": true, 2317 | "requires": { 2318 | "is-number": "^7.0.0" 2319 | } 2320 | }, 2321 | "tr46": { 2322 | "version": "1.0.1", 2323 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-1.0.1.tgz", 2324 | "integrity": "sha1-qLE/1r/SSJUZZ0zN5VujaTtwbQk=", 2325 | "dev": true, 2326 | "requires": { 2327 | "punycode": "^2.1.0" 2328 | } 2329 | }, 2330 | "traverse": { 2331 | "version": "0.3.9", 2332 | "resolved": "https://registry.npmjs.org/traverse/-/traverse-0.3.9.tgz", 2333 | "integrity": "sha1-cXuPIgzAu3tE5AUUwisui7xw2Lk=", 2334 | "dev": true 2335 | }, 2336 | "ts-loader": { 2337 | "version": "9.3.0", 2338 | "resolved": "https://registry.npmjs.org/ts-loader/-/ts-loader-9.3.0.tgz", 2339 | "integrity": "sha512-2kLLAdAD+FCKijvGKi9sS0OzoqxLCF3CxHpok7rVgCZ5UldRzH0TkbwG9XECKjBzHsAewntC5oDaI/FwKzEUog==", 2340 | "dev": true, 2341 | "requires": { 2342 | "chalk": "^4.1.0", 2343 | "enhanced-resolve": "^5.0.0", 2344 | "micromatch": "^4.0.0", 2345 | "semver": "^7.3.4" 2346 | } 2347 | }, 2348 | "tslib": { 2349 | "version": "1.14.1", 2350 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 2351 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 2352 | "dev": true 2353 | }, 2354 | "tsutils": { 2355 | "version": "3.21.0", 2356 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", 2357 | "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", 2358 | "dev": true, 2359 | "requires": { 2360 | "tslib": "^1.8.1" 2361 | } 2362 | }, 2363 | "type-check": { 2364 | "version": "0.4.0", 2365 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2366 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2367 | "dev": true, 2368 | "requires": { 2369 | "prelude-ls": "^1.2.1" 2370 | } 2371 | }, 2372 | "type-fest": { 2373 | "version": "0.20.2", 2374 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 2375 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 2376 | "dev": true 2377 | }, 2378 | "typescript": { 2379 | "version": "4.7.2", 2380 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.7.2.tgz", 2381 | "integrity": "sha512-Mamb1iX2FDUpcTRzltPxgWMKy3fhg0TN378ylbktPGPK/99KbDtMQ4W1hwgsbPAsG3a0xKa1vmw4VKZQbkvz5A==", 2382 | "dev": true 2383 | }, 2384 | "unzipper": { 2385 | "version": "0.10.11", 2386 | "resolved": "https://registry.npmjs.org/unzipper/-/unzipper-0.10.11.tgz", 2387 | "integrity": "sha512-+BrAq2oFqWod5IESRjL3S8baohbevGcVA+teAIOYWM3pDVdseogqbzhhvvmiyQrUNKFUnDMtELW3X8ykbyDCJw==", 2388 | "dev": true, 2389 | "requires": { 2390 | "big-integer": "^1.6.17", 2391 | "binary": "~0.3.0", 2392 | "bluebird": "~3.4.1", 2393 | "buffer-indexof-polyfill": "~1.0.0", 2394 | "duplexer2": "~0.1.4", 2395 | "fstream": "^1.0.12", 2396 | "graceful-fs": "^4.2.2", 2397 | "listenercount": "~1.0.1", 2398 | "readable-stream": "~2.3.6", 2399 | "setimmediate": "~1.0.4" 2400 | } 2401 | }, 2402 | "uri-js": { 2403 | "version": "4.4.1", 2404 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 2405 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 2406 | "dev": true, 2407 | "requires": { 2408 | "punycode": "^2.1.0" 2409 | } 2410 | }, 2411 | "util-deprecate": { 2412 | "version": "1.0.2", 2413 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2414 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 2415 | "dev": true 2416 | }, 2417 | "v8-compile-cache": { 2418 | "version": "2.3.0", 2419 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 2420 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 2421 | "dev": true 2422 | }, 2423 | "watchpack": { 2424 | "version": "2.3.1", 2425 | "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-2.3.1.tgz", 2426 | "integrity": "sha512-x0t0JuydIo8qCNctdDrn1OzH/qDzk2+rdCOC3YzumZ42fiMqmQ7T3xQurykYMhYfHaPHTp4ZxAx2NfUo1K6QaA==", 2427 | "dev": true, 2428 | "requires": { 2429 | "glob-to-regexp": "^0.4.1", 2430 | "graceful-fs": "^4.1.2" 2431 | } 2432 | }, 2433 | "webidl-conversions": { 2434 | "version": "4.0.2", 2435 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-4.0.2.tgz", 2436 | "integrity": "sha512-YQ+BmxuTgd6UXZW3+ICGfyqRyHXVlD5GtQr5+qjiNW7bF0cqrzX500HVXPBOvgXb5YnzDd+h0zqyv61KUD7+Sg==", 2437 | "dev": true 2438 | }, 2439 | "webpack": { 2440 | "version": "5.72.1", 2441 | "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.72.1.tgz", 2442 | "integrity": "sha512-dXG5zXCLspQR4krZVR6QgajnZOjW2K/djHvdcRaDQvsjV9z9vaW6+ja5dZOYbqBBjF6kGXka/2ZyxNdc+8Jung==", 2443 | "dev": true, 2444 | "requires": { 2445 | "@types/eslint-scope": "^3.7.3", 2446 | "@types/estree": "^0.0.51", 2447 | "@webassemblyjs/ast": "1.11.1", 2448 | "@webassemblyjs/wasm-edit": "1.11.1", 2449 | "@webassemblyjs/wasm-parser": "1.11.1", 2450 | "acorn": "^8.4.1", 2451 | "acorn-import-assertions": "^1.7.6", 2452 | "browserslist": "^4.14.5", 2453 | "chrome-trace-event": "^1.0.2", 2454 | "enhanced-resolve": "^5.9.3", 2455 | "es-module-lexer": "^0.9.0", 2456 | "eslint-scope": "5.1.1", 2457 | "events": "^3.2.0", 2458 | "glob-to-regexp": "^0.4.1", 2459 | "graceful-fs": "^4.2.9", 2460 | "json-parse-even-better-errors": "^2.3.1", 2461 | "loader-runner": "^4.2.0", 2462 | "mime-types": "^2.1.27", 2463 | "neo-async": "^2.6.2", 2464 | "schema-utils": "^3.1.0", 2465 | "tapable": "^2.1.1", 2466 | "terser-webpack-plugin": "^5.1.3", 2467 | "watchpack": "^2.3.1", 2468 | "webpack-sources": "^3.2.3" 2469 | } 2470 | }, 2471 | "webpack-cli": { 2472 | "version": "4.9.2", 2473 | "resolved": "https://registry.npmjs.org/webpack-cli/-/webpack-cli-4.9.2.tgz", 2474 | "integrity": "sha512-m3/AACnBBzK/kMTcxWHcZFPrw/eQuY4Df1TxvIWfWM2x7mRqBQCqKEd96oCUa9jkapLBaFfRce33eGDb4Pr7YQ==", 2475 | "dev": true, 2476 | "requires": { 2477 | "@discoveryjs/json-ext": "^0.5.0", 2478 | "@webpack-cli/configtest": "^1.1.1", 2479 | "@webpack-cli/info": "^1.4.1", 2480 | "@webpack-cli/serve": "^1.6.1", 2481 | "colorette": "^2.0.14", 2482 | "commander": "^7.0.0", 2483 | "execa": "^5.0.0", 2484 | "fastest-levenshtein": "^1.0.12", 2485 | "import-local": "^3.0.2", 2486 | "interpret": "^2.2.0", 2487 | "rechoir": "^0.7.0", 2488 | "webpack-merge": "^5.7.3" 2489 | }, 2490 | "dependencies": { 2491 | "commander": { 2492 | "version": "7.2.0", 2493 | "resolved": "https://registry.npmjs.org/commander/-/commander-7.2.0.tgz", 2494 | "integrity": "sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw==", 2495 | "dev": true 2496 | } 2497 | } 2498 | }, 2499 | "webpack-merge": { 2500 | "version": "5.8.0", 2501 | "resolved": "https://registry.npmjs.org/webpack-merge/-/webpack-merge-5.8.0.tgz", 2502 | "integrity": "sha512-/SaI7xY0831XwP6kzuwhKWVKDP9t1QY1h65lAFLbZqMPIuYcD9QAW4u9STIbU9kaJbPBB/geU/gLr1wDjOhQ+Q==", 2503 | "dev": true, 2504 | "requires": { 2505 | "clone-deep": "^4.0.1", 2506 | "wildcard": "^2.0.0" 2507 | } 2508 | }, 2509 | "webpack-sources": { 2510 | "version": "3.2.3", 2511 | "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-3.2.3.tgz", 2512 | "integrity": "sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w==", 2513 | "dev": true 2514 | }, 2515 | "whatwg-url": { 2516 | "version": "7.1.0", 2517 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-7.1.0.tgz", 2518 | "integrity": "sha512-WUu7Rg1DroM7oQvGWfOiAK21n74Gg+T4elXEQYkOhtyLeWiJFoOGLXPKI/9gzIie9CtwVLm8wtw6YJdKyxSjeg==", 2519 | "dev": true, 2520 | "requires": { 2521 | "lodash.sortby": "^4.7.0", 2522 | "tr46": "^1.0.1", 2523 | "webidl-conversions": "^4.0.2" 2524 | } 2525 | }, 2526 | "which": { 2527 | "version": "2.0.2", 2528 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2529 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2530 | "dev": true, 2531 | "requires": { 2532 | "isexe": "^2.0.0" 2533 | } 2534 | }, 2535 | "wildcard": { 2536 | "version": "2.0.0", 2537 | "resolved": "https://registry.npmjs.org/wildcard/-/wildcard-2.0.0.tgz", 2538 | "integrity": "sha512-JcKqAHLPxcdb9KM49dufGXn2x3ssnfjbcaQdLlfZsL9rH9wgDQjUtDxbo8NE0F6SFvydeu1VhZe7hZuHsB2/pw==", 2539 | "dev": true 2540 | }, 2541 | "word-wrap": { 2542 | "version": "1.2.3", 2543 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 2544 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 2545 | "dev": true 2546 | }, 2547 | "workerpool": { 2548 | "version": "6.2.0", 2549 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.0.tgz", 2550 | "integrity": "sha512-Rsk5qQHJ9eowMH28Jwhe8HEbmdYDX4lwoMWshiCXugjtHqMD9ZbiqSDLxcsfdqsETPzVUtX5s1Z5kStiIM6l4A==", 2551 | "dev": true 2552 | }, 2553 | "wrap-ansi": { 2554 | "version": "7.0.0", 2555 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2556 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2557 | "dev": true, 2558 | "requires": { 2559 | "ansi-styles": "^4.0.0", 2560 | "string-width": "^4.1.0", 2561 | "strip-ansi": "^6.0.0" 2562 | } 2563 | }, 2564 | "wrappy": { 2565 | "version": "1.0.2", 2566 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2567 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2568 | "dev": true 2569 | }, 2570 | "y18n": { 2571 | "version": "5.0.8", 2572 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 2573 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 2574 | "dev": true 2575 | }, 2576 | "yallist": { 2577 | "version": "4.0.0", 2578 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2579 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2580 | "dev": true 2581 | }, 2582 | "yargs": { 2583 | "version": "16.2.0", 2584 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 2585 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 2586 | "dev": true, 2587 | "requires": { 2588 | "cliui": "^7.0.2", 2589 | "escalade": "^3.1.1", 2590 | "get-caller-file": "^2.0.5", 2591 | "require-directory": "^2.1.1", 2592 | "string-width": "^4.2.0", 2593 | "y18n": "^5.0.5", 2594 | "yargs-parser": "^20.2.2" 2595 | } 2596 | }, 2597 | "yargs-parser": { 2598 | "version": "20.2.4", 2599 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 2600 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 2601 | "dev": true 2602 | }, 2603 | "yargs-unparser": { 2604 | "version": "2.0.0", 2605 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 2606 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 2607 | "dev": true, 2608 | "requires": { 2609 | "camelcase": "^6.0.0", 2610 | "decamelize": "^4.0.0", 2611 | "flat": "^5.0.2", 2612 | "is-plain-obj": "^2.1.0" 2613 | } 2614 | }, 2615 | "yocto-queue": { 2616 | "version": "0.1.0", 2617 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 2618 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 2619 | "dev": true 2620 | } 2621 | } 2622 | } 2623 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "ruby-book", 3 | "displayName": "RubyBook", 4 | "description": "RubyBook is a VSCode extension that provides a notebook interface for Ruby code.", 5 | "version": "1.0.3", 6 | "engines": { 7 | "vscode": "^1.66.0" 8 | }, 9 | "publisher": "rajshah11", 10 | "repository": { 11 | "url": "https://github.com/rajshah11/ruby-book" 12 | }, 13 | "categories": [ 14 | "Notebooks" 15 | ], 16 | "icon": "docs/images/rubybook.png", 17 | "activationEvents": [ 18 | "onCommand:ruby-book.newNotebook", 19 | "onNotebook:ruby-book" 20 | ], 21 | "main": "./dist/extension.js", 22 | "contributes": { 23 | "commands": [ 24 | { 25 | "command": "ruby-book.newNotebook", 26 | "title": "Create a new blank RubyBook", 27 | "shortTitle": "RubyBook", 28 | "category": "RubyBook" 29 | } 30 | ], 31 | "menus": { 32 | "file/newFile": [ 33 | { 34 | "command": "ruby-book.newNotebook", 35 | "group": "notebook" 36 | } 37 | ] 38 | }, 39 | "notebooks": [ 40 | { 41 | "id": "ruby-book", 42 | "type": "ruby-book", 43 | "displayName": "RubyBook", 44 | "selector": [ 45 | { 46 | "filenamePattern": "*.rubybook" 47 | } 48 | ] 49 | } 50 | ], 51 | "languages": [ 52 | { 53 | "id": "ruby-book", 54 | "extensions": [ 55 | ".rubybook" 56 | ], 57 | "aliases": [ 58 | "RubyBook", 59 | "rubybook" 60 | ] 61 | } 62 | ] 63 | }, 64 | "scripts": { 65 | "vscode:prepublish": "npm run package", 66 | "compile": "webpack", 67 | "watch": "webpack --watch", 68 | "package": "webpack --mode production --devtool hidden-source-map", 69 | "compile-tests": "tsc -p . --outDir out", 70 | "watch-tests": "tsc -p . -w --outDir out", 71 | "pretest": "npm run compile-tests && npm run compile && npm run lint", 72 | "lint": "eslint src --ext ts", 73 | "test": "node ./out/test/runTest.js" 74 | }, 75 | "devDependencies": { 76 | "@types/glob": "^7.2.0", 77 | "@types/mocha": "^9.1.1", 78 | "@types/node": "^14.18.18", 79 | "@types/vscode": "^1.66.0", 80 | "@typescript-eslint/eslint-plugin": "^5.21.0", 81 | "@typescript-eslint/parser": "^5.21.0", 82 | "@vscode/test-electron": "^2.1.3", 83 | "eslint": "^8.14.0", 84 | "glob": "^8.0.1", 85 | "mocha": "^9.2.2", 86 | "ts-loader": "^9.2.8", 87 | "typescript": "^4.6.4", 88 | "webpack": "^5.70.0", 89 | "webpack-cli": "^4.9.2" 90 | }, 91 | "dependencies": { 92 | "async-wait-until": "^2.0.12" 93 | } 94 | } 95 | -------------------------------------------------------------------------------- /src/extension.ts: -------------------------------------------------------------------------------- 1 | import * as vscode from 'vscode'; 2 | import * as rubyBookCommands from './rubyBookCommands'; 3 | import * as rubyBookController from './rubyBookController'; 4 | import * as rubyBookSerializer from './rubyBookSerializer'; 5 | export function activate(context: vscode.ExtensionContext) { 6 | console.log('Congratulations, your extension "ruby-book" is now active!'); 7 | 8 | rubyBookCommands.activate(context); 9 | rubyBookSerializer.activate(context); 10 | rubyBookController.activate(context); 11 | } 12 | 13 | export function deactivate() {} 14 | -------------------------------------------------------------------------------- /src/rubyBook.ts: -------------------------------------------------------------------------------- 1 | import * as vscode from 'vscode'; 2 | import { RubyKernel } from './rubyKernel'; 3 | 4 | export class RubyBook implements vscode.Disposable { 5 | 6 | private rubyKernel: RubyKernel; 7 | private _hasStarted: Boolean; 8 | 9 | constructor() { 10 | this.rubyKernel = new RubyKernel(); 11 | this._hasStarted = false; 12 | } 13 | 14 | async dispose() { 15 | this.rubyKernel.stop(); 16 | } 17 | 18 | public async restartKernel() { 19 | await vscode.commands.executeCommand('notebook.clearAllCellsOutputs'); 20 | await this.rubyKernel.restart(); 21 | } 22 | 23 | public async startKernel() { 24 | await this.rubyKernel.start(); 25 | this._hasStarted = true; 26 | } 27 | 28 | public hasStarted() : Boolean{ 29 | return this._hasStarted; 30 | } 31 | 32 | public eval(cell: vscode.NotebookCell, cancellationToken: vscode.CancellationToken): Promise<[boolean, string, string]> { 33 | return this.rubyKernel.eval(cell, cancellationToken); 34 | } 35 | 36 | public postEval() { 37 | this.rubyKernel.clearBuffers(); 38 | } 39 | } -------------------------------------------------------------------------------- /src/rubyBookCommands.ts: -------------------------------------------------------------------------------- 1 | import * as vscode from 'vscode'; 2 | 3 | export function activate(context: vscode.ExtensionContext) { 4 | context.subscriptions.push(vscode.commands.registerCommand('ruby-book.newNotebook', async () => { 5 | const newNotebook = await vscode.workspace.openNotebookDocument('ruby-book', 6 | new vscode.NotebookData([ 7 | new vscode.NotebookCellData(vscode.NotebookCellKind.Code, "puts 'Hello World'", 'ruby-book') 8 | ])); 9 | })); 10 | } -------------------------------------------------------------------------------- /src/rubyBookController.ts: -------------------------------------------------------------------------------- 1 | import * as vscode from 'vscode'; 2 | import { RubyBook } from './rubyBook'; 3 | 4 | interface RawNotebookCell { 5 | language: string; 6 | value: string; 7 | kind: vscode.NotebookCellKind; 8 | editable?: boolean; 9 | } 10 | 11 | export function activate(context: vscode.ExtensionContext) { 12 | context.subscriptions.push(new RubyBookController()); 13 | } 14 | 15 | class RubyBookController { 16 | readonly controllerId = 'ruby-book-controller-id'; 17 | readonly notebookType = 'ruby-book'; 18 | readonly label = 'RubyBook'; 19 | readonly supportedLanguages = ['ruby']; 20 | 21 | private readonly _controller: vscode.NotebookController; 22 | private _executionOrder = 0; 23 | private rubyBook: RubyBook | undefined; 24 | 25 | constructor() { 26 | this._controller = vscode.notebooks.createNotebookController( 27 | this.controllerId, 28 | this.notebookType, 29 | this.label 30 | ); 31 | 32 | this._controller.supportedLanguages = this.supportedLanguages; 33 | this._controller.supportsExecutionOrder = true; 34 | this._controller.executeHandler = this._execute.bind(this); 35 | this.rubyBook = new RubyBook(); 36 | } 37 | 38 | dispose() { 39 | this.rubyBook?.dispose(); 40 | this._controller?.dispose(); 41 | } 42 | 43 | private async _execute( 44 | cells: vscode.NotebookCell[], 45 | _notebook: vscode.NotebookDocument, 46 | _controller: vscode.NotebookController 47 | ): Promise { 48 | if (!this.rubyBook?.hasStarted()) { 49 | await this.rubyBook?.startKernel(); 50 | } 51 | 52 | for (let cell of cells) { 53 | await this._doExecution(cell); 54 | } 55 | } 56 | 57 | private async _doExecution(cell: vscode.NotebookCell): Promise { 58 | if (!this.rubyBook?.hasStarted()) { 59 | await this.rubyBook?.startKernel(); 60 | } 61 | 62 | const execution = this._controller.createNotebookCellExecution(cell); 63 | execution.executionOrder = ++this._executionOrder; 64 | execution.start(Date.now()); // Keep track of elapsed time to execute cell. 65 | 66 | /* Do some execution here; not implemented */ 67 | const output = await this.rubyBook!.eval(cell, execution.token); 68 | this.rubyBook!.postEval(); 69 | 70 | execution.replaceOutput([ 71 | new vscode.NotebookCellOutput([ 72 | vscode.NotebookCellOutputItem.text(output[1]), 73 | ]) 74 | ]); 75 | execution.appendOutput(new vscode.NotebookCellOutput([ 76 | vscode.NotebookCellOutputItem.text(output[2]), 77 | ])); 78 | execution.end(output[0], Date.now()); 79 | } 80 | } -------------------------------------------------------------------------------- /src/rubyBookSerializer.ts: -------------------------------------------------------------------------------- 1 | import { TextDecoder, TextEncoder } from 'util'; 2 | import * as vscode from 'vscode'; 3 | 4 | export function activate(context: vscode.ExtensionContext) { 5 | context.subscriptions.push( 6 | vscode.workspace.registerNotebookSerializer('ruby-book', new RubyBookSerializer()) 7 | ); 8 | } 9 | 10 | interface RawNotebookCell { 11 | language: string; 12 | value: string; 13 | kind: vscode.NotebookCellKind; 14 | } 15 | 16 | class RubyBookSerializer implements vscode.NotebookSerializer { 17 | async deserializeNotebook( 18 | content: Uint8Array, 19 | _token: vscode.CancellationToken 20 | ): Promise { 21 | var contents = new TextDecoder().decode(content); 22 | 23 | let raw: RawNotebookCell[]; 24 | try { 25 | raw = JSON.parse(contents); 26 | } catch { 27 | raw = []; 28 | } 29 | 30 | const cells = raw.map( 31 | item => new vscode.NotebookCellData(item.kind, item.value, item.language) 32 | ); 33 | 34 | return new vscode.NotebookData(cells); 35 | } 36 | 37 | async serializeNotebook( 38 | data: vscode.NotebookData, 39 | _token: vscode.CancellationToken 40 | ): Promise { 41 | let contents: RawNotebookCell[] = []; 42 | 43 | for (const cell of data.cells) { 44 | contents.push({ 45 | kind: cell.kind, 46 | language: cell.languageId, 47 | value: cell.value 48 | }); 49 | } 50 | 51 | return new TextEncoder().encode(JSON.stringify(contents)); 52 | } 53 | } -------------------------------------------------------------------------------- /src/rubyKernel.ts: -------------------------------------------------------------------------------- 1 | import * as vscode from 'vscode'; 2 | import * as cp from 'child_process'; 3 | import * as fs from 'fs'; 4 | import * as PATH from 'path'; 5 | import * as os from 'os'; 6 | import { waitUntil, WAIT_FOREVER } from 'async-wait-until'; 7 | import { kill } from 'process'; 8 | const rmdir = require('rimraf'); 9 | 10 | export class RubyKernel { 11 | 12 | private rubyRuntime: cp.ChildProcess | undefined; 13 | private outputBuffer = ''; // collect output here 14 | private errorBuffer = ''; 15 | private commandDone = false; 16 | 17 | private pathToCell: Map = new Map(); 18 | private tmpDirectory?: string; 19 | private pryStarted = false; 20 | private started = false; 21 | 22 | constructor() { 23 | } 24 | 25 | public async start() { 26 | if (!this.started) { 27 | this.rubyRuntime = cp.exec('pry', (error, stdout, stderr) => { 28 | console.log(`stdout: ${stdout}`); 29 | console.log(`stderr: ${stderr}`); 30 | console.log(`error: ${error}`); 31 | }); 32 | 33 | var pryStarted = new Promise((resolve) => { 34 | if (this.rubyRuntime?.stdout) { 35 | this.rubyRuntime?.stdout.on('data', (data: Buffer) => { 36 | this.outputBuffer += data.toString(); 37 | this.pryStarted = /\[1\] pry\(main\)> /.test(this.outputBuffer); 38 | if (this.pryStarted) { 39 | console.log(data); 40 | resolve(); 41 | } 42 | }); 43 | } 44 | }); 45 | 46 | var errorFlushed = new Promise((resolve) => { 47 | if (this.rubyRuntime?.stderr) { 48 | this.rubyRuntime.stderr?.on('readable', () => { 49 | let data; 50 | while (null !== (data = this.rubyRuntime!.stderr?.read())) { 51 | this.errorBuffer += data.toString(); 52 | } 53 | console.log(this.errorBuffer); 54 | resolve(); 55 | }); 56 | } 57 | }); 58 | 59 | await Promise.all([pryStarted, errorFlushed]); 60 | 61 | this.rubyRuntime.stdout?.removeAllListeners(); 62 | this.rubyRuntime.stderr?.removeAllListeners(); 63 | this.clearBuffers(); 64 | 65 | if (this.rubyRuntime.stdout) { 66 | this.rubyRuntime.stdout.on('data', (data: Buffer) => { 67 | this.outputBuffer += data.toString(); 68 | this.commandDone = /[\n]?\[[0-9]*\] pry\(main\)> /.test(this.outputBuffer); 69 | if (this.commandDone) { 70 | this.outputBuffer = this.outputBuffer.replace(/[\n]?\[[0-9]*\] pry\(main\)> /g, ''); 71 | } 72 | }); 73 | } 74 | 75 | if (this.rubyRuntime.stderr) { 76 | this.rubyRuntime.stderr.on('data', (data: Buffer) => { 77 | this.errorBuffer += data.toString(); 78 | }); 79 | } 80 | 81 | this.started = true; 82 | } 83 | } 84 | 85 | public async restart() { 86 | this.stop(); 87 | await this.start(); 88 | } 89 | 90 | public stop() { 91 | 92 | if (this.rubyRuntime) { 93 | this.rubyRuntime.kill(); 94 | this.rubyRuntime = undefined; 95 | } 96 | 97 | if (this.tmpDirectory) { 98 | const t = this.tmpDirectory; 99 | this.tmpDirectory = undefined; 100 | rmdir(t, { glob: false }, (err: Error | undefined) => { 101 | if (err) { 102 | console.log(err); 103 | } 104 | }); 105 | } 106 | } 107 | 108 | public async eval(cell: vscode.NotebookCell, cancellationToken: vscode.CancellationToken): Promise<[boolean, string, string]> { 109 | 110 | const cellPath = this.dumpCell(cell); 111 | if (cellPath && this.rubyRuntime && this.rubyRuntime.stdin) { 112 | 113 | this.outputBuffer = ''; 114 | this.errorBuffer = ''; 115 | this.commandDone = false; 116 | 117 | this.rubyRuntime.stdin.write(`Pry.toplevel_binding.eval File.read('${cellPath}')\n`); 118 | const cancellationPromise = new Promise((resolve) => { 119 | cancellationToken.onCancellationRequested(() => { 120 | resolve(); 121 | }); 122 | }); 123 | 124 | const waitPromise = waitUntil(() => this.commandDone, WAIT_FOREVER); 125 | 126 | await Promise.race([waitPromise, cancellationPromise]); 127 | 128 | if(cancellationToken.isCancellationRequested){ 129 | let killed = this.rubyRuntime.kill('SIGINT'); 130 | if (killed){ 131 | this.errorBuffer = 'Cancelled!'; 132 | } 133 | else{ 134 | this.errorBuffer = `Cancellation requested, but killing the background process failed.` 135 | this.errorBuffer += `Please restart VSCode to avoid unintended results.`; 136 | } 137 | } 138 | 139 | return Promise.resolve([!cancellationToken.isCancellationRequested, this.outputBuffer, this.errorBuffer]); 140 | } 141 | throw new Error('Evaluation failed'); 142 | } 143 | 144 | public clearBuffers() { 145 | this.outputBuffer = ''; 146 | this.errorBuffer = ''; 147 | } 148 | 149 | 150 | 151 | /** 152 | * Store cell in temporary file and return its path or undefined if uri does not denote a cell. 153 | */ 154 | private dumpCell(cell: vscode.NotebookCell): string | undefined { 155 | try { 156 | if (cell) { 157 | if (!this.tmpDirectory) { 158 | this.tmpDirectory = fs.mkdtempSync(PATH.join(os.tmpdir(), 'vscode-nodebook-')); 159 | } 160 | const cellPath = `${this.tmpDirectory}/nodebook_cell_${cell.document.uri.fragment}.rb`; 161 | this.pathToCell.set(cellPath, cell); 162 | 163 | let data = cell.document.getText(); 164 | data += `\n# @ sourceURL=${cellPath}`; // trick to make node.js report the eval's source under this path 165 | fs.writeFileSync(cellPath, data); 166 | 167 | return cellPath; 168 | } 169 | } catch (e) { 170 | } 171 | return undefined; 172 | } 173 | } -------------------------------------------------------------------------------- /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 test runner 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 | import * as assert from 'assert'; 2 | 3 | // You can import and use all API from the 'vscode' module 4 | // as well as import your extension to test it 5 | import * as vscode from 'vscode'; 6 | // import * as myExtension from '../../extension'; 7 | 8 | suite('Extension Test Suite', () => { 9 | vscode.window.showInformationMessage('Start all tests.'); 10 | 11 | test('Sample test', () => { 12 | assert.strictEqual(-1, [1, 2, 3].indexOf(5)); 13 | assert.strictEqual(-1, [1, 2, 3].indexOf(0)); 14 | }); 15 | }); 16 | -------------------------------------------------------------------------------- /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 | color: true 10 | }); 11 | 12 | const testsRoot = path.resolve(__dirname, '..'); 13 | 14 | return new Promise((c, e) => { 15 | glob('**/**.test.js', { cwd: testsRoot }, (err, files) => { 16 | if (err) { 17 | return e(err); 18 | } 19 | 20 | // Add files to the test suite 21 | files.forEach(f => mocha.addFile(path.resolve(testsRoot, f))); 22 | 23 | try { 24 | // Run the mocha test 25 | mocha.run(failures => { 26 | if (failures > 0) { 27 | e(new Error(`${failures} tests failed.`)); 28 | } else { 29 | c(); 30 | } 31 | }); 32 | } catch (err) { 33 | console.error(err); 34 | e(err); 35 | } 36 | }); 37 | }); 38 | } 39 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "target": "ES2020", 5 | "lib": [ 6 | "ES2020" 7 | ], 8 | "sourceMap": true, 9 | "rootDir": "src", 10 | "strict": true /* enable all strict type-checking options */ 11 | /* Additional Checks */ 12 | // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ 13 | // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ 14 | // "noUnusedParameters": true, /* Report errors on unused parameters. */ 15 | } 16 | } 17 | -------------------------------------------------------------------------------- /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 | ## Setup 13 | 14 | * install the recommended extensions (amodio.tsl-problem-matcher and dbaeumer.vscode-eslint) 15 | 16 | 17 | ## Get up and running straight away 18 | 19 | * Press `F5` to open a new window with your extension loaded. 20 | * Run your command from the command palette by pressing (`Ctrl+Shift+P` or `Cmd+Shift+P` on Mac) and typing `Hello World`. 21 | * Set breakpoints in your code inside `src/extension.ts` to debug your extension. 22 | * Find output from your extension in the debug console. 23 | 24 | ## Make changes 25 | 26 | * You can relaunch the extension from the debug toolbar after changing code in `src/extension.ts`. 27 | * You can also reload (`Ctrl+R` or `Cmd+R` on Mac) the VS Code window with your extension to load your changes. 28 | 29 | 30 | ## Explore the API 31 | 32 | * You can open the full set of our API when you open the file `node_modules/@types/vscode/index.d.ts`. 33 | 34 | ## Run tests 35 | 36 | * Open the debug viewlet (`Ctrl+Shift+D` or `Cmd+Shift+D` on Mac) and from the launch configuration dropdown pick `Extension Tests`. 37 | * Press `F5` to run the tests in a new window with your extension loaded. 38 | * See the output of the test result in the debug console. 39 | * Make changes to `src/test/suite/extension.test.ts` or create new test files inside the `test/suite` folder. 40 | * The provided test runner will only consider files matching the name pattern `**.test.ts`. 41 | * You can create folders inside the `test` folder to structure your tests any way you want. 42 | 43 | ## Go further 44 | 45 | * Reduce the extension size and improve the startup time by [bundling your extension](https://code.visualstudio.com/api/working-with-extensions/bundling-extension). 46 | * [Publish your extension](https://code.visualstudio.com/api/working-with-extensions/publishing-extension) on the VSCode extension marketplace. 47 | * Automate builds by setting up [Continuous Integration](https://code.visualstudio.com/api/working-with-extensions/continuous-integration). 48 | -------------------------------------------------------------------------------- /webpack.config.js: -------------------------------------------------------------------------------- 1 | //@ts-check 2 | 3 | 'use strict'; 4 | 5 | const path = require('path'); 6 | 7 | //@ts-check 8 | /** @typedef {import('webpack').Configuration} WebpackConfig **/ 9 | 10 | /** @type WebpackConfig */ 11 | const extensionConfig = { 12 | target: 'node', // vscode extensions run in a Node.js-context 📖 -> https://webpack.js.org/configuration/node/ 13 | mode: 'none', // this leaves the source code as close as possible to the original (when packaging we set this to 'production') 14 | 15 | entry: './src/extension.ts', // the entry point of this extension, 📖 -> https://webpack.js.org/configuration/entry-context/ 16 | output: { 17 | // the bundle is stored in the 'dist' folder (check package.json), 📖 -> https://webpack.js.org/configuration/output/ 18 | path: path.resolve(__dirname, 'dist'), 19 | filename: 'extension.js', 20 | libraryTarget: 'commonjs2' 21 | }, 22 | externals: { 23 | vscode: 'commonjs vscode' // the vscode-module is created on-the-fly and must be excluded. Add other modules that cannot be webpack'ed, 📖 -> https://webpack.js.org/configuration/externals/ 24 | // modules added here also need to be added in the .vscodeignore file 25 | }, 26 | resolve: { 27 | // support reading TypeScript and JavaScript files, 📖 -> https://github.com/TypeStrong/ts-loader 28 | extensions: ['.ts', '.js'] 29 | }, 30 | module: { 31 | rules: [ 32 | { 33 | test: /\.ts$/, 34 | exclude: /node_modules/, 35 | use: [ 36 | { 37 | loader: 'ts-loader' 38 | } 39 | ] 40 | } 41 | ] 42 | }, 43 | devtool: 'nosources-source-map', 44 | infrastructureLogging: { 45 | level: "log", // enables logging required for problem matchers 46 | }, 47 | }; 48 | module.exports = [ extensionConfig ]; --------------------------------------------------------------------------------