├── .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 | 
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 ];
--------------------------------------------------------------------------------