├── .eslintrc.json ├── .github └── workflows │ └── ci.yaml ├── .gitignore ├── .vscode ├── extensions.json └── launch.json ├── .vscodeignore ├── CHANGELOG.md ├── LICENSE ├── README.md ├── icon.png ├── jsconfig.json ├── package-lock.json ├── package.json ├── schemas └── dspf.code-snippets ├── src ├── dspf.js ├── extension.js ├── indicators.js ├── lensProvider.js ├── render.js └── window.js └── test ├── file ├── depts.js ├── issue1149.js ├── issue1382.js └── replloadfm.js ├── index.js └── tests.js /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "env": { 3 | "browser": false, 4 | "commonjs": true, 5 | "es6": true, 6 | "node": true, 7 | "mocha": true 8 | }, 9 | "parserOptions": { 10 | "ecmaVersion": 2018, 11 | "ecmaFeatures": { 12 | "jsx": true 13 | }, 14 | "sourceType": "module" 15 | }, 16 | "rules": { 17 | "indent": ["warn", 2], 18 | "no-const-assign": "warn", 19 | "no-this-before-super": "warn", 20 | "no-undef": "warn", 21 | "no-unreachable": "warn", 22 | "no-unused-vars": "warn", 23 | "constructor-super": "warn", 24 | "valid-typeof": "warn" 25 | } 26 | } 27 | -------------------------------------------------------------------------------- /.github/workflows/ci.yaml: -------------------------------------------------------------------------------- 1 | on: 2 | release: 3 | types: [created] 4 | 5 | jobs: 6 | release: 7 | name: Release and publish 8 | runs-on: ubuntu-latest 9 | steps: 10 | - uses: actions/setup-node@v2 11 | with: 12 | node-version: '16' 13 | - uses: actions/checkout@v2 14 | 15 | - run: npm install 16 | 17 | - run: npm install -g vsce ovsx 18 | 19 | - name: Publish to Marketplace 20 | run: vsce publish -p $PUBLISHER_TOKEN 21 | env: 22 | PUBLISHER_TOKEN: ${{ secrets.PUBLISHER_TOKEN }} 23 | 24 | - name: Publish to Open VSX 25 | run: npx ovsx publish -p ${{ secrets.OPENVSX_TOKEN }} 26 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | dist 3 | *.vsix -------------------------------------------------------------------------------- /.vscode/extensions.json: -------------------------------------------------------------------------------- 1 | { 2 | // See https://go.microsoft.com/fwlink/?LinkId=733558 3 | // for the documentation about the extensions.json format 4 | "recommendations": [ 5 | "dbaeumer.vscode-eslint" 6 | ] 7 | } -------------------------------------------------------------------------------- /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | // A launch configuration that launches the extension inside a new window 2 | // Use IntelliSense to learn about possible attributes. 3 | // Hover to view descriptions of existing attributes. 4 | // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 5 | { 6 | "version": "0.2.0", 7 | "configurations": [ 8 | { 9 | "name": "Launch Tests", 10 | "program": "${workspaceFolder}/test/index.js", 11 | "request": "launch", 12 | "skipFiles": [ 13 | "/**" 14 | ], 15 | "type": "node" 16 | }, 17 | { 18 | "name": "Run Extension", 19 | "type": "extensionHost", 20 | "request": "launch", 21 | "args": [ 22 | "--extensionDevelopmentPath=${workspaceFolder}" 23 | ] 24 | }, 25 | 26 | ] 27 | } 28 | -------------------------------------------------------------------------------- /.vscodeignore: -------------------------------------------------------------------------------- 1 | .vscode/** 2 | .vscode-test/** 3 | test/** 4 | .gitignore 5 | .yarnrc 6 | vsc-extension-quickstart.md 7 | **/jsconfig.json 8 | **/*.map 9 | **/.eslintrc.json 10 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # Change Log 2 | 3 | All notable changes to the "vscode-displayfile" extension will be documented in this file. 4 | 5 | Check [Keep a Changelog](http://keepachangelog.com/) for recommendations on how to structure this file. 6 | 7 | ## [Unreleased] 8 | 9 | - Initial release -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2022 Halcyon Tech Ltd 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 | ## vscode-displayfile 2 | 3 | A display and printer file renderer for Visual Studio Code. In preview. Not perfected. 4 | 5 | * Provides a Code Lens on `dds.dspf` and `dds.prtf` to let the user render all or a specific record format into a new tab. 6 | * Configurable option to change preview update rate. Default is 1.5 seconds. 7 | 8 | ![image](https://user-images.githubusercontent.com/3708366/147897988-c9f9f3cd-11ca-485b-a698-a8a55a5bafc7.png) 9 | -------------------------------------------------------------------------------- /icon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/codefori/vscode-displayfile/e0fbc7100b5eb2a4951a826833e46c3bd06d4072/icon.png -------------------------------------------------------------------------------- /jsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "module": "commonjs", 4 | "target": "ES2020", 5 | "checkJs": true, /* Typecheck .js files. */ 6 | "lib": [ 7 | "ES2020" 8 | ] 9 | }, 10 | "exclude": [ 11 | "node_modules" 12 | ] 13 | } 14 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "vscode-displayfile", 3 | "version": "0.0.1", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "version": "0.0.1", 9 | "devDependencies": { 10 | "@types/glob": "^7.1.4", 11 | "@types/mocha": "^9.0.0", 12 | "@types/node": "14.x", 13 | "@types/vscode": "^1.63.0", 14 | "@vscode/test-electron": "^1.6.2", 15 | "eslint": "^8.6.0", 16 | "glob": "^7.1.7", 17 | "mocha": "^9.1.3", 18 | "typescript": "^4.4.4" 19 | }, 20 | "engines": { 21 | "vscode": "^1.63.0" 22 | } 23 | }, 24 | "node_modules/@eslint/eslintrc": { 25 | "version": "1.0.5", 26 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.0.5.tgz", 27 | "integrity": "sha512-BLxsnmK3KyPunz5wmCCpqy0YelEoxxGmH73Is+Z74oOTMtExcjkr3dDR6quwrjh1YspA8DH9gnX1o069KiS9AQ==", 28 | "dev": true, 29 | "dependencies": { 30 | "ajv": "^6.12.4", 31 | "debug": "^4.3.2", 32 | "espree": "^9.2.0", 33 | "globals": "^13.9.0", 34 | "ignore": "^4.0.6", 35 | "import-fresh": "^3.2.1", 36 | "js-yaml": "^4.1.0", 37 | "minimatch": "^3.0.4", 38 | "strip-json-comments": "^3.1.1" 39 | }, 40 | "engines": { 41 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 42 | } 43 | }, 44 | "node_modules/@humanwhocodes/config-array": { 45 | "version": "0.9.2", 46 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.9.2.tgz", 47 | "integrity": "sha512-UXOuFCGcwciWckOpmfKDq/GyhlTf9pN/BzG//x8p8zTOFEcGuA68ANXheFS0AGvy3qgZqLBUkMs7hqzqCKOVwA==", 48 | "dev": true, 49 | "dependencies": { 50 | "@humanwhocodes/object-schema": "^1.2.1", 51 | "debug": "^4.1.1", 52 | "minimatch": "^3.0.4" 53 | }, 54 | "engines": { 55 | "node": ">=10.10.0" 56 | } 57 | }, 58 | "node_modules/@humanwhocodes/object-schema": { 59 | "version": "1.2.1", 60 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 61 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 62 | "dev": true 63 | }, 64 | "node_modules/@tootallnate/once": { 65 | "version": "1.1.2", 66 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 67 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", 68 | "dev": true, 69 | "engines": { 70 | "node": ">= 6" 71 | } 72 | }, 73 | "node_modules/@types/glob": { 74 | "version": "7.2.0", 75 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.2.0.tgz", 76 | "integrity": "sha512-ZUxbzKl0IfJILTS6t7ip5fQQM/J3TJYubDm3nMbgubNNYS62eXeUpoLUC8/7fJNiFYHTrGPQn7hspDUzIHX3UA==", 77 | "dev": true, 78 | "dependencies": { 79 | "@types/minimatch": "*", 80 | "@types/node": "*" 81 | } 82 | }, 83 | "node_modules/@types/minimatch": { 84 | "version": "3.0.5", 85 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.5.tgz", 86 | "integrity": "sha512-Klz949h02Gz2uZCMGwDUSDS1YBlTdDDgbWHi+81l29tQALUtvz4rAYi5uoVhE5Lagoq6DeqAUlbrHvW/mXDgdQ==", 87 | "dev": true 88 | }, 89 | "node_modules/@types/mocha": { 90 | "version": "9.0.0", 91 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-9.0.0.tgz", 92 | "integrity": "sha512-scN0hAWyLVAvLR9AyW7HoFF5sJZglyBsbPuHO4fv7JRvfmPBMfp1ozWqOf/e4wwPNxezBZXRfWzMb6iFLgEVRA==", 93 | "dev": true 94 | }, 95 | "node_modules/@types/node": { 96 | "version": "14.18.4", 97 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.18.4.tgz", 98 | "integrity": "sha512-swe3lD4izOJWHuxvsZdDFRq6S9i6koJsXOnQKYekhSO5JTizMVirUFgY/bUsaOJQj8oSD4oxmRYPBM/0b6jpdw==", 99 | "dev": true 100 | }, 101 | "node_modules/@types/vscode": { 102 | "version": "1.63.1", 103 | "resolved": "https://registry.npmjs.org/@types/vscode/-/vscode-1.63.1.tgz", 104 | "integrity": "sha512-Z+ZqjRcnGfHP86dvx/BtSwWyZPKQ/LBdmAVImY82TphyjOw2KgTKcp7Nx92oNwCTsHzlshwexAG/WiY2JuUm3g==", 105 | "dev": true 106 | }, 107 | "node_modules/@ungap/promise-all-settled": { 108 | "version": "1.1.2", 109 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 110 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 111 | "dev": true 112 | }, 113 | "node_modules/@vscode/test-electron": { 114 | "version": "1.6.2", 115 | "resolved": "https://registry.npmjs.org/@vscode/test-electron/-/test-electron-1.6.2.tgz", 116 | "integrity": "sha512-W01ajJEMx6223Y7J5yaajGjVs1QfW3YGkkOJHVKfAMEqNB1ZHN9wCcViehv5ZwVSSJnjhu6lYEYgwBdHtCxqhQ==", 117 | "dev": true, 118 | "dependencies": { 119 | "http-proxy-agent": "^4.0.1", 120 | "https-proxy-agent": "^5.0.0", 121 | "rimraf": "^3.0.2", 122 | "unzipper": "^0.10.11" 123 | }, 124 | "engines": { 125 | "node": ">=8.9.3" 126 | } 127 | }, 128 | "node_modules/acorn": { 129 | "version": "8.7.0", 130 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.0.tgz", 131 | "integrity": "sha512-V/LGr1APy+PXIwKebEWrkZPwoeoF+w1jiOBUmuxuiUIaOHtob8Qc9BTrYo7VuI5fR8tqsy+buA2WFooR5olqvQ==", 132 | "dev": true, 133 | "bin": { 134 | "acorn": "bin/acorn" 135 | }, 136 | "engines": { 137 | "node": ">=0.4.0" 138 | } 139 | }, 140 | "node_modules/acorn-jsx": { 141 | "version": "5.3.2", 142 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 143 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 144 | "dev": true, 145 | "peerDependencies": { 146 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 147 | } 148 | }, 149 | "node_modules/agent-base": { 150 | "version": "6.0.2", 151 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 152 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 153 | "dev": true, 154 | "dependencies": { 155 | "debug": "4" 156 | }, 157 | "engines": { 158 | "node": ">= 6.0.0" 159 | } 160 | }, 161 | "node_modules/ajv": { 162 | "version": "6.12.6", 163 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 164 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 165 | "dev": true, 166 | "dependencies": { 167 | "fast-deep-equal": "^3.1.1", 168 | "fast-json-stable-stringify": "^2.0.0", 169 | "json-schema-traverse": "^0.4.1", 170 | "uri-js": "^4.2.2" 171 | }, 172 | "funding": { 173 | "type": "github", 174 | "url": "https://github.com/sponsors/epoberezkin" 175 | } 176 | }, 177 | "node_modules/ansi-colors": { 178 | "version": "4.1.1", 179 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 180 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 181 | "dev": true, 182 | "engines": { 183 | "node": ">=6" 184 | } 185 | }, 186 | "node_modules/ansi-regex": { 187 | "version": "5.0.1", 188 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 189 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 190 | "dev": true, 191 | "engines": { 192 | "node": ">=8" 193 | } 194 | }, 195 | "node_modules/ansi-styles": { 196 | "version": "4.3.0", 197 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 198 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 199 | "dev": true, 200 | "dependencies": { 201 | "color-convert": "^2.0.1" 202 | }, 203 | "engines": { 204 | "node": ">=8" 205 | }, 206 | "funding": { 207 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 208 | } 209 | }, 210 | "node_modules/anymatch": { 211 | "version": "3.1.2", 212 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 213 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 214 | "dev": true, 215 | "dependencies": { 216 | "normalize-path": "^3.0.0", 217 | "picomatch": "^2.0.4" 218 | }, 219 | "engines": { 220 | "node": ">= 8" 221 | } 222 | }, 223 | "node_modules/argparse": { 224 | "version": "2.0.1", 225 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 226 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 227 | "dev": true 228 | }, 229 | "node_modules/balanced-match": { 230 | "version": "1.0.2", 231 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 232 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 233 | "dev": true 234 | }, 235 | "node_modules/big-integer": { 236 | "version": "1.6.51", 237 | "resolved": "https://registry.npmjs.org/big-integer/-/big-integer-1.6.51.tgz", 238 | "integrity": "sha512-GPEid2Y9QU1Exl1rpO9B2IPJGHPSupF5GnVIP0blYvNOMer2bTvSWs1jGOUg04hTmu67nmLsQ9TBo1puaotBHg==", 239 | "dev": true, 240 | "engines": { 241 | "node": ">=0.6" 242 | } 243 | }, 244 | "node_modules/binary": { 245 | "version": "0.3.0", 246 | "resolved": "https://registry.npmjs.org/binary/-/binary-0.3.0.tgz", 247 | "integrity": "sha1-n2BVO8XOjDOG87VTz/R0Yq3sqnk=", 248 | "dev": true, 249 | "dependencies": { 250 | "buffers": "~0.1.1", 251 | "chainsaw": "~0.1.0" 252 | }, 253 | "engines": { 254 | "node": "*" 255 | } 256 | }, 257 | "node_modules/binary-extensions": { 258 | "version": "2.2.0", 259 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 260 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 261 | "dev": true, 262 | "engines": { 263 | "node": ">=8" 264 | } 265 | }, 266 | "node_modules/bluebird": { 267 | "version": "3.4.7", 268 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.4.7.tgz", 269 | "integrity": "sha1-9y12C+Cbf3bQjtj66Ysomo0F+rM=", 270 | "dev": true 271 | }, 272 | "node_modules/brace-expansion": { 273 | "version": "1.1.11", 274 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 275 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 276 | "dev": true, 277 | "dependencies": { 278 | "balanced-match": "^1.0.0", 279 | "concat-map": "0.0.1" 280 | } 281 | }, 282 | "node_modules/braces": { 283 | "version": "3.0.2", 284 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 285 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 286 | "dev": true, 287 | "dependencies": { 288 | "fill-range": "^7.0.1" 289 | }, 290 | "engines": { 291 | "node": ">=8" 292 | } 293 | }, 294 | "node_modules/browser-stdout": { 295 | "version": "1.3.1", 296 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 297 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 298 | "dev": true 299 | }, 300 | "node_modules/buffer-indexof-polyfill": { 301 | "version": "1.0.2", 302 | "resolved": "https://registry.npmjs.org/buffer-indexof-polyfill/-/buffer-indexof-polyfill-1.0.2.tgz", 303 | "integrity": "sha512-I7wzHwA3t1/lwXQh+A5PbNvJxgfo5r3xulgpYDB5zckTu/Z9oUK9biouBKQUjEqzaz3HnAT6TYoovmE+GqSf7A==", 304 | "dev": true, 305 | "engines": { 306 | "node": ">=0.10" 307 | } 308 | }, 309 | "node_modules/buffers": { 310 | "version": "0.1.1", 311 | "resolved": "https://registry.npmjs.org/buffers/-/buffers-0.1.1.tgz", 312 | "integrity": "sha1-skV5w77U1tOWru5tmorn9Ugqt7s=", 313 | "dev": true, 314 | "engines": { 315 | "node": ">=0.2.0" 316 | } 317 | }, 318 | "node_modules/callsites": { 319 | "version": "3.1.0", 320 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 321 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 322 | "dev": true, 323 | "engines": { 324 | "node": ">=6" 325 | } 326 | }, 327 | "node_modules/camelcase": { 328 | "version": "6.3.0", 329 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 330 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 331 | "dev": true, 332 | "engines": { 333 | "node": ">=10" 334 | }, 335 | "funding": { 336 | "url": "https://github.com/sponsors/sindresorhus" 337 | } 338 | }, 339 | "node_modules/chainsaw": { 340 | "version": "0.1.0", 341 | "resolved": "https://registry.npmjs.org/chainsaw/-/chainsaw-0.1.0.tgz", 342 | "integrity": "sha1-XqtQsor+WAdNDVgpE4iCi15fvJg=", 343 | "dev": true, 344 | "dependencies": { 345 | "traverse": ">=0.3.0 <0.4" 346 | }, 347 | "engines": { 348 | "node": "*" 349 | } 350 | }, 351 | "node_modules/chalk": { 352 | "version": "4.1.2", 353 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 354 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 355 | "dev": true, 356 | "dependencies": { 357 | "ansi-styles": "^4.1.0", 358 | "supports-color": "^7.1.0" 359 | }, 360 | "engines": { 361 | "node": ">=10" 362 | }, 363 | "funding": { 364 | "url": "https://github.com/chalk/chalk?sponsor=1" 365 | } 366 | }, 367 | "node_modules/chokidar": { 368 | "version": "3.5.2", 369 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz", 370 | "integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==", 371 | "dev": true, 372 | "dependencies": { 373 | "anymatch": "~3.1.2", 374 | "braces": "~3.0.2", 375 | "glob-parent": "~5.1.2", 376 | "is-binary-path": "~2.1.0", 377 | "is-glob": "~4.0.1", 378 | "normalize-path": "~3.0.0", 379 | "readdirp": "~3.6.0" 380 | }, 381 | "engines": { 382 | "node": ">= 8.10.0" 383 | }, 384 | "optionalDependencies": { 385 | "fsevents": "~2.3.2" 386 | } 387 | }, 388 | "node_modules/chokidar/node_modules/glob-parent": { 389 | "version": "5.1.2", 390 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 391 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 392 | "dev": true, 393 | "dependencies": { 394 | "is-glob": "^4.0.1" 395 | }, 396 | "engines": { 397 | "node": ">= 6" 398 | } 399 | }, 400 | "node_modules/cliui": { 401 | "version": "7.0.4", 402 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 403 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 404 | "dev": true, 405 | "dependencies": { 406 | "string-width": "^4.2.0", 407 | "strip-ansi": "^6.0.0", 408 | "wrap-ansi": "^7.0.0" 409 | } 410 | }, 411 | "node_modules/color-convert": { 412 | "version": "2.0.1", 413 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 414 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 415 | "dev": true, 416 | "dependencies": { 417 | "color-name": "~1.1.4" 418 | }, 419 | "engines": { 420 | "node": ">=7.0.0" 421 | } 422 | }, 423 | "node_modules/color-name": { 424 | "version": "1.1.4", 425 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 426 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 427 | "dev": true 428 | }, 429 | "node_modules/concat-map": { 430 | "version": "0.0.1", 431 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 432 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 433 | "dev": true 434 | }, 435 | "node_modules/core-util-is": { 436 | "version": "1.0.3", 437 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", 438 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", 439 | "dev": true 440 | }, 441 | "node_modules/cross-spawn": { 442 | "version": "7.0.3", 443 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 444 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 445 | "dev": true, 446 | "dependencies": { 447 | "path-key": "^3.1.0", 448 | "shebang-command": "^2.0.0", 449 | "which": "^2.0.1" 450 | }, 451 | "engines": { 452 | "node": ">= 8" 453 | } 454 | }, 455 | "node_modules/debug": { 456 | "version": "4.3.3", 457 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", 458 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", 459 | "dev": true, 460 | "dependencies": { 461 | "ms": "2.1.2" 462 | }, 463 | "engines": { 464 | "node": ">=6.0" 465 | }, 466 | "peerDependenciesMeta": { 467 | "supports-color": { 468 | "optional": true 469 | } 470 | } 471 | }, 472 | "node_modules/decamelize": { 473 | "version": "4.0.0", 474 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 475 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 476 | "dev": true, 477 | "engines": { 478 | "node": ">=10" 479 | }, 480 | "funding": { 481 | "url": "https://github.com/sponsors/sindresorhus" 482 | } 483 | }, 484 | "node_modules/deep-is": { 485 | "version": "0.1.4", 486 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 487 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 488 | "dev": true 489 | }, 490 | "node_modules/diff": { 491 | "version": "5.0.0", 492 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 493 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 494 | "dev": true, 495 | "engines": { 496 | "node": ">=0.3.1" 497 | } 498 | }, 499 | "node_modules/doctrine": { 500 | "version": "3.0.0", 501 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 502 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 503 | "dev": true, 504 | "dependencies": { 505 | "esutils": "^2.0.2" 506 | }, 507 | "engines": { 508 | "node": ">=6.0.0" 509 | } 510 | }, 511 | "node_modules/duplexer2": { 512 | "version": "0.1.4", 513 | "resolved": "https://registry.npmjs.org/duplexer2/-/duplexer2-0.1.4.tgz", 514 | "integrity": "sha1-ixLauHjA1p4+eJEFFmKjL8a93ME=", 515 | "dev": true, 516 | "dependencies": { 517 | "readable-stream": "^2.0.2" 518 | } 519 | }, 520 | "node_modules/emoji-regex": { 521 | "version": "8.0.0", 522 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 523 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 524 | "dev": true 525 | }, 526 | "node_modules/enquirer": { 527 | "version": "2.3.6", 528 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 529 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 530 | "dev": true, 531 | "dependencies": { 532 | "ansi-colors": "^4.1.1" 533 | }, 534 | "engines": { 535 | "node": ">=8.6" 536 | } 537 | }, 538 | "node_modules/escalade": { 539 | "version": "3.1.1", 540 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 541 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 542 | "dev": true, 543 | "engines": { 544 | "node": ">=6" 545 | } 546 | }, 547 | "node_modules/escape-string-regexp": { 548 | "version": "4.0.0", 549 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 550 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 551 | "dev": true, 552 | "engines": { 553 | "node": ">=10" 554 | }, 555 | "funding": { 556 | "url": "https://github.com/sponsors/sindresorhus" 557 | } 558 | }, 559 | "node_modules/eslint": { 560 | "version": "8.6.0", 561 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.6.0.tgz", 562 | "integrity": "sha512-UvxdOJ7mXFlw7iuHZA4jmzPaUqIw54mZrv+XPYKNbKdLR0et4rf60lIZUU9kiNtnzzMzGWxMV+tQ7uG7JG8DPw==", 563 | "dev": true, 564 | "dependencies": { 565 | "@eslint/eslintrc": "^1.0.5", 566 | "@humanwhocodes/config-array": "^0.9.2", 567 | "ajv": "^6.10.0", 568 | "chalk": "^4.0.0", 569 | "cross-spawn": "^7.0.2", 570 | "debug": "^4.3.2", 571 | "doctrine": "^3.0.0", 572 | "enquirer": "^2.3.5", 573 | "escape-string-regexp": "^4.0.0", 574 | "eslint-scope": "^7.1.0", 575 | "eslint-utils": "^3.0.0", 576 | "eslint-visitor-keys": "^3.1.0", 577 | "espree": "^9.3.0", 578 | "esquery": "^1.4.0", 579 | "esutils": "^2.0.2", 580 | "fast-deep-equal": "^3.1.3", 581 | "file-entry-cache": "^6.0.1", 582 | "functional-red-black-tree": "^1.0.1", 583 | "glob-parent": "^6.0.1", 584 | "globals": "^13.6.0", 585 | "ignore": "^4.0.6", 586 | "import-fresh": "^3.0.0", 587 | "imurmurhash": "^0.1.4", 588 | "is-glob": "^4.0.0", 589 | "js-yaml": "^4.1.0", 590 | "json-stable-stringify-without-jsonify": "^1.0.1", 591 | "levn": "^0.4.1", 592 | "lodash.merge": "^4.6.2", 593 | "minimatch": "^3.0.4", 594 | "natural-compare": "^1.4.0", 595 | "optionator": "^0.9.1", 596 | "progress": "^2.0.0", 597 | "regexpp": "^3.2.0", 598 | "semver": "^7.2.1", 599 | "strip-ansi": "^6.0.1", 600 | "strip-json-comments": "^3.1.0", 601 | "text-table": "^0.2.0", 602 | "v8-compile-cache": "^2.0.3" 603 | }, 604 | "bin": { 605 | "eslint": "bin/eslint.js" 606 | }, 607 | "engines": { 608 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 609 | }, 610 | "funding": { 611 | "url": "https://opencollective.com/eslint" 612 | } 613 | }, 614 | "node_modules/eslint-scope": { 615 | "version": "7.1.0", 616 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.0.tgz", 617 | "integrity": "sha512-aWwkhnS0qAXqNOgKOK0dJ2nvzEbhEvpy8OlJ9kZ0FeZnA6zpjv1/Vei+puGFFX7zkPCkHHXb7IDX3A+7yPrRWg==", 618 | "dev": true, 619 | "dependencies": { 620 | "esrecurse": "^4.3.0", 621 | "estraverse": "^5.2.0" 622 | }, 623 | "engines": { 624 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 625 | } 626 | }, 627 | "node_modules/eslint-utils": { 628 | "version": "3.0.0", 629 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", 630 | "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", 631 | "dev": true, 632 | "dependencies": { 633 | "eslint-visitor-keys": "^2.0.0" 634 | }, 635 | "engines": { 636 | "node": "^10.0.0 || ^12.0.0 || >= 14.0.0" 637 | }, 638 | "funding": { 639 | "url": "https://github.com/sponsors/mysticatea" 640 | }, 641 | "peerDependencies": { 642 | "eslint": ">=5" 643 | } 644 | }, 645 | "node_modules/eslint-utils/node_modules/eslint-visitor-keys": { 646 | "version": "2.1.0", 647 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 648 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 649 | "dev": true, 650 | "engines": { 651 | "node": ">=10" 652 | } 653 | }, 654 | "node_modules/eslint-visitor-keys": { 655 | "version": "3.1.0", 656 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.1.0.tgz", 657 | "integrity": "sha512-yWJFpu4DtjsWKkt5GeNBBuZMlNcYVs6vRCLoCVEJrTjaSB6LC98gFipNK/erM2Heg/E8mIK+hXG/pJMLK+eRZA==", 658 | "dev": true, 659 | "engines": { 660 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 661 | } 662 | }, 663 | "node_modules/espree": { 664 | "version": "9.3.0", 665 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.3.0.tgz", 666 | "integrity": "sha512-d/5nCsb0JcqsSEeQzFZ8DH1RmxPcglRWh24EFTlUEmCKoehXGdpsx0RkHDubqUI8LSAIKMQp4r9SzQ3n+sm4HQ==", 667 | "dev": true, 668 | "dependencies": { 669 | "acorn": "^8.7.0", 670 | "acorn-jsx": "^5.3.1", 671 | "eslint-visitor-keys": "^3.1.0" 672 | }, 673 | "engines": { 674 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 675 | } 676 | }, 677 | "node_modules/esquery": { 678 | "version": "1.4.0", 679 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 680 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 681 | "dev": true, 682 | "dependencies": { 683 | "estraverse": "^5.1.0" 684 | }, 685 | "engines": { 686 | "node": ">=0.10" 687 | } 688 | }, 689 | "node_modules/esrecurse": { 690 | "version": "4.3.0", 691 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 692 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 693 | "dev": true, 694 | "dependencies": { 695 | "estraverse": "^5.2.0" 696 | }, 697 | "engines": { 698 | "node": ">=4.0" 699 | } 700 | }, 701 | "node_modules/estraverse": { 702 | "version": "5.3.0", 703 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 704 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 705 | "dev": true, 706 | "engines": { 707 | "node": ">=4.0" 708 | } 709 | }, 710 | "node_modules/esutils": { 711 | "version": "2.0.3", 712 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 713 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 714 | "dev": true, 715 | "engines": { 716 | "node": ">=0.10.0" 717 | } 718 | }, 719 | "node_modules/fast-deep-equal": { 720 | "version": "3.1.3", 721 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 722 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 723 | "dev": true 724 | }, 725 | "node_modules/fast-json-stable-stringify": { 726 | "version": "2.1.0", 727 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 728 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 729 | "dev": true 730 | }, 731 | "node_modules/fast-levenshtein": { 732 | "version": "2.0.6", 733 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 734 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 735 | "dev": true 736 | }, 737 | "node_modules/file-entry-cache": { 738 | "version": "6.0.1", 739 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 740 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 741 | "dev": true, 742 | "dependencies": { 743 | "flat-cache": "^3.0.4" 744 | }, 745 | "engines": { 746 | "node": "^10.12.0 || >=12.0.0" 747 | } 748 | }, 749 | "node_modules/fill-range": { 750 | "version": "7.0.1", 751 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 752 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 753 | "dev": true, 754 | "dependencies": { 755 | "to-regex-range": "^5.0.1" 756 | }, 757 | "engines": { 758 | "node": ">=8" 759 | } 760 | }, 761 | "node_modules/find-up": { 762 | "version": "5.0.0", 763 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 764 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 765 | "dev": true, 766 | "dependencies": { 767 | "locate-path": "^6.0.0", 768 | "path-exists": "^4.0.0" 769 | }, 770 | "engines": { 771 | "node": ">=10" 772 | }, 773 | "funding": { 774 | "url": "https://github.com/sponsors/sindresorhus" 775 | } 776 | }, 777 | "node_modules/flat": { 778 | "version": "5.0.2", 779 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 780 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 781 | "dev": true, 782 | "bin": { 783 | "flat": "cli.js" 784 | } 785 | }, 786 | "node_modules/flat-cache": { 787 | "version": "3.0.4", 788 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 789 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 790 | "dev": true, 791 | "dependencies": { 792 | "flatted": "^3.1.0", 793 | "rimraf": "^3.0.2" 794 | }, 795 | "engines": { 796 | "node": "^10.12.0 || >=12.0.0" 797 | } 798 | }, 799 | "node_modules/flatted": { 800 | "version": "3.2.4", 801 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.4.tgz", 802 | "integrity": "sha512-8/sOawo8tJ4QOBX8YlQBMxL8+RLZfxMQOif9o0KUKTNTjMYElWPE0r/m5VNFxTRd0NSw8qSy8dajrwX4RYI1Hw==", 803 | "dev": true 804 | }, 805 | "node_modules/fs.realpath": { 806 | "version": "1.0.0", 807 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 808 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 809 | "dev": true 810 | }, 811 | "node_modules/fsevents": { 812 | "version": "2.3.2", 813 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 814 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 815 | "dev": true, 816 | "hasInstallScript": true, 817 | "optional": true, 818 | "os": [ 819 | "darwin" 820 | ], 821 | "engines": { 822 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 823 | } 824 | }, 825 | "node_modules/fstream": { 826 | "version": "1.0.12", 827 | "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.12.tgz", 828 | "integrity": "sha512-WvJ193OHa0GHPEL+AycEJgxvBEwyfRkN1vhjca23OaPVMCaLCXTd5qAu82AjTcgP1UJmytkOKb63Ypde7raDIg==", 829 | "dev": true, 830 | "dependencies": { 831 | "graceful-fs": "^4.1.2", 832 | "inherits": "~2.0.0", 833 | "mkdirp": ">=0.5 0", 834 | "rimraf": "2" 835 | }, 836 | "engines": { 837 | "node": ">=0.6" 838 | } 839 | }, 840 | "node_modules/fstream/node_modules/rimraf": { 841 | "version": "2.7.1", 842 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 843 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 844 | "dev": true, 845 | "dependencies": { 846 | "glob": "^7.1.3" 847 | }, 848 | "bin": { 849 | "rimraf": "bin.js" 850 | } 851 | }, 852 | "node_modules/functional-red-black-tree": { 853 | "version": "1.0.1", 854 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 855 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 856 | "dev": true 857 | }, 858 | "node_modules/get-caller-file": { 859 | "version": "2.0.5", 860 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 861 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 862 | "dev": true, 863 | "engines": { 864 | "node": "6.* || 8.* || >= 10.*" 865 | } 866 | }, 867 | "node_modules/glob": { 868 | "version": "7.2.0", 869 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 870 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 871 | "dev": true, 872 | "dependencies": { 873 | "fs.realpath": "^1.0.0", 874 | "inflight": "^1.0.4", 875 | "inherits": "2", 876 | "minimatch": "^3.0.4", 877 | "once": "^1.3.0", 878 | "path-is-absolute": "^1.0.0" 879 | }, 880 | "engines": { 881 | "node": "*" 882 | }, 883 | "funding": { 884 | "url": "https://github.com/sponsors/isaacs" 885 | } 886 | }, 887 | "node_modules/glob-parent": { 888 | "version": "6.0.2", 889 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 890 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 891 | "dev": true, 892 | "dependencies": { 893 | "is-glob": "^4.0.3" 894 | }, 895 | "engines": { 896 | "node": ">=10.13.0" 897 | } 898 | }, 899 | "node_modules/globals": { 900 | "version": "13.12.0", 901 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.12.0.tgz", 902 | "integrity": "sha512-uS8X6lSKN2JumVoXrbUz+uG4BYG+eiawqm3qFcT7ammfbUHeCBoJMlHcec/S3krSk73/AE/f0szYFmgAA3kYZg==", 903 | "dev": true, 904 | "dependencies": { 905 | "type-fest": "^0.20.2" 906 | }, 907 | "engines": { 908 | "node": ">=8" 909 | }, 910 | "funding": { 911 | "url": "https://github.com/sponsors/sindresorhus" 912 | } 913 | }, 914 | "node_modules/graceful-fs": { 915 | "version": "4.2.8", 916 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.8.tgz", 917 | "integrity": "sha512-qkIilPUYcNhJpd33n0GBXTB1MMPp14TxEsEs0pTrsSVucApsYzW5V+Q8Qxhik6KU3evy+qkAAowTByymK0avdg==", 918 | "dev": true 919 | }, 920 | "node_modules/growl": { 921 | "version": "1.10.5", 922 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 923 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 924 | "dev": true, 925 | "engines": { 926 | "node": ">=4.x" 927 | } 928 | }, 929 | "node_modules/has-flag": { 930 | "version": "4.0.0", 931 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 932 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 933 | "dev": true, 934 | "engines": { 935 | "node": ">=8" 936 | } 937 | }, 938 | "node_modules/he": { 939 | "version": "1.2.0", 940 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 941 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 942 | "dev": true, 943 | "bin": { 944 | "he": "bin/he" 945 | } 946 | }, 947 | "node_modules/http-proxy-agent": { 948 | "version": "4.0.1", 949 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 950 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 951 | "dev": true, 952 | "dependencies": { 953 | "@tootallnate/once": "1", 954 | "agent-base": "6", 955 | "debug": "4" 956 | }, 957 | "engines": { 958 | "node": ">= 6" 959 | } 960 | }, 961 | "node_modules/https-proxy-agent": { 962 | "version": "5.0.0", 963 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", 964 | "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", 965 | "dev": true, 966 | "dependencies": { 967 | "agent-base": "6", 968 | "debug": "4" 969 | }, 970 | "engines": { 971 | "node": ">= 6" 972 | } 973 | }, 974 | "node_modules/ignore": { 975 | "version": "4.0.6", 976 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 977 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 978 | "dev": true, 979 | "engines": { 980 | "node": ">= 4" 981 | } 982 | }, 983 | "node_modules/import-fresh": { 984 | "version": "3.3.0", 985 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 986 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 987 | "dev": true, 988 | "dependencies": { 989 | "parent-module": "^1.0.0", 990 | "resolve-from": "^4.0.0" 991 | }, 992 | "engines": { 993 | "node": ">=6" 994 | }, 995 | "funding": { 996 | "url": "https://github.com/sponsors/sindresorhus" 997 | } 998 | }, 999 | "node_modules/imurmurhash": { 1000 | "version": "0.1.4", 1001 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1002 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1003 | "dev": true, 1004 | "engines": { 1005 | "node": ">=0.8.19" 1006 | } 1007 | }, 1008 | "node_modules/inflight": { 1009 | "version": "1.0.6", 1010 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1011 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1012 | "dev": true, 1013 | "dependencies": { 1014 | "once": "^1.3.0", 1015 | "wrappy": "1" 1016 | } 1017 | }, 1018 | "node_modules/inherits": { 1019 | "version": "2.0.4", 1020 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1021 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1022 | "dev": true 1023 | }, 1024 | "node_modules/is-binary-path": { 1025 | "version": "2.1.0", 1026 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1027 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1028 | "dev": true, 1029 | "dependencies": { 1030 | "binary-extensions": "^2.0.0" 1031 | }, 1032 | "engines": { 1033 | "node": ">=8" 1034 | } 1035 | }, 1036 | "node_modules/is-extglob": { 1037 | "version": "2.1.1", 1038 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1039 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1040 | "dev": true, 1041 | "engines": { 1042 | "node": ">=0.10.0" 1043 | } 1044 | }, 1045 | "node_modules/is-fullwidth-code-point": { 1046 | "version": "3.0.0", 1047 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1048 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1049 | "dev": true, 1050 | "engines": { 1051 | "node": ">=8" 1052 | } 1053 | }, 1054 | "node_modules/is-glob": { 1055 | "version": "4.0.3", 1056 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1057 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1058 | "dev": true, 1059 | "dependencies": { 1060 | "is-extglob": "^2.1.1" 1061 | }, 1062 | "engines": { 1063 | "node": ">=0.10.0" 1064 | } 1065 | }, 1066 | "node_modules/is-number": { 1067 | "version": "7.0.0", 1068 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1069 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1070 | "dev": true, 1071 | "engines": { 1072 | "node": ">=0.12.0" 1073 | } 1074 | }, 1075 | "node_modules/is-plain-obj": { 1076 | "version": "2.1.0", 1077 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 1078 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 1079 | "dev": true, 1080 | "engines": { 1081 | "node": ">=8" 1082 | } 1083 | }, 1084 | "node_modules/is-unicode-supported": { 1085 | "version": "0.1.0", 1086 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 1087 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 1088 | "dev": true, 1089 | "engines": { 1090 | "node": ">=10" 1091 | }, 1092 | "funding": { 1093 | "url": "https://github.com/sponsors/sindresorhus" 1094 | } 1095 | }, 1096 | "node_modules/isarray": { 1097 | "version": "1.0.0", 1098 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1099 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1100 | "dev": true 1101 | }, 1102 | "node_modules/isexe": { 1103 | "version": "2.0.0", 1104 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1105 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1106 | "dev": true 1107 | }, 1108 | "node_modules/js-yaml": { 1109 | "version": "4.1.0", 1110 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1111 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1112 | "dev": true, 1113 | "dependencies": { 1114 | "argparse": "^2.0.1" 1115 | }, 1116 | "bin": { 1117 | "js-yaml": "bin/js-yaml.js" 1118 | } 1119 | }, 1120 | "node_modules/json-schema-traverse": { 1121 | "version": "0.4.1", 1122 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1123 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1124 | "dev": true 1125 | }, 1126 | "node_modules/json-stable-stringify-without-jsonify": { 1127 | "version": "1.0.1", 1128 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1129 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1130 | "dev": true 1131 | }, 1132 | "node_modules/levn": { 1133 | "version": "0.4.1", 1134 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1135 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1136 | "dev": true, 1137 | "dependencies": { 1138 | "prelude-ls": "^1.2.1", 1139 | "type-check": "~0.4.0" 1140 | }, 1141 | "engines": { 1142 | "node": ">= 0.8.0" 1143 | } 1144 | }, 1145 | "node_modules/listenercount": { 1146 | "version": "1.0.1", 1147 | "resolved": "https://registry.npmjs.org/listenercount/-/listenercount-1.0.1.tgz", 1148 | "integrity": "sha1-hMinKrWcRyUyFIDJdeZQg0LnCTc=", 1149 | "dev": true 1150 | }, 1151 | "node_modules/locate-path": { 1152 | "version": "6.0.0", 1153 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1154 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1155 | "dev": true, 1156 | "dependencies": { 1157 | "p-locate": "^5.0.0" 1158 | }, 1159 | "engines": { 1160 | "node": ">=10" 1161 | }, 1162 | "funding": { 1163 | "url": "https://github.com/sponsors/sindresorhus" 1164 | } 1165 | }, 1166 | "node_modules/lodash.merge": { 1167 | "version": "4.6.2", 1168 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1169 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1170 | "dev": true 1171 | }, 1172 | "node_modules/log-symbols": { 1173 | "version": "4.1.0", 1174 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 1175 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 1176 | "dev": true, 1177 | "dependencies": { 1178 | "chalk": "^4.1.0", 1179 | "is-unicode-supported": "^0.1.0" 1180 | }, 1181 | "engines": { 1182 | "node": ">=10" 1183 | }, 1184 | "funding": { 1185 | "url": "https://github.com/sponsors/sindresorhus" 1186 | } 1187 | }, 1188 | "node_modules/lru-cache": { 1189 | "version": "6.0.0", 1190 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1191 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1192 | "dev": true, 1193 | "dependencies": { 1194 | "yallist": "^4.0.0" 1195 | }, 1196 | "engines": { 1197 | "node": ">=10" 1198 | } 1199 | }, 1200 | "node_modules/minimatch": { 1201 | "version": "3.0.4", 1202 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1203 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1204 | "dev": true, 1205 | "dependencies": { 1206 | "brace-expansion": "^1.1.7" 1207 | }, 1208 | "engines": { 1209 | "node": "*" 1210 | } 1211 | }, 1212 | "node_modules/minimist": { 1213 | "version": "1.2.5", 1214 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1215 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1216 | "dev": true 1217 | }, 1218 | "node_modules/mkdirp": { 1219 | "version": "0.5.5", 1220 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1221 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1222 | "dev": true, 1223 | "dependencies": { 1224 | "minimist": "^1.2.5" 1225 | }, 1226 | "bin": { 1227 | "mkdirp": "bin/cmd.js" 1228 | } 1229 | }, 1230 | "node_modules/mocha": { 1231 | "version": "9.1.3", 1232 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-9.1.3.tgz", 1233 | "integrity": "sha512-Xcpl9FqXOAYqI3j79pEtHBBnQgVXIhpULjGQa7DVb0Po+VzmSIK9kanAiWLHoRR/dbZ2qpdPshuXr8l1VaHCzw==", 1234 | "dev": true, 1235 | "dependencies": { 1236 | "@ungap/promise-all-settled": "1.1.2", 1237 | "ansi-colors": "4.1.1", 1238 | "browser-stdout": "1.3.1", 1239 | "chokidar": "3.5.2", 1240 | "debug": "4.3.2", 1241 | "diff": "5.0.0", 1242 | "escape-string-regexp": "4.0.0", 1243 | "find-up": "5.0.0", 1244 | "glob": "7.1.7", 1245 | "growl": "1.10.5", 1246 | "he": "1.2.0", 1247 | "js-yaml": "4.1.0", 1248 | "log-symbols": "4.1.0", 1249 | "minimatch": "3.0.4", 1250 | "ms": "2.1.3", 1251 | "nanoid": "3.1.25", 1252 | "serialize-javascript": "6.0.0", 1253 | "strip-json-comments": "3.1.1", 1254 | "supports-color": "8.1.1", 1255 | "which": "2.0.2", 1256 | "workerpool": "6.1.5", 1257 | "yargs": "16.2.0", 1258 | "yargs-parser": "20.2.4", 1259 | "yargs-unparser": "2.0.0" 1260 | }, 1261 | "bin": { 1262 | "_mocha": "bin/_mocha", 1263 | "mocha": "bin/mocha" 1264 | }, 1265 | "engines": { 1266 | "node": ">= 12.0.0" 1267 | }, 1268 | "funding": { 1269 | "type": "opencollective", 1270 | "url": "https://opencollective.com/mochajs" 1271 | } 1272 | }, 1273 | "node_modules/mocha/node_modules/debug": { 1274 | "version": "4.3.2", 1275 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 1276 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 1277 | "dev": true, 1278 | "dependencies": { 1279 | "ms": "2.1.2" 1280 | }, 1281 | "engines": { 1282 | "node": ">=6.0" 1283 | }, 1284 | "peerDependenciesMeta": { 1285 | "supports-color": { 1286 | "optional": true 1287 | } 1288 | } 1289 | }, 1290 | "node_modules/mocha/node_modules/debug/node_modules/ms": { 1291 | "version": "2.1.2", 1292 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1293 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1294 | "dev": true 1295 | }, 1296 | "node_modules/mocha/node_modules/glob": { 1297 | "version": "7.1.7", 1298 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", 1299 | "integrity": "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==", 1300 | "dev": true, 1301 | "dependencies": { 1302 | "fs.realpath": "^1.0.0", 1303 | "inflight": "^1.0.4", 1304 | "inherits": "2", 1305 | "minimatch": "^3.0.4", 1306 | "once": "^1.3.0", 1307 | "path-is-absolute": "^1.0.0" 1308 | }, 1309 | "engines": { 1310 | "node": "*" 1311 | }, 1312 | "funding": { 1313 | "url": "https://github.com/sponsors/isaacs" 1314 | } 1315 | }, 1316 | "node_modules/mocha/node_modules/ms": { 1317 | "version": "2.1.3", 1318 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1319 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1320 | "dev": true 1321 | }, 1322 | "node_modules/mocha/node_modules/supports-color": { 1323 | "version": "8.1.1", 1324 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 1325 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 1326 | "dev": true, 1327 | "dependencies": { 1328 | "has-flag": "^4.0.0" 1329 | }, 1330 | "engines": { 1331 | "node": ">=10" 1332 | }, 1333 | "funding": { 1334 | "url": "https://github.com/chalk/supports-color?sponsor=1" 1335 | } 1336 | }, 1337 | "node_modules/ms": { 1338 | "version": "2.1.2", 1339 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1340 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1341 | "dev": true 1342 | }, 1343 | "node_modules/nanoid": { 1344 | "version": "3.1.25", 1345 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.1.25.tgz", 1346 | "integrity": "sha512-rdwtIXaXCLFAQbnfqDRnI6jaRHp9fTcYBjtFKE8eezcZ7LuLjhUaQGNeMXf1HmRoCH32CLz6XwX0TtxEOS/A3Q==", 1347 | "dev": true, 1348 | "bin": { 1349 | "nanoid": "bin/nanoid.cjs" 1350 | }, 1351 | "engines": { 1352 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 1353 | } 1354 | }, 1355 | "node_modules/natural-compare": { 1356 | "version": "1.4.0", 1357 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1358 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1359 | "dev": true 1360 | }, 1361 | "node_modules/normalize-path": { 1362 | "version": "3.0.0", 1363 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1364 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1365 | "dev": true, 1366 | "engines": { 1367 | "node": ">=0.10.0" 1368 | } 1369 | }, 1370 | "node_modules/once": { 1371 | "version": "1.4.0", 1372 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1373 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1374 | "dev": true, 1375 | "dependencies": { 1376 | "wrappy": "1" 1377 | } 1378 | }, 1379 | "node_modules/optionator": { 1380 | "version": "0.9.1", 1381 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1382 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1383 | "dev": true, 1384 | "dependencies": { 1385 | "deep-is": "^0.1.3", 1386 | "fast-levenshtein": "^2.0.6", 1387 | "levn": "^0.4.1", 1388 | "prelude-ls": "^1.2.1", 1389 | "type-check": "^0.4.0", 1390 | "word-wrap": "^1.2.3" 1391 | }, 1392 | "engines": { 1393 | "node": ">= 0.8.0" 1394 | } 1395 | }, 1396 | "node_modules/p-limit": { 1397 | "version": "3.1.0", 1398 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1399 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1400 | "dev": true, 1401 | "dependencies": { 1402 | "yocto-queue": "^0.1.0" 1403 | }, 1404 | "engines": { 1405 | "node": ">=10" 1406 | }, 1407 | "funding": { 1408 | "url": "https://github.com/sponsors/sindresorhus" 1409 | } 1410 | }, 1411 | "node_modules/p-locate": { 1412 | "version": "5.0.0", 1413 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1414 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1415 | "dev": true, 1416 | "dependencies": { 1417 | "p-limit": "^3.0.2" 1418 | }, 1419 | "engines": { 1420 | "node": ">=10" 1421 | }, 1422 | "funding": { 1423 | "url": "https://github.com/sponsors/sindresorhus" 1424 | } 1425 | }, 1426 | "node_modules/parent-module": { 1427 | "version": "1.0.1", 1428 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1429 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1430 | "dev": true, 1431 | "dependencies": { 1432 | "callsites": "^3.0.0" 1433 | }, 1434 | "engines": { 1435 | "node": ">=6" 1436 | } 1437 | }, 1438 | "node_modules/path-exists": { 1439 | "version": "4.0.0", 1440 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1441 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1442 | "dev": true, 1443 | "engines": { 1444 | "node": ">=8" 1445 | } 1446 | }, 1447 | "node_modules/path-is-absolute": { 1448 | "version": "1.0.1", 1449 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1450 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1451 | "dev": true, 1452 | "engines": { 1453 | "node": ">=0.10.0" 1454 | } 1455 | }, 1456 | "node_modules/path-key": { 1457 | "version": "3.1.1", 1458 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1459 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1460 | "dev": true, 1461 | "engines": { 1462 | "node": ">=8" 1463 | } 1464 | }, 1465 | "node_modules/picomatch": { 1466 | "version": "2.3.0", 1467 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 1468 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 1469 | "dev": true, 1470 | "engines": { 1471 | "node": ">=8.6" 1472 | }, 1473 | "funding": { 1474 | "url": "https://github.com/sponsors/jonschlinkert" 1475 | } 1476 | }, 1477 | "node_modules/prelude-ls": { 1478 | "version": "1.2.1", 1479 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1480 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1481 | "dev": true, 1482 | "engines": { 1483 | "node": ">= 0.8.0" 1484 | } 1485 | }, 1486 | "node_modules/process-nextick-args": { 1487 | "version": "2.0.1", 1488 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 1489 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 1490 | "dev": true 1491 | }, 1492 | "node_modules/progress": { 1493 | "version": "2.0.3", 1494 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1495 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1496 | "dev": true, 1497 | "engines": { 1498 | "node": ">=0.4.0" 1499 | } 1500 | }, 1501 | "node_modules/punycode": { 1502 | "version": "2.1.1", 1503 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1504 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1505 | "dev": true, 1506 | "engines": { 1507 | "node": ">=6" 1508 | } 1509 | }, 1510 | "node_modules/randombytes": { 1511 | "version": "2.1.0", 1512 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1513 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1514 | "dev": true, 1515 | "dependencies": { 1516 | "safe-buffer": "^5.1.0" 1517 | } 1518 | }, 1519 | "node_modules/readable-stream": { 1520 | "version": "2.3.7", 1521 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 1522 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 1523 | "dev": true, 1524 | "dependencies": { 1525 | "core-util-is": "~1.0.0", 1526 | "inherits": "~2.0.3", 1527 | "isarray": "~1.0.0", 1528 | "process-nextick-args": "~2.0.0", 1529 | "safe-buffer": "~5.1.1", 1530 | "string_decoder": "~1.1.1", 1531 | "util-deprecate": "~1.0.1" 1532 | } 1533 | }, 1534 | "node_modules/readdirp": { 1535 | "version": "3.6.0", 1536 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1537 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1538 | "dev": true, 1539 | "dependencies": { 1540 | "picomatch": "^2.2.1" 1541 | }, 1542 | "engines": { 1543 | "node": ">=8.10.0" 1544 | } 1545 | }, 1546 | "node_modules/regexpp": { 1547 | "version": "3.2.0", 1548 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 1549 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 1550 | "dev": true, 1551 | "engines": { 1552 | "node": ">=8" 1553 | }, 1554 | "funding": { 1555 | "url": "https://github.com/sponsors/mysticatea" 1556 | } 1557 | }, 1558 | "node_modules/require-directory": { 1559 | "version": "2.1.1", 1560 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1561 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1562 | "dev": true, 1563 | "engines": { 1564 | "node": ">=0.10.0" 1565 | } 1566 | }, 1567 | "node_modules/resolve-from": { 1568 | "version": "4.0.0", 1569 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1570 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1571 | "dev": true, 1572 | "engines": { 1573 | "node": ">=4" 1574 | } 1575 | }, 1576 | "node_modules/rimraf": { 1577 | "version": "3.0.2", 1578 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1579 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1580 | "dev": true, 1581 | "dependencies": { 1582 | "glob": "^7.1.3" 1583 | }, 1584 | "bin": { 1585 | "rimraf": "bin.js" 1586 | }, 1587 | "funding": { 1588 | "url": "https://github.com/sponsors/isaacs" 1589 | } 1590 | }, 1591 | "node_modules/safe-buffer": { 1592 | "version": "5.1.2", 1593 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1594 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1595 | "dev": true 1596 | }, 1597 | "node_modules/semver": { 1598 | "version": "7.3.5", 1599 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 1600 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 1601 | "dev": true, 1602 | "dependencies": { 1603 | "lru-cache": "^6.0.0" 1604 | }, 1605 | "bin": { 1606 | "semver": "bin/semver.js" 1607 | }, 1608 | "engines": { 1609 | "node": ">=10" 1610 | } 1611 | }, 1612 | "node_modules/serialize-javascript": { 1613 | "version": "6.0.0", 1614 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 1615 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 1616 | "dev": true, 1617 | "dependencies": { 1618 | "randombytes": "^2.1.0" 1619 | } 1620 | }, 1621 | "node_modules/setimmediate": { 1622 | "version": "1.0.5", 1623 | "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", 1624 | "integrity": "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU=", 1625 | "dev": true 1626 | }, 1627 | "node_modules/shebang-command": { 1628 | "version": "2.0.0", 1629 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1630 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1631 | "dev": true, 1632 | "dependencies": { 1633 | "shebang-regex": "^3.0.0" 1634 | }, 1635 | "engines": { 1636 | "node": ">=8" 1637 | } 1638 | }, 1639 | "node_modules/shebang-regex": { 1640 | "version": "3.0.0", 1641 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1642 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1643 | "dev": true, 1644 | "engines": { 1645 | "node": ">=8" 1646 | } 1647 | }, 1648 | "node_modules/string_decoder": { 1649 | "version": "1.1.1", 1650 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 1651 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1652 | "dev": true, 1653 | "dependencies": { 1654 | "safe-buffer": "~5.1.0" 1655 | } 1656 | }, 1657 | "node_modules/string-width": { 1658 | "version": "4.2.3", 1659 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1660 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1661 | "dev": true, 1662 | "dependencies": { 1663 | "emoji-regex": "^8.0.0", 1664 | "is-fullwidth-code-point": "^3.0.0", 1665 | "strip-ansi": "^6.0.1" 1666 | }, 1667 | "engines": { 1668 | "node": ">=8" 1669 | } 1670 | }, 1671 | "node_modules/strip-ansi": { 1672 | "version": "6.0.1", 1673 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1674 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1675 | "dev": true, 1676 | "dependencies": { 1677 | "ansi-regex": "^5.0.1" 1678 | }, 1679 | "engines": { 1680 | "node": ">=8" 1681 | } 1682 | }, 1683 | "node_modules/strip-json-comments": { 1684 | "version": "3.1.1", 1685 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1686 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1687 | "dev": true, 1688 | "engines": { 1689 | "node": ">=8" 1690 | }, 1691 | "funding": { 1692 | "url": "https://github.com/sponsors/sindresorhus" 1693 | } 1694 | }, 1695 | "node_modules/supports-color": { 1696 | "version": "7.2.0", 1697 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1698 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1699 | "dev": true, 1700 | "dependencies": { 1701 | "has-flag": "^4.0.0" 1702 | }, 1703 | "engines": { 1704 | "node": ">=8" 1705 | } 1706 | }, 1707 | "node_modules/text-table": { 1708 | "version": "0.2.0", 1709 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1710 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1711 | "dev": true 1712 | }, 1713 | "node_modules/to-regex-range": { 1714 | "version": "5.0.1", 1715 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1716 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1717 | "dev": true, 1718 | "dependencies": { 1719 | "is-number": "^7.0.0" 1720 | }, 1721 | "engines": { 1722 | "node": ">=8.0" 1723 | } 1724 | }, 1725 | "node_modules/traverse": { 1726 | "version": "0.3.9", 1727 | "resolved": "https://registry.npmjs.org/traverse/-/traverse-0.3.9.tgz", 1728 | "integrity": "sha1-cXuPIgzAu3tE5AUUwisui7xw2Lk=", 1729 | "dev": true, 1730 | "engines": { 1731 | "node": "*" 1732 | } 1733 | }, 1734 | "node_modules/type-check": { 1735 | "version": "0.4.0", 1736 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1737 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1738 | "dev": true, 1739 | "dependencies": { 1740 | "prelude-ls": "^1.2.1" 1741 | }, 1742 | "engines": { 1743 | "node": ">= 0.8.0" 1744 | } 1745 | }, 1746 | "node_modules/type-fest": { 1747 | "version": "0.20.2", 1748 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1749 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 1750 | "dev": true, 1751 | "engines": { 1752 | "node": ">=10" 1753 | }, 1754 | "funding": { 1755 | "url": "https://github.com/sponsors/sindresorhus" 1756 | } 1757 | }, 1758 | "node_modules/typescript": { 1759 | "version": "4.5.4", 1760 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.5.4.tgz", 1761 | "integrity": "sha512-VgYs2A2QIRuGphtzFV7aQJduJ2gyfTljngLzjpfW9FoYZF6xuw1W0vW9ghCKLfcWrCFxK81CSGRAvS1pn4fIUg==", 1762 | "dev": true, 1763 | "bin": { 1764 | "tsc": "bin/tsc", 1765 | "tsserver": "bin/tsserver" 1766 | }, 1767 | "engines": { 1768 | "node": ">=4.2.0" 1769 | } 1770 | }, 1771 | "node_modules/unzipper": { 1772 | "version": "0.10.11", 1773 | "resolved": "https://registry.npmjs.org/unzipper/-/unzipper-0.10.11.tgz", 1774 | "integrity": "sha512-+BrAq2oFqWod5IESRjL3S8baohbevGcVA+teAIOYWM3pDVdseogqbzhhvvmiyQrUNKFUnDMtELW3X8ykbyDCJw==", 1775 | "dev": true, 1776 | "dependencies": { 1777 | "big-integer": "^1.6.17", 1778 | "binary": "~0.3.0", 1779 | "bluebird": "~3.4.1", 1780 | "buffer-indexof-polyfill": "~1.0.0", 1781 | "duplexer2": "~0.1.4", 1782 | "fstream": "^1.0.12", 1783 | "graceful-fs": "^4.2.2", 1784 | "listenercount": "~1.0.1", 1785 | "readable-stream": "~2.3.6", 1786 | "setimmediate": "~1.0.4" 1787 | } 1788 | }, 1789 | "node_modules/uri-js": { 1790 | "version": "4.4.1", 1791 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1792 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1793 | "dev": true, 1794 | "dependencies": { 1795 | "punycode": "^2.1.0" 1796 | } 1797 | }, 1798 | "node_modules/util-deprecate": { 1799 | "version": "1.0.2", 1800 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1801 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 1802 | "dev": true 1803 | }, 1804 | "node_modules/v8-compile-cache": { 1805 | "version": "2.3.0", 1806 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 1807 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 1808 | "dev": true 1809 | }, 1810 | "node_modules/which": { 1811 | "version": "2.0.2", 1812 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1813 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1814 | "dev": true, 1815 | "dependencies": { 1816 | "isexe": "^2.0.0" 1817 | }, 1818 | "bin": { 1819 | "node-which": "bin/node-which" 1820 | }, 1821 | "engines": { 1822 | "node": ">= 8" 1823 | } 1824 | }, 1825 | "node_modules/word-wrap": { 1826 | "version": "1.2.3", 1827 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 1828 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 1829 | "dev": true, 1830 | "engines": { 1831 | "node": ">=0.10.0" 1832 | } 1833 | }, 1834 | "node_modules/workerpool": { 1835 | "version": "6.1.5", 1836 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.1.5.tgz", 1837 | "integrity": "sha512-XdKkCK0Zqc6w3iTxLckiuJ81tiD/o5rBE/m+nXpRCB+/Sq4DqkfXZ/x0jW02DG1tGsfUGXbTJyZDP+eu67haSw==", 1838 | "dev": true 1839 | }, 1840 | "node_modules/wrap-ansi": { 1841 | "version": "7.0.0", 1842 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1843 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1844 | "dev": true, 1845 | "dependencies": { 1846 | "ansi-styles": "^4.0.0", 1847 | "string-width": "^4.1.0", 1848 | "strip-ansi": "^6.0.0" 1849 | }, 1850 | "engines": { 1851 | "node": ">=10" 1852 | }, 1853 | "funding": { 1854 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 1855 | } 1856 | }, 1857 | "node_modules/wrappy": { 1858 | "version": "1.0.2", 1859 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1860 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1861 | "dev": true 1862 | }, 1863 | "node_modules/y18n": { 1864 | "version": "5.0.8", 1865 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 1866 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 1867 | "dev": true, 1868 | "engines": { 1869 | "node": ">=10" 1870 | } 1871 | }, 1872 | "node_modules/yallist": { 1873 | "version": "4.0.0", 1874 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1875 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 1876 | "dev": true 1877 | }, 1878 | "node_modules/yargs": { 1879 | "version": "16.2.0", 1880 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 1881 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 1882 | "dev": true, 1883 | "dependencies": { 1884 | "cliui": "^7.0.2", 1885 | "escalade": "^3.1.1", 1886 | "get-caller-file": "^2.0.5", 1887 | "require-directory": "^2.1.1", 1888 | "string-width": "^4.2.0", 1889 | "y18n": "^5.0.5", 1890 | "yargs-parser": "^20.2.2" 1891 | }, 1892 | "engines": { 1893 | "node": ">=10" 1894 | } 1895 | }, 1896 | "node_modules/yargs-parser": { 1897 | "version": "20.2.4", 1898 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 1899 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 1900 | "dev": true, 1901 | "engines": { 1902 | "node": ">=10" 1903 | } 1904 | }, 1905 | "node_modules/yargs-unparser": { 1906 | "version": "2.0.0", 1907 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 1908 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 1909 | "dev": true, 1910 | "dependencies": { 1911 | "camelcase": "^6.0.0", 1912 | "decamelize": "^4.0.0", 1913 | "flat": "^5.0.2", 1914 | "is-plain-obj": "^2.1.0" 1915 | }, 1916 | "engines": { 1917 | "node": ">=10" 1918 | } 1919 | }, 1920 | "node_modules/yocto-queue": { 1921 | "version": "0.1.0", 1922 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1923 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1924 | "dev": true, 1925 | "engines": { 1926 | "node": ">=10" 1927 | }, 1928 | "funding": { 1929 | "url": "https://github.com/sponsors/sindresorhus" 1930 | } 1931 | } 1932 | }, 1933 | "dependencies": { 1934 | "@eslint/eslintrc": { 1935 | "version": "1.0.5", 1936 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.0.5.tgz", 1937 | "integrity": "sha512-BLxsnmK3KyPunz5wmCCpqy0YelEoxxGmH73Is+Z74oOTMtExcjkr3dDR6quwrjh1YspA8DH9gnX1o069KiS9AQ==", 1938 | "dev": true, 1939 | "requires": { 1940 | "ajv": "^6.12.4", 1941 | "debug": "^4.3.2", 1942 | "espree": "^9.2.0", 1943 | "globals": "^13.9.0", 1944 | "ignore": "^4.0.6", 1945 | "import-fresh": "^3.2.1", 1946 | "js-yaml": "^4.1.0", 1947 | "minimatch": "^3.0.4", 1948 | "strip-json-comments": "^3.1.1" 1949 | } 1950 | }, 1951 | "@humanwhocodes/config-array": { 1952 | "version": "0.9.2", 1953 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.9.2.tgz", 1954 | "integrity": "sha512-UXOuFCGcwciWckOpmfKDq/GyhlTf9pN/BzG//x8p8zTOFEcGuA68ANXheFS0AGvy3qgZqLBUkMs7hqzqCKOVwA==", 1955 | "dev": true, 1956 | "requires": { 1957 | "@humanwhocodes/object-schema": "^1.2.1", 1958 | "debug": "^4.1.1", 1959 | "minimatch": "^3.0.4" 1960 | } 1961 | }, 1962 | "@humanwhocodes/object-schema": { 1963 | "version": "1.2.1", 1964 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 1965 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 1966 | "dev": true 1967 | }, 1968 | "@tootallnate/once": { 1969 | "version": "1.1.2", 1970 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 1971 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", 1972 | "dev": true 1973 | }, 1974 | "@types/glob": { 1975 | "version": "7.2.0", 1976 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.2.0.tgz", 1977 | "integrity": "sha512-ZUxbzKl0IfJILTS6t7ip5fQQM/J3TJYubDm3nMbgubNNYS62eXeUpoLUC8/7fJNiFYHTrGPQn7hspDUzIHX3UA==", 1978 | "dev": true, 1979 | "requires": { 1980 | "@types/minimatch": "*", 1981 | "@types/node": "*" 1982 | } 1983 | }, 1984 | "@types/minimatch": { 1985 | "version": "3.0.5", 1986 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.5.tgz", 1987 | "integrity": "sha512-Klz949h02Gz2uZCMGwDUSDS1YBlTdDDgbWHi+81l29tQALUtvz4rAYi5uoVhE5Lagoq6DeqAUlbrHvW/mXDgdQ==", 1988 | "dev": true 1989 | }, 1990 | "@types/mocha": { 1991 | "version": "9.0.0", 1992 | "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-9.0.0.tgz", 1993 | "integrity": "sha512-scN0hAWyLVAvLR9AyW7HoFF5sJZglyBsbPuHO4fv7JRvfmPBMfp1ozWqOf/e4wwPNxezBZXRfWzMb6iFLgEVRA==", 1994 | "dev": true 1995 | }, 1996 | "@types/node": { 1997 | "version": "14.18.4", 1998 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.18.4.tgz", 1999 | "integrity": "sha512-swe3lD4izOJWHuxvsZdDFRq6S9i6koJsXOnQKYekhSO5JTizMVirUFgY/bUsaOJQj8oSD4oxmRYPBM/0b6jpdw==", 2000 | "dev": true 2001 | }, 2002 | "@types/vscode": { 2003 | "version": "1.63.1", 2004 | "resolved": "https://registry.npmjs.org/@types/vscode/-/vscode-1.63.1.tgz", 2005 | "integrity": "sha512-Z+ZqjRcnGfHP86dvx/BtSwWyZPKQ/LBdmAVImY82TphyjOw2KgTKcp7Nx92oNwCTsHzlshwexAG/WiY2JuUm3g==", 2006 | "dev": true 2007 | }, 2008 | "@ungap/promise-all-settled": { 2009 | "version": "1.1.2", 2010 | "resolved": "https://registry.npmjs.org/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz", 2011 | "integrity": "sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q==", 2012 | "dev": true 2013 | }, 2014 | "@vscode/test-electron": { 2015 | "version": "1.6.2", 2016 | "resolved": "https://registry.npmjs.org/@vscode/test-electron/-/test-electron-1.6.2.tgz", 2017 | "integrity": "sha512-W01ajJEMx6223Y7J5yaajGjVs1QfW3YGkkOJHVKfAMEqNB1ZHN9wCcViehv5ZwVSSJnjhu6lYEYgwBdHtCxqhQ==", 2018 | "dev": true, 2019 | "requires": { 2020 | "http-proxy-agent": "^4.0.1", 2021 | "https-proxy-agent": "^5.0.0", 2022 | "rimraf": "^3.0.2", 2023 | "unzipper": "^0.10.11" 2024 | } 2025 | }, 2026 | "acorn": { 2027 | "version": "8.7.0", 2028 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.0.tgz", 2029 | "integrity": "sha512-V/LGr1APy+PXIwKebEWrkZPwoeoF+w1jiOBUmuxuiUIaOHtob8Qc9BTrYo7VuI5fR8tqsy+buA2WFooR5olqvQ==", 2030 | "dev": true 2031 | }, 2032 | "acorn-jsx": { 2033 | "version": "5.3.2", 2034 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 2035 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 2036 | "dev": true, 2037 | "requires": {} 2038 | }, 2039 | "agent-base": { 2040 | "version": "6.0.2", 2041 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 2042 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 2043 | "dev": true, 2044 | "requires": { 2045 | "debug": "4" 2046 | } 2047 | }, 2048 | "ajv": { 2049 | "version": "6.12.6", 2050 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 2051 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 2052 | "dev": true, 2053 | "requires": { 2054 | "fast-deep-equal": "^3.1.1", 2055 | "fast-json-stable-stringify": "^2.0.0", 2056 | "json-schema-traverse": "^0.4.1", 2057 | "uri-js": "^4.2.2" 2058 | } 2059 | }, 2060 | "ansi-colors": { 2061 | "version": "4.1.1", 2062 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 2063 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 2064 | "dev": true 2065 | }, 2066 | "ansi-regex": { 2067 | "version": "5.0.1", 2068 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2069 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2070 | "dev": true 2071 | }, 2072 | "ansi-styles": { 2073 | "version": "4.3.0", 2074 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2075 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2076 | "dev": true, 2077 | "requires": { 2078 | "color-convert": "^2.0.1" 2079 | } 2080 | }, 2081 | "anymatch": { 2082 | "version": "3.1.2", 2083 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 2084 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 2085 | "dev": true, 2086 | "requires": { 2087 | "normalize-path": "^3.0.0", 2088 | "picomatch": "^2.0.4" 2089 | } 2090 | }, 2091 | "argparse": { 2092 | "version": "2.0.1", 2093 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 2094 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 2095 | "dev": true 2096 | }, 2097 | "balanced-match": { 2098 | "version": "1.0.2", 2099 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2100 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 2101 | "dev": true 2102 | }, 2103 | "big-integer": { 2104 | "version": "1.6.51", 2105 | "resolved": "https://registry.npmjs.org/big-integer/-/big-integer-1.6.51.tgz", 2106 | "integrity": "sha512-GPEid2Y9QU1Exl1rpO9B2IPJGHPSupF5GnVIP0blYvNOMer2bTvSWs1jGOUg04hTmu67nmLsQ9TBo1puaotBHg==", 2107 | "dev": true 2108 | }, 2109 | "binary": { 2110 | "version": "0.3.0", 2111 | "resolved": "https://registry.npmjs.org/binary/-/binary-0.3.0.tgz", 2112 | "integrity": "sha1-n2BVO8XOjDOG87VTz/R0Yq3sqnk=", 2113 | "dev": true, 2114 | "requires": { 2115 | "buffers": "~0.1.1", 2116 | "chainsaw": "~0.1.0" 2117 | } 2118 | }, 2119 | "binary-extensions": { 2120 | "version": "2.2.0", 2121 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 2122 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 2123 | "dev": true 2124 | }, 2125 | "bluebird": { 2126 | "version": "3.4.7", 2127 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.4.7.tgz", 2128 | "integrity": "sha1-9y12C+Cbf3bQjtj66Ysomo0F+rM=", 2129 | "dev": true 2130 | }, 2131 | "brace-expansion": { 2132 | "version": "1.1.11", 2133 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2134 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2135 | "dev": true, 2136 | "requires": { 2137 | "balanced-match": "^1.0.0", 2138 | "concat-map": "0.0.1" 2139 | } 2140 | }, 2141 | "braces": { 2142 | "version": "3.0.2", 2143 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 2144 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 2145 | "dev": true, 2146 | "requires": { 2147 | "fill-range": "^7.0.1" 2148 | } 2149 | }, 2150 | "browser-stdout": { 2151 | "version": "1.3.1", 2152 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 2153 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 2154 | "dev": true 2155 | }, 2156 | "buffer-indexof-polyfill": { 2157 | "version": "1.0.2", 2158 | "resolved": "https://registry.npmjs.org/buffer-indexof-polyfill/-/buffer-indexof-polyfill-1.0.2.tgz", 2159 | "integrity": "sha512-I7wzHwA3t1/lwXQh+A5PbNvJxgfo5r3xulgpYDB5zckTu/Z9oUK9biouBKQUjEqzaz3HnAT6TYoovmE+GqSf7A==", 2160 | "dev": true 2161 | }, 2162 | "buffers": { 2163 | "version": "0.1.1", 2164 | "resolved": "https://registry.npmjs.org/buffers/-/buffers-0.1.1.tgz", 2165 | "integrity": "sha1-skV5w77U1tOWru5tmorn9Ugqt7s=", 2166 | "dev": true 2167 | }, 2168 | "callsites": { 2169 | "version": "3.1.0", 2170 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 2171 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 2172 | "dev": true 2173 | }, 2174 | "camelcase": { 2175 | "version": "6.3.0", 2176 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 2177 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 2178 | "dev": true 2179 | }, 2180 | "chainsaw": { 2181 | "version": "0.1.0", 2182 | "resolved": "https://registry.npmjs.org/chainsaw/-/chainsaw-0.1.0.tgz", 2183 | "integrity": "sha1-XqtQsor+WAdNDVgpE4iCi15fvJg=", 2184 | "dev": true, 2185 | "requires": { 2186 | "traverse": ">=0.3.0 <0.4" 2187 | } 2188 | }, 2189 | "chalk": { 2190 | "version": "4.1.2", 2191 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2192 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2193 | "dev": true, 2194 | "requires": { 2195 | "ansi-styles": "^4.1.0", 2196 | "supports-color": "^7.1.0" 2197 | } 2198 | }, 2199 | "chokidar": { 2200 | "version": "3.5.2", 2201 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.2.tgz", 2202 | "integrity": "sha512-ekGhOnNVPgT77r4K/U3GDhu+FQ2S8TnK/s2KbIGXi0SZWuwkZ2QNyfWdZW+TVfn84DpEP7rLeCt2UI6bJ8GwbQ==", 2203 | "dev": true, 2204 | "requires": { 2205 | "anymatch": "~3.1.2", 2206 | "braces": "~3.0.2", 2207 | "fsevents": "~2.3.2", 2208 | "glob-parent": "~5.1.2", 2209 | "is-binary-path": "~2.1.0", 2210 | "is-glob": "~4.0.1", 2211 | "normalize-path": "~3.0.0", 2212 | "readdirp": "~3.6.0" 2213 | }, 2214 | "dependencies": { 2215 | "glob-parent": { 2216 | "version": "5.1.2", 2217 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2218 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2219 | "dev": true, 2220 | "requires": { 2221 | "is-glob": "^4.0.1" 2222 | } 2223 | } 2224 | } 2225 | }, 2226 | "cliui": { 2227 | "version": "7.0.4", 2228 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 2229 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 2230 | "dev": true, 2231 | "requires": { 2232 | "string-width": "^4.2.0", 2233 | "strip-ansi": "^6.0.0", 2234 | "wrap-ansi": "^7.0.0" 2235 | } 2236 | }, 2237 | "color-convert": { 2238 | "version": "2.0.1", 2239 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2240 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2241 | "dev": true, 2242 | "requires": { 2243 | "color-name": "~1.1.4" 2244 | } 2245 | }, 2246 | "color-name": { 2247 | "version": "1.1.4", 2248 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2249 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2250 | "dev": true 2251 | }, 2252 | "concat-map": { 2253 | "version": "0.0.1", 2254 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2255 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 2256 | "dev": true 2257 | }, 2258 | "core-util-is": { 2259 | "version": "1.0.3", 2260 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", 2261 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", 2262 | "dev": true 2263 | }, 2264 | "cross-spawn": { 2265 | "version": "7.0.3", 2266 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 2267 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 2268 | "dev": true, 2269 | "requires": { 2270 | "path-key": "^3.1.0", 2271 | "shebang-command": "^2.0.0", 2272 | "which": "^2.0.1" 2273 | } 2274 | }, 2275 | "debug": { 2276 | "version": "4.3.3", 2277 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", 2278 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", 2279 | "dev": true, 2280 | "requires": { 2281 | "ms": "2.1.2" 2282 | } 2283 | }, 2284 | "decamelize": { 2285 | "version": "4.0.0", 2286 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", 2287 | "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", 2288 | "dev": true 2289 | }, 2290 | "deep-is": { 2291 | "version": "0.1.4", 2292 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 2293 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 2294 | "dev": true 2295 | }, 2296 | "diff": { 2297 | "version": "5.0.0", 2298 | "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", 2299 | "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", 2300 | "dev": true 2301 | }, 2302 | "doctrine": { 2303 | "version": "3.0.0", 2304 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 2305 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 2306 | "dev": true, 2307 | "requires": { 2308 | "esutils": "^2.0.2" 2309 | } 2310 | }, 2311 | "duplexer2": { 2312 | "version": "0.1.4", 2313 | "resolved": "https://registry.npmjs.org/duplexer2/-/duplexer2-0.1.4.tgz", 2314 | "integrity": "sha1-ixLauHjA1p4+eJEFFmKjL8a93ME=", 2315 | "dev": true, 2316 | "requires": { 2317 | "readable-stream": "^2.0.2" 2318 | } 2319 | }, 2320 | "emoji-regex": { 2321 | "version": "8.0.0", 2322 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2323 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2324 | "dev": true 2325 | }, 2326 | "enquirer": { 2327 | "version": "2.3.6", 2328 | "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.3.6.tgz", 2329 | "integrity": "sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==", 2330 | "dev": true, 2331 | "requires": { 2332 | "ansi-colors": "^4.1.1" 2333 | } 2334 | }, 2335 | "escalade": { 2336 | "version": "3.1.1", 2337 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 2338 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 2339 | "dev": true 2340 | }, 2341 | "escape-string-regexp": { 2342 | "version": "4.0.0", 2343 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2344 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2345 | "dev": true 2346 | }, 2347 | "eslint": { 2348 | "version": "8.6.0", 2349 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.6.0.tgz", 2350 | "integrity": "sha512-UvxdOJ7mXFlw7iuHZA4jmzPaUqIw54mZrv+XPYKNbKdLR0et4rf60lIZUU9kiNtnzzMzGWxMV+tQ7uG7JG8DPw==", 2351 | "dev": true, 2352 | "requires": { 2353 | "@eslint/eslintrc": "^1.0.5", 2354 | "@humanwhocodes/config-array": "^0.9.2", 2355 | "ajv": "^6.10.0", 2356 | "chalk": "^4.0.0", 2357 | "cross-spawn": "^7.0.2", 2358 | "debug": "^4.3.2", 2359 | "doctrine": "^3.0.0", 2360 | "enquirer": "^2.3.5", 2361 | "escape-string-regexp": "^4.0.0", 2362 | "eslint-scope": "^7.1.0", 2363 | "eslint-utils": "^3.0.0", 2364 | "eslint-visitor-keys": "^3.1.0", 2365 | "espree": "^9.3.0", 2366 | "esquery": "^1.4.0", 2367 | "esutils": "^2.0.2", 2368 | "fast-deep-equal": "^3.1.3", 2369 | "file-entry-cache": "^6.0.1", 2370 | "functional-red-black-tree": "^1.0.1", 2371 | "glob-parent": "^6.0.1", 2372 | "globals": "^13.6.0", 2373 | "ignore": "^4.0.6", 2374 | "import-fresh": "^3.0.0", 2375 | "imurmurhash": "^0.1.4", 2376 | "is-glob": "^4.0.0", 2377 | "js-yaml": "^4.1.0", 2378 | "json-stable-stringify-without-jsonify": "^1.0.1", 2379 | "levn": "^0.4.1", 2380 | "lodash.merge": "^4.6.2", 2381 | "minimatch": "^3.0.4", 2382 | "natural-compare": "^1.4.0", 2383 | "optionator": "^0.9.1", 2384 | "progress": "^2.0.0", 2385 | "regexpp": "^3.2.0", 2386 | "semver": "^7.2.1", 2387 | "strip-ansi": "^6.0.1", 2388 | "strip-json-comments": "^3.1.0", 2389 | "text-table": "^0.2.0", 2390 | "v8-compile-cache": "^2.0.3" 2391 | } 2392 | }, 2393 | "eslint-scope": { 2394 | "version": "7.1.0", 2395 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.0.tgz", 2396 | "integrity": "sha512-aWwkhnS0qAXqNOgKOK0dJ2nvzEbhEvpy8OlJ9kZ0FeZnA6zpjv1/Vei+puGFFX7zkPCkHHXb7IDX3A+7yPrRWg==", 2397 | "dev": true, 2398 | "requires": { 2399 | "esrecurse": "^4.3.0", 2400 | "estraverse": "^5.2.0" 2401 | } 2402 | }, 2403 | "eslint-utils": { 2404 | "version": "3.0.0", 2405 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", 2406 | "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", 2407 | "dev": true, 2408 | "requires": { 2409 | "eslint-visitor-keys": "^2.0.0" 2410 | }, 2411 | "dependencies": { 2412 | "eslint-visitor-keys": { 2413 | "version": "2.1.0", 2414 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 2415 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 2416 | "dev": true 2417 | } 2418 | } 2419 | }, 2420 | "eslint-visitor-keys": { 2421 | "version": "3.1.0", 2422 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.1.0.tgz", 2423 | "integrity": "sha512-yWJFpu4DtjsWKkt5GeNBBuZMlNcYVs6vRCLoCVEJrTjaSB6LC98gFipNK/erM2Heg/E8mIK+hXG/pJMLK+eRZA==", 2424 | "dev": true 2425 | }, 2426 | "espree": { 2427 | "version": "9.3.0", 2428 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.3.0.tgz", 2429 | "integrity": "sha512-d/5nCsb0JcqsSEeQzFZ8DH1RmxPcglRWh24EFTlUEmCKoehXGdpsx0RkHDubqUI8LSAIKMQp4r9SzQ3n+sm4HQ==", 2430 | "dev": true, 2431 | "requires": { 2432 | "acorn": "^8.7.0", 2433 | "acorn-jsx": "^5.3.1", 2434 | "eslint-visitor-keys": "^3.1.0" 2435 | } 2436 | }, 2437 | "esquery": { 2438 | "version": "1.4.0", 2439 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 2440 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 2441 | "dev": true, 2442 | "requires": { 2443 | "estraverse": "^5.1.0" 2444 | } 2445 | }, 2446 | "esrecurse": { 2447 | "version": "4.3.0", 2448 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2449 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2450 | "dev": true, 2451 | "requires": { 2452 | "estraverse": "^5.2.0" 2453 | } 2454 | }, 2455 | "estraverse": { 2456 | "version": "5.3.0", 2457 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 2458 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 2459 | "dev": true 2460 | }, 2461 | "esutils": { 2462 | "version": "2.0.3", 2463 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2464 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2465 | "dev": true 2466 | }, 2467 | "fast-deep-equal": { 2468 | "version": "3.1.3", 2469 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2470 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2471 | "dev": true 2472 | }, 2473 | "fast-json-stable-stringify": { 2474 | "version": "2.1.0", 2475 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 2476 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 2477 | "dev": true 2478 | }, 2479 | "fast-levenshtein": { 2480 | "version": "2.0.6", 2481 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2482 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 2483 | "dev": true 2484 | }, 2485 | "file-entry-cache": { 2486 | "version": "6.0.1", 2487 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 2488 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 2489 | "dev": true, 2490 | "requires": { 2491 | "flat-cache": "^3.0.4" 2492 | } 2493 | }, 2494 | "fill-range": { 2495 | "version": "7.0.1", 2496 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2497 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2498 | "dev": true, 2499 | "requires": { 2500 | "to-regex-range": "^5.0.1" 2501 | } 2502 | }, 2503 | "find-up": { 2504 | "version": "5.0.0", 2505 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2506 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2507 | "dev": true, 2508 | "requires": { 2509 | "locate-path": "^6.0.0", 2510 | "path-exists": "^4.0.0" 2511 | } 2512 | }, 2513 | "flat": { 2514 | "version": "5.0.2", 2515 | "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", 2516 | "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", 2517 | "dev": true 2518 | }, 2519 | "flat-cache": { 2520 | "version": "3.0.4", 2521 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 2522 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 2523 | "dev": true, 2524 | "requires": { 2525 | "flatted": "^3.1.0", 2526 | "rimraf": "^3.0.2" 2527 | } 2528 | }, 2529 | "flatted": { 2530 | "version": "3.2.4", 2531 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.4.tgz", 2532 | "integrity": "sha512-8/sOawo8tJ4QOBX8YlQBMxL8+RLZfxMQOif9o0KUKTNTjMYElWPE0r/m5VNFxTRd0NSw8qSy8dajrwX4RYI1Hw==", 2533 | "dev": true 2534 | }, 2535 | "fs.realpath": { 2536 | "version": "1.0.0", 2537 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2538 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 2539 | "dev": true 2540 | }, 2541 | "fsevents": { 2542 | "version": "2.3.2", 2543 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2544 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2545 | "dev": true, 2546 | "optional": true 2547 | }, 2548 | "fstream": { 2549 | "version": "1.0.12", 2550 | "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.12.tgz", 2551 | "integrity": "sha512-WvJ193OHa0GHPEL+AycEJgxvBEwyfRkN1vhjca23OaPVMCaLCXTd5qAu82AjTcgP1UJmytkOKb63Ypde7raDIg==", 2552 | "dev": true, 2553 | "requires": { 2554 | "graceful-fs": "^4.1.2", 2555 | "inherits": "~2.0.0", 2556 | "mkdirp": ">=0.5 0", 2557 | "rimraf": "2" 2558 | }, 2559 | "dependencies": { 2560 | "rimraf": { 2561 | "version": "2.7.1", 2562 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 2563 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 2564 | "dev": true, 2565 | "requires": { 2566 | "glob": "^7.1.3" 2567 | } 2568 | } 2569 | } 2570 | }, 2571 | "functional-red-black-tree": { 2572 | "version": "1.0.1", 2573 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 2574 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 2575 | "dev": true 2576 | }, 2577 | "get-caller-file": { 2578 | "version": "2.0.5", 2579 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 2580 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 2581 | "dev": true 2582 | }, 2583 | "glob": { 2584 | "version": "7.2.0", 2585 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", 2586 | "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", 2587 | "dev": true, 2588 | "requires": { 2589 | "fs.realpath": "^1.0.0", 2590 | "inflight": "^1.0.4", 2591 | "inherits": "2", 2592 | "minimatch": "^3.0.4", 2593 | "once": "^1.3.0", 2594 | "path-is-absolute": "^1.0.0" 2595 | } 2596 | }, 2597 | "glob-parent": { 2598 | "version": "6.0.2", 2599 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 2600 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 2601 | "dev": true, 2602 | "requires": { 2603 | "is-glob": "^4.0.3" 2604 | } 2605 | }, 2606 | "globals": { 2607 | "version": "13.12.0", 2608 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.12.0.tgz", 2609 | "integrity": "sha512-uS8X6lSKN2JumVoXrbUz+uG4BYG+eiawqm3qFcT7ammfbUHeCBoJMlHcec/S3krSk73/AE/f0szYFmgAA3kYZg==", 2610 | "dev": true, 2611 | "requires": { 2612 | "type-fest": "^0.20.2" 2613 | } 2614 | }, 2615 | "graceful-fs": { 2616 | "version": "4.2.8", 2617 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.8.tgz", 2618 | "integrity": "sha512-qkIilPUYcNhJpd33n0GBXTB1MMPp14TxEsEs0pTrsSVucApsYzW5V+Q8Qxhik6KU3evy+qkAAowTByymK0avdg==", 2619 | "dev": true 2620 | }, 2621 | "growl": { 2622 | "version": "1.10.5", 2623 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 2624 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 2625 | "dev": true 2626 | }, 2627 | "has-flag": { 2628 | "version": "4.0.0", 2629 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2630 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2631 | "dev": true 2632 | }, 2633 | "he": { 2634 | "version": "1.2.0", 2635 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 2636 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 2637 | "dev": true 2638 | }, 2639 | "http-proxy-agent": { 2640 | "version": "4.0.1", 2641 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 2642 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 2643 | "dev": true, 2644 | "requires": { 2645 | "@tootallnate/once": "1", 2646 | "agent-base": "6", 2647 | "debug": "4" 2648 | } 2649 | }, 2650 | "https-proxy-agent": { 2651 | "version": "5.0.0", 2652 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", 2653 | "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", 2654 | "dev": true, 2655 | "requires": { 2656 | "agent-base": "6", 2657 | "debug": "4" 2658 | } 2659 | }, 2660 | "ignore": { 2661 | "version": "4.0.6", 2662 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 2663 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 2664 | "dev": true 2665 | }, 2666 | "import-fresh": { 2667 | "version": "3.3.0", 2668 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2669 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2670 | "dev": true, 2671 | "requires": { 2672 | "parent-module": "^1.0.0", 2673 | "resolve-from": "^4.0.0" 2674 | } 2675 | }, 2676 | "imurmurhash": { 2677 | "version": "0.1.4", 2678 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2679 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 2680 | "dev": true 2681 | }, 2682 | "inflight": { 2683 | "version": "1.0.6", 2684 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2685 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 2686 | "dev": true, 2687 | "requires": { 2688 | "once": "^1.3.0", 2689 | "wrappy": "1" 2690 | } 2691 | }, 2692 | "inherits": { 2693 | "version": "2.0.4", 2694 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2695 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2696 | "dev": true 2697 | }, 2698 | "is-binary-path": { 2699 | "version": "2.1.0", 2700 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 2701 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 2702 | "dev": true, 2703 | "requires": { 2704 | "binary-extensions": "^2.0.0" 2705 | } 2706 | }, 2707 | "is-extglob": { 2708 | "version": "2.1.1", 2709 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2710 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 2711 | "dev": true 2712 | }, 2713 | "is-fullwidth-code-point": { 2714 | "version": "3.0.0", 2715 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2716 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2717 | "dev": true 2718 | }, 2719 | "is-glob": { 2720 | "version": "4.0.3", 2721 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2722 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2723 | "dev": true, 2724 | "requires": { 2725 | "is-extglob": "^2.1.1" 2726 | } 2727 | }, 2728 | "is-number": { 2729 | "version": "7.0.0", 2730 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2731 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2732 | "dev": true 2733 | }, 2734 | "is-plain-obj": { 2735 | "version": "2.1.0", 2736 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", 2737 | "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", 2738 | "dev": true 2739 | }, 2740 | "is-unicode-supported": { 2741 | "version": "0.1.0", 2742 | "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", 2743 | "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", 2744 | "dev": true 2745 | }, 2746 | "isarray": { 2747 | "version": "1.0.0", 2748 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 2749 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 2750 | "dev": true 2751 | }, 2752 | "isexe": { 2753 | "version": "2.0.0", 2754 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2755 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 2756 | "dev": true 2757 | }, 2758 | "js-yaml": { 2759 | "version": "4.1.0", 2760 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2761 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2762 | "dev": true, 2763 | "requires": { 2764 | "argparse": "^2.0.1" 2765 | } 2766 | }, 2767 | "json-schema-traverse": { 2768 | "version": "0.4.1", 2769 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2770 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2771 | "dev": true 2772 | }, 2773 | "json-stable-stringify-without-jsonify": { 2774 | "version": "1.0.1", 2775 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2776 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 2777 | "dev": true 2778 | }, 2779 | "levn": { 2780 | "version": "0.4.1", 2781 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2782 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2783 | "dev": true, 2784 | "requires": { 2785 | "prelude-ls": "^1.2.1", 2786 | "type-check": "~0.4.0" 2787 | } 2788 | }, 2789 | "listenercount": { 2790 | "version": "1.0.1", 2791 | "resolved": "https://registry.npmjs.org/listenercount/-/listenercount-1.0.1.tgz", 2792 | "integrity": "sha1-hMinKrWcRyUyFIDJdeZQg0LnCTc=", 2793 | "dev": true 2794 | }, 2795 | "locate-path": { 2796 | "version": "6.0.0", 2797 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2798 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2799 | "dev": true, 2800 | "requires": { 2801 | "p-locate": "^5.0.0" 2802 | } 2803 | }, 2804 | "lodash.merge": { 2805 | "version": "4.6.2", 2806 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2807 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2808 | "dev": true 2809 | }, 2810 | "log-symbols": { 2811 | "version": "4.1.0", 2812 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", 2813 | "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", 2814 | "dev": true, 2815 | "requires": { 2816 | "chalk": "^4.1.0", 2817 | "is-unicode-supported": "^0.1.0" 2818 | } 2819 | }, 2820 | "lru-cache": { 2821 | "version": "6.0.0", 2822 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2823 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2824 | "dev": true, 2825 | "requires": { 2826 | "yallist": "^4.0.0" 2827 | } 2828 | }, 2829 | "minimatch": { 2830 | "version": "3.0.4", 2831 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2832 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2833 | "dev": true, 2834 | "requires": { 2835 | "brace-expansion": "^1.1.7" 2836 | } 2837 | }, 2838 | "minimist": { 2839 | "version": "1.2.5", 2840 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 2841 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 2842 | "dev": true 2843 | }, 2844 | "mkdirp": { 2845 | "version": "0.5.5", 2846 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 2847 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 2848 | "dev": true, 2849 | "requires": { 2850 | "minimist": "^1.2.5" 2851 | } 2852 | }, 2853 | "mocha": { 2854 | "version": "9.1.3", 2855 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-9.1.3.tgz", 2856 | "integrity": "sha512-Xcpl9FqXOAYqI3j79pEtHBBnQgVXIhpULjGQa7DVb0Po+VzmSIK9kanAiWLHoRR/dbZ2qpdPshuXr8l1VaHCzw==", 2857 | "dev": true, 2858 | "requires": { 2859 | "@ungap/promise-all-settled": "1.1.2", 2860 | "ansi-colors": "4.1.1", 2861 | "browser-stdout": "1.3.1", 2862 | "chokidar": "3.5.2", 2863 | "debug": "4.3.2", 2864 | "diff": "5.0.0", 2865 | "escape-string-regexp": "4.0.0", 2866 | "find-up": "5.0.0", 2867 | "glob": "7.1.7", 2868 | "growl": "1.10.5", 2869 | "he": "1.2.0", 2870 | "js-yaml": "4.1.0", 2871 | "log-symbols": "4.1.0", 2872 | "minimatch": "3.0.4", 2873 | "ms": "2.1.3", 2874 | "nanoid": "3.1.25", 2875 | "serialize-javascript": "6.0.0", 2876 | "strip-json-comments": "3.1.1", 2877 | "supports-color": "8.1.1", 2878 | "which": "2.0.2", 2879 | "workerpool": "6.1.5", 2880 | "yargs": "16.2.0", 2881 | "yargs-parser": "20.2.4", 2882 | "yargs-unparser": "2.0.0" 2883 | }, 2884 | "dependencies": { 2885 | "debug": { 2886 | "version": "4.3.2", 2887 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.2.tgz", 2888 | "integrity": "sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==", 2889 | "dev": true, 2890 | "requires": { 2891 | "ms": "2.1.2" 2892 | }, 2893 | "dependencies": { 2894 | "ms": { 2895 | "version": "2.1.2", 2896 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2897 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2898 | "dev": true 2899 | } 2900 | } 2901 | }, 2902 | "glob": { 2903 | "version": "7.1.7", 2904 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", 2905 | "integrity": "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==", 2906 | "dev": true, 2907 | "requires": { 2908 | "fs.realpath": "^1.0.0", 2909 | "inflight": "^1.0.4", 2910 | "inherits": "2", 2911 | "minimatch": "^3.0.4", 2912 | "once": "^1.3.0", 2913 | "path-is-absolute": "^1.0.0" 2914 | } 2915 | }, 2916 | "ms": { 2917 | "version": "2.1.3", 2918 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2919 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 2920 | "dev": true 2921 | }, 2922 | "supports-color": { 2923 | "version": "8.1.1", 2924 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 2925 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 2926 | "dev": true, 2927 | "requires": { 2928 | "has-flag": "^4.0.0" 2929 | } 2930 | } 2931 | } 2932 | }, 2933 | "ms": { 2934 | "version": "2.1.2", 2935 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2936 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2937 | "dev": true 2938 | }, 2939 | "nanoid": { 2940 | "version": "3.1.25", 2941 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.1.25.tgz", 2942 | "integrity": "sha512-rdwtIXaXCLFAQbnfqDRnI6jaRHp9fTcYBjtFKE8eezcZ7LuLjhUaQGNeMXf1HmRoCH32CLz6XwX0TtxEOS/A3Q==", 2943 | "dev": true 2944 | }, 2945 | "natural-compare": { 2946 | "version": "1.4.0", 2947 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2948 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2949 | "dev": true 2950 | }, 2951 | "normalize-path": { 2952 | "version": "3.0.0", 2953 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2954 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2955 | "dev": true 2956 | }, 2957 | "once": { 2958 | "version": "1.4.0", 2959 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2960 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2961 | "dev": true, 2962 | "requires": { 2963 | "wrappy": "1" 2964 | } 2965 | }, 2966 | "optionator": { 2967 | "version": "0.9.1", 2968 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 2969 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 2970 | "dev": true, 2971 | "requires": { 2972 | "deep-is": "^0.1.3", 2973 | "fast-levenshtein": "^2.0.6", 2974 | "levn": "^0.4.1", 2975 | "prelude-ls": "^1.2.1", 2976 | "type-check": "^0.4.0", 2977 | "word-wrap": "^1.2.3" 2978 | } 2979 | }, 2980 | "p-limit": { 2981 | "version": "3.1.0", 2982 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2983 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2984 | "dev": true, 2985 | "requires": { 2986 | "yocto-queue": "^0.1.0" 2987 | } 2988 | }, 2989 | "p-locate": { 2990 | "version": "5.0.0", 2991 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2992 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2993 | "dev": true, 2994 | "requires": { 2995 | "p-limit": "^3.0.2" 2996 | } 2997 | }, 2998 | "parent-module": { 2999 | "version": "1.0.1", 3000 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 3001 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 3002 | "dev": true, 3003 | "requires": { 3004 | "callsites": "^3.0.0" 3005 | } 3006 | }, 3007 | "path-exists": { 3008 | "version": "4.0.0", 3009 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 3010 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 3011 | "dev": true 3012 | }, 3013 | "path-is-absolute": { 3014 | "version": "1.0.1", 3015 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3016 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 3017 | "dev": true 3018 | }, 3019 | "path-key": { 3020 | "version": "3.1.1", 3021 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3022 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3023 | "dev": true 3024 | }, 3025 | "picomatch": { 3026 | "version": "2.3.0", 3027 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 3028 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 3029 | "dev": true 3030 | }, 3031 | "prelude-ls": { 3032 | "version": "1.2.1", 3033 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 3034 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 3035 | "dev": true 3036 | }, 3037 | "process-nextick-args": { 3038 | "version": "2.0.1", 3039 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 3040 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 3041 | "dev": true 3042 | }, 3043 | "progress": { 3044 | "version": "2.0.3", 3045 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 3046 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 3047 | "dev": true 3048 | }, 3049 | "punycode": { 3050 | "version": "2.1.1", 3051 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 3052 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 3053 | "dev": true 3054 | }, 3055 | "randombytes": { 3056 | "version": "2.1.0", 3057 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 3058 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 3059 | "dev": true, 3060 | "requires": { 3061 | "safe-buffer": "^5.1.0" 3062 | } 3063 | }, 3064 | "readable-stream": { 3065 | "version": "2.3.7", 3066 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 3067 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 3068 | "dev": true, 3069 | "requires": { 3070 | "core-util-is": "~1.0.0", 3071 | "inherits": "~2.0.3", 3072 | "isarray": "~1.0.0", 3073 | "process-nextick-args": "~2.0.0", 3074 | "safe-buffer": "~5.1.1", 3075 | "string_decoder": "~1.1.1", 3076 | "util-deprecate": "~1.0.1" 3077 | } 3078 | }, 3079 | "readdirp": { 3080 | "version": "3.6.0", 3081 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 3082 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 3083 | "dev": true, 3084 | "requires": { 3085 | "picomatch": "^2.2.1" 3086 | } 3087 | }, 3088 | "regexpp": { 3089 | "version": "3.2.0", 3090 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 3091 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 3092 | "dev": true 3093 | }, 3094 | "require-directory": { 3095 | "version": "2.1.1", 3096 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 3097 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 3098 | "dev": true 3099 | }, 3100 | "resolve-from": { 3101 | "version": "4.0.0", 3102 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 3103 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 3104 | "dev": true 3105 | }, 3106 | "rimraf": { 3107 | "version": "3.0.2", 3108 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 3109 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 3110 | "dev": true, 3111 | "requires": { 3112 | "glob": "^7.1.3" 3113 | } 3114 | }, 3115 | "safe-buffer": { 3116 | "version": "5.1.2", 3117 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 3118 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 3119 | "dev": true 3120 | }, 3121 | "semver": { 3122 | "version": "7.3.5", 3123 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 3124 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 3125 | "dev": true, 3126 | "requires": { 3127 | "lru-cache": "^6.0.0" 3128 | } 3129 | }, 3130 | "serialize-javascript": { 3131 | "version": "6.0.0", 3132 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", 3133 | "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", 3134 | "dev": true, 3135 | "requires": { 3136 | "randombytes": "^2.1.0" 3137 | } 3138 | }, 3139 | "setimmediate": { 3140 | "version": "1.0.5", 3141 | "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", 3142 | "integrity": "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU=", 3143 | "dev": true 3144 | }, 3145 | "shebang-command": { 3146 | "version": "2.0.0", 3147 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3148 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3149 | "dev": true, 3150 | "requires": { 3151 | "shebang-regex": "^3.0.0" 3152 | } 3153 | }, 3154 | "shebang-regex": { 3155 | "version": "3.0.0", 3156 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3157 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3158 | "dev": true 3159 | }, 3160 | "string_decoder": { 3161 | "version": "1.1.1", 3162 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 3163 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 3164 | "dev": true, 3165 | "requires": { 3166 | "safe-buffer": "~5.1.0" 3167 | } 3168 | }, 3169 | "string-width": { 3170 | "version": "4.2.3", 3171 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3172 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3173 | "dev": true, 3174 | "requires": { 3175 | "emoji-regex": "^8.0.0", 3176 | "is-fullwidth-code-point": "^3.0.0", 3177 | "strip-ansi": "^6.0.1" 3178 | } 3179 | }, 3180 | "strip-ansi": { 3181 | "version": "6.0.1", 3182 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3183 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3184 | "dev": true, 3185 | "requires": { 3186 | "ansi-regex": "^5.0.1" 3187 | } 3188 | }, 3189 | "strip-json-comments": { 3190 | "version": "3.1.1", 3191 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3192 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3193 | "dev": true 3194 | }, 3195 | "supports-color": { 3196 | "version": "7.2.0", 3197 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 3198 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 3199 | "dev": true, 3200 | "requires": { 3201 | "has-flag": "^4.0.0" 3202 | } 3203 | }, 3204 | "text-table": { 3205 | "version": "0.2.0", 3206 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3207 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 3208 | "dev": true 3209 | }, 3210 | "to-regex-range": { 3211 | "version": "5.0.1", 3212 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3213 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3214 | "dev": true, 3215 | "requires": { 3216 | "is-number": "^7.0.0" 3217 | } 3218 | }, 3219 | "traverse": { 3220 | "version": "0.3.9", 3221 | "resolved": "https://registry.npmjs.org/traverse/-/traverse-0.3.9.tgz", 3222 | "integrity": "sha1-cXuPIgzAu3tE5AUUwisui7xw2Lk=", 3223 | "dev": true 3224 | }, 3225 | "type-check": { 3226 | "version": "0.4.0", 3227 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3228 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3229 | "dev": true, 3230 | "requires": { 3231 | "prelude-ls": "^1.2.1" 3232 | } 3233 | }, 3234 | "type-fest": { 3235 | "version": "0.20.2", 3236 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 3237 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 3238 | "dev": true 3239 | }, 3240 | "typescript": { 3241 | "version": "4.5.4", 3242 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.5.4.tgz", 3243 | "integrity": "sha512-VgYs2A2QIRuGphtzFV7aQJduJ2gyfTljngLzjpfW9FoYZF6xuw1W0vW9ghCKLfcWrCFxK81CSGRAvS1pn4fIUg==", 3244 | "dev": true 3245 | }, 3246 | "unzipper": { 3247 | "version": "0.10.11", 3248 | "resolved": "https://registry.npmjs.org/unzipper/-/unzipper-0.10.11.tgz", 3249 | "integrity": "sha512-+BrAq2oFqWod5IESRjL3S8baohbevGcVA+teAIOYWM3pDVdseogqbzhhvvmiyQrUNKFUnDMtELW3X8ykbyDCJw==", 3250 | "dev": true, 3251 | "requires": { 3252 | "big-integer": "^1.6.17", 3253 | "binary": "~0.3.0", 3254 | "bluebird": "~3.4.1", 3255 | "buffer-indexof-polyfill": "~1.0.0", 3256 | "duplexer2": "~0.1.4", 3257 | "fstream": "^1.0.12", 3258 | "graceful-fs": "^4.2.2", 3259 | "listenercount": "~1.0.1", 3260 | "readable-stream": "~2.3.6", 3261 | "setimmediate": "~1.0.4" 3262 | } 3263 | }, 3264 | "uri-js": { 3265 | "version": "4.4.1", 3266 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 3267 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 3268 | "dev": true, 3269 | "requires": { 3270 | "punycode": "^2.1.0" 3271 | } 3272 | }, 3273 | "util-deprecate": { 3274 | "version": "1.0.2", 3275 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3276 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 3277 | "dev": true 3278 | }, 3279 | "v8-compile-cache": { 3280 | "version": "2.3.0", 3281 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 3282 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 3283 | "dev": true 3284 | }, 3285 | "which": { 3286 | "version": "2.0.2", 3287 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3288 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3289 | "dev": true, 3290 | "requires": { 3291 | "isexe": "^2.0.0" 3292 | } 3293 | }, 3294 | "word-wrap": { 3295 | "version": "1.2.3", 3296 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 3297 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 3298 | "dev": true 3299 | }, 3300 | "workerpool": { 3301 | "version": "6.1.5", 3302 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.1.5.tgz", 3303 | "integrity": "sha512-XdKkCK0Zqc6w3iTxLckiuJ81tiD/o5rBE/m+nXpRCB+/Sq4DqkfXZ/x0jW02DG1tGsfUGXbTJyZDP+eu67haSw==", 3304 | "dev": true 3305 | }, 3306 | "wrap-ansi": { 3307 | "version": "7.0.0", 3308 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3309 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3310 | "dev": true, 3311 | "requires": { 3312 | "ansi-styles": "^4.0.0", 3313 | "string-width": "^4.1.0", 3314 | "strip-ansi": "^6.0.0" 3315 | } 3316 | }, 3317 | "wrappy": { 3318 | "version": "1.0.2", 3319 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3320 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 3321 | "dev": true 3322 | }, 3323 | "y18n": { 3324 | "version": "5.0.8", 3325 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3326 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3327 | "dev": true 3328 | }, 3329 | "yallist": { 3330 | "version": "4.0.0", 3331 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3332 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3333 | "dev": true 3334 | }, 3335 | "yargs": { 3336 | "version": "16.2.0", 3337 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 3338 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 3339 | "dev": true, 3340 | "requires": { 3341 | "cliui": "^7.0.2", 3342 | "escalade": "^3.1.1", 3343 | "get-caller-file": "^2.0.5", 3344 | "require-directory": "^2.1.1", 3345 | "string-width": "^4.2.0", 3346 | "y18n": "^5.0.5", 3347 | "yargs-parser": "^20.2.2" 3348 | } 3349 | }, 3350 | "yargs-parser": { 3351 | "version": "20.2.4", 3352 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", 3353 | "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", 3354 | "dev": true 3355 | }, 3356 | "yargs-unparser": { 3357 | "version": "2.0.0", 3358 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", 3359 | "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", 3360 | "dev": true, 3361 | "requires": { 3362 | "camelcase": "^6.0.0", 3363 | "decamelize": "^4.0.0", 3364 | "flat": "^5.0.2", 3365 | "is-plain-obj": "^2.1.0" 3366 | } 3367 | }, 3368 | "yocto-queue": { 3369 | "version": "0.1.0", 3370 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3371 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3372 | "dev": true 3373 | } 3374 | } 3375 | } 3376 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "vscode-displayfile", 3 | "displayName": "IBM i Renderer", 4 | "description": "Preview IBM i display & printer files", 5 | "version": "0.1.3", 6 | "publisher": "halcyontechltd", 7 | "author": { 8 | "name": "Halcyon-Tech, Liam Allan" 9 | }, 10 | "keywords": [ 11 | "ibmi", 12 | "rpgle", 13 | "cobol", 14 | "ile", 15 | "iseries", 16 | "as400", 17 | "printer", 18 | "5250" 19 | ], 20 | "preview": true, 21 | "repository": "https://github.com/halcyon-tech/vscode-displayfile", 22 | "engines": { 23 | "vscode": "^1.63.0" 24 | }, 25 | "categories": [ 26 | "Other" 27 | ], 28 | "icon": "icon.png", 29 | "activationEvents": [ 30 | "onLanguage:dds.dspf", 31 | "onLanguage:dds.prtf" 32 | ], 33 | "main": "./src/extension.js", 34 | "contributes": { 35 | "snippets": [ 36 | { 37 | "path": "./schemas/dspf.code-snippets", 38 | "language": "dds.dspf" 39 | } 40 | ], 41 | "configuration": { 42 | "title": "Display File", 43 | "properties": { 44 | "vscode-displayfile.renderTimeout": { 45 | "type": "number", 46 | "description": "Amount of time to wait before rendering changes after the cursor has moved. You may have to restart VS Code if you change this value.", 47 | "default": 1500, 48 | "minimum": 0 49 | } 50 | } 51 | }, 52 | "commands": [ 53 | { 54 | "command": "vscode-displayfile.changeInd", 55 | "title": "Flip indicators", 56 | "category": "Display File" 57 | } 58 | ] 59 | }, 60 | "extensionDependencies": [ 61 | "barrettotte.ibmi-languages" 62 | ], 63 | "scripts": { 64 | "lint": "eslint .", 65 | "test": "node ./test", 66 | "package": "vsce package" 67 | }, 68 | "devDependencies": { 69 | "@types/glob": "^7.1.4", 70 | "@types/mocha": "^9.0.0", 71 | "@types/node": "14.x", 72 | "@types/vscode": "^1.63.0", 73 | "@vscode/test-electron": "^1.6.2", 74 | "eslint": "^8.6.0", 75 | "glob": "^7.1.7", 76 | "mocha": "^9.1.3", 77 | "typescript": "^4.4.4" 78 | } 79 | } 80 | -------------------------------------------------------------------------------- /schemas/dspf.code-snippets: -------------------------------------------------------------------------------- 1 | { 2 | "subfile": { 3 | "scope": "dds.dspf", 4 | "description": "Basic load all subfile", 5 | "isFileTemplate": true, 6 | "prefix": "subfile", 7 | "body": [ 8 | " A INDARA", 9 | " A CA12(12)", 10 | " A R SFLDTA SFL", 11 | " A RRN 4Y 0H", 12 | " A* DISPLAY DTA", 13 | " A XSEL 1A B 7 8", 14 | " A XID 3A O 7 12", 15 | " A XNAME 38A O 7 16", 16 | " A* COLOR HELLO", 17 | " A R SFLCTL SFLCTL(SFLDTA)", 18 | " A SFLPAG(0014)", 19 | " A SFLSIZ(9999)", 20 | " A OVERLAY", 21 | " A 85 SFLDSPCTL", 22 | " A 95 SFLDSP", 23 | " A N85 SFLCLR", 24 | " A SFLRRN 4S 0H SFLRCDNBR(CURSOR)", 25 | " A*", 26 | " A 6 6'Opt'", 27 | " A DSPATR(HI)", 28 | " A DSPATR(UL)", 29 | " A 6 12'ID'", 30 | " A DSPATR(HI)", 31 | " A DSPATR(UL)", 32 | " A 6 16'Name'", 33 | " A DSPATR(UL)", 34 | " A COLOR(WHT)", 35 | " A R FOOTER_FMT", 36 | " A OVERLAY", 37 | " A 3 6'F3=Exit'", 38 | " A COLOR(BLU)", 39 | " A 2 35'$1'", 40 | " A DSPATR(UL)", 41 | " A COLOR(WHT)", 42 | " A 4 6'5=View'", 43 | " A COLOR(BLU)", 44 | "", 45 | ] 46 | } 47 | } -------------------------------------------------------------------------------- /src/dspf.js: -------------------------------------------------------------------------------- 1 | 2 | class DisplayFile { 3 | constructor() { 4 | /** @type {RecordInfo[]} */ 5 | this.formats = []; 6 | 7 | /** @type {FieldInfo} */ 8 | this.currentField = null; 9 | 10 | /** @type {FieldInfo[]} */ 11 | this.currentFields = []; 12 | 13 | /** @type {RecordInfo} */ 14 | this.currentRecord = new RecordInfo(`GLOBAL`); 15 | } 16 | 17 | /** 18 | * @param {string[]} lines 19 | */ 20 | parse(lines) { 21 | let textCounter = 0; 22 | 23 | let conditionals, name, len, type, dec, inout, x, y, keywords; 24 | 25 | lines.forEach((line, index) => { 26 | line = line.padEnd(80); 27 | 28 | if (line[6] === `*`) return; 29 | 30 | conditionals = line.substring(6, 16).padEnd(10); 31 | name = line.substring(18, 28).trim(); 32 | len = line.substring(29, 34).trim(); 33 | type = line[34].toUpperCase(); 34 | dec = line.substring(35, 37).trim(); 35 | inout = line[37].toUpperCase(); 36 | y = line.substring(38, 41).trim(); 37 | x = line.substring(41, 44).trim(); 38 | keywords = line.substring(44).trimEnd(); 39 | 40 | switch (line[16]) { 41 | case 'R': 42 | if (this.currentField !== null) { 43 | this.currentField.handleKeywords(); 44 | this.currentFields.push(this.currentField); 45 | }; 46 | if (this.currentFields !== null) this.currentRecord.fields = this.currentFields; 47 | if (this.currentRecord !== null) { 48 | this.currentRecord.range.end = index; 49 | this.currentRecord.handleKeywords(); 50 | this.formats.push(this.currentRecord); 51 | } 52 | 53 | this.currentRecord = new RecordInfo(name); 54 | this.currentRecord.range.start = index; 55 | 56 | this.currentFields = []; 57 | this.currentField = null; 58 | 59 | this.HandleKeywords(keywords); 60 | break; 61 | 62 | case ' ': 63 | if ((x !== "" && y !== "") || inout === `H`) { 64 | // From a regular display file 65 | if (this.currentField !== null) { 66 | this.currentField.handleKeywords(); 67 | this.currentFields.push(this.currentField); 68 | } 69 | 70 | this.currentField = new FieldInfo(); 71 | this.currentField.position = { 72 | x: Number(x), 73 | y: Number(y) 74 | }; 75 | } else if (x !== "" && y === "") { 76 | // From a printer file with no Y position 77 | if (this.currentField !== null) { 78 | this.currentField.handleKeywords(); 79 | this.currentFields.push(this.currentField); 80 | } 81 | 82 | let totalX = Number(x); 83 | if (x.startsWith(`+`)) { 84 | totalX = this.currentFields[this.currentFields.length - 1].position.x + Number(x.substring(1)); 85 | 86 | if (this.currentFields[this.currentFields.length - 1].value) { 87 | totalX += this.currentFields[this.currentFields.length - 1].value.length; 88 | } 89 | } 90 | 91 | this.currentField = new FieldInfo(); 92 | this.currentField.position = { 93 | x: totalX, 94 | y: 0 95 | }; 96 | } 97 | 98 | if (name != "") 99 | { 100 | if (this.currentField) { 101 | this.currentField.name = name; 102 | this.currentField.value = ""; 103 | this.currentField.length = Number(len); 104 | switch (inout) 105 | { 106 | case "I": 107 | this.currentField.displayType = `input`; 108 | break; 109 | case "B": 110 | this.currentField.displayType = `both`; 111 | break; 112 | case "H": 113 | this.currentField.displayType = `hidden`; 114 | break; 115 | case " ": 116 | case "O": 117 | this.currentField.displayType = `output`; 118 | break; 119 | } 120 | 121 | this.currentField.decimals = 0; 122 | switch (type) 123 | { 124 | case "D": 125 | case "Z": 126 | case "Y": 127 | this.currentField.type = `decimal`; 128 | if (dec != "") this.currentField.decimals = Number(dec); 129 | break; 130 | case `L`: //Date 131 | this.currentField.length = 8; 132 | this.currentField.type = `char`; 133 | this.currentField.keywords.push({ 134 | name: `DATE`, 135 | value: undefined, 136 | conditions: [] 137 | }); 138 | break; 139 | case `T`: //Time 140 | this.currentField.length = 8; 141 | this.currentField.type = `char`; 142 | this.currentField.keywords.push({ 143 | name: `TIME`, 144 | value: undefined, 145 | conditions: [] 146 | }); 147 | break; 148 | default: 149 | this.currentField.type = `char`; 150 | break; 151 | } 152 | 153 | this.currentField.conditions.push( 154 | ...DisplayFile.parseConditionals(conditionals) 155 | ) 156 | 157 | this.HandleKeywords(keywords, conditionals); 158 | } 159 | } 160 | else 161 | { 162 | if (this.currentField != null) 163 | { 164 | if (this.currentField.name == null) 165 | { 166 | textCounter++; 167 | this.currentField.name = `TEXT${textCounter}`; 168 | if (this.currentField.value == null) this.currentField.value = ""; 169 | this.currentField.length = this.currentField.value.length; 170 | this.currentField.displayType = `const`; 171 | 172 | this.currentField.conditions.push( 173 | ...DisplayFile.parseConditionals(conditionals) 174 | ) 175 | } 176 | } 177 | this.HandleKeywords(keywords, conditionals); 178 | } 179 | break; 180 | } 181 | }); 182 | 183 | if (this.currentField !== null) { 184 | this.currentField.handleKeywords(); 185 | this.currentFields.push(this.currentField); 186 | }; 187 | if (this.currentFields !== null) this.currentRecord.fields = this.currentFields; 188 | if (this.currentRecord !== null) { 189 | this.currentRecord.range.end = lines.length; 190 | this.currentRecord.handleKeywords(); 191 | this.formats.push(this.currentRecord); 192 | } 193 | 194 | this.currentField = null; 195 | this.currentFields = null; 196 | this.currentRecord = null; 197 | } 198 | 199 | /** 200 | * @param {string} keywords 201 | * @param {string} [conditionals] 202 | * @returns 203 | */ 204 | HandleKeywords(keywords, conditionals = ``) { 205 | let insertIndex; 206 | 207 | if (this.currentField) { 208 | insertIndex = this.currentField.keywordStrings.keywordLines.push(keywords); 209 | this.currentField.keywordStrings.conditionalLines[insertIndex] = conditionals; 210 | } else { 211 | this.currentRecord.keywordStrings.push(keywords); 212 | } 213 | 214 | 215 | } 216 | 217 | static parseConditionals(conditionColumns) { 218 | if (conditionColumns.trim() === "") return []; 219 | 220 | /** @type {Conditional[]} */ 221 | let conditionals = []; 222 | 223 | //TODO: something with condition 224 | //const condition = conditionColumns.substring(0, 1); //A (and) or O (or) 225 | 226 | let current = ""; 227 | let negate = false; 228 | let indicator = 0; 229 | 230 | let cIndex = 1; 231 | 232 | while (cIndex <= 7) { 233 | current = conditionColumns.substring(cIndex, cIndex + 3); 234 | 235 | if (current.trim() !== "") { 236 | negate = (conditionColumns.substring(cIndex, cIndex + 1) == "N"); 237 | indicator = Number(conditionColumns.substring(cIndex+1, cIndex+3)); 238 | 239 | conditionals.push(new Conditional(indicator, negate)); 240 | } 241 | 242 | cIndex += 3; 243 | } 244 | 245 | return conditionals; 246 | } 247 | 248 | /** 249 | * @param {string[]} keywordStrings 250 | * @param {{[line: number]: string}} [conditionalStrings] 251 | * */ 252 | static parseKeywords(keywordStrings, conditionalStrings) { 253 | let result = { 254 | value: ``, 255 | keywords: [], 256 | conditions: [] 257 | }; 258 | 259 | const newLineMark = `~`; 260 | 261 | let value = keywordStrings.join(newLineMark) + newLineMark; 262 | let conditionalLine = 1; 263 | 264 | if (value.length > 0) { 265 | value += ` `; 266 | 267 | let inBrackets = 0; 268 | let word = ``; 269 | let innerValue = ``; 270 | let inString = false; 271 | 272 | for (let i = 0; i < value.length; i++) { 273 | switch (value[i]) { 274 | case `+`: 275 | case `-`: 276 | if (value[i+1] !== newLineMark) { 277 | innerValue += value[i]; 278 | } 279 | break; 280 | 281 | case `'`: 282 | if (inBrackets > 0) { 283 | innerValue += value[i]; 284 | } else { 285 | if (inString) { 286 | inString = false; 287 | 288 | result.value = innerValue; 289 | innerValue = ``; 290 | } else { 291 | inString = true; 292 | } 293 | } 294 | break; 295 | 296 | case `(`: 297 | if (inString) { 298 | innerValue += value[i]; 299 | } else { 300 | inBrackets++; 301 | } 302 | break; 303 | case `)`: 304 | if (inString) { 305 | innerValue += value[i]; 306 | } else { 307 | inBrackets--; 308 | } 309 | break; 310 | 311 | case newLineMark: 312 | case ` `: 313 | if (inBrackets > 0 || inString) { 314 | if (value[i] !== newLineMark) { 315 | innerValue += value[i]; 316 | } 317 | } else { 318 | if (word.length > 0) { 319 | let conditionals = conditionalStrings ? conditionalStrings[conditionalLine] : undefined; 320 | 321 | result.keywords.push({ 322 | name: word.toUpperCase(), 323 | value: innerValue.length > 0 ? innerValue : undefined, 324 | conditions: conditionals ? DisplayFile.parseConditionals(conditionals) : [] 325 | }); 326 | 327 | word = ``; 328 | innerValue = ``; 329 | } 330 | } 331 | 332 | if (value[i] === newLineMark) conditionalLine += 1; 333 | break; 334 | default: 335 | if (inBrackets > 0 || inString) 336 | innerValue += value[i]; 337 | else 338 | word += value[i]; 339 | break; 340 | } 341 | } 342 | } 343 | 344 | return result; 345 | } 346 | } 347 | 348 | class RecordInfo { 349 | constructor(name) { 350 | this.name = name; 351 | 352 | /** @type {FieldInfo[]} */ 353 | this.fields = []; 354 | 355 | this.range = { 356 | start: -1, 357 | end: -1 358 | }; 359 | 360 | this.isWindow = false; 361 | /** @type {string} */ 362 | this.windowReference = undefined; 363 | this.windowSize = { 364 | y: 0, 365 | x: 0, 366 | width: 80, 367 | height: 24 368 | }; 369 | 370 | /** @type {string[]} */ 371 | this.keywordStrings = []; 372 | 373 | /** @type {{name: string, value: string}[]} */ 374 | this.keywords = []; 375 | } 376 | 377 | handleKeywords() { 378 | const data = DisplayFile.parseKeywords(this.keywordStrings); 379 | 380 | this.keywords.push(...data.keywords); 381 | 382 | this.keywords.forEach(keyword => { 383 | switch (keyword.name) { 384 | case "WINDOW": 385 | this.isWindow = true; 386 | let points = keyword.value.split(' '); 387 | 388 | 389 | if (points.length >= 3 && points[0].toUpperCase() === `*DFT`) { 390 | // WINDOW (*DFT Y X) 391 | this.windowSize = { 392 | y: 2, 393 | x: 2, 394 | width: Number(points[2]), 395 | height: Number(points[1]) 396 | }; 397 | } else { 398 | if (points.length === 1) { 399 | // WINDOW (REF) 400 | this.windowReference = points[0]; 401 | 402 | } else if (points.length >= 4) { 403 | // WINDOW (*DFT SY SX Y X) 404 | this.windowSize = { 405 | y: Number(points[0]) || 2, 406 | x: Number(points[1]) || 2, 407 | width: Number(points[3]), 408 | height: Number(points[2]) 409 | }; 410 | } 411 | } 412 | 413 | switch (points[0]) { 414 | case `*DFT`: 415 | break; 416 | 417 | } 418 | 419 | switch (points.length) { 420 | case 4: 421 | //WINDOW (STARTY STARTX SIZEY SIZEX) 422 | 423 | break; 424 | case 1: 425 | //WINDOW (REF) 426 | this.windowReference = points[0]; 427 | break; 428 | } 429 | 430 | break; 431 | } 432 | }); 433 | } 434 | } 435 | 436 | class FieldInfo { 437 | constructor(name) { 438 | /** @type {string} */ 439 | this.name = name; 440 | 441 | /** @type {string} */ 442 | this.value = ``; 443 | 444 | /** @type {`char`|`decimal`} */ 445 | this.type = null; 446 | 447 | /** @type {`input`|`output`|`both`|`const`|`hidden`} */ 448 | this.displayType = null; 449 | 450 | this.length = 0; 451 | this.decimals = 0; 452 | 453 | this.position = { 454 | x: 0, 455 | y: 0 456 | }; 457 | 458 | /** @type {{keywordLines: string[], conditionalLines: {[lineIndex: number]: string}}} */ 459 | this.keywordStrings = { 460 | keywordLines: [], 461 | conditionalLines: {} 462 | }; 463 | 464 | /** @type {Conditional[]} */ 465 | this.conditions = []; 466 | 467 | /** @type {{name: string, value: string, conditions: Conditional[]}[]} */ 468 | this.keywords = []; 469 | } 470 | 471 | handleKeywords() { 472 | const data = DisplayFile.parseKeywords(this.keywordStrings.keywordLines, this.keywordStrings.conditionalLines); 473 | 474 | this.keywords.push(...data.keywords); 475 | 476 | if (data.value.length > 0) this.value = data.value; 477 | } 478 | } 479 | 480 | class Conditional { 481 | /** 482 | * @param {number} ind 483 | * @param {boolean} [negate] 484 | */ 485 | constructor(ind, negate = false) { 486 | this.indicator = ind; 487 | this.negate = negate; 488 | } 489 | } 490 | 491 | module.exports = { 492 | DisplayFile, 493 | FieldInfo, 494 | RecordInfo 495 | } -------------------------------------------------------------------------------- /src/extension.js: -------------------------------------------------------------------------------- 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 | const vscode = require('vscode'); 4 | 5 | const lensProvider = require(`./lensProvider`); 6 | 7 | const { DisplayFile } = require(`./dspf`); 8 | const Render = require(`./render`); 9 | const Window = require(`./window`); 10 | 11 | const Indicators = require(`./indicators`); 12 | 13 | let renderTimeout; 14 | 15 | // this method is called when your extension is activated 16 | // your extension is activated the very first time the command is executed 17 | 18 | /** 19 | * @param {vscode.ExtensionContext} context 20 | */ 21 | function activate(context) { 22 | 23 | // Use the console to output diagnostic information (console.log) and errors (console.error) 24 | // This line of code will only be executed once when your extension is activated 25 | console.log('Congratulations, your extension "vscode-displayfile" is now active!'); 26 | 27 | Indicators.initialize(); 28 | 29 | const lens = new lensProvider(); 30 | 31 | const config = vscode.workspace.getConfiguration('vscode-displayfile'); 32 | 33 | // The command has been defined in the package.json file 34 | // Now provide the implementation of the command with registerCommand 35 | // The commandId parameter must match the command field in package.json 36 | context.subscriptions.push( 37 | vscode.commands.registerCommand('vscode-displayfile.render', function (sourceLines, format, type) { 38 | // The code you place here will be executed every time your command is executed 39 | 40 | try { 41 | const dspf = new DisplayFile(); 42 | dspf.parse(sourceLines); 43 | 44 | const render = new Render(dspf, Indicators.values, type); 45 | 46 | const html = render.generate(format); 47 | 48 | Window.create(); 49 | Window.update(html); 50 | 51 | } catch (e) { 52 | console.log(e); 53 | } 54 | }), 55 | 56 | vscode.commands.registerCommand(`vscode-displayfile.changeInd`, async () => { 57 | const inds = Object.keys(Indicators.values); 58 | 59 | vscode.window.showQuickPick(inds.map((ind) => ({ 60 | label: `${ind} - ${Indicators.values[ind]}`, 61 | value: ind 62 | })), { 63 | canPickMany: true, 64 | placeHolder: `Chose which indicators to switch` 65 | }).then(chosen => { 66 | chosen.forEach(ind => { 67 | const index = Number(ind.value); 68 | Indicators.values[index] = !Indicators.values[index]; 69 | }) 70 | }) 71 | }), 72 | 73 | vscode.window.onDidChangeTextEditorSelection((event) => { 74 | const editor = event.textEditor; 75 | const selection = editor.selection; 76 | 77 | const timeout = config.get(`renderTimeout`) || 1500; 78 | 79 | clearTimeout(renderTimeout); 80 | 81 | renderTimeout = setTimeout(() => { 82 | if (Window.isActive()) { 83 | const activeEditor = vscode.window.activeTextEditor; 84 | if (editor && activeEditor) { 85 | const document = editor.document; 86 | const id = document.languageId; 87 | 88 | if ([`dds.dspf`, `dds.prtf`].includes(id)) { 89 | const eol = document.eol === vscode.EndOfLine.CRLF ? `\r\n` : `\n`; 90 | const sourceLines = document.getText().split(eol); 91 | 92 | const dspf = new DisplayFile(); 93 | dspf.parse(sourceLines); 94 | 95 | const render = new Render(dspf, Indicators.values, id); 96 | 97 | const line = selection.start.line; 98 | 99 | const format = dspf.formats.find(f => line >= f.range.start && line < f.range.end); 100 | 101 | if (format) { 102 | const html = render.generate(format.name); 103 | 104 | Window.update(html); 105 | } 106 | } 107 | } 108 | } 109 | }, timeout); 110 | 111 | }), 112 | 113 | vscode.languages.registerCodeLensProvider( 114 | { 115 | language: `dds.dspf`, 116 | }, 117 | lens 118 | ), 119 | vscode.languages.registerCodeLensProvider( 120 | { 121 | language: `dds.prtf`, 122 | }, 123 | lens 124 | ), 125 | ); 126 | } 127 | 128 | // this method is called when your extension is deactivated 129 | function deactivate() {} 130 | 131 | module.exports = { 132 | activate, 133 | deactivate 134 | } 135 | -------------------------------------------------------------------------------- /src/indicators.js: -------------------------------------------------------------------------------- 1 | /** @type {{[ind: number]: boolean}} */ 2 | exports.values = {}; 3 | 4 | exports.initialize = () => { 5 | for (let i = 1; i <= 99; i++) { 6 | this.values[i] = false; 7 | } 8 | } -------------------------------------------------------------------------------- /src/lensProvider.js: -------------------------------------------------------------------------------- 1 | 2 | const vscode = require(`vscode`); 3 | 4 | /** 5 | * @type {vscode.CodeLensProvider} 6 | */ 7 | module.exports = class lensProvider { 8 | constructor() { 9 | this.emitter = new vscode.EventEmitter(); 10 | this.onDidChangeCodeLenses = this.emitter.event; 11 | } 12 | 13 | refresh() { 14 | this.emitter.fire(); 15 | } 16 | 17 | /** 18 | * 19 | * @param {vscode.TextDocument} document 20 | * @returns {Promise} 21 | */ 22 | async provideCodeLenses(document) { 23 | const codeLens = []; 24 | 25 | const eol = document.eol === 1 ? `\n` : `\r\n`; 26 | const lines = document.getText().split(eol); 27 | 28 | lines.forEach((line, index) => { 29 | line = line.padEnd(30); 30 | // Not a comment 31 | if (line[6] !== `*`) { 32 | // Is a record format definition 33 | if (line[16].toUpperCase() === `R`) { 34 | const name = line.substring(18, 28).trim(); 35 | 36 | codeLens.push(new vscode.CodeLens( 37 | new vscode.Range( 38 | index, 0, index, 0 39 | ), 40 | { 41 | command: `vscode-displayfile.render`, 42 | title: `Preview ${name}`, 43 | arguments: [lines, name, document.languageId] 44 | } 45 | )); 46 | } 47 | } 48 | }); 49 | 50 | // If codelens exist, that means there is formats 51 | // Let's add a show all button 52 | codeLens.push(new vscode.CodeLens( 53 | new vscode.Range( 54 | 0, 0, 0, 0 55 | ), 56 | { 57 | command: `vscode-displayfile.render`, 58 | title: `Preview all`, 59 | arguments: [lines, undefined, document.languageId] 60 | } 61 | )); 62 | 63 | return codeLens; 64 | } 65 | } 66 | -------------------------------------------------------------------------------- /src/render.js: -------------------------------------------------------------------------------- 1 | 2 | const { DisplayFile, FieldInfo, RecordInfo } = require(`./dspf`); 3 | 4 | const colors = { 5 | RED: `red`, 6 | BLU: `#4287f5`, 7 | WHT: `#FFFFFF`, 8 | GRN: `green`, 9 | TRQ: `turquoise`, 10 | YLW: `yellow`, 11 | PNK: `pink`, 12 | BLK: `black`, 13 | }; 14 | 15 | const dateFormats = { 16 | '*MDY': `mm/dd/yyyy`, 17 | '*DMY': `dd/mm/yyyy`, 18 | '*YMD': `yyyy/mm/dd`, 19 | '*JUL': 'yy/ddd', 20 | '*ISO': 'yyyy-mm-dd', 21 | '*USA': 'mm/dd/yyyy', 22 | '*EUR': 'dd.mm.yyyy', 23 | '*JIS': 'yyyy-mm-dd', 24 | }; 25 | 26 | const timeFormats = { 27 | '*HMS': 'hh:mm:ss', 28 | '*ISO': 'hh.mm.ss', 29 | '*USA': 'hh:mm am', 30 | '*EUR': 'hh.mm.ss', 31 | '*JIS': 'hh:mm:ss', 32 | }; 33 | 34 | module.exports = class Render { 35 | constructor(display, indicators, type) { 36 | /** @type {DisplayFile} */ 37 | this.display = display; 38 | 39 | /** @type {{[ind: number]: boolean}} */ 40 | this.indicators = indicators || {}; 41 | 42 | this.printerFileLine = 0; 43 | 44 | /** @type {"dds.dspf"|"dds.prtf"} */ 45 | this.type = type; 46 | } 47 | 48 | generate(format) { 49 | let props = { 50 | borderSize: '0px', 51 | shadow: false, 52 | zoom: `0.9`, 53 | size: { 54 | width: 880, 55 | height: 480 56 | }, 57 | backgroundColor: colors.BLK, 58 | textColor: colors.GRN, 59 | } 60 | 61 | switch (this.type) { 62 | case `dds.dspf`: 63 | const globalFormat = this.display.formats.find(currentFormat => currentFormat.name === `GLOBAL`); 64 | 65 | let parts; 66 | 67 | if (globalFormat) { 68 | const displaySize = globalFormat.keywords.find(keyword => keyword.name === `DSPSIZ`); 69 | 70 | if (displaySize) { 71 | parts = Render.parseParms(displaySize.value); 72 | 73 | if (parts.length >= 2) { 74 | const [height, width] = parts; 75 | 76 | props.size = { 77 | width: Number(width) * 11, 78 | height: Number(height) * 20 79 | }; 80 | } 81 | } 82 | } 83 | break; 84 | case `dds.prtf`: 85 | props.zoom = `0.7`; 86 | props.size = { 87 | width: 132 * 11, 88 | height: 66 * 20 89 | }; 90 | 91 | props.shadow = true; 92 | props.borderSize = `3px`; 93 | props.backgroundColor = `#fffdf0`; 94 | props.textColor = colors.BLK; 95 | break; 96 | } 97 | 98 | let css = [ 99 | `#container {`, 100 | ` margin-top: 10px;`, 101 | ` font-family: monospace;`, 102 | ` font-size: 18px;`, 103 | ` border: solid black ${props.borderSize};`, 104 | ` width: ${props.size.width}px;`, 105 | ` height: ${props.size.height}px;`, 106 | ` position: absolute;`, 107 | ` --g: transparent calc(100% - 1px), #ebebeb 0;`, 108 | ` letter-spacing: 0.15px;`, 109 | ` color: ${props.textColor};`, 110 | ` background: ${props.backgroundColor};`, 111 | ` background-size:`, 112 | ` 11px 100%,`, 113 | ` 100% 20px;`, 114 | (props.shadow ? `box-shadow: 5px 5px 5px grey;` : ``), 115 | `}`, 116 | `@keyframes blinker {`, 117 | ` 50% {`, 118 | ` opacity: 0;`, 119 | ` }`, 120 | `}`, 121 | ].join(` `); 122 | 123 | let body = `
`; 124 | 125 | const content = this.getHTML(format); 126 | css += content.css; 127 | body += content.body; 128 | body += `
`; 129 | 130 | return [ 131 | ``, 132 | ``, 133 | `${body}`, 134 | `` 135 | ].join(``); 136 | } 137 | 138 | /** 139 | * @param {string} format 140 | */ 141 | getHTML(format) { 142 | let parts; 143 | 144 | /** @type {RecordInfo} */ 145 | let windowFormat; 146 | 147 | /** @type {{baseX: number, baseY: number, baseWidth: number, baseHeight: number, x: number, y: number, width: number, height: number, color?: string}} */ 148 | let windowConfig; 149 | 150 | /** @type {FieldInfo} */ 151 | let windowTitle; 152 | 153 | /** @type {RecordInfo} */ 154 | let recordFormat; 155 | if (format) { 156 | recordFormat = this.display.formats.find(currentFormat => currentFormat.name === format); 157 | } 158 | 159 | if (recordFormat) { 160 | if (recordFormat.isWindow) { 161 | if (recordFormat.windowReference) { 162 | windowFormat = this.display.formats.find(currentFormat => currentFormat.name === recordFormat.windowReference); 163 | } else { 164 | windowFormat = recordFormat; 165 | } 166 | 167 | const { x, y, width, height } = windowFormat.windowSize; 168 | windowConfig = { 169 | baseX: x, 170 | baseY: y, 171 | baseWidth: width, 172 | baseHeight: height, 173 | x: x * 11, 174 | y: y * 20, 175 | width: width * 11, 176 | height: (height-1) * 20 177 | }; 178 | 179 | const borderInfo = windowFormat.keywords.find(keyword => keyword.name === `WDWBORDER`); 180 | if (borderInfo) { 181 | parts = Render.parseParms(borderInfo.value); 182 | 183 | parts.forEach((part, index) => { 184 | switch (part.toUpperCase()) { 185 | case `*COLOR`: 186 | windowConfig.color = parts[index + 1]; 187 | break; 188 | } 189 | }); 190 | } 191 | 192 | const windowInfo = windowFormat.keywords.find(keyword => keyword.name === `WDWTITLE`); 193 | if (windowInfo) { 194 | windowTitle = new FieldInfo(`WINDOWTITLE`); 195 | windowTitle.type = `char`; 196 | windowTitle.displayType = `const`; 197 | 198 | let xPositionValue = `center`; 199 | let yPositionValue = `top`; 200 | 201 | parts = Render.parseParms(windowInfo.value); 202 | 203 | parts.forEach((part, index) => { 204 | switch (part.toUpperCase()) { 205 | case `*TEXT`: 206 | windowTitle.value = parts[index + 1]; 207 | break; 208 | case `*COLOR`: 209 | windowTitle.keywords.push({ 210 | name: `COLOR`, 211 | value: parts[index + 1], 212 | conditions: [] 213 | }); 214 | case `*DSPATR`: 215 | windowTitle.keywords.push({ 216 | name: `DSPATR`, 217 | value: parts[index + 1], 218 | conditions: [] 219 | }); 220 | break; 221 | 222 | case `*CENTER`: 223 | case `*LEFT`: 224 | case `*RIGHT`: 225 | xPositionValue = part.substring(1).toLowerCase(); 226 | break; 227 | 228 | case `*TOP`: 229 | case `*BOTTOM`: 230 | yPositionValue = part.substring(1).toLowerCase(); 231 | break; 232 | } 233 | }); 234 | 235 | // If no color is found, the default is blue. 236 | if (!windowTitle.keywords.find(keyword => keyword.name === `COLOR`)) { 237 | windowTitle.keywords.push({ 238 | name: `COLOR`, 239 | value: `BLU`, 240 | conditions: [] 241 | }); 242 | } 243 | 244 | const txtLength = windowTitle.value.length; 245 | 246 | const yPosition = (windowConfig.baseY) + (yPositionValue === `top` ? 0 : windowConfig.baseHeight); 247 | let xPosition = (windowConfig.baseX + 1); 248 | 249 | switch (xPositionValue) { 250 | case `center`: 251 | xPosition = (windowConfig.baseX + 1) + Math.floor((windowConfig.baseWidth / 2) - (txtLength / 2)); 252 | break; 253 | case `right`: 254 | xPosition = (windowConfig.baseX + 1) + windowConfig.baseWidth - txtLength; 255 | break; 256 | case `left`: 257 | xPosition = (windowConfig.baseX + 1); 258 | break; 259 | } 260 | 261 | windowTitle.position = { 262 | x: xPosition, 263 | y: yPosition 264 | }; 265 | 266 | } 267 | 268 | } 269 | } 270 | 271 | let css = ``; 272 | let body = ``; 273 | 274 | if (windowFormat) { 275 | // If this is a window, add the window CSS 276 | if (windowConfig) { 277 | const windowColor = colors[windowConfig.color] || colors.BLU; 278 | css += [ 279 | `#${windowFormat.name} {`, 280 | ` position: absolute;`, 281 | ` width: ${windowConfig.width}px;`, 282 | ` height: ${windowConfig.height}px;`, 283 | ` top: ${windowConfig.y}px;`, 284 | ` left: ${windowConfig.x}px;`, 285 | ` border: solid ${windowColor} 5px;`, 286 | `}`, 287 | ].join(` `); 288 | } 289 | 290 | if (windowTitle) { 291 | const windowContent = this.getContent(windowTitle); 292 | 293 | css += windowContent.css; 294 | body += windowContent.body; 295 | } 296 | 297 | if (windowConfig) { 298 | body += `
`; 299 | } 300 | 301 | if (windowFormat.name !== format) { 302 | const windowContent = this.getFormatContent(windowFormat.name); 303 | 304 | css += windowContent.css; 305 | body += windowContent.body; 306 | } 307 | } 308 | 309 | if (format) { 310 | const content = this.getFormatContent(format); 311 | 312 | css += content.css; 313 | body += content.body; 314 | 315 | } else { 316 | this.display.formats.forEach(currentFormat => { 317 | if (currentFormat.keywords.find(key => [`SFL`, `WINDOW`].includes(key.name))) { 318 | // All but subfiles and windows 319 | // SFL gets written by SFLCTL 320 | return; 321 | } 322 | 323 | const content = this.getFormatContent(currentFormat.name); 324 | 325 | css += content.css; 326 | body += content.body; 327 | }); 328 | } 329 | 330 | if (windowFormat && windowConfig) { 331 | body += `
`; 332 | } 333 | 334 | return { 335 | css, 336 | body 337 | } 338 | } 339 | 340 | /** 341 | * @param {string} recordFormat 342 | */ 343 | getFormatContent(recordFormat) { 344 | let css = ``; 345 | let body = ``; 346 | 347 | const formats = this.display.formats; 348 | 349 | const format = formats.find(format => format.name === recordFormat); 350 | if (format) { 351 | const subfileFormat = format.keywords.find(keyword => keyword.name === `SFLCTL`); 352 | 353 | // If there is a subfile format, render that first 354 | if (subfileFormat) { 355 | const subfilePage = format.keywords.find(keyword => keyword.name === `SFLPAG`) 356 | const rows = Number(subfilePage ? subfilePage.value : 1); 357 | 358 | const subfileRecord = formats.find(format => format.name === subfileFormat.value); 359 | 360 | if (subfileRecord) { 361 | const subfileFields = subfileRecord.fields.filter(field => field.displayType !== `hidden`); 362 | 363 | const low = Math.min(...subfileFields.map(field => field.position.y)); 364 | const high = Math.max(...subfileFields.map(field => field.position.y)); 365 | const linesPerItem = (high - low) + 1 366 | 367 | for (let row = 0; row < rows; row++) { 368 | subfileFields.forEach(field => { 369 | let canDisplay = true; 370 | 371 | field.conditions.forEach(cond => { 372 | if (this.indicators[cond.indicator] !== (cond.negate ? false : true)) { 373 | canDisplay = false; 374 | } 375 | }) 376 | 377 | if (canDisplay) { 378 | field.name = `${field.name}_${row}`; 379 | const content = this.getContent(field); 380 | css += content.css; 381 | body += content.body; 382 | } 383 | 384 | field.position.y += linesPerItem; 385 | }); 386 | } 387 | 388 | 389 | } else { 390 | throw new Error(`Unable to find SFLCTL format ${subfileFormat} from ${recordFormat}`); 391 | } 392 | } 393 | 394 | // Printer file keywords 395 | let skipBefore = format.keywords.find(keyword => keyword.name === `SKIPB`); 396 | let skipAfter = format.keywords.find(keyword => keyword.name === `SKIPA`); 397 | let spaceBefore = format.keywords.find(keyword => keyword.name === `SPACEB`); 398 | let spaceAfter = format.keywords.find(keyword => keyword.name === `SPACEA`); 399 | 400 | if (this.printerFileLine === 0) this.printerFileLine += 1; 401 | 402 | if (skipBefore) { 403 | this.printerFileLine = Number(skipBefore.value); 404 | } 405 | 406 | if (spaceBefore) { 407 | this.printerFileLine += Number(spaceBefore.value); 408 | } 409 | 410 | if (spaceAfter) { 411 | this.printerFileLine += Number(spaceAfter.value); 412 | } 413 | 414 | if (skipAfter) { 415 | this.printerFileLine += Number(skipAfter.value); 416 | } 417 | 418 | const fields = format.fields.filter(field => field.displayType !== `hidden`); 419 | fields.forEach(field => { 420 | let canDisplay = true; 421 | 422 | field.conditions.forEach(cond => { 423 | if (this.indicators[cond.indicator] !== (cond.negate ? false : true)) { 424 | canDisplay = false; 425 | } 426 | }); 427 | 428 | spaceBefore = field.keywords.find(keyword => keyword.name === `SPACEB`); 429 | spaceAfter = field.keywords.find(keyword => keyword.name === `SPACEA`); 430 | 431 | if (spaceBefore) { 432 | this.printerFileLine += Number(spaceBefore.value); 433 | } 434 | 435 | if (field.position.y === 0) 436 | field.position.y += this.printerFileLine; 437 | 438 | if (canDisplay) { 439 | const content = this.getContent(field); 440 | css += content.css; 441 | body += content.body; 442 | } 443 | 444 | if (spaceAfter) { 445 | this.printerFileLine += Number(spaceAfter.value); 446 | } 447 | }); 448 | 449 | } else { 450 | throw new Error(`Record format does not exist.`); 451 | } 452 | 453 | return { 454 | css, 455 | body 456 | } 457 | } 458 | 459 | /** 460 | * @param {FieldInfo} field 461 | */ 462 | getContent(field) { 463 | if (field.displayType !== `hidden`) { 464 | // Hacky way to make names valid IDs 465 | const htmlName = field.name 466 | .replace(new RegExp(`1`, `g`), `ONE`) 467 | .replace(new RegExp(`2`, `g`), `TWO`) 468 | .replace(new RegExp(`3`, `g`), `THREE`) 469 | .replace(new RegExp(`4`, `g`), `FOUR`) 470 | .replace(new RegExp(`5`, `g`), `FIVE`) 471 | .replace(new RegExp(`6`, `g`), `SIX`) 472 | .replace(new RegExp(`7`, `g`), `SEVEN`) 473 | .replace(new RegExp(`8`, `g`), `EIGHT`) 474 | .replace(new RegExp(`9`, `g`), `NINE`) 475 | .replace(new RegExp(`0`, `g`), `ZERO`) 476 | .replace(new RegExp(`#`, `g`), `HASH`) 477 | .replace(new RegExp(`@`, `g`), `HASH`) 478 | .replace(new RegExp(`\\$`, `g`), `DOLLAR`) 479 | .replace(new RegExp(`_`, `g`), `US`) 480 | 481 | let css = `#${htmlName} {`; 482 | 483 | const keywords = field.keywords; 484 | 485 | keywords.forEach(keyword => { 486 | let canDisplay = true; 487 | 488 | keyword.conditions.forEach(cond => { 489 | if (this.indicators[cond.indicator] !== (cond.negate ? false : true)) { 490 | canDisplay = false; 491 | } 492 | }) 493 | 494 | if (!canDisplay) return; 495 | 496 | const key = keyword.name; 497 | switch (key) { 498 | case `PAGNBR`: 499 | field.value = `####` 500 | break; 501 | case `COLOR`: 502 | css += `color: ${colors[keyword.value]};` 503 | break; 504 | case `SYSNAME`: 505 | field.value = `SYSNAME_` 506 | break; 507 | case `USER`: 508 | field.value = `USERNAME__` 509 | break; 510 | case `DATE`: 511 | const dateSep = keywords.find(keyword => keyword.name === `DATSEP`); 512 | 513 | const dateFormat = keywords.find(keyword => keyword.name === `DATFMT`); 514 | if (dateFormat) { 515 | field.value = dateFormats[dateFormat.value] || `?FORMAT?`; 516 | 517 | if (dateSep && dateSep.value.toUpperCase() !== `*JOB`) { 518 | field.value = field.value.replace(new RegExp(`[./-:]`, `g`), dateSep.value); 519 | } 520 | } 521 | break; 522 | case `TIME`: 523 | const sep = keywords.find(keyword => keyword.name === `TIMSEP`); 524 | 525 | const format = keywords.find(keyword => keyword.name === `TIMFMT`); 526 | if (format) { 527 | field.value = timeFormats[format.value] || `?FORMAT?`; 528 | 529 | if (sep && sep.value.toUpperCase() !== `*JOB`) { 530 | field.value = field.value.replace(new RegExp(`[./-:]`, `g`), sep.value); 531 | } 532 | } 533 | break; 534 | case `UNDERLINE`: 535 | css += `text-decoration: underline;`; 536 | break; 537 | case `HIGHLIGHT`: 538 | css += `font-weight: 900;`; 539 | break; 540 | case `DSPATR`: 541 | keyword.value.split(` `).forEach(value => { 542 | switch (value) { 543 | case `UL`: 544 | css += `text-decoration: underline;`; 545 | break; 546 | case `HI`: 547 | css += `font-weight: 900;`; 548 | if (!keywords.find(keyword => keyword.name === `COLOR`)) { 549 | css += `color: ${colors.WHT};`; 550 | } 551 | break; 552 | case `BL`: 553 | css += `animation: blinker 1s step-start infinite;`; 554 | break; 555 | } 556 | }) 557 | break; 558 | } 559 | }); 560 | 561 | const length = field.length > 0 && field.value.length < field.length ? field.length : field.value.length; 562 | const value = field.value 563 | .replace(/ /g, ` `) 564 | .replace(new RegExp(`''`, `g`), `'`); 565 | 566 | let padString = `-`; 567 | 568 | switch (field.type) { 569 | case `char`: 570 | switch (field.displayType) { 571 | case `input`: padString = `I`; break; 572 | case `output`: padString = `O`; break; 573 | case `both`: padString = `B`; break; 574 | } 575 | break; 576 | case `decimal`: 577 | switch (field.displayType) { 578 | case `input`: padString = `3`; break; 579 | case `output`: padString = `6`; break; 580 | case `both`: padString = `9`; break; 581 | } 582 | break; 583 | } 584 | 585 | let displayName = (field.displayType === `const` ? 586 | `Constant` : 587 | (field.name.includes(`_0`) ? field.name.substring(0, field.name.indexOf(`_0`)) : field.name)) 588 | 589 | const textKeyword = keywords.find(keyword => keyword.name === `TEXT`); 590 | const hoverText = `${displayName} (${field.position.y}, ${field.position.x}) ${textKeyword ? textKeyword.value : ``}`.trim(); 591 | 592 | let body = `
${hoverText ? `
${hoverText}
` : ``}${value.padEnd(length, padString)}
` 593 | 594 | css += [ 595 | `position: absolute`, 596 | `width: ${length * 11}px`, 597 | `height: 19px`, 598 | `top: ${(field.position.y - 1) * 20}px`, 599 | `left: ${(field.position.x - 1) * 11}px`, 600 | ].join(`;`) + `;`; 601 | 602 | if ([`input`, `both`].includes(field.displayType)) { 603 | css += `text-decoration: underline;`; 604 | } 605 | 606 | css += `} `; 607 | 608 | if (hoverText) { 609 | css += `` + 610 | [ 611 | `#${htmlName} #${htmlName}_tooltip {`, 612 | ` font-size: 12px;`, 613 | ` visibility: hidden;`, 614 | ` width: 120px;`, 615 | ` background-color: #121212;`, 616 | ` color: #fff;`, 617 | ` text-align: center;`, 618 | ` border-radius: 6px;`, 619 | ` padding: 5px 0;`, 620 | ` `, 621 | ` /* Position the tooltip */`, 622 | ` position: absolute;`, 623 | ` z-index: 1;`, 624 | ` top: 100%;`, 625 | ` left: 50%;`, 626 | ` margin-left: -60px;`, 627 | ` margin-top: 10px;`, 628 | `}` 629 | ].join(``); 630 | 631 | css += [ 632 | `#${htmlName}:hover #${htmlName}_tooltip {`, 633 | ` visibility: visible;`, 634 | `}`, 635 | ].join(``) + ` `; 636 | 637 | css += [ 638 | `#${htmlName} #${htmlName}_tooltip::after {`, 639 | ` content: "";`, 640 | ` position: absolute;`, 641 | ` bottom: 100%; /* At the top of the tooltip */`, 642 | ` left: 50%;`, 643 | ` margin-left: -5px;`, 644 | ` border-width: 5px;`, 645 | ` border-style: solid;`, 646 | ` border-color: transparent transparent #121212 transparent;`, 647 | `}`, 648 | ].join(``) + ` `; 649 | } 650 | 651 | return { 652 | css, 653 | body 654 | }; 655 | 656 | } else { 657 | return { 658 | css: ``, 659 | body: `` 660 | } 661 | } 662 | } 663 | 664 | /** 665 | * @param {string} string 666 | * @returns {string[]} 667 | */ 668 | static parseParms(string) { 669 | let items = []; 670 | let inString = false; 671 | let current = ``; 672 | 673 | for (let i = 0; i < string.length; i++) { 674 | switch (string[i]) { 675 | case `'`: 676 | inString = !inString; 677 | break; 678 | case ` `: 679 | if (inString) current += string[i]; 680 | else { 681 | items.push(current); 682 | current = ``; 683 | } 684 | break; 685 | default: 686 | current += string[i]; 687 | break; 688 | } 689 | } 690 | 691 | if (current.trim().length > 0) { 692 | items.push(current.trim()); 693 | } 694 | 695 | return items; 696 | } 697 | } -------------------------------------------------------------------------------- /src/window.js: -------------------------------------------------------------------------------- 1 | const vscode = require(`vscode`); 2 | 3 | /** @type {vscode.WebviewPanel} */ 4 | let panel; 5 | 6 | module.exports = class { 7 | static create() { 8 | if (panel) { 9 | panel.reveal(); 10 | } else { 11 | panel = vscode.window.createWebviewPanel( 12 | `displayFile`, 13 | `Preview`, 14 | vscode.ViewColumn.Active 15 | ); 16 | 17 | panel.onDidDispose(() => { 18 | panel = undefined; 19 | }); 20 | } 21 | } 22 | 23 | static update(html) { 24 | if (panel) { 25 | panel.webview.html = html; 26 | } 27 | } 28 | 29 | static isActive() { 30 | return panel !== undefined; 31 | } 32 | } -------------------------------------------------------------------------------- /test/file/depts.js: -------------------------------------------------------------------------------- 1 | exports.lines = [ 2 | ` A INDARA`, 3 | ` A CA03(03)`, 4 | ` A R SFLDTA SFL`, 5 | ` A RRN 4Y 0H`, 6 | ` A* DISPLAY DTA`, 7 | ` A XSEL 1A B 7 8`, 8 | ` A XID 3A O 7 12`, 9 | ` A XNAME 38A O 7 16`, 10 | ` A* COLOR HELLO`, 11 | ` A R SFLCTL SFLCTL(SFLDTA)`, 12 | ` A SFLPAG(0014)`, 13 | ` A SFLSIZ(9999)`, 14 | ` A OVERLAY`, 15 | ` A 85 SFLDSPCTL`, 16 | ` A 95 SFLDSP`, 17 | ` A N85 SFLCLR`, 18 | ` A SFLRRN 4S 0H SFLRCDNBR(CURSOR)`, 19 | ` A*`, 20 | ` A 6 6'Opt'`, 21 | ` A DSPATR(HI)`, 22 | ` A DSPATR(UL)`, 23 | ` A 6 12'ID'`, 24 | ` A DSPATR(HI)`, 25 | ` A DSPATR(UL)`, 26 | ` A 6 16'Name'`, 27 | ` A DSPATR(UL)`, 28 | ` A COLOR(WHT)`, 29 | ` A R FOOTER_FMT`, 30 | ` A OVERLAY`, 31 | ` A 3 6'F3=Exit'`, 32 | ` A COLOR(BLU)`, 33 | ` A 2 35'Departments'`, 34 | ` A DSPATR(UL)`, 35 | ` A COLOR(WHT)`, 36 | ` A 4 6'5=View' COLOR(BLU)`, 37 | ]; -------------------------------------------------------------------------------- /test/file/issue1149.js: -------------------------------------------------------------------------------- 1 | exports.lines = [ 2 | ` A R HELP`, 3 | ` A*%%TS SD 20080304 144943 PGML REL-V5R4M0 5722-WDS`, 4 | ` A KEEP`, 5 | ` A OVERLAY`, 6 | ` A WINDOW(10 2 10 70 *NORSTCSR)`, 7 | ` A WDWBORDER((*DSPATR RI) (*CHAR ':.::-`, 8 | ` A ::.:'))`, 9 | ` A WDWTITLE((*TEXT 'Print accounts by -`, 10 | ` A store number for status type - Help-`, 11 | ` A ') (*COLOR WHT))`, 12 | ` A 1 26'Print accounts - Help'`, 13 | ` A COLOR(WHT)`, 14 | ` A 3 3'This report print all accounts of -`, 15 | ` A selected status for a store or all'`, 16 | ` A 4 2'stores. An account will print for-`, 17 | ` A a store only if that store has'`, 18 | ` A 5 2'taken a check from that account. -`, 19 | ` A You can only select one status type'`, 20 | ` A 6 2'for each report request.'`, 21 | ` A 9 2'Press Enter to return'`, 22 | ] -------------------------------------------------------------------------------- /test/file/issue1382.js: -------------------------------------------------------------------------------- 1 | exports.lines = [ 2 | ` A DSPSIZ(27 132 *DS4)`, 3 | ` A R SCRN2`, 4 | ` A 2 2'This text containt parentheses (Y/N)'`, 5 | ` A 3 2'This text containt dashes -Y/N-'`, 6 | ]; -------------------------------------------------------------------------------- /test/file/replloadfm.js: -------------------------------------------------------------------------------- 1 | // https://github.com/tom-writes-code/rpgle-repl 2 | 3 | exports.lines = [ 4 | ` DSPSIZ(27 132 *DS4)`, 5 | ` INDARA`, 6 | ``, 7 | ` R HEADER`, 8 | ` 1 2'repl:load snippets'`, 9 | ` COLOR(BLU)`, 10 | ``, 11 | ` 2 2'1=Load 4=Delete'`, 12 | ` COLOR(WHT)`, 13 | ``, 14 | ` H_MODE 16A O 2 84`, 15 | ` 50 COLOR(WHT)`, 16 | ` N50 COLOR(RED)`, 17 | ` 2102'filter by profile:'`, 18 | ` COLOR(WHT)`, 19 | ` H_FILTER 10A B 2122`, 20 | ` COLOR(WHT)`, 21 | ``, 22 | ` R SNIPPET SFL`, 23 | ` CHGINPDFT(LC)`, 24 | ` S_SELECT 1A B 3 2COLOR(WHT)`, 25 | ` DSPATR(UL)`, 26 | ` 99 DSPATR(RI)`, 27 | ` 99 DSPATR(PC)`, 28 | ` S_ORIGIN 30A O 3 4COLOR(BLU)`, 29 | ` S_LASTCHG 10A O 3 35COLOR(BLU)`, 30 | ` S_PREVIEW 85A O 3 46COLOR(GRN)`, 31 | ` S_OWNER 10A H`, 32 | ` S_SAVENAME 20A H`, 33 | ` S_SESSION 28A H`, 34 | ``, 35 | ` R SNIPPETS SFLCTL(SNIPPET)`, 36 | ` SFLSIZ(23)`, 37 | ` SFLPAG(22)`, 38 | ` TEXT('Snippets Control Format')`, 39 | ` CF03(03 'Exit')`, 40 | ` CF11(11 'Saved/Unsaved')`, 41 | ` OVERLAY`, 42 | ` 40 SFLDSP`, 43 | ` 41 SFLDSPCTL`, 44 | ` 42 SFLCLR`, 45 | ` 43 SFLEND(*MORE)`, 46 | ``, 47 | ` R NORECORDS`, 48 | ` OVERLAY`, 49 | ` 4 5'no snippets found for the current -`, 50 | ` search criteria'`, 51 | ``, 52 | ` R FKEYS`, 53 | ` FRCDTA`, 54 | ` OVERLAY`, 55 | ` MSGLIN 129A O 27 2DSPATR(HI)`, 56 | ``, 57 | ` 26 2'F3=Exit F11=Saved/Unsaved Snippet-`, 58 | ` s'`, 59 | ` COLOR(BLU)`, 60 | ``, 61 | ` R CONFIRM`, 62 | ` OVERLAY`, 63 | ` WINDOW(6 6 6 54)`, 64 | ` CF10(10 'Confirm')`, 65 | ` CF12(12 'Cancel')`, 66 | ``, 67 | ``, 68 | ` CNFTXT1 50A O 2 3COLOR(WHT)`, 69 | ` CNFTXT2 50A O 3 3COLOR(WHT)`, 70 | ``, 71 | ` 5 3'F10=Confirm -`, 72 | ` F12=Cancel'`, 73 | ` COLOR(BLU)`, 74 | ] -------------------------------------------------------------------------------- /test/index.js: -------------------------------------------------------------------------------- 1 | const cases = require("./tests"); 2 | 3 | Object.values(cases).forEach(testcase => testcase()); -------------------------------------------------------------------------------- /test/tests.js: -------------------------------------------------------------------------------- 1 | const assert = require("assert"); 2 | const { DisplayFile } = require("../src/dspf"); 3 | 4 | const depts = require("./file/depts"); 5 | const replloadfm = require("./file/replloadfm"); 6 | const issue1149 = require(`./file/issue1149`); 7 | const issue1382 = require(`./file/issue1382`); 8 | 9 | exports.simple = () => { 10 | const file = new DisplayFile(); 11 | file.parse(depts.lines); 12 | 13 | assert.strictEqual(file.formats.length, 4); 14 | 15 | // Testing: window size, keywords 16 | 17 | const globalFormat = file.formats[0]; 18 | assert.strictEqual(globalFormat.name, `GLOBAL`); 19 | assert.deepStrictEqual(globalFormat.windowSize, { 20 | height: 24, width: 80, x: 0, y: 0 21 | }); 22 | assert.strictEqual(globalFormat.keywords.length, 2); 23 | assert.deepStrictEqual(globalFormat.keywords[0], { 24 | name: `INDARA`, value: undefined, conditions: [] 25 | }); 26 | assert.deepStrictEqual(globalFormat.keywords[1], { 27 | name: `CA03`, value: `03`, conditions: [] 28 | }); 29 | 30 | // Field type tests: 31 | 32 | const subfileData = file.formats[1]; 33 | assert.strictEqual(subfileData.name, `SFLDTA`); 34 | assert.deepStrictEqual(subfileData.keywords[0], { 35 | name: `SFL`, value: undefined, conditions: [] 36 | }); 37 | 38 | const rrnField = subfileData.fields[0]; 39 | assert.strictEqual(rrnField.type, `decimal`); 40 | assert.strictEqual(rrnField.length, 4); 41 | assert.strictEqual(rrnField.decimals, 0); 42 | assert.strictEqual(rrnField.displayType, `hidden`); 43 | assert.strictEqual(rrnField.name, `RRN`); 44 | assert.deepStrictEqual(rrnField.position, {x: 0, y: 0}); 45 | 46 | const xselField = subfileData.fields[1]; 47 | assert.strictEqual(xselField.type, `char`); 48 | assert.strictEqual(xselField.length, 1); 49 | assert.strictEqual(xselField.decimals, 0); 50 | assert.strictEqual(xselField.displayType, `both`); 51 | assert.strictEqual(xselField.name, `XSEL`); 52 | assert.deepStrictEqual(xselField.position, {x: 8, y: 7}); 53 | 54 | const xidField = subfileData.fields[2]; 55 | assert.strictEqual(xidField.type, `char`); 56 | assert.strictEqual(xidField.length, 3); 57 | assert.strictEqual(xidField.decimals, 0); 58 | assert.strictEqual(xidField.displayType, `output`); 59 | assert.strictEqual(xidField.name, `XID`); 60 | assert.deepStrictEqual(xidField.position, {x: 12, y: 7}); 61 | 62 | const xnameField = subfileData.fields[3]; 63 | assert.strictEqual(xnameField.type, `char`); 64 | assert.strictEqual(xnameField.length, 38); 65 | assert.strictEqual(xnameField.decimals, 0); 66 | assert.strictEqual(xnameField.displayType, `output`); 67 | assert.strictEqual(xnameField.name, `XNAME`); 68 | assert.deepStrictEqual(xnameField.position, {x: 16, y: 7}); 69 | 70 | // Const (text field) tests 71 | 72 | const subfileControl = file.formats[2]; 73 | assert.strictEqual(subfileControl.fields.length, 4); 74 | assert.strictEqual(subfileControl.keywords.length, 7); 75 | 76 | const text1 = subfileControl.fields[1]; 77 | assert.strictEqual(text1.name, `TEXT1`); 78 | assert.strictEqual(text1.displayType, `const`); 79 | assert.strictEqual(text1.value, `Opt`); 80 | assert.deepStrictEqual(text1.position, {x: 6, y: 6}); 81 | assert.deepStrictEqual(text1.keywords, [ 82 | { name: `DSPATR`, value: `HI`, conditions: [] }, 83 | { name: `DSPATR`, value: `UL`, conditions: [] } 84 | ]); 85 | 86 | // Keywords on same line tests 87 | const footer = file.formats[3]; 88 | assert.strictEqual(footer.fields.length, 3); 89 | assert.strictEqual(footer.keywords.length, 1); 90 | 91 | const sameLineField = footer.fields[2]; 92 | assert.strictEqual(sameLineField.name, `TEXT6`); 93 | assert.strictEqual(sameLineField.displayType, `const`); 94 | assert.strictEqual(sameLineField.value, `5=View`); 95 | assert.deepStrictEqual(sameLineField.position, {x: 6, y: 4}); 96 | assert.deepStrictEqual(sameLineField.keywords, [ 97 | { name: `COLOR`, value: `BLU`, conditions: [] }, 98 | ]); 99 | } 100 | 101 | exports.strings = () => { 102 | const file = new DisplayFile(); 103 | file.parse(replloadfm.lines); 104 | 105 | assert.strictEqual(file.formats.length, 7); 106 | 107 | // Verify parsing keywords with strings in 108 | const snippetsFormat = file.formats[3]; 109 | assert.strictEqual(snippetsFormat.name, `SNIPPETS`); 110 | 111 | const CF03 = snippetsFormat.keywords.find(keyword => keyword.name === `CF03`); 112 | assert.notStrictEqual(CF03, undefined); 113 | assert.strictEqual(CF03.value, `03 'Exit'`); 114 | 115 | // Verify strings over many lines 116 | 117 | const noRecordsFormat = file.formats[4]; 118 | assert.strictEqual(noRecordsFormat.name, `NORECORDS`); 119 | const textField = noRecordsFormat.fields[0]; 120 | assert.strictEqual(textField.name, `TEXT4`); 121 | assert.deepStrictEqual(textField.position, {x: 5, y: 4}); 122 | assert.strictEqual(textField.value, `no snippets found for the current search criteria`); 123 | 124 | // Second verification, with space at the start 125 | 126 | const confirmWindowFormat = file.formats[6]; 127 | assert.strictEqual(confirmWindowFormat.name, `CONFIRM`); 128 | const longTextField = confirmWindowFormat.fields[2]; 129 | assert.strictEqual(longTextField.value, `F10=Confirm F12=Cancel`) 130 | } 131 | 132 | exports.window = () => { 133 | const file = new DisplayFile(); 134 | file.parse(replloadfm.lines); 135 | 136 | const confirmWindowFormat = file.formats[6]; 137 | assert.strictEqual(confirmWindowFormat.name, `CONFIRM`); 138 | assert.deepStrictEqual(confirmWindowFormat.windowSize, { 139 | height: 6, width: 54, x: 6, y: 6 140 | }); 141 | } 142 | 143 | exports.issue1149 = () => { 144 | const file = new DisplayFile(); 145 | file.parse(issue1149.lines); 146 | 147 | const windowFormat = file.formats[1]; 148 | assert.strictEqual(windowFormat.name, `HELP`); 149 | assert.deepStrictEqual(windowFormat.windowSize, { 150 | height: 10, width: 70, x: 2, y: 10 151 | }); 152 | 153 | const windowTitle = windowFormat.keywords.find(keyword => keyword.name === `WDWTITLE`); 154 | assert.strictEqual(windowTitle.value, `*TEXT 'Print accounts by store number for status type - Help' *COLOR WHT`); 155 | 156 | const text4 = windowFormat.fields.find(field => field.name === `TEXT4`); 157 | assert.ok(text4); 158 | assert.strictEqual(text4.value, `taken a check from that account. You can only select one status type`); 159 | assert.deepStrictEqual(text4.position, {x: 2, y: 5}); 160 | } 161 | 162 | exports.issue1382 = () => { 163 | const file = new DisplayFile(); 164 | file.parse(issue1382.lines); 165 | 166 | const screenFormat = file.formats[1]; 167 | assert.strictEqual(screenFormat.name, `SCRN2`); 168 | 169 | const textField1 = screenFormat.fields[0]; 170 | assert.strictEqual(textField1.name, `TEXT1`); 171 | assert.strictEqual(textField1.value, `This text containt parentheses (Y/N)`); 172 | 173 | const textField2 = screenFormat.fields[1]; 174 | assert.strictEqual(textField2.name, `TEXT2`); 175 | assert.strictEqual(textField2.value, `This text containt dashes -Y/N-`); 176 | } --------------------------------------------------------------------------------