├── .github └── workflows │ └── codeql-analysis.yml ├── .gitignore ├── .vscode ├── extensions.json ├── launch.json ├── settings.json └── tasks.json ├── .vscodeignore ├── CHANGELOG.md ├── LICENSE ├── README.md ├── images ├── demo.gif └── icon.png ├── package-lock.json ├── package.json ├── src ├── CsvColumn.ts ├── CsvParser.ts ├── CsvRecord.ts ├── TableWriter.ts ├── extension.ts └── test │ ├── runTest.ts │ └── suite │ ├── extension.test.ts │ └── index.ts ├── tsconfig.json ├── tslint.json └── vsc-extension-quickstart.md /.github/workflows/codeql-analysis.yml: -------------------------------------------------------------------------------- 1 | # For most projects, this workflow file will not need changing; you simply need 2 | # to commit it to your repository. 3 | # 4 | # You may wish to alter this file to override the set of languages analyzed, 5 | # or to provide custom queries or build logic. 6 | # 7 | # ******** NOTE ******** 8 | # We have attempted to detect the languages in your repository. Please check 9 | # the `language` matrix defined below to confirm you have the correct set of 10 | # supported CodeQL languages. 11 | # 12 | name: "CodeQL" 13 | 14 | on: 15 | push: 16 | branches: [ main ] 17 | pull_request: 18 | # The branches below must be a subset of the branches above 19 | branches: [ main ] 20 | schedule: 21 | - cron: '29 13 * * 5' 22 | 23 | jobs: 24 | analyze: 25 | name: Analyze 26 | runs-on: ubuntu-latest 27 | permissions: 28 | actions: read 29 | contents: read 30 | security-events: write 31 | 32 | strategy: 33 | fail-fast: false 34 | matrix: 35 | language: [ 'javascript' ] 36 | # CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python', 'ruby' ] 37 | # Learn more about CodeQL language support at https://git.io/codeql-language-support 38 | 39 | steps: 40 | - name: Checkout repository 41 | uses: actions/checkout@v2 42 | 43 | # Initializes the CodeQL tools for scanning. 44 | - name: Initialize CodeQL 45 | uses: github/codeql-action/init@v3 46 | with: 47 | languages: ${{ matrix.language }} 48 | # If you wish to specify custom queries, you can do so here or in a config file. 49 | # By default, queries listed here will override any specified in a config file. 50 | # Prefix the list here with "+" to use these queries and those in the config file. 51 | # queries: ./path/to/local/query, your-org/your-repo/queries@main 52 | 53 | # Autobuild attempts to build any compiled languages (C/C++, C#, or Java). 54 | # If this step fails, then you should remove it and run the build manually (see below) 55 | - name: Autobuild 56 | uses: github/codeql-action/autobuild@v3 57 | 58 | # ℹ️ Command-line programs to run using the OS shell. 59 | # 📚 https://git.io/JvXDl 60 | 61 | # ✏️ If the Autobuild fails above, remove it and uncomment the following three lines 62 | # and modify them (or add more) to build your code if your project 63 | # uses a compiled language 64 | 65 | #- run: | 66 | # make bootstrap 67 | # make release 68 | 69 | - name: Perform CodeQL Analysis 70 | uses: github/codeql-action/analyze@v3 71 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | out 2 | node_modules 3 | .vscode-test/ 4 | *.vsix 5 | -------------------------------------------------------------------------------- /.vscode/extensions.json: -------------------------------------------------------------------------------- 1 | { 2 | // See http://go.microsoft.com/fwlink/?LinkId=827846 3 | // for the documentation about the extensions.json format 4 | "recommendations": [ 5 | "ms-vscode.vscode-typescript-tslint-plugin" 6 | ] 7 | } -------------------------------------------------------------------------------- /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | // A launch configuration that compiles the extension and then opens it inside a new window 2 | // Use IntelliSense to learn about possible attributes. 3 | // Hover to view descriptions of existing attributes. 4 | // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 5 | { 6 | "version": "0.2.0", 7 | "configurations": [ 8 | 9 | { 10 | "name": "Run Extension", 11 | "type": "extensionHost", 12 | "request": "launch", 13 | "runtimeExecutable": "${execPath}", 14 | "args": [ 15 | "--extensionDevelopmentPath=${workspaceFolder}" 16 | ], 17 | "outFiles": [ 18 | "${workspaceFolder}/out/**/*.js" 19 | ], 20 | "preLaunchTask": "npm: watch" 21 | }, 22 | { 23 | "name": "Extension Tests", 24 | "type": "extensionHost", 25 | "request": "launch", 26 | "runtimeExecutable": "${execPath}", 27 | "args": [ 28 | "--extensionDevelopmentPath=${workspaceFolder}", 29 | "--extensionTestsPath=${workspaceFolder}/out/test/suite/index" 30 | ], 31 | "outFiles": [ 32 | "${workspaceFolder}/out/test/**/*.js" 33 | ], 34 | "preLaunchTask": "npm: watch" 35 | } 36 | ] 37 | } 38 | -------------------------------------------------------------------------------- /.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 | out/test/** 4 | src/** 5 | .gitignore 6 | vsc-extension-quickstart.md 7 | **/tsconfig.json 8 | **/tslint.json 9 | **/*.map 10 | **/*.ts -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # Change Log 2 | 3 | All notable changes to the "csv-to-table" extension will be documented in this file. 4 | 5 | ### 1.4.1 6 | Updated dependencies 7 | 8 | ### 1.4.0 9 | Added support for right-aligning numeric values in table cells. 10 | 11 | This option can be changed via Extension settings, and is enabled by default. 12 | 13 | ### 1.3.0 14 | Added support to write the generated table using Markdown format. 15 | 16 | This option can be changed via Extension settings. 17 | 18 | ### 1.2.3 19 | Trivial performance improvement during table generation. 20 | 21 | ### 1.2.2 22 | Added a new option that is off by default, to transform the first row (header) values to upper-case, to make the column headers stand out. 23 | 24 | This option can be changed via Extension settings. 25 | 26 | ### 1.2.1 27 | Added option to specify a custom separator ("Convert to table from a custom defined separator" command). 28 | 29 | ### 1.2.0 30 | Added a new option that is on by default, where the generated table appears in a new editor window. 31 | 32 | This option can be changed (so that the existing document is replaced) via Extension settings. 33 | 34 | ### 1.1.0 35 | Added support for SSV (semicolon separated) files. 36 | 37 | ### 1.0.0 38 | 39 | Initial release of the extension. 40 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2022 Andrew Armstrong 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # CSV/TSV/PSV to Table 2 | 3 | Convert your CSV/TSV/PSV files to an ASCII formatted table. 4 | 5 | Useful when you want to paste CSV related data into an e-mail or Slack room. 6 | 7 | By default the generated table opens in a new editor tab, but you can change this to update the existing editor via extension settings. 8 | 9 | ## Quick Start 10 | 11 | Select the rows of CSV text (or no selection, to convert the entire document) and then via the command palette choose __Convert to table from CSV/TSV/PSV__ to have the text replaced with an ASCII formatted table. 12 | 13 | ## Features 14 | 15 | CSV to Table in action on an example data set. 16 | 17 | ![Convert to Table](images/demo.gif) 18 | 19 | ## Release Notes 20 | 21 | See Changelog for details of release notes. 22 | 23 | ## Attributions 24 | Icon made by Pixel Perfect (https://www.flaticon.com/authors/pixel-perfect) from www.flaticon.com 25 | -------------------------------------------------------------------------------- /images/demo.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Plasma/csv-to-table/0e0ca788802d9c89b8c63b0c262c46b5181bc518/images/demo.gif -------------------------------------------------------------------------------- /images/icon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Plasma/csv-to-table/0e0ca788802d9c89b8c63b0c262c46b5181bc518/images/icon.png -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "csv-to-table", 3 | "version": "1.4.1", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "csv-to-table", 9 | "version": "1.4.1", 10 | "devDependencies": { 11 | "@types/glob": "^8.0.1", 12 | "@types/mocha": "^10.0.1", 13 | "@types/node": "^20.5.0", 14 | "@types/vscode": "^1.79.0", 15 | "@vscode/test-electron": "^2.4.1", 16 | "glob": "^8.1.0", 17 | "minimist": "^1.2.7", 18 | "mkdirp": "^1.0.4", 19 | "mocha": "^10.2.0", 20 | "tslint": "^6.1.3", 21 | "typescript": "^5.3.0" 22 | }, 23 | "engines": { 24 | "vscode": "^1.79.0" 25 | } 26 | }, 27 | "node_modules/@babel/code-frame": { 28 | "version": "7.26.2", 29 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.26.2.tgz", 30 | "integrity": "sha512-RJlIHRueQgwWitWgF8OdFYGZX328Ax5BCemNGlqHfplnRT9ESi8JkFlvaVYbS+UubVY6dpv87Fs2u5M29iNFVQ==", 31 | "dev": true, 32 | "dependencies": { 33 | "@babel/helper-validator-identifier": "^7.25.9", 34 | "js-tokens": "^4.0.0", 35 | "picocolors": "^1.0.0" 36 | }, 37 | "engines": { 38 | "node": ">=6.9.0" 39 | } 40 | }, 41 | "node_modules/@babel/helper-validator-identifier": { 42 | "version": "7.25.9", 43 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.9.tgz", 44 | "integrity": "sha512-Ed61U6XJc3CVRfkERJWDz4dJwKe7iLmmJsbOGu9wSloNSFttHV0I8g6UAgb7qnK5ly5bGLPd4oXZlxCdANBOWQ==", 45 | "dev": true, 46 | "engines": { 47 | "node": ">=6.9.0" 48 | } 49 | }, 50 | "node_modules/@types/glob": { 51 | "version": "8.1.0", 52 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-8.1.0.tgz", 53 | "integrity": "sha512-IO+MJPVhoqz+28h1qLAcBEH2+xHMK6MTyHJc7MTnnYb6wsoLR29POVGJ7LycmVXIqyy/4/2ShP5sUwTXuOwb/w==", 54 | "dev": true, 55 | "dependencies": { 56 | "@types/minimatch": "^5.1.2", 57 | "@types/node": "*" 58 | } 59 | }, 60 | "node_modules/@types/minimatch": { 61 | "version": "5.1.2", 62 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-5.1.2.tgz", 63 | "integrity": "sha512-K0VQKziLUWkVKiRVrx4a40iPaxTUefQmjtkQofBkYRcoaaL/8rhwDWww9qWbrgicNOgnpIsMxyNIUM4+n6dUIA==", 64 | "dev": true 65 | }, 66 | "node_modules/@types/mocha": { 67 | "version": "10.0.9", 68 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-10.0.9.tgz", 69 | "integrity": "sha512-sicdRoWtYevwxjOHNMPTl3vSfJM6oyW8o1wXeI7uww6b6xHg8eBznQDNSGBCDJmsE8UMxP05JgZRtsKbTqt//Q==", 70 | "dev": true 71 | }, 72 | "node_modules/@types/node": { 73 | "version": "20.17.6", 74 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.17.6.tgz", 75 | "integrity": "sha512-VEI7OdvK2wP7XHnsuXbAJnEpEkF6NjSN45QJlL4VGqZSXsnicpesdTWsg9RISeSdYd3yeRj/y3k5KGjUXYnFwQ==", 76 | "dev": true, 77 | "dependencies": { 78 | "undici-types": "~6.19.2" 79 | } 80 | }, 81 | "node_modules/@types/vscode": { 82 | "version": "1.95.0", 83 | "resolved": "https://registry.npmjs.org/@types/vscode/-/vscode-1.95.0.tgz", 84 | "integrity": "sha512-0LBD8TEiNbet3NvWsmn59zLzOFu/txSlGxnv5yAFHCrhG9WvAnR3IvfHzMOs2aeWqgvNjq9pO99IUw8d3n+unw==", 85 | "dev": true 86 | }, 87 | "node_modules/@vscode/test-electron": { 88 | "version": "2.4.1", 89 | "resolved": "https://registry.npmjs.org/@vscode/test-electron/-/test-electron-2.4.1.tgz", 90 | "integrity": "sha512-Gc6EdaLANdktQ1t+zozoBVRynfIsMKMc94Svu1QreOBC8y76x4tvaK32TljrLi1LI2+PK58sDVbL7ALdqf3VRQ==", 91 | "dev": true, 92 | "dependencies": { 93 | "http-proxy-agent": "^7.0.2", 94 | "https-proxy-agent": "^7.0.5", 95 | "jszip": "^3.10.1", 96 | "ora": "^7.0.1", 97 | "semver": "^7.6.2" 98 | }, 99 | "engines": { 100 | "node": ">=16" 101 | } 102 | }, 103 | "node_modules/agent-base": { 104 | "version": "7.1.1", 105 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.1.tgz", 106 | "integrity": "sha512-H0TSyFNDMomMNJQBn8wFV5YC/2eJ+VXECwOadZJT554xP6cODZHPX3H9QMQECxvrgiSOP1pHjy1sMWQVYJOUOA==", 107 | "dev": true, 108 | "dependencies": { 109 | "debug": "^4.3.4" 110 | }, 111 | "engines": { 112 | "node": ">= 14" 113 | } 114 | }, 115 | "node_modules/ansi-colors": { 116 | "version": "4.1.3", 117 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.3.tgz", 118 | "integrity": "sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==", 119 | "dev": true, 120 | "engines": { 121 | "node": ">=6" 122 | } 123 | }, 124 | "node_modules/ansi-regex": { 125 | "version": "6.1.0", 126 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz", 127 | "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==", 128 | "dev": true, 129 | "engines": { 130 | "node": ">=12" 131 | }, 132 | "funding": { 133 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 134 | } 135 | }, 136 | "node_modules/ansi-styles": { 137 | "version": "4.3.0", 138 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 139 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 140 | "dev": true, 141 | "dependencies": { 142 | "color-convert": "^2.0.1" 143 | }, 144 | "engines": { 145 | "node": ">=8" 146 | }, 147 | "funding": { 148 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 149 | } 150 | }, 151 | "node_modules/anymatch": { 152 | "version": "3.1.3", 153 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 154 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 155 | "dev": true, 156 | "dependencies": { 157 | "normalize-path": "^3.0.0", 158 | "picomatch": "^2.0.4" 159 | }, 160 | "engines": { 161 | "node": ">= 8" 162 | } 163 | }, 164 | "node_modules/argparse": { 165 | "version": "2.0.1", 166 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 167 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 168 | "dev": true 169 | }, 170 | "node_modules/balanced-match": { 171 | "version": "1.0.2", 172 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 173 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 174 | "dev": true 175 | }, 176 | "node_modules/base64-js": { 177 | "version": "1.5.1", 178 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 179 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", 180 | "dev": true, 181 | "funding": [ 182 | { 183 | "type": "github", 184 | "url": "https://github.com/sponsors/feross" 185 | }, 186 | { 187 | "type": "patreon", 188 | "url": "https://www.patreon.com/feross" 189 | }, 190 | { 191 | "type": "consulting", 192 | "url": "https://feross.org/support" 193 | } 194 | ] 195 | }, 196 | "node_modules/binary-extensions": { 197 | "version": "2.3.0", 198 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", 199 | "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", 200 | "dev": true, 201 | "engines": { 202 | "node": ">=8" 203 | }, 204 | "funding": { 205 | "url": "https://github.com/sponsors/sindresorhus" 206 | } 207 | }, 208 | "node_modules/bl": { 209 | "version": "5.1.0", 210 | "resolved": "https://registry.npmjs.org/bl/-/bl-5.1.0.tgz", 211 | "integrity": "sha512-tv1ZJHLfTDnXE6tMHv73YgSJaWR2AFuPwMntBe7XL/GBFHnT0CLnsHMogfk5+GzCDC5ZWarSCYaIGATZt9dNsQ==", 212 | "dev": true, 213 | "dependencies": { 214 | "buffer": "^6.0.3", 215 | "inherits": "^2.0.4", 216 | "readable-stream": "^3.4.0" 217 | } 218 | }, 219 | "node_modules/bl/node_modules/readable-stream": { 220 | "version": "3.6.2", 221 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", 222 | "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", 223 | "dev": true, 224 | "dependencies": { 225 | "inherits": "^2.0.3", 226 | "string_decoder": "^1.1.1", 227 | "util-deprecate": "^1.0.1" 228 | }, 229 | "engines": { 230 | "node": ">= 6" 231 | } 232 | }, 233 | "node_modules/brace-expansion": { 234 | "version": "2.0.1", 235 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 236 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 237 | "dev": true, 238 | "dependencies": { 239 | "balanced-match": "^1.0.0" 240 | } 241 | }, 242 | "node_modules/braces": { 243 | "version": "3.0.3", 244 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", 245 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", 246 | "dev": true, 247 | "dependencies": { 248 | "fill-range": "^7.1.1" 249 | }, 250 | "engines": { 251 | "node": ">=8" 252 | } 253 | }, 254 | "node_modules/browser-stdout": { 255 | "version": "1.3.1", 256 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 257 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 258 | "dev": true 259 | }, 260 | "node_modules/buffer": { 261 | "version": "6.0.3", 262 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz", 263 | "integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==", 264 | "dev": true, 265 | "funding": [ 266 | { 267 | "type": "github", 268 | "url": "https://github.com/sponsors/feross" 269 | }, 270 | { 271 | "type": "patreon", 272 | "url": "https://www.patreon.com/feross" 273 | }, 274 | { 275 | "type": "consulting", 276 | "url": "https://feross.org/support" 277 | } 278 | ], 279 | "dependencies": { 280 | "base64-js": "^1.3.1", 281 | "ieee754": "^1.2.1" 282 | } 283 | }, 284 | "node_modules/builtin-modules": { 285 | "version": "1.1.1", 286 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 287 | "integrity": "sha512-wxXCdllwGhI2kCC0MnvTGYTMvnVZTvqgypkiTI8Pa5tcz2i6VqsqwYGgqwXji+4RgCzms6EajE4IxiUH6HH8nQ==", 288 | "dev": true, 289 | "engines": { 290 | "node": ">=0.10.0" 291 | } 292 | }, 293 | "node_modules/camelcase": { 294 | "version": "6.3.0", 295 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 296 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 297 | "dev": true, 298 | "engines": { 299 | "node": ">=10" 300 | }, 301 | "funding": { 302 | "url": "https://github.com/sponsors/sindresorhus" 303 | } 304 | }, 305 | "node_modules/chalk": { 306 | "version": "4.1.2", 307 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 308 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 309 | "dev": true, 310 | "dependencies": { 311 | "ansi-styles": "^4.1.0", 312 | "supports-color": "^7.1.0" 313 | }, 314 | "engines": { 315 | "node": ">=10" 316 | }, 317 | "funding": { 318 | "url": "https://github.com/chalk/chalk?sponsor=1" 319 | } 320 | }, 321 | "node_modules/chalk/node_modules/supports-color": { 322 | "version": "7.2.0", 323 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 324 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 325 | "dev": true, 326 | "dependencies": { 327 | "has-flag": "^4.0.0" 328 | }, 329 | "engines": { 330 | "node": ">=8" 331 | } 332 | }, 333 | "node_modules/chokidar": { 334 | "version": "3.6.0", 335 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", 336 | "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", 337 | "dev": true, 338 | "dependencies": { 339 | "anymatch": "~3.1.2", 340 | "braces": "~3.0.2", 341 | "glob-parent": "~5.1.2", 342 | "is-binary-path": "~2.1.0", 343 | "is-glob": "~4.0.1", 344 | "normalize-path": "~3.0.0", 345 | "readdirp": "~3.6.0" 346 | }, 347 | "engines": { 348 | "node": ">= 8.10.0" 349 | }, 350 | "funding": { 351 | "url": "https://paulmillr.com/funding/" 352 | }, 353 | "optionalDependencies": { 354 | "fsevents": "~2.3.2" 355 | } 356 | }, 357 | "node_modules/cli-cursor": { 358 | "version": "4.0.0", 359 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-4.0.0.tgz", 360 | "integrity": "sha512-VGtlMu3x/4DOtIUwEkRezxUZ2lBacNJCHash0N0WeZDBS+7Ux1dm3XWAgWYxLJFMMdOeXMHXorshEFhbMSGelg==", 361 | "dev": true, 362 | "dependencies": { 363 | "restore-cursor": "^4.0.0" 364 | }, 365 | "engines": { 366 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 367 | }, 368 | "funding": { 369 | "url": "https://github.com/sponsors/sindresorhus" 370 | } 371 | }, 372 | "node_modules/cli-spinners": { 373 | "version": "2.9.2", 374 | "resolved": "https://registry.npmjs.org/cli-spinners/-/cli-spinners-2.9.2.tgz", 375 | "integrity": "sha512-ywqV+5MmyL4E7ybXgKys4DugZbX0FC6LnwrhjuykIjnK9k8OQacQ7axGKnjDXWNhns0xot3bZI5h55H8yo9cJg==", 376 | "dev": true, 377 | "engines": { 378 | "node": ">=6" 379 | }, 380 | "funding": { 381 | "url": "https://github.com/sponsors/sindresorhus" 382 | } 383 | }, 384 | "node_modules/cliui": { 385 | "version": "7.0.4", 386 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 387 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 388 | "dev": true, 389 | "dependencies": { 390 | "string-width": "^4.2.0", 391 | "strip-ansi": "^6.0.0", 392 | "wrap-ansi": "^7.0.0" 393 | } 394 | }, 395 | "node_modules/cliui/node_modules/ansi-regex": { 396 | "version": "5.0.1", 397 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 398 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 399 | "dev": true, 400 | "engines": { 401 | "node": ">=8" 402 | } 403 | }, 404 | "node_modules/cliui/node_modules/emoji-regex": { 405 | "version": "8.0.0", 406 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 407 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 408 | "dev": true 409 | }, 410 | "node_modules/cliui/node_modules/string-width": { 411 | "version": "4.2.3", 412 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 413 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 414 | "dev": true, 415 | "dependencies": { 416 | "emoji-regex": "^8.0.0", 417 | "is-fullwidth-code-point": "^3.0.0", 418 | "strip-ansi": "^6.0.1" 419 | }, 420 | "engines": { 421 | "node": ">=8" 422 | } 423 | }, 424 | "node_modules/cliui/node_modules/strip-ansi": { 425 | "version": "6.0.1", 426 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 427 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 428 | "dev": true, 429 | "dependencies": { 430 | "ansi-regex": "^5.0.1" 431 | }, 432 | "engines": { 433 | "node": ">=8" 434 | } 435 | }, 436 | "node_modules/color-convert": { 437 | "version": "2.0.1", 438 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 439 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 440 | "dev": true, 441 | "dependencies": { 442 | "color-name": "~1.1.4" 443 | }, 444 | "engines": { 445 | "node": ">=7.0.0" 446 | } 447 | }, 448 | "node_modules/color-name": { 449 | "version": "1.1.4", 450 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 451 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 452 | "dev": true 453 | }, 454 | "node_modules/commander": { 455 | "version": "2.20.3", 456 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 457 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", 458 | "dev": true 459 | }, 460 | "node_modules/concat-map": { 461 | "version": "0.0.1", 462 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 463 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 464 | "dev": true 465 | }, 466 | "node_modules/core-util-is": { 467 | "version": "1.0.3", 468 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", 469 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", 470 | "dev": true 471 | }, 472 | "node_modules/debug": { 473 | "version": "4.3.7", 474 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.7.tgz", 475 | "integrity": "sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==", 476 | "dev": true, 477 | "dependencies": { 478 | "ms": "^2.1.3" 479 | }, 480 | "engines": { 481 | "node": ">=6.0" 482 | }, 483 | "peerDependenciesMeta": { 484 | "supports-color": { 485 | "optional": true 486 | } 487 | } 488 | }, 489 | "node_modules/decamelize": { 490 | "version": "4.0.0", 491 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 492 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 493 | "dev": true, 494 | "engines": { 495 | "node": ">=10" 496 | }, 497 | "funding": { 498 | "url": "https://github.com/sponsors/sindresorhus" 499 | } 500 | }, 501 | "node_modules/diff": { 502 | "version": "5.2.0", 503 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.2.0.tgz", 504 | "integrity": "sha512-uIFDxqpRZGZ6ThOk84hEfqWoHx2devRFvpTZcTHur85vImfaxUbTW9Ryh4CpCuDnToOP1CEtXKIgytHBPVff5A==", 505 | "dev": true, 506 | "engines": { 507 | "node": ">=0.3.1" 508 | } 509 | }, 510 | "node_modules/eastasianwidth": { 511 | "version": "0.2.0", 512 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 513 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", 514 | "dev": true 515 | }, 516 | "node_modules/emoji-regex": { 517 | "version": "10.4.0", 518 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.4.0.tgz", 519 | "integrity": "sha512-EC+0oUMY1Rqm4O6LLrgjtYDvcVYTy7chDnM4Q7030tP4Kwj3u/pR6gP9ygnp2CJMK5Gq+9Q2oqmrFJAz01DXjw==", 520 | "dev": true 521 | }, 522 | "node_modules/escalade": { 523 | "version": "3.2.0", 524 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", 525 | "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==", 526 | "dev": true, 527 | "engines": { 528 | "node": ">=6" 529 | } 530 | }, 531 | "node_modules/escape-string-regexp": { 532 | "version": "4.0.0", 533 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 534 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 535 | "dev": true, 536 | "engines": { 537 | "node": ">=10" 538 | }, 539 | "funding": { 540 | "url": "https://github.com/sponsors/sindresorhus" 541 | } 542 | }, 543 | "node_modules/esprima": { 544 | "version": "4.0.1", 545 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 546 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 547 | "dev": true, 548 | "bin": { 549 | "esparse": "bin/esparse.js", 550 | "esvalidate": "bin/esvalidate.js" 551 | }, 552 | "engines": { 553 | "node": ">=4" 554 | } 555 | }, 556 | "node_modules/fill-range": { 557 | "version": "7.1.1", 558 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", 559 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", 560 | "dev": true, 561 | "dependencies": { 562 | "to-regex-range": "^5.0.1" 563 | }, 564 | "engines": { 565 | "node": ">=8" 566 | } 567 | }, 568 | "node_modules/find-up": { 569 | "version": "5.0.0", 570 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 571 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 572 | "dev": true, 573 | "dependencies": { 574 | "locate-path": "^6.0.0", 575 | "path-exists": "^4.0.0" 576 | }, 577 | "engines": { 578 | "node": ">=10" 579 | }, 580 | "funding": { 581 | "url": "https://github.com/sponsors/sindresorhus" 582 | } 583 | }, 584 | "node_modules/flat": { 585 | "version": "5.0.2", 586 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 587 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 588 | "dev": true, 589 | "bin": { 590 | "flat": "cli.js" 591 | } 592 | }, 593 | "node_modules/fs.realpath": { 594 | "version": "1.0.0", 595 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 596 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 597 | "dev": true 598 | }, 599 | "node_modules/fsevents": { 600 | "version": "2.3.3", 601 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 602 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 603 | "dev": true, 604 | "hasInstallScript": true, 605 | "optional": true, 606 | "os": [ 607 | "darwin" 608 | ], 609 | "engines": { 610 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 611 | } 612 | }, 613 | "node_modules/function-bind": { 614 | "version": "1.1.2", 615 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 616 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 617 | "dev": true, 618 | "funding": { 619 | "url": "https://github.com/sponsors/ljharb" 620 | } 621 | }, 622 | "node_modules/get-caller-file": { 623 | "version": "2.0.5", 624 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 625 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 626 | "dev": true, 627 | "engines": { 628 | "node": "6.* || 8.* || >= 10.*" 629 | } 630 | }, 631 | "node_modules/glob": { 632 | "version": "8.1.0", 633 | "resolved": "https://registry.npmjs.org/glob/-/glob-8.1.0.tgz", 634 | "integrity": "sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ==", 635 | "deprecated": "Glob versions prior to v9 are no longer supported", 636 | "dev": true, 637 | "dependencies": { 638 | "fs.realpath": "^1.0.0", 639 | "inflight": "^1.0.4", 640 | "inherits": "2", 641 | "minimatch": "^5.0.1", 642 | "once": "^1.3.0" 643 | }, 644 | "engines": { 645 | "node": ">=12" 646 | }, 647 | "funding": { 648 | "url": "https://github.com/sponsors/isaacs" 649 | } 650 | }, 651 | "node_modules/glob-parent": { 652 | "version": "5.1.2", 653 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 654 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 655 | "dev": true, 656 | "dependencies": { 657 | "is-glob": "^4.0.1" 658 | }, 659 | "engines": { 660 | "node": ">= 6" 661 | } 662 | }, 663 | "node_modules/has-flag": { 664 | "version": "4.0.0", 665 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 666 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 667 | "dev": true, 668 | "engines": { 669 | "node": ">=8" 670 | } 671 | }, 672 | "node_modules/hasown": { 673 | "version": "2.0.2", 674 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 675 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 676 | "dev": true, 677 | "dependencies": { 678 | "function-bind": "^1.1.2" 679 | }, 680 | "engines": { 681 | "node": ">= 0.4" 682 | } 683 | }, 684 | "node_modules/he": { 685 | "version": "1.2.0", 686 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 687 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 688 | "dev": true, 689 | "bin": { 690 | "he": "bin/he" 691 | } 692 | }, 693 | "node_modules/http-proxy-agent": { 694 | "version": "7.0.2", 695 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-7.0.2.tgz", 696 | "integrity": "sha512-T1gkAiYYDWYx3V5Bmyu7HcfcvL7mUrTWiM6yOfa3PIphViJ/gFPbvidQ+veqSOHci/PxBcDabeUNCzpOODJZig==", 697 | "dev": true, 698 | "dependencies": { 699 | "agent-base": "^7.1.0", 700 | "debug": "^4.3.4" 701 | }, 702 | "engines": { 703 | "node": ">= 14" 704 | } 705 | }, 706 | "node_modules/https-proxy-agent": { 707 | "version": "7.0.5", 708 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-7.0.5.tgz", 709 | "integrity": "sha512-1e4Wqeblerz+tMKPIq2EMGiiWW1dIjZOksyHWSUm1rmuvw/how9hBHZ38lAGj5ID4Ik6EdkOw7NmWPy6LAwalw==", 710 | "dev": true, 711 | "dependencies": { 712 | "agent-base": "^7.0.2", 713 | "debug": "4" 714 | }, 715 | "engines": { 716 | "node": ">= 14" 717 | } 718 | }, 719 | "node_modules/ieee754": { 720 | "version": "1.2.1", 721 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 722 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", 723 | "dev": true, 724 | "funding": [ 725 | { 726 | "type": "github", 727 | "url": "https://github.com/sponsors/feross" 728 | }, 729 | { 730 | "type": "patreon", 731 | "url": "https://www.patreon.com/feross" 732 | }, 733 | { 734 | "type": "consulting", 735 | "url": "https://feross.org/support" 736 | } 737 | ] 738 | }, 739 | "node_modules/immediate": { 740 | "version": "3.0.6", 741 | "resolved": "https://registry.npmjs.org/immediate/-/immediate-3.0.6.tgz", 742 | "integrity": "sha512-XXOFtyqDjNDAQxVfYxuF7g9Il/IbWmmlQg2MYKOH8ExIT1qg6xc4zyS3HaEEATgs1btfzxq15ciUiY7gjSXRGQ==", 743 | "dev": true 744 | }, 745 | "node_modules/inflight": { 746 | "version": "1.0.6", 747 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 748 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 749 | "deprecated": "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.", 750 | "dev": true, 751 | "dependencies": { 752 | "once": "^1.3.0", 753 | "wrappy": "1" 754 | } 755 | }, 756 | "node_modules/inherits": { 757 | "version": "2.0.4", 758 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 759 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 760 | "dev": true 761 | }, 762 | "node_modules/is-binary-path": { 763 | "version": "2.1.0", 764 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 765 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 766 | "dev": true, 767 | "dependencies": { 768 | "binary-extensions": "^2.0.0" 769 | }, 770 | "engines": { 771 | "node": ">=8" 772 | } 773 | }, 774 | "node_modules/is-core-module": { 775 | "version": "2.15.1", 776 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.15.1.tgz", 777 | "integrity": "sha512-z0vtXSwucUJtANQWldhbtbt7BnL0vxiFjIdDLAatwhDYty2bad6s+rijD6Ri4YuYJubLzIJLUidCh09e1djEVQ==", 778 | "dev": true, 779 | "dependencies": { 780 | "hasown": "^2.0.2" 781 | }, 782 | "engines": { 783 | "node": ">= 0.4" 784 | }, 785 | "funding": { 786 | "url": "https://github.com/sponsors/ljharb" 787 | } 788 | }, 789 | "node_modules/is-extglob": { 790 | "version": "2.1.1", 791 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 792 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 793 | "dev": true, 794 | "engines": { 795 | "node": ">=0.10.0" 796 | } 797 | }, 798 | "node_modules/is-fullwidth-code-point": { 799 | "version": "3.0.0", 800 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 801 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 802 | "dev": true, 803 | "engines": { 804 | "node": ">=8" 805 | } 806 | }, 807 | "node_modules/is-glob": { 808 | "version": "4.0.3", 809 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 810 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 811 | "dev": true, 812 | "dependencies": { 813 | "is-extglob": "^2.1.1" 814 | }, 815 | "engines": { 816 | "node": ">=0.10.0" 817 | } 818 | }, 819 | "node_modules/is-interactive": { 820 | "version": "2.0.0", 821 | "resolved": "https://registry.npmjs.org/is-interactive/-/is-interactive-2.0.0.tgz", 822 | "integrity": "sha512-qP1vozQRI+BMOPcjFzrjXuQvdak2pHNUMZoeG2eRbiSqyvbEf/wQtEOTOX1guk6E3t36RkaqiSt8A/6YElNxLQ==", 823 | "dev": true, 824 | "engines": { 825 | "node": ">=12" 826 | }, 827 | "funding": { 828 | "url": "https://github.com/sponsors/sindresorhus" 829 | } 830 | }, 831 | "node_modules/is-number": { 832 | "version": "7.0.0", 833 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 834 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 835 | "dev": true, 836 | "engines": { 837 | "node": ">=0.12.0" 838 | } 839 | }, 840 | "node_modules/is-plain-obj": { 841 | "version": "2.1.0", 842 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 843 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 844 | "dev": true, 845 | "engines": { 846 | "node": ">=8" 847 | } 848 | }, 849 | "node_modules/is-unicode-supported": { 850 | "version": "0.1.0", 851 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 852 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 853 | "dev": true, 854 | "engines": { 855 | "node": ">=10" 856 | }, 857 | "funding": { 858 | "url": "https://github.com/sponsors/sindresorhus" 859 | } 860 | }, 861 | "node_modules/isarray": { 862 | "version": "1.0.0", 863 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 864 | "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==", 865 | "dev": true 866 | }, 867 | "node_modules/js-tokens": { 868 | "version": "4.0.0", 869 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 870 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 871 | "dev": true 872 | }, 873 | "node_modules/js-yaml": { 874 | "version": "4.1.0", 875 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 876 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 877 | "dev": true, 878 | "dependencies": { 879 | "argparse": "^2.0.1" 880 | }, 881 | "bin": { 882 | "js-yaml": "bin/js-yaml.js" 883 | } 884 | }, 885 | "node_modules/jszip": { 886 | "version": "3.10.1", 887 | "resolved": "https://registry.npmjs.org/jszip/-/jszip-3.10.1.tgz", 888 | "integrity": "sha512-xXDvecyTpGLrqFrvkrUSoxxfJI5AH7U8zxxtVclpsUtMCq4JQ290LY8AW5c7Ggnr/Y/oK+bQMbqK2qmtk3pN4g==", 889 | "dev": true, 890 | "dependencies": { 891 | "lie": "~3.3.0", 892 | "pako": "~1.0.2", 893 | "readable-stream": "~2.3.6", 894 | "setimmediate": "^1.0.5" 895 | } 896 | }, 897 | "node_modules/lie": { 898 | "version": "3.3.0", 899 | "resolved": "https://registry.npmjs.org/lie/-/lie-3.3.0.tgz", 900 | "integrity": "sha512-UaiMJzeWRlEujzAuw5LokY1L5ecNQYZKfmyZ9L7wDHb/p5etKaxXhohBcrw0EYby+G/NA52vRSN4N39dxHAIwQ==", 901 | "dev": true, 902 | "dependencies": { 903 | "immediate": "~3.0.5" 904 | } 905 | }, 906 | "node_modules/locate-path": { 907 | "version": "6.0.0", 908 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 909 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 910 | "dev": true, 911 | "dependencies": { 912 | "p-locate": "^5.0.0" 913 | }, 914 | "engines": { 915 | "node": ">=10" 916 | }, 917 | "funding": { 918 | "url": "https://github.com/sponsors/sindresorhus" 919 | } 920 | }, 921 | "node_modules/log-symbols": { 922 | "version": "4.1.0", 923 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 924 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 925 | "dev": true, 926 | "dependencies": { 927 | "chalk": "^4.1.0", 928 | "is-unicode-supported": "^0.1.0" 929 | }, 930 | "engines": { 931 | "node": ">=10" 932 | }, 933 | "funding": { 934 | "url": "https://github.com/sponsors/sindresorhus" 935 | } 936 | }, 937 | "node_modules/mimic-fn": { 938 | "version": "2.1.0", 939 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 940 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 941 | "dev": true, 942 | "engines": { 943 | "node": ">=6" 944 | } 945 | }, 946 | "node_modules/minimatch": { 947 | "version": "5.1.6", 948 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", 949 | "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", 950 | "dev": true, 951 | "dependencies": { 952 | "brace-expansion": "^2.0.1" 953 | }, 954 | "engines": { 955 | "node": ">=10" 956 | } 957 | }, 958 | "node_modules/minimist": { 959 | "version": "1.2.8", 960 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 961 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 962 | "dev": true, 963 | "funding": { 964 | "url": "https://github.com/sponsors/ljharb" 965 | } 966 | }, 967 | "node_modules/mkdirp": { 968 | "version": "1.0.4", 969 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 970 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 971 | "dev": true, 972 | "bin": { 973 | "mkdirp": "bin/cmd.js" 974 | }, 975 | "engines": { 976 | "node": ">=10" 977 | } 978 | }, 979 | "node_modules/mocha": { 980 | "version": "10.8.2", 981 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.8.2.tgz", 982 | "integrity": "sha512-VZlYo/WE8t1tstuRmqgeyBgCbJc/lEdopaa+axcKzTBJ+UIdlAB9XnmvTCAH4pwR4ElNInaedhEBmZD8iCSVEg==", 983 | "dev": true, 984 | "dependencies": { 985 | "ansi-colors": "^4.1.3", 986 | "browser-stdout": "^1.3.1", 987 | "chokidar": "^3.5.3", 988 | "debug": "^4.3.5", 989 | "diff": "^5.2.0", 990 | "escape-string-regexp": "^4.0.0", 991 | "find-up": "^5.0.0", 992 | "glob": "^8.1.0", 993 | "he": "^1.2.0", 994 | "js-yaml": "^4.1.0", 995 | "log-symbols": "^4.1.0", 996 | "minimatch": "^5.1.6", 997 | "ms": "^2.1.3", 998 | "serialize-javascript": "^6.0.2", 999 | "strip-json-comments": "^3.1.1", 1000 | "supports-color": "^8.1.1", 1001 | "workerpool": "^6.5.1", 1002 | "yargs": "^16.2.0", 1003 | "yargs-parser": "^20.2.9", 1004 | "yargs-unparser": "^2.0.0" 1005 | }, 1006 | "bin": { 1007 | "_mocha": "bin/_mocha", 1008 | "mocha": "bin/mocha.js" 1009 | }, 1010 | "engines": { 1011 | "node": ">= 14.0.0" 1012 | } 1013 | }, 1014 | "node_modules/ms": { 1015 | "version": "2.1.3", 1016 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1017 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1018 | "dev": true 1019 | }, 1020 | "node_modules/normalize-path": { 1021 | "version": "3.0.0", 1022 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1023 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1024 | "dev": true, 1025 | "engines": { 1026 | "node": ">=0.10.0" 1027 | } 1028 | }, 1029 | "node_modules/once": { 1030 | "version": "1.4.0", 1031 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1032 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1033 | "dev": true, 1034 | "dependencies": { 1035 | "wrappy": "1" 1036 | } 1037 | }, 1038 | "node_modules/onetime": { 1039 | "version": "5.1.2", 1040 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 1041 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 1042 | "dev": true, 1043 | "dependencies": { 1044 | "mimic-fn": "^2.1.0" 1045 | }, 1046 | "engines": { 1047 | "node": ">=6" 1048 | }, 1049 | "funding": { 1050 | "url": "https://github.com/sponsors/sindresorhus" 1051 | } 1052 | }, 1053 | "node_modules/ora": { 1054 | "version": "7.0.1", 1055 | "resolved": "https://registry.npmjs.org/ora/-/ora-7.0.1.tgz", 1056 | "integrity": "sha512-0TUxTiFJWv+JnjWm4o9yvuskpEJLXTcng8MJuKd+SzAzp2o+OP3HWqNhB4OdJRt1Vsd9/mR0oyaEYlOnL7XIRw==", 1057 | "dev": true, 1058 | "dependencies": { 1059 | "chalk": "^5.3.0", 1060 | "cli-cursor": "^4.0.0", 1061 | "cli-spinners": "^2.9.0", 1062 | "is-interactive": "^2.0.0", 1063 | "is-unicode-supported": "^1.3.0", 1064 | "log-symbols": "^5.1.0", 1065 | "stdin-discarder": "^0.1.0", 1066 | "string-width": "^6.1.0", 1067 | "strip-ansi": "^7.1.0" 1068 | }, 1069 | "engines": { 1070 | "node": ">=16" 1071 | }, 1072 | "funding": { 1073 | "url": "https://github.com/sponsors/sindresorhus" 1074 | } 1075 | }, 1076 | "node_modules/ora/node_modules/chalk": { 1077 | "version": "5.3.0", 1078 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.3.0.tgz", 1079 | "integrity": "sha512-dLitG79d+GV1Nb/VYcCDFivJeK1hiukt9QjRNVOsUtTy1rR1YJsmpGGTZ3qJos+uw7WmWF4wUwBd9jxjocFC2w==", 1080 | "dev": true, 1081 | "engines": { 1082 | "node": "^12.17.0 || ^14.13 || >=16.0.0" 1083 | }, 1084 | "funding": { 1085 | "url": "https://github.com/chalk/chalk?sponsor=1" 1086 | } 1087 | }, 1088 | "node_modules/ora/node_modules/is-unicode-supported": { 1089 | "version": "1.3.0", 1090 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-1.3.0.tgz", 1091 | "integrity": "sha512-43r2mRvz+8JRIKnWJ+3j8JtjRKZ6GmjzfaE/qiBJnikNnYv/6bagRJ1kUhNk8R5EX/GkobD+r+sfxCPJsiKBLQ==", 1092 | "dev": true, 1093 | "engines": { 1094 | "node": ">=12" 1095 | }, 1096 | "funding": { 1097 | "url": "https://github.com/sponsors/sindresorhus" 1098 | } 1099 | }, 1100 | "node_modules/ora/node_modules/log-symbols": { 1101 | "version": "5.1.0", 1102 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-5.1.0.tgz", 1103 | "integrity": "sha512-l0x2DvrW294C9uDCoQe1VSU4gf529FkSZ6leBl4TiqZH/e+0R7hSfHQBNut2mNygDgHwvYHfFLn6Oxb3VWj2rA==", 1104 | "dev": true, 1105 | "dependencies": { 1106 | "chalk": "^5.0.0", 1107 | "is-unicode-supported": "^1.1.0" 1108 | }, 1109 | "engines": { 1110 | "node": ">=12" 1111 | }, 1112 | "funding": { 1113 | "url": "https://github.com/sponsors/sindresorhus" 1114 | } 1115 | }, 1116 | "node_modules/p-limit": { 1117 | "version": "3.1.0", 1118 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1119 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1120 | "dev": true, 1121 | "dependencies": { 1122 | "yocto-queue": "^0.1.0" 1123 | }, 1124 | "engines": { 1125 | "node": ">=10" 1126 | }, 1127 | "funding": { 1128 | "url": "https://github.com/sponsors/sindresorhus" 1129 | } 1130 | }, 1131 | "node_modules/p-locate": { 1132 | "version": "5.0.0", 1133 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1134 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1135 | "dev": true, 1136 | "dependencies": { 1137 | "p-limit": "^3.0.2" 1138 | }, 1139 | "engines": { 1140 | "node": ">=10" 1141 | }, 1142 | "funding": { 1143 | "url": "https://github.com/sponsors/sindresorhus" 1144 | } 1145 | }, 1146 | "node_modules/pako": { 1147 | "version": "1.0.11", 1148 | "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.11.tgz", 1149 | "integrity": "sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw==", 1150 | "dev": true 1151 | }, 1152 | "node_modules/path-exists": { 1153 | "version": "4.0.0", 1154 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1155 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1156 | "dev": true, 1157 | "engines": { 1158 | "node": ">=8" 1159 | } 1160 | }, 1161 | "node_modules/path-is-absolute": { 1162 | "version": "1.0.1", 1163 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1164 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1165 | "dev": true, 1166 | "engines": { 1167 | "node": ">=0.10.0" 1168 | } 1169 | }, 1170 | "node_modules/path-parse": { 1171 | "version": "1.0.7", 1172 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1173 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1174 | "dev": true 1175 | }, 1176 | "node_modules/picocolors": { 1177 | "version": "1.1.1", 1178 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz", 1179 | "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==", 1180 | "dev": true 1181 | }, 1182 | "node_modules/picomatch": { 1183 | "version": "2.3.1", 1184 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1185 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1186 | "dev": true, 1187 | "engines": { 1188 | "node": ">=8.6" 1189 | }, 1190 | "funding": { 1191 | "url": "https://github.com/sponsors/jonschlinkert" 1192 | } 1193 | }, 1194 | "node_modules/process-nextick-args": { 1195 | "version": "2.0.1", 1196 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 1197 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 1198 | "dev": true 1199 | }, 1200 | "node_modules/randombytes": { 1201 | "version": "2.1.0", 1202 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1203 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1204 | "dev": true, 1205 | "dependencies": { 1206 | "safe-buffer": "^5.1.0" 1207 | } 1208 | }, 1209 | "node_modules/readable-stream": { 1210 | "version": "2.3.8", 1211 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", 1212 | "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", 1213 | "dev": true, 1214 | "dependencies": { 1215 | "core-util-is": "~1.0.0", 1216 | "inherits": "~2.0.3", 1217 | "isarray": "~1.0.0", 1218 | "process-nextick-args": "~2.0.0", 1219 | "safe-buffer": "~5.1.1", 1220 | "string_decoder": "~1.1.1", 1221 | "util-deprecate": "~1.0.1" 1222 | } 1223 | }, 1224 | "node_modules/readdirp": { 1225 | "version": "3.6.0", 1226 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1227 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1228 | "dev": true, 1229 | "dependencies": { 1230 | "picomatch": "^2.2.1" 1231 | }, 1232 | "engines": { 1233 | "node": ">=8.10.0" 1234 | } 1235 | }, 1236 | "node_modules/require-directory": { 1237 | "version": "2.1.1", 1238 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1239 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 1240 | "dev": true, 1241 | "engines": { 1242 | "node": ">=0.10.0" 1243 | } 1244 | }, 1245 | "node_modules/resolve": { 1246 | "version": "1.22.8", 1247 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", 1248 | "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", 1249 | "dev": true, 1250 | "dependencies": { 1251 | "is-core-module": "^2.13.0", 1252 | "path-parse": "^1.0.7", 1253 | "supports-preserve-symlinks-flag": "^1.0.0" 1254 | }, 1255 | "bin": { 1256 | "resolve": "bin/resolve" 1257 | }, 1258 | "funding": { 1259 | "url": "https://github.com/sponsors/ljharb" 1260 | } 1261 | }, 1262 | "node_modules/restore-cursor": { 1263 | "version": "4.0.0", 1264 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-4.0.0.tgz", 1265 | "integrity": "sha512-I9fPXU9geO9bHOt9pHHOhOkYerIMsmVaWB0rA2AI9ERh/+x/i7MV5HKBNrg+ljO5eoPVgCcnFuRjJ9uH6I/3eg==", 1266 | "dev": true, 1267 | "dependencies": { 1268 | "onetime": "^5.1.0", 1269 | "signal-exit": "^3.0.2" 1270 | }, 1271 | "engines": { 1272 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 1273 | }, 1274 | "funding": { 1275 | "url": "https://github.com/sponsors/sindresorhus" 1276 | } 1277 | }, 1278 | "node_modules/safe-buffer": { 1279 | "version": "5.1.2", 1280 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1281 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1282 | "dev": true 1283 | }, 1284 | "node_modules/semver": { 1285 | "version": "7.6.3", 1286 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 1287 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 1288 | "dev": true, 1289 | "bin": { 1290 | "semver": "bin/semver.js" 1291 | }, 1292 | "engines": { 1293 | "node": ">=10" 1294 | } 1295 | }, 1296 | "node_modules/serialize-javascript": { 1297 | "version": "6.0.2", 1298 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.2.tgz", 1299 | "integrity": "sha512-Saa1xPByTTq2gdeFZYLLo+RFE35NHZkAbqZeWNd3BpzppeVisAqpDjcp8dyf6uIvEqJRd46jemmyA4iFIeVk8g==", 1300 | "dev": true, 1301 | "dependencies": { 1302 | "randombytes": "^2.1.0" 1303 | } 1304 | }, 1305 | "node_modules/setimmediate": { 1306 | "version": "1.0.5", 1307 | "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", 1308 | "integrity": "sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA==", 1309 | "dev": true 1310 | }, 1311 | "node_modules/signal-exit": { 1312 | "version": "3.0.7", 1313 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 1314 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 1315 | "dev": true 1316 | }, 1317 | "node_modules/sprintf-js": { 1318 | "version": "1.0.3", 1319 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1320 | "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", 1321 | "dev": true 1322 | }, 1323 | "node_modules/stdin-discarder": { 1324 | "version": "0.1.0", 1325 | "resolved": "https://registry.npmjs.org/stdin-discarder/-/stdin-discarder-0.1.0.tgz", 1326 | "integrity": "sha512-xhV7w8S+bUwlPTb4bAOUQhv8/cSS5offJuX8GQGq32ONF0ZtDWKfkdomM3HMRA+LhX6um/FZ0COqlwsjD53LeQ==", 1327 | "dev": true, 1328 | "dependencies": { 1329 | "bl": "^5.0.0" 1330 | }, 1331 | "engines": { 1332 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 1333 | }, 1334 | "funding": { 1335 | "url": "https://github.com/sponsors/sindresorhus" 1336 | } 1337 | }, 1338 | "node_modules/string_decoder": { 1339 | "version": "1.1.1", 1340 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 1341 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1342 | "dev": true, 1343 | "dependencies": { 1344 | "safe-buffer": "~5.1.0" 1345 | } 1346 | }, 1347 | "node_modules/string-width": { 1348 | "version": "6.1.0", 1349 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-6.1.0.tgz", 1350 | "integrity": "sha512-k01swCJAgQmuADB0YIc+7TuatfNvTBVOoaUWJjTB9R4VJzR5vNWzf5t42ESVZFPS8xTySF7CAdV4t/aaIm3UnQ==", 1351 | "dev": true, 1352 | "dependencies": { 1353 | "eastasianwidth": "^0.2.0", 1354 | "emoji-regex": "^10.2.1", 1355 | "strip-ansi": "^7.0.1" 1356 | }, 1357 | "engines": { 1358 | "node": ">=16" 1359 | }, 1360 | "funding": { 1361 | "url": "https://github.com/sponsors/sindresorhus" 1362 | } 1363 | }, 1364 | "node_modules/strip-ansi": { 1365 | "version": "7.1.0", 1366 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", 1367 | "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", 1368 | "dev": true, 1369 | "dependencies": { 1370 | "ansi-regex": "^6.0.1" 1371 | }, 1372 | "engines": { 1373 | "node": ">=12" 1374 | }, 1375 | "funding": { 1376 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 1377 | } 1378 | }, 1379 | "node_modules/strip-json-comments": { 1380 | "version": "3.1.1", 1381 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1382 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1383 | "dev": true, 1384 | "engines": { 1385 | "node": ">=8" 1386 | }, 1387 | "funding": { 1388 | "url": "https://github.com/sponsors/sindresorhus" 1389 | } 1390 | }, 1391 | "node_modules/supports-color": { 1392 | "version": "8.1.1", 1393 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 1394 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 1395 | "dev": true, 1396 | "dependencies": { 1397 | "has-flag": "^4.0.0" 1398 | }, 1399 | "engines": { 1400 | "node": ">=10" 1401 | }, 1402 | "funding": { 1403 | "url": "https://github.com/chalk/supports-color?sponsor=1" 1404 | } 1405 | }, 1406 | "node_modules/supports-preserve-symlinks-flag": { 1407 | "version": "1.0.0", 1408 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1409 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1410 | "dev": true, 1411 | "engines": { 1412 | "node": ">= 0.4" 1413 | }, 1414 | "funding": { 1415 | "url": "https://github.com/sponsors/ljharb" 1416 | } 1417 | }, 1418 | "node_modules/to-regex-range": { 1419 | "version": "5.0.1", 1420 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1421 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1422 | "dev": true, 1423 | "dependencies": { 1424 | "is-number": "^7.0.0" 1425 | }, 1426 | "engines": { 1427 | "node": ">=8.0" 1428 | } 1429 | }, 1430 | "node_modules/tslib": { 1431 | "version": "1.14.1", 1432 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 1433 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 1434 | "dev": true 1435 | }, 1436 | "node_modules/tslint": { 1437 | "version": "6.1.3", 1438 | "resolved": "https://registry.npmjs.org/tslint/-/tslint-6.1.3.tgz", 1439 | "integrity": "sha512-IbR4nkT96EQOvKE2PW/djGz8iGNeJ4rF2mBfiYaR/nvUWYKJhLwimoJKgjIFEIDibBtOevj7BqCRL4oHeWWUCg==", 1440 | "deprecated": "TSLint has been deprecated in favor of ESLint. Please see https://github.com/palantir/tslint/issues/4534 for more information.", 1441 | "dev": true, 1442 | "dependencies": { 1443 | "@babel/code-frame": "^7.0.0", 1444 | "builtin-modules": "^1.1.1", 1445 | "chalk": "^2.3.0", 1446 | "commander": "^2.12.1", 1447 | "diff": "^4.0.1", 1448 | "glob": "^7.1.1", 1449 | "js-yaml": "^3.13.1", 1450 | "minimatch": "^3.0.4", 1451 | "mkdirp": "^0.5.3", 1452 | "resolve": "^1.3.2", 1453 | "semver": "^5.3.0", 1454 | "tslib": "^1.13.0", 1455 | "tsutils": "^2.29.0" 1456 | }, 1457 | "bin": { 1458 | "tslint": "bin/tslint" 1459 | }, 1460 | "engines": { 1461 | "node": ">=4.8.0" 1462 | }, 1463 | "peerDependencies": { 1464 | "typescript": ">=2.3.0-dev || >=2.4.0-dev || >=2.5.0-dev || >=2.6.0-dev || >=2.7.0-dev || >=2.8.0-dev || >=2.9.0-dev || >=3.0.0-dev || >= 3.1.0-dev || >= 3.2.0-dev || >= 4.0.0-dev" 1465 | } 1466 | }, 1467 | "node_modules/tslint/node_modules/ansi-styles": { 1468 | "version": "3.2.1", 1469 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1470 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1471 | "dev": true, 1472 | "dependencies": { 1473 | "color-convert": "^1.9.0" 1474 | }, 1475 | "engines": { 1476 | "node": ">=4" 1477 | } 1478 | }, 1479 | "node_modules/tslint/node_modules/argparse": { 1480 | "version": "1.0.10", 1481 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 1482 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 1483 | "dev": true, 1484 | "dependencies": { 1485 | "sprintf-js": "~1.0.2" 1486 | } 1487 | }, 1488 | "node_modules/tslint/node_modules/brace-expansion": { 1489 | "version": "1.1.11", 1490 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1491 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1492 | "dev": true, 1493 | "dependencies": { 1494 | "balanced-match": "^1.0.0", 1495 | "concat-map": "0.0.1" 1496 | } 1497 | }, 1498 | "node_modules/tslint/node_modules/chalk": { 1499 | "version": "2.4.2", 1500 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1501 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1502 | "dev": true, 1503 | "dependencies": { 1504 | "ansi-styles": "^3.2.1", 1505 | "escape-string-regexp": "^1.0.5", 1506 | "supports-color": "^5.3.0" 1507 | }, 1508 | "engines": { 1509 | "node": ">=4" 1510 | } 1511 | }, 1512 | "node_modules/tslint/node_modules/color-convert": { 1513 | "version": "1.9.3", 1514 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1515 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1516 | "dev": true, 1517 | "dependencies": { 1518 | "color-name": "1.1.3" 1519 | } 1520 | }, 1521 | "node_modules/tslint/node_modules/color-name": { 1522 | "version": "1.1.3", 1523 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1524 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 1525 | "dev": true 1526 | }, 1527 | "node_modules/tslint/node_modules/diff": { 1528 | "version": "4.0.2", 1529 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 1530 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 1531 | "dev": true, 1532 | "engines": { 1533 | "node": ">=0.3.1" 1534 | } 1535 | }, 1536 | "node_modules/tslint/node_modules/escape-string-regexp": { 1537 | "version": "1.0.5", 1538 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1539 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 1540 | "dev": true, 1541 | "engines": { 1542 | "node": ">=0.8.0" 1543 | } 1544 | }, 1545 | "node_modules/tslint/node_modules/glob": { 1546 | "version": "7.2.3", 1547 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 1548 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 1549 | "deprecated": "Glob versions prior to v9 are no longer supported", 1550 | "dev": true, 1551 | "dependencies": { 1552 | "fs.realpath": "^1.0.0", 1553 | "inflight": "^1.0.4", 1554 | "inherits": "2", 1555 | "minimatch": "^3.1.1", 1556 | "once": "^1.3.0", 1557 | "path-is-absolute": "^1.0.0" 1558 | }, 1559 | "engines": { 1560 | "node": "*" 1561 | }, 1562 | "funding": { 1563 | "url": "https://github.com/sponsors/isaacs" 1564 | } 1565 | }, 1566 | "node_modules/tslint/node_modules/has-flag": { 1567 | "version": "3.0.0", 1568 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1569 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 1570 | "dev": true, 1571 | "engines": { 1572 | "node": ">=4" 1573 | } 1574 | }, 1575 | "node_modules/tslint/node_modules/js-yaml": { 1576 | "version": "3.14.1", 1577 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 1578 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 1579 | "dev": true, 1580 | "dependencies": { 1581 | "argparse": "^1.0.7", 1582 | "esprima": "^4.0.0" 1583 | }, 1584 | "bin": { 1585 | "js-yaml": "bin/js-yaml.js" 1586 | } 1587 | }, 1588 | "node_modules/tslint/node_modules/minimatch": { 1589 | "version": "3.1.2", 1590 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1591 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1592 | "dev": true, 1593 | "dependencies": { 1594 | "brace-expansion": "^1.1.7" 1595 | }, 1596 | "engines": { 1597 | "node": "*" 1598 | } 1599 | }, 1600 | "node_modules/tslint/node_modules/mkdirp": { 1601 | "version": "0.5.6", 1602 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", 1603 | "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", 1604 | "dev": true, 1605 | "dependencies": { 1606 | "minimist": "^1.2.6" 1607 | }, 1608 | "bin": { 1609 | "mkdirp": "bin/cmd.js" 1610 | } 1611 | }, 1612 | "node_modules/tslint/node_modules/semver": { 1613 | "version": "5.7.2", 1614 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", 1615 | "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", 1616 | "dev": true, 1617 | "bin": { 1618 | "semver": "bin/semver" 1619 | } 1620 | }, 1621 | "node_modules/tslint/node_modules/supports-color": { 1622 | "version": "5.5.0", 1623 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1624 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1625 | "dev": true, 1626 | "dependencies": { 1627 | "has-flag": "^3.0.0" 1628 | }, 1629 | "engines": { 1630 | "node": ">=4" 1631 | } 1632 | }, 1633 | "node_modules/tsutils": { 1634 | "version": "2.29.0", 1635 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-2.29.0.tgz", 1636 | "integrity": "sha512-g5JVHCIJwzfISaXpXE1qvNalca5Jwob6FjI4AoPlqMusJ6ftFE7IkkFoMhVLRgK+4Kx3gkzb8UZK5t5yTTvEmA==", 1637 | "dev": true, 1638 | "dependencies": { 1639 | "tslib": "^1.8.1" 1640 | }, 1641 | "peerDependencies": { 1642 | "typescript": ">=2.1.0 || >=2.1.0-dev || >=2.2.0-dev || >=2.3.0-dev || >=2.4.0-dev || >=2.5.0-dev || >=2.6.0-dev || >=2.7.0-dev || >=2.8.0-dev || >=2.9.0-dev || >= 3.0.0-dev || >= 3.1.0-dev" 1643 | } 1644 | }, 1645 | "node_modules/typescript": { 1646 | "version": "5.6.3", 1647 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.6.3.tgz", 1648 | "integrity": "sha512-hjcS1mhfuyi4WW8IWtjP7brDrG2cuDZukyrYrSauoXGNgx0S7zceP07adYkJycEr56BOUTNPzbInooiN3fn1qw==", 1649 | "dev": true, 1650 | "bin": { 1651 | "tsc": "bin/tsc", 1652 | "tsserver": "bin/tsserver" 1653 | }, 1654 | "engines": { 1655 | "node": ">=14.17" 1656 | } 1657 | }, 1658 | "node_modules/undici-types": { 1659 | "version": "6.19.8", 1660 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-6.19.8.tgz", 1661 | "integrity": "sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==", 1662 | "dev": true 1663 | }, 1664 | "node_modules/util-deprecate": { 1665 | "version": "1.0.2", 1666 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1667 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", 1668 | "dev": true 1669 | }, 1670 | "node_modules/workerpool": { 1671 | "version": "6.5.1", 1672 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.5.1.tgz", 1673 | "integrity": "sha512-Fs4dNYcsdpYSAfVxhnl1L5zTksjvOJxtC5hzMNl+1t9B8hTJTdKDyZ5ju7ztgPy+ft9tBFXoOlDNiOT9WUXZlA==", 1674 | "dev": true 1675 | }, 1676 | "node_modules/wrap-ansi": { 1677 | "version": "7.0.0", 1678 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1679 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1680 | "dev": true, 1681 | "dependencies": { 1682 | "ansi-styles": "^4.0.0", 1683 | "string-width": "^4.1.0", 1684 | "strip-ansi": "^6.0.0" 1685 | }, 1686 | "engines": { 1687 | "node": ">=10" 1688 | }, 1689 | "funding": { 1690 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 1691 | } 1692 | }, 1693 | "node_modules/wrap-ansi/node_modules/ansi-regex": { 1694 | "version": "5.0.1", 1695 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1696 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1697 | "dev": true, 1698 | "engines": { 1699 | "node": ">=8" 1700 | } 1701 | }, 1702 | "node_modules/wrap-ansi/node_modules/emoji-regex": { 1703 | "version": "8.0.0", 1704 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1705 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1706 | "dev": true 1707 | }, 1708 | "node_modules/wrap-ansi/node_modules/string-width": { 1709 | "version": "4.2.3", 1710 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1711 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1712 | "dev": true, 1713 | "dependencies": { 1714 | "emoji-regex": "^8.0.0", 1715 | "is-fullwidth-code-point": "^3.0.0", 1716 | "strip-ansi": "^6.0.1" 1717 | }, 1718 | "engines": { 1719 | "node": ">=8" 1720 | } 1721 | }, 1722 | "node_modules/wrap-ansi/node_modules/strip-ansi": { 1723 | "version": "6.0.1", 1724 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1725 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1726 | "dev": true, 1727 | "dependencies": { 1728 | "ansi-regex": "^5.0.1" 1729 | }, 1730 | "engines": { 1731 | "node": ">=8" 1732 | } 1733 | }, 1734 | "node_modules/wrappy": { 1735 | "version": "1.0.2", 1736 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1737 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 1738 | "dev": true 1739 | }, 1740 | "node_modules/y18n": { 1741 | "version": "5.0.8", 1742 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 1743 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 1744 | "dev": true, 1745 | "engines": { 1746 | "node": ">=10" 1747 | } 1748 | }, 1749 | "node_modules/yargs": { 1750 | "version": "16.2.0", 1751 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 1752 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 1753 | "dev": true, 1754 | "dependencies": { 1755 | "cliui": "^7.0.2", 1756 | "escalade": "^3.1.1", 1757 | "get-caller-file": "^2.0.5", 1758 | "require-directory": "^2.1.1", 1759 | "string-width": "^4.2.0", 1760 | "y18n": "^5.0.5", 1761 | "yargs-parser": "^20.2.2" 1762 | }, 1763 | "engines": { 1764 | "node": ">=10" 1765 | } 1766 | }, 1767 | "node_modules/yargs-parser": { 1768 | "version": "20.2.9", 1769 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", 1770 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", 1771 | "dev": true, 1772 | "engines": { 1773 | "node": ">=10" 1774 | } 1775 | }, 1776 | "node_modules/yargs-unparser": { 1777 | "version": "2.0.0", 1778 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 1779 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 1780 | "dev": true, 1781 | "dependencies": { 1782 | "camelcase": "^6.0.0", 1783 | "decamelize": "^4.0.0", 1784 | "flat": "^5.0.2", 1785 | "is-plain-obj": "^2.1.0" 1786 | }, 1787 | "engines": { 1788 | "node": ">=10" 1789 | } 1790 | }, 1791 | "node_modules/yargs/node_modules/ansi-regex": { 1792 | "version": "5.0.1", 1793 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1794 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1795 | "dev": true, 1796 | "engines": { 1797 | "node": ">=8" 1798 | } 1799 | }, 1800 | "node_modules/yargs/node_modules/emoji-regex": { 1801 | "version": "8.0.0", 1802 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1803 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1804 | "dev": true 1805 | }, 1806 | "node_modules/yargs/node_modules/string-width": { 1807 | "version": "4.2.3", 1808 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1809 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1810 | "dev": true, 1811 | "dependencies": { 1812 | "emoji-regex": "^8.0.0", 1813 | "is-fullwidth-code-point": "^3.0.0", 1814 | "strip-ansi": "^6.0.1" 1815 | }, 1816 | "engines": { 1817 | "node": ">=8" 1818 | } 1819 | }, 1820 | "node_modules/yargs/node_modules/strip-ansi": { 1821 | "version": "6.0.1", 1822 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1823 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1824 | "dev": true, 1825 | "dependencies": { 1826 | "ansi-regex": "^5.0.1" 1827 | }, 1828 | "engines": { 1829 | "node": ">=8" 1830 | } 1831 | }, 1832 | "node_modules/yocto-queue": { 1833 | "version": "0.1.0", 1834 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1835 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1836 | "dev": true, 1837 | "engines": { 1838 | "node": ">=10" 1839 | }, 1840 | "funding": { 1841 | "url": "https://github.com/sponsors/sindresorhus" 1842 | } 1843 | } 1844 | }, 1845 | "dependencies": { 1846 | "@babel/code-frame": { 1847 | "version": "7.26.2", 1848 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.26.2.tgz", 1849 | "integrity": "sha512-RJlIHRueQgwWitWgF8OdFYGZX328Ax5BCemNGlqHfplnRT9ESi8JkFlvaVYbS+UubVY6dpv87Fs2u5M29iNFVQ==", 1850 | "dev": true, 1851 | "requires": { 1852 | "@babel/helper-validator-identifier": "^7.25.9", 1853 | "js-tokens": "^4.0.0", 1854 | "picocolors": "^1.0.0" 1855 | } 1856 | }, 1857 | "@babel/helper-validator-identifier": { 1858 | "version": "7.25.9", 1859 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.9.tgz", 1860 | "integrity": "sha512-Ed61U6XJc3CVRfkERJWDz4dJwKe7iLmmJsbOGu9wSloNSFttHV0I8g6UAgb7qnK5ly5bGLPd4oXZlxCdANBOWQ==", 1861 | "dev": true 1862 | }, 1863 | "@types/glob": { 1864 | "version": "8.1.0", 1865 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-8.1.0.tgz", 1866 | "integrity": "sha512-IO+MJPVhoqz+28h1qLAcBEH2+xHMK6MTyHJc7MTnnYb6wsoLR29POVGJ7LycmVXIqyy/4/2ShP5sUwTXuOwb/w==", 1867 | "dev": true, 1868 | "requires": { 1869 | "@types/minimatch": "^5.1.2", 1870 | "@types/node": "*" 1871 | } 1872 | }, 1873 | "@types/minimatch": { 1874 | "version": "5.1.2", 1875 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-5.1.2.tgz", 1876 | "integrity": "sha512-K0VQKziLUWkVKiRVrx4a40iPaxTUefQmjtkQofBkYRcoaaL/8rhwDWww9qWbrgicNOgnpIsMxyNIUM4+n6dUIA==", 1877 | "dev": true 1878 | }, 1879 | "@types/mocha": { 1880 | "version": "10.0.9", 1881 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-10.0.9.tgz", 1882 | "integrity": "sha512-sicdRoWtYevwxjOHNMPTl3vSfJM6oyW8o1wXeI7uww6b6xHg8eBznQDNSGBCDJmsE8UMxP05JgZRtsKbTqt//Q==", 1883 | "dev": true 1884 | }, 1885 | "@types/node": { 1886 | "version": "20.17.6", 1887 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.17.6.tgz", 1888 | "integrity": "sha512-VEI7OdvK2wP7XHnsuXbAJnEpEkF6NjSN45QJlL4VGqZSXsnicpesdTWsg9RISeSdYd3yeRj/y3k5KGjUXYnFwQ==", 1889 | "dev": true, 1890 | "requires": { 1891 | "undici-types": "~6.19.2" 1892 | } 1893 | }, 1894 | "@types/vscode": { 1895 | "version": "1.95.0", 1896 | "resolved": "https://registry.npmjs.org/@types/vscode/-/vscode-1.95.0.tgz", 1897 | "integrity": "sha512-0LBD8TEiNbet3NvWsmn59zLzOFu/txSlGxnv5yAFHCrhG9WvAnR3IvfHzMOs2aeWqgvNjq9pO99IUw8d3n+unw==", 1898 | "dev": true 1899 | }, 1900 | "@vscode/test-electron": { 1901 | "version": "2.4.1", 1902 | "resolved": "https://registry.npmjs.org/@vscode/test-electron/-/test-electron-2.4.1.tgz", 1903 | "integrity": "sha512-Gc6EdaLANdktQ1t+zozoBVRynfIsMKMc94Svu1QreOBC8y76x4tvaK32TljrLi1LI2+PK58sDVbL7ALdqf3VRQ==", 1904 | "dev": true, 1905 | "requires": { 1906 | "http-proxy-agent": "^7.0.2", 1907 | "https-proxy-agent": "^7.0.5", 1908 | "jszip": "^3.10.1", 1909 | "ora": "^7.0.1", 1910 | "semver": "^7.6.2" 1911 | } 1912 | }, 1913 | "agent-base": { 1914 | "version": "7.1.1", 1915 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.1.tgz", 1916 | "integrity": "sha512-H0TSyFNDMomMNJQBn8wFV5YC/2eJ+VXECwOadZJT554xP6cODZHPX3H9QMQECxvrgiSOP1pHjy1sMWQVYJOUOA==", 1917 | "dev": true, 1918 | "requires": { 1919 | "debug": "^4.3.4" 1920 | } 1921 | }, 1922 | "ansi-colors": { 1923 | "version": "4.1.3", 1924 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.3.tgz", 1925 | "integrity": "sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==", 1926 | "dev": true 1927 | }, 1928 | "ansi-regex": { 1929 | "version": "6.1.0", 1930 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz", 1931 | "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==", 1932 | "dev": true 1933 | }, 1934 | "ansi-styles": { 1935 | "version": "4.3.0", 1936 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1937 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1938 | "dev": true, 1939 | "requires": { 1940 | "color-convert": "^2.0.1" 1941 | } 1942 | }, 1943 | "anymatch": { 1944 | "version": "3.1.3", 1945 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 1946 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 1947 | "dev": true, 1948 | "requires": { 1949 | "normalize-path": "^3.0.0", 1950 | "picomatch": "^2.0.4" 1951 | } 1952 | }, 1953 | "argparse": { 1954 | "version": "2.0.1", 1955 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 1956 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 1957 | "dev": true 1958 | }, 1959 | "balanced-match": { 1960 | "version": "1.0.2", 1961 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1962 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1963 | "dev": true 1964 | }, 1965 | "base64-js": { 1966 | "version": "1.5.1", 1967 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", 1968 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", 1969 | "dev": true 1970 | }, 1971 | "binary-extensions": { 1972 | "version": "2.3.0", 1973 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", 1974 | "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", 1975 | "dev": true 1976 | }, 1977 | "bl": { 1978 | "version": "5.1.0", 1979 | "resolved": "https://registry.npmjs.org/bl/-/bl-5.1.0.tgz", 1980 | "integrity": "sha512-tv1ZJHLfTDnXE6tMHv73YgSJaWR2AFuPwMntBe7XL/GBFHnT0CLnsHMogfk5+GzCDC5ZWarSCYaIGATZt9dNsQ==", 1981 | "dev": true, 1982 | "requires": { 1983 | "buffer": "^6.0.3", 1984 | "inherits": "^2.0.4", 1985 | "readable-stream": "^3.4.0" 1986 | }, 1987 | "dependencies": { 1988 | "readable-stream": { 1989 | "version": "3.6.2", 1990 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", 1991 | "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", 1992 | "dev": true, 1993 | "requires": { 1994 | "inherits": "^2.0.3", 1995 | "string_decoder": "^1.1.1", 1996 | "util-deprecate": "^1.0.1" 1997 | } 1998 | } 1999 | } 2000 | }, 2001 | "brace-expansion": { 2002 | "version": "2.0.1", 2003 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 2004 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 2005 | "dev": true, 2006 | "requires": { 2007 | "balanced-match": "^1.0.0" 2008 | } 2009 | }, 2010 | "braces": { 2011 | "version": "3.0.3", 2012 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", 2013 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", 2014 | "dev": true, 2015 | "requires": { 2016 | "fill-range": "^7.1.1" 2017 | } 2018 | }, 2019 | "browser-stdout": { 2020 | "version": "1.3.1", 2021 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 2022 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 2023 | "dev": true 2024 | }, 2025 | "buffer": { 2026 | "version": "6.0.3", 2027 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz", 2028 | "integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==", 2029 | "dev": true, 2030 | "requires": { 2031 | "base64-js": "^1.3.1", 2032 | "ieee754": "^1.2.1" 2033 | } 2034 | }, 2035 | "builtin-modules": { 2036 | "version": "1.1.1", 2037 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 2038 | "integrity": "sha512-wxXCdllwGhI2kCC0MnvTGYTMvnVZTvqgypkiTI8Pa5tcz2i6VqsqwYGgqwXji+4RgCzms6EajE4IxiUH6HH8nQ==", 2039 | "dev": true 2040 | }, 2041 | "camelcase": { 2042 | "version": "6.3.0", 2043 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 2044 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 2045 | "dev": true 2046 | }, 2047 | "chalk": { 2048 | "version": "4.1.2", 2049 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2050 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2051 | "dev": true, 2052 | "requires": { 2053 | "ansi-styles": "^4.1.0", 2054 | "supports-color": "^7.1.0" 2055 | }, 2056 | "dependencies": { 2057 | "supports-color": { 2058 | "version": "7.2.0", 2059 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2060 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2061 | "dev": true, 2062 | "requires": { 2063 | "has-flag": "^4.0.0" 2064 | } 2065 | } 2066 | } 2067 | }, 2068 | "chokidar": { 2069 | "version": "3.6.0", 2070 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", 2071 | "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", 2072 | "dev": true, 2073 | "requires": { 2074 | "anymatch": "~3.1.2", 2075 | "braces": "~3.0.2", 2076 | "fsevents": "~2.3.2", 2077 | "glob-parent": "~5.1.2", 2078 | "is-binary-path": "~2.1.0", 2079 | "is-glob": "~4.0.1", 2080 | "normalize-path": "~3.0.0", 2081 | "readdirp": "~3.6.0" 2082 | } 2083 | }, 2084 | "cli-cursor": { 2085 | "version": "4.0.0", 2086 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-4.0.0.tgz", 2087 | "integrity": "sha512-VGtlMu3x/4DOtIUwEkRezxUZ2lBacNJCHash0N0WeZDBS+7Ux1dm3XWAgWYxLJFMMdOeXMHXorshEFhbMSGelg==", 2088 | "dev": true, 2089 | "requires": { 2090 | "restore-cursor": "^4.0.0" 2091 | } 2092 | }, 2093 | "cli-spinners": { 2094 | "version": "2.9.2", 2095 | "resolved": "https://registry.npmjs.org/cli-spinners/-/cli-spinners-2.9.2.tgz", 2096 | "integrity": "sha512-ywqV+5MmyL4E7ybXgKys4DugZbX0FC6LnwrhjuykIjnK9k8OQacQ7axGKnjDXWNhns0xot3bZI5h55H8yo9cJg==", 2097 | "dev": true 2098 | }, 2099 | "cliui": { 2100 | "version": "7.0.4", 2101 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 2102 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 2103 | "dev": true, 2104 | "requires": { 2105 | "string-width": "^4.2.0", 2106 | "strip-ansi": "^6.0.0", 2107 | "wrap-ansi": "^7.0.0" 2108 | }, 2109 | "dependencies": { 2110 | "ansi-regex": { 2111 | "version": "5.0.1", 2112 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2113 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2114 | "dev": true 2115 | }, 2116 | "emoji-regex": { 2117 | "version": "8.0.0", 2118 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2119 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2120 | "dev": true 2121 | }, 2122 | "string-width": { 2123 | "version": "4.2.3", 2124 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2125 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2126 | "dev": true, 2127 | "requires": { 2128 | "emoji-regex": "^8.0.0", 2129 | "is-fullwidth-code-point": "^3.0.0", 2130 | "strip-ansi": "^6.0.1" 2131 | } 2132 | }, 2133 | "strip-ansi": { 2134 | "version": "6.0.1", 2135 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2136 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2137 | "dev": true, 2138 | "requires": { 2139 | "ansi-regex": "^5.0.1" 2140 | } 2141 | } 2142 | } 2143 | }, 2144 | "color-convert": { 2145 | "version": "2.0.1", 2146 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2147 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2148 | "dev": true, 2149 | "requires": { 2150 | "color-name": "~1.1.4" 2151 | } 2152 | }, 2153 | "color-name": { 2154 | "version": "1.1.4", 2155 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2156 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2157 | "dev": true 2158 | }, 2159 | "commander": { 2160 | "version": "2.20.3", 2161 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 2162 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", 2163 | "dev": true 2164 | }, 2165 | "concat-map": { 2166 | "version": "0.0.1", 2167 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2168 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 2169 | "dev": true 2170 | }, 2171 | "core-util-is": { 2172 | "version": "1.0.3", 2173 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", 2174 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", 2175 | "dev": true 2176 | }, 2177 | "debug": { 2178 | "version": "4.3.7", 2179 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.7.tgz", 2180 | "integrity": "sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==", 2181 | "dev": true, 2182 | "requires": { 2183 | "ms": "^2.1.3" 2184 | } 2185 | }, 2186 | "decamelize": { 2187 | "version": "4.0.0", 2188 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 2189 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 2190 | "dev": true 2191 | }, 2192 | "diff": { 2193 | "version": "5.2.0", 2194 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.2.0.tgz", 2195 | "integrity": "sha512-uIFDxqpRZGZ6ThOk84hEfqWoHx2devRFvpTZcTHur85vImfaxUbTW9Ryh4CpCuDnToOP1CEtXKIgytHBPVff5A==", 2196 | "dev": true 2197 | }, 2198 | "eastasianwidth": { 2199 | "version": "0.2.0", 2200 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 2201 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", 2202 | "dev": true 2203 | }, 2204 | "emoji-regex": { 2205 | "version": "10.4.0", 2206 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.4.0.tgz", 2207 | "integrity": "sha512-EC+0oUMY1Rqm4O6LLrgjtYDvcVYTy7chDnM4Q7030tP4Kwj3u/pR6gP9ygnp2CJMK5Gq+9Q2oqmrFJAz01DXjw==", 2208 | "dev": true 2209 | }, 2210 | "escalade": { 2211 | "version": "3.2.0", 2212 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", 2213 | "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==", 2214 | "dev": true 2215 | }, 2216 | "escape-string-regexp": { 2217 | "version": "4.0.0", 2218 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2219 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2220 | "dev": true 2221 | }, 2222 | "esprima": { 2223 | "version": "4.0.1", 2224 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 2225 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 2226 | "dev": true 2227 | }, 2228 | "fill-range": { 2229 | "version": "7.1.1", 2230 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", 2231 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", 2232 | "dev": true, 2233 | "requires": { 2234 | "to-regex-range": "^5.0.1" 2235 | } 2236 | }, 2237 | "find-up": { 2238 | "version": "5.0.0", 2239 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2240 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2241 | "dev": true, 2242 | "requires": { 2243 | "locate-path": "^6.0.0", 2244 | "path-exists": "^4.0.0" 2245 | } 2246 | }, 2247 | "flat": { 2248 | "version": "5.0.2", 2249 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 2250 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 2251 | "dev": true 2252 | }, 2253 | "fs.realpath": { 2254 | "version": "1.0.0", 2255 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2256 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 2257 | "dev": true 2258 | }, 2259 | "fsevents": { 2260 | "version": "2.3.3", 2261 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 2262 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 2263 | "dev": true, 2264 | "optional": true 2265 | }, 2266 | "function-bind": { 2267 | "version": "1.1.2", 2268 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 2269 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 2270 | "dev": true 2271 | }, 2272 | "get-caller-file": { 2273 | "version": "2.0.5", 2274 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 2275 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 2276 | "dev": true 2277 | }, 2278 | "glob": { 2279 | "version": "8.1.0", 2280 | "resolved": "https://registry.npmjs.org/glob/-/glob-8.1.0.tgz", 2281 | "integrity": "sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ==", 2282 | "dev": true, 2283 | "requires": { 2284 | "fs.realpath": "^1.0.0", 2285 | "inflight": "^1.0.4", 2286 | "inherits": "2", 2287 | "minimatch": "^5.0.1", 2288 | "once": "^1.3.0" 2289 | } 2290 | }, 2291 | "glob-parent": { 2292 | "version": "5.1.2", 2293 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2294 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2295 | "dev": true, 2296 | "requires": { 2297 | "is-glob": "^4.0.1" 2298 | } 2299 | }, 2300 | "has-flag": { 2301 | "version": "4.0.0", 2302 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2303 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2304 | "dev": true 2305 | }, 2306 | "hasown": { 2307 | "version": "2.0.2", 2308 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 2309 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 2310 | "dev": true, 2311 | "requires": { 2312 | "function-bind": "^1.1.2" 2313 | } 2314 | }, 2315 | "he": { 2316 | "version": "1.2.0", 2317 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 2318 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 2319 | "dev": true 2320 | }, 2321 | "http-proxy-agent": { 2322 | "version": "7.0.2", 2323 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-7.0.2.tgz", 2324 | "integrity": "sha512-T1gkAiYYDWYx3V5Bmyu7HcfcvL7mUrTWiM6yOfa3PIphViJ/gFPbvidQ+veqSOHci/PxBcDabeUNCzpOODJZig==", 2325 | "dev": true, 2326 | "requires": { 2327 | "agent-base": "^7.1.0", 2328 | "debug": "^4.3.4" 2329 | } 2330 | }, 2331 | "https-proxy-agent": { 2332 | "version": "7.0.5", 2333 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-7.0.5.tgz", 2334 | "integrity": "sha512-1e4Wqeblerz+tMKPIq2EMGiiWW1dIjZOksyHWSUm1rmuvw/how9hBHZ38lAGj5ID4Ik6EdkOw7NmWPy6LAwalw==", 2335 | "dev": true, 2336 | "requires": { 2337 | "agent-base": "^7.0.2", 2338 | "debug": "4" 2339 | } 2340 | }, 2341 | "ieee754": { 2342 | "version": "1.2.1", 2343 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", 2344 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", 2345 | "dev": true 2346 | }, 2347 | "immediate": { 2348 | "version": "3.0.6", 2349 | "resolved": "https://registry.npmjs.org/immediate/-/immediate-3.0.6.tgz", 2350 | "integrity": "sha512-XXOFtyqDjNDAQxVfYxuF7g9Il/IbWmmlQg2MYKOH8ExIT1qg6xc4zyS3HaEEATgs1btfzxq15ciUiY7gjSXRGQ==", 2351 | "dev": true 2352 | }, 2353 | "inflight": { 2354 | "version": "1.0.6", 2355 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2356 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 2357 | "dev": true, 2358 | "requires": { 2359 | "once": "^1.3.0", 2360 | "wrappy": "1" 2361 | } 2362 | }, 2363 | "inherits": { 2364 | "version": "2.0.4", 2365 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2366 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2367 | "dev": true 2368 | }, 2369 | "is-binary-path": { 2370 | "version": "2.1.0", 2371 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 2372 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 2373 | "dev": true, 2374 | "requires": { 2375 | "binary-extensions": "^2.0.0" 2376 | } 2377 | }, 2378 | "is-core-module": { 2379 | "version": "2.15.1", 2380 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.15.1.tgz", 2381 | "integrity": "sha512-z0vtXSwucUJtANQWldhbtbt7BnL0vxiFjIdDLAatwhDYty2bad6s+rijD6Ri4YuYJubLzIJLUidCh09e1djEVQ==", 2382 | "dev": true, 2383 | "requires": { 2384 | "hasown": "^2.0.2" 2385 | } 2386 | }, 2387 | "is-extglob": { 2388 | "version": "2.1.1", 2389 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2390 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2391 | "dev": true 2392 | }, 2393 | "is-fullwidth-code-point": { 2394 | "version": "3.0.0", 2395 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2396 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2397 | "dev": true 2398 | }, 2399 | "is-glob": { 2400 | "version": "4.0.3", 2401 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2402 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2403 | "dev": true, 2404 | "requires": { 2405 | "is-extglob": "^2.1.1" 2406 | } 2407 | }, 2408 | "is-interactive": { 2409 | "version": "2.0.0", 2410 | "resolved": "https://registry.npmjs.org/is-interactive/-/is-interactive-2.0.0.tgz", 2411 | "integrity": "sha512-qP1vozQRI+BMOPcjFzrjXuQvdak2pHNUMZoeG2eRbiSqyvbEf/wQtEOTOX1guk6E3t36RkaqiSt8A/6YElNxLQ==", 2412 | "dev": true 2413 | }, 2414 | "is-number": { 2415 | "version": "7.0.0", 2416 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2417 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2418 | "dev": true 2419 | }, 2420 | "is-plain-obj": { 2421 | "version": "2.1.0", 2422 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 2423 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 2424 | "dev": true 2425 | }, 2426 | "is-unicode-supported": { 2427 | "version": "0.1.0", 2428 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 2429 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 2430 | "dev": true 2431 | }, 2432 | "isarray": { 2433 | "version": "1.0.0", 2434 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 2435 | "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==", 2436 | "dev": true 2437 | }, 2438 | "js-tokens": { 2439 | "version": "4.0.0", 2440 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2441 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 2442 | "dev": true 2443 | }, 2444 | "js-yaml": { 2445 | "version": "4.1.0", 2446 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2447 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2448 | "dev": true, 2449 | "requires": { 2450 | "argparse": "^2.0.1" 2451 | } 2452 | }, 2453 | "jszip": { 2454 | "version": "3.10.1", 2455 | "resolved": "https://registry.npmjs.org/jszip/-/jszip-3.10.1.tgz", 2456 | "integrity": "sha512-xXDvecyTpGLrqFrvkrUSoxxfJI5AH7U8zxxtVclpsUtMCq4JQ290LY8AW5c7Ggnr/Y/oK+bQMbqK2qmtk3pN4g==", 2457 | "dev": true, 2458 | "requires": { 2459 | "lie": "~3.3.0", 2460 | "pako": "~1.0.2", 2461 | "readable-stream": "~2.3.6", 2462 | "setimmediate": "^1.0.5" 2463 | } 2464 | }, 2465 | "lie": { 2466 | "version": "3.3.0", 2467 | "resolved": "https://registry.npmjs.org/lie/-/lie-3.3.0.tgz", 2468 | "integrity": "sha512-UaiMJzeWRlEujzAuw5LokY1L5ecNQYZKfmyZ9L7wDHb/p5etKaxXhohBcrw0EYby+G/NA52vRSN4N39dxHAIwQ==", 2469 | "dev": true, 2470 | "requires": { 2471 | "immediate": "~3.0.5" 2472 | } 2473 | }, 2474 | "locate-path": { 2475 | "version": "6.0.0", 2476 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2477 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2478 | "dev": true, 2479 | "requires": { 2480 | "p-locate": "^5.0.0" 2481 | } 2482 | }, 2483 | "log-symbols": { 2484 | "version": "4.1.0", 2485 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 2486 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 2487 | "dev": true, 2488 | "requires": { 2489 | "chalk": "^4.1.0", 2490 | "is-unicode-supported": "^0.1.0" 2491 | } 2492 | }, 2493 | "mimic-fn": { 2494 | "version": "2.1.0", 2495 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 2496 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 2497 | "dev": true 2498 | }, 2499 | "minimatch": { 2500 | "version": "5.1.6", 2501 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", 2502 | "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", 2503 | "dev": true, 2504 | "requires": { 2505 | "brace-expansion": "^2.0.1" 2506 | } 2507 | }, 2508 | "minimist": { 2509 | "version": "1.2.8", 2510 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 2511 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 2512 | "dev": true 2513 | }, 2514 | "mkdirp": { 2515 | "version": "1.0.4", 2516 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 2517 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", 2518 | "dev": true 2519 | }, 2520 | "mocha": { 2521 | "version": "10.8.2", 2522 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.8.2.tgz", 2523 | "integrity": "sha512-VZlYo/WE8t1tstuRmqgeyBgCbJc/lEdopaa+axcKzTBJ+UIdlAB9XnmvTCAH4pwR4ElNInaedhEBmZD8iCSVEg==", 2524 | "dev": true, 2525 | "requires": { 2526 | "ansi-colors": "^4.1.3", 2527 | "browser-stdout": "^1.3.1", 2528 | "chokidar": "^3.5.3", 2529 | "debug": "^4.3.5", 2530 | "diff": "^5.2.0", 2531 | "escape-string-regexp": "^4.0.0", 2532 | "find-up": "^5.0.0", 2533 | "glob": "^8.1.0", 2534 | "he": "^1.2.0", 2535 | "js-yaml": "^4.1.0", 2536 | "log-symbols": "^4.1.0", 2537 | "minimatch": "^5.1.6", 2538 | "ms": "^2.1.3", 2539 | "serialize-javascript": "^6.0.2", 2540 | "strip-json-comments": "^3.1.1", 2541 | "supports-color": "^8.1.1", 2542 | "workerpool": "^6.5.1", 2543 | "yargs": "^16.2.0", 2544 | "yargs-parser": "^20.2.9", 2545 | "yargs-unparser": "^2.0.0" 2546 | } 2547 | }, 2548 | "ms": { 2549 | "version": "2.1.3", 2550 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2551 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 2552 | "dev": true 2553 | }, 2554 | "normalize-path": { 2555 | "version": "3.0.0", 2556 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2557 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2558 | "dev": true 2559 | }, 2560 | "once": { 2561 | "version": "1.4.0", 2562 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2563 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2564 | "dev": true, 2565 | "requires": { 2566 | "wrappy": "1" 2567 | } 2568 | }, 2569 | "onetime": { 2570 | "version": "5.1.2", 2571 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 2572 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 2573 | "dev": true, 2574 | "requires": { 2575 | "mimic-fn": "^2.1.0" 2576 | } 2577 | }, 2578 | "ora": { 2579 | "version": "7.0.1", 2580 | "resolved": "https://registry.npmjs.org/ora/-/ora-7.0.1.tgz", 2581 | "integrity": "sha512-0TUxTiFJWv+JnjWm4o9yvuskpEJLXTcng8MJuKd+SzAzp2o+OP3HWqNhB4OdJRt1Vsd9/mR0oyaEYlOnL7XIRw==", 2582 | "dev": true, 2583 | "requires": { 2584 | "chalk": "^5.3.0", 2585 | "cli-cursor": "^4.0.0", 2586 | "cli-spinners": "^2.9.0", 2587 | "is-interactive": "^2.0.0", 2588 | "is-unicode-supported": "^1.3.0", 2589 | "log-symbols": "^5.1.0", 2590 | "stdin-discarder": "^0.1.0", 2591 | "string-width": "^6.1.0", 2592 | "strip-ansi": "^7.1.0" 2593 | }, 2594 | "dependencies": { 2595 | "chalk": { 2596 | "version": "5.3.0", 2597 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.3.0.tgz", 2598 | "integrity": "sha512-dLitG79d+GV1Nb/VYcCDFivJeK1hiukt9QjRNVOsUtTy1rR1YJsmpGGTZ3qJos+uw7WmWF4wUwBd9jxjocFC2w==", 2599 | "dev": true 2600 | }, 2601 | "is-unicode-supported": { 2602 | "version": "1.3.0", 2603 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-1.3.0.tgz", 2604 | "integrity": "sha512-43r2mRvz+8JRIKnWJ+3j8JtjRKZ6GmjzfaE/qiBJnikNnYv/6bagRJ1kUhNk8R5EX/GkobD+r+sfxCPJsiKBLQ==", 2605 | "dev": true 2606 | }, 2607 | "log-symbols": { 2608 | "version": "5.1.0", 2609 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-5.1.0.tgz", 2610 | "integrity": "sha512-l0x2DvrW294C9uDCoQe1VSU4gf529FkSZ6leBl4TiqZH/e+0R7hSfHQBNut2mNygDgHwvYHfFLn6Oxb3VWj2rA==", 2611 | "dev": true, 2612 | "requires": { 2613 | "chalk": "^5.0.0", 2614 | "is-unicode-supported": "^1.1.0" 2615 | } 2616 | } 2617 | } 2618 | }, 2619 | "p-limit": { 2620 | "version": "3.1.0", 2621 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2622 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2623 | "dev": true, 2624 | "requires": { 2625 | "yocto-queue": "^0.1.0" 2626 | } 2627 | }, 2628 | "p-locate": { 2629 | "version": "5.0.0", 2630 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2631 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2632 | "dev": true, 2633 | "requires": { 2634 | "p-limit": "^3.0.2" 2635 | } 2636 | }, 2637 | "pako": { 2638 | "version": "1.0.11", 2639 | "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.11.tgz", 2640 | "integrity": "sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw==", 2641 | "dev": true 2642 | }, 2643 | "path-exists": { 2644 | "version": "4.0.0", 2645 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2646 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2647 | "dev": true 2648 | }, 2649 | "path-is-absolute": { 2650 | "version": "1.0.1", 2651 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2652 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 2653 | "dev": true 2654 | }, 2655 | "path-parse": { 2656 | "version": "1.0.7", 2657 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2658 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 2659 | "dev": true 2660 | }, 2661 | "picocolors": { 2662 | "version": "1.1.1", 2663 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz", 2664 | "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==", 2665 | "dev": true 2666 | }, 2667 | "picomatch": { 2668 | "version": "2.3.1", 2669 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2670 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2671 | "dev": true 2672 | }, 2673 | "process-nextick-args": { 2674 | "version": "2.0.1", 2675 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 2676 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 2677 | "dev": true 2678 | }, 2679 | "randombytes": { 2680 | "version": "2.1.0", 2681 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 2682 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 2683 | "dev": true, 2684 | "requires": { 2685 | "safe-buffer": "^5.1.0" 2686 | } 2687 | }, 2688 | "readable-stream": { 2689 | "version": "2.3.8", 2690 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", 2691 | "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", 2692 | "dev": true, 2693 | "requires": { 2694 | "core-util-is": "~1.0.0", 2695 | "inherits": "~2.0.3", 2696 | "isarray": "~1.0.0", 2697 | "process-nextick-args": "~2.0.0", 2698 | "safe-buffer": "~5.1.1", 2699 | "string_decoder": "~1.1.1", 2700 | "util-deprecate": "~1.0.1" 2701 | } 2702 | }, 2703 | "readdirp": { 2704 | "version": "3.6.0", 2705 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 2706 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 2707 | "dev": true, 2708 | "requires": { 2709 | "picomatch": "^2.2.1" 2710 | } 2711 | }, 2712 | "require-directory": { 2713 | "version": "2.1.1", 2714 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2715 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 2716 | "dev": true 2717 | }, 2718 | "resolve": { 2719 | "version": "1.22.8", 2720 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", 2721 | "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", 2722 | "dev": true, 2723 | "requires": { 2724 | "is-core-module": "^2.13.0", 2725 | "path-parse": "^1.0.7", 2726 | "supports-preserve-symlinks-flag": "^1.0.0" 2727 | } 2728 | }, 2729 | "restore-cursor": { 2730 | "version": "4.0.0", 2731 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-4.0.0.tgz", 2732 | "integrity": "sha512-I9fPXU9geO9bHOt9pHHOhOkYerIMsmVaWB0rA2AI9ERh/+x/i7MV5HKBNrg+ljO5eoPVgCcnFuRjJ9uH6I/3eg==", 2733 | "dev": true, 2734 | "requires": { 2735 | "onetime": "^5.1.0", 2736 | "signal-exit": "^3.0.2" 2737 | } 2738 | }, 2739 | "safe-buffer": { 2740 | "version": "5.1.2", 2741 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2742 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 2743 | "dev": true 2744 | }, 2745 | "semver": { 2746 | "version": "7.6.3", 2747 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 2748 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 2749 | "dev": true 2750 | }, 2751 | "serialize-javascript": { 2752 | "version": "6.0.2", 2753 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.2.tgz", 2754 | "integrity": "sha512-Saa1xPByTTq2gdeFZYLLo+RFE35NHZkAbqZeWNd3BpzppeVisAqpDjcp8dyf6uIvEqJRd46jemmyA4iFIeVk8g==", 2755 | "dev": true, 2756 | "requires": { 2757 | "randombytes": "^2.1.0" 2758 | } 2759 | }, 2760 | "setimmediate": { 2761 | "version": "1.0.5", 2762 | "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", 2763 | "integrity": "sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA==", 2764 | "dev": true 2765 | }, 2766 | "signal-exit": { 2767 | "version": "3.0.7", 2768 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 2769 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 2770 | "dev": true 2771 | }, 2772 | "sprintf-js": { 2773 | "version": "1.0.3", 2774 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2775 | "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", 2776 | "dev": true 2777 | }, 2778 | "stdin-discarder": { 2779 | "version": "0.1.0", 2780 | "resolved": "https://registry.npmjs.org/stdin-discarder/-/stdin-discarder-0.1.0.tgz", 2781 | "integrity": "sha512-xhV7w8S+bUwlPTb4bAOUQhv8/cSS5offJuX8GQGq32ONF0ZtDWKfkdomM3HMRA+LhX6um/FZ0COqlwsjD53LeQ==", 2782 | "dev": true, 2783 | "requires": { 2784 | "bl": "^5.0.0" 2785 | } 2786 | }, 2787 | "string_decoder": { 2788 | "version": "1.1.1", 2789 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2790 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2791 | "dev": true, 2792 | "requires": { 2793 | "safe-buffer": "~5.1.0" 2794 | } 2795 | }, 2796 | "string-width": { 2797 | "version": "6.1.0", 2798 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-6.1.0.tgz", 2799 | "integrity": "sha512-k01swCJAgQmuADB0YIc+7TuatfNvTBVOoaUWJjTB9R4VJzR5vNWzf5t42ESVZFPS8xTySF7CAdV4t/aaIm3UnQ==", 2800 | "dev": true, 2801 | "requires": { 2802 | "eastasianwidth": "^0.2.0", 2803 | "emoji-regex": "^10.2.1", 2804 | "strip-ansi": "^7.0.1" 2805 | } 2806 | }, 2807 | "strip-ansi": { 2808 | "version": "7.1.0", 2809 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", 2810 | "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", 2811 | "dev": true, 2812 | "requires": { 2813 | "ansi-regex": "^6.0.1" 2814 | } 2815 | }, 2816 | "strip-json-comments": { 2817 | "version": "3.1.1", 2818 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2819 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2820 | "dev": true 2821 | }, 2822 | "supports-color": { 2823 | "version": "8.1.1", 2824 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 2825 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 2826 | "dev": true, 2827 | "requires": { 2828 | "has-flag": "^4.0.0" 2829 | } 2830 | }, 2831 | "supports-preserve-symlinks-flag": { 2832 | "version": "1.0.0", 2833 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 2834 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 2835 | "dev": true 2836 | }, 2837 | "to-regex-range": { 2838 | "version": "5.0.1", 2839 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2840 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2841 | "dev": true, 2842 | "requires": { 2843 | "is-number": "^7.0.0" 2844 | } 2845 | }, 2846 | "tslib": { 2847 | "version": "1.14.1", 2848 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 2849 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 2850 | "dev": true 2851 | }, 2852 | "tslint": { 2853 | "version": "6.1.3", 2854 | "resolved": "https://registry.npmjs.org/tslint/-/tslint-6.1.3.tgz", 2855 | "integrity": "sha512-IbR4nkT96EQOvKE2PW/djGz8iGNeJ4rF2mBfiYaR/nvUWYKJhLwimoJKgjIFEIDibBtOevj7BqCRL4oHeWWUCg==", 2856 | "dev": true, 2857 | "requires": { 2858 | "@babel/code-frame": "^7.0.0", 2859 | "builtin-modules": "^1.1.1", 2860 | "chalk": "^2.3.0", 2861 | "commander": "^2.12.1", 2862 | "diff": "^4.0.1", 2863 | "glob": "^7.1.1", 2864 | "js-yaml": "^3.13.1", 2865 | "minimatch": "^3.0.4", 2866 | "mkdirp": "^0.5.3", 2867 | "resolve": "^1.3.2", 2868 | "semver": "^5.3.0", 2869 | "tslib": "^1.13.0", 2870 | "tsutils": "^2.29.0" 2871 | }, 2872 | "dependencies": { 2873 | "ansi-styles": { 2874 | "version": "3.2.1", 2875 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 2876 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 2877 | "dev": true, 2878 | "requires": { 2879 | "color-convert": "^1.9.0" 2880 | } 2881 | }, 2882 | "argparse": { 2883 | "version": "1.0.10", 2884 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 2885 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 2886 | "dev": true, 2887 | "requires": { 2888 | "sprintf-js": "~1.0.2" 2889 | } 2890 | }, 2891 | "brace-expansion": { 2892 | "version": "1.1.11", 2893 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2894 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2895 | "dev": true, 2896 | "requires": { 2897 | "balanced-match": "^1.0.0", 2898 | "concat-map": "0.0.1" 2899 | } 2900 | }, 2901 | "chalk": { 2902 | "version": "2.4.2", 2903 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 2904 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 2905 | "dev": true, 2906 | "requires": { 2907 | "ansi-styles": "^3.2.1", 2908 | "escape-string-regexp": "^1.0.5", 2909 | "supports-color": "^5.3.0" 2910 | } 2911 | }, 2912 | "color-convert": { 2913 | "version": "1.9.3", 2914 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 2915 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 2916 | "dev": true, 2917 | "requires": { 2918 | "color-name": "1.1.3" 2919 | } 2920 | }, 2921 | "color-name": { 2922 | "version": "1.1.3", 2923 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 2924 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 2925 | "dev": true 2926 | }, 2927 | "diff": { 2928 | "version": "4.0.2", 2929 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 2930 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 2931 | "dev": true 2932 | }, 2933 | "escape-string-regexp": { 2934 | "version": "1.0.5", 2935 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 2936 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 2937 | "dev": true 2938 | }, 2939 | "glob": { 2940 | "version": "7.2.3", 2941 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2942 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2943 | "dev": true, 2944 | "requires": { 2945 | "fs.realpath": "^1.0.0", 2946 | "inflight": "^1.0.4", 2947 | "inherits": "2", 2948 | "minimatch": "^3.1.1", 2949 | "once": "^1.3.0", 2950 | "path-is-absolute": "^1.0.0" 2951 | } 2952 | }, 2953 | "has-flag": { 2954 | "version": "3.0.0", 2955 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2956 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 2957 | "dev": true 2958 | }, 2959 | "js-yaml": { 2960 | "version": "3.14.1", 2961 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 2962 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 2963 | "dev": true, 2964 | "requires": { 2965 | "argparse": "^1.0.7", 2966 | "esprima": "^4.0.0" 2967 | } 2968 | }, 2969 | "minimatch": { 2970 | "version": "3.1.2", 2971 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2972 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2973 | "dev": true, 2974 | "requires": { 2975 | "brace-expansion": "^1.1.7" 2976 | } 2977 | }, 2978 | "mkdirp": { 2979 | "version": "0.5.6", 2980 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", 2981 | "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", 2982 | "dev": true, 2983 | "requires": { 2984 | "minimist": "^1.2.6" 2985 | } 2986 | }, 2987 | "semver": { 2988 | "version": "5.7.2", 2989 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", 2990 | "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", 2991 | "dev": true 2992 | }, 2993 | "supports-color": { 2994 | "version": "5.5.0", 2995 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2996 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2997 | "dev": true, 2998 | "requires": { 2999 | "has-flag": "^3.0.0" 3000 | } 3001 | } 3002 | } 3003 | }, 3004 | "tsutils": { 3005 | "version": "2.29.0", 3006 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-2.29.0.tgz", 3007 | "integrity": "sha512-g5JVHCIJwzfISaXpXE1qvNalca5Jwob6FjI4AoPlqMusJ6ftFE7IkkFoMhVLRgK+4Kx3gkzb8UZK5t5yTTvEmA==", 3008 | "dev": true, 3009 | "requires": { 3010 | "tslib": "^1.8.1" 3011 | } 3012 | }, 3013 | "typescript": { 3014 | "version": "5.6.3", 3015 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.6.3.tgz", 3016 | "integrity": "sha512-hjcS1mhfuyi4WW8IWtjP7brDrG2cuDZukyrYrSauoXGNgx0S7zceP07adYkJycEr56BOUTNPzbInooiN3fn1qw==", 3017 | "dev": true 3018 | }, 3019 | "undici-types": { 3020 | "version": "6.19.8", 3021 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-6.19.8.tgz", 3022 | "integrity": "sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==", 3023 | "dev": true 3024 | }, 3025 | "util-deprecate": { 3026 | "version": "1.0.2", 3027 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3028 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", 3029 | "dev": true 3030 | }, 3031 | "workerpool": { 3032 | "version": "6.5.1", 3033 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.5.1.tgz", 3034 | "integrity": "sha512-Fs4dNYcsdpYSAfVxhnl1L5zTksjvOJxtC5hzMNl+1t9B8hTJTdKDyZ5ju7ztgPy+ft9tBFXoOlDNiOT9WUXZlA==", 3035 | "dev": true 3036 | }, 3037 | "wrap-ansi": { 3038 | "version": "7.0.0", 3039 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3040 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3041 | "dev": true, 3042 | "requires": { 3043 | "ansi-styles": "^4.0.0", 3044 | "string-width": "^4.1.0", 3045 | "strip-ansi": "^6.0.0" 3046 | }, 3047 | "dependencies": { 3048 | "ansi-regex": { 3049 | "version": "5.0.1", 3050 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 3051 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 3052 | "dev": true 3053 | }, 3054 | "emoji-regex": { 3055 | "version": "8.0.0", 3056 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 3057 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 3058 | "dev": true 3059 | }, 3060 | "string-width": { 3061 | "version": "4.2.3", 3062 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3063 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3064 | "dev": true, 3065 | "requires": { 3066 | "emoji-regex": "^8.0.0", 3067 | "is-fullwidth-code-point": "^3.0.0", 3068 | "strip-ansi": "^6.0.1" 3069 | } 3070 | }, 3071 | "strip-ansi": { 3072 | "version": "6.0.1", 3073 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3074 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3075 | "dev": true, 3076 | "requires": { 3077 | "ansi-regex": "^5.0.1" 3078 | } 3079 | } 3080 | } 3081 | }, 3082 | "wrappy": { 3083 | "version": "1.0.2", 3084 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3085 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3086 | "dev": true 3087 | }, 3088 | "y18n": { 3089 | "version": "5.0.8", 3090 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3091 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3092 | "dev": true 3093 | }, 3094 | "yargs": { 3095 | "version": "16.2.0", 3096 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 3097 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 3098 | "dev": true, 3099 | "requires": { 3100 | "cliui": "^7.0.2", 3101 | "escalade": "^3.1.1", 3102 | "get-caller-file": "^2.0.5", 3103 | "require-directory": "^2.1.1", 3104 | "string-width": "^4.2.0", 3105 | "y18n": "^5.0.5", 3106 | "yargs-parser": "^20.2.2" 3107 | }, 3108 | "dependencies": { 3109 | "ansi-regex": { 3110 | "version": "5.0.1", 3111 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 3112 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 3113 | "dev": true 3114 | }, 3115 | "emoji-regex": { 3116 | "version": "8.0.0", 3117 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 3118 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 3119 | "dev": true 3120 | }, 3121 | "string-width": { 3122 | "version": "4.2.3", 3123 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3124 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3125 | "dev": true, 3126 | "requires": { 3127 | "emoji-regex": "^8.0.0", 3128 | "is-fullwidth-code-point": "^3.0.0", 3129 | "strip-ansi": "^6.0.1" 3130 | } 3131 | }, 3132 | "strip-ansi": { 3133 | "version": "6.0.1", 3134 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3135 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3136 | "dev": true, 3137 | "requires": { 3138 | "ansi-regex": "^5.0.1" 3139 | } 3140 | } 3141 | } 3142 | }, 3143 | "yargs-parser": { 3144 | "version": "20.2.9", 3145 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", 3146 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", 3147 | "dev": true 3148 | }, 3149 | "yargs-unparser": { 3150 | "version": "2.0.0", 3151 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 3152 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 3153 | "dev": true, 3154 | "requires": { 3155 | "camelcase": "^6.0.0", 3156 | "decamelize": "^4.0.0", 3157 | "flat": "^5.0.2", 3158 | "is-plain-obj": "^2.1.0" 3159 | } 3160 | }, 3161 | "yocto-queue": { 3162 | "version": "0.1.0", 3163 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3164 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3165 | "dev": true 3166 | } 3167 | } 3168 | } 3169 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "csv-to-table", 3 | "icon": "images/icon.png", 4 | "displayName": "CSV to Table", 5 | "publisher": "phplasma", 6 | "description": "Convert a CSV/TSV/PSV file to an ASCII formatted table", 7 | "version": "1.4.1", 8 | "repository": { 9 | "type": "git", 10 | "url": "https://github.com/Plasma/csv-to-table.git" 11 | }, 12 | "engines": { 13 | "vscode": "^1.79.0" 14 | }, 15 | "categories": [ 16 | "Other" 17 | ], 18 | "activationEvents": [ 19 | "onCommand:extension.csv-to-table.csv", 20 | "onCommand:extension.csv-to-table.tsv", 21 | "onCommand:extension.csv-to-table.psv", 22 | "onCommand:extension.csv-to-table.ssv", 23 | "onCommand:extension.csv-to-table.custom" 24 | ], 25 | "main": "./out/extension.js", 26 | "contributes": { 27 | "commands": [ 28 | { 29 | "command": "extension.csv-to-table.csv", 30 | "title": "Convert to table from CSV (.csv / commas)" 31 | }, 32 | { 33 | "command": "extension.csv-to-table.tsv", 34 | "title": "Convert to table from TSV (.tsv / tabs)" 35 | }, 36 | { 37 | "command": "extension.csv-to-table.psv", 38 | "title": "Convert to table from PSV (.psv / pipes)" 39 | }, 40 | { 41 | "command": "extension.csv-to-table.ssv", 42 | "title": "Convert to table from SSV (.ssv / semicolon)" 43 | }, 44 | { 45 | "command": "extension.csv-to-table.custom", 46 | "title": "Convert to table from a custom defined separator" 47 | } 48 | ], 49 | "configuration": { 50 | "title": "CSV to Table", 51 | "properties": { 52 | "csv-to-table.openGeneratedTableInNewEditor": { 53 | "type": "boolean", 54 | "default": true, 55 | "description": "Open the generated table in a new editor window, instead of replacing the current editor's content." 56 | }, 57 | "csv-to-table.upperCaseHeader": { 58 | "type": "boolean", 59 | "default": false, 60 | "description": "Convert the first row's values (header) in the table to upper-case." 61 | }, 62 | "csv-to-table.markdownFormat": { 63 | "type": "boolean", 64 | "default": false, 65 | "description": "Write the generated table using Markdown format instead of the default style." 66 | }, 67 | "csv-to-table.rightAlignNumbers": { 68 | "type": "boolean", 69 | "default": true, 70 | "description": "Align cell values that are numbers to the right side for easy comparison between other row values." 71 | } 72 | } 73 | } 74 | }, 75 | "scripts": { 76 | "vscode:prepublish": "npm run compile", 77 | "compile": "tsc -p ./", 78 | "watch": "tsc -watch -p ./", 79 | "pretest": "npm run compile", 80 | "test": "node ./out/test/runTest.js" 81 | }, 82 | "devDependencies": { 83 | "@types/glob": "^8.0.1", 84 | "@types/mocha": "^10.0.1", 85 | "@types/node": "^20.5.0", 86 | "@types/vscode": "^1.79.0", 87 | "glob": "^8.1.0", 88 | "minimist": "^1.2.7", 89 | "mkdirp": "^1.0.4", 90 | "mocha": "^10.2.0", 91 | "tslint": "^6.1.3", 92 | "typescript": "^5.3.0", 93 | "@vscode/test-electron": "^2.4.1" 94 | }, 95 | "dependencies": {} 96 | } -------------------------------------------------------------------------------- /src/CsvColumn.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * Represents a column value in a CsvRecord 3 | */ 4 | export default class CsvColumn 5 | { 6 | private _value: string; 7 | 8 | constructor(value: string) { 9 | this._value = value; 10 | } 11 | 12 | /** 13 | * Return the value of this column 14 | */ 15 | public getValue(): string { 16 | return this._value; 17 | } 18 | } -------------------------------------------------------------------------------- /src/CsvParser.ts: -------------------------------------------------------------------------------- 1 | import CsvColumn from './CsvColumn'; 2 | import CsvRecord from './CsvRecord'; 3 | 4 | /** 5 | * Parser that takes a string input and parsers it into a list of CsvRecord's that contain CsvColumn's 6 | */ 7 | export default class CsvParser 8 | { 9 | private _text: string; 10 | private _separator: string; 11 | private _position: number; 12 | 13 | /** 14 | * Initialie a CsvParser using the provided text 15 | * @param text The text to be parsed 16 | */ 17 | constructor(text: string, separator: string) { 18 | this._text = this.ensureEndOfRecord(text); 19 | this._separator = separator; 20 | this._position = 0; 21 | } 22 | 23 | /** 24 | * Ensures the provided text ends with a new line 25 | * @param text The processed text 26 | */ 27 | private ensureEndOfRecord(text: string): string { 28 | if (!this.isNewLine(text[text.length - 1])) { 29 | text += '\r\n'; 30 | } 31 | 32 | return text; 33 | } 34 | 35 | /** 36 | * Determines if we have reached the end of the input data 37 | */ 38 | private isEof(): boolean { 39 | return this._position >= this._text.length; 40 | } 41 | 42 | /** 43 | * Parse the provided text and emit the parsed CsvRecords 44 | */ 45 | public getRecords(): CsvRecord[] { 46 | let records: CsvRecord[] = []; 47 | let currentRecord: CsvRecord = new CsvRecord(); 48 | records.push(currentRecord); 49 | 50 | // Scan for records 51 | while(!this.isEof()) { 52 | // Parse column 53 | const columnResult = this.readColumn(); 54 | 55 | // Add to existing Record 56 | currentRecord.addColumn(columnResult.getColumn()); 57 | 58 | // Start new record? 59 | if (columnResult.getDidTerminateRecord() && !this.isEof()) { 60 | currentRecord = new CsvRecord(); 61 | records.push(currentRecord); 62 | } 63 | } 64 | 65 | return records; 66 | } 67 | 68 | /** 69 | * Peek at the current character in the input without advancing the position 70 | */ 71 | private peekChar(): string { 72 | return this._text.substr(this._position, 1); 73 | } 74 | 75 | /** 76 | * Advance our position to the first quote, if one looks to exist amongst leading spaces 77 | */ 78 | private advanceToQuoteIfLeadingSpaces(): void { 79 | for(var i = this._position; i < this._text.length; i++) { 80 | const char = this._text[i]; 81 | 82 | // If this is a space, continue to next character 83 | if (char === ' ') { 84 | continue; 85 | } 86 | 87 | // If this is a quote, advance our position to this value 88 | if (char === '"') { 89 | this._position = i; 90 | } 91 | 92 | // Break out 93 | break; 94 | } 95 | } 96 | 97 | /** 98 | * Consumes the current character sequence until a column has been read 99 | * Assumes it is starting with a potential quote character 100 | */ 101 | private readColumn(): CsvColumnResult { 102 | // If the column has leading spaces, followed by a quote, then we should jump to the quote character 103 | this.advanceToQuoteIfLeadingSpaces(); 104 | 105 | // Consume the current character sequence until we have a completed column 106 | let startingPosition = this._position; 107 | let isInQuote = false; 108 | let didTerminateRecord = false; 109 | let value = ''; 110 | 111 | // Read character sequence 112 | for(; this._position < this._text.length; this._position++) { 113 | const char = this._text[this._position]; 114 | const nextChar = this._position + 1 < this._text.length ? this._text[this._position + 1] : null; 115 | const isSeparator = this.isSeparator(char); 116 | const isQuote = char === '"'; 117 | const isNewLine = this.isNewLine(char); 118 | 119 | // Is this column value quoted? 120 | if (startingPosition === this._position && isQuote) { 121 | isInQuote = true; 122 | continue; 123 | } 124 | 125 | // Have we encountered a separator or new line, that terminates this column? 126 | if (!isInQuote && (isSeparator || isNewLine)) { 127 | if (isNewLine) { 128 | didTerminateRecord = true; 129 | } 130 | 131 | break; 132 | } 133 | 134 | // Skip past an escaped quote? 135 | if (isInQuote && isQuote && nextChar === '"') { 136 | // Append single (un-escaped from double) quote 137 | // Then advanced past our escaped quote value 138 | value += char; 139 | this._position++; 140 | continue; 141 | } 142 | 143 | 144 | // Or, have we closed our quoted value? 145 | if (isInQuote && isQuote && nextChar !== '"') { 146 | break; 147 | } 148 | 149 | // Otherwise, continue reading column value 150 | value += char; 151 | } 152 | 153 | // Read past the upcoming separator characgter 154 | if (this.readPastSeparatorCharacter()) { 155 | didTerminateRecord = true; 156 | } 157 | 158 | // Return result 159 | const column = new CsvColumn(value); 160 | return new CsvColumnResult(column, didTerminateRecord); 161 | } 162 | 163 | /** 164 | * Determine if the provided character appears to be a newline character 165 | * @param char The character to check 166 | */ 167 | private isNewLine(char: string): boolean { 168 | return char === '\r' || char === '\n'; 169 | } 170 | 171 | /** 172 | * Determine if the provided character appears to be a separator character 173 | * @param char The character to check 174 | */ 175 | private isSeparator(char: string): boolean { 176 | return char === this._separator; 177 | } 178 | 179 | /** 180 | * Advance the current position to the next non-separator character 181 | */ 182 | private readPastSeparatorCharacter(): boolean { 183 | let didTerminateRecord = false; 184 | let didEncounterNonSeparatorOrNewLine = false; 185 | let initialPosition = this._position; 186 | 187 | while(!this.isEof()) { 188 | const char = this.peekChar(); 189 | const isNewLine = this.isNewLine(char); 190 | const isSeparator = this.isSeparator(char); 191 | const isSeparatorOrNewLine = isSeparator || isNewLine; 192 | 193 | // If our first character being read is the separator, advance and bail out now 194 | if (initialPosition === this._position && isSeparator) { 195 | this._position++; 196 | break; 197 | } 198 | 199 | // Consider separators (eg ,) and new lines (record separators) as control characters 200 | // Skip past these so that we leave the next parser read starting at a new column (that may start with a quote) 201 | if (isSeparatorOrNewLine) { 202 | if (isNewLine) { 203 | didTerminateRecord = true; 204 | } 205 | 206 | // If we already encountered our separator before, return now as this could be a blank column value (eg: a,,b) 207 | if (didEncounterNonSeparatorOrNewLine && isSeparator) { 208 | break; 209 | } 210 | 211 | didEncounterNonSeparatorOrNewLine = true; 212 | this._position++; 213 | continue; 214 | } 215 | 216 | // If this is a quote, and we have not yet seen our separator, continue 217 | if (char === '"' && !didEncounterNonSeparatorOrNewLine) { 218 | this._position++; 219 | continue; 220 | } 221 | 222 | // Must have encountered our separator or newline 223 | if (!didEncounterNonSeparatorOrNewLine) { 224 | this._position++; 225 | continue; 226 | } 227 | 228 | // Encountered non-separator 229 | break; 230 | } 231 | 232 | return didTerminateRecord; 233 | } 234 | } 235 | 236 | /** 237 | * Wrapper class around CsvColumn that also indicates whether the current Record has completed 238 | */ 239 | class CsvColumnResult 240 | { 241 | private _column: CsvColumn; 242 | private _didTerminateRecord: boolean; 243 | 244 | constructor(column: CsvColumn, didTerminateRecord: boolean) { 245 | this._column = column; 246 | this._didTerminateRecord = didTerminateRecord; 247 | } 248 | 249 | /** 250 | * Return the CsvColumn value 251 | */ 252 | public getColumn(): CsvColumn { 253 | return this._column; 254 | } 255 | 256 | /** 257 | * Return whether the column also terminated the current CsvRecord 258 | */ 259 | public getDidTerminateRecord(): boolean { 260 | return this._didTerminateRecord; 261 | } 262 | } 263 | -------------------------------------------------------------------------------- /src/CsvRecord.ts: -------------------------------------------------------------------------------- 1 | import CsvColumn from './CsvColumn'; 2 | 3 | /** 4 | * Represents a record in a CSV/TSV/PSV file 5 | */ 6 | export default class CsvRecord 7 | { 8 | private _columns: CsvColumn[] = []; 9 | 10 | /** 11 | * Add the provided column to the Record 12 | * @param column The column to add 13 | */ 14 | public addColumn(column: CsvColumn) { 15 | this._columns.push(column); 16 | } 17 | 18 | /** 19 | * Return the list of available columns for this Record 20 | */ 21 | public getColumns(): CsvColumn[] { 22 | return this._columns; 23 | } 24 | } 25 | -------------------------------------------------------------------------------- /src/TableWriter.ts: -------------------------------------------------------------------------------- 1 | import { isNumber } from 'util'; 2 | import CsvColumn from './CsvColumn'; 3 | import CsvRecord from './CsvRecord'; 4 | 5 | /** 6 | * Class resposible for rendering a provided list of CsvRecord's into an ASCII table 7 | */ 8 | export default class TableWriter 9 | { 10 | /** 11 | * Return a formatted text table 12 | * @param records Records to be formatted 13 | */ 14 | public getFormattedTable(records: CsvRecord[], upperCaseHeader: boolean, useMarkdownFormat: boolean, rightAlignNumbers: boolean): string { 15 | // Get column lengths 16 | const columnLengths = this.getColumnLengths(records); 17 | 18 | // Build separator record 19 | const separatorRecord = this.buildSeparatorRecord(columnLengths); 20 | const separatorRecordLine = this.getFormattedRecord(separatorRecord, columnLengths, false, false, rightAlignNumbers); 21 | 22 | // Build table 23 | let result = ''; 24 | 25 | // Write records 26 | for(var i = 0; i < records.length; i++) { 27 | const record = records[i]; 28 | 29 | // Skip empty records 30 | if (record.getColumns().length === 0) { 31 | continue; 32 | } 33 | 34 | // Build formatted record 35 | const upperCaseRecordValue = upperCaseHeader && i === 0; 36 | const formattedRecord = this.getFormattedRecord(record, columnLengths, true, upperCaseRecordValue, rightAlignNumbers); 37 | 38 | // Write Record Separator 39 | // When using Markdown format, we only want to write this once after the initial header row 40 | if (!useMarkdownFormat || i === 1) 41 | result += separatorRecordLine + "\r\n"; 42 | 43 | // Write Record 44 | result += formattedRecord + "\r\n"; 45 | } 46 | 47 | // Write final ending formatting record (if not using Markdown format) 48 | if (!useMarkdownFormat) 49 | result += separatorRecordLine + "\r\n"; 50 | 51 | // Return result 52 | return result; 53 | } 54 | 55 | /** 56 | * Returns a CsvRecord that is suitable as a row separator 57 | * @param columnLengths Column length map 58 | */ 59 | private buildSeparatorRecord(columnLengths: any[]): CsvRecord { 60 | const record = new CsvRecord(); 61 | 62 | for(var i = 0; i < columnLengths.length; i++) { 63 | const colLength = columnLengths[i] + 2; 64 | const value = this.getRepeatedChar('-', colLength); 65 | 66 | record.addColumn(new CsvColumn(value)); 67 | } 68 | 69 | return record; 70 | } 71 | 72 | /** 73 | * Repeat the provided character N times 74 | * @param char The character to repeat 75 | * @param repeat Number of occurrances 76 | */ 77 | private getRepeatedChar(char: string, repeat: number): string { 78 | if (repeat <= 0) { 79 | return ''; 80 | } 81 | 82 | return char.repeat(repeat); 83 | } 84 | 85 | /** 86 | * Return a string representation of the provided Record 87 | * @param record The record to be formatted 88 | * @param columnLengths Column length map 89 | * @param useValuePadding Whether we are using value padding 90 | */ 91 | private getFormattedRecord(record: CsvRecord, columnLengths: any[], useValuePadding: boolean, upperCaseValue: boolean, rightAlignNumbers: boolean): string { 92 | const columns = record.getColumns(); 93 | const ValuePadding = useValuePadding ? ' ' : ''; 94 | const ColumnSeparator = '|'; 95 | 96 | let result = ''; 97 | 98 | // Iterate columns 99 | for(var i = 0; i < columns.length; i++) { 100 | // Get column 101 | const column = columns[i]; 102 | let value = column.getValue(); 103 | const maxLen = columnLengths[i] + ValuePadding.length + ColumnSeparator.length; 104 | 105 | // Upper-case transform this value? 106 | if (upperCaseValue) { 107 | value = value.toUpperCase(); 108 | } 109 | 110 | // Calculate left and right padding 111 | const isRightAligned = rightAlignNumbers && this.isNumberValue(value); 112 | const leftPaddingLength = useValuePadding ? (isRightAligned ? maxLen - value.length - 1 : 1) : 0; 113 | const rightPaddingLength = isRightAligned ? 0 : maxLen - (ValuePadding.length * 2) - value.length; 114 | 115 | // Start with column separator? 116 | if (i === 0) { 117 | result += ColumnSeparator; 118 | } 119 | 120 | // Write left padding 121 | result += this.getRepeatedChar(' ', leftPaddingLength); 122 | 123 | // Write value 124 | result += value; 125 | 126 | // Write right padding 127 | result += this.getRepeatedChar(' ', rightPaddingLength); 128 | 129 | // End with separator 130 | result += ValuePadding; 131 | 132 | // End with column separator 133 | result += ColumnSeparator; 134 | } 135 | 136 | return result; 137 | } 138 | 139 | /** 140 | * Calculate the maximum column lengths based on the provided Record set 141 | * @param records Record data to analyze 142 | */ 143 | private getColumnLengths(records: CsvRecord[]): any[] { 144 | // Calculate column lengths 145 | let columnLengths = []; 146 | for(var i = 0; i < records.length; i++) { 147 | const record = records[i]; 148 | const columns = record.getColumns(); 149 | 150 | for(var colIndex = 0; colIndex < columns.length; colIndex++) { 151 | const len = columns[colIndex].getValue().length; 152 | 153 | if (columnLengths[colIndex] === undefined || len > columnLengths[colIndex]) { 154 | columnLengths[colIndex] = len; 155 | } 156 | } 157 | } 158 | 159 | return columnLengths; 160 | } 161 | 162 | /** 163 | * Determine if the provided cell value appears to be a number 164 | * @param value string value to analyze 165 | */ 166 | private isNumberValue(value: string): boolean { 167 | // Early return 168 | if (value.length === 0) 169 | return false; 170 | 171 | // Look for number-like characters 172 | for(let i = 0; i < value.length; i++) { 173 | const char = value[i]; 174 | 175 | // Check for number signs 176 | if (char === '+' || char === '-' || char === ',' || char === '.') 177 | continue; 178 | 179 | // Check for digits 180 | if (char >= '0' && char <= '9') 181 | continue; 182 | 183 | // Not a number 184 | return false; 185 | } 186 | 187 | // Appears to be a number 188 | return true; 189 | } 190 | } 191 | -------------------------------------------------------------------------------- /src/extension.ts: -------------------------------------------------------------------------------- 1 | // The module 'vscode' contains the VS Code extensibility API 2 | // Import the module and reference it with the alias vscode in your code below 3 | import * as vscode from 'vscode'; 4 | import CsvParser from './CsvParser'; 5 | import TableWriter from './TableWriter'; 6 | import { sep } from 'path'; 7 | 8 | // this method is called when your extension is activated 9 | // your extension is activated the very first time the command is executed 10 | export function activate(context: vscode.ExtensionContext) { 11 | context.subscriptions.push(registerCsvToTableCommand(',', 'extension.csv-to-table.csv')); 12 | context.subscriptions.push(registerCsvToTableCommand('\t', 'extension.csv-to-table.tsv')); 13 | context.subscriptions.push(registerCsvToTableCommand('|', 'extension.csv-to-table.psv')); 14 | context.subscriptions.push(registerCsvToTableCommand(';', 'extension.csv-to-table.ssv')); 15 | context.subscriptions.push(registerCsvToTableCommand('' /* Custom */, 'extension.csv-to-table.custom')); 16 | } 17 | 18 | /** 19 | * Helper method to register different commands 20 | * @param separator Separator to register 21 | * @param commandName Name of the command we are registering 22 | */ 23 | function registerCsvToTableCommand(separator: string, commandName: string): vscode.Disposable { 24 | let disposable = vscode.commands.registerCommand(commandName, async function () { 25 | // Get the active text editor 26 | let editor = vscode.window.activeTextEditor; 27 | 28 | if (editor) { 29 | let document = editor.document; 30 | let selection = editor.selection; 31 | 32 | // Select full range if needed 33 | if (selection.isEmpty) { 34 | selection = new vscode.Selection(document.positionAt(0), document.positionAt(document.getText().length)); 35 | } 36 | 37 | // Get selected text 38 | let text = document.getText(selection); 39 | 40 | // Prompt for separator value if unset 41 | let separatorToUse = separator; 42 | if (separator === '') { 43 | const promptResult = await vscode.window.showInputBox({ 44 | placeHolder: 'Separator character (eg: ,)' 45 | }); 46 | 47 | // Bail out of user has pressed cancel 48 | if (promptResult === '' || promptResult === undefined) { 49 | return; 50 | } 51 | 52 | // Otherwise update separator 53 | separatorToUse = promptResult; 54 | } 55 | 56 | // Load settings 57 | const settings = vscode.workspace.getConfiguration('csv-to-table'); 58 | 59 | // Create parser 60 | let parser = new CsvParser(text, separatorToUse); 61 | let records = parser.getRecords(); 62 | 63 | let formatter = new TableWriter(); 64 | let formattedResult = formatter.getFormattedTable(records, settings.upperCaseHeader, settings.markdownFormat, settings.rightAlignNumbers); 65 | 66 | // Write result 67 | // Determine if we are going to replace current content, or open a new window 68 | if (settings.openGeneratedTableInNewEditor) { 69 | // Open new window 70 | const newDoc = await vscode.workspace.openTextDocument({ 71 | content: formattedResult, 72 | language: 'csv (pipe)' 73 | }); 74 | vscode.window.showTextDocument(newDoc, vscode.ViewColumn.Active); 75 | } else { 76 | // Edit existing window 77 | editor.edit(editBuilder => { 78 | editBuilder.replace(selection, formattedResult); 79 | }); 80 | } 81 | } 82 | }); 83 | 84 | return disposable; 85 | } 86 | 87 | // this method is called when your extension is deactivated 88 | export function deactivate() {} 89 | -------------------------------------------------------------------------------- /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 CsvParser from '../../CsvParser'; 7 | import TableWriter from '../../TableWriter'; 8 | 9 | suite('Extension Test Suite', () => { 10 | vscode.window.showInformationMessage('Start all tests.'); 11 | 12 | test('Can handle empty right aligned cell value', () => { 13 | // Arrange 14 | const parser = new CsvParser('2022,Name,Value\n"","",""', ','); 15 | const writer = new TableWriter(); 16 | 17 | // Act 18 | const records = parser.getRecords(); 19 | const result = writer.getFormattedTable(records, false, false, true); 20 | 21 | console.log(result); 22 | 23 | // Assert 24 | assert.equal(` 25 | |------|------|-------| 26 | | 2022 | Name | Value | 27 | |------|------|-------| 28 | | | | | 29 | |------|------|-------| 30 | `.trim(), result.replace(/\r?\n/g, "\n").trim()); 31 | }); 32 | 33 | test('Can right align cell values that contain numbers', () => { 34 | // Arrange 35 | const parser = new CsvParser('2022,Name,Value\nExample Value,Andrew,12345.67\nTest Value,Lisa,35\n123,John,"19.600,12"\nABC,Megan,"12.34,56"\n55,Alex,"1,234"\n-1,Plus Minus,+1.50', ','); 36 | const writer = new TableWriter(); 37 | 38 | // Act 39 | const records = parser.getRecords(); 40 | const result = writer.getFormattedTable(records, false, false, true); 41 | 42 | console.log(result); 43 | 44 | // Assert 45 | assert.equal(` 46 | |---------------|------------|-----------| 47 | | 2022 | Name | Value | 48 | |---------------|------------|-----------| 49 | | Example Value | Andrew | 12345.67 | 50 | |---------------|------------|-----------| 51 | | Test Value | Lisa | 35 | 52 | |---------------|------------|-----------| 53 | | 123 | John | 19.600,12 | 54 | |---------------|------------|-----------| 55 | | ABC | Megan | 12.34,56 | 56 | |---------------|------------|-----------| 57 | | 55 | Alex | 1,234 | 58 | |---------------|------------|-----------| 59 | | -1 | Plus Minus | +1.50 | 60 | |---------------|------------|-----------| 61 | `.trim(), result.replace(/\r?\n/g, "\n").trim()); 62 | }); 63 | 64 | test('Can write output using TableWriter (Markdowm output format)', () => { 65 | // Arrange 66 | const parser = new CsvParser('Name,Age\nAndrew,30\nLisa,35', ','); 67 | const writer = new TableWriter(); 68 | 69 | // Act 70 | const records = parser.getRecords(); 71 | const result = writer.getFormattedTable(records, false, true, false); 72 | 73 | // Assert 74 | assert.equal(` 75 | | Name | Age | 76 | |--------|-----| 77 | | Andrew | 30 | 78 | | Lisa | 35 | 79 | `.trim(), result.replace(/\r?\n/g, "\n").trim()); 80 | }); 81 | 82 | test('Can write output using TableWriter (upper-case headers)', () => { 83 | // Arrange 84 | const parser = new CsvParser('Name,Age\nAndrew,30', ','); 85 | const writer = new TableWriter(); 86 | 87 | // Act 88 | const records = parser.getRecords(); 89 | const result = writer.getFormattedTable(records, true, false, false); 90 | 91 | // Assert 92 | assert.equal(` 93 | |--------|-----| 94 | | NAME | AGE | 95 | |--------|-----| 96 | | Andrew | 30 | 97 | |--------|-----| 98 | `.trim(), result.replace(/\r?\n/g, "\n").trim()); 99 | }); 100 | 101 | test('Can write output using TableWriter', () => { 102 | // Arrange 103 | const parser = new CsvParser('Name,Age\nAndrew,30', ','); 104 | const writer = new TableWriter(); 105 | 106 | // Act 107 | const records = parser.getRecords(); 108 | const result = writer.getFormattedTable(records, false, false, false); 109 | 110 | // Assert 111 | assert.equal(` 112 | |--------|-----| 113 | | Name | Age | 114 | |--------|-----| 115 | | Andrew | 30 | 116 | |--------|-----| 117 | `.trim(), result.replace(/\r?\n/g, "\n").trim()); 118 | }); 119 | 120 | test('Can handle leading spaces before quotes in column value', () => { 121 | // Arrange 122 | const parser = new CsvParser('1, "two" ,"three"', ','); 123 | 124 | // Act 125 | const records = parser.getRecords(); 126 | const record = records[0]; 127 | const columns = record.getColumns(); 128 | 129 | // Assert 130 | assert.equal(1, records.length); 131 | assert.equal(3, columns.length); 132 | 133 | // Validate records 134 | assert.equal("1", columns[0].getValue()); 135 | assert.equal("two", columns[1].getValue()); 136 | assert.equal("three", columns[2].getValue()); 137 | }); 138 | 139 | test('Can handle blank value in last column', () => { 140 | // Arrange 141 | const parser = new CsvParser('1,', ','); 142 | 143 | // Act 144 | const records = parser.getRecords(); 145 | const record = records[0]; 146 | const columns = record.getColumns(); 147 | 148 | // Assert 149 | assert.equal(1, records.length); 150 | assert.equal(2, columns.length); 151 | 152 | // Validate records 153 | assert.equal("1", columns[0].getValue()); 154 | assert.equal("", columns[1].getValue()); 155 | }); 156 | 157 | test('Can handle blank value in last column in two record CSV', () => { 158 | // Arrange 159 | const parser = new CsvParser("1,\r\n3,4", ','); 160 | 161 | // Act 162 | const records = parser.getRecords(); 163 | const record = records[0]; 164 | const columns = record.getColumns(); 165 | 166 | // Assert 167 | assert.equal(2, records.length); 168 | assert.equal(2, columns.length); 169 | 170 | // Validate records 171 | assert.equal("1", columns[0].getValue()); 172 | assert.equal("", columns[1].getValue()); 173 | }); 174 | 175 | test('Can handle blank value in first column', () => { 176 | // Arrange 177 | const parser = new CsvParser(',2', ','); 178 | 179 | // Act 180 | const records = parser.getRecords(); 181 | const record = records[0]; 182 | const columns = record.getColumns(); 183 | 184 | // Assert 185 | assert.equal(1, records.length); 186 | assert.equal(2, columns.length); 187 | 188 | // Validate records 189 | assert.equal("", columns[0].getValue()); 190 | assert.equal("2", columns[1].getValue()); 191 | }); 192 | 193 | test('Can handle blank value in middle column', () => { 194 | // Arrange 195 | const parser = new CsvParser('1,,3', ','); 196 | 197 | // Act 198 | const records = parser.getRecords(); 199 | const record = records[0]; 200 | const columns = record.getColumns(); 201 | 202 | // Assert 203 | assert.equal(1, records.length); 204 | assert.equal(3, columns.length); 205 | 206 | // Validate records 207 | assert.equal("1", columns[0].getValue()); 208 | assert.equal("", columns[1].getValue()); 209 | assert.equal("3", columns[2].getValue()); 210 | }); 211 | 212 | test('Can parse using space as separator', () => { 213 | // Arrange 214 | const parser = new CsvParser('1 "quoted with space" 3', ' '); 215 | 216 | // Act 217 | const records = parser.getRecords(); 218 | const record = records[0]; 219 | const columns = record.getColumns(); 220 | 221 | // Assert 222 | assert.equal(1, records.length); 223 | assert.equal(3, columns.length); 224 | 225 | // Validate records 226 | assert.equal("1", columns[0].getValue()); 227 | assert.equal("quoted with space", columns[1].getValue()); 228 | assert.equal("3", columns[2].getValue()); 229 | }); 230 | 231 | test('Can parse simple CSV', () => { 232 | // Arrange 233 | const parser = new CsvParser('1,2,3', ','); 234 | 235 | // Act 236 | const records = parser.getRecords(); 237 | const record = records[0]; 238 | const columns = record.getColumns(); 239 | 240 | // Assert 241 | assert.equal(1, records.length); 242 | assert.equal(3, columns.length); 243 | 244 | // Validate records 245 | assert.equal("1", columns[0].getValue()); 246 | assert.equal("2", columns[1].getValue()); 247 | assert.equal("3", columns[2].getValue()); 248 | }); 249 | 250 | test('Can parse simple PSV', () => { 251 | // Arrange 252 | const parser = new CsvParser('1|2|3', '|'); 253 | 254 | // Act 255 | const records = parser.getRecords(); 256 | const record = records[0]; 257 | const columns = record.getColumns(); 258 | 259 | // Assert 260 | assert.equal(1, records.length); 261 | assert.equal(3, columns.length); 262 | 263 | // Validate records 264 | assert.equal("1", columns[0].getValue()); 265 | assert.equal("2", columns[1].getValue()); 266 | assert.equal("3", columns[2].getValue()); 267 | }); 268 | 269 | test('Can parse simple Semi-Colon SSV', () => { 270 | // Arrange 271 | const parser = new CsvParser('1;2;3', ';'); 272 | 273 | // Act 274 | const records = parser.getRecords(); 275 | const record = records[0]; 276 | const columns = record.getColumns(); 277 | 278 | // Assert 279 | assert.equal(1, records.length); 280 | assert.equal(3, columns.length); 281 | 282 | // Validate records 283 | assert.equal("1", columns[0].getValue()); 284 | assert.equal("2", columns[1].getValue()); 285 | assert.equal("3", columns[2].getValue()); 286 | }); 287 | 288 | test('Can parse simple TSV', () => { 289 | // Arrange 290 | const parser = new CsvParser("1\t2\t3", '\t'); 291 | 292 | // Act 293 | const records = parser.getRecords(); 294 | const record = records[0]; 295 | const columns = record.getColumns(); 296 | 297 | // Assert 298 | assert.equal(1, records.length); 299 | assert.equal(3, columns.length); 300 | 301 | // Validate records 302 | assert.equal("1", columns[0].getValue()); 303 | assert.equal("2", columns[1].getValue()); 304 | assert.equal("3", columns[2].getValue()); 305 | }); 306 | 307 | test('Can parse simple TSV and commas', () => { 308 | // Arrange 309 | const parser = new CsvParser("1\tshould,be,ignored\t3", '\t'); 310 | 311 | // Act 312 | const records = parser.getRecords(); 313 | const record = records[0]; 314 | const columns = record.getColumns(); 315 | 316 | // Assert 317 | assert.equal(1, records.length); 318 | assert.equal(3, columns.length); 319 | 320 | // Validate records 321 | assert.equal("1", columns[0].getValue()); 322 | assert.equal("should,be,ignored", columns[1].getValue()); 323 | assert.equal("3", columns[2].getValue()); 324 | }); 325 | 326 | test('Can parse double quoted value', () => { 327 | // Arrange 328 | const parser = new CsvParser('1,"This is a ""quoted"" word",3', ','); 329 | 330 | // Act 331 | const records = parser.getRecords(); 332 | const record = records[0]; 333 | const columns = record.getColumns(); 334 | 335 | // Assert 336 | assert.equal(1, records.length); 337 | assert.equal(3, columns.length); 338 | 339 | // Validate records 340 | assert.equal("1", columns[0].getValue()); 341 | assert.equal('This is a "quoted" word', columns[1].getValue()); 342 | assert.equal("3", columns[2].getValue()); 343 | }); 344 | 345 | test('Can parse repeated double quoted value', () => { 346 | // Arrange 347 | const parser = new CsvParser('1,"This is a """"quoted"""""" word",3', ','); 348 | 349 | // Act 350 | const records = parser.getRecords(); 351 | const record = records[0]; 352 | const columns = record.getColumns(); 353 | 354 | // Assert 355 | assert.equal(1, records.length); 356 | assert.equal(3, columns.length); 357 | 358 | // Validate records 359 | assert.equal("1", columns[0].getValue()); 360 | assert.equal('This is a ""quoted""" word', columns[1].getValue()); 361 | assert.equal("3", columns[2].getValue()); 362 | }); 363 | 364 | test('Can parse quoted value CSV', () => { 365 | // Arrange 366 | const parser = new CsvParser('1,"hello world","with a, comma"', ','); 367 | 368 | // Act 369 | const records = parser.getRecords(); 370 | const record = records[0]; 371 | const columns = record.getColumns(); 372 | 373 | // Assert 374 | assert.equal(1, records.length); 375 | assert.equal(3, columns.length); 376 | 377 | // Validate records 378 | assert.equal("1", columns[0].getValue()); 379 | assert.equal("hello world", columns[1].getValue()); 380 | assert.equal("with a, comma", columns[2].getValue()); 381 | }); 382 | 383 | test('Can parse single column CSV', () => { 384 | // Arrange 385 | const parser = new CsvParser('1', ','); 386 | 387 | // Act 388 | const records = parser.getRecords(); 389 | const record = records[0]; 390 | const columns = record.getColumns(); 391 | 392 | // Assert 393 | assert.equal(1, records.length); 394 | assert.equal(1, columns.length); 395 | 396 | // Validate records 397 | assert.equal("1", columns[0].getValue()); 398 | }); 399 | 400 | test('Can interpret new line in quoted column as value', () => { 401 | // Arrange 402 | const parser = new CsvParser("\"first\r\ncolumn\",second column", ','); 403 | 404 | // Act 405 | const records = parser.getRecords(); 406 | const record = records[0]; 407 | const columns = record.getColumns(); 408 | 409 | // Assert 410 | assert.equal(1, records.length); 411 | assert.equal(2, columns.length); 412 | 413 | // Validate records 414 | assert.equal("first\r\ncolumn", columns[0].getValue()); 415 | assert.equal("second column", columns[1].getValue()); 416 | }); 417 | 418 | test('Can parse multi-line CSV', () => { 419 | // Arrange 420 | const parser = new CsvParser("a,b\r\nc,\"quoted\"", ','); 421 | 422 | // Act 423 | const records = parser.getRecords(); 424 | const columns1 = records[0].getColumns(); 425 | const columns2 = records[1].getColumns(); 426 | 427 | // Assert 428 | assert.equal(2, records.length); 429 | assert.equal(2, columns1.length); 430 | assert.equal(2, columns2.length); 431 | 432 | // Validate records 433 | assert.equal("a", columns1[0].getValue()); 434 | assert.equal("b", columns1[1].getValue()); 435 | 436 | assert.equal("c", columns2[0].getValue()); 437 | assert.equal("quoted", columns2[1].getValue()); 438 | }); 439 | }); 440 | -------------------------------------------------------------------------------- /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 | e(err); 34 | } 35 | }); 36 | }); 37 | } 38 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "target": "es6", 5 | "outDir": "out", 6 | "lib": [ 7 | "es6" 8 | ], 9 | "sourceMap": true, 10 | "rootDir": "src", 11 | "strict": true /* enable all strict type-checking options */ 12 | /* Additional Checks */ 13 | // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ 14 | // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ 15 | // "noUnusedParameters": true, /* Report errors on unused parameters. */ 16 | }, 17 | "exclude": [ 18 | "node_modules", 19 | ".vscode-test" 20 | ] 21 | } 22 | -------------------------------------------------------------------------------- /tslint.json: -------------------------------------------------------------------------------- 1 | { 2 | "rules": { 3 | "no-string-throw": true, 4 | "no-unused-expression": true, 5 | "no-duplicate-variable": true, 6 | "curly": true, 7 | "class-name": true, 8 | "semicolon": [ 9 | true, 10 | "always" 11 | ], 12 | "triple-equals": true 13 | }, 14 | "defaultSeverity": "warning" 15 | } 16 | -------------------------------------------------------------------------------- /vsc-extension-quickstart.md: -------------------------------------------------------------------------------- 1 | # Welcome to your VS Code Extension 2 | 3 | ## What's in the folder 4 | 5 | * This folder contains all of the files necessary for your extension. 6 | * `package.json` - this is the manifest file in which you declare your extension and command. 7 | * The sample plugin registers a command and defines its title and command name. With this information VS Code can show the command in the command palette. It doesn’t yet need to load the plugin. 8 | * `src/extension.ts` - this is the main file where you will provide the implementation of your command. 9 | * The file exports one function, `activate`, which is called the very first time your extension is activated (in this case by executing the command). Inside the `activate` function we call `registerCommand`. 10 | * We pass the function containing the implementation of the command as the second parameter to `registerCommand`. 11 | 12 | ## Get up and running straight away 13 | 14 | * Press `F5` to open a new window with your extension loaded. 15 | * Run your command from the command palette by pressing (`Ctrl+Shift+P` or `Cmd+Shift+P` on Mac) and typing `Hello World`. 16 | * Set breakpoints in your code inside `src/extension.ts` to debug your extension. 17 | * Find output from your extension in the debug console. 18 | 19 | ## Make changes 20 | 21 | * You can relaunch the extension from the debug toolbar after changing code in `src/extension.ts`. 22 | * You can also reload (`Ctrl+R` or `Cmd+R` on Mac) the VS Code window with your extension to load your changes. 23 | 24 | 25 | ## Explore the API 26 | 27 | * You can open the full set of our API when you open the file `node_modules/@types/vscode/index.d.ts`. 28 | 29 | ## Run tests 30 | 31 | * Open the debug viewlet (`Ctrl+Shift+D` or `Cmd+Shift+D` on Mac) and from the launch configuration dropdown pick `Extension Tests`. 32 | * Press `F5` to run the tests in a new window with your extension loaded. 33 | * See the output of the test result in the debug console. 34 | * Make changes to `src/test/suite/extension.test.ts` or create new test files inside the `test/suite` folder. 35 | * The provided test runner will only consider files matching the name pattern `**.test.ts`. 36 | * You can create folders inside the `test` folder to structure your tests any way you want. 37 | 38 | ## Go further 39 | 40 | * Reduce the extension size and improve the startup time by [bundling your extension](https://code.visualstudio.com/api/working-with-extensions/bundling-extension). 41 | * [Publish your extension](https://code.visualstudio.com/api/working-with-extensions/publishing-extension) on the VSCode extension marketplace. 42 | * Automate builds by setting up [Continuous Integration](https://code.visualstudio.com/api/working-with-extensions/continuous-integration). 43 | --------------------------------------------------------------------------------