├── .eslintrc.json ├── .gitignore ├── .vscode ├── extensions.json ├── launch.json ├── settings.json └── tasks.json ├── .vscodeignore ├── CHANGELOG.org ├── LICENSE.md ├── README.md ├── abc.tmGrammar.json ├── abc.tmGrammar.tmLanguage.yml ├── package-lock.json ├── package.json ├── publish.cmd ├── res ├── Screenshot-1.png ├── export.html ├── icon.png ├── icon128.png ├── print.html ├── screenshot.printPreview.png └── viewer.html ├── snippets.json ├── src ├── extension.ts └── test │ ├── runTest.ts │ └── suite │ ├── extension.test.ts │ └── index.ts ├── tsconfig.json └── vsc-extension-quickstart.md /.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 | "env": { 12 | "browser": false, 13 | "commonjs": true, 14 | "es6": true, 15 | "node": true, 16 | "mocha": true 17 | }, 18 | "rules": { 19 | "@typescript-eslint/naming-convention": "warn", 20 | "@typescript-eslint/semi": "warn", 21 | "curly": "warn", 22 | "eqeqeq": "warn", 23 | "no-const-assign": "warn", 24 | "no-this-before-super": "warn", 25 | "no-throw-literal": "warn", 26 | "no-undef": "warn", 27 | "no-unreachable": "warn", 28 | "no-unused-vars": "warn", 29 | "constructor-super": "warn", 30 | "semi": "off", 31 | "valid-typeof": "warn" 32 | }, 33 | "ignorePatterns": [ 34 | "out", 35 | "dist", 36 | "**/*.d.ts" 37 | ] 38 | } 39 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | .vscode-test/ 3 | *.vsix 4 | out/ -------------------------------------------------------------------------------- /.vscode/extensions.json: -------------------------------------------------------------------------------- 1 | { 2 | // See https://go.microsoft.com/fwlink/?LinkId=733558 3 | // for the documentation about the extensions.json format 4 | "recommendations": [ 5 | "dbaeumer.vscode-eslint" 6 | ] 7 | } -------------------------------------------------------------------------------- /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | // A launch configuration that launches the extension 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}/out/**/*.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/test/**/*.js" 30 | ], 31 | "preLaunchTask": "${defaultBuildTask}" 32 | } 33 | ] 34 | } 35 | -------------------------------------------------------------------------------- /.vscode/settings.json: -------------------------------------------------------------------------------- 1 | // Place your settings in this file to overwrite default and user settings. 2 | { 3 | "files.exclude": { 4 | "out": false // set this to true to hide the "out" folder with the compiled JS files 5 | }, 6 | "search.exclude": { 7 | "out": true // set this to false to include "out" folder in search results 8 | }, 9 | // Turn off tsc task auto detection since we have the necessary tasks as npm scripts 10 | "typescript.tsc.autoDetect": "off" 11 | } -------------------------------------------------------------------------------- /.vscode/tasks.json: -------------------------------------------------------------------------------- 1 | // See https://go.microsoft.com/fwlink/?LinkId=733558 2 | // for the documentation about the tasks.json format 3 | { 4 | "version": "2.0.0", 5 | "tasks": [ 6 | { 7 | "type": "npm", 8 | "script": "watch", 9 | "problemMatcher": "$tsc-watch", 10 | "isBackground": true, 11 | "presentation": { 12 | "reveal": "never" 13 | }, 14 | "group": { 15 | "kind": "build", 16 | "isDefault": true 17 | } 18 | } 19 | ] 20 | } 21 | -------------------------------------------------------------------------------- /.vscodeignore: -------------------------------------------------------------------------------- 1 | .vscode/** 2 | .vscode-test/** 3 | src/** 4 | test/** 5 | .gitignore 6 | .yarnrc 7 | vsc-extension-quickstart.md 8 | **/tsconfig.json 9 | **/jsconfig.json 10 | **/.eslintrc.json 11 | **/*.map 12 | **/*.ts -------------------------------------------------------------------------------- /CHANGELOG.org: -------------------------------------------------------------------------------- 1 | * Change Log 2 | 3 | All notable changes to the "abcjs-editor" extension will be documented in this file. 4 | 5 | Check [Keep a Changelog](http://keepachangelog.com/) for recommendations on how to structure this file. 6 | 7 | ** 2.7 8 | 9 | Grammar additions and adjustments to improve code coloring. 10 | 11 | ** 2.6.0 12 | 13 | Grammar update. Thanks Antoine Balaine! 14 | 15 | ** 2.5.0 16 | 17 | Updating abcjs to v6.1.6 18 | 19 | ** 2.4.1 20 | 21 | Added showDebug setting. 22 | 23 | ** 2.4.0 24 | 25 | Added Export HTML command. 26 | 27 | ** 2.3.0 28 | 29 | Added Export SVG command. 30 | 31 | ** 2.2.1 32 | 33 | Added oneSvgPerLine setting. 34 | 35 | ** 2.2.0 36 | 37 | Configuration settings for sheet formatting and rendering. 38 | 39 | ** 2.1.0 40 | 41 | Added Print Preview and Export options. 42 | 43 | ** 2.0.0 44 | 45 | Under-the-hood housekeeping. 46 | Converted source code to TypeScript. 47 | Extracted the viewer into a separate page for easier editing. 48 | 49 | ** 1.3.1 50 | 51 | Update abcjs to v6.1.3. Add option to show transposed ABC string. Add option to show tablature. Add snippet for creating a new tune. 52 | 53 | ** 1.3.0 54 | 55 | Update abcjs to v6.0.4. Add option for transpose. Add font for chords. 56 | 57 | ** 1.2.0 58 | 59 | Title taken from the filename. Multiple files support. 60 | 61 | ** 1.1.0 62 | 63 | Updated the abcjs to v6.0.2. 64 | 65 | ** 1.0.x 66 | 67 | Updating the abcjs library the latest beta version. 68 | 69 | ** 0.4.0 70 | 71 | Updating the abcjs library to 6.0.0-beta.31. 72 | 73 | ** 0.3.0 74 | 75 | Recognizing Parts syntax. 76 | 77 | ** 0.2.x 78 | 79 | Updating the abcjs to v6.0.0-beta.28. The text is now visible on dark background. 80 | 81 | ** 0.0.x 82 | 83 | Prototyping! 84 | Initial release of abcjs-vscode. 85 | Code coloring and sheet rendering from the text in the editor. 86 | It is possible to select the notes by clicking the sheet. 87 | -------------------------------------------------------------------------------- /LICENSE.md: -------------------------------------------------------------------------------- 1 | abcjs extension for Visual Studio Code 2 | Copyright (C) 2022 Alen Šiljak 3 | 4 | This program is free software: you can redistribute it and/or modify 5 | it under the terms of the GNU General Public License as published by 6 | the Free Software Foundation, either version 3 of the License, or 7 | (at your option) any later version. 8 | 9 | This program is distributed in the hope that it will be useful, 10 | but WITHOUT ANY WARRANTY; without even the implied warranty of 11 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 | GNU General Public License for more details. 13 | 14 | You should have received a copy of the GNU General Public License 15 | along with this program. If not, see . -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # abcjs-vscode 2 | 3 | This is an editor for the ABC music notation, powered by the [abcjs](https://abcjs.net/) library. 4 | 5 | It is an extension for Visual Studio Code and is available at [Visual Studio Marketplace](https://marketplace.visualstudio.com/items?itemName=alensiljak.abcjs-vscode) or through the Extensions panel in VS Code. 6 | 7 | ABC notation - 🔤 - is known as the "Markdown for music". Learn more at the ABC Notation [homepage](https://abcnotation.com/). 8 | 9 | ## Features 10 | 11 | The extension displays the music sheet based on the Abc notation in the current editor. 12 | Clicking the note on the displayed sheet will select it in the editor. 13 | 14 | Minimalistic tune 15 | 16 | ![Screenshot 1](https://imgur.com/v5y0qVB.png) 17 | 18 | And a bit more elaborate: 19 | 20 | ![Screenshot 2](https://imgur.com/HMILUbe.png) 21 | 22 | ### Print Preview 23 | 24 | This command will display a print-ready sheet in a browser. There you can print it to PDF or paper. 25 | 26 | ![Print Preview](https://imgur.com/4enTxxd.png) 27 | 28 | ### Export 29 | 30 | The Export command will export an HTML page with the rendered score sheet. 31 | 32 | The Export SVG command will export the score sheet as SVG. 33 | 34 | ## Usage 35 | 36 | Press Ctrl+Shift+P and type "abcjs" to access the available commands. 37 | 38 | Available commands: 39 | - `abcjs-vscode: Show Preview` 40 | - `abcjs-vscode: Print Preview` 41 | - `abcjs-vscode: Export Sheet to HTML` 42 | - `abcjs-vscode: Export Sheet as SVG` 43 | 44 | The Viewer works both with new text files in the editor and existing `.abc` files. 45 | 46 | ## Requirements 47 | 48 | The abcjs library is currently loaded from CDN and not packaged with the extension. 49 | 50 | ## Extension Settings 51 | 52 | In VSCode Settings, look for `abcjs vscode` configuration section. Editing the settings will apply them immediately to the Viewer. For convenience, you can arrange the window layout and keep the Settings window open in order to apply the settings to the current sheet preview. 53 | 54 | 64 | 65 | ## Known Issues 66 | 67 | The line-endings in the file need to be set to LF instead of CRLF (on Windows). Then the offsets will match between the sheet and the abc code. 68 | 69 | ## Release Notes 70 | 71 | See [CHANGELOG.org](CHANGELOG.org). 72 | 73 | -------------------------------------------------------------------------------------------------- 74 | 75 | # Development 76 | 77 | The package manager is npm. 78 | 79 | ## Publishing 80 | 81 | `npm run deploy` 82 | 83 | - [Bundling](https://code.visualstudio.com/api/working-with-extensions/bundling-extension) 84 | 85 | Note that the vscode engine version must start with a cared (^), otherwise it gets rejected by vscode on installation most of the time. 86 | 87 | # License 88 | 89 | See [license](LICENSE). 90 | 91 | # References 92 | 93 | - https://github.com/softawaregmbh/vscode-abc/ 94 | 95 | 113 | -------------------------------------------------------------------------------- /abc.tmGrammar.json: -------------------------------------------------------------------------------- 1 | { 2 | "scopeName": "source.abc", 3 | "patterns": [ 4 | { "include": "#accidentalsAndOctaves" }, 5 | { "include": "#annotations" }, 6 | { "include": "#bar" }, 7 | { "include": "#comments" }, 8 | { "include": "#composer" }, 9 | { "include": "#instructions" }, 10 | { "include": "#key" }, 11 | { "include": "#length" }, 12 | { "include": "#meter" }, 13 | { "include": "#note-rhythm" }, 14 | { "include": "#notes" }, 15 | { "include": "#origin" }, 16 | { "include": "#ornaments" }, 17 | { "include": "#part" }, 18 | { "include": "#redefine" }, 19 | { "include": "#referencenumber" }, 20 | { "include": "#rhythm" }, 21 | { "include": "#rhythm" }, 22 | { "include": "#source" }, 23 | { "include": "#symbols" }, 24 | { "include": "#tempo" }, 25 | { "include": "#ties" }, 26 | { "include": "#title" }, 27 | { "include": "#voice" }, 28 | { "include": "#voice-section" }, 29 | { "include": "#words" } 30 | ], 31 | "repository": { 32 | "composer": { 33 | "patterns": [ 34 | { 35 | "match": "^(C:)(.*)", 36 | "captures": { 37 | "1": { "name": "keyword.other.composer.abc" }, 38 | "2": { "name": "string.value.composer.abc" } 39 | } 40 | } 41 | ] 42 | }, 43 | "key": { 44 | "patterns": [ 45 | { 46 | "match": "^(K:)(.*)", 47 | "captures": { 48 | "1": { "name": "keyword.other.key.abc" }, 49 | "2": { "name": "string.value.key.abc" } 50 | } 51 | } 52 | ] 53 | }, 54 | "length": { 55 | "patterns": [ 56 | { 57 | "match": "^(L:)(.*)", 58 | "captures": { 59 | "1": { "name": "keyword.other.length.abc" }, 60 | "2": { "name": "string.value.length.abc" } 61 | } 62 | } 63 | ] 64 | }, 65 | "meter": { 66 | "patterns": [ 67 | { 68 | "match": "^(M:)(.*)", 69 | "captures": { 70 | "1": { "name": "keyword.other.meter.abc" }, 71 | "2": { "name": "string.value.meter.abc" } 72 | } 73 | }, { 74 | "match": "(\\[M:)(.*?)\\]", 75 | "captures": { 76 | "1": { "name": "keyword.other.meter.abc" }, 77 | "2": { "name": "string.value.meter.abc" } 78 | } 79 | } 80 | ] 81 | }, 82 | "notes": { 83 | "patterns": [ 84 | { 85 | "match": "^(N:)(.*)", 86 | "captures": { 87 | "1": { "name": "keyword.other.notes.abc" }, 88 | "2": { "name": "string.value.notes.abc" } 89 | } 90 | } 91 | ] 92 | }, 93 | "origin": { 94 | "patterns": [ 95 | { 96 | "match": "^(O:)(.*)", 97 | "captures": { 98 | "1": { "name": "keyword.other.origin.abc" }, 99 | "2": { "name": "string.value.origin.abc" } 100 | } 101 | } 102 | ] 103 | }, 104 | "part": { 105 | "patterns": [ 106 | { 107 | "match": "^(P:)(.*)", 108 | "captures": { 109 | "1": { "name": "keyword.other.part.abc" }, 110 | "2": { "name": "markup.bold.other.part.abc" } 111 | } 112 | } 113 | ] 114 | }, 115 | "tempo": { 116 | "patterns": [ 117 | { 118 | "match": "^(Q:)(.*)", 119 | "captures": { 120 | "1": { "name": "keyword.other.tempo.abc" }, 121 | "2": { "name": "string.value.tempo.abc" } 122 | } 123 | } 124 | ] 125 | }, 126 | "rhythm": { 127 | "patterns": [ 128 | { 129 | "match": "^(R:)(.*)", 130 | "captures": { 131 | "1": { "name": "keyword.other.rhythm.abc" }, 132 | "2": { "name": "string.value.rhythm.abc" } 133 | } 134 | } 135 | ] 136 | }, 137 | "source": { 138 | "patterns": [ 139 | { 140 | "match": "^(S:)(.*)", 141 | "captures": { 142 | "1": { "name": "keyword.other.source.abc" }, 143 | "2": { "name": "string.value.source.abc" } 144 | } 145 | } 146 | ] 147 | }, 148 | "title": { 149 | "patterns": [ 150 | { 151 | "match": "^(T:)(.*)", 152 | "captures": { 153 | "1": { "name": "keyword.other.title.abc" }, 154 | "2": { "name": "string.value.title.abc" } 155 | } 156 | } 157 | ] 158 | }, 159 | "redefine": { 160 | "patterns": [ 161 | { 162 | "match": "^(U:)(.*)", 163 | "captures": { 164 | "1": { "name": "keyword.other.redefine.abc" }, 165 | "2": { "name": "string.value.redefine.abc" } 166 | } 167 | } 168 | ] 169 | }, 170 | "referencenumber": { 171 | "patterns": [ 172 | { 173 | "match": "^(X:)(.*)", 174 | "captures": { 175 | "1": { "name": "keyword.other.referencenumber.abc" }, 176 | "2": { "name": "string.value.referencenumber.abc" } 177 | } 178 | } 179 | ] 180 | }, 181 | "transcription": { 182 | "patterns": [ 183 | { 184 | "match": "^(Z:)(.*)", 185 | "captures": { 186 | "1": { "name": "keyword.other.transcription.abc" }, 187 | "2": { "name": "string.value.transcription.abc" } 188 | } 189 | } 190 | ] 191 | }, 192 | "instructions": { 193 | "patterns": [ 194 | { 195 | "match": "^%%.*", 196 | "name": "keyword.other.instruction.abc" 197 | } 198 | ] 199 | }, 200 | "annotations": { 201 | "patterns": [ 202 | { 203 | "match": "\"([^\".]*)\"", 204 | "name": "comment" 205 | } 206 | ] 207 | }, 208 | "comments": { 209 | "patterns": [ 210 | { 211 | "match": "%[^%].*", 212 | "name": "comment.line.abc" 213 | } 214 | ] 215 | }, 216 | "voice-section": { 217 | "name": "abc.section.voice", 218 | "begin": "^(V:\\d)(.*)", 219 | "beginCaptures": { 220 | "0": { "name": "keyword.other.region.voice.abc" } 221 | }, 222 | "while": "(?# include lines until one contains 'V:')^(?!V:\\d|X:)", 223 | "patterns": [ 224 | { "include": "#annotations" }, 225 | { "include": "#words" }, 226 | { "include": "#bar" }, 227 | { "include": "#ornaments" } 228 | ] 229 | }, 230 | "accidentalsAndOctaves": { 231 | "patterns": [ 232 | { 233 | "match": "[\\^_=,']", 234 | "name": "string" 235 | } 236 | ] 237 | }, 238 | "words": { 239 | "patterns": [ 240 | { 241 | "match": "^([Ww]:)(.*)", 242 | "name": "keyword.other.words.abc" 243 | } 244 | ] 245 | }, 246 | "bar": { 247 | "patterns": [ 248 | { 249 | "match": ":?\\|[:\\]]?", 250 | "name": "keyword.other.bar.abc" 251 | } 252 | ] 253 | }, 254 | "ornaments": { 255 | "patterns": [ 256 | { 257 | "match": "\\!([^\\!.]*)\\!", 258 | "name": "entity.name.type.other.ornaments.abc" 259 | } 260 | ] 261 | }, 262 | "symbols": { 263 | "patterns": [ 264 | { 265 | "match": "!([^!.]*)!", 266 | "name": "keyword.other.symbols.abc" 267 | } 268 | ] 269 | }, 270 | "ties": { 271 | "patterns": [ 272 | { 273 | "match": "\\(", 274 | "name": "string" 275 | }, 276 | { 277 | "match": "\\)", 278 | "name": "string" 279 | } 280 | ] 281 | }, 282 | "chord": { 283 | "patterns": [ 284 | { 285 | "match": "\\[", 286 | "name": "string" 287 | }, 288 | { 289 | "match": "\\]", 290 | "name": "string" 291 | } 292 | ] 293 | }, 294 | "voice": { 295 | "patterns": [ 296 | { 297 | "match": "^\\[V:[^\\]]*\\]", 298 | "name": "comment" 299 | } 300 | ] 301 | }, 302 | "note-rhythm": { 303 | "patterns": [ 304 | { 305 | "match": "[><]", 306 | "name": "string" 307 | }, 308 | { 309 | "match": "(?!^[a-gzA-GZ]([,']?)+)[/0-9]+", 310 | "name": "string" 311 | } 312 | ] 313 | } 314 | } 315 | } 316 | -------------------------------------------------------------------------------- /abc.tmGrammar.tmLanguage.yml: -------------------------------------------------------------------------------- 1 | scopeName: source.abc 2 | patterns: 3 | - include: "#ties" 4 | - include: "#instructions" 5 | - include: "#comments" 6 | - include: "#voice" 7 | - include: "#annotations" 8 | - include: "#information" 9 | - include: "#bar" 10 | - include: "#symbols" 11 | - include: "#accidentalsAndOctaves" 12 | - include: "#referencenumber" 13 | - include: "#title" 14 | - include: "#key" 15 | - include: "#meter" 16 | - include: "#length" 17 | - include: "#tempo" 18 | - include: "#composer" 19 | - include: "#rhythm" 20 | - include: "#note-rhythm" 21 | - include: "#origin" 22 | - include: "#notes" 23 | - include: "#part" 24 | - include: "#redefine" 25 | - include: "#rhythm" 26 | - include: "#source" 27 | - include: "#instructions" 28 | - include: "#comments" 29 | - include: "#voice-section" 30 | - include: "#chords" 31 | - include: "#words" 32 | - include: "#bar" 33 | - include: "#ornaments" 34 | repository: 35 | title: 36 | patterns: 37 | - match: ^(T:)(.*) 38 | captures: 39 | "1": 40 | name: keyword.other.title.abc 41 | "2": 42 | name: string.value.title.abc 43 | key: 44 | patterns: 45 | - match: ^(K:)(.*) 46 | captures: 47 | "1": 48 | name: keyword.other.key.abc 49 | "2": 50 | name: string.value.key.abc 51 | meter: 52 | patterns: 53 | - match: ^(M:)(.*) 54 | captures: 55 | "1": 56 | name: keyword.other.meter.abc 57 | "2": 58 | name: string.value.meter.abc 59 | length: 60 | patterns: 61 | - match: ^(L:)(.*) 62 | captures: 63 | "1": 64 | name: keyword.other.length.abc 65 | "2": 66 | name: string.value.length.abc 67 | part: 68 | patterns: 69 | - match: ^(P:)(.*) 70 | captures: 71 | "1": 72 | name: markup.underline.other.part.abc 73 | "2": 74 | name: markup.underline.other.part.abc 75 | notes: 76 | patterns: 77 | - match: ^(N:)(.*) 78 | captures: 79 | "1": 80 | name: keyword.other.notes.abc 81 | "2": 82 | name: string.value.notes.abc 83 | redefine: 84 | patterns: 85 | - match: ^(U:)(.*) 86 | captures: 87 | "1": 88 | name: keyword.other.redefine.abc 89 | "2": 90 | name: string.value.redefine.abc 91 | rhythm: 92 | patterns: 93 | - match: ^(R:)(.*) 94 | captures: 95 | "1": 96 | name: keyword.other.rhythm.abc 97 | "2": 98 | name: string.value.rhythm.abc 99 | source: 100 | patterns: 101 | - match: ^(S:)(.*) 102 | captures: 103 | "1": 104 | name: keyword.other.source.abc 105 | "2": 106 | name: string.value.source.abc 107 | tempo: 108 | patterns: 109 | - match: ^(Q:)(.*) 110 | captures: 111 | "1": 112 | name: keyword.other.tempo.abc 113 | "2": 114 | name: string.value.tempo.abc 115 | referencenumber: 116 | patterns: 117 | - match: ^(X:)(.*) 118 | captures: 119 | "1": 120 | name: keyword.other.referencenumber.abc 121 | "2": 122 | name: string.value.referencenumber.abc 123 | composer: 124 | patterns: 125 | - match: ^(C:)(.*) 126 | captures: 127 | "1": 128 | name: keyword.other.composer.abc 129 | "2": 130 | name: string.value.composer.abc 131 | origin: 132 | patterns: 133 | - match: ^(O:)(.*) 134 | captures: 135 | "1": 136 | name: keyword.other.origin.abc 137 | "2": 138 | name: string.value.origin.abc 139 | instructions: 140 | patterns: 141 | - match: ^%%.* 142 | name: keyword.other.instruction.abc 143 | annotations: 144 | patterns: 145 | - match: '"([^".]*)"' 146 | name: comment 147 | comments: 148 | patterns: 149 | - match: "%.*" 150 | name: comment.line.abc 151 | voice-section: 152 | name: abc.section.voice 153 | begin: ^(V:\d)(.*) 154 | beginCaptures: 155 | "0": 156 | name: keyword.other.region.voice.abc 157 | while: (?# include lines until one contains 'V:')^(?!V:\d|X:) 158 | patterns: 159 | - include: "#annotations" 160 | - include: "#words" 161 | - include: "#bar" 162 | - include: "#ornaments" 163 | accidentalsAndOctaves: 164 | patterns: 165 | - match: "[\\^_=,']" 166 | name: string 167 | words: 168 | patterns: 169 | - match: ^([Ww]:)(.*) 170 | name: keyword.other.words.abc 171 | bar: 172 | patterns: 173 | - match: :?\|[:\]]? 174 | name: keyword.other.bar.abc 175 | ornaments: 176 | patterns: 177 | - match: \!([^\!.]*)\! 178 | name: entity.name.type.other.ornaments.abc 179 | symbols: 180 | patterns: 181 | - match: "!([^!.]*)!" 182 | name: keyword.other.symbols.abc 183 | ties: 184 | patterns: 185 | - match: \( 186 | name: string 187 | - match: \) 188 | name: string 189 | chord: 190 | patterns: 191 | - match: \[ 192 | name: string 193 | - match: \] 194 | name: string 195 | voice: 196 | patterns: 197 | - match: ^\[V:[^\]]*\] 198 | name: comment 199 | note-rhythm: 200 | patterns: 201 | - match: "[><]" 202 | name: string 203 | - match: (?!^[a-gzA-GZ]([,']?)+)[/0-9]+ 204 | name: string 205 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "abcjs-vscode", 3 | "version": "2.8.1", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "abcjs-vscode", 9 | "version": "2.8.1", 10 | "license": "GPL-3.0-or-later", 11 | "devDependencies": { 12 | "@types/glob": "8.1.0", 13 | "@types/mocha": "10.0.1", 14 | "@types/node": "16.0.0", 15 | "@types/vscode": "1.75.0", 16 | "@typescript-eslint/eslint-plugin": "5.58.0", 17 | "@typescript-eslint/parser": "5.58.0", 18 | "@vscode/test-electron": "2.3.0", 19 | "@vscode/vsce": "2.19.0", 20 | "esbuild": "0.17.16", 21 | "eslint": "8.38.0", 22 | "glob": "8.0.3", 23 | "mocha": "10.2.0", 24 | "typescript": "5.0.4" 25 | }, 26 | "engines": { 27 | "vscode": "^1.75.0" 28 | } 29 | }, 30 | "node_modules/@esbuild/android-arm": { 31 | "version": "0.17.16", 32 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.16.tgz", 33 | "integrity": "sha512-baLqRpLe4JnKrUXLJChoTN0iXZH7El/mu58GE3WIA6/H834k0XWvLRmGLG8y8arTRS9hJJibPnF0tiGhmWeZgw==", 34 | "cpu": [ 35 | "arm" 36 | ], 37 | "dev": true, 38 | "optional": true, 39 | "os": [ 40 | "android" 41 | ], 42 | "engines": { 43 | "node": ">=12" 44 | } 45 | }, 46 | "node_modules/@esbuild/android-arm64": { 47 | "version": "0.17.16", 48 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.16.tgz", 49 | "integrity": "sha512-QX48qmsEZW+gcHgTmAj+x21mwTz8MlYQBnzF6861cNdQGvj2jzzFjqH0EBabrIa/WVZ2CHolwMoqxVryqKt8+Q==", 50 | "cpu": [ 51 | "arm64" 52 | ], 53 | "dev": true, 54 | "optional": true, 55 | "os": [ 56 | "android" 57 | ], 58 | "engines": { 59 | "node": ">=12" 60 | } 61 | }, 62 | "node_modules/@esbuild/android-x64": { 63 | "version": "0.17.16", 64 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.16.tgz", 65 | "integrity": "sha512-G4wfHhrrz99XJgHnzFvB4UwwPxAWZaZBOFXh+JH1Duf1I4vIVfuYY9uVLpx4eiV2D/Jix8LJY+TAdZ3i40tDow==", 66 | "cpu": [ 67 | "x64" 68 | ], 69 | "dev": true, 70 | "optional": true, 71 | "os": [ 72 | "android" 73 | ], 74 | "engines": { 75 | "node": ">=12" 76 | } 77 | }, 78 | "node_modules/@esbuild/darwin-arm64": { 79 | "version": "0.17.16", 80 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.16.tgz", 81 | "integrity": "sha512-/Ofw8UXZxuzTLsNFmz1+lmarQI6ztMZ9XktvXedTbt3SNWDn0+ODTwxExLYQ/Hod91EZB4vZPQJLoqLF0jvEzA==", 82 | "cpu": [ 83 | "arm64" 84 | ], 85 | "dev": true, 86 | "optional": true, 87 | "os": [ 88 | "darwin" 89 | ], 90 | "engines": { 91 | "node": ">=12" 92 | } 93 | }, 94 | "node_modules/@esbuild/darwin-x64": { 95 | "version": "0.17.16", 96 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.16.tgz", 97 | "integrity": "sha512-SzBQtCV3Pdc9kyizh36Ol+dNVhkDyIrGb/JXZqFq8WL37LIyrXU0gUpADcNV311sCOhvY+f2ivMhb5Tuv8nMOQ==", 98 | "cpu": [ 99 | "x64" 100 | ], 101 | "dev": true, 102 | "optional": true, 103 | "os": [ 104 | "darwin" 105 | ], 106 | "engines": { 107 | "node": ">=12" 108 | } 109 | }, 110 | "node_modules/@esbuild/freebsd-arm64": { 111 | "version": "0.17.16", 112 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.16.tgz", 113 | "integrity": "sha512-ZqftdfS1UlLiH1DnS2u3It7l4Bc3AskKeu+paJSfk7RNOMrOxmeFDhLTMQqMxycP1C3oj8vgkAT6xfAuq7ZPRA==", 114 | "cpu": [ 115 | "arm64" 116 | ], 117 | "dev": true, 118 | "optional": true, 119 | "os": [ 120 | "freebsd" 121 | ], 122 | "engines": { 123 | "node": ">=12" 124 | } 125 | }, 126 | "node_modules/@esbuild/freebsd-x64": { 127 | "version": "0.17.16", 128 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.16.tgz", 129 | "integrity": "sha512-rHV6zNWW1tjgsu0dKQTX9L0ByiJHHLvQKrWtnz8r0YYJI27FU3Xu48gpK2IBj1uCSYhJ+pEk6Y0Um7U3rIvV8g==", 130 | "cpu": [ 131 | "x64" 132 | ], 133 | "dev": true, 134 | "optional": true, 135 | "os": [ 136 | "freebsd" 137 | ], 138 | "engines": { 139 | "node": ">=12" 140 | } 141 | }, 142 | "node_modules/@esbuild/linux-arm": { 143 | "version": "0.17.16", 144 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.16.tgz", 145 | "integrity": "sha512-n4O8oVxbn7nl4+m+ISb0a68/lcJClIbaGAoXwqeubj/D1/oMMuaAXmJVfFlRjJLu/ZvHkxoiFJnmbfp4n8cdSw==", 146 | "cpu": [ 147 | "arm" 148 | ], 149 | "dev": true, 150 | "optional": true, 151 | "os": [ 152 | "linux" 153 | ], 154 | "engines": { 155 | "node": ">=12" 156 | } 157 | }, 158 | "node_modules/@esbuild/linux-arm64": { 159 | "version": "0.17.16", 160 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.16.tgz", 161 | "integrity": "sha512-8yoZhGkU6aHu38WpaM4HrRLTFc7/VVD9Q2SvPcmIQIipQt2I/GMTZNdEHXoypbbGao5kggLcxg0iBKjo0SQYKA==", 162 | "cpu": [ 163 | "arm64" 164 | ], 165 | "dev": true, 166 | "optional": true, 167 | "os": [ 168 | "linux" 169 | ], 170 | "engines": { 171 | "node": ">=12" 172 | } 173 | }, 174 | "node_modules/@esbuild/linux-ia32": { 175 | "version": "0.17.16", 176 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.16.tgz", 177 | "integrity": "sha512-9ZBjlkdaVYxPNO8a7OmzDbOH9FMQ1a58j7Xb21UfRU29KcEEU3VTHk+Cvrft/BNv0gpWJMiiZ/f4w0TqSP0gLA==", 178 | "cpu": [ 179 | "ia32" 180 | ], 181 | "dev": true, 182 | "optional": true, 183 | "os": [ 184 | "linux" 185 | ], 186 | "engines": { 187 | "node": ">=12" 188 | } 189 | }, 190 | "node_modules/@esbuild/linux-loong64": { 191 | "version": "0.17.16", 192 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.16.tgz", 193 | "integrity": "sha512-TIZTRojVBBzdgChY3UOG7BlPhqJz08AL7jdgeeu+kiObWMFzGnQD7BgBBkWRwOtKR1i2TNlO7YK6m4zxVjjPRQ==", 194 | "cpu": [ 195 | "loong64" 196 | ], 197 | "dev": true, 198 | "optional": true, 199 | "os": [ 200 | "linux" 201 | ], 202 | "engines": { 203 | "node": ">=12" 204 | } 205 | }, 206 | "node_modules/@esbuild/linux-mips64el": { 207 | "version": "0.17.16", 208 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.16.tgz", 209 | "integrity": "sha512-UPeRuFKCCJYpBbIdczKyHLAIU31GEm0dZl1eMrdYeXDH+SJZh/i+2cAmD3A1Wip9pIc5Sc6Kc5cFUrPXtR0XHA==", 210 | "cpu": [ 211 | "mips64el" 212 | ], 213 | "dev": true, 214 | "optional": true, 215 | "os": [ 216 | "linux" 217 | ], 218 | "engines": { 219 | "node": ">=12" 220 | } 221 | }, 222 | "node_modules/@esbuild/linux-ppc64": { 223 | "version": "0.17.16", 224 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.16.tgz", 225 | "integrity": "sha512-io6yShgIEgVUhExJejJ21xvO5QtrbiSeI7vYUnr7l+v/O9t6IowyhdiYnyivX2X5ysOVHAuyHW+Wyi7DNhdw6Q==", 226 | "cpu": [ 227 | "ppc64" 228 | ], 229 | "dev": true, 230 | "optional": true, 231 | "os": [ 232 | "linux" 233 | ], 234 | "engines": { 235 | "node": ">=12" 236 | } 237 | }, 238 | "node_modules/@esbuild/linux-riscv64": { 239 | "version": "0.17.16", 240 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.16.tgz", 241 | "integrity": "sha512-WhlGeAHNbSdG/I2gqX2RK2gfgSNwyJuCiFHMc8s3GNEMMHUI109+VMBfhVqRb0ZGzEeRiibi8dItR3ws3Lk+cA==", 242 | "cpu": [ 243 | "riscv64" 244 | ], 245 | "dev": true, 246 | "optional": true, 247 | "os": [ 248 | "linux" 249 | ], 250 | "engines": { 251 | "node": ">=12" 252 | } 253 | }, 254 | "node_modules/@esbuild/linux-s390x": { 255 | "version": "0.17.16", 256 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.16.tgz", 257 | "integrity": "sha512-gHRReYsJtViir63bXKoFaQ4pgTyah4ruiMRQ6im9YZuv+gp3UFJkNTY4sFA73YDynmXZA6hi45en4BGhNOJUsw==", 258 | "cpu": [ 259 | "s390x" 260 | ], 261 | "dev": true, 262 | "optional": true, 263 | "os": [ 264 | "linux" 265 | ], 266 | "engines": { 267 | "node": ">=12" 268 | } 269 | }, 270 | "node_modules/@esbuild/linux-x64": { 271 | "version": "0.17.16", 272 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.16.tgz", 273 | "integrity": "sha512-mfiiBkxEbUHvi+v0P+TS7UnA9TeGXR48aK4XHkTj0ZwOijxexgMF01UDFaBX7Q6CQsB0d+MFNv9IiXbIHTNd4g==", 274 | "cpu": [ 275 | "x64" 276 | ], 277 | "dev": true, 278 | "optional": true, 279 | "os": [ 280 | "linux" 281 | ], 282 | "engines": { 283 | "node": ">=12" 284 | } 285 | }, 286 | "node_modules/@esbuild/netbsd-x64": { 287 | "version": "0.17.16", 288 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.16.tgz", 289 | "integrity": "sha512-n8zK1YRDGLRZfVcswcDMDM0j2xKYLNXqei217a4GyBxHIuPMGrrVuJ+Ijfpr0Kufcm7C1k/qaIrGy6eG7wvgmA==", 290 | "cpu": [ 291 | "x64" 292 | ], 293 | "dev": true, 294 | "optional": true, 295 | "os": [ 296 | "netbsd" 297 | ], 298 | "engines": { 299 | "node": ">=12" 300 | } 301 | }, 302 | "node_modules/@esbuild/openbsd-x64": { 303 | "version": "0.17.16", 304 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.16.tgz", 305 | "integrity": "sha512-lEEfkfsUbo0xC47eSTBqsItXDSzwzwhKUSsVaVjVji07t8+6KA5INp2rN890dHZeueXJAI8q0tEIfbwVRYf6Ew==", 306 | "cpu": [ 307 | "x64" 308 | ], 309 | "dev": true, 310 | "optional": true, 311 | "os": [ 312 | "openbsd" 313 | ], 314 | "engines": { 315 | "node": ">=12" 316 | } 317 | }, 318 | "node_modules/@esbuild/sunos-x64": { 319 | "version": "0.17.16", 320 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.16.tgz", 321 | "integrity": "sha512-jlRjsuvG1fgGwnE8Afs7xYDnGz0dBgTNZfgCK6TlvPH3Z13/P5pi6I57vyLE8qZYLrGVtwcm9UbUx1/mZ8Ukag==", 322 | "cpu": [ 323 | "x64" 324 | ], 325 | "dev": true, 326 | "optional": true, 327 | "os": [ 328 | "sunos" 329 | ], 330 | "engines": { 331 | "node": ">=12" 332 | } 333 | }, 334 | "node_modules/@esbuild/win32-arm64": { 335 | "version": "0.17.16", 336 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.16.tgz", 337 | "integrity": "sha512-TzoU2qwVe2boOHl/3KNBUv2PNUc38U0TNnzqOAcgPiD/EZxT2s736xfC2dYQbszAwo4MKzzwBV0iHjhfjxMimg==", 338 | "cpu": [ 339 | "arm64" 340 | ], 341 | "dev": true, 342 | "optional": true, 343 | "os": [ 344 | "win32" 345 | ], 346 | "engines": { 347 | "node": ">=12" 348 | } 349 | }, 350 | "node_modules/@esbuild/win32-ia32": { 351 | "version": "0.17.16", 352 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.16.tgz", 353 | "integrity": "sha512-B8b7W+oo2yb/3xmwk9Vc99hC9bNolvqjaTZYEfMQhzdpBsjTvZBlXQ/teUE55Ww6sg//wlcDjOaqldOKyigWdA==", 354 | "cpu": [ 355 | "ia32" 356 | ], 357 | "dev": true, 358 | "optional": true, 359 | "os": [ 360 | "win32" 361 | ], 362 | "engines": { 363 | "node": ">=12" 364 | } 365 | }, 366 | "node_modules/@esbuild/win32-x64": { 367 | "version": "0.17.16", 368 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.16.tgz", 369 | "integrity": "sha512-xJ7OH/nanouJO9pf03YsL9NAFQBHd8AqfrQd7Pf5laGyyTt/gToul6QYOA/i5i/q8y9iaM5DQFNTgpi995VkOg==", 370 | "cpu": [ 371 | "x64" 372 | ], 373 | "dev": true, 374 | "optional": true, 375 | "os": [ 376 | "win32" 377 | ], 378 | "engines": { 379 | "node": ">=12" 380 | } 381 | }, 382 | "node_modules/@eslint-community/eslint-utils": { 383 | "version": "4.4.0", 384 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 385 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 386 | "dev": true, 387 | "dependencies": { 388 | "eslint-visitor-keys": "^3.3.0" 389 | }, 390 | "engines": { 391 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 392 | }, 393 | "peerDependencies": { 394 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 395 | } 396 | }, 397 | "node_modules/@eslint-community/regexpp": { 398 | "version": "4.5.0", 399 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.5.0.tgz", 400 | "integrity": "sha512-vITaYzIcNmjn5tF5uxcZ/ft7/RXGrMUIS9HalWckEOF6ESiwXKoMzAQf2UW0aVd6rnOeExTJVd5hmWXucBKGXQ==", 401 | "dev": true, 402 | "engines": { 403 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 404 | } 405 | }, 406 | "node_modules/@eslint/eslintrc": { 407 | "version": "2.0.2", 408 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.0.2.tgz", 409 | "integrity": "sha512-3W4f5tDUra+pA+FzgugqL2pRimUTDJWKr7BINqOpkZrC0uYI0NIc0/JFgBROCU07HR6GieA5m3/rsPIhDmCXTQ==", 410 | "dev": true, 411 | "dependencies": { 412 | "ajv": "^6.12.4", 413 | "debug": "^4.3.2", 414 | "espree": "^9.5.1", 415 | "globals": "^13.19.0", 416 | "ignore": "^5.2.0", 417 | "import-fresh": "^3.2.1", 418 | "js-yaml": "^4.1.0", 419 | "minimatch": "^3.1.2", 420 | "strip-json-comments": "^3.1.1" 421 | }, 422 | "engines": { 423 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 424 | }, 425 | "funding": { 426 | "url": "https://opencollective.com/eslint" 427 | } 428 | }, 429 | "node_modules/@eslint/js": { 430 | "version": "8.38.0", 431 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.38.0.tgz", 432 | "integrity": "sha512-IoD2MfUnOV58ghIHCiil01PcohxjbYR/qCxsoC+xNgUwh1EY8jOOrYmu3d3a71+tJJ23uscEV4X2HJWMsPJu4g==", 433 | "dev": true, 434 | "engines": { 435 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 436 | } 437 | }, 438 | "node_modules/@humanwhocodes/config-array": { 439 | "version": "0.11.8", 440 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.8.tgz", 441 | "integrity": "sha512-UybHIJzJnR5Qc/MsD9Kr+RpO2h+/P1GhOwdiLPXK5TWk5sgTdu88bTD9UP+CKbPPh5Rni1u0GjAdYQLemG8g+g==", 442 | "dev": true, 443 | "dependencies": { 444 | "@humanwhocodes/object-schema": "^1.2.1", 445 | "debug": "^4.1.1", 446 | "minimatch": "^3.0.5" 447 | }, 448 | "engines": { 449 | "node": ">=10.10.0" 450 | } 451 | }, 452 | "node_modules/@humanwhocodes/module-importer": { 453 | "version": "1.0.1", 454 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 455 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 456 | "dev": true, 457 | "engines": { 458 | "node": ">=12.22" 459 | }, 460 | "funding": { 461 | "type": "github", 462 | "url": "https://github.com/sponsors/nzakas" 463 | } 464 | }, 465 | "node_modules/@humanwhocodes/object-schema": { 466 | "version": "1.2.1", 467 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 468 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 469 | "dev": true 470 | }, 471 | "node_modules/@nodelib/fs.scandir": { 472 | "version": "2.1.5", 473 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 474 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 475 | "dev": true, 476 | "dependencies": { 477 | "@nodelib/fs.stat": "2.0.5", 478 | "run-parallel": "^1.1.9" 479 | }, 480 | "engines": { 481 | "node": ">= 8" 482 | } 483 | }, 484 | "node_modules/@nodelib/fs.stat": { 485 | "version": "2.0.5", 486 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 487 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 488 | "dev": true, 489 | "engines": { 490 | "node": ">= 8" 491 | } 492 | }, 493 | "node_modules/@nodelib/fs.walk": { 494 | "version": "1.2.8", 495 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 496 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 497 | "dev": true, 498 | "dependencies": { 499 | "@nodelib/fs.scandir": "2.1.5", 500 | "fastq": "^1.6.0" 501 | }, 502 | "engines": { 503 | "node": ">= 8" 504 | } 505 | }, 506 | "node_modules/@tootallnate/once": { 507 | "version": "1.1.2", 508 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 509 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", 510 | "dev": true, 511 | "engines": { 512 | "node": ">= 6" 513 | } 514 | }, 515 | "node_modules/@types/glob": { 516 | "version": "8.1.0", 517 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-8.1.0.tgz", 518 | "integrity": "sha512-IO+MJPVhoqz+28h1qLAcBEH2+xHMK6MTyHJc7MTnnYb6wsoLR29POVGJ7LycmVXIqyy/4/2ShP5sUwTXuOwb/w==", 519 | "dev": true, 520 | "dependencies": { 521 | "@types/minimatch": "^5.1.2", 522 | "@types/node": "*" 523 | } 524 | }, 525 | "node_modules/@types/json-schema": { 526 | "version": "7.0.11", 527 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz", 528 | "integrity": "sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==", 529 | "dev": true 530 | }, 531 | "node_modules/@types/minimatch": { 532 | "version": "5.1.2", 533 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-5.1.2.tgz", 534 | "integrity": "sha512-K0VQKziLUWkVKiRVrx4a40iPaxTUefQmjtkQofBkYRcoaaL/8rhwDWww9qWbrgicNOgnpIsMxyNIUM4+n6dUIA==", 535 | "dev": true 536 | }, 537 | "node_modules/@types/mocha": { 538 | "version": "10.0.1", 539 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-10.0.1.tgz", 540 | "integrity": "sha512-/fvYntiO1GeICvqbQ3doGDIP97vWmvFt83GKguJ6prmQM2iXZfFcq6YE8KteFyRtX2/h5Hf91BYvPodJKFYv5Q==", 541 | "dev": true 542 | }, 543 | "node_modules/@types/node": { 544 | "version": "16.0.0", 545 | "resolved": "https://registry.npmjs.org/@types/node/-/node-16.0.0.tgz", 546 | "integrity": "sha512-TmCW5HoZ2o2/z2EYi109jLqIaPIi9y/lc2LmDCWzuCi35bcaQ+OtUh6nwBiFK7SOu25FAU5+YKdqFZUwtqGSdg==", 547 | "dev": true 548 | }, 549 | "node_modules/@types/semver": { 550 | "version": "7.3.13", 551 | "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.3.13.tgz", 552 | "integrity": "sha512-21cFJr9z3g5dW8B0CVI9g2O9beqaThGQ6ZFBqHfwhzLDKUxaqTIy3vnfah/UPkfOiF2pLq+tGz+W8RyCskuslw==", 553 | "dev": true 554 | }, 555 | "node_modules/@types/vscode": { 556 | "version": "1.75.0", 557 | "resolved": "https://registry.npmjs.org/@types/vscode/-/vscode-1.75.0.tgz", 558 | "integrity": "sha512-SAr0PoOhJS6FUq5LjNr8C/StBKALZwDVm3+U4pjF/3iYkt3GioJOPV/oB1Sf1l7lROe4TgrMyL5N1yaEgTWycw==", 559 | "dev": true 560 | }, 561 | "node_modules/@typescript-eslint/eslint-plugin": { 562 | "version": "5.58.0", 563 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.58.0.tgz", 564 | "integrity": "sha512-vxHvLhH0qgBd3/tW6/VccptSfc8FxPQIkmNTVLWcCOVqSBvqpnKkBTYrhcGlXfSnd78azwe+PsjYFj0X34/njA==", 565 | "dev": true, 566 | "dependencies": { 567 | "@eslint-community/regexpp": "^4.4.0", 568 | "@typescript-eslint/scope-manager": "5.58.0", 569 | "@typescript-eslint/type-utils": "5.58.0", 570 | "@typescript-eslint/utils": "5.58.0", 571 | "debug": "^4.3.4", 572 | "grapheme-splitter": "^1.0.4", 573 | "ignore": "^5.2.0", 574 | "natural-compare-lite": "^1.4.0", 575 | "semver": "^7.3.7", 576 | "tsutils": "^3.21.0" 577 | }, 578 | "engines": { 579 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 580 | }, 581 | "funding": { 582 | "type": "opencollective", 583 | "url": "https://opencollective.com/typescript-eslint" 584 | }, 585 | "peerDependencies": { 586 | "@typescript-eslint/parser": "^5.0.0", 587 | "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" 588 | }, 589 | "peerDependenciesMeta": { 590 | "typescript": { 591 | "optional": true 592 | } 593 | } 594 | }, 595 | "node_modules/@typescript-eslint/parser": { 596 | "version": "5.58.0", 597 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.58.0.tgz", 598 | "integrity": "sha512-ixaM3gRtlfrKzP8N6lRhBbjTow1t6ztfBvQNGuRM8qH1bjFFXIJ35XY+FC0RRBKn3C6cT+7VW1y8tNm7DwPHDQ==", 599 | "dev": true, 600 | "dependencies": { 601 | "@typescript-eslint/scope-manager": "5.58.0", 602 | "@typescript-eslint/types": "5.58.0", 603 | "@typescript-eslint/typescript-estree": "5.58.0", 604 | "debug": "^4.3.4" 605 | }, 606 | "engines": { 607 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 608 | }, 609 | "funding": { 610 | "type": "opencollective", 611 | "url": "https://opencollective.com/typescript-eslint" 612 | }, 613 | "peerDependencies": { 614 | "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" 615 | }, 616 | "peerDependenciesMeta": { 617 | "typescript": { 618 | "optional": true 619 | } 620 | } 621 | }, 622 | "node_modules/@typescript-eslint/scope-manager": { 623 | "version": "5.58.0", 624 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.58.0.tgz", 625 | "integrity": "sha512-b+w8ypN5CFvrXWQb9Ow9T4/6LC2MikNf1viLkYTiTbkQl46CnR69w7lajz1icW0TBsYmlpg+mRzFJ4LEJ8X9NA==", 626 | "dev": true, 627 | "dependencies": { 628 | "@typescript-eslint/types": "5.58.0", 629 | "@typescript-eslint/visitor-keys": "5.58.0" 630 | }, 631 | "engines": { 632 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 633 | }, 634 | "funding": { 635 | "type": "opencollective", 636 | "url": "https://opencollective.com/typescript-eslint" 637 | } 638 | }, 639 | "node_modules/@typescript-eslint/type-utils": { 640 | "version": "5.58.0", 641 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.58.0.tgz", 642 | "integrity": "sha512-FF5vP/SKAFJ+LmR9PENql7fQVVgGDOS+dq3j+cKl9iW/9VuZC/8CFmzIP0DLKXfWKpRHawJiG70rVH+xZZbp8w==", 643 | "dev": true, 644 | "dependencies": { 645 | "@typescript-eslint/typescript-estree": "5.58.0", 646 | "@typescript-eslint/utils": "5.58.0", 647 | "debug": "^4.3.4", 648 | "tsutils": "^3.21.0" 649 | }, 650 | "engines": { 651 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 652 | }, 653 | "funding": { 654 | "type": "opencollective", 655 | "url": "https://opencollective.com/typescript-eslint" 656 | }, 657 | "peerDependencies": { 658 | "eslint": "*" 659 | }, 660 | "peerDependenciesMeta": { 661 | "typescript": { 662 | "optional": true 663 | } 664 | } 665 | }, 666 | "node_modules/@typescript-eslint/types": { 667 | "version": "5.58.0", 668 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.58.0.tgz", 669 | "integrity": "sha512-JYV4eITHPzVQMnHZcYJXl2ZloC7thuUHrcUmxtzvItyKPvQ50kb9QXBkgNAt90OYMqwaodQh2kHutWZl1fc+1g==", 670 | "dev": true, 671 | "engines": { 672 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 673 | }, 674 | "funding": { 675 | "type": "opencollective", 676 | "url": "https://opencollective.com/typescript-eslint" 677 | } 678 | }, 679 | "node_modules/@typescript-eslint/typescript-estree": { 680 | "version": "5.58.0", 681 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.58.0.tgz", 682 | "integrity": "sha512-cRACvGTodA+UxnYM2uwA2KCwRL7VAzo45syNysqlMyNyjw0Z35Icc9ihPJZjIYuA5bXJYiJ2YGUB59BqlOZT1Q==", 683 | "dev": true, 684 | "dependencies": { 685 | "@typescript-eslint/types": "5.58.0", 686 | "@typescript-eslint/visitor-keys": "5.58.0", 687 | "debug": "^4.3.4", 688 | "globby": "^11.1.0", 689 | "is-glob": "^4.0.3", 690 | "semver": "^7.3.7", 691 | "tsutils": "^3.21.0" 692 | }, 693 | "engines": { 694 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 695 | }, 696 | "funding": { 697 | "type": "opencollective", 698 | "url": "https://opencollective.com/typescript-eslint" 699 | }, 700 | "peerDependenciesMeta": { 701 | "typescript": { 702 | "optional": true 703 | } 704 | } 705 | }, 706 | "node_modules/@typescript-eslint/utils": { 707 | "version": "5.58.0", 708 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.58.0.tgz", 709 | "integrity": "sha512-gAmLOTFXMXOC+zP1fsqm3VceKSBQJNzV385Ok3+yzlavNHZoedajjS4UyS21gabJYcobuigQPs/z71A9MdJFqQ==", 710 | "dev": true, 711 | "dependencies": { 712 | "@eslint-community/eslint-utils": "^4.2.0", 713 | "@types/json-schema": "^7.0.9", 714 | "@types/semver": "^7.3.12", 715 | "@typescript-eslint/scope-manager": "5.58.0", 716 | "@typescript-eslint/types": "5.58.0", 717 | "@typescript-eslint/typescript-estree": "5.58.0", 718 | "eslint-scope": "^5.1.1", 719 | "semver": "^7.3.7" 720 | }, 721 | "engines": { 722 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 723 | }, 724 | "funding": { 725 | "type": "opencollective", 726 | "url": "https://opencollective.com/typescript-eslint" 727 | }, 728 | "peerDependencies": { 729 | "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" 730 | } 731 | }, 732 | "node_modules/@typescript-eslint/visitor-keys": { 733 | "version": "5.58.0", 734 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.58.0.tgz", 735 | "integrity": "sha512-/fBraTlPj0jwdyTwLyrRTxv/3lnU2H96pNTVM6z3esTWLtA5MZ9ghSMJ7Rb+TtUAdtEw9EyJzJ0EydIMKxQ9gA==", 736 | "dev": true, 737 | "dependencies": { 738 | "@typescript-eslint/types": "5.58.0", 739 | "eslint-visitor-keys": "^3.3.0" 740 | }, 741 | "engines": { 742 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 743 | }, 744 | "funding": { 745 | "type": "opencollective", 746 | "url": "https://opencollective.com/typescript-eslint" 747 | } 748 | }, 749 | "node_modules/@vscode/test-electron": { 750 | "version": "2.3.0", 751 | "resolved": "https://registry.npmjs.org/@vscode/test-electron/-/test-electron-2.3.0.tgz", 752 | "integrity": "sha512-fwzA9RtazH1GT/sckYlbxu6t5e4VaMXwCVtyLv4UAG0hP6NTfnMaaG25XCfWqlVwFhBMcQXHBCy5dmz2eLUnkw==", 753 | "dev": true, 754 | "dependencies": { 755 | "http-proxy-agent": "^4.0.1", 756 | "https-proxy-agent": "^5.0.0", 757 | "jszip": "^3.10.1", 758 | "semver": "^7.3.8" 759 | }, 760 | "engines": { 761 | "node": ">=16" 762 | } 763 | }, 764 | "node_modules/@vscode/vsce": { 765 | "version": "2.19.0", 766 | "resolved": "https://registry.npmjs.org/@vscode/vsce/-/vsce-2.19.0.tgz", 767 | "integrity": "sha512-dAlILxC5ggOutcvJY24jxz913wimGiUrHaPkk16Gm9/PGFbz1YezWtrXsTKUtJws4fIlpX2UIlVlVESWq8lkfQ==", 768 | "dev": true, 769 | "dependencies": { 770 | "azure-devops-node-api": "^11.0.1", 771 | "chalk": "^2.4.2", 772 | "cheerio": "^1.0.0-rc.9", 773 | "commander": "^6.1.0", 774 | "glob": "^7.0.6", 775 | "hosted-git-info": "^4.0.2", 776 | "jsonc-parser": "^3.2.0", 777 | "leven": "^3.1.0", 778 | "markdown-it": "^12.3.2", 779 | "mime": "^1.3.4", 780 | "minimatch": "^3.0.3", 781 | "parse-semver": "^1.1.1", 782 | "read": "^1.0.7", 783 | "semver": "^5.1.0", 784 | "tmp": "^0.2.1", 785 | "typed-rest-client": "^1.8.4", 786 | "url-join": "^4.0.1", 787 | "xml2js": "^0.5.0", 788 | "yauzl": "^2.3.1", 789 | "yazl": "^2.2.2" 790 | }, 791 | "bin": { 792 | "vsce": "vsce" 793 | }, 794 | "engines": { 795 | "node": ">= 14" 796 | }, 797 | "optionalDependencies": { 798 | "keytar": "^7.7.0" 799 | } 800 | }, 801 | "node_modules/@vscode/vsce/node_modules/glob": { 802 | "version": "7.2.3", 803 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 804 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 805 | "dev": true, 806 | "dependencies": { 807 | "fs.realpath": "^1.0.0", 808 | "inflight": "^1.0.4", 809 | "inherits": "2", 810 | "minimatch": "^3.1.1", 811 | "once": "^1.3.0", 812 | "path-is-absolute": "^1.0.0" 813 | }, 814 | "engines": { 815 | "node": "*" 816 | }, 817 | "funding": { 818 | "url": "https://github.com/sponsors/isaacs" 819 | } 820 | }, 821 | "node_modules/@vscode/vsce/node_modules/semver": { 822 | "version": "5.7.1", 823 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 824 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 825 | "dev": true, 826 | "bin": { 827 | "semver": "bin/semver" 828 | } 829 | }, 830 | "node_modules/acorn": { 831 | "version": "8.8.2", 832 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.2.tgz", 833 | "integrity": "sha512-xjIYgE8HBrkpd/sJqOGNspf8uHG+NOHGOw6a/Urj8taM2EXfdNAH2oFcPeIFfsv3+kz/mJrS5VuMqbNLjCa2vw==", 834 | "dev": true, 835 | "bin": { 836 | "acorn": "bin/acorn" 837 | }, 838 | "engines": { 839 | "node": ">=0.4.0" 840 | } 841 | }, 842 | "node_modules/acorn-jsx": { 843 | "version": "5.3.2", 844 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 845 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 846 | "dev": true, 847 | "peerDependencies": { 848 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 849 | } 850 | }, 851 | "node_modules/agent-base": { 852 | "version": "6.0.2", 853 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 854 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 855 | "dev": true, 856 | "dependencies": { 857 | "debug": "4" 858 | }, 859 | "engines": { 860 | "node": ">= 6.0.0" 861 | } 862 | }, 863 | "node_modules/ajv": { 864 | "version": "6.12.6", 865 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 866 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 867 | "dev": true, 868 | "dependencies": { 869 | "fast-deep-equal": "^3.1.1", 870 | "fast-json-stable-stringify": "^2.0.0", 871 | "json-schema-traverse": "^0.4.1", 872 | "uri-js": "^4.2.2" 873 | }, 874 | "funding": { 875 | "type": "github", 876 | "url": "https://github.com/sponsors/epoberezkin" 877 | } 878 | }, 879 | "node_modules/ansi-colors": { 880 | "version": "4.1.1", 881 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 882 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 883 | "dev": true, 884 | "engines": { 885 | "node": ">=6" 886 | } 887 | }, 888 | "node_modules/ansi-regex": { 889 | "version": "5.0.1", 890 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 891 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 892 | "dev": true, 893 | "engines": { 894 | "node": ">=8" 895 | } 896 | }, 897 | "node_modules/ansi-styles": { 898 | "version": "3.2.1", 899 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 900 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 901 | "dev": true, 902 | "dependencies": { 903 | "color-convert": "^1.9.0" 904 | }, 905 | "engines": { 906 | "node": ">=4" 907 | } 908 | }, 909 | "node_modules/anymatch": { 910 | "version": "3.1.3", 911 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 912 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 913 | "dev": true, 914 | "dependencies": { 915 | "normalize-path": "^3.0.0", 916 | "picomatch": "^2.0.4" 917 | }, 918 | "engines": { 919 | "node": ">= 8" 920 | } 921 | }, 922 | "node_modules/argparse": { 923 | "version": "2.0.1", 924 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 925 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 926 | "dev": true 927 | }, 928 | "node_modules/array-union": { 929 | "version": "2.1.0", 930 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 931 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 932 | "dev": true, 933 | "engines": { 934 | "node": ">=8" 935 | } 936 | }, 937 | "node_modules/azure-devops-node-api": { 938 | "version": "11.2.0", 939 | "resolved": "https://registry.npmjs.org/azure-devops-node-api/-/azure-devops-node-api-11.2.0.tgz", 940 | "integrity": "sha512-XdiGPhrpaT5J8wdERRKs5g8E0Zy1pvOYTli7z9E8nmOn3YGp4FhtjhrOyFmX/8veWCwdI69mCHKJw6l+4J/bHA==", 941 | "dev": true, 942 | "dependencies": { 943 | "tunnel": "0.0.6", 944 | "typed-rest-client": "^1.8.4" 945 | } 946 | }, 947 | "node_modules/balanced-match": { 948 | "version": "1.0.2", 949 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 950 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 951 | "dev": true 952 | }, 953 | "node_modules/base64-js": { 954 | "version": "1.5.1", 955 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 956 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", 957 | "dev": true, 958 | "funding": [ 959 | { 960 | "type": "github", 961 | "url": "https://github.com/sponsors/feross" 962 | }, 963 | { 964 | "type": "patreon", 965 | "url": "https://www.patreon.com/feross" 966 | }, 967 | { 968 | "type": "consulting", 969 | "url": "https://feross.org/support" 970 | } 971 | ], 972 | "optional": true 973 | }, 974 | "node_modules/binary-extensions": { 975 | "version": "2.2.0", 976 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 977 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 978 | "dev": true, 979 | "engines": { 980 | "node": ">=8" 981 | } 982 | }, 983 | "node_modules/bl": { 984 | "version": "4.1.0", 985 | "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz", 986 | "integrity": "sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==", 987 | "dev": true, 988 | "optional": true, 989 | "dependencies": { 990 | "buffer": "^5.5.0", 991 | "inherits": "^2.0.4", 992 | "readable-stream": "^3.4.0" 993 | } 994 | }, 995 | "node_modules/boolbase": { 996 | "version": "1.0.0", 997 | "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", 998 | "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==", 999 | "dev": true 1000 | }, 1001 | "node_modules/brace-expansion": { 1002 | "version": "1.1.11", 1003 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1004 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1005 | "dev": true, 1006 | "dependencies": { 1007 | "balanced-match": "^1.0.0", 1008 | "concat-map": "0.0.1" 1009 | } 1010 | }, 1011 | "node_modules/braces": { 1012 | "version": "3.0.2", 1013 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 1014 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 1015 | "dev": true, 1016 | "dependencies": { 1017 | "fill-range": "^7.0.1" 1018 | }, 1019 | "engines": { 1020 | "node": ">=8" 1021 | } 1022 | }, 1023 | "node_modules/browser-stdout": { 1024 | "version": "1.3.1", 1025 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 1026 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 1027 | "dev": true 1028 | }, 1029 | "node_modules/buffer": { 1030 | "version": "5.7.1", 1031 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", 1032 | "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", 1033 | "dev": true, 1034 | "funding": [ 1035 | { 1036 | "type": "github", 1037 | "url": "https://github.com/sponsors/feross" 1038 | }, 1039 | { 1040 | "type": "patreon", 1041 | "url": "https://www.patreon.com/feross" 1042 | }, 1043 | { 1044 | "type": "consulting", 1045 | "url": "https://feross.org/support" 1046 | } 1047 | ], 1048 | "optional": true, 1049 | "dependencies": { 1050 | "base64-js": "^1.3.1", 1051 | "ieee754": "^1.1.13" 1052 | } 1053 | }, 1054 | "node_modules/buffer-crc32": { 1055 | "version": "0.2.13", 1056 | "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", 1057 | "integrity": "sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ==", 1058 | "dev": true, 1059 | "engines": { 1060 | "node": "*" 1061 | } 1062 | }, 1063 | "node_modules/call-bind": { 1064 | "version": "1.0.2", 1065 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 1066 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 1067 | "dev": true, 1068 | "dependencies": { 1069 | "function-bind": "^1.1.1", 1070 | "get-intrinsic": "^1.0.2" 1071 | }, 1072 | "funding": { 1073 | "url": "https://github.com/sponsors/ljharb" 1074 | } 1075 | }, 1076 | "node_modules/callsites": { 1077 | "version": "3.1.0", 1078 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1079 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 1080 | "dev": true, 1081 | "engines": { 1082 | "node": ">=6" 1083 | } 1084 | }, 1085 | "node_modules/camelcase": { 1086 | "version": "6.3.0", 1087 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 1088 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 1089 | "dev": true, 1090 | "engines": { 1091 | "node": ">=10" 1092 | }, 1093 | "funding": { 1094 | "url": "https://github.com/sponsors/sindresorhus" 1095 | } 1096 | }, 1097 | "node_modules/chalk": { 1098 | "version": "2.4.2", 1099 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1100 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1101 | "dev": true, 1102 | "dependencies": { 1103 | "ansi-styles": "^3.2.1", 1104 | "escape-string-regexp": "^1.0.5", 1105 | "supports-color": "^5.3.0" 1106 | }, 1107 | "engines": { 1108 | "node": ">=4" 1109 | } 1110 | }, 1111 | "node_modules/cheerio": { 1112 | "version": "1.0.0-rc.12", 1113 | "resolved": "https://registry.npmjs.org/cheerio/-/cheerio-1.0.0-rc.12.tgz", 1114 | "integrity": "sha512-VqR8m68vM46BNnuZ5NtnGBKIE/DfN0cRIzg9n40EIq9NOv90ayxLBXA8fXC5gquFRGJSTRqBq25Jt2ECLR431Q==", 1115 | "dev": true, 1116 | "dependencies": { 1117 | "cheerio-select": "^2.1.0", 1118 | "dom-serializer": "^2.0.0", 1119 | "domhandler": "^5.0.3", 1120 | "domutils": "^3.0.1", 1121 | "htmlparser2": "^8.0.1", 1122 | "parse5": "^7.0.0", 1123 | "parse5-htmlparser2-tree-adapter": "^7.0.0" 1124 | }, 1125 | "engines": { 1126 | "node": ">= 6" 1127 | }, 1128 | "funding": { 1129 | "url": "https://github.com/cheeriojs/cheerio?sponsor=1" 1130 | } 1131 | }, 1132 | "node_modules/cheerio-select": { 1133 | "version": "2.1.0", 1134 | "resolved": "https://registry.npmjs.org/cheerio-select/-/cheerio-select-2.1.0.tgz", 1135 | "integrity": "sha512-9v9kG0LvzrlcungtnJtpGNxY+fzECQKhK4EGJX2vByejiMX84MFNQw4UxPJl3bFbTMw+Dfs37XaIkCwTZfLh4g==", 1136 | "dev": true, 1137 | "dependencies": { 1138 | "boolbase": "^1.0.0", 1139 | "css-select": "^5.1.0", 1140 | "css-what": "^6.1.0", 1141 | "domelementtype": "^2.3.0", 1142 | "domhandler": "^5.0.3", 1143 | "domutils": "^3.0.1" 1144 | }, 1145 | "funding": { 1146 | "url": "https://github.com/sponsors/fb55" 1147 | } 1148 | }, 1149 | "node_modules/chokidar": { 1150 | "version": "3.5.3", 1151 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", 1152 | "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", 1153 | "dev": true, 1154 | "funding": [ 1155 | { 1156 | "type": "individual", 1157 | "url": "https://paulmillr.com/funding/" 1158 | } 1159 | ], 1160 | "dependencies": { 1161 | "anymatch": "~3.1.2", 1162 | "braces": "~3.0.2", 1163 | "glob-parent": "~5.1.2", 1164 | "is-binary-path": "~2.1.0", 1165 | "is-glob": "~4.0.1", 1166 | "normalize-path": "~3.0.0", 1167 | "readdirp": "~3.6.0" 1168 | }, 1169 | "engines": { 1170 | "node": ">= 8.10.0" 1171 | }, 1172 | "optionalDependencies": { 1173 | "fsevents": "~2.3.2" 1174 | } 1175 | }, 1176 | "node_modules/chokidar/node_modules/glob-parent": { 1177 | "version": "5.1.2", 1178 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1179 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1180 | "dev": true, 1181 | "dependencies": { 1182 | "is-glob": "^4.0.1" 1183 | }, 1184 | "engines": { 1185 | "node": ">= 6" 1186 | } 1187 | }, 1188 | "node_modules/chownr": { 1189 | "version": "1.1.4", 1190 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", 1191 | "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==", 1192 | "dev": true, 1193 | "optional": true 1194 | }, 1195 | "node_modules/cliui": { 1196 | "version": "7.0.4", 1197 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 1198 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 1199 | "dev": true, 1200 | "dependencies": { 1201 | "string-width": "^4.2.0", 1202 | "strip-ansi": "^6.0.0", 1203 | "wrap-ansi": "^7.0.0" 1204 | } 1205 | }, 1206 | "node_modules/color-convert": { 1207 | "version": "1.9.3", 1208 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1209 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1210 | "dev": true, 1211 | "dependencies": { 1212 | "color-name": "1.1.3" 1213 | } 1214 | }, 1215 | "node_modules/color-name": { 1216 | "version": "1.1.3", 1217 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1218 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 1219 | "dev": true 1220 | }, 1221 | "node_modules/commander": { 1222 | "version": "6.2.1", 1223 | "resolved": "https://registry.npmjs.org/commander/-/commander-6.2.1.tgz", 1224 | "integrity": "sha512-U7VdrJFnJgo4xjrHpTzu0yrHPGImdsmD95ZlgYSEajAn2JKzDhDTPG9kBTefmObL2w/ngeZnilk+OV9CG3d7UA==", 1225 | "dev": true, 1226 | "engines": { 1227 | "node": ">= 6" 1228 | } 1229 | }, 1230 | "node_modules/concat-map": { 1231 | "version": "0.0.1", 1232 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1233 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 1234 | "dev": true 1235 | }, 1236 | "node_modules/core-util-is": { 1237 | "version": "1.0.3", 1238 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", 1239 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", 1240 | "dev": true 1241 | }, 1242 | "node_modules/cross-spawn": { 1243 | "version": "7.0.3", 1244 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1245 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1246 | "dev": true, 1247 | "dependencies": { 1248 | "path-key": "^3.1.0", 1249 | "shebang-command": "^2.0.0", 1250 | "which": "^2.0.1" 1251 | }, 1252 | "engines": { 1253 | "node": ">= 8" 1254 | } 1255 | }, 1256 | "node_modules/css-select": { 1257 | "version": "5.1.0", 1258 | "resolved": "https://registry.npmjs.org/css-select/-/css-select-5.1.0.tgz", 1259 | "integrity": "sha512-nwoRF1rvRRnnCqqY7updORDsuqKzqYJ28+oSMaJMMgOauh3fvwHqMS7EZpIPqK8GL+g9mKxF1vP/ZjSeNjEVHg==", 1260 | "dev": true, 1261 | "dependencies": { 1262 | "boolbase": "^1.0.0", 1263 | "css-what": "^6.1.0", 1264 | "domhandler": "^5.0.2", 1265 | "domutils": "^3.0.1", 1266 | "nth-check": "^2.0.1" 1267 | }, 1268 | "funding": { 1269 | "url": "https://github.com/sponsors/fb55" 1270 | } 1271 | }, 1272 | "node_modules/css-what": { 1273 | "version": "6.1.0", 1274 | "resolved": "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz", 1275 | "integrity": "sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==", 1276 | "dev": true, 1277 | "engines": { 1278 | "node": ">= 6" 1279 | }, 1280 | "funding": { 1281 | "url": "https://github.com/sponsors/fb55" 1282 | } 1283 | }, 1284 | "node_modules/debug": { 1285 | "version": "4.3.4", 1286 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1287 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1288 | "dev": true, 1289 | "dependencies": { 1290 | "ms": "2.1.2" 1291 | }, 1292 | "engines": { 1293 | "node": ">=6.0" 1294 | }, 1295 | "peerDependenciesMeta": { 1296 | "supports-color": { 1297 | "optional": true 1298 | } 1299 | } 1300 | }, 1301 | "node_modules/decamelize": { 1302 | "version": "4.0.0", 1303 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 1304 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 1305 | "dev": true, 1306 | "engines": { 1307 | "node": ">=10" 1308 | }, 1309 | "funding": { 1310 | "url": "https://github.com/sponsors/sindresorhus" 1311 | } 1312 | }, 1313 | "node_modules/decompress-response": { 1314 | "version": "6.0.0", 1315 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-6.0.0.tgz", 1316 | "integrity": "sha512-aW35yZM6Bb/4oJlZncMH2LCoZtJXTRxES17vE3hoRiowU2kWHaJKFkSBDnDR+cm9J+9QhXmREyIfv0pji9ejCQ==", 1317 | "dev": true, 1318 | "optional": true, 1319 | "dependencies": { 1320 | "mimic-response": "^3.1.0" 1321 | }, 1322 | "engines": { 1323 | "node": ">=10" 1324 | }, 1325 | "funding": { 1326 | "url": "https://github.com/sponsors/sindresorhus" 1327 | } 1328 | }, 1329 | "node_modules/deep-extend": { 1330 | "version": "0.6.0", 1331 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 1332 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", 1333 | "dev": true, 1334 | "optional": true, 1335 | "engines": { 1336 | "node": ">=4.0.0" 1337 | } 1338 | }, 1339 | "node_modules/deep-is": { 1340 | "version": "0.1.4", 1341 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 1342 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 1343 | "dev": true 1344 | }, 1345 | "node_modules/detect-libc": { 1346 | "version": "2.0.1", 1347 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-2.0.1.tgz", 1348 | "integrity": "sha512-463v3ZeIrcWtdgIg6vI6XUncguvr2TnGl4SzDXinkt9mSLpBJKXT3mW6xT3VQdDN11+WVs29pgvivTc4Lp8v+w==", 1349 | "dev": true, 1350 | "optional": true, 1351 | "engines": { 1352 | "node": ">=8" 1353 | } 1354 | }, 1355 | "node_modules/diff": { 1356 | "version": "5.0.0", 1357 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 1358 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 1359 | "dev": true, 1360 | "engines": { 1361 | "node": ">=0.3.1" 1362 | } 1363 | }, 1364 | "node_modules/dir-glob": { 1365 | "version": "3.0.1", 1366 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 1367 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 1368 | "dev": true, 1369 | "dependencies": { 1370 | "path-type": "^4.0.0" 1371 | }, 1372 | "engines": { 1373 | "node": ">=8" 1374 | } 1375 | }, 1376 | "node_modules/doctrine": { 1377 | "version": "3.0.0", 1378 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 1379 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 1380 | "dev": true, 1381 | "dependencies": { 1382 | "esutils": "^2.0.2" 1383 | }, 1384 | "engines": { 1385 | "node": ">=6.0.0" 1386 | } 1387 | }, 1388 | "node_modules/dom-serializer": { 1389 | "version": "2.0.0", 1390 | "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-2.0.0.tgz", 1391 | "integrity": "sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg==", 1392 | "dev": true, 1393 | "dependencies": { 1394 | "domelementtype": "^2.3.0", 1395 | "domhandler": "^5.0.2", 1396 | "entities": "^4.2.0" 1397 | }, 1398 | "funding": { 1399 | "url": "https://github.com/cheeriojs/dom-serializer?sponsor=1" 1400 | } 1401 | }, 1402 | "node_modules/domelementtype": { 1403 | "version": "2.3.0", 1404 | "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz", 1405 | "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==", 1406 | "dev": true, 1407 | "funding": [ 1408 | { 1409 | "type": "github", 1410 | "url": "https://github.com/sponsors/fb55" 1411 | } 1412 | ] 1413 | }, 1414 | "node_modules/domhandler": { 1415 | "version": "5.0.3", 1416 | "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-5.0.3.tgz", 1417 | "integrity": "sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w==", 1418 | "dev": true, 1419 | "dependencies": { 1420 | "domelementtype": "^2.3.0" 1421 | }, 1422 | "engines": { 1423 | "node": ">= 4" 1424 | }, 1425 | "funding": { 1426 | "url": "https://github.com/fb55/domhandler?sponsor=1" 1427 | } 1428 | }, 1429 | "node_modules/domutils": { 1430 | "version": "3.0.1", 1431 | "resolved": "https://registry.npmjs.org/domutils/-/domutils-3.0.1.tgz", 1432 | "integrity": "sha512-z08c1l761iKhDFtfXO04C7kTdPBLi41zwOZl00WS8b5eiaebNpY00HKbztwBq+e3vyqWNwWF3mP9YLUeqIrF+Q==", 1433 | "dev": true, 1434 | "dependencies": { 1435 | "dom-serializer": "^2.0.0", 1436 | "domelementtype": "^2.3.0", 1437 | "domhandler": "^5.0.1" 1438 | }, 1439 | "funding": { 1440 | "url": "https://github.com/fb55/domutils?sponsor=1" 1441 | } 1442 | }, 1443 | "node_modules/emoji-regex": { 1444 | "version": "8.0.0", 1445 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1446 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1447 | "dev": true 1448 | }, 1449 | "node_modules/end-of-stream": { 1450 | "version": "1.4.4", 1451 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 1452 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 1453 | "dev": true, 1454 | "optional": true, 1455 | "dependencies": { 1456 | "once": "^1.4.0" 1457 | } 1458 | }, 1459 | "node_modules/entities": { 1460 | "version": "4.4.0", 1461 | "resolved": "https://registry.npmjs.org/entities/-/entities-4.4.0.tgz", 1462 | "integrity": "sha512-oYp7156SP8LkeGD0GF85ad1X9Ai79WtRsZ2gxJqtBuzH+98YUV6jkHEKlZkMbcrjJjIVJNIDP/3WL9wQkoPbWA==", 1463 | "dev": true, 1464 | "engines": { 1465 | "node": ">=0.12" 1466 | }, 1467 | "funding": { 1468 | "url": "https://github.com/fb55/entities?sponsor=1" 1469 | } 1470 | }, 1471 | "node_modules/esbuild": { 1472 | "version": "0.17.16", 1473 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.16.tgz", 1474 | "integrity": "sha512-aeSuUKr9aFVY9Dc8ETVELGgkj4urg5isYx8pLf4wlGgB0vTFjxJQdHnNH6Shmx4vYYrOTLCHtRI5i1XZ9l2Zcg==", 1475 | "dev": true, 1476 | "hasInstallScript": true, 1477 | "bin": { 1478 | "esbuild": "bin/esbuild" 1479 | }, 1480 | "engines": { 1481 | "node": ">=12" 1482 | }, 1483 | "optionalDependencies": { 1484 | "@esbuild/android-arm": "0.17.16", 1485 | "@esbuild/android-arm64": "0.17.16", 1486 | "@esbuild/android-x64": "0.17.16", 1487 | "@esbuild/darwin-arm64": "0.17.16", 1488 | "@esbuild/darwin-x64": "0.17.16", 1489 | "@esbuild/freebsd-arm64": "0.17.16", 1490 | "@esbuild/freebsd-x64": "0.17.16", 1491 | "@esbuild/linux-arm": "0.17.16", 1492 | "@esbuild/linux-arm64": "0.17.16", 1493 | "@esbuild/linux-ia32": "0.17.16", 1494 | "@esbuild/linux-loong64": "0.17.16", 1495 | "@esbuild/linux-mips64el": "0.17.16", 1496 | "@esbuild/linux-ppc64": "0.17.16", 1497 | "@esbuild/linux-riscv64": "0.17.16", 1498 | "@esbuild/linux-s390x": "0.17.16", 1499 | "@esbuild/linux-x64": "0.17.16", 1500 | "@esbuild/netbsd-x64": "0.17.16", 1501 | "@esbuild/openbsd-x64": "0.17.16", 1502 | "@esbuild/sunos-x64": "0.17.16", 1503 | "@esbuild/win32-arm64": "0.17.16", 1504 | "@esbuild/win32-ia32": "0.17.16", 1505 | "@esbuild/win32-x64": "0.17.16" 1506 | } 1507 | }, 1508 | "node_modules/escalade": { 1509 | "version": "3.1.1", 1510 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 1511 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 1512 | "dev": true, 1513 | "engines": { 1514 | "node": ">=6" 1515 | } 1516 | }, 1517 | "node_modules/escape-string-regexp": { 1518 | "version": "1.0.5", 1519 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1520 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 1521 | "dev": true, 1522 | "engines": { 1523 | "node": ">=0.8.0" 1524 | } 1525 | }, 1526 | "node_modules/eslint": { 1527 | "version": "8.38.0", 1528 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.38.0.tgz", 1529 | "integrity": "sha512-pIdsD2jwlUGf/U38Jv97t8lq6HpaU/G9NKbYmpWpZGw3LdTNhZLbJePqxOXGB5+JEKfOPU/XLxYxFh03nr1KTg==", 1530 | "dev": true, 1531 | "dependencies": { 1532 | "@eslint-community/eslint-utils": "^4.2.0", 1533 | "@eslint-community/regexpp": "^4.4.0", 1534 | "@eslint/eslintrc": "^2.0.2", 1535 | "@eslint/js": "8.38.0", 1536 | "@humanwhocodes/config-array": "^0.11.8", 1537 | "@humanwhocodes/module-importer": "^1.0.1", 1538 | "@nodelib/fs.walk": "^1.2.8", 1539 | "ajv": "^6.10.0", 1540 | "chalk": "^4.0.0", 1541 | "cross-spawn": "^7.0.2", 1542 | "debug": "^4.3.2", 1543 | "doctrine": "^3.0.0", 1544 | "escape-string-regexp": "^4.0.0", 1545 | "eslint-scope": "^7.1.1", 1546 | "eslint-visitor-keys": "^3.4.0", 1547 | "espree": "^9.5.1", 1548 | "esquery": "^1.4.2", 1549 | "esutils": "^2.0.2", 1550 | "fast-deep-equal": "^3.1.3", 1551 | "file-entry-cache": "^6.0.1", 1552 | "find-up": "^5.0.0", 1553 | "glob-parent": "^6.0.2", 1554 | "globals": "^13.19.0", 1555 | "grapheme-splitter": "^1.0.4", 1556 | "ignore": "^5.2.0", 1557 | "import-fresh": "^3.0.0", 1558 | "imurmurhash": "^0.1.4", 1559 | "is-glob": "^4.0.0", 1560 | "is-path-inside": "^3.0.3", 1561 | "js-sdsl": "^4.1.4", 1562 | "js-yaml": "^4.1.0", 1563 | "json-stable-stringify-without-jsonify": "^1.0.1", 1564 | "levn": "^0.4.1", 1565 | "lodash.merge": "^4.6.2", 1566 | "minimatch": "^3.1.2", 1567 | "natural-compare": "^1.4.0", 1568 | "optionator": "^0.9.1", 1569 | "strip-ansi": "^6.0.1", 1570 | "strip-json-comments": "^3.1.0", 1571 | "text-table": "^0.2.0" 1572 | }, 1573 | "bin": { 1574 | "eslint": "bin/eslint.js" 1575 | }, 1576 | "engines": { 1577 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1578 | }, 1579 | "funding": { 1580 | "url": "https://opencollective.com/eslint" 1581 | } 1582 | }, 1583 | "node_modules/eslint-scope": { 1584 | "version": "5.1.1", 1585 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 1586 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 1587 | "dev": true, 1588 | "dependencies": { 1589 | "esrecurse": "^4.3.0", 1590 | "estraverse": "^4.1.1" 1591 | }, 1592 | "engines": { 1593 | "node": ">=8.0.0" 1594 | } 1595 | }, 1596 | "node_modules/eslint-visitor-keys": { 1597 | "version": "3.4.0", 1598 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.0.tgz", 1599 | "integrity": "sha512-HPpKPUBQcAsZOsHAFwTtIKcYlCje62XB7SEAcxjtmW6TD1WVpkS6i6/hOVtTZIl4zGj/mBqpFVGvaDneik+VoQ==", 1600 | "dev": true, 1601 | "engines": { 1602 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1603 | }, 1604 | "funding": { 1605 | "url": "https://opencollective.com/eslint" 1606 | } 1607 | }, 1608 | "node_modules/eslint/node_modules/ansi-styles": { 1609 | "version": "4.3.0", 1610 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1611 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1612 | "dev": true, 1613 | "dependencies": { 1614 | "color-convert": "^2.0.1" 1615 | }, 1616 | "engines": { 1617 | "node": ">=8" 1618 | }, 1619 | "funding": { 1620 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1621 | } 1622 | }, 1623 | "node_modules/eslint/node_modules/chalk": { 1624 | "version": "4.1.2", 1625 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 1626 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 1627 | "dev": true, 1628 | "dependencies": { 1629 | "ansi-styles": "^4.1.0", 1630 | "supports-color": "^7.1.0" 1631 | }, 1632 | "engines": { 1633 | "node": ">=10" 1634 | }, 1635 | "funding": { 1636 | "url": "https://github.com/chalk/chalk?sponsor=1" 1637 | } 1638 | }, 1639 | "node_modules/eslint/node_modules/color-convert": { 1640 | "version": "2.0.1", 1641 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1642 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1643 | "dev": true, 1644 | "dependencies": { 1645 | "color-name": "~1.1.4" 1646 | }, 1647 | "engines": { 1648 | "node": ">=7.0.0" 1649 | } 1650 | }, 1651 | "node_modules/eslint/node_modules/color-name": { 1652 | "version": "1.1.4", 1653 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1654 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1655 | "dev": true 1656 | }, 1657 | "node_modules/eslint/node_modules/escape-string-regexp": { 1658 | "version": "4.0.0", 1659 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 1660 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 1661 | "dev": true, 1662 | "engines": { 1663 | "node": ">=10" 1664 | }, 1665 | "funding": { 1666 | "url": "https://github.com/sponsors/sindresorhus" 1667 | } 1668 | }, 1669 | "node_modules/eslint/node_modules/eslint-scope": { 1670 | "version": "7.1.1", 1671 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.1.tgz", 1672 | "integrity": "sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==", 1673 | "dev": true, 1674 | "dependencies": { 1675 | "esrecurse": "^4.3.0", 1676 | "estraverse": "^5.2.0" 1677 | }, 1678 | "engines": { 1679 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1680 | } 1681 | }, 1682 | "node_modules/eslint/node_modules/estraverse": { 1683 | "version": "5.3.0", 1684 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 1685 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 1686 | "dev": true, 1687 | "engines": { 1688 | "node": ">=4.0" 1689 | } 1690 | }, 1691 | "node_modules/eslint/node_modules/has-flag": { 1692 | "version": "4.0.0", 1693 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1694 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1695 | "dev": true, 1696 | "engines": { 1697 | "node": ">=8" 1698 | } 1699 | }, 1700 | "node_modules/eslint/node_modules/supports-color": { 1701 | "version": "7.2.0", 1702 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1703 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1704 | "dev": true, 1705 | "dependencies": { 1706 | "has-flag": "^4.0.0" 1707 | }, 1708 | "engines": { 1709 | "node": ">=8" 1710 | } 1711 | }, 1712 | "node_modules/espree": { 1713 | "version": "9.5.1", 1714 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.5.1.tgz", 1715 | "integrity": "sha512-5yxtHSZXRSW5pvv3hAlXM5+/Oswi1AUFqBmbibKb5s6bp3rGIDkyXU6xCoyuuLhijr4SFwPrXRoZjz0AZDN9tg==", 1716 | "dev": true, 1717 | "dependencies": { 1718 | "acorn": "^8.8.0", 1719 | "acorn-jsx": "^5.3.2", 1720 | "eslint-visitor-keys": "^3.4.0" 1721 | }, 1722 | "engines": { 1723 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1724 | }, 1725 | "funding": { 1726 | "url": "https://opencollective.com/eslint" 1727 | } 1728 | }, 1729 | "node_modules/esquery": { 1730 | "version": "1.5.0", 1731 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 1732 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 1733 | "dev": true, 1734 | "dependencies": { 1735 | "estraverse": "^5.1.0" 1736 | }, 1737 | "engines": { 1738 | "node": ">=0.10" 1739 | } 1740 | }, 1741 | "node_modules/esquery/node_modules/estraverse": { 1742 | "version": "5.3.0", 1743 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 1744 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 1745 | "dev": true, 1746 | "engines": { 1747 | "node": ">=4.0" 1748 | } 1749 | }, 1750 | "node_modules/esrecurse": { 1751 | "version": "4.3.0", 1752 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 1753 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 1754 | "dev": true, 1755 | "dependencies": { 1756 | "estraverse": "^5.2.0" 1757 | }, 1758 | "engines": { 1759 | "node": ">=4.0" 1760 | } 1761 | }, 1762 | "node_modules/esrecurse/node_modules/estraverse": { 1763 | "version": "5.3.0", 1764 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 1765 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 1766 | "dev": true, 1767 | "engines": { 1768 | "node": ">=4.0" 1769 | } 1770 | }, 1771 | "node_modules/estraverse": { 1772 | "version": "4.3.0", 1773 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 1774 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 1775 | "dev": true, 1776 | "engines": { 1777 | "node": ">=4.0" 1778 | } 1779 | }, 1780 | "node_modules/esutils": { 1781 | "version": "2.0.3", 1782 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1783 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1784 | "dev": true, 1785 | "engines": { 1786 | "node": ">=0.10.0" 1787 | } 1788 | }, 1789 | "node_modules/expand-template": { 1790 | "version": "2.0.3", 1791 | "resolved": "https://registry.npmjs.org/expand-template/-/expand-template-2.0.3.tgz", 1792 | "integrity": "sha512-XYfuKMvj4O35f/pOXLObndIRvyQ+/+6AhODh+OKWj9S9498pHHn/IMszH+gt0fBCRWMNfk1ZSp5x3AifmnI2vg==", 1793 | "dev": true, 1794 | "optional": true, 1795 | "engines": { 1796 | "node": ">=6" 1797 | } 1798 | }, 1799 | "node_modules/fast-deep-equal": { 1800 | "version": "3.1.3", 1801 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1802 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1803 | "dev": true 1804 | }, 1805 | "node_modules/fast-glob": { 1806 | "version": "3.2.12", 1807 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.12.tgz", 1808 | "integrity": "sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==", 1809 | "dev": true, 1810 | "dependencies": { 1811 | "@nodelib/fs.stat": "^2.0.2", 1812 | "@nodelib/fs.walk": "^1.2.3", 1813 | "glob-parent": "^5.1.2", 1814 | "merge2": "^1.3.0", 1815 | "micromatch": "^4.0.4" 1816 | }, 1817 | "engines": { 1818 | "node": ">=8.6.0" 1819 | } 1820 | }, 1821 | "node_modules/fast-glob/node_modules/glob-parent": { 1822 | "version": "5.1.2", 1823 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1824 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1825 | "dev": true, 1826 | "dependencies": { 1827 | "is-glob": "^4.0.1" 1828 | }, 1829 | "engines": { 1830 | "node": ">= 6" 1831 | } 1832 | }, 1833 | "node_modules/fast-json-stable-stringify": { 1834 | "version": "2.1.0", 1835 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1836 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1837 | "dev": true 1838 | }, 1839 | "node_modules/fast-levenshtein": { 1840 | "version": "2.0.6", 1841 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1842 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 1843 | "dev": true 1844 | }, 1845 | "node_modules/fastq": { 1846 | "version": "1.15.0", 1847 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz", 1848 | "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==", 1849 | "dev": true, 1850 | "dependencies": { 1851 | "reusify": "^1.0.4" 1852 | } 1853 | }, 1854 | "node_modules/fd-slicer": { 1855 | "version": "1.1.0", 1856 | "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.1.0.tgz", 1857 | "integrity": "sha512-cE1qsB/VwyQozZ+q1dGxR8LBYNZeofhEdUNGSMbQD3Gw2lAzX9Zb3uIU6Ebc/Fmyjo9AWWfnn0AUCHqtevs/8g==", 1858 | "dev": true, 1859 | "dependencies": { 1860 | "pend": "~1.2.0" 1861 | } 1862 | }, 1863 | "node_modules/file-entry-cache": { 1864 | "version": "6.0.1", 1865 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 1866 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 1867 | "dev": true, 1868 | "dependencies": { 1869 | "flat-cache": "^3.0.4" 1870 | }, 1871 | "engines": { 1872 | "node": "^10.12.0 || >=12.0.0" 1873 | } 1874 | }, 1875 | "node_modules/fill-range": { 1876 | "version": "7.0.1", 1877 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1878 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1879 | "dev": true, 1880 | "dependencies": { 1881 | "to-regex-range": "^5.0.1" 1882 | }, 1883 | "engines": { 1884 | "node": ">=8" 1885 | } 1886 | }, 1887 | "node_modules/find-up": { 1888 | "version": "5.0.0", 1889 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1890 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1891 | "dev": true, 1892 | "dependencies": { 1893 | "locate-path": "^6.0.0", 1894 | "path-exists": "^4.0.0" 1895 | }, 1896 | "engines": { 1897 | "node": ">=10" 1898 | }, 1899 | "funding": { 1900 | "url": "https://github.com/sponsors/sindresorhus" 1901 | } 1902 | }, 1903 | "node_modules/flat": { 1904 | "version": "5.0.2", 1905 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 1906 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 1907 | "dev": true, 1908 | "bin": { 1909 | "flat": "cli.js" 1910 | } 1911 | }, 1912 | "node_modules/flat-cache": { 1913 | "version": "3.0.4", 1914 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 1915 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 1916 | "dev": true, 1917 | "dependencies": { 1918 | "flatted": "^3.1.0", 1919 | "rimraf": "^3.0.2" 1920 | }, 1921 | "engines": { 1922 | "node": "^10.12.0 || >=12.0.0" 1923 | } 1924 | }, 1925 | "node_modules/flatted": { 1926 | "version": "3.2.7", 1927 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.7.tgz", 1928 | "integrity": "sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==", 1929 | "dev": true 1930 | }, 1931 | "node_modules/fs-constants": { 1932 | "version": "1.0.0", 1933 | "resolved": "https://registry.npmjs.org/fs-constants/-/fs-constants-1.0.0.tgz", 1934 | "integrity": "sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow==", 1935 | "dev": true, 1936 | "optional": true 1937 | }, 1938 | "node_modules/fs.realpath": { 1939 | "version": "1.0.0", 1940 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1941 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1942 | "dev": true 1943 | }, 1944 | "node_modules/fsevents": { 1945 | "version": "2.3.2", 1946 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1947 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1948 | "dev": true, 1949 | "hasInstallScript": true, 1950 | "optional": true, 1951 | "os": [ 1952 | "darwin" 1953 | ], 1954 | "engines": { 1955 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1956 | } 1957 | }, 1958 | "node_modules/function-bind": { 1959 | "version": "1.1.1", 1960 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1961 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1962 | "dev": true 1963 | }, 1964 | "node_modules/get-caller-file": { 1965 | "version": "2.0.5", 1966 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1967 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1968 | "dev": true, 1969 | "engines": { 1970 | "node": "6.* || 8.* || >= 10.*" 1971 | } 1972 | }, 1973 | "node_modules/get-intrinsic": { 1974 | "version": "1.2.0", 1975 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.0.tgz", 1976 | "integrity": "sha512-L049y6nFOuom5wGyRc3/gdTLO94dySVKRACj1RmJZBQXlbTMhtNIgkWkUHq+jYmZvKf14EW1EoJnnjbmoHij0Q==", 1977 | "dev": true, 1978 | "dependencies": { 1979 | "function-bind": "^1.1.1", 1980 | "has": "^1.0.3", 1981 | "has-symbols": "^1.0.3" 1982 | }, 1983 | "funding": { 1984 | "url": "https://github.com/sponsors/ljharb" 1985 | } 1986 | }, 1987 | "node_modules/github-from-package": { 1988 | "version": "0.0.0", 1989 | "resolved": "https://registry.npmjs.org/github-from-package/-/github-from-package-0.0.0.tgz", 1990 | "integrity": "sha512-SyHy3T1v2NUXn29OsWdxmK6RwHD+vkj3v8en8AOBZ1wBQ/hCAQ5bAQTD02kW4W9tUp/3Qh6J8r9EvntiyCmOOw==", 1991 | "dev": true, 1992 | "optional": true 1993 | }, 1994 | "node_modules/glob": { 1995 | "version": "8.0.3", 1996 | "resolved": "https://registry.npmjs.org/glob/-/glob-8.0.3.tgz", 1997 | "integrity": "sha512-ull455NHSHI/Y1FqGaaYFaLGkNMMJbavMrEGFXG/PGrg6y7sutWHUHrz6gy6WEBH6akM1M414dWKCNs+IhKdiQ==", 1998 | "dev": true, 1999 | "dependencies": { 2000 | "fs.realpath": "^1.0.0", 2001 | "inflight": "^1.0.4", 2002 | "inherits": "2", 2003 | "minimatch": "^5.0.1", 2004 | "once": "^1.3.0" 2005 | }, 2006 | "engines": { 2007 | "node": ">=12" 2008 | }, 2009 | "funding": { 2010 | "url": "https://github.com/sponsors/isaacs" 2011 | } 2012 | }, 2013 | "node_modules/glob-parent": { 2014 | "version": "6.0.2", 2015 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 2016 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 2017 | "dev": true, 2018 | "dependencies": { 2019 | "is-glob": "^4.0.3" 2020 | }, 2021 | "engines": { 2022 | "node": ">=10.13.0" 2023 | } 2024 | }, 2025 | "node_modules/glob/node_modules/brace-expansion": { 2026 | "version": "2.0.1", 2027 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 2028 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 2029 | "dev": true, 2030 | "dependencies": { 2031 | "balanced-match": "^1.0.0" 2032 | } 2033 | }, 2034 | "node_modules/glob/node_modules/minimatch": { 2035 | "version": "5.1.6", 2036 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", 2037 | "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", 2038 | "dev": true, 2039 | "dependencies": { 2040 | "brace-expansion": "^2.0.1" 2041 | }, 2042 | "engines": { 2043 | "node": ">=10" 2044 | } 2045 | }, 2046 | "node_modules/globals": { 2047 | "version": "13.20.0", 2048 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.20.0.tgz", 2049 | "integrity": "sha512-Qg5QtVkCy/kv3FUSlu4ukeZDVf9ee0iXLAUYX13gbR17bnejFTzr4iS9bY7kwCf1NztRNm1t91fjOiyx4CSwPQ==", 2050 | "dev": true, 2051 | "dependencies": { 2052 | "type-fest": "^0.20.2" 2053 | }, 2054 | "engines": { 2055 | "node": ">=8" 2056 | }, 2057 | "funding": { 2058 | "url": "https://github.com/sponsors/sindresorhus" 2059 | } 2060 | }, 2061 | "node_modules/globby": { 2062 | "version": "11.1.0", 2063 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 2064 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 2065 | "dev": true, 2066 | "dependencies": { 2067 | "array-union": "^2.1.0", 2068 | "dir-glob": "^3.0.1", 2069 | "fast-glob": "^3.2.9", 2070 | "ignore": "^5.2.0", 2071 | "merge2": "^1.4.1", 2072 | "slash": "^3.0.0" 2073 | }, 2074 | "engines": { 2075 | "node": ">=10" 2076 | }, 2077 | "funding": { 2078 | "url": "https://github.com/sponsors/sindresorhus" 2079 | } 2080 | }, 2081 | "node_modules/grapheme-splitter": { 2082 | "version": "1.0.4", 2083 | "resolved": "https://registry.npmjs.org/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz", 2084 | "integrity": "sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ==", 2085 | "dev": true 2086 | }, 2087 | "node_modules/has": { 2088 | "version": "1.0.3", 2089 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 2090 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 2091 | "dev": true, 2092 | "dependencies": { 2093 | "function-bind": "^1.1.1" 2094 | }, 2095 | "engines": { 2096 | "node": ">= 0.4.0" 2097 | } 2098 | }, 2099 | "node_modules/has-flag": { 2100 | "version": "3.0.0", 2101 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2102 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 2103 | "dev": true, 2104 | "engines": { 2105 | "node": ">=4" 2106 | } 2107 | }, 2108 | "node_modules/has-symbols": { 2109 | "version": "1.0.3", 2110 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 2111 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 2112 | "dev": true, 2113 | "engines": { 2114 | "node": ">= 0.4" 2115 | }, 2116 | "funding": { 2117 | "url": "https://github.com/sponsors/ljharb" 2118 | } 2119 | }, 2120 | "node_modules/he": { 2121 | "version": "1.2.0", 2122 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 2123 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 2124 | "dev": true, 2125 | "bin": { 2126 | "he": "bin/he" 2127 | } 2128 | }, 2129 | "node_modules/hosted-git-info": { 2130 | "version": "4.1.0", 2131 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-4.1.0.tgz", 2132 | "integrity": "sha512-kyCuEOWjJqZuDbRHzL8V93NzQhwIB71oFWSyzVo+KPZI+pnQPPxucdkrOZvkLRnrf5URsQM+IJ09Dw29cRALIA==", 2133 | "dev": true, 2134 | "dependencies": { 2135 | "lru-cache": "^6.0.0" 2136 | }, 2137 | "engines": { 2138 | "node": ">=10" 2139 | } 2140 | }, 2141 | "node_modules/htmlparser2": { 2142 | "version": "8.0.2", 2143 | "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-8.0.2.tgz", 2144 | "integrity": "sha512-GYdjWKDkbRLkZ5geuHs5NY1puJ+PXwP7+fHPRz06Eirsb9ugf6d8kkXav6ADhcODhFFPMIXyxkxSuMf3D6NCFA==", 2145 | "dev": true, 2146 | "funding": [ 2147 | "https://github.com/fb55/htmlparser2?sponsor=1", 2148 | { 2149 | "type": "github", 2150 | "url": "https://github.com/sponsors/fb55" 2151 | } 2152 | ], 2153 | "dependencies": { 2154 | "domelementtype": "^2.3.0", 2155 | "domhandler": "^5.0.3", 2156 | "domutils": "^3.0.1", 2157 | "entities": "^4.4.0" 2158 | } 2159 | }, 2160 | "node_modules/http-proxy-agent": { 2161 | "version": "4.0.1", 2162 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 2163 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 2164 | "dev": true, 2165 | "dependencies": { 2166 | "@tootallnate/once": "1", 2167 | "agent-base": "6", 2168 | "debug": "4" 2169 | }, 2170 | "engines": { 2171 | "node": ">= 6" 2172 | } 2173 | }, 2174 | "node_modules/https-proxy-agent": { 2175 | "version": "5.0.1", 2176 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", 2177 | "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", 2178 | "dev": true, 2179 | "dependencies": { 2180 | "agent-base": "6", 2181 | "debug": "4" 2182 | }, 2183 | "engines": { 2184 | "node": ">= 6" 2185 | } 2186 | }, 2187 | "node_modules/ieee754": { 2188 | "version": "1.2.1", 2189 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 2190 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", 2191 | "dev": true, 2192 | "funding": [ 2193 | { 2194 | "type": "github", 2195 | "url": "https://github.com/sponsors/feross" 2196 | }, 2197 | { 2198 | "type": "patreon", 2199 | "url": "https://www.patreon.com/feross" 2200 | }, 2201 | { 2202 | "type": "consulting", 2203 | "url": "https://feross.org/support" 2204 | } 2205 | ], 2206 | "optional": true 2207 | }, 2208 | "node_modules/ignore": { 2209 | "version": "5.2.4", 2210 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", 2211 | "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", 2212 | "dev": true, 2213 | "engines": { 2214 | "node": ">= 4" 2215 | } 2216 | }, 2217 | "node_modules/immediate": { 2218 | "version": "3.0.6", 2219 | "resolved": "https://registry.npmjs.org/immediate/-/immediate-3.0.6.tgz", 2220 | "integrity": "sha512-XXOFtyqDjNDAQxVfYxuF7g9Il/IbWmmlQg2MYKOH8ExIT1qg6xc4zyS3HaEEATgs1btfzxq15ciUiY7gjSXRGQ==", 2221 | "dev": true 2222 | }, 2223 | "node_modules/import-fresh": { 2224 | "version": "3.3.0", 2225 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2226 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2227 | "dev": true, 2228 | "dependencies": { 2229 | "parent-module": "^1.0.0", 2230 | "resolve-from": "^4.0.0" 2231 | }, 2232 | "engines": { 2233 | "node": ">=6" 2234 | }, 2235 | "funding": { 2236 | "url": "https://github.com/sponsors/sindresorhus" 2237 | } 2238 | }, 2239 | "node_modules/imurmurhash": { 2240 | "version": "0.1.4", 2241 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2242 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 2243 | "dev": true, 2244 | "engines": { 2245 | "node": ">=0.8.19" 2246 | } 2247 | }, 2248 | "node_modules/inflight": { 2249 | "version": "1.0.6", 2250 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2251 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 2252 | "dev": true, 2253 | "dependencies": { 2254 | "once": "^1.3.0", 2255 | "wrappy": "1" 2256 | } 2257 | }, 2258 | "node_modules/inherits": { 2259 | "version": "2.0.4", 2260 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2261 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2262 | "dev": true 2263 | }, 2264 | "node_modules/ini": { 2265 | "version": "1.3.8", 2266 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", 2267 | "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==", 2268 | "dev": true, 2269 | "optional": true 2270 | }, 2271 | "node_modules/is-binary-path": { 2272 | "version": "2.1.0", 2273 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 2274 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 2275 | "dev": true, 2276 | "dependencies": { 2277 | "binary-extensions": "^2.0.0" 2278 | }, 2279 | "engines": { 2280 | "node": ">=8" 2281 | } 2282 | }, 2283 | "node_modules/is-extglob": { 2284 | "version": "2.1.1", 2285 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2286 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2287 | "dev": true, 2288 | "engines": { 2289 | "node": ">=0.10.0" 2290 | } 2291 | }, 2292 | "node_modules/is-fullwidth-code-point": { 2293 | "version": "3.0.0", 2294 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2295 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2296 | "dev": true, 2297 | "engines": { 2298 | "node": ">=8" 2299 | } 2300 | }, 2301 | "node_modules/is-glob": { 2302 | "version": "4.0.3", 2303 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2304 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2305 | "dev": true, 2306 | "dependencies": { 2307 | "is-extglob": "^2.1.1" 2308 | }, 2309 | "engines": { 2310 | "node": ">=0.10.0" 2311 | } 2312 | }, 2313 | "node_modules/is-number": { 2314 | "version": "7.0.0", 2315 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2316 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2317 | "dev": true, 2318 | "engines": { 2319 | "node": ">=0.12.0" 2320 | } 2321 | }, 2322 | "node_modules/is-path-inside": { 2323 | "version": "3.0.3", 2324 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 2325 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 2326 | "dev": true, 2327 | "engines": { 2328 | "node": ">=8" 2329 | } 2330 | }, 2331 | "node_modules/is-plain-obj": { 2332 | "version": "2.1.0", 2333 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 2334 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 2335 | "dev": true, 2336 | "engines": { 2337 | "node": ">=8" 2338 | } 2339 | }, 2340 | "node_modules/is-unicode-supported": { 2341 | "version": "0.1.0", 2342 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 2343 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 2344 | "dev": true, 2345 | "engines": { 2346 | "node": ">=10" 2347 | }, 2348 | "funding": { 2349 | "url": "https://github.com/sponsors/sindresorhus" 2350 | } 2351 | }, 2352 | "node_modules/isarray": { 2353 | "version": "1.0.0", 2354 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 2355 | "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==", 2356 | "dev": true 2357 | }, 2358 | "node_modules/isexe": { 2359 | "version": "2.0.0", 2360 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2361 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2362 | "dev": true 2363 | }, 2364 | "node_modules/js-sdsl": { 2365 | "version": "4.4.0", 2366 | "resolved": "https://registry.npmjs.org/js-sdsl/-/js-sdsl-4.4.0.tgz", 2367 | "integrity": "sha512-FfVSdx6pJ41Oa+CF7RDaFmTnCaFhua+SNYQX74riGOpl96x+2jQCqEfQ2bnXu/5DPCqlRuiqyvTJM0Qjz26IVg==", 2368 | "dev": true, 2369 | "funding": { 2370 | "type": "opencollective", 2371 | "url": "https://opencollective.com/js-sdsl" 2372 | } 2373 | }, 2374 | "node_modules/js-yaml": { 2375 | "version": "4.1.0", 2376 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2377 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2378 | "dev": true, 2379 | "dependencies": { 2380 | "argparse": "^2.0.1" 2381 | }, 2382 | "bin": { 2383 | "js-yaml": "bin/js-yaml.js" 2384 | } 2385 | }, 2386 | "node_modules/json-schema-traverse": { 2387 | "version": "0.4.1", 2388 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2389 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2390 | "dev": true 2391 | }, 2392 | "node_modules/json-stable-stringify-without-jsonify": { 2393 | "version": "1.0.1", 2394 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2395 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 2396 | "dev": true 2397 | }, 2398 | "node_modules/jsonc-parser": { 2399 | "version": "3.2.0", 2400 | "resolved": "https://registry.npmjs.org/jsonc-parser/-/jsonc-parser-3.2.0.tgz", 2401 | "integrity": "sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w==", 2402 | "dev": true 2403 | }, 2404 | "node_modules/jszip": { 2405 | "version": "3.10.1", 2406 | "resolved": "https://registry.npmjs.org/jszip/-/jszip-3.10.1.tgz", 2407 | "integrity": "sha512-xXDvecyTpGLrqFrvkrUSoxxfJI5AH7U8zxxtVclpsUtMCq4JQ290LY8AW5c7Ggnr/Y/oK+bQMbqK2qmtk3pN4g==", 2408 | "dev": true, 2409 | "dependencies": { 2410 | "lie": "~3.3.0", 2411 | "pako": "~1.0.2", 2412 | "readable-stream": "~2.3.6", 2413 | "setimmediate": "^1.0.5" 2414 | } 2415 | }, 2416 | "node_modules/jszip/node_modules/readable-stream": { 2417 | "version": "2.3.8", 2418 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", 2419 | "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", 2420 | "dev": true, 2421 | "dependencies": { 2422 | "core-util-is": "~1.0.0", 2423 | "inherits": "~2.0.3", 2424 | "isarray": "~1.0.0", 2425 | "process-nextick-args": "~2.0.0", 2426 | "safe-buffer": "~5.1.1", 2427 | "string_decoder": "~1.1.1", 2428 | "util-deprecate": "~1.0.1" 2429 | } 2430 | }, 2431 | "node_modules/jszip/node_modules/safe-buffer": { 2432 | "version": "5.1.2", 2433 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2434 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 2435 | "dev": true 2436 | }, 2437 | "node_modules/jszip/node_modules/string_decoder": { 2438 | "version": "1.1.1", 2439 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2440 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2441 | "dev": true, 2442 | "dependencies": { 2443 | "safe-buffer": "~5.1.0" 2444 | } 2445 | }, 2446 | "node_modules/keytar": { 2447 | "version": "7.9.0", 2448 | "resolved": "https://registry.npmjs.org/keytar/-/keytar-7.9.0.tgz", 2449 | "integrity": "sha512-VPD8mtVtm5JNtA2AErl6Chp06JBfy7diFQ7TQQhdpWOl6MrCRB+eRbvAZUsbGQS9kiMq0coJsy0W0vHpDCkWsQ==", 2450 | "dev": true, 2451 | "hasInstallScript": true, 2452 | "optional": true, 2453 | "dependencies": { 2454 | "node-addon-api": "^4.3.0", 2455 | "prebuild-install": "^7.0.1" 2456 | } 2457 | }, 2458 | "node_modules/leven": { 2459 | "version": "3.1.0", 2460 | "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", 2461 | "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", 2462 | "dev": true, 2463 | "engines": { 2464 | "node": ">=6" 2465 | } 2466 | }, 2467 | "node_modules/levn": { 2468 | "version": "0.4.1", 2469 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2470 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2471 | "dev": true, 2472 | "dependencies": { 2473 | "prelude-ls": "^1.2.1", 2474 | "type-check": "~0.4.0" 2475 | }, 2476 | "engines": { 2477 | "node": ">= 0.8.0" 2478 | } 2479 | }, 2480 | "node_modules/lie": { 2481 | "version": "3.3.0", 2482 | "resolved": "https://registry.npmjs.org/lie/-/lie-3.3.0.tgz", 2483 | "integrity": "sha512-UaiMJzeWRlEujzAuw5LokY1L5ecNQYZKfmyZ9L7wDHb/p5etKaxXhohBcrw0EYby+G/NA52vRSN4N39dxHAIwQ==", 2484 | "dev": true, 2485 | "dependencies": { 2486 | "immediate": "~3.0.5" 2487 | } 2488 | }, 2489 | "node_modules/linkify-it": { 2490 | "version": "3.0.3", 2491 | "resolved": "https://registry.npmjs.org/linkify-it/-/linkify-it-3.0.3.tgz", 2492 | "integrity": "sha512-ynTsyrFSdE5oZ/O9GEf00kPngmOfVwazR5GKDq6EYfhlpFug3J2zybX56a2PRRpc9P+FuSoGNAwjlbDs9jJBPQ==", 2493 | "dev": true, 2494 | "dependencies": { 2495 | "uc.micro": "^1.0.1" 2496 | } 2497 | }, 2498 | "node_modules/locate-path": { 2499 | "version": "6.0.0", 2500 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2501 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2502 | "dev": true, 2503 | "dependencies": { 2504 | "p-locate": "^5.0.0" 2505 | }, 2506 | "engines": { 2507 | "node": ">=10" 2508 | }, 2509 | "funding": { 2510 | "url": "https://github.com/sponsors/sindresorhus" 2511 | } 2512 | }, 2513 | "node_modules/lodash.merge": { 2514 | "version": "4.6.2", 2515 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2516 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2517 | "dev": true 2518 | }, 2519 | "node_modules/log-symbols": { 2520 | "version": "4.1.0", 2521 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 2522 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 2523 | "dev": true, 2524 | "dependencies": { 2525 | "chalk": "^4.1.0", 2526 | "is-unicode-supported": "^0.1.0" 2527 | }, 2528 | "engines": { 2529 | "node": ">=10" 2530 | }, 2531 | "funding": { 2532 | "url": "https://github.com/sponsors/sindresorhus" 2533 | } 2534 | }, 2535 | "node_modules/log-symbols/node_modules/ansi-styles": { 2536 | "version": "4.3.0", 2537 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2538 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2539 | "dev": true, 2540 | "dependencies": { 2541 | "color-convert": "^2.0.1" 2542 | }, 2543 | "engines": { 2544 | "node": ">=8" 2545 | }, 2546 | "funding": { 2547 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 2548 | } 2549 | }, 2550 | "node_modules/log-symbols/node_modules/chalk": { 2551 | "version": "4.1.2", 2552 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2553 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2554 | "dev": true, 2555 | "dependencies": { 2556 | "ansi-styles": "^4.1.0", 2557 | "supports-color": "^7.1.0" 2558 | }, 2559 | "engines": { 2560 | "node": ">=10" 2561 | }, 2562 | "funding": { 2563 | "url": "https://github.com/chalk/chalk?sponsor=1" 2564 | } 2565 | }, 2566 | "node_modules/log-symbols/node_modules/color-convert": { 2567 | "version": "2.0.1", 2568 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2569 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2570 | "dev": true, 2571 | "dependencies": { 2572 | "color-name": "~1.1.4" 2573 | }, 2574 | "engines": { 2575 | "node": ">=7.0.0" 2576 | } 2577 | }, 2578 | "node_modules/log-symbols/node_modules/color-name": { 2579 | "version": "1.1.4", 2580 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2581 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2582 | "dev": true 2583 | }, 2584 | "node_modules/log-symbols/node_modules/has-flag": { 2585 | "version": "4.0.0", 2586 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2587 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2588 | "dev": true, 2589 | "engines": { 2590 | "node": ">=8" 2591 | } 2592 | }, 2593 | "node_modules/log-symbols/node_modules/supports-color": { 2594 | "version": "7.2.0", 2595 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2596 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2597 | "dev": true, 2598 | "dependencies": { 2599 | "has-flag": "^4.0.0" 2600 | }, 2601 | "engines": { 2602 | "node": ">=8" 2603 | } 2604 | }, 2605 | "node_modules/lru-cache": { 2606 | "version": "6.0.0", 2607 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2608 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2609 | "dev": true, 2610 | "dependencies": { 2611 | "yallist": "^4.0.0" 2612 | }, 2613 | "engines": { 2614 | "node": ">=10" 2615 | } 2616 | }, 2617 | "node_modules/markdown-it": { 2618 | "version": "12.3.2", 2619 | "resolved": "https://registry.npmjs.org/markdown-it/-/markdown-it-12.3.2.tgz", 2620 | "integrity": "sha512-TchMembfxfNVpHkbtriWltGWc+m3xszaRD0CZup7GFFhzIgQqxIfn3eGj1yZpfuflzPvfkt611B2Q/Bsk1YnGg==", 2621 | "dev": true, 2622 | "dependencies": { 2623 | "argparse": "^2.0.1", 2624 | "entities": "~2.1.0", 2625 | "linkify-it": "^3.0.1", 2626 | "mdurl": "^1.0.1", 2627 | "uc.micro": "^1.0.5" 2628 | }, 2629 | "bin": { 2630 | "markdown-it": "bin/markdown-it.js" 2631 | } 2632 | }, 2633 | "node_modules/markdown-it/node_modules/entities": { 2634 | "version": "2.1.0", 2635 | "resolved": "https://registry.npmjs.org/entities/-/entities-2.1.0.tgz", 2636 | "integrity": "sha512-hCx1oky9PFrJ611mf0ifBLBRW8lUUVRlFolb5gWRfIELabBlbp9xZvrqZLZAs+NxFnbfQoeGd8wDkygjg7U85w==", 2637 | "dev": true, 2638 | "funding": { 2639 | "url": "https://github.com/fb55/entities?sponsor=1" 2640 | } 2641 | }, 2642 | "node_modules/mdurl": { 2643 | "version": "1.0.1", 2644 | "resolved": "https://registry.npmjs.org/mdurl/-/mdurl-1.0.1.tgz", 2645 | "integrity": "sha512-/sKlQJCBYVY9Ers9hqzKou4H6V5UWc/M59TH2dvkt+84itfnq7uFOMLpOiOS4ujvHP4etln18fmIxA5R5fll0g==", 2646 | "dev": true 2647 | }, 2648 | "node_modules/merge2": { 2649 | "version": "1.4.1", 2650 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 2651 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 2652 | "dev": true, 2653 | "engines": { 2654 | "node": ">= 8" 2655 | } 2656 | }, 2657 | "node_modules/micromatch": { 2658 | "version": "4.0.5", 2659 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 2660 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 2661 | "dev": true, 2662 | "dependencies": { 2663 | "braces": "^3.0.2", 2664 | "picomatch": "^2.3.1" 2665 | }, 2666 | "engines": { 2667 | "node": ">=8.6" 2668 | } 2669 | }, 2670 | "node_modules/mime": { 2671 | "version": "1.6.0", 2672 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 2673 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 2674 | "dev": true, 2675 | "bin": { 2676 | "mime": "cli.js" 2677 | }, 2678 | "engines": { 2679 | "node": ">=4" 2680 | } 2681 | }, 2682 | "node_modules/mimic-response": { 2683 | "version": "3.1.0", 2684 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-3.1.0.tgz", 2685 | "integrity": "sha512-z0yWI+4FDrrweS8Zmt4Ej5HdJmky15+L2e6Wgn3+iK5fWzb6T3fhNFq2+MeTRb064c6Wr4N/wv0DzQTjNzHNGQ==", 2686 | "dev": true, 2687 | "optional": true, 2688 | "engines": { 2689 | "node": ">=10" 2690 | }, 2691 | "funding": { 2692 | "url": "https://github.com/sponsors/sindresorhus" 2693 | } 2694 | }, 2695 | "node_modules/minimatch": { 2696 | "version": "3.1.2", 2697 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2698 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2699 | "dev": true, 2700 | "dependencies": { 2701 | "brace-expansion": "^1.1.7" 2702 | }, 2703 | "engines": { 2704 | "node": "*" 2705 | } 2706 | }, 2707 | "node_modules/minimist": { 2708 | "version": "1.2.8", 2709 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 2710 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 2711 | "dev": true, 2712 | "optional": true, 2713 | "funding": { 2714 | "url": "https://github.com/sponsors/ljharb" 2715 | } 2716 | }, 2717 | "node_modules/mkdirp-classic": { 2718 | "version": "0.5.3", 2719 | "resolved": "https://registry.npmjs.org/mkdirp-classic/-/mkdirp-classic-0.5.3.tgz", 2720 | "integrity": "sha512-gKLcREMhtuZRwRAfqP3RFW+TK4JqApVBtOIftVgjuABpAtpxhPGaDcfvbhNvD0B8iD1oUr/txX35NjcaY6Ns/A==", 2721 | "dev": true, 2722 | "optional": true 2723 | }, 2724 | "node_modules/mocha": { 2725 | "version": "10.2.0", 2726 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.2.0.tgz", 2727 | "integrity": "sha512-IDY7fl/BecMwFHzoqF2sg/SHHANeBoMMXFlS9r0OXKDssYE1M5O43wUY/9BVPeIvfH2zmEbBfseqN9gBQZzXkg==", 2728 | "dev": true, 2729 | "dependencies": { 2730 | "ansi-colors": "4.1.1", 2731 | "browser-stdout": "1.3.1", 2732 | "chokidar": "3.5.3", 2733 | "debug": "4.3.4", 2734 | "diff": "5.0.0", 2735 | "escape-string-regexp": "4.0.0", 2736 | "find-up": "5.0.0", 2737 | "glob": "7.2.0", 2738 | "he": "1.2.0", 2739 | "js-yaml": "4.1.0", 2740 | "log-symbols": "4.1.0", 2741 | "minimatch": "5.0.1", 2742 | "ms": "2.1.3", 2743 | "nanoid": "3.3.3", 2744 | "serialize-javascript": "6.0.0", 2745 | "strip-json-comments": "3.1.1", 2746 | "supports-color": "8.1.1", 2747 | "workerpool": "6.2.1", 2748 | "yargs": "16.2.0", 2749 | "yargs-parser": "20.2.4", 2750 | "yargs-unparser": "2.0.0" 2751 | }, 2752 | "bin": { 2753 | "_mocha": "bin/_mocha", 2754 | "mocha": "bin/mocha.js" 2755 | }, 2756 | "engines": { 2757 | "node": ">= 14.0.0" 2758 | }, 2759 | "funding": { 2760 | "type": "opencollective", 2761 | "url": "https://opencollective.com/mochajs" 2762 | } 2763 | }, 2764 | "node_modules/mocha/node_modules/escape-string-regexp": { 2765 | "version": "4.0.0", 2766 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2767 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2768 | "dev": true, 2769 | "engines": { 2770 | "node": ">=10" 2771 | }, 2772 | "funding": { 2773 | "url": "https://github.com/sponsors/sindresorhus" 2774 | } 2775 | }, 2776 | "node_modules/mocha/node_modules/glob": { 2777 | "version": "7.2.0", 2778 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 2779 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 2780 | "dev": true, 2781 | "dependencies": { 2782 | "fs.realpath": "^1.0.0", 2783 | "inflight": "^1.0.4", 2784 | "inherits": "2", 2785 | "minimatch": "^3.0.4", 2786 | "once": "^1.3.0", 2787 | "path-is-absolute": "^1.0.0" 2788 | }, 2789 | "engines": { 2790 | "node": "*" 2791 | }, 2792 | "funding": { 2793 | "url": "https://github.com/sponsors/isaacs" 2794 | } 2795 | }, 2796 | "node_modules/mocha/node_modules/glob/node_modules/minimatch": { 2797 | "version": "3.1.2", 2798 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2799 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2800 | "dev": true, 2801 | "dependencies": { 2802 | "brace-expansion": "^1.1.7" 2803 | }, 2804 | "engines": { 2805 | "node": "*" 2806 | } 2807 | }, 2808 | "node_modules/mocha/node_modules/has-flag": { 2809 | "version": "4.0.0", 2810 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2811 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2812 | "dev": true, 2813 | "engines": { 2814 | "node": ">=8" 2815 | } 2816 | }, 2817 | "node_modules/mocha/node_modules/minimatch": { 2818 | "version": "5.0.1", 2819 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.0.1.tgz", 2820 | "integrity": "sha512-nLDxIFRyhDblz3qMuq+SoRZED4+miJ/G+tdDrjkkkRnjAsBexeGpgjLEQ0blJy7rHhR2b93rhQY4SvyWu9v03g==", 2821 | "dev": true, 2822 | "dependencies": { 2823 | "brace-expansion": "^2.0.1" 2824 | }, 2825 | "engines": { 2826 | "node": ">=10" 2827 | } 2828 | }, 2829 | "node_modules/mocha/node_modules/minimatch/node_modules/brace-expansion": { 2830 | "version": "2.0.1", 2831 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 2832 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 2833 | "dev": true, 2834 | "dependencies": { 2835 | "balanced-match": "^1.0.0" 2836 | } 2837 | }, 2838 | "node_modules/mocha/node_modules/ms": { 2839 | "version": "2.1.3", 2840 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2841 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 2842 | "dev": true 2843 | }, 2844 | "node_modules/mocha/node_modules/supports-color": { 2845 | "version": "8.1.1", 2846 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 2847 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 2848 | "dev": true, 2849 | "dependencies": { 2850 | "has-flag": "^4.0.0" 2851 | }, 2852 | "engines": { 2853 | "node": ">=10" 2854 | }, 2855 | "funding": { 2856 | "url": "https://github.com/chalk/supports-color?sponsor=1" 2857 | } 2858 | }, 2859 | "node_modules/ms": { 2860 | "version": "2.1.2", 2861 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2862 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2863 | "dev": true 2864 | }, 2865 | "node_modules/mute-stream": { 2866 | "version": "0.0.8", 2867 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 2868 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", 2869 | "dev": true 2870 | }, 2871 | "node_modules/nanoid": { 2872 | "version": "3.3.3", 2873 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.3.tgz", 2874 | "integrity": "sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w==", 2875 | "dev": true, 2876 | "bin": { 2877 | "nanoid": "bin/nanoid.cjs" 2878 | }, 2879 | "engines": { 2880 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 2881 | } 2882 | }, 2883 | "node_modules/napi-build-utils": { 2884 | "version": "1.0.2", 2885 | "resolved": "https://registry.npmjs.org/napi-build-utils/-/napi-build-utils-1.0.2.tgz", 2886 | "integrity": "sha512-ONmRUqK7zj7DWX0D9ADe03wbwOBZxNAfF20PlGfCWQcD3+/MakShIHrMqx9YwPTfxDdF1zLeL+RGZiR9kGMLdg==", 2887 | "dev": true, 2888 | "optional": true 2889 | }, 2890 | "node_modules/natural-compare": { 2891 | "version": "1.4.0", 2892 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2893 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 2894 | "dev": true 2895 | }, 2896 | "node_modules/natural-compare-lite": { 2897 | "version": "1.4.0", 2898 | "resolved": "https://registry.npmjs.org/natural-compare-lite/-/natural-compare-lite-1.4.0.tgz", 2899 | "integrity": "sha512-Tj+HTDSJJKaZnfiuw+iaF9skdPpTo2GtEly5JHnWV/hfv2Qj/9RKsGISQtLh2ox3l5EAGw487hnBee0sIJ6v2g==", 2900 | "dev": true 2901 | }, 2902 | "node_modules/node-abi": { 2903 | "version": "3.35.0", 2904 | "resolved": "https://registry.npmjs.org/node-abi/-/node-abi-3.35.0.tgz", 2905 | "integrity": "sha512-jAlSOFR1Bls963NmFwxeQkNTzqjUF0NThm8Le7eRIRGzFUVJuMOFZDLv5Y30W/Oaw+KEebEJLAigwO9gQHoEmw==", 2906 | "dev": true, 2907 | "optional": true, 2908 | "dependencies": { 2909 | "semver": "^7.3.5" 2910 | }, 2911 | "engines": { 2912 | "node": ">=10" 2913 | } 2914 | }, 2915 | "node_modules/node-addon-api": { 2916 | "version": "4.3.0", 2917 | "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-4.3.0.tgz", 2918 | "integrity": "sha512-73sE9+3UaLYYFmDsFZnqCInzPyh3MqIwZO9cw58yIqAZhONrrabrYyYe3TuIqtIiOuTXVhsGau8hcrhhwSsDIQ==", 2919 | "dev": true, 2920 | "optional": true 2921 | }, 2922 | "node_modules/normalize-path": { 2923 | "version": "3.0.0", 2924 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2925 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2926 | "dev": true, 2927 | "engines": { 2928 | "node": ">=0.10.0" 2929 | } 2930 | }, 2931 | "node_modules/nth-check": { 2932 | "version": "2.1.1", 2933 | "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-2.1.1.tgz", 2934 | "integrity": "sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==", 2935 | "dev": true, 2936 | "dependencies": { 2937 | "boolbase": "^1.0.0" 2938 | }, 2939 | "funding": { 2940 | "url": "https://github.com/fb55/nth-check?sponsor=1" 2941 | } 2942 | }, 2943 | "node_modules/object-inspect": { 2944 | "version": "1.12.3", 2945 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.3.tgz", 2946 | "integrity": "sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==", 2947 | "dev": true, 2948 | "funding": { 2949 | "url": "https://github.com/sponsors/ljharb" 2950 | } 2951 | }, 2952 | "node_modules/once": { 2953 | "version": "1.4.0", 2954 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2955 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2956 | "dev": true, 2957 | "dependencies": { 2958 | "wrappy": "1" 2959 | } 2960 | }, 2961 | "node_modules/optionator": { 2962 | "version": "0.9.1", 2963 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 2964 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 2965 | "dev": true, 2966 | "dependencies": { 2967 | "deep-is": "^0.1.3", 2968 | "fast-levenshtein": "^2.0.6", 2969 | "levn": "^0.4.1", 2970 | "prelude-ls": "^1.2.1", 2971 | "type-check": "^0.4.0", 2972 | "word-wrap": "^1.2.3" 2973 | }, 2974 | "engines": { 2975 | "node": ">= 0.8.0" 2976 | } 2977 | }, 2978 | "node_modules/p-limit": { 2979 | "version": "3.1.0", 2980 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2981 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2982 | "dev": true, 2983 | "dependencies": { 2984 | "yocto-queue": "^0.1.0" 2985 | }, 2986 | "engines": { 2987 | "node": ">=10" 2988 | }, 2989 | "funding": { 2990 | "url": "https://github.com/sponsors/sindresorhus" 2991 | } 2992 | }, 2993 | "node_modules/p-locate": { 2994 | "version": "5.0.0", 2995 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2996 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2997 | "dev": true, 2998 | "dependencies": { 2999 | "p-limit": "^3.0.2" 3000 | }, 3001 | "engines": { 3002 | "node": ">=10" 3003 | }, 3004 | "funding": { 3005 | "url": "https://github.com/sponsors/sindresorhus" 3006 | } 3007 | }, 3008 | "node_modules/pako": { 3009 | "version": "1.0.11", 3010 | "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.11.tgz", 3011 | "integrity": "sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw==", 3012 | "dev": true 3013 | }, 3014 | "node_modules/parent-module": { 3015 | "version": "1.0.1", 3016 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 3017 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 3018 | "dev": true, 3019 | "dependencies": { 3020 | "callsites": "^3.0.0" 3021 | }, 3022 | "engines": { 3023 | "node": ">=6" 3024 | } 3025 | }, 3026 | "node_modules/parse-semver": { 3027 | "version": "1.1.1", 3028 | "resolved": "https://registry.npmjs.org/parse-semver/-/parse-semver-1.1.1.tgz", 3029 | "integrity": "sha512-Eg1OuNntBMH0ojvEKSrvDSnwLmvVuUOSdylH/pSCPNMIspLlweJyIWXCE+k/5hm3cj/EBUYwmWkjhBALNP4LXQ==", 3030 | "dev": true, 3031 | "dependencies": { 3032 | "semver": "^5.1.0" 3033 | } 3034 | }, 3035 | "node_modules/parse-semver/node_modules/semver": { 3036 | "version": "5.7.1", 3037 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 3038 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 3039 | "dev": true, 3040 | "bin": { 3041 | "semver": "bin/semver" 3042 | } 3043 | }, 3044 | "node_modules/parse5": { 3045 | "version": "7.1.2", 3046 | "resolved": "https://registry.npmjs.org/parse5/-/parse5-7.1.2.tgz", 3047 | "integrity": "sha512-Czj1WaSVpaoj0wbhMzLmWD69anp2WH7FXMB9n1Sy8/ZFF9jolSQVMu1Ij5WIyGmcBmhk7EOndpO4mIpihVqAXw==", 3048 | "dev": true, 3049 | "dependencies": { 3050 | "entities": "^4.4.0" 3051 | }, 3052 | "funding": { 3053 | "url": "https://github.com/inikulin/parse5?sponsor=1" 3054 | } 3055 | }, 3056 | "node_modules/parse5-htmlparser2-tree-adapter": { 3057 | "version": "7.0.0", 3058 | "resolved": "https://registry.npmjs.org/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-7.0.0.tgz", 3059 | "integrity": "sha512-B77tOZrqqfUfnVcOrUvfdLbz4pu4RopLD/4vmu3HUPswwTA8OH0EMW9BlWR2B0RCoiZRAHEUu7IxeP1Pd1UU+g==", 3060 | "dev": true, 3061 | "dependencies": { 3062 | "domhandler": "^5.0.2", 3063 | "parse5": "^7.0.0" 3064 | }, 3065 | "funding": { 3066 | "url": "https://github.com/inikulin/parse5?sponsor=1" 3067 | } 3068 | }, 3069 | "node_modules/path-exists": { 3070 | "version": "4.0.0", 3071 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 3072 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 3073 | "dev": true, 3074 | "engines": { 3075 | "node": ">=8" 3076 | } 3077 | }, 3078 | "node_modules/path-is-absolute": { 3079 | "version": "1.0.1", 3080 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3081 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 3082 | "dev": true, 3083 | "engines": { 3084 | "node": ">=0.10.0" 3085 | } 3086 | }, 3087 | "node_modules/path-key": { 3088 | "version": "3.1.1", 3089 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3090 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3091 | "dev": true, 3092 | "engines": { 3093 | "node": ">=8" 3094 | } 3095 | }, 3096 | "node_modules/path-type": { 3097 | "version": "4.0.0", 3098 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 3099 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 3100 | "dev": true, 3101 | "engines": { 3102 | "node": ">=8" 3103 | } 3104 | }, 3105 | "node_modules/pend": { 3106 | "version": "1.2.0", 3107 | "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", 3108 | "integrity": "sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg==", 3109 | "dev": true 3110 | }, 3111 | "node_modules/picomatch": { 3112 | "version": "2.3.1", 3113 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 3114 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 3115 | "dev": true, 3116 | "engines": { 3117 | "node": ">=8.6" 3118 | }, 3119 | "funding": { 3120 | "url": "https://github.com/sponsors/jonschlinkert" 3121 | } 3122 | }, 3123 | "node_modules/prebuild-install": { 3124 | "version": "7.1.1", 3125 | "resolved": "https://registry.npmjs.org/prebuild-install/-/prebuild-install-7.1.1.tgz", 3126 | "integrity": "sha512-jAXscXWMcCK8GgCoHOfIr0ODh5ai8mj63L2nWrjuAgXE6tDyYGnx4/8o/rCgU+B4JSyZBKbeZqzhtwtC3ovxjw==", 3127 | "dev": true, 3128 | "optional": true, 3129 | "dependencies": { 3130 | "detect-libc": "^2.0.0", 3131 | "expand-template": "^2.0.3", 3132 | "github-from-package": "0.0.0", 3133 | "minimist": "^1.2.3", 3134 | "mkdirp-classic": "^0.5.3", 3135 | "napi-build-utils": "^1.0.1", 3136 | "node-abi": "^3.3.0", 3137 | "pump": "^3.0.0", 3138 | "rc": "^1.2.7", 3139 | "simple-get": "^4.0.0", 3140 | "tar-fs": "^2.0.0", 3141 | "tunnel-agent": "^0.6.0" 3142 | }, 3143 | "bin": { 3144 | "prebuild-install": "bin.js" 3145 | }, 3146 | "engines": { 3147 | "node": ">=10" 3148 | } 3149 | }, 3150 | "node_modules/prelude-ls": { 3151 | "version": "1.2.1", 3152 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 3153 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 3154 | "dev": true, 3155 | "engines": { 3156 | "node": ">= 0.8.0" 3157 | } 3158 | }, 3159 | "node_modules/process-nextick-args": { 3160 | "version": "2.0.1", 3161 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 3162 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 3163 | "dev": true 3164 | }, 3165 | "node_modules/pump": { 3166 | "version": "3.0.0", 3167 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 3168 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 3169 | "dev": true, 3170 | "optional": true, 3171 | "dependencies": { 3172 | "end-of-stream": "^1.1.0", 3173 | "once": "^1.3.1" 3174 | } 3175 | }, 3176 | "node_modules/punycode": { 3177 | "version": "2.3.0", 3178 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", 3179 | "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==", 3180 | "dev": true, 3181 | "engines": { 3182 | "node": ">=6" 3183 | } 3184 | }, 3185 | "node_modules/qs": { 3186 | "version": "6.11.1", 3187 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.1.tgz", 3188 | "integrity": "sha512-0wsrzgTz/kAVIeuxSjnpGC56rzYtr6JT/2BwEvMaPhFIoYa1aGO8LbzuU1R0uUYQkLpWBTOj0l/CLAJB64J6nQ==", 3189 | "dev": true, 3190 | "dependencies": { 3191 | "side-channel": "^1.0.4" 3192 | }, 3193 | "engines": { 3194 | "node": ">=0.6" 3195 | }, 3196 | "funding": { 3197 | "url": "https://github.com/sponsors/ljharb" 3198 | } 3199 | }, 3200 | "node_modules/queue-microtask": { 3201 | "version": "1.2.3", 3202 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 3203 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 3204 | "dev": true, 3205 | "funding": [ 3206 | { 3207 | "type": "github", 3208 | "url": "https://github.com/sponsors/feross" 3209 | }, 3210 | { 3211 | "type": "patreon", 3212 | "url": "https://www.patreon.com/feross" 3213 | }, 3214 | { 3215 | "type": "consulting", 3216 | "url": "https://feross.org/support" 3217 | } 3218 | ] 3219 | }, 3220 | "node_modules/randombytes": { 3221 | "version": "2.1.0", 3222 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 3223 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 3224 | "dev": true, 3225 | "dependencies": { 3226 | "safe-buffer": "^5.1.0" 3227 | } 3228 | }, 3229 | "node_modules/rc": { 3230 | "version": "1.2.8", 3231 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 3232 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 3233 | "dev": true, 3234 | "optional": true, 3235 | "dependencies": { 3236 | "deep-extend": "^0.6.0", 3237 | "ini": "~1.3.0", 3238 | "minimist": "^1.2.0", 3239 | "strip-json-comments": "~2.0.1" 3240 | }, 3241 | "bin": { 3242 | "rc": "cli.js" 3243 | } 3244 | }, 3245 | "node_modules/rc/node_modules/strip-json-comments": { 3246 | "version": "2.0.1", 3247 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 3248 | "integrity": "sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ==", 3249 | "dev": true, 3250 | "optional": true, 3251 | "engines": { 3252 | "node": ">=0.10.0" 3253 | } 3254 | }, 3255 | "node_modules/read": { 3256 | "version": "1.0.7", 3257 | "resolved": "https://registry.npmjs.org/read/-/read-1.0.7.tgz", 3258 | "integrity": "sha512-rSOKNYUmaxy0om1BNjMN4ezNT6VKK+2xF4GBhc81mkH7L60i6dp8qPYrkndNLT3QPphoII3maL9PVC9XmhHwVQ==", 3259 | "dev": true, 3260 | "dependencies": { 3261 | "mute-stream": "~0.0.4" 3262 | }, 3263 | "engines": { 3264 | "node": ">=0.8" 3265 | } 3266 | }, 3267 | "node_modules/readable-stream": { 3268 | "version": "3.6.2", 3269 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", 3270 | "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", 3271 | "dev": true, 3272 | "optional": true, 3273 | "dependencies": { 3274 | "inherits": "^2.0.3", 3275 | "string_decoder": "^1.1.1", 3276 | "util-deprecate": "^1.0.1" 3277 | }, 3278 | "engines": { 3279 | "node": ">= 6" 3280 | } 3281 | }, 3282 | "node_modules/readdirp": { 3283 | "version": "3.6.0", 3284 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 3285 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 3286 | "dev": true, 3287 | "dependencies": { 3288 | "picomatch": "^2.2.1" 3289 | }, 3290 | "engines": { 3291 | "node": ">=8.10.0" 3292 | } 3293 | }, 3294 | "node_modules/require-directory": { 3295 | "version": "2.1.1", 3296 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 3297 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 3298 | "dev": true, 3299 | "engines": { 3300 | "node": ">=0.10.0" 3301 | } 3302 | }, 3303 | "node_modules/resolve-from": { 3304 | "version": "4.0.0", 3305 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 3306 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 3307 | "dev": true, 3308 | "engines": { 3309 | "node": ">=4" 3310 | } 3311 | }, 3312 | "node_modules/reusify": { 3313 | "version": "1.0.4", 3314 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 3315 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 3316 | "dev": true, 3317 | "engines": { 3318 | "iojs": ">=1.0.0", 3319 | "node": ">=0.10.0" 3320 | } 3321 | }, 3322 | "node_modules/rimraf": { 3323 | "version": "3.0.2", 3324 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 3325 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 3326 | "dev": true, 3327 | "dependencies": { 3328 | "glob": "^7.1.3" 3329 | }, 3330 | "bin": { 3331 | "rimraf": "bin.js" 3332 | }, 3333 | "funding": { 3334 | "url": "https://github.com/sponsors/isaacs" 3335 | } 3336 | }, 3337 | "node_modules/rimraf/node_modules/glob": { 3338 | "version": "7.2.3", 3339 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 3340 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 3341 | "dev": true, 3342 | "dependencies": { 3343 | "fs.realpath": "^1.0.0", 3344 | "inflight": "^1.0.4", 3345 | "inherits": "2", 3346 | "minimatch": "^3.1.1", 3347 | "once": "^1.3.0", 3348 | "path-is-absolute": "^1.0.0" 3349 | }, 3350 | "engines": { 3351 | "node": "*" 3352 | }, 3353 | "funding": { 3354 | "url": "https://github.com/sponsors/isaacs" 3355 | } 3356 | }, 3357 | "node_modules/run-parallel": { 3358 | "version": "1.2.0", 3359 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 3360 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 3361 | "dev": true, 3362 | "funding": [ 3363 | { 3364 | "type": "github", 3365 | "url": "https://github.com/sponsors/feross" 3366 | }, 3367 | { 3368 | "type": "patreon", 3369 | "url": "https://www.patreon.com/feross" 3370 | }, 3371 | { 3372 | "type": "consulting", 3373 | "url": "https://feross.org/support" 3374 | } 3375 | ], 3376 | "dependencies": { 3377 | "queue-microtask": "^1.2.2" 3378 | } 3379 | }, 3380 | "node_modules/safe-buffer": { 3381 | "version": "5.2.1", 3382 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 3383 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 3384 | "dev": true, 3385 | "funding": [ 3386 | { 3387 | "type": "github", 3388 | "url": "https://github.com/sponsors/feross" 3389 | }, 3390 | { 3391 | "type": "patreon", 3392 | "url": "https://www.patreon.com/feross" 3393 | }, 3394 | { 3395 | "type": "consulting", 3396 | "url": "https://feross.org/support" 3397 | } 3398 | ] 3399 | }, 3400 | "node_modules/sax": { 3401 | "version": "1.2.4", 3402 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", 3403 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==", 3404 | "dev": true 3405 | }, 3406 | "node_modules/semver": { 3407 | "version": "7.4.0", 3408 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.4.0.tgz", 3409 | "integrity": "sha512-RgOxM8Mw+7Zus0+zcLEUn8+JfoLpj/huFTItQy2hsM4khuC1HYRDp0cU482Ewn/Fcy6bCjufD8vAj7voC66KQw==", 3410 | "dev": true, 3411 | "dependencies": { 3412 | "lru-cache": "^6.0.0" 3413 | }, 3414 | "bin": { 3415 | "semver": "bin/semver.js" 3416 | }, 3417 | "engines": { 3418 | "node": ">=10" 3419 | } 3420 | }, 3421 | "node_modules/serialize-javascript": { 3422 | "version": "6.0.0", 3423 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 3424 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 3425 | "dev": true, 3426 | "dependencies": { 3427 | "randombytes": "^2.1.0" 3428 | } 3429 | }, 3430 | "node_modules/setimmediate": { 3431 | "version": "1.0.5", 3432 | "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", 3433 | "integrity": "sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA==", 3434 | "dev": true 3435 | }, 3436 | "node_modules/shebang-command": { 3437 | "version": "2.0.0", 3438 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3439 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3440 | "dev": true, 3441 | "dependencies": { 3442 | "shebang-regex": "^3.0.0" 3443 | }, 3444 | "engines": { 3445 | "node": ">=8" 3446 | } 3447 | }, 3448 | "node_modules/shebang-regex": { 3449 | "version": "3.0.0", 3450 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3451 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3452 | "dev": true, 3453 | "engines": { 3454 | "node": ">=8" 3455 | } 3456 | }, 3457 | "node_modules/side-channel": { 3458 | "version": "1.0.4", 3459 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 3460 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 3461 | "dev": true, 3462 | "dependencies": { 3463 | "call-bind": "^1.0.0", 3464 | "get-intrinsic": "^1.0.2", 3465 | "object-inspect": "^1.9.0" 3466 | }, 3467 | "funding": { 3468 | "url": "https://github.com/sponsors/ljharb" 3469 | } 3470 | }, 3471 | "node_modules/simple-concat": { 3472 | "version": "1.0.1", 3473 | "resolved": "https://registry.npmjs.org/simple-concat/-/simple-concat-1.0.1.tgz", 3474 | "integrity": "sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q==", 3475 | "dev": true, 3476 | "funding": [ 3477 | { 3478 | "type": "github", 3479 | "url": "https://github.com/sponsors/feross" 3480 | }, 3481 | { 3482 | "type": "patreon", 3483 | "url": "https://www.patreon.com/feross" 3484 | }, 3485 | { 3486 | "type": "consulting", 3487 | "url": "https://feross.org/support" 3488 | } 3489 | ], 3490 | "optional": true 3491 | }, 3492 | "node_modules/simple-get": { 3493 | "version": "4.0.1", 3494 | "resolved": "https://registry.npmjs.org/simple-get/-/simple-get-4.0.1.tgz", 3495 | "integrity": "sha512-brv7p5WgH0jmQJr1ZDDfKDOSeWWg+OVypG99A/5vYGPqJ6pxiaHLy8nxtFjBA7oMa01ebA9gfh1uMCFqOuXxvA==", 3496 | "dev": true, 3497 | "funding": [ 3498 | { 3499 | "type": "github", 3500 | "url": "https://github.com/sponsors/feross" 3501 | }, 3502 | { 3503 | "type": "patreon", 3504 | "url": "https://www.patreon.com/feross" 3505 | }, 3506 | { 3507 | "type": "consulting", 3508 | "url": "https://feross.org/support" 3509 | } 3510 | ], 3511 | "optional": true, 3512 | "dependencies": { 3513 | "decompress-response": "^6.0.0", 3514 | "once": "^1.3.1", 3515 | "simple-concat": "^1.0.0" 3516 | } 3517 | }, 3518 | "node_modules/slash": { 3519 | "version": "3.0.0", 3520 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 3521 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 3522 | "dev": true, 3523 | "engines": { 3524 | "node": ">=8" 3525 | } 3526 | }, 3527 | "node_modules/string_decoder": { 3528 | "version": "1.3.0", 3529 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", 3530 | "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", 3531 | "dev": true, 3532 | "optional": true, 3533 | "dependencies": { 3534 | "safe-buffer": "~5.2.0" 3535 | } 3536 | }, 3537 | "node_modules/string-width": { 3538 | "version": "4.2.3", 3539 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3540 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3541 | "dev": true, 3542 | "dependencies": { 3543 | "emoji-regex": "^8.0.0", 3544 | "is-fullwidth-code-point": "^3.0.0", 3545 | "strip-ansi": "^6.0.1" 3546 | }, 3547 | "engines": { 3548 | "node": ">=8" 3549 | } 3550 | }, 3551 | "node_modules/strip-ansi": { 3552 | "version": "6.0.1", 3553 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3554 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3555 | "dev": true, 3556 | "dependencies": { 3557 | "ansi-regex": "^5.0.1" 3558 | }, 3559 | "engines": { 3560 | "node": ">=8" 3561 | } 3562 | }, 3563 | "node_modules/strip-json-comments": { 3564 | "version": "3.1.1", 3565 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3566 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3567 | "dev": true, 3568 | "engines": { 3569 | "node": ">=8" 3570 | }, 3571 | "funding": { 3572 | "url": "https://github.com/sponsors/sindresorhus" 3573 | } 3574 | }, 3575 | "node_modules/supports-color": { 3576 | "version": "5.5.0", 3577 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 3578 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 3579 | "dev": true, 3580 | "dependencies": { 3581 | "has-flag": "^3.0.0" 3582 | }, 3583 | "engines": { 3584 | "node": ">=4" 3585 | } 3586 | }, 3587 | "node_modules/tar-fs": { 3588 | "version": "2.1.1", 3589 | "resolved": "https://registry.npmjs.org/tar-fs/-/tar-fs-2.1.1.tgz", 3590 | "integrity": "sha512-V0r2Y9scmbDRLCNex/+hYzvp/zyYjvFbHPNgVTKfQvVrb6guiE/fxP+XblDNR011utopbkex2nM4dHNV6GDsng==", 3591 | "dev": true, 3592 | "optional": true, 3593 | "dependencies": { 3594 | "chownr": "^1.1.1", 3595 | "mkdirp-classic": "^0.5.2", 3596 | "pump": "^3.0.0", 3597 | "tar-stream": "^2.1.4" 3598 | } 3599 | }, 3600 | "node_modules/tar-stream": { 3601 | "version": "2.2.0", 3602 | "resolved": "https://registry.npmjs.org/tar-stream/-/tar-stream-2.2.0.tgz", 3603 | "integrity": "sha512-ujeqbceABgwMZxEJnk2HDY2DlnUZ+9oEcb1KzTVfYHio0UE6dG71n60d8D2I4qNvleWrrXpmjpt7vZeF1LnMZQ==", 3604 | "dev": true, 3605 | "optional": true, 3606 | "dependencies": { 3607 | "bl": "^4.0.3", 3608 | "end-of-stream": "^1.4.1", 3609 | "fs-constants": "^1.0.0", 3610 | "inherits": "^2.0.3", 3611 | "readable-stream": "^3.1.1" 3612 | }, 3613 | "engines": { 3614 | "node": ">=6" 3615 | } 3616 | }, 3617 | "node_modules/text-table": { 3618 | "version": "0.2.0", 3619 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3620 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 3621 | "dev": true 3622 | }, 3623 | "node_modules/tmp": { 3624 | "version": "0.2.1", 3625 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.2.1.tgz", 3626 | "integrity": "sha512-76SUhtfqR2Ijn+xllcI5P1oyannHNHByD80W1q447gU3mp9G9PSpGdWmjUOHRDPiHYacIk66W7ubDTuPF3BEtQ==", 3627 | "dev": true, 3628 | "dependencies": { 3629 | "rimraf": "^3.0.0" 3630 | }, 3631 | "engines": { 3632 | "node": ">=8.17.0" 3633 | } 3634 | }, 3635 | "node_modules/to-regex-range": { 3636 | "version": "5.0.1", 3637 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3638 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3639 | "dev": true, 3640 | "dependencies": { 3641 | "is-number": "^7.0.0" 3642 | }, 3643 | "engines": { 3644 | "node": ">=8.0" 3645 | } 3646 | }, 3647 | "node_modules/tslib": { 3648 | "version": "1.14.1", 3649 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 3650 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 3651 | "dev": true 3652 | }, 3653 | "node_modules/tsutils": { 3654 | "version": "3.21.0", 3655 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", 3656 | "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", 3657 | "dev": true, 3658 | "dependencies": { 3659 | "tslib": "^1.8.1" 3660 | }, 3661 | "engines": { 3662 | "node": ">= 6" 3663 | }, 3664 | "peerDependencies": { 3665 | "typescript": ">=2.8.0 || >= 3.2.0-dev || >= 3.3.0-dev || >= 3.4.0-dev || >= 3.5.0-dev || >= 3.6.0-dev || >= 3.6.0-beta || >= 3.7.0-dev || >= 3.7.0-beta" 3666 | } 3667 | }, 3668 | "node_modules/tunnel": { 3669 | "version": "0.0.6", 3670 | "resolved": "https://registry.npmjs.org/tunnel/-/tunnel-0.0.6.tgz", 3671 | "integrity": "sha512-1h/Lnq9yajKY2PEbBadPXj3VxsDDu844OnaAo52UVmIzIvwwtBPIuNvkjuzBlTWpfJyUbG3ez0KSBibQkj4ojg==", 3672 | "dev": true, 3673 | "engines": { 3674 | "node": ">=0.6.11 <=0.7.0 || >=0.7.3" 3675 | } 3676 | }, 3677 | "node_modules/tunnel-agent": { 3678 | "version": "0.6.0", 3679 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 3680 | "integrity": "sha512-McnNiV1l8RYeY8tBgEpuodCC1mLUdbSN+CYBL7kJsJNInOP8UjDDEwdk6Mw60vdLLrr5NHKZhMAOSrR2NZuQ+w==", 3681 | "dev": true, 3682 | "optional": true, 3683 | "dependencies": { 3684 | "safe-buffer": "^5.0.1" 3685 | }, 3686 | "engines": { 3687 | "node": "*" 3688 | } 3689 | }, 3690 | "node_modules/type-check": { 3691 | "version": "0.4.0", 3692 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3693 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3694 | "dev": true, 3695 | "dependencies": { 3696 | "prelude-ls": "^1.2.1" 3697 | }, 3698 | "engines": { 3699 | "node": ">= 0.8.0" 3700 | } 3701 | }, 3702 | "node_modules/type-fest": { 3703 | "version": "0.20.2", 3704 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 3705 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 3706 | "dev": true, 3707 | "engines": { 3708 | "node": ">=10" 3709 | }, 3710 | "funding": { 3711 | "url": "https://github.com/sponsors/sindresorhus" 3712 | } 3713 | }, 3714 | "node_modules/typed-rest-client": { 3715 | "version": "1.8.9", 3716 | "resolved": "https://registry.npmjs.org/typed-rest-client/-/typed-rest-client-1.8.9.tgz", 3717 | "integrity": "sha512-uSmjE38B80wjL85UFX3sTYEUlvZ1JgCRhsWj/fJ4rZ0FqDUFoIuodtiVeE+cUqiVTOKPdKrp/sdftD15MDek6g==", 3718 | "dev": true, 3719 | "dependencies": { 3720 | "qs": "^6.9.1", 3721 | "tunnel": "0.0.6", 3722 | "underscore": "^1.12.1" 3723 | } 3724 | }, 3725 | "node_modules/typescript": { 3726 | "version": "5.0.4", 3727 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.0.4.tgz", 3728 | "integrity": "sha512-cW9T5W9xY37cc+jfEnaUvX91foxtHkza3Nw3wkoF4sSlKn0MONdkdEndig/qPBWXNkmplh3NzayQzCiHM4/hqw==", 3729 | "dev": true, 3730 | "bin": { 3731 | "tsc": "bin/tsc", 3732 | "tsserver": "bin/tsserver" 3733 | }, 3734 | "engines": { 3735 | "node": ">=12.20" 3736 | } 3737 | }, 3738 | "node_modules/uc.micro": { 3739 | "version": "1.0.6", 3740 | "resolved": "https://registry.npmjs.org/uc.micro/-/uc.micro-1.0.6.tgz", 3741 | "integrity": "sha512-8Y75pvTYkLJW2hWQHXxoqRgV7qb9B+9vFEtidML+7koHUFapnVJAZ6cKs+Qjz5Aw3aZWHMC6u0wJE3At+nSGwA==", 3742 | "dev": true 3743 | }, 3744 | "node_modules/underscore": { 3745 | "version": "1.13.6", 3746 | "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.13.6.tgz", 3747 | "integrity": "sha512-+A5Sja4HP1M08MaXya7p5LvjuM7K6q/2EaC0+iovj/wOcMsTzMvDFbasi/oSapiwOlt252IqsKqPjCl7huKS0A==", 3748 | "dev": true 3749 | }, 3750 | "node_modules/uri-js": { 3751 | "version": "4.4.1", 3752 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 3753 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 3754 | "dev": true, 3755 | "dependencies": { 3756 | "punycode": "^2.1.0" 3757 | } 3758 | }, 3759 | "node_modules/url-join": { 3760 | "version": "4.0.1", 3761 | "resolved": "https://registry.npmjs.org/url-join/-/url-join-4.0.1.tgz", 3762 | "integrity": "sha512-jk1+QP6ZJqyOiuEI9AEWQfju/nB2Pw466kbA0LEZljHwKeMgd9WrAEgEGxjPDD2+TNbbb37rTyhEfrCXfuKXnA==", 3763 | "dev": true 3764 | }, 3765 | "node_modules/util-deprecate": { 3766 | "version": "1.0.2", 3767 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3768 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", 3769 | "dev": true 3770 | }, 3771 | "node_modules/which": { 3772 | "version": "2.0.2", 3773 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3774 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3775 | "dev": true, 3776 | "dependencies": { 3777 | "isexe": "^2.0.0" 3778 | }, 3779 | "bin": { 3780 | "node-which": "bin/node-which" 3781 | }, 3782 | "engines": { 3783 | "node": ">= 8" 3784 | } 3785 | }, 3786 | "node_modules/word-wrap": { 3787 | "version": "1.2.3", 3788 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 3789 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 3790 | "dev": true, 3791 | "engines": { 3792 | "node": ">=0.10.0" 3793 | } 3794 | }, 3795 | "node_modules/workerpool": { 3796 | "version": "6.2.1", 3797 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.1.tgz", 3798 | "integrity": "sha512-ILEIE97kDZvF9Wb9f6h5aXK4swSlKGUcOEGiIYb2OOu/IrDU9iwj0fD//SsA6E5ibwJxpEvhullJY4Sl4GcpAw==", 3799 | "dev": true 3800 | }, 3801 | "node_modules/wrap-ansi": { 3802 | "version": "7.0.0", 3803 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3804 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3805 | "dev": true, 3806 | "dependencies": { 3807 | "ansi-styles": "^4.0.0", 3808 | "string-width": "^4.1.0", 3809 | "strip-ansi": "^6.0.0" 3810 | }, 3811 | "engines": { 3812 | "node": ">=10" 3813 | }, 3814 | "funding": { 3815 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 3816 | } 3817 | }, 3818 | "node_modules/wrap-ansi/node_modules/ansi-styles": { 3819 | "version": "4.3.0", 3820 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 3821 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 3822 | "dev": true, 3823 | "dependencies": { 3824 | "color-convert": "^2.0.1" 3825 | }, 3826 | "engines": { 3827 | "node": ">=8" 3828 | }, 3829 | "funding": { 3830 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 3831 | } 3832 | }, 3833 | "node_modules/wrap-ansi/node_modules/color-convert": { 3834 | "version": "2.0.1", 3835 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 3836 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 3837 | "dev": true, 3838 | "dependencies": { 3839 | "color-name": "~1.1.4" 3840 | }, 3841 | "engines": { 3842 | "node": ">=7.0.0" 3843 | } 3844 | }, 3845 | "node_modules/wrap-ansi/node_modules/color-name": { 3846 | "version": "1.1.4", 3847 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 3848 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 3849 | "dev": true 3850 | }, 3851 | "node_modules/wrappy": { 3852 | "version": "1.0.2", 3853 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3854 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3855 | "dev": true 3856 | }, 3857 | "node_modules/xml2js": { 3858 | "version": "0.5.0", 3859 | "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.5.0.tgz", 3860 | "integrity": "sha512-drPFnkQJik/O+uPKpqSgr22mpuFHqKdbS835iAQrUC73L2F5WkboIRd63ai/2Yg6I1jzifPFKH2NTK+cfglkIA==", 3861 | "dev": true, 3862 | "dependencies": { 3863 | "sax": ">=0.6.0", 3864 | "xmlbuilder": "~11.0.0" 3865 | }, 3866 | "engines": { 3867 | "node": ">=4.0.0" 3868 | } 3869 | }, 3870 | "node_modules/xmlbuilder": { 3871 | "version": "11.0.1", 3872 | "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-11.0.1.tgz", 3873 | "integrity": "sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA==", 3874 | "dev": true, 3875 | "engines": { 3876 | "node": ">=4.0" 3877 | } 3878 | }, 3879 | "node_modules/y18n": { 3880 | "version": "5.0.8", 3881 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3882 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3883 | "dev": true, 3884 | "engines": { 3885 | "node": ">=10" 3886 | } 3887 | }, 3888 | "node_modules/yallist": { 3889 | "version": "4.0.0", 3890 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3891 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3892 | "dev": true 3893 | }, 3894 | "node_modules/yargs": { 3895 | "version": "16.2.0", 3896 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 3897 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 3898 | "dev": true, 3899 | "dependencies": { 3900 | "cliui": "^7.0.2", 3901 | "escalade": "^3.1.1", 3902 | "get-caller-file": "^2.0.5", 3903 | "require-directory": "^2.1.1", 3904 | "string-width": "^4.2.0", 3905 | "y18n": "^5.0.5", 3906 | "yargs-parser": "^20.2.2" 3907 | }, 3908 | "engines": { 3909 | "node": ">=10" 3910 | } 3911 | }, 3912 | "node_modules/yargs-parser": { 3913 | "version": "20.2.4", 3914 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 3915 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 3916 | "dev": true, 3917 | "engines": { 3918 | "node": ">=10" 3919 | } 3920 | }, 3921 | "node_modules/yargs-unparser": { 3922 | "version": "2.0.0", 3923 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 3924 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 3925 | "dev": true, 3926 | "dependencies": { 3927 | "camelcase": "^6.0.0", 3928 | "decamelize": "^4.0.0", 3929 | "flat": "^5.0.2", 3930 | "is-plain-obj": "^2.1.0" 3931 | }, 3932 | "engines": { 3933 | "node": ">=10" 3934 | } 3935 | }, 3936 | "node_modules/yauzl": { 3937 | "version": "2.10.0", 3938 | "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.10.0.tgz", 3939 | "integrity": "sha512-p4a9I6X6nu6IhoGmBqAcbJy1mlC4j27vEPZX9F4L4/vZT3Lyq1VkFHw/V/PUcB9Buo+DG3iHkT0x3Qya58zc3g==", 3940 | "dev": true, 3941 | "dependencies": { 3942 | "buffer-crc32": "~0.2.3", 3943 | "fd-slicer": "~1.1.0" 3944 | } 3945 | }, 3946 | "node_modules/yazl": { 3947 | "version": "2.5.1", 3948 | "resolved": "https://registry.npmjs.org/yazl/-/yazl-2.5.1.tgz", 3949 | "integrity": "sha512-phENi2PLiHnHb6QBVot+dJnaAZ0xosj7p3fWl+znIjBDlnMI2PsZCJZ306BPTFOaHf5qdDEI8x5qFrSOBN5vrw==", 3950 | "dev": true, 3951 | "dependencies": { 3952 | "buffer-crc32": "~0.2.3" 3953 | } 3954 | }, 3955 | "node_modules/yocto-queue": { 3956 | "version": "0.1.0", 3957 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3958 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3959 | "dev": true, 3960 | "engines": { 3961 | "node": ">=10" 3962 | }, 3963 | "funding": { 3964 | "url": "https://github.com/sponsors/sindresorhus" 3965 | } 3966 | } 3967 | } 3968 | } 3969 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "abcjs-vscode", 3 | "displayName": "abcjs vscode", 4 | "description": "ABC music notation editor, using abcjs library", 5 | "version": "2.8.1", 6 | "publisher": "alensiljak", 7 | "author": { 8 | "name": "Alen Šiljak" 9 | }, 10 | "license": "GPL-3.0-or-later", 11 | "icon": "res/icon128.png", 12 | "repository": { 13 | "type": "git", 14 | "url": "https://github.com/abcjs-music/abcjs-vscode" 15 | }, 16 | "engines": { 17 | "vscode": "^1.75.0" 18 | }, 19 | "categories": [ 20 | "Other" 21 | ], 22 | "main": "./out/extension.js", 23 | "contributes": { 24 | "commands": [ 25 | { 26 | "command": "abcjs-vscode.showPreview", 27 | "title": "abcjs-vscode: Show Preview" 28 | }, 29 | { 30 | "command": "abcjs-vscode.exportHtml", 31 | "title": "abcjs-vscode: Export Sheet to HTML" 32 | }, 33 | { 34 | "command": "abcjs-vscode.exportSvg", 35 | "title": "abcjs-vscode: Export Sheet as SVG" 36 | }, 37 | { 38 | "command": "abcjs-vscode.printPreview", 39 | "title": "abcjs-vscode: Print Preview" 40 | } 41 | ], 42 | "languages": [ 43 | { 44 | "id": "abc", 45 | "aliases": [ 46 | "ABC" 47 | ], 48 | "extensions": [ 49 | ".abc" 50 | ] 51 | } 52 | ], 53 | "grammars": [ 54 | { 55 | "language": "abc", 56 | "scopeName": "source.abc", 57 | "path": "./abc.tmGrammar.json" 58 | } 59 | ], 60 | "snippets": [ 61 | { 62 | "language": "abc", 63 | "path": "./snippets.json" 64 | } 65 | ], 66 | "configuration": [ 67 | { 68 | "title": "Page Formatting", 69 | "properties": { 70 | "abcjs-vscode.pageFormatting.responsive": { 71 | "type": "string", 72 | "default": "resize", 73 | "enum": [ 74 | "", 75 | "resize" 76 | ], 77 | "scope": "resource", 78 | "markdownDescription": "Use all the available width for the score. [Documentation](https://paulrosen.github.io/abcjs/visual/render-abc-options.html#responsive)" 79 | }, 80 | "abcjs-vscode.pageFormatting.print": { 81 | "type": "boolean", 82 | "default": false, 83 | "scope": "resource", 84 | "description": "Apply print formatting" 85 | }, 86 | "abcjs-vscode.pageFormatting.oneSvgPerLine": { 87 | "type": "boolean", 88 | "default": false, 89 | "scope": "resource", 90 | "markdownDescription": "Render each stave system as a separate SVG. Helps with page breaks. [Documentation](https://paulrosen.github.io/abcjs/visual/render-abc-options.html#onesvgperline)" 91 | } 92 | } 93 | }, 94 | { 95 | "title": "Sheet", 96 | "properties": { 97 | "abcjs-vscode.sheet.jazzchords": { 98 | "type": "boolean", 99 | "default": true, 100 | "scope": "resource", 101 | "markdownDescription": "Jazz style chord symbols formatting. [Documentation](https://paulrosen.github.io/abcjs/visual/render-abc-options.html#jazzchords)" 102 | }, 103 | "abcjs-vscode.sheet.showDebug": { 104 | "type": "boolean", 105 | "default": false, 106 | "scope": "resource", 107 | "description": "Debug options for abcjs." 108 | }, 109 | "abcjs-vscode.sheet.tablature": { 110 | "type": "string", 111 | "default": "", 112 | "enum": [ 113 | "", 114 | "Violin", 115 | "Guitar" 116 | ], 117 | "markdownDescription": "Display a tablature-style staff. [Documentation](https://paulrosen.github.io/abcjs/visual/render-abc-options.html#tablatures)" 118 | } 119 | } 120 | }, 121 | { 122 | "title": "Transposition", 123 | "properties": { 124 | "abcjs-vscode.transposition.visualTranspose": { 125 | "type": "integer", 126 | "default": 0, 127 | "minimum": -12, 128 | "maximum": 12, 129 | "description": "Tune transposition (in half-steps)" 130 | }, 131 | "abcjs-vscode.transposition.showTransposedSource": { 132 | "type": "boolean", 133 | "default": false, 134 | "description": "Show transposed ABC source code" 135 | } 136 | } 137 | } 138 | ] 139 | }, 140 | "scripts": { 141 | "deprecated: vscode:prepublish": "npm run compile", 142 | "compile": "tsc -p ./", 143 | "watch": "tsc -watch -p ./", 144 | "pretest": "npm run compile && npm run lint", 145 | "lint": "eslint src --ext ts", 146 | "test": "node ./out/test/runTest.js", 147 | "vscode:prepublish": "npm run esbuild-base -- --minify", 148 | "esbuild-base": "npx esbuild ./src/extension.ts --bundle --outfile=out/main.js --external:vscode --format=cjs --platform=node", 149 | "esbuild": "npm run esbuild-base -- --sourcemap", 150 | "esbuild-watch": "npm run esbuild-base -- --sourcemap --watch", 151 | "test-compile": "tsc -p ./", 152 | "build": "npm run esbuild", 153 | "deploy": "npx vsce publish" 154 | }, 155 | "devDependencies": { 156 | "@types/glob": "8.1.0", 157 | "@types/mocha": "10.0.1", 158 | "@types/node": "16.0.0", 159 | "@types/vscode": "1.75.0", 160 | "@typescript-eslint/eslint-plugin": "5.58.0", 161 | "@typescript-eslint/parser": "5.58.0", 162 | "@vscode/test-electron": "2.3.0", 163 | "@vscode/vsce": "2.19.0", 164 | "esbuild": "0.17.16", 165 | "eslint": "8.38.0", 166 | "glob": "8.0.3", 167 | "mocha": "10.2.0", 168 | "typescript": "5.0.4" 169 | }, 170 | "dependencies": {} 171 | } 172 | -------------------------------------------------------------------------------- /publish.cmd: -------------------------------------------------------------------------------- 1 | :: Publishes the extension to VS Marketplace 2 | 3 | :: vsce package 4 | vsce publish 5 | -------------------------------------------------------------------------------- /res/Screenshot-1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/abcjs-music/abcjs-vscode/fea0595356a4de9fa6f6eddbb64867158c83515e/res/Screenshot-1.png -------------------------------------------------------------------------------- /res/export.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | {{body}} 10 | 11 | 12 | -------------------------------------------------------------------------------- /res/icon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/abcjs-music/abcjs-vscode/fea0595356a4de9fa6f6eddbb64867158c83515e/res/icon.png -------------------------------------------------------------------------------- /res/icon128.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/abcjs-music/abcjs-vscode/fea0595356a4de9fa6f6eddbb64867158c83515e/res/icon128.png -------------------------------------------------------------------------------- /res/print.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 20 | 21 | 22 | 23 | 27 | 28 | 29 |
30 | 31 | 32 | 33 | 51 | 52 | 53 | -------------------------------------------------------------------------------- /res/screenshot.printPreview.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/abcjs-music/abcjs-vscode/fea0595356a4de9fa6f6eddbb64867158c83515e/res/screenshot.printPreview.png -------------------------------------------------------------------------------- /res/viewer.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | ABC Preview 8 | 62 | 63 | 64 | 65 |
66 | 69 |
70 | 71 |
72 |
73 | 74 | 75 | 210 | 211 | 212 | -------------------------------------------------------------------------------- /snippets.json: -------------------------------------------------------------------------------- 1 | { 2 | "Abcjs": { 3 | "prefix": "abc-headers", 4 | "body": [ 5 | "X:1", 6 | "T:Title", 7 | "C:Composer", 8 | "O:Origin", 9 | "N:Notes", 10 | "L:1/4", 11 | "M:4/4", 12 | "Q:1/4=100", 13 | "P:AABB", 14 | "R:Reel", 15 | "K:C", 16 | "z4" 17 | ], 18 | "description": "Header Fields for ABC File." 19 | } 20 | } 21 | -------------------------------------------------------------------------------- /src/extension.ts: -------------------------------------------------------------------------------- 1 | /* 2 | Extension code 3 | */ 4 | import { WebviewPanel } from 'vscode'; 5 | 6 | import * as vscode from 'vscode'; 7 | import path = require('path'); 8 | // The module 'vscode' contains the VS Code extensibility API 9 | import * as os from 'os'; 10 | import { pathToFileURL } from 'url'; 11 | 12 | let panel: WebviewPanel; 13 | let outputChannel: vscode.OutputChannel; 14 | let svgHandler: Function; // the function that receives the SVG 15 | let _context: vscode.ExtensionContext; 16 | 17 | /** 18 | * @param {vscode.ExtensionContext} context 19 | */ 20 | function activate(context: vscode.ExtensionContext) { 21 | outputChannel = vscode.window.createOutputChannel('abcjs-vscode'); 22 | outputChannel.appendLine('starting abcjs extension...'); 23 | //outputChannel.show(); 24 | 25 | _context = context; 26 | 27 | // Commands 28 | registerCommands(context); 29 | 30 | // Behaviour 31 | registerEvents(context); 32 | } 33 | 34 | function registerCommands(context: vscode.ExtensionContext) { 35 | // Show Viewer 36 | let viewer = vscode.commands.registerCommand('abcjs-vscode.showPreview', () => 37 | showPreview(context) 38 | ); 39 | context.subscriptions.push(viewer); 40 | 41 | // Export 42 | let exportCommand = vscode.commands.registerCommand( 43 | 'abcjs-vscode.exportHtml', 44 | () => requestHtmlExport() 45 | ); 46 | context.subscriptions.push(exportCommand); 47 | 48 | // Export SVG 49 | let exportSvgCommand = vscode.commands.registerCommand( 50 | 'abcjs-vscode.exportSvg', 51 | () => requestSvgExport() 52 | ); 53 | context.subscriptions.push(exportSvgCommand); 54 | 55 | // Print Preview 56 | let printCommand = vscode.commands.registerCommand( 57 | 'abcjs-vscode.printPreview', 58 | () => printPreview(context) 59 | ); 60 | context.subscriptions.push(printCommand); 61 | } 62 | 63 | function registerEvents(context: vscode.ExtensionContext) { 64 | // Update the Preview when code changes. 65 | context.subscriptions.push( 66 | vscode.workspace.onDidChangeTextDocument((eventArgs) => { 67 | updatePreview(eventArgs); 68 | }) 69 | ); 70 | 71 | context.subscriptions.push( 72 | vscode.window.onDidChangeActiveTextEditor(async (eventArgs) => { 73 | if (eventArgs) { 74 | if (!panel || !vscode.window.activeTextEditor) { 75 | return; 76 | } 77 | 78 | updatePreview(eventArgs); 79 | } 80 | }) 81 | ); 82 | 83 | // Handle configuration changes. 84 | // todo: pass the configuration options to the viewer panel. 85 | context.subscriptions.push( 86 | vscode.workspace.onDidChangeConfiguration(async () => { 87 | // receives an event (e) 88 | //if (e.affectsConfiguration('abcjs-vscode.pageFormatting.print')) 89 | outputChannel.appendLine('configuration changed'); 90 | 91 | // read configuration options and send all to the Viewer 92 | const options = readConfiguration(); 93 | 94 | await panel.webview.postMessage({ 95 | command: 'configurationChange', 96 | content: options, 97 | }); 98 | }) 99 | ); 100 | } 101 | 102 | async function requestHtmlExport() { 103 | if (!panel) { 104 | vscode.window.showWarningMessage( 105 | 'The HTML Export requires the preview panel to be open, to render content.' 106 | ); 107 | return; 108 | } 109 | 110 | // set the receiving handler 111 | svgHandler = exportHtml; 112 | 113 | // Send a message to the Viewer, requesting the current SVG. 114 | await panel.webview.postMessage({ command: 'requestSvg' }); 115 | } 116 | 117 | async function requestSvgExport() { 118 | if (!panel) { 119 | vscode.window.showWarningMessage( 120 | 'The SVG Export requires the preview panel to be open, to render content.' 121 | ); 122 | return; 123 | } 124 | 125 | // set the receiving handler 126 | svgHandler = exportSvg; 127 | 128 | // Send a message to the Viewer, requesting the current SVG. 129 | await panel.webview.postMessage({ command: 'requestSvg' }); 130 | } 131 | 132 | function initializePanel(context: vscode.ExtensionContext) { 133 | panel = createPanel(context); 134 | 135 | // Receiving messages from the Viewer. 136 | panel.webview.onDidReceiveMessage((message) => { 137 | switch (message.name) { 138 | case 'click': 139 | // Select the character in the editor. 140 | select(message.startChar, message.endChar); 141 | break; 142 | 143 | case 'svgExport': 144 | const svg = message.content; 145 | svgHandler(svg); 146 | break; 147 | } 148 | 149 | // try { 150 | // } catch (error: any) { 151 | // outputChannel.appendLine(error); 152 | // outputChannel.show(); 153 | // vscode.window.showErrorMessage(error); 154 | // } 155 | }); 156 | } 157 | 158 | /** 159 | * open the preview window to the side. 160 | */ 161 | async function showPreview(context: vscode.ExtensionContext) { 162 | initializePanel(context); 163 | 164 | panel.webview.html = await getHtml(context, getFileNameFromEditor()); 165 | } 166 | 167 | /** 168 | * Export command. Render the sheet in HTML and open in a browser. 169 | * @param context vs code context 170 | */ 171 | async function exportHtml(svg: string) { 172 | // if (editor?.document.isUntitled) { 173 | // vscode.window.showInformationMessage( 174 | // 'Please save document before exporting.' 175 | // ); 176 | // } 177 | 178 | // generate HTML with the SVG inside. 179 | 180 | // load HTML template 181 | const templatePath = path.join(_context.extensionPath, 'res', 'export.html'); 182 | let html = await loadFileContent(templatePath); 183 | html = html.replace('{{body}}', svg); 184 | 185 | const editorFilePath = getEditorFilePath(); 186 | const filePath = editorFilePath + '.html'; 187 | saveToFile(filePath, html); 188 | 189 | vscode.window.showInformationMessage('HTML exported to', filePath); 190 | 191 | // Open browser. 192 | let url = filePath.replaceAll('\\', '/'); 193 | url = 'file:///' + url; 194 | await vscode.env.openExternal(vscode.Uri.parse(url)); 195 | } 196 | 197 | function exportSvg(svg: string) { 198 | const editorFilePath = getEditorFilePath(); 199 | // getEditorFilename() 200 | //let filePath = getTempFilePath(editorFilename + '.svg'); 201 | const filePath = editorFilePath + '.svg'; 202 | 203 | saveToFile(filePath, svg); 204 | 205 | vscode.window.showInformationMessage('SVG exported to', filePath); 206 | } 207 | 208 | function getCurrentEditorContent(): string { 209 | const editor = getEditor(); 210 | 211 | const editorContent = getNormalizedEditorContent(editor); 212 | return editorContent; 213 | } 214 | 215 | function getEditorFilePath(): string { 216 | const editor = getEditor(); 217 | if (!editor) { 218 | return ''; 219 | } 220 | 221 | const filePath = editor?.document.fileName; 222 | return filePath; 223 | } 224 | 225 | function getFileNameFromEditor() { 226 | const filePath = getEditorFilePath(); 227 | const arr = filePath.split(path.sep); 228 | 229 | return arr[arr.length - 1]; 230 | } 231 | 232 | /** 233 | * Get a filename for saving HTML. 234 | */ 235 | function getHtmlFilenameForExport(): string { 236 | let filePath: string; 237 | const editor = getEditor(); 238 | 239 | // if document is untitled, use tmp file. 240 | if (editor?.document.isUntitled) { 241 | filePath = getTempFilenameForExport(); 242 | } else { 243 | // existing file? 244 | filePath = editor?.document.fileName as string; 245 | filePath += '.html'; 246 | 247 | // Depending on the window from which the command was executed, this might be 248 | // just a title, an invalid path. 249 | if (!path.isAbsolute) { 250 | filePath = getTempFilenameForExport(); 251 | } 252 | } 253 | 254 | return filePath; 255 | } 256 | 257 | function getTempFilenameForExport() { 258 | const filePath = getTempFilePath('abcjs-vscode-printPreview.html'); 259 | return filePath; 260 | } 261 | 262 | function getTempFilePath(filename: string) { 263 | const tempDir = os.tmpdir(); 264 | const filePath = path.join(tempDir, filename); 265 | return filePath; 266 | } 267 | 268 | /** 269 | * Read the configuration settings and prepare abcjs Options object. 270 | */ 271 | function readConfiguration(): object { 272 | const editor = getEditor(); 273 | const currentDocument = editor?.document; 274 | const configuration = vscode.workspace.getConfiguration( 275 | 'abcjs-vscode', 276 | currentDocument?.uri 277 | ); 278 | 279 | // specific settings 280 | const tablatureValue: string | undefined = configuration.get('sheet.tablature'); 281 | const tablature = tablatureValue 282 | ? [{ instrument: tablatureValue.toLowerCase() }] : undefined; 283 | 284 | const options = { 285 | // Page Formatting 286 | oneSvgPerLine: configuration.get('pageFormatting.oneSvgPerLine'), 287 | responsive: configuration.get('pageFormatting.responsive'), 288 | print: configuration.get('pageFormatting.print'), 289 | // Sheet 290 | showDebug: configuration.get('sheet.showDebug') ? ['grid', 'box'] : [], 291 | jazzchords: configuration.get('sheet.jazzchords'), 292 | tablature: tablature, 293 | // Transposition 294 | visualTranspose: configuration.get('transposition.visualTranspose'), 295 | showTransposedSource: configuration.get('transposition.showTransposedSource') 296 | }; 297 | return options; 298 | } 299 | 300 | async function updatePreview( 301 | eventArgs: vscode.TextEditor | vscode.TextDocumentChangeEvent 302 | ) { 303 | const editor = getEditor(); 304 | 305 | if (!editor) { 306 | //throw new Error('No text editors available!'); 307 | return; 308 | } 309 | if (!panel) { 310 | throw new Error('No preview panel found!'); 311 | } 312 | 313 | const language = eventArgs.document.languageId; 314 | 315 | // plaintext is for unsaved files. 316 | if (language !== 'abc' && language !== 'plaintext') { 317 | //outputChannel.appendLine(`language is ${language}`); 318 | return; 319 | } 320 | 321 | const editorContent = getNormalizedEditorContent(editor); 322 | 323 | await panel.webview.postMessage({ 324 | command: 'contentChange', 325 | content: editorContent, 326 | }); 327 | 328 | panel.title = 'abc: ' + getFileNameFromEditor(); 329 | } 330 | 331 | /** 332 | * Generate the Preview HTML. 333 | * @param {String} editorContent 334 | */ 335 | async function getHtml(context: vscode.ExtensionContext, fileName: string) { 336 | const editorContent = getCurrentEditorContent(); 337 | 338 | const filePath = path.join(context.extensionPath, 'res', 'viewer.html'); 339 | //const filePath = panel.webview.asWebviewUri(onDiskPath); 340 | let html = await loadFileContent(filePath); 341 | 342 | // replace variables 343 | html = html.replace('{editorContent}', editorContent); 344 | html = html.replace('${fileName}', fileName); 345 | html = html.replace('${title}', fileName); 346 | 347 | return html; 348 | } 349 | 350 | function getEditor() { 351 | let editor = vscode.window.activeTextEditor; 352 | if (!editor) { 353 | // Take the first visible one?! 354 | editor = vscode.window.visibleTextEditors[0]; 355 | } 356 | return editor; 357 | } 358 | 359 | /** 360 | * Select the code in the editor between the given locations. Used on sheet click. 361 | * @param {Number} start 362 | * @param {Number} end 363 | */ 364 | function select(start: number, end: number) { 365 | const editor = getEditor(); 366 | 367 | //editor.document.offsetAt() 368 | const startPos = editor.document.positionAt(start); 369 | const endPos = editor.document.positionAt(end); 370 | //outputChannel.appendLine(`positions: ${startPos}, ${endPos}`) 371 | 372 | // vscode.commands.executeCommand("cursorMove", { 373 | // to: "down", 374 | // by: "wrappedLine", 375 | // select: true, 376 | // value: 1 377 | // }); 378 | 379 | editor.selection = new vscode.Selection(startPos, endPos); 380 | editor.revealRange(editor.selection); 381 | } 382 | 383 | function getNormalizedEditorContent(editor?: vscode.TextEditor) { 384 | if (!editor) { 385 | return ''; 386 | } 387 | 388 | let content = editor.document.getText(); 389 | 390 | // escape the \ 391 | content = content.replaceAll('\\', '\\\\'); 392 | 393 | if (editor.document.eol === vscode.EndOfLine.CRLF) { 394 | content = content.replace(/\r\n/g, '\n'); 395 | } 396 | 397 | return content; 398 | } 399 | 400 | function createPanel(context: vscode.ExtensionContext): WebviewPanel { 401 | //vscode.window.showInformationMessage('Opening the preview in abcjs editor!'); 402 | var result = vscode.window.createWebviewPanel( 403 | 'abcjsPreview', 404 | 'abcjs preview', 405 | vscode.ViewColumn.Beside, 406 | { 407 | enableScripts: true, 408 | // Only allow the webview to access resources in our extension's media directory 409 | localResourceRoots: [ 410 | vscode.Uri.file(path.join(context.extensionPath, 'src')), 411 | ], 412 | } 413 | ); 414 | return result; 415 | } 416 | 417 | function saveToFile(filePath: string, content: string) { 418 | let fs = require('fs'); 419 | fs.writeFileSync(filePath, content); 420 | } 421 | 422 | /** 423 | * Print command. Prepare the sheet for printing and open in a browser. 424 | */ 425 | async function printPreview(context: vscode.ExtensionContext) { 426 | // load print template 427 | const filePath = path.join(context.extensionPath, 'res', 'print.html'); 428 | let html = await loadFileContent(filePath); 429 | 430 | // add content 431 | const editorContent = getCurrentEditorContent(); 432 | html = html.replace('{{body}}', editorContent); 433 | 434 | // save 435 | let savePath = getHtmlFilenameForExport(); 436 | const url = pathToFileURL(savePath).toString(); 437 | const uri = vscode.Uri.parse(url); 438 | var content = Uint8Array.from(html.split('').map((x) => x.charCodeAt(0))); 439 | await vscode.workspace.fs.writeFile(uri, content); 440 | 441 | // open browser 442 | await vscode.env.openExternal(uri); 443 | } 444 | 445 | async function loadFileContent(filePath: string): Promise { 446 | const onDiskPath = vscode.Uri.file(filePath); 447 | 448 | const fileContent = await vscode.workspace.fs.readFile(onDiskPath); 449 | 450 | let readableContent = fileContent.toString(); 451 | return readableContent; 452 | } 453 | 454 | // this method is called when your extension is deactivated 455 | function deactivate() {} 456 | 457 | module.exports = { 458 | activate, 459 | deactivate, 460 | }; 461 | -------------------------------------------------------------------------------- /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": "ES2021", 5 | "outDir": "out", 6 | //"checkJs": true, /* Typecheck .js files. */ 7 | "lib": [ 8 | "ES2021" 9 | ], 10 | "sourceMap": true, 11 | "rootDir": "src", 12 | "strict": true /* enable all strict type-checking options */ 13 | /* Additional Checks */ 14 | // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ 15 | // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ 16 | // "noUnusedParameters": true, /* Report errors on unused parameters. */ 17 | }, 18 | "exclude": [ 19 | "node_modules" 20 | ] 21 | } 22 | -------------------------------------------------------------------------------- /vsc-extension-quickstart.md: -------------------------------------------------------------------------------- 1 | # Welcome to your VS Code Extension 2 | 3 | ## What's in the folder 4 | 5 | * This folder contains all of the files necessary for your extension. 6 | * `package.json` - this is the manifest file in which you declare your extension and command. 7 | * The sample plugin registers a command and defines its title and command name. With this information VS Code can show the command in the command palette. It doesn’t yet need to load the plugin. 8 | * `extension.js` - this is the main file where you will provide the implementation of your command. 9 | * The file exports one function, `activate`, which is called the very first time your extension is activated (in this case by executing the command). Inside the `activate` function we call `registerCommand`. 10 | * We pass the function containing the implementation of the command as the second parameter to `registerCommand`. 11 | 12 | ## Get up and running straight away 13 | 14 | * Press `F5` to open a new window with your extension loaded. 15 | * Run your command from the command palette by pressing (`Ctrl+Shift+P` or `Cmd+Shift+P` on Mac) and typing `Hello World`. 16 | * Set breakpoints in your code inside `extension.js` to debug your extension. 17 | * Find output from your extension in the debug console. 18 | 19 | ## Make changes 20 | 21 | * You can relaunch the extension from the debug toolbar after changing code in `extension.js`. 22 | * You can also reload (`Ctrl+R` or `Cmd+R` on Mac) the VS Code window with your extension to load your changes. 23 | 24 | ## Explore the API 25 | 26 | * You can open the full set of our API when you open the file `node_modules/@types/vscode/index.d.ts`. 27 | 28 | ## Run tests 29 | 30 | * Open the debug viewlet (`Ctrl+Shift+D` or `Cmd+Shift+D` on Mac) and from the launch configuration dropdown pick `Extension Tests`. 31 | * Press `F5` to run the tests in a new window with your extension loaded. 32 | * See the output of the test result in the debug console. 33 | * Make changes to `src/test/suite/extension.test.js` or create new test files inside the `test/suite` folder. 34 | * The provided test runner will only consider files matching the name pattern `**.test.ts`. 35 | * You can create folders inside the `test` folder to structure your tests any way you want. 36 | ## Go further 37 | 38 | * [Publish your extension](https://code.visualstudio.com/api/working-with-extensions/publishing-extension) on the VSCode extension marketplace. 39 | * Automate builds by setting up [Continuous Integration](https://code.visualstudio.com/api/working-with-extensions/continuous-integration). 40 | --------------------------------------------------------------------------------