├── .gitattributes ├── .github └── workflows │ └── codeql-analysis.yml ├── .gitignore ├── .prettierrc.mjs ├── .travis.yml ├── CHANGELOG.md ├── LICENSE ├── README.md ├── devserver.mjs ├── eslint.config.js ├── hamlet.html ├── package-lock.json ├── package.json ├── src ├── bin │ └── pseudo-localize.ts ├── dom.ts ├── localize.test.ts └── localize.ts ├── tsconfig.json └── tsconfig.lib.json /.gitattributes: -------------------------------------------------------------------------------- 1 | dist/* -diff -------------------------------------------------------------------------------- /.github/workflows/codeql-analysis.yml: -------------------------------------------------------------------------------- 1 | # For most projects, this workflow file will not need changing; you simply need 2 | # to commit it to your repository. 3 | # 4 | # You may wish to alter this file to override the set of languages analyzed, 5 | # or to provide custom queries or build logic. 6 | # 7 | # ******** NOTE ******** 8 | # We have attempted to detect the languages in your repository. Please check 9 | # the `language` matrix defined below to confirm you have the correct set of 10 | # supported CodeQL languages. 11 | # 12 | name: "CodeQL" 13 | 14 | on: 15 | push: 16 | branches: [ master ] 17 | pull_request: 18 | # The branches below must be a subset of the branches above 19 | branches: [ master ] 20 | schedule: 21 | - cron: '28 3 * * 4' 22 | 23 | jobs: 24 | analyze: 25 | name: Analyze 26 | runs-on: ubuntu-latest 27 | permissions: 28 | actions: read 29 | contents: read 30 | security-events: write 31 | 32 | strategy: 33 | fail-fast: false 34 | matrix: 35 | language: [ 'javascript' ] 36 | # CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python' ] 37 | # Learn more: 38 | # https://docs.github.com/en/free-pro-team@latest/github/finding-security-vulnerabilities-and-errors-in-your-code/configuring-code-scanning#changing-the-languages-that-are-analyzed 39 | 40 | steps: 41 | - name: Checkout repository 42 | uses: actions/checkout@v2 43 | 44 | # Initializes the CodeQL tools for scanning. 45 | - name: Initialize CodeQL 46 | uses: github/codeql-action/init@v1 47 | with: 48 | languages: ${{ matrix.language }} 49 | # If you wish to specify custom queries, you can do so here or in a config file. 50 | # By default, queries listed here will override any specified in a config file. 51 | # Prefix the list here with "+" to use these queries and those in the config file. 52 | # queries: ./path/to/local/query, your-org/your-repo/queries@main 53 | 54 | # Autobuild attempts to build any compiled languages (C/C++, C#, or Java). 55 | # If this step fails, then you should remove it and run the build manually (see below) 56 | - name: Autobuild 57 | uses: github/codeql-action/autobuild@v1 58 | 59 | # ℹ️ Command-line programs to run using the OS shell. 60 | # 📚 https://git.io/JvXDl 61 | 62 | # ✏️ If the Autobuild fails above, remove it and uncomment the following three lines 63 | # and modify them (or add more) to build your code if your project 64 | # uses a compiled language 65 | 66 | #- run: | 67 | # make bootstrap 68 | # make release 69 | 70 | - name: Perform CodeQL Analysis 71 | uses: github/codeql-action/analyze@v1 72 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | dist -------------------------------------------------------------------------------- /.prettierrc.mjs: -------------------------------------------------------------------------------- 1 | // prettier.config.js, .prettierrc.js, prettier.config.mjs, or .prettierrc.mjs 2 | 3 | /** 4 | * @see https://prettier.io/docs/en/configuration.html 5 | * @type {import("prettier").Config} 6 | */ 7 | const config = { 8 | trailingComma: 'es5', 9 | tabWidth: 2, 10 | singleQuote: true, 11 | printWidth: 80, 12 | }; 13 | 14 | export default config; 15 | -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | node_js: 3 | - '9' 4 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | ## 2.4.0 2 | 3 | Add Typescript support. 4 | 5 | ##2.3.5 6 | 7 | - Add isEnabled boolean to `pseudo-localization` 8 | - prevent calling start/stop if pseudo-localization is already enabled/disabled 9 | 10 | ```tsx 11 | const [enabled, setEnabled] = React.useState(pseudoLocalization.isEnabled()); 12 | 13 | { 16 | const selected = event.target.checked; 17 | if (selected) { 18 | setEnabled(true); 19 | pseudoLocalization.start(); 20 | } else { 21 | setEnabled(false); 22 | pseudoLocalization.stop(); 23 | window.location.reload(); 24 | } 25 | }} 26 | />; 27 | ``` 28 | 29 | ##2.1.0 30 | 31 | - Adding CLI interface 32 | 33 | ##2.0.2 34 | 35 | - Fix a bug where blacklisted nodes would get pseudo-localized when mutated in the DOM 36 | 37 | ##2.0.1 38 | 39 | - Mention in package.json description that `pseudo-localization` works with nodejs. 40 | 41 | ##2.0.0 42 | 43 | - Safeguard childlist mutations and empty strings https://github.com/tryggvigy/pseudo-localization/pull/12 44 | - Fixes https://github.com/tryggvigy/pseudo-localization/issues/6 and https://github.com/tryggvigy/pseudo-localization/issues/11 45 | - Fix a bug where DOM mutation localizations did not respect the strategy specified https://github.com/tryggvigy/pseudo-localization/pull/16 46 | - Refactor internals to use import/export ES modules https://github.com/tryggvigy/pseudo-localization/pull/16 47 | - **BREAKING** `require` usage will have to change from 48 | ```js 49 | const pseudoLocalization = require('pseudo-localization'); 50 | ``` 51 | to 52 | ```js 53 | const pseudoLocalization = require('pseudo-localization').default; 54 | ``` 55 | - Transform to "not dead" browsers through babel https://github.com/tryggvigy/pseudo-localization/pull/16 56 | - Fixes https://github.com/tryggvigy/pseudo-localization/issues/8 57 | 58 | ##1.3.0 59 | 60 | - Allow blacklisting nodes ([#9](https://github.com/tryggvigy/pseudo-localization/pull/9)) 61 | 62 | ## 1.2.0 63 | 64 | - Expose `localize` function 65 | 66 | ## 1.1.5 67 | 68 | - Fix typo in README 69 | - Set MIT as license in package.json 70 | 71 | ## 1.1.4 72 | 73 | - Update explanatory picture in README.md 74 | 75 | ## 1.1.3 76 | 77 | - Add support for bidirectional text 78 | - `pseudoLocalization.start({ strategy: 'bidi' });` 79 | - Changed several things to improve legibility 80 | - Removed `[]` surrounding each string. horizontal Cutoff should be relatively easy to spot without those. 81 | - Stop using `one two three ...` to elongagate the string by ~30-40% and instead duplicate letters withing the string itself. 82 | - Tidy up pseudo language symbols maps to contain more legibile symbols 83 | - Make pseudo language deterministic. Always use the same pseudo symbol for the same english letter. 84 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2018 Tryggvi Gylfason 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 | Inspired by pseudo-localization at [Netflix](https://medium.com/netflix-techblog/pseudo-localization-netflix-12fff76fbcbe) and [Firefox](https://reviewboard.mozilla.org/r/248606/diff/2#index_header). 2 | 3 | # Pseudo-Localization 4 | 5 | Pseudo-localization helps developers test UI elements for localization issues before actual translations are available. This package transforms text into a pseudo-language to simulate real-world localization challenges. 6 | 7 | ## Preview 8 | 9 | | English | Pseudo Language | 10 | | ----------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------- | 11 | | ![English example](https://user-images.githubusercontent.com/2373958/44001651-21f32b42-9e36-11e8-80eb-5b88e8fd9b13.png) | ![Pseudo-localized example](https://user-images.githubusercontent.com/2373958/44311352-2a29fb00-a3e6-11e8-88ed-5485697f7a40.png) | 12 | 13 | ### [Live Demo](https://tryggvigy.github.io/pseudo-localization/hamlet.html) 14 | 15 | See it in action on [https://tryggvigy.github.io/pseudo-localization/hamlet.html](https://tryggvigy.github.io/pseudo-localization/hamlet.html) 16 | 17 | Changes to the DOM trigger pseudo-localization in real time. Try modifying text nodes or adding/removing elements via DevTools. 18 | 19 | --- 20 | 21 | ## Why Use This? 22 | 23 | Pseudo-localization helps detect issues such as: 24 | 25 | - **Text Overflow** – Translations are often longer than the original text, which may cause UI breaking. 26 | - **Font Rendering** – Certain languages have larger glyphs or diacritics that may be cut off. 27 | - **Right-to-Left (RTL) Support** – Ensures proper layout handling for RTL languages. 28 | - **Hardcoded Strings** – Identifies untranslated or hardcoded text that should be localized. 29 | 30 | --- 31 | 32 | ## Installation 33 | 34 | ### Via npm 35 | 36 | ```sh 37 | npm install pseudo-localization 38 | ``` 39 | 40 | ### Copy The Source Code 41 | 42 | Copy the files from [`src`](https://github.com/tryggvigy/pseudo-localization/blob/master/src) and use them directly. 43 | 44 | --- 45 | 46 | ## Usage 47 | 48 | ### `pseudoLocalizeString` 49 | 50 | Transform individual strings: 51 | 52 | ```js 53 | import { pseudoLocalizeString } from 'pseudo-localization'; 54 | 55 | console.log(pseudoLocalizeString('hello')); // ħḗḗŀŀǿǿ 56 | console.log(pseudoLocalizeString('hello', { strategy: 'bidi' })); // oʅʅǝɥ 57 | ``` 58 | 59 | Use-case: Ensure text is passing through a translation function. 60 | 61 | ```js 62 | import translate from './my-translation-lib'; 63 | const _ = (key) => pseudoLocalizeString(translate(key, navigator.language)); 64 | 65 | console.log(_('Some Localized Text')); // Şǿǿḿḗḗ Ŀǿǿƈȧȧŀīẑḗḗḓ Ŧḗḗẋŧ 66 | ``` 67 | 68 | --- 69 | 70 | ### `pseudo-localization/dom` 71 | 72 | Automatically localize the entire page or parts of the DOM. 73 | 74 | #### React Example 75 | 76 | ```jsx 77 | import React, { useEffect } from 'react'; 78 | import { PseudoLocalizeDom } from 'pseudo-localization/dom'; 79 | 80 | function Page() { 81 | useEffect(() => PseudoLocalizeDom.start(), []); 82 | return

This text will be pseudo-localized!

; 83 | } 84 | ``` 85 | 86 | --- 87 | 88 | ## Strategies 89 | 90 | Pseudo-localization supports two strategies: 91 | 92 | ### 1. Accented (`accented`) 93 | 94 | Expands text and replaces Latin letters with accented Unicode counterparts. 95 | 96 | ```js 97 | pseudoLocalization.start({ strategy: 'accented' }); 98 | ``` 99 | 100 | Example output: **Ȧȧƈƈḗḗƞŧḗḗḓ Ḗḗƞɠŀīīşħ** 101 | 102 | ![Accented example](https://user-images.githubusercontent.com/2373958/44311259-62303e80-a3e4-11e8-884a-54c77416b922.png) 103 | 104 | --- 105 | 106 | ### 2. Bidirectional (`bidi`) 107 | 108 | Simulates an RTL language by reversing words and using right-to-left Unicode formatting. 109 | 110 | ```js 111 | pseudoLocalization.start({ strategy: 'bidi' }); 112 | ``` 113 | 114 | Example output: **ɥsıʅƃuƎ ıpıԐ** 115 | 116 | ![Bidi example](https://user-images.githubusercontent.com/2373958/44311263-770cd200-a3e4-11e8-97e4-9a1896bd5975.png) 117 | 118 | --- 119 | 120 | ## API Reference 121 | 122 | ### `pseudoLocalizeString(str: string, options?: Options): string` 123 | 124 | - `str`: String to localize. 125 | - `options.strategy`: `'accented'` (default) or `'bidi'`. 126 | 127 | ### `PseudoLocalizeDom.start(options?: DomOptions): StopFn` 128 | 129 | Pseudo-localizes the page and watches for DOM changes. 130 | 131 | ```js 132 | import { PseudoLocalizeDom } from 'pseudo-localization/dom'; 133 | const stop = new PseudoLocalizeDom().start(); 134 | // Stop pseudo-localization later 135 | stop(); 136 | ``` 137 | 138 | #### `DomOptions` 139 | 140 | - `strategy`: `'accented'` or `'bidi'`. 141 | - `blacklistedNodeNames`: Nodes to ignore (default: `['STYLE']`). 142 | - `root`: Root element for localization (default: `document.body`). 143 | 144 | --- 145 | 146 | ## CLI Usage 147 | 148 | A command-line interface (CLI) is available for quick testing and automation. 149 | 150 | ```sh 151 | npx pseudo-localization "hello world" 152 | ``` 153 | 154 | ### CLI Options 155 | 156 | ``` 157 | pseudo-localization [src] [options] 158 | 159 | Positionals: 160 | src Input string 161 | 162 | Options: 163 | --strategy Localization strategy (accented or bidi) 164 | --help Show help 165 | ``` 166 | 167 | --- 168 | 169 | ## Browser Compatibility 170 | 171 | Works in all modern browsers. 172 | 173 | --- 174 | 175 | By using pseudo-localization, you can catch UI issues early, ensuring your app is truly localization-ready! 176 | -------------------------------------------------------------------------------- /devserver.mjs: -------------------------------------------------------------------------------- 1 | import http from 'http'; 2 | import url from 'url'; 3 | import fs from 'fs'; 4 | import path from 'path'; 5 | 6 | const port = 8080; 7 | const baseDirectory = url.fileURLToPath(new URL('.', import.meta.url)); 8 | 9 | http 10 | .createServer(function (request, response) { 11 | try { 12 | var requestUrl = url.parse(request.url); 13 | 14 | // need to use path.normalize so people can't access directories underneath baseDirectory 15 | var fsPath = path.join( 16 | baseDirectory, 17 | path.normalize(requestUrl.pathname) 18 | ); 19 | 20 | console.log(fsPath); 21 | 22 | // Force correct content-type for JavaScript 23 | // This is a work-around for an issue where 24 | // es6 modules have "" as content-type. 25 | if (fsPath.endsWith('.mjs')) { 26 | response.setHeader('content-type', 'text/javascript'); 27 | } 28 | 29 | var fileStream = fs.createReadStream(fsPath); 30 | 31 | fileStream.pipe(response); 32 | fileStream.on('open', function () { 33 | response.writeHead(200); 34 | }); 35 | fileStream.on('error', function () { 36 | response.writeHead(404); // assume the file doesn't exist 37 | response.end(); 38 | }); 39 | } catch (e) { 40 | response.writeHead(500); 41 | response.end(); // end the response so browsers don't hang 42 | console.log(e.stack); 43 | } 44 | }) 45 | .listen(port); 46 | 47 | console.log('Serving http://localhost:' + port + '/hamlet.html'); 48 | -------------------------------------------------------------------------------- /eslint.config.js: -------------------------------------------------------------------------------- 1 | import globals from 'globals'; 2 | import pluginJs from '@eslint/js'; 3 | import tseslint from 'typescript-eslint'; 4 | 5 | /** @type {import('eslint').Linter.Config[]} */ 6 | export default [ 7 | { files: ['**/*.{js,mjs,cjs,ts}'] }, 8 | { languageOptions: { globals: { ...globals.browser, ...globals.node } } }, 9 | pluginJs.configs.recommended, 10 | ...tseslint.configs.recommended, 11 | ]; 12 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "pseudo-localization", 3 | "version": "3.0.4", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "pseudo-localization", 9 | "version": "3.0.4", 10 | "license": "MIT", 11 | "dependencies": { 12 | "yargs": "^17.7.2" 13 | }, 14 | "bin": { 15 | "pseudo-localization": "bin/pseudo-localize.mjs" 16 | }, 17 | "devDependencies": { 18 | "@eslint/js": "^9.17.0", 19 | "@types/node": "^22.10.2", 20 | "@types/yargs": "^17.0.33", 21 | "eslint": "^9.17.0", 22 | "globals": "^15.13.0", 23 | "prettier": "^3.4.2", 24 | "typescript": "^5.7.2", 25 | "typescript-eslint": "^8.18.0" 26 | }, 27 | "engines": { 28 | "node": "^23" 29 | } 30 | }, 31 | "node_modules/@eslint-community/eslint-utils": { 32 | "version": "4.4.1", 33 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.1.tgz", 34 | "integrity": "sha512-s3O3waFUrMV8P/XaF/+ZTp1X9XBZW1a4B97ZnjQF2KYWaFD2A8KyFBsrsfSjEmjn3RGWAIuvlneuZm3CUK3jbA==", 35 | "dev": true, 36 | "license": "MIT", 37 | "dependencies": { 38 | "eslint-visitor-keys": "^3.4.3" 39 | }, 40 | "engines": { 41 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 42 | }, 43 | "funding": { 44 | "url": "https://opencollective.com/eslint" 45 | }, 46 | "peerDependencies": { 47 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 48 | } 49 | }, 50 | "node_modules/@eslint-community/eslint-utils/node_modules/eslint-visitor-keys": { 51 | "version": "3.4.3", 52 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 53 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 54 | "dev": true, 55 | "license": "Apache-2.0", 56 | "engines": { 57 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 58 | }, 59 | "funding": { 60 | "url": "https://opencollective.com/eslint" 61 | } 62 | }, 63 | "node_modules/@eslint-community/regexpp": { 64 | "version": "4.12.1", 65 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.12.1.tgz", 66 | "integrity": "sha512-CCZCDJuduB9OUkFkY2IgppNZMi2lBQgD2qzwXkEia16cge2pijY/aXi96CJMquDMn3nJdlPV1A5KrJEXwfLNzQ==", 67 | "dev": true, 68 | "license": "MIT", 69 | "engines": { 70 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 71 | } 72 | }, 73 | "node_modules/@eslint/config-array": { 74 | "version": "0.19.1", 75 | "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.19.1.tgz", 76 | "integrity": "sha512-fo6Mtm5mWyKjA/Chy1BYTdn5mGJoDNjC7C64ug20ADsRDGrA85bN3uK3MaKbeRkRuuIEAR5N33Jr1pbm411/PA==", 77 | "dev": true, 78 | "license": "Apache-2.0", 79 | "dependencies": { 80 | "@eslint/object-schema": "^2.1.5", 81 | "debug": "^4.3.1", 82 | "minimatch": "^3.1.2" 83 | }, 84 | "engines": { 85 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 86 | } 87 | }, 88 | "node_modules/@eslint/core": { 89 | "version": "0.9.1", 90 | "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.9.1.tgz", 91 | "integrity": "sha512-GuUdqkyyzQI5RMIWkHhvTWLCyLo1jNK3vzkSyaExH5kHPDHcuL2VOpHjmMY+y3+NC69qAKToBqldTBgYeLSr9Q==", 92 | "dev": true, 93 | "license": "Apache-2.0", 94 | "dependencies": { 95 | "@types/json-schema": "^7.0.15" 96 | }, 97 | "engines": { 98 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 99 | } 100 | }, 101 | "node_modules/@eslint/eslintrc": { 102 | "version": "3.2.0", 103 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.2.0.tgz", 104 | "integrity": "sha512-grOjVNN8P3hjJn/eIETF1wwd12DdnwFDoyceUJLYYdkpbwq3nLi+4fqrTAONx7XDALqlL220wC/RHSC/QTI/0w==", 105 | "dev": true, 106 | "license": "MIT", 107 | "dependencies": { 108 | "ajv": "^6.12.4", 109 | "debug": "^4.3.2", 110 | "espree": "^10.0.1", 111 | "globals": "^14.0.0", 112 | "ignore": "^5.2.0", 113 | "import-fresh": "^3.2.1", 114 | "js-yaml": "^4.1.0", 115 | "minimatch": "^3.1.2", 116 | "strip-json-comments": "^3.1.1" 117 | }, 118 | "engines": { 119 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 120 | }, 121 | "funding": { 122 | "url": "https://opencollective.com/eslint" 123 | } 124 | }, 125 | "node_modules/@eslint/eslintrc/node_modules/globals": { 126 | "version": "14.0.0", 127 | "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz", 128 | "integrity": "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ==", 129 | "dev": true, 130 | "license": "MIT", 131 | "engines": { 132 | "node": ">=18" 133 | }, 134 | "funding": { 135 | "url": "https://github.com/sponsors/sindresorhus" 136 | } 137 | }, 138 | "node_modules/@eslint/js": { 139 | "version": "9.17.0", 140 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.17.0.tgz", 141 | "integrity": "sha512-Sxc4hqcs1kTu0iID3kcZDW3JHq2a77HO9P8CP6YEA/FpH3Ll8UXE2r/86Rz9YJLKme39S9vU5OWNjC6Xl0Cr3w==", 142 | "dev": true, 143 | "license": "MIT", 144 | "engines": { 145 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 146 | } 147 | }, 148 | "node_modules/@eslint/object-schema": { 149 | "version": "2.1.5", 150 | "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.5.tgz", 151 | "integrity": "sha512-o0bhxnL89h5Bae5T318nFoFzGy+YE5i/gGkoPAgkmTVdRKTiv3p8JHevPiPaMwoloKfEiiaHlawCqaZMqRm+XQ==", 152 | "dev": true, 153 | "license": "Apache-2.0", 154 | "engines": { 155 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 156 | } 157 | }, 158 | "node_modules/@eslint/plugin-kit": { 159 | "version": "0.2.4", 160 | "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.2.4.tgz", 161 | "integrity": "sha512-zSkKow6H5Kdm0ZUQUB2kV5JIXqoG0+uH5YADhaEHswm664N9Db8dXSi0nMJpacpMf+MyyglF1vnZohpEg5yUtg==", 162 | "dev": true, 163 | "license": "Apache-2.0", 164 | "dependencies": { 165 | "levn": "^0.4.1" 166 | }, 167 | "engines": { 168 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 169 | } 170 | }, 171 | "node_modules/@humanfs/core": { 172 | "version": "0.19.1", 173 | "resolved": "https://registry.npmjs.org/@humanfs/core/-/core-0.19.1.tgz", 174 | "integrity": "sha512-5DyQ4+1JEUzejeK1JGICcideyfUbGixgS9jNgex5nqkW+cY7WZhxBigmieN5Qnw9ZosSNVC9KQKyb+GUaGyKUA==", 175 | "dev": true, 176 | "license": "Apache-2.0", 177 | "engines": { 178 | "node": ">=18.18.0" 179 | } 180 | }, 181 | "node_modules/@humanfs/node": { 182 | "version": "0.16.6", 183 | "resolved": "https://registry.npmjs.org/@humanfs/node/-/node-0.16.6.tgz", 184 | "integrity": "sha512-YuI2ZHQL78Q5HbhDiBA1X4LmYdXCKCMQIfw0pw7piHJwyREFebJUvrQN4cMssyES6x+vfUbx1CIpaQUKYdQZOw==", 185 | "dev": true, 186 | "license": "Apache-2.0", 187 | "dependencies": { 188 | "@humanfs/core": "^0.19.1", 189 | "@humanwhocodes/retry": "^0.3.0" 190 | }, 191 | "engines": { 192 | "node": ">=18.18.0" 193 | } 194 | }, 195 | "node_modules/@humanfs/node/node_modules/@humanwhocodes/retry": { 196 | "version": "0.3.1", 197 | "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.3.1.tgz", 198 | "integrity": "sha512-JBxkERygn7Bv/GbN5Rv8Ul6LVknS+5Bp6RgDC/O8gEBU/yeH5Ui5C/OlWrTb6qct7LjjfT6Re2NxB0ln0yYybA==", 199 | "dev": true, 200 | "license": "Apache-2.0", 201 | "engines": { 202 | "node": ">=18.18" 203 | }, 204 | "funding": { 205 | "type": "github", 206 | "url": "https://github.com/sponsors/nzakas" 207 | } 208 | }, 209 | "node_modules/@humanwhocodes/module-importer": { 210 | "version": "1.0.1", 211 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 212 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 213 | "dev": true, 214 | "license": "Apache-2.0", 215 | "engines": { 216 | "node": ">=12.22" 217 | }, 218 | "funding": { 219 | "type": "github", 220 | "url": "https://github.com/sponsors/nzakas" 221 | } 222 | }, 223 | "node_modules/@humanwhocodes/retry": { 224 | "version": "0.4.1", 225 | "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.4.1.tgz", 226 | "integrity": "sha512-c7hNEllBlenFTHBky65mhq8WD2kbN9Q6gk0bTk8lSBvc554jpXSkST1iePudpt7+A/AQvuHs9EMqjHDXMY1lrA==", 227 | "dev": true, 228 | "license": "Apache-2.0", 229 | "engines": { 230 | "node": ">=18.18" 231 | }, 232 | "funding": { 233 | "type": "github", 234 | "url": "https://github.com/sponsors/nzakas" 235 | } 236 | }, 237 | "node_modules/@nodelib/fs.scandir": { 238 | "version": "2.1.5", 239 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 240 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 241 | "dev": true, 242 | "license": "MIT", 243 | "dependencies": { 244 | "@nodelib/fs.stat": "2.0.5", 245 | "run-parallel": "^1.1.9" 246 | }, 247 | "engines": { 248 | "node": ">= 8" 249 | } 250 | }, 251 | "node_modules/@nodelib/fs.stat": { 252 | "version": "2.0.5", 253 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 254 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 255 | "dev": true, 256 | "license": "MIT", 257 | "engines": { 258 | "node": ">= 8" 259 | } 260 | }, 261 | "node_modules/@nodelib/fs.walk": { 262 | "version": "1.2.8", 263 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 264 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 265 | "dev": true, 266 | "license": "MIT", 267 | "dependencies": { 268 | "@nodelib/fs.scandir": "2.1.5", 269 | "fastq": "^1.6.0" 270 | }, 271 | "engines": { 272 | "node": ">= 8" 273 | } 274 | }, 275 | "node_modules/@types/estree": { 276 | "version": "1.0.6", 277 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.6.tgz", 278 | "integrity": "sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==", 279 | "dev": true, 280 | "license": "MIT" 281 | }, 282 | "node_modules/@types/json-schema": { 283 | "version": "7.0.15", 284 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", 285 | "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==", 286 | "dev": true, 287 | "license": "MIT" 288 | }, 289 | "node_modules/@types/node": { 290 | "version": "22.10.2", 291 | "resolved": "https://registry.npmjs.org/@types/node/-/node-22.10.2.tgz", 292 | "integrity": "sha512-Xxr6BBRCAOQixvonOye19wnzyDiUtTeqldOOmj3CkeblonbccA12PFwlufvRdrpjXxqnmUaeiU5EOA+7s5diUQ==", 293 | "dev": true, 294 | "license": "MIT", 295 | "dependencies": { 296 | "undici-types": "~6.20.0" 297 | } 298 | }, 299 | "node_modules/@types/yargs": { 300 | "version": "17.0.33", 301 | "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.33.tgz", 302 | "integrity": "sha512-WpxBCKWPLr4xSsHgz511rFJAM+wS28w2zEO1QDNY5zM/S8ok70NNfztH0xwhqKyaK0OHCbN98LDAZuy1ctxDkA==", 303 | "dev": true, 304 | "license": "MIT", 305 | "dependencies": { 306 | "@types/yargs-parser": "*" 307 | } 308 | }, 309 | "node_modules/@types/yargs-parser": { 310 | "version": "21.0.3", 311 | "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.3.tgz", 312 | "integrity": "sha512-I4q9QU9MQv4oEOz4tAHJtNz1cwuLxn2F3xcc2iV5WdqLPpUnj30aUuxt1mAxYTG+oe8CZMV/+6rU4S4gRDzqtQ==", 313 | "dev": true, 314 | "license": "MIT" 315 | }, 316 | "node_modules/@typescript-eslint/eslint-plugin": { 317 | "version": "8.18.0", 318 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-8.18.0.tgz", 319 | "integrity": "sha512-NR2yS7qUqCL7AIxdJUQf2MKKNDVNaig/dEB0GBLU7D+ZdHgK1NoH/3wsgO3OnPVipn51tG3MAwaODEGil70WEw==", 320 | "dev": true, 321 | "license": "MIT", 322 | "dependencies": { 323 | "@eslint-community/regexpp": "^4.10.0", 324 | "@typescript-eslint/scope-manager": "8.18.0", 325 | "@typescript-eslint/type-utils": "8.18.0", 326 | "@typescript-eslint/utils": "8.18.0", 327 | "@typescript-eslint/visitor-keys": "8.18.0", 328 | "graphemer": "^1.4.0", 329 | "ignore": "^5.3.1", 330 | "natural-compare": "^1.4.0", 331 | "ts-api-utils": "^1.3.0" 332 | }, 333 | "engines": { 334 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 335 | }, 336 | "funding": { 337 | "type": "opencollective", 338 | "url": "https://opencollective.com/typescript-eslint" 339 | }, 340 | "peerDependencies": { 341 | "@typescript-eslint/parser": "^8.0.0 || ^8.0.0-alpha.0", 342 | "eslint": "^8.57.0 || ^9.0.0", 343 | "typescript": ">=4.8.4 <5.8.0" 344 | } 345 | }, 346 | "node_modules/@typescript-eslint/parser": { 347 | "version": "8.18.0", 348 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-8.18.0.tgz", 349 | "integrity": "sha512-hgUZ3kTEpVzKaK3uNibExUYm6SKKOmTU2BOxBSvOYwtJEPdVQ70kZJpPjstlnhCHcuc2WGfSbpKlb/69ttyN5Q==", 350 | "dev": true, 351 | "license": "MITClause", 352 | "dependencies": { 353 | "@typescript-eslint/scope-manager": "8.18.0", 354 | "@typescript-eslint/types": "8.18.0", 355 | "@typescript-eslint/typescript-estree": "8.18.0", 356 | "@typescript-eslint/visitor-keys": "8.18.0", 357 | "debug": "^4.3.4" 358 | }, 359 | "engines": { 360 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 361 | }, 362 | "funding": { 363 | "type": "opencollective", 364 | "url": "https://opencollective.com/typescript-eslint" 365 | }, 366 | "peerDependencies": { 367 | "eslint": "^8.57.0 || ^9.0.0", 368 | "typescript": ">=4.8.4 <5.8.0" 369 | } 370 | }, 371 | "node_modules/@typescript-eslint/scope-manager": { 372 | "version": "8.18.0", 373 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-8.18.0.tgz", 374 | "integrity": "sha512-PNGcHop0jkK2WVYGotk/hxj+UFLhXtGPiGtiaWgVBVP1jhMoMCHlTyJA+hEj4rszoSdLTK3fN4oOatrL0Cp+Xw==", 375 | "dev": true, 376 | "license": "MIT", 377 | "dependencies": { 378 | "@typescript-eslint/types": "8.18.0", 379 | "@typescript-eslint/visitor-keys": "8.18.0" 380 | }, 381 | "engines": { 382 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 383 | }, 384 | "funding": { 385 | "type": "opencollective", 386 | "url": "https://opencollective.com/typescript-eslint" 387 | } 388 | }, 389 | "node_modules/@typescript-eslint/type-utils": { 390 | "version": "8.18.0", 391 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-8.18.0.tgz", 392 | "integrity": "sha512-er224jRepVAVLnMF2Q7MZJCq5CsdH2oqjP4dT7K6ij09Kyd+R21r7UVJrF0buMVdZS5QRhDzpvzAxHxabQadow==", 393 | "dev": true, 394 | "license": "MIT", 395 | "dependencies": { 396 | "@typescript-eslint/typescript-estree": "8.18.0", 397 | "@typescript-eslint/utils": "8.18.0", 398 | "debug": "^4.3.4", 399 | "ts-api-utils": "^1.3.0" 400 | }, 401 | "engines": { 402 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 403 | }, 404 | "funding": { 405 | "type": "opencollective", 406 | "url": "https://opencollective.com/typescript-eslint" 407 | }, 408 | "peerDependencies": { 409 | "eslint": "^8.57.0 || ^9.0.0", 410 | "typescript": ">=4.8.4 <5.8.0" 411 | } 412 | }, 413 | "node_modules/@typescript-eslint/types": { 414 | "version": "8.18.0", 415 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.18.0.tgz", 416 | "integrity": "sha512-FNYxgyTCAnFwTrzpBGq+zrnoTO4x0c1CKYY5MuUTzpScqmY5fmsh2o3+57lqdI3NZucBDCzDgdEbIaNfAjAHQA==", 417 | "dev": true, 418 | "license": "MIT", 419 | "engines": { 420 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 421 | }, 422 | "funding": { 423 | "type": "opencollective", 424 | "url": "https://opencollective.com/typescript-eslint" 425 | } 426 | }, 427 | "node_modules/@typescript-eslint/typescript-estree": { 428 | "version": "8.18.0", 429 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-8.18.0.tgz", 430 | "integrity": "sha512-rqQgFRu6yPkauz+ms3nQpohwejS8bvgbPyIDq13cgEDbkXt4LH4OkDMT0/fN1RUtzG8e8AKJyDBoocuQh8qNeg==", 431 | "dev": true, 432 | "license": "MIT", 433 | "dependencies": { 434 | "@typescript-eslint/types": "8.18.0", 435 | "@typescript-eslint/visitor-keys": "8.18.0", 436 | "debug": "^4.3.4", 437 | "fast-glob": "^3.3.2", 438 | "is-glob": "^4.0.3", 439 | "minimatch": "^9.0.4", 440 | "semver": "^7.6.0", 441 | "ts-api-utils": "^1.3.0" 442 | }, 443 | "engines": { 444 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 445 | }, 446 | "funding": { 447 | "type": "opencollective", 448 | "url": "https://opencollective.com/typescript-eslint" 449 | }, 450 | "peerDependencies": { 451 | "typescript": ">=4.8.4 <5.8.0" 452 | } 453 | }, 454 | "node_modules/@typescript-eslint/typescript-estree/node_modules/brace-expansion": { 455 | "version": "2.0.1", 456 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 457 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 458 | "dev": true, 459 | "license": "MIT", 460 | "dependencies": { 461 | "balanced-match": "^1.0.0" 462 | } 463 | }, 464 | "node_modules/@typescript-eslint/typescript-estree/node_modules/minimatch": { 465 | "version": "9.0.5", 466 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", 467 | "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", 468 | "dev": true, 469 | "license": "ISC", 470 | "dependencies": { 471 | "brace-expansion": "^2.0.1" 472 | }, 473 | "engines": { 474 | "node": ">=16 || 14 >=14.17" 475 | }, 476 | "funding": { 477 | "url": "https://github.com/sponsors/isaacs" 478 | } 479 | }, 480 | "node_modules/@typescript-eslint/utils": { 481 | "version": "8.18.0", 482 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-8.18.0.tgz", 483 | "integrity": "sha512-p6GLdY383i7h5b0Qrfbix3Vc3+J2k6QWw6UMUeY5JGfm3C5LbZ4QIZzJNoNOfgyRe0uuYKjvVOsO/jD4SJO+xg==", 484 | "dev": true, 485 | "license": "MIT", 486 | "dependencies": { 487 | "@eslint-community/eslint-utils": "^4.4.0", 488 | "@typescript-eslint/scope-manager": "8.18.0", 489 | "@typescript-eslint/types": "8.18.0", 490 | "@typescript-eslint/typescript-estree": "8.18.0" 491 | }, 492 | "engines": { 493 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 494 | }, 495 | "funding": { 496 | "type": "opencollective", 497 | "url": "https://opencollective.com/typescript-eslint" 498 | }, 499 | "peerDependencies": { 500 | "eslint": "^8.57.0 || ^9.0.0", 501 | "typescript": ">=4.8.4 <5.8.0" 502 | } 503 | }, 504 | "node_modules/@typescript-eslint/visitor-keys": { 505 | "version": "8.18.0", 506 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-8.18.0.tgz", 507 | "integrity": "sha512-pCh/qEA8Lb1wVIqNvBke8UaRjJ6wrAWkJO5yyIbs8Yx6TNGYyfNjOo61tLv+WwLvoLPp4BQ8B7AHKijl8NGUfw==", 508 | "dev": true, 509 | "license": "MIT", 510 | "dependencies": { 511 | "@typescript-eslint/types": "8.18.0", 512 | "eslint-visitor-keys": "^4.2.0" 513 | }, 514 | "engines": { 515 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 516 | }, 517 | "funding": { 518 | "type": "opencollective", 519 | "url": "https://opencollective.com/typescript-eslint" 520 | } 521 | }, 522 | "node_modules/acorn": { 523 | "version": "8.14.0", 524 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.14.0.tgz", 525 | "integrity": "sha512-cl669nCJTZBsL97OF4kUQm5g5hC2uihk0NxY3WENAC0TYdILVkAyHymAntgxGkl7K+t0cXIrH5siy5S4XkFycA==", 526 | "dev": true, 527 | "license": "MIT", 528 | "bin": { 529 | "acorn": "bin/acorn" 530 | }, 531 | "engines": { 532 | "node": ">=0.4.0" 533 | } 534 | }, 535 | "node_modules/acorn-jsx": { 536 | "version": "5.3.2", 537 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 538 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 539 | "dev": true, 540 | "license": "MIT", 541 | "peerDependencies": { 542 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 543 | } 544 | }, 545 | "node_modules/ajv": { 546 | "version": "6.12.6", 547 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 548 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 549 | "dev": true, 550 | "license": "MIT", 551 | "dependencies": { 552 | "fast-deep-equal": "^3.1.1", 553 | "fast-json-stable-stringify": "^2.0.0", 554 | "json-schema-traverse": "^0.4.1", 555 | "uri-js": "^4.2.2" 556 | }, 557 | "funding": { 558 | "type": "github", 559 | "url": "https://github.com/sponsors/epoberezkin" 560 | } 561 | }, 562 | "node_modules/ansi-regex": { 563 | "version": "5.0.1", 564 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 565 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 566 | "license": "MIT", 567 | "engines": { 568 | "node": ">=8" 569 | } 570 | }, 571 | "node_modules/ansi-styles": { 572 | "version": "4.3.0", 573 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 574 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 575 | "license": "MIT", 576 | "dependencies": { 577 | "color-convert": "^2.0.1" 578 | }, 579 | "engines": { 580 | "node": ">=8" 581 | }, 582 | "funding": { 583 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 584 | } 585 | }, 586 | "node_modules/argparse": { 587 | "version": "2.0.1", 588 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 589 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 590 | "dev": true, 591 | "license": "Python-2.0" 592 | }, 593 | "node_modules/balanced-match": { 594 | "version": "1.0.2", 595 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 596 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 597 | "dev": true, 598 | "license": "MIT" 599 | }, 600 | "node_modules/brace-expansion": { 601 | "version": "1.1.11", 602 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 603 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 604 | "dev": true, 605 | "license": "MIT", 606 | "dependencies": { 607 | "balanced-match": "^1.0.0", 608 | "concat-map": "0.0.1" 609 | } 610 | }, 611 | "node_modules/braces": { 612 | "version": "3.0.3", 613 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", 614 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", 615 | "dev": true, 616 | "license": "MIT", 617 | "dependencies": { 618 | "fill-range": "^7.1.1" 619 | }, 620 | "engines": { 621 | "node": ">=8" 622 | } 623 | }, 624 | "node_modules/callsites": { 625 | "version": "3.1.0", 626 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 627 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 628 | "dev": true, 629 | "license": "MIT", 630 | "engines": { 631 | "node": ">=6" 632 | } 633 | }, 634 | "node_modules/chalk": { 635 | "version": "4.1.2", 636 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 637 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 638 | "dev": true, 639 | "license": "MIT", 640 | "dependencies": { 641 | "ansi-styles": "^4.1.0", 642 | "supports-color": "^7.1.0" 643 | }, 644 | "engines": { 645 | "node": ">=10" 646 | }, 647 | "funding": { 648 | "url": "https://github.com/chalk/chalk?sponsor=1" 649 | } 650 | }, 651 | "node_modules/cliui": { 652 | "version": "8.0.1", 653 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", 654 | "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", 655 | "license": "ISC", 656 | "dependencies": { 657 | "string-width": "^4.2.0", 658 | "strip-ansi": "^6.0.1", 659 | "wrap-ansi": "^7.0.0" 660 | }, 661 | "engines": { 662 | "node": ">=12" 663 | } 664 | }, 665 | "node_modules/color-convert": { 666 | "version": "2.0.1", 667 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 668 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 669 | "license": "MIT", 670 | "dependencies": { 671 | "color-name": "~1.1.4" 672 | }, 673 | "engines": { 674 | "node": ">=7.0.0" 675 | } 676 | }, 677 | "node_modules/color-name": { 678 | "version": "1.1.4", 679 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 680 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 681 | "license": "MIT" 682 | }, 683 | "node_modules/concat-map": { 684 | "version": "0.0.1", 685 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 686 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 687 | "dev": true, 688 | "license": "MIT" 689 | }, 690 | "node_modules/cross-spawn": { 691 | "version": "7.0.6", 692 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz", 693 | "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==", 694 | "dev": true, 695 | "license": "MIT", 696 | "dependencies": { 697 | "path-key": "^3.1.0", 698 | "shebang-command": "^2.0.0", 699 | "which": "^2.0.1" 700 | }, 701 | "engines": { 702 | "node": ">= 8" 703 | } 704 | }, 705 | "node_modules/debug": { 706 | "version": "4.4.0", 707 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", 708 | "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", 709 | "dev": true, 710 | "license": "MIT", 711 | "dependencies": { 712 | "ms": "^2.1.3" 713 | }, 714 | "engines": { 715 | "node": ">=6.0" 716 | }, 717 | "peerDependenciesMeta": { 718 | "supports-color": { 719 | "optional": true 720 | } 721 | } 722 | }, 723 | "node_modules/deep-is": { 724 | "version": "0.1.4", 725 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 726 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 727 | "dev": true, 728 | "license": "MIT" 729 | }, 730 | "node_modules/emoji-regex": { 731 | "version": "8.0.0", 732 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 733 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 734 | "license": "MIT" 735 | }, 736 | "node_modules/escalade": { 737 | "version": "3.2.0", 738 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", 739 | "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==", 740 | "license": "MIT", 741 | "engines": { 742 | "node": ">=6" 743 | } 744 | }, 745 | "node_modules/escape-string-regexp": { 746 | "version": "4.0.0", 747 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 748 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 749 | "dev": true, 750 | "license": "MIT", 751 | "engines": { 752 | "node": ">=10" 753 | }, 754 | "funding": { 755 | "url": "https://github.com/sponsors/sindresorhus" 756 | } 757 | }, 758 | "node_modules/eslint": { 759 | "version": "9.17.0", 760 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.17.0.tgz", 761 | "integrity": "sha512-evtlNcpJg+cZLcnVKwsai8fExnqjGPicK7gnUtlNuzu+Fv9bI0aLpND5T44VLQtoMEnI57LoXO9XAkIXwohKrA==", 762 | "dev": true, 763 | "license": "MIT", 764 | "dependencies": { 765 | "@eslint-community/eslint-utils": "^4.2.0", 766 | "@eslint-community/regexpp": "^4.12.1", 767 | "@eslint/config-array": "^0.19.0", 768 | "@eslint/core": "^0.9.0", 769 | "@eslint/eslintrc": "^3.2.0", 770 | "@eslint/js": "9.17.0", 771 | "@eslint/plugin-kit": "^0.2.3", 772 | "@humanfs/node": "^0.16.6", 773 | "@humanwhocodes/module-importer": "^1.0.1", 774 | "@humanwhocodes/retry": "^0.4.1", 775 | "@types/estree": "^1.0.6", 776 | "@types/json-schema": "^7.0.15", 777 | "ajv": "^6.12.4", 778 | "chalk": "^4.0.0", 779 | "cross-spawn": "^7.0.6", 780 | "debug": "^4.3.2", 781 | "escape-string-regexp": "^4.0.0", 782 | "eslint-scope": "^8.2.0", 783 | "eslint-visitor-keys": "^4.2.0", 784 | "espree": "^10.3.0", 785 | "esquery": "^1.5.0", 786 | "esutils": "^2.0.2", 787 | "fast-deep-equal": "^3.1.3", 788 | "file-entry-cache": "^8.0.0", 789 | "find-up": "^5.0.0", 790 | "glob-parent": "^6.0.2", 791 | "ignore": "^5.2.0", 792 | "imurmurhash": "^0.1.4", 793 | "is-glob": "^4.0.0", 794 | "json-stable-stringify-without-jsonify": "^1.0.1", 795 | "lodash.merge": "^4.6.2", 796 | "minimatch": "^3.1.2", 797 | "natural-compare": "^1.4.0", 798 | "optionator": "^0.9.3" 799 | }, 800 | "bin": { 801 | "eslint": "bin/eslint.js" 802 | }, 803 | "engines": { 804 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 805 | }, 806 | "funding": { 807 | "url": "https://eslint.org/donate" 808 | }, 809 | "peerDependencies": { 810 | "jiti": "*" 811 | }, 812 | "peerDependenciesMeta": { 813 | "jiti": { 814 | "optional": true 815 | } 816 | } 817 | }, 818 | "node_modules/eslint-scope": { 819 | "version": "8.2.0", 820 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-8.2.0.tgz", 821 | "integrity": "sha512-PHlWUfG6lvPc3yvP5A4PNyBL1W8fkDUccmI21JUu/+GKZBoH/W5u6usENXUrWFRsyoW5ACUjFGgAFQp5gUlb/A==", 822 | "dev": true, 823 | "license": "BSD-2-Clause", 824 | "dependencies": { 825 | "esrecurse": "^4.3.0", 826 | "estraverse": "^5.2.0" 827 | }, 828 | "engines": { 829 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 830 | }, 831 | "funding": { 832 | "url": "https://opencollective.com/eslint" 833 | } 834 | }, 835 | "node_modules/eslint-visitor-keys": { 836 | "version": "4.2.0", 837 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.0.tgz", 838 | "integrity": "sha512-UyLnSehNt62FFhSwjZlHmeokpRK59rcz29j+F1/aDgbkbRTk7wIc9XzdoasMUbRNKDM0qQt/+BJ4BrpFeABemw==", 839 | "dev": true, 840 | "license": "Apache-2.0", 841 | "engines": { 842 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 843 | }, 844 | "funding": { 845 | "url": "https://opencollective.com/eslint" 846 | } 847 | }, 848 | "node_modules/espree": { 849 | "version": "10.3.0", 850 | "resolved": "https://registry.npmjs.org/espree/-/espree-10.3.0.tgz", 851 | "integrity": "sha512-0QYC8b24HWY8zjRnDTL6RiHfDbAWn63qb4LMj1Z4b076A4une81+z03Kg7l7mn/48PUTqoLptSXez8oknU8Clg==", 852 | "dev": true, 853 | "license": "BSD-2-Clause", 854 | "dependencies": { 855 | "acorn": "^8.14.0", 856 | "acorn-jsx": "^5.3.2", 857 | "eslint-visitor-keys": "^4.2.0" 858 | }, 859 | "engines": { 860 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 861 | }, 862 | "funding": { 863 | "url": "https://opencollective.com/eslint" 864 | } 865 | }, 866 | "node_modules/esquery": { 867 | "version": "1.6.0", 868 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.6.0.tgz", 869 | "integrity": "sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg==", 870 | "dev": true, 871 | "license": "BSD-3-Clause", 872 | "dependencies": { 873 | "estraverse": "^5.1.0" 874 | }, 875 | "engines": { 876 | "node": ">=0.10" 877 | } 878 | }, 879 | "node_modules/esrecurse": { 880 | "version": "4.3.0", 881 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 882 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 883 | "dev": true, 884 | "license": "BSD-2-Clause", 885 | "dependencies": { 886 | "estraverse": "^5.2.0" 887 | }, 888 | "engines": { 889 | "node": ">=4.0" 890 | } 891 | }, 892 | "node_modules/estraverse": { 893 | "version": "5.3.0", 894 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 895 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 896 | "dev": true, 897 | "license": "BSD-2-Clause", 898 | "engines": { 899 | "node": ">=4.0" 900 | } 901 | }, 902 | "node_modules/esutils": { 903 | "version": "2.0.3", 904 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 905 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 906 | "dev": true, 907 | "license": "BSD-2-Clause", 908 | "engines": { 909 | "node": ">=0.10.0" 910 | } 911 | }, 912 | "node_modules/fast-deep-equal": { 913 | "version": "3.1.3", 914 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 915 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 916 | "dev": true, 917 | "license": "MIT" 918 | }, 919 | "node_modules/fast-glob": { 920 | "version": "3.3.2", 921 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", 922 | "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", 923 | "dev": true, 924 | "license": "MIT", 925 | "dependencies": { 926 | "@nodelib/fs.stat": "^2.0.2", 927 | "@nodelib/fs.walk": "^1.2.3", 928 | "glob-parent": "^5.1.2", 929 | "merge2": "^1.3.0", 930 | "micromatch": "^4.0.4" 931 | }, 932 | "engines": { 933 | "node": ">=8.6.0" 934 | } 935 | }, 936 | "node_modules/fast-glob/node_modules/glob-parent": { 937 | "version": "5.1.2", 938 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 939 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 940 | "dev": true, 941 | "license": "ISC", 942 | "dependencies": { 943 | "is-glob": "^4.0.1" 944 | }, 945 | "engines": { 946 | "node": ">= 6" 947 | } 948 | }, 949 | "node_modules/fast-json-stable-stringify": { 950 | "version": "2.1.0", 951 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 952 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 953 | "dev": true, 954 | "license": "MIT" 955 | }, 956 | "node_modules/fast-levenshtein": { 957 | "version": "2.0.6", 958 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 959 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 960 | "dev": true, 961 | "license": "MIT" 962 | }, 963 | "node_modules/fastq": { 964 | "version": "1.17.1", 965 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", 966 | "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", 967 | "dev": true, 968 | "license": "ISC", 969 | "dependencies": { 970 | "reusify": "^1.0.4" 971 | } 972 | }, 973 | "node_modules/file-entry-cache": { 974 | "version": "8.0.0", 975 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-8.0.0.tgz", 976 | "integrity": "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==", 977 | "dev": true, 978 | "license": "MIT", 979 | "dependencies": { 980 | "flat-cache": "^4.0.0" 981 | }, 982 | "engines": { 983 | "node": ">=16.0.0" 984 | } 985 | }, 986 | "node_modules/fill-range": { 987 | "version": "7.1.1", 988 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", 989 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", 990 | "dev": true, 991 | "license": "MIT", 992 | "dependencies": { 993 | "to-regex-range": "^5.0.1" 994 | }, 995 | "engines": { 996 | "node": ">=8" 997 | } 998 | }, 999 | "node_modules/find-up": { 1000 | "version": "5.0.0", 1001 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1002 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1003 | "dev": true, 1004 | "license": "MIT", 1005 | "dependencies": { 1006 | "locate-path": "^6.0.0", 1007 | "path-exists": "^4.0.0" 1008 | }, 1009 | "engines": { 1010 | "node": ">=10" 1011 | }, 1012 | "funding": { 1013 | "url": "https://github.com/sponsors/sindresorhus" 1014 | } 1015 | }, 1016 | "node_modules/flat-cache": { 1017 | "version": "4.0.1", 1018 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-4.0.1.tgz", 1019 | "integrity": "sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw==", 1020 | "dev": true, 1021 | "license": "MIT", 1022 | "dependencies": { 1023 | "flatted": "^3.2.9", 1024 | "keyv": "^4.5.4" 1025 | }, 1026 | "engines": { 1027 | "node": ">=16" 1028 | } 1029 | }, 1030 | "node_modules/flatted": { 1031 | "version": "3.3.2", 1032 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.2.tgz", 1033 | "integrity": "sha512-AiwGJM8YcNOaobumgtng+6NHuOqC3A7MixFeDafM3X9cIUM+xUXoS5Vfgf+OihAYe20fxqNM9yPBXJzRtZ/4eA==", 1034 | "dev": true, 1035 | "license": "ISC" 1036 | }, 1037 | "node_modules/get-caller-file": { 1038 | "version": "2.0.5", 1039 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1040 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1041 | "license": "ISC", 1042 | "engines": { 1043 | "node": "6.* || 8.* || >= 10.*" 1044 | } 1045 | }, 1046 | "node_modules/glob-parent": { 1047 | "version": "6.0.2", 1048 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 1049 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 1050 | "dev": true, 1051 | "license": "ISC", 1052 | "dependencies": { 1053 | "is-glob": "^4.0.3" 1054 | }, 1055 | "engines": { 1056 | "node": ">=10.13.0" 1057 | } 1058 | }, 1059 | "node_modules/globals": { 1060 | "version": "15.13.0", 1061 | "resolved": "https://registry.npmjs.org/globals/-/globals-15.13.0.tgz", 1062 | "integrity": "sha512-49TewVEz0UxZjr1WYYsWpPrhyC/B/pA8Bq0fUmet2n+eR7yn0IvNzNaoBwnK6mdkzcN+se7Ez9zUgULTz2QH4g==", 1063 | "dev": true, 1064 | "license": "MIT", 1065 | "engines": { 1066 | "node": ">=18" 1067 | }, 1068 | "funding": { 1069 | "url": "https://github.com/sponsors/sindresorhus" 1070 | } 1071 | }, 1072 | "node_modules/graphemer": { 1073 | "version": "1.4.0", 1074 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 1075 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 1076 | "dev": true, 1077 | "license": "MIT" 1078 | }, 1079 | "node_modules/has-flag": { 1080 | "version": "4.0.0", 1081 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1082 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1083 | "dev": true, 1084 | "license": "MIT", 1085 | "engines": { 1086 | "node": ">=8" 1087 | } 1088 | }, 1089 | "node_modules/ignore": { 1090 | "version": "5.3.2", 1091 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz", 1092 | "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==", 1093 | "dev": true, 1094 | "license": "MIT", 1095 | "engines": { 1096 | "node": ">= 4" 1097 | } 1098 | }, 1099 | "node_modules/import-fresh": { 1100 | "version": "3.3.0", 1101 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1102 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1103 | "dev": true, 1104 | "license": "MIT", 1105 | "dependencies": { 1106 | "parent-module": "^1.0.0", 1107 | "resolve-from": "^4.0.0" 1108 | }, 1109 | "engines": { 1110 | "node": ">=6" 1111 | }, 1112 | "funding": { 1113 | "url": "https://github.com/sponsors/sindresorhus" 1114 | } 1115 | }, 1116 | "node_modules/imurmurhash": { 1117 | "version": "0.1.4", 1118 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1119 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1120 | "dev": true, 1121 | "engines": { 1122 | "node": ">=0.8.19" 1123 | } 1124 | }, 1125 | "node_modules/is-extglob": { 1126 | "version": "2.1.1", 1127 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1128 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1129 | "dev": true, 1130 | "license": "MIT", 1131 | "engines": { 1132 | "node": ">=0.10.0" 1133 | } 1134 | }, 1135 | "node_modules/is-fullwidth-code-point": { 1136 | "version": "3.0.0", 1137 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1138 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1139 | "license": "MIT", 1140 | "engines": { 1141 | "node": ">=8" 1142 | } 1143 | }, 1144 | "node_modules/is-glob": { 1145 | "version": "4.0.3", 1146 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1147 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1148 | "dev": true, 1149 | "license": "MIT", 1150 | "dependencies": { 1151 | "is-extglob": "^2.1.1" 1152 | }, 1153 | "engines": { 1154 | "node": ">=0.10.0" 1155 | } 1156 | }, 1157 | "node_modules/is-number": { 1158 | "version": "7.0.0", 1159 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1160 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1161 | "dev": true, 1162 | "license": "MIT", 1163 | "engines": { 1164 | "node": ">=0.12.0" 1165 | } 1166 | }, 1167 | "node_modules/isexe": { 1168 | "version": "2.0.0", 1169 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1170 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 1171 | "dev": true, 1172 | "license": "ISC" 1173 | }, 1174 | "node_modules/js-yaml": { 1175 | "version": "4.1.0", 1176 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1177 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1178 | "dev": true, 1179 | "license": "MIT", 1180 | "dependencies": { 1181 | "argparse": "^2.0.1" 1182 | }, 1183 | "bin": { 1184 | "js-yaml": "bin/js-yaml.js" 1185 | } 1186 | }, 1187 | "node_modules/json-buffer": { 1188 | "version": "3.0.1", 1189 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 1190 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 1191 | "dev": true, 1192 | "license": "MIT" 1193 | }, 1194 | "node_modules/json-schema-traverse": { 1195 | "version": "0.4.1", 1196 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1197 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1198 | "dev": true, 1199 | "license": "MIT" 1200 | }, 1201 | "node_modules/json-stable-stringify-without-jsonify": { 1202 | "version": "1.0.1", 1203 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1204 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1205 | "dev": true 1206 | }, 1207 | "node_modules/keyv": { 1208 | "version": "4.5.4", 1209 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 1210 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 1211 | "dev": true, 1212 | "license": "MIT", 1213 | "dependencies": { 1214 | "json-buffer": "3.0.1" 1215 | } 1216 | }, 1217 | "node_modules/levn": { 1218 | "version": "0.4.1", 1219 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1220 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1221 | "dev": true, 1222 | "license": "MIT", 1223 | "dependencies": { 1224 | "prelude-ls": "^1.2.1", 1225 | "type-check": "~0.4.0" 1226 | }, 1227 | "engines": { 1228 | "node": ">= 0.8.0" 1229 | } 1230 | }, 1231 | "node_modules/locate-path": { 1232 | "version": "6.0.0", 1233 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1234 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1235 | "dev": true, 1236 | "license": "MIT", 1237 | "dependencies": { 1238 | "p-locate": "^5.0.0" 1239 | }, 1240 | "engines": { 1241 | "node": ">=10" 1242 | }, 1243 | "funding": { 1244 | "url": "https://github.com/sponsors/sindresorhus" 1245 | } 1246 | }, 1247 | "node_modules/lodash.merge": { 1248 | "version": "4.6.2", 1249 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1250 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1251 | "dev": true, 1252 | "license": "MIT" 1253 | }, 1254 | "node_modules/merge2": { 1255 | "version": "1.4.1", 1256 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 1257 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 1258 | "dev": true, 1259 | "license": "MIT", 1260 | "engines": { 1261 | "node": ">= 8" 1262 | } 1263 | }, 1264 | "node_modules/micromatch": { 1265 | "version": "4.0.8", 1266 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.8.tgz", 1267 | "integrity": "sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==", 1268 | "dev": true, 1269 | "license": "MIT", 1270 | "dependencies": { 1271 | "braces": "^3.0.3", 1272 | "picomatch": "^2.3.1" 1273 | }, 1274 | "engines": { 1275 | "node": ">=8.6" 1276 | } 1277 | }, 1278 | "node_modules/minimatch": { 1279 | "version": "3.1.2", 1280 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1281 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1282 | "dev": true, 1283 | "license": "ISC", 1284 | "dependencies": { 1285 | "brace-expansion": "^1.1.7" 1286 | }, 1287 | "engines": { 1288 | "node": "*" 1289 | } 1290 | }, 1291 | "node_modules/ms": { 1292 | "version": "2.1.3", 1293 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 1294 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 1295 | "dev": true, 1296 | "license": "MIT" 1297 | }, 1298 | "node_modules/natural-compare": { 1299 | "version": "1.4.0", 1300 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1301 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1302 | "dev": true 1303 | }, 1304 | "node_modules/optionator": { 1305 | "version": "0.9.4", 1306 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz", 1307 | "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==", 1308 | "dev": true, 1309 | "license": "MIT", 1310 | "dependencies": { 1311 | "deep-is": "^0.1.3", 1312 | "fast-levenshtein": "^2.0.6", 1313 | "levn": "^0.4.1", 1314 | "prelude-ls": "^1.2.1", 1315 | "type-check": "^0.4.0", 1316 | "word-wrap": "^1.2.5" 1317 | }, 1318 | "engines": { 1319 | "node": ">= 0.8.0" 1320 | } 1321 | }, 1322 | "node_modules/p-limit": { 1323 | "version": "3.1.0", 1324 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1325 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1326 | "dev": true, 1327 | "license": "MIT", 1328 | "dependencies": { 1329 | "yocto-queue": "^0.1.0" 1330 | }, 1331 | "engines": { 1332 | "node": ">=10" 1333 | }, 1334 | "funding": { 1335 | "url": "https://github.com/sponsors/sindresorhus" 1336 | } 1337 | }, 1338 | "node_modules/p-locate": { 1339 | "version": "5.0.0", 1340 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1341 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1342 | "dev": true, 1343 | "license": "MIT", 1344 | "dependencies": { 1345 | "p-limit": "^3.0.2" 1346 | }, 1347 | "engines": { 1348 | "node": ">=10" 1349 | }, 1350 | "funding": { 1351 | "url": "https://github.com/sponsors/sindresorhus" 1352 | } 1353 | }, 1354 | "node_modules/parent-module": { 1355 | "version": "1.0.1", 1356 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1357 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1358 | "dev": true, 1359 | "license": "MIT", 1360 | "dependencies": { 1361 | "callsites": "^3.0.0" 1362 | }, 1363 | "engines": { 1364 | "node": ">=6" 1365 | } 1366 | }, 1367 | "node_modules/path-exists": { 1368 | "version": "4.0.0", 1369 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1370 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1371 | "dev": true, 1372 | "license": "MIT", 1373 | "engines": { 1374 | "node": ">=8" 1375 | } 1376 | }, 1377 | "node_modules/path-key": { 1378 | "version": "3.1.1", 1379 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1380 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1381 | "dev": true, 1382 | "license": "MIT", 1383 | "engines": { 1384 | "node": ">=8" 1385 | } 1386 | }, 1387 | "node_modules/picomatch": { 1388 | "version": "2.3.1", 1389 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1390 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1391 | "dev": true, 1392 | "license": "MIT", 1393 | "engines": { 1394 | "node": ">=8.6" 1395 | }, 1396 | "funding": { 1397 | "url": "https://github.com/sponsors/jonschlinkert" 1398 | } 1399 | }, 1400 | "node_modules/prelude-ls": { 1401 | "version": "1.2.1", 1402 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1403 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1404 | "dev": true, 1405 | "license": "MIT", 1406 | "engines": { 1407 | "node": ">= 0.8.0" 1408 | } 1409 | }, 1410 | "node_modules/prettier": { 1411 | "version": "3.4.2", 1412 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.4.2.tgz", 1413 | "integrity": "sha512-e9MewbtFo+Fevyuxn/4rrcDAaq0IYxPGLvObpQjiZBMAzB9IGmzlnG9RZy3FFas+eBMu2vA0CszMeduow5dIuQ==", 1414 | "dev": true, 1415 | "license": "MIT", 1416 | "bin": { 1417 | "prettier": "bin/prettier.cjs" 1418 | }, 1419 | "engines": { 1420 | "node": ">=14" 1421 | }, 1422 | "funding": { 1423 | "url": "https://github.com/prettier/prettier?sponsor=1" 1424 | } 1425 | }, 1426 | "node_modules/punycode": { 1427 | "version": "2.3.1", 1428 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 1429 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 1430 | "dev": true, 1431 | "license": "MIT", 1432 | "engines": { 1433 | "node": ">=6" 1434 | } 1435 | }, 1436 | "node_modules/queue-microtask": { 1437 | "version": "1.2.3", 1438 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 1439 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 1440 | "dev": true, 1441 | "funding": [ 1442 | { 1443 | "type": "github", 1444 | "url": "https://github.com/sponsors/feross" 1445 | }, 1446 | { 1447 | "type": "patreon", 1448 | "url": "https://www.patreon.com/feross" 1449 | }, 1450 | { 1451 | "type": "consulting", 1452 | "url": "https://feross.org/support" 1453 | } 1454 | ], 1455 | "license": "MIT" 1456 | }, 1457 | "node_modules/require-directory": { 1458 | "version": "2.1.1", 1459 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1460 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 1461 | "license": "MIT", 1462 | "engines": { 1463 | "node": ">=0.10.0" 1464 | } 1465 | }, 1466 | "node_modules/resolve-from": { 1467 | "version": "4.0.0", 1468 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1469 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1470 | "dev": true, 1471 | "license": "MIT", 1472 | "engines": { 1473 | "node": ">=4" 1474 | } 1475 | }, 1476 | "node_modules/reusify": { 1477 | "version": "1.0.4", 1478 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 1479 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 1480 | "dev": true, 1481 | "license": "MIT", 1482 | "engines": { 1483 | "iojs": ">=1.0.0", 1484 | "node": ">=0.10.0" 1485 | } 1486 | }, 1487 | "node_modules/run-parallel": { 1488 | "version": "1.2.0", 1489 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 1490 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 1491 | "dev": true, 1492 | "funding": [ 1493 | { 1494 | "type": "github", 1495 | "url": "https://github.com/sponsors/feross" 1496 | }, 1497 | { 1498 | "type": "patreon", 1499 | "url": "https://www.patreon.com/feross" 1500 | }, 1501 | { 1502 | "type": "consulting", 1503 | "url": "https://feross.org/support" 1504 | } 1505 | ], 1506 | "license": "MIT", 1507 | "dependencies": { 1508 | "queue-microtask": "^1.2.2" 1509 | } 1510 | }, 1511 | "node_modules/semver": { 1512 | "version": "7.6.3", 1513 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 1514 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 1515 | "dev": true, 1516 | "license": "ISC", 1517 | "bin": { 1518 | "semver": "bin/semver.js" 1519 | }, 1520 | "engines": { 1521 | "node": ">=10" 1522 | } 1523 | }, 1524 | "node_modules/shebang-command": { 1525 | "version": "2.0.0", 1526 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1527 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1528 | "dev": true, 1529 | "license": "MIT", 1530 | "dependencies": { 1531 | "shebang-regex": "^3.0.0" 1532 | }, 1533 | "engines": { 1534 | "node": ">=8" 1535 | } 1536 | }, 1537 | "node_modules/shebang-regex": { 1538 | "version": "3.0.0", 1539 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1540 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1541 | "dev": true, 1542 | "license": "MIT", 1543 | "engines": { 1544 | "node": ">=8" 1545 | } 1546 | }, 1547 | "node_modules/string-width": { 1548 | "version": "4.2.3", 1549 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1550 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1551 | "license": "MIT", 1552 | "dependencies": { 1553 | "emoji-regex": "^8.0.0", 1554 | "is-fullwidth-code-point": "^3.0.0", 1555 | "strip-ansi": "^6.0.1" 1556 | }, 1557 | "engines": { 1558 | "node": ">=8" 1559 | } 1560 | }, 1561 | "node_modules/strip-ansi": { 1562 | "version": "6.0.1", 1563 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1564 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1565 | "license": "MIT", 1566 | "dependencies": { 1567 | "ansi-regex": "^5.0.1" 1568 | }, 1569 | "engines": { 1570 | "node": ">=8" 1571 | } 1572 | }, 1573 | "node_modules/strip-json-comments": { 1574 | "version": "3.1.1", 1575 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1576 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1577 | "dev": true, 1578 | "license": "MIT", 1579 | "engines": { 1580 | "node": ">=8" 1581 | }, 1582 | "funding": { 1583 | "url": "https://github.com/sponsors/sindresorhus" 1584 | } 1585 | }, 1586 | "node_modules/supports-color": { 1587 | "version": "7.2.0", 1588 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1589 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1590 | "dev": true, 1591 | "license": "MIT", 1592 | "dependencies": { 1593 | "has-flag": "^4.0.0" 1594 | }, 1595 | "engines": { 1596 | "node": ">=8" 1597 | } 1598 | }, 1599 | "node_modules/to-regex-range": { 1600 | "version": "5.0.1", 1601 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1602 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1603 | "dev": true, 1604 | "license": "MIT", 1605 | "dependencies": { 1606 | "is-number": "^7.0.0" 1607 | }, 1608 | "engines": { 1609 | "node": ">=8.0" 1610 | } 1611 | }, 1612 | "node_modules/ts-api-utils": { 1613 | "version": "1.4.3", 1614 | "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.4.3.tgz", 1615 | "integrity": "sha512-i3eMG77UTMD0hZhgRS562pv83RC6ukSAC2GMNWc+9dieh/+jDM5u5YG+NHX6VNDRHQcHwmsTHctP9LhbC3WxVw==", 1616 | "dev": true, 1617 | "license": "MIT", 1618 | "engines": { 1619 | "node": ">=16" 1620 | }, 1621 | "peerDependencies": { 1622 | "typescript": ">=4.2.0" 1623 | } 1624 | }, 1625 | "node_modules/type-check": { 1626 | "version": "0.4.0", 1627 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1628 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1629 | "dev": true, 1630 | "license": "MIT", 1631 | "dependencies": { 1632 | "prelude-ls": "^1.2.1" 1633 | }, 1634 | "engines": { 1635 | "node": ">= 0.8.0" 1636 | } 1637 | }, 1638 | "node_modules/typescript": { 1639 | "version": "5.7.2", 1640 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.7.2.tgz", 1641 | "integrity": "sha512-i5t66RHxDvVN40HfDd1PsEThGNnlMCMT3jMUuoh9/0TaqWevNontacunWyN02LA9/fIbEWlcHZcgTKb9QoaLfg==", 1642 | "dev": true, 1643 | "license": "Apache-2.0", 1644 | "bin": { 1645 | "tsc": "bin/tsc", 1646 | "tsserver": "bin/tsserver" 1647 | }, 1648 | "engines": { 1649 | "node": ">=14.17" 1650 | } 1651 | }, 1652 | "node_modules/typescript-eslint": { 1653 | "version": "8.18.0", 1654 | "resolved": "https://registry.npmjs.org/typescript-eslint/-/typescript-eslint-8.18.0.tgz", 1655 | "integrity": "sha512-Xq2rRjn6tzVpAyHr3+nmSg1/9k9aIHnJ2iZeOH7cfGOWqTkXTm3kwpQglEuLGdNrYvPF+2gtAs+/KF5rjVo+WQ==", 1656 | "dev": true, 1657 | "license": "MIT", 1658 | "dependencies": { 1659 | "@typescript-eslint/eslint-plugin": "8.18.0", 1660 | "@typescript-eslint/parser": "8.18.0", 1661 | "@typescript-eslint/utils": "8.18.0" 1662 | }, 1663 | "engines": { 1664 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 1665 | }, 1666 | "funding": { 1667 | "type": "opencollective", 1668 | "url": "https://opencollective.com/typescript-eslint" 1669 | }, 1670 | "peerDependencies": { 1671 | "eslint": "^8.57.0 || ^9.0.0", 1672 | "typescript": ">=4.8.4 <5.8.0" 1673 | } 1674 | }, 1675 | "node_modules/undici-types": { 1676 | "version": "6.20.0", 1677 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-6.20.0.tgz", 1678 | "integrity": "sha512-Ny6QZ2Nju20vw1SRHe3d9jVu6gJ+4e3+MMpqu7pqE5HT6WsTSlce++GQmK5UXS8mzV8DSYHrQH+Xrf2jVcuKNg==", 1679 | "dev": true, 1680 | "license": "MIT" 1681 | }, 1682 | "node_modules/uri-js": { 1683 | "version": "4.4.1", 1684 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1685 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1686 | "dev": true, 1687 | "license": "BSD-2-Clause", 1688 | "dependencies": { 1689 | "punycode": "^2.1.0" 1690 | } 1691 | }, 1692 | "node_modules/which": { 1693 | "version": "2.0.2", 1694 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1695 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1696 | "dev": true, 1697 | "license": "ISC", 1698 | "dependencies": { 1699 | "isexe": "^2.0.0" 1700 | }, 1701 | "bin": { 1702 | "node-which": "bin/node-which" 1703 | }, 1704 | "engines": { 1705 | "node": ">= 8" 1706 | } 1707 | }, 1708 | "node_modules/word-wrap": { 1709 | "version": "1.2.5", 1710 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", 1711 | "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", 1712 | "dev": true, 1713 | "license": "MIT", 1714 | "engines": { 1715 | "node": ">=0.10.0" 1716 | } 1717 | }, 1718 | "node_modules/wrap-ansi": { 1719 | "version": "7.0.0", 1720 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 1721 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 1722 | "license": "MIT", 1723 | "dependencies": { 1724 | "ansi-styles": "^4.0.0", 1725 | "string-width": "^4.1.0", 1726 | "strip-ansi": "^6.0.0" 1727 | }, 1728 | "engines": { 1729 | "node": ">=10" 1730 | }, 1731 | "funding": { 1732 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 1733 | } 1734 | }, 1735 | "node_modules/y18n": { 1736 | "version": "5.0.8", 1737 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 1738 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 1739 | "license": "ISC", 1740 | "engines": { 1741 | "node": ">=10" 1742 | } 1743 | }, 1744 | "node_modules/yargs": { 1745 | "version": "17.7.2", 1746 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", 1747 | "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", 1748 | "license": "MIT", 1749 | "dependencies": { 1750 | "cliui": "^8.0.1", 1751 | "escalade": "^3.1.1", 1752 | "get-caller-file": "^2.0.5", 1753 | "require-directory": "^2.1.1", 1754 | "string-width": "^4.2.3", 1755 | "y18n": "^5.0.5", 1756 | "yargs-parser": "^21.1.1" 1757 | }, 1758 | "engines": { 1759 | "node": ">=12" 1760 | } 1761 | }, 1762 | "node_modules/yargs-parser": { 1763 | "version": "21.1.1", 1764 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", 1765 | "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", 1766 | "license": "ISC", 1767 | "engines": { 1768 | "node": ">=12" 1769 | } 1770 | }, 1771 | "node_modules/yocto-queue": { 1772 | "version": "0.1.0", 1773 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1774 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1775 | "dev": true, 1776 | "license": "MIT", 1777 | "engines": { 1778 | "node": ">=10" 1779 | }, 1780 | "funding": { 1781 | "url": "https://github.com/sponsors/sindresorhus" 1782 | } 1783 | } 1784 | }, 1785 | "dependencies": { 1786 | "@eslint-community/eslint-utils": { 1787 | "version": "4.4.1", 1788 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.1.tgz", 1789 | "integrity": "sha512-s3O3waFUrMV8P/XaF/+ZTp1X9XBZW1a4B97ZnjQF2KYWaFD2A8KyFBsrsfSjEmjn3RGWAIuvlneuZm3CUK3jbA==", 1790 | "dev": true, 1791 | "requires": { 1792 | "eslint-visitor-keys": "^3.4.3" 1793 | }, 1794 | "dependencies": { 1795 | "eslint-visitor-keys": { 1796 | "version": "3.4.3", 1797 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 1798 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 1799 | "dev": true 1800 | } 1801 | } 1802 | }, 1803 | "@eslint-community/regexpp": { 1804 | "version": "4.12.1", 1805 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.12.1.tgz", 1806 | "integrity": "sha512-CCZCDJuduB9OUkFkY2IgppNZMi2lBQgD2qzwXkEia16cge2pijY/aXi96CJMquDMn3nJdlPV1A5KrJEXwfLNzQ==", 1807 | "dev": true 1808 | }, 1809 | "@eslint/config-array": { 1810 | "version": "0.19.1", 1811 | "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.19.1.tgz", 1812 | "integrity": "sha512-fo6Mtm5mWyKjA/Chy1BYTdn5mGJoDNjC7C64ug20ADsRDGrA85bN3uK3MaKbeRkRuuIEAR5N33Jr1pbm411/PA==", 1813 | "dev": true, 1814 | "requires": { 1815 | "@eslint/object-schema": "^2.1.5", 1816 | "debug": "^4.3.1", 1817 | "minimatch": "^3.1.2" 1818 | } 1819 | }, 1820 | "@eslint/core": { 1821 | "version": "0.9.1", 1822 | "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.9.1.tgz", 1823 | "integrity": "sha512-GuUdqkyyzQI5RMIWkHhvTWLCyLo1jNK3vzkSyaExH5kHPDHcuL2VOpHjmMY+y3+NC69qAKToBqldTBgYeLSr9Q==", 1824 | "dev": true, 1825 | "requires": { 1826 | "@types/json-schema": "^7.0.15" 1827 | } 1828 | }, 1829 | "@eslint/eslintrc": { 1830 | "version": "3.2.0", 1831 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.2.0.tgz", 1832 | "integrity": "sha512-grOjVNN8P3hjJn/eIETF1wwd12DdnwFDoyceUJLYYdkpbwq3nLi+4fqrTAONx7XDALqlL220wC/RHSC/QTI/0w==", 1833 | "dev": true, 1834 | "requires": { 1835 | "ajv": "^6.12.4", 1836 | "debug": "^4.3.2", 1837 | "espree": "^10.0.1", 1838 | "globals": "^14.0.0", 1839 | "ignore": "^5.2.0", 1840 | "import-fresh": "^3.2.1", 1841 | "js-yaml": "^4.1.0", 1842 | "minimatch": "^3.1.2", 1843 | "strip-json-comments": "^3.1.1" 1844 | }, 1845 | "dependencies": { 1846 | "globals": { 1847 | "version": "14.0.0", 1848 | "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz", 1849 | "integrity": "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ==", 1850 | "dev": true 1851 | } 1852 | } 1853 | }, 1854 | "@eslint/js": { 1855 | "version": "9.17.0", 1856 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.17.0.tgz", 1857 | "integrity": "sha512-Sxc4hqcs1kTu0iID3kcZDW3JHq2a77HO9P8CP6YEA/FpH3Ll8UXE2r/86Rz9YJLKme39S9vU5OWNjC6Xl0Cr3w==", 1858 | "dev": true 1859 | }, 1860 | "@eslint/object-schema": { 1861 | "version": "2.1.5", 1862 | "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.5.tgz", 1863 | "integrity": "sha512-o0bhxnL89h5Bae5T318nFoFzGy+YE5i/gGkoPAgkmTVdRKTiv3p8JHevPiPaMwoloKfEiiaHlawCqaZMqRm+XQ==", 1864 | "dev": true 1865 | }, 1866 | "@eslint/plugin-kit": { 1867 | "version": "0.2.4", 1868 | "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.2.4.tgz", 1869 | "integrity": "sha512-zSkKow6H5Kdm0ZUQUB2kV5JIXqoG0+uH5YADhaEHswm664N9Db8dXSi0nMJpacpMf+MyyglF1vnZohpEg5yUtg==", 1870 | "dev": true, 1871 | "requires": { 1872 | "levn": "^0.4.1" 1873 | } 1874 | }, 1875 | "@humanfs/core": { 1876 | "version": "0.19.1", 1877 | "resolved": "https://registry.npmjs.org/@humanfs/core/-/core-0.19.1.tgz", 1878 | "integrity": "sha512-5DyQ4+1JEUzejeK1JGICcideyfUbGixgS9jNgex5nqkW+cY7WZhxBigmieN5Qnw9ZosSNVC9KQKyb+GUaGyKUA==", 1879 | "dev": true 1880 | }, 1881 | "@humanfs/node": { 1882 | "version": "0.16.6", 1883 | "resolved": "https://registry.npmjs.org/@humanfs/node/-/node-0.16.6.tgz", 1884 | "integrity": "sha512-YuI2ZHQL78Q5HbhDiBA1X4LmYdXCKCMQIfw0pw7piHJwyREFebJUvrQN4cMssyES6x+vfUbx1CIpaQUKYdQZOw==", 1885 | "dev": true, 1886 | "requires": { 1887 | "@humanfs/core": "^0.19.1", 1888 | "@humanwhocodes/retry": "^0.3.0" 1889 | }, 1890 | "dependencies": { 1891 | "@humanwhocodes/retry": { 1892 | "version": "0.3.1", 1893 | "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.3.1.tgz", 1894 | "integrity": "sha512-JBxkERygn7Bv/GbN5Rv8Ul6LVknS+5Bp6RgDC/O8gEBU/yeH5Ui5C/OlWrTb6qct7LjjfT6Re2NxB0ln0yYybA==", 1895 | "dev": true 1896 | } 1897 | } 1898 | }, 1899 | "@humanwhocodes/module-importer": { 1900 | "version": "1.0.1", 1901 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 1902 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 1903 | "dev": true 1904 | }, 1905 | "@humanwhocodes/retry": { 1906 | "version": "0.4.1", 1907 | "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.4.1.tgz", 1908 | "integrity": "sha512-c7hNEllBlenFTHBky65mhq8WD2kbN9Q6gk0bTk8lSBvc554jpXSkST1iePudpt7+A/AQvuHs9EMqjHDXMY1lrA==", 1909 | "dev": true 1910 | }, 1911 | "@nodelib/fs.scandir": { 1912 | "version": "2.1.5", 1913 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 1914 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 1915 | "dev": true, 1916 | "requires": { 1917 | "@nodelib/fs.stat": "2.0.5", 1918 | "run-parallel": "^1.1.9" 1919 | } 1920 | }, 1921 | "@nodelib/fs.stat": { 1922 | "version": "2.0.5", 1923 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 1924 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 1925 | "dev": true 1926 | }, 1927 | "@nodelib/fs.walk": { 1928 | "version": "1.2.8", 1929 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 1930 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 1931 | "dev": true, 1932 | "requires": { 1933 | "@nodelib/fs.scandir": "2.1.5", 1934 | "fastq": "^1.6.0" 1935 | } 1936 | }, 1937 | "@types/estree": { 1938 | "version": "1.0.6", 1939 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.6.tgz", 1940 | "integrity": "sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==", 1941 | "dev": true 1942 | }, 1943 | "@types/json-schema": { 1944 | "version": "7.0.15", 1945 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", 1946 | "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==", 1947 | "dev": true 1948 | }, 1949 | "@types/node": { 1950 | "version": "22.10.2", 1951 | "resolved": "https://registry.npmjs.org/@types/node/-/node-22.10.2.tgz", 1952 | "integrity": "sha512-Xxr6BBRCAOQixvonOye19wnzyDiUtTeqldOOmj3CkeblonbccA12PFwlufvRdrpjXxqnmUaeiU5EOA+7s5diUQ==", 1953 | "dev": true, 1954 | "requires": { 1955 | "undici-types": "~6.20.0" 1956 | } 1957 | }, 1958 | "@types/yargs": { 1959 | "version": "17.0.33", 1960 | "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.33.tgz", 1961 | "integrity": "sha512-WpxBCKWPLr4xSsHgz511rFJAM+wS28w2zEO1QDNY5zM/S8ok70NNfztH0xwhqKyaK0OHCbN98LDAZuy1ctxDkA==", 1962 | "dev": true, 1963 | "requires": { 1964 | "@types/yargs-parser": "*" 1965 | } 1966 | }, 1967 | "@types/yargs-parser": { 1968 | "version": "21.0.3", 1969 | "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.3.tgz", 1970 | "integrity": "sha512-I4q9QU9MQv4oEOz4tAHJtNz1cwuLxn2F3xcc2iV5WdqLPpUnj30aUuxt1mAxYTG+oe8CZMV/+6rU4S4gRDzqtQ==", 1971 | "dev": true 1972 | }, 1973 | "@typescript-eslint/eslint-plugin": { 1974 | "version": "8.18.0", 1975 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-8.18.0.tgz", 1976 | "integrity": "sha512-NR2yS7qUqCL7AIxdJUQf2MKKNDVNaig/dEB0GBLU7D+ZdHgK1NoH/3wsgO3OnPVipn51tG3MAwaODEGil70WEw==", 1977 | "dev": true, 1978 | "requires": { 1979 | "@eslint-community/regexpp": "^4.10.0", 1980 | "@typescript-eslint/scope-manager": "8.18.0", 1981 | "@typescript-eslint/type-utils": "8.18.0", 1982 | "@typescript-eslint/utils": "8.18.0", 1983 | "@typescript-eslint/visitor-keys": "8.18.0", 1984 | "graphemer": "^1.4.0", 1985 | "ignore": "^5.3.1", 1986 | "natural-compare": "^1.4.0", 1987 | "ts-api-utils": "^1.3.0" 1988 | } 1989 | }, 1990 | "@typescript-eslint/parser": { 1991 | "version": "8.18.0", 1992 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-8.18.0.tgz", 1993 | "integrity": "sha512-hgUZ3kTEpVzKaK3uNibExUYm6SKKOmTU2BOxBSvOYwtJEPdVQ70kZJpPjstlnhCHcuc2WGfSbpKlb/69ttyN5Q==", 1994 | "dev": true, 1995 | "requires": { 1996 | "@typescript-eslint/scope-manager": "8.18.0", 1997 | "@typescript-eslint/types": "8.18.0", 1998 | "@typescript-eslint/typescript-estree": "8.18.0", 1999 | "@typescript-eslint/visitor-keys": "8.18.0", 2000 | "debug": "^4.3.4" 2001 | } 2002 | }, 2003 | "@typescript-eslint/scope-manager": { 2004 | "version": "8.18.0", 2005 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-8.18.0.tgz", 2006 | "integrity": "sha512-PNGcHop0jkK2WVYGotk/hxj+UFLhXtGPiGtiaWgVBVP1jhMoMCHlTyJA+hEj4rszoSdLTK3fN4oOatrL0Cp+Xw==", 2007 | "dev": true, 2008 | "requires": { 2009 | "@typescript-eslint/types": "8.18.0", 2010 | "@typescript-eslint/visitor-keys": "8.18.0" 2011 | } 2012 | }, 2013 | "@typescript-eslint/type-utils": { 2014 | "version": "8.18.0", 2015 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-8.18.0.tgz", 2016 | "integrity": "sha512-er224jRepVAVLnMF2Q7MZJCq5CsdH2oqjP4dT7K6ij09Kyd+R21r7UVJrF0buMVdZS5QRhDzpvzAxHxabQadow==", 2017 | "dev": true, 2018 | "requires": { 2019 | "@typescript-eslint/typescript-estree": "8.18.0", 2020 | "@typescript-eslint/utils": "8.18.0", 2021 | "debug": "^4.3.4", 2022 | "ts-api-utils": "^1.3.0" 2023 | } 2024 | }, 2025 | "@typescript-eslint/types": { 2026 | "version": "8.18.0", 2027 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.18.0.tgz", 2028 | "integrity": "sha512-FNYxgyTCAnFwTrzpBGq+zrnoTO4x0c1CKYY5MuUTzpScqmY5fmsh2o3+57lqdI3NZucBDCzDgdEbIaNfAjAHQA==", 2029 | "dev": true 2030 | }, 2031 | "@typescript-eslint/typescript-estree": { 2032 | "version": "8.18.0", 2033 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-8.18.0.tgz", 2034 | "integrity": "sha512-rqQgFRu6yPkauz+ms3nQpohwejS8bvgbPyIDq13cgEDbkXt4LH4OkDMT0/fN1RUtzG8e8AKJyDBoocuQh8qNeg==", 2035 | "dev": true, 2036 | "requires": { 2037 | "@typescript-eslint/types": "8.18.0", 2038 | "@typescript-eslint/visitor-keys": "8.18.0", 2039 | "debug": "^4.3.4", 2040 | "fast-glob": "^3.3.2", 2041 | "is-glob": "^4.0.3", 2042 | "minimatch": "^9.0.4", 2043 | "semver": "^7.6.0", 2044 | "ts-api-utils": "^1.3.0" 2045 | }, 2046 | "dependencies": { 2047 | "brace-expansion": { 2048 | "version": "2.0.1", 2049 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 2050 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 2051 | "dev": true, 2052 | "requires": { 2053 | "balanced-match": "^1.0.0" 2054 | } 2055 | }, 2056 | "minimatch": { 2057 | "version": "9.0.5", 2058 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", 2059 | "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", 2060 | "dev": true, 2061 | "requires": { 2062 | "brace-expansion": "^2.0.1" 2063 | } 2064 | } 2065 | } 2066 | }, 2067 | "@typescript-eslint/utils": { 2068 | "version": "8.18.0", 2069 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-8.18.0.tgz", 2070 | "integrity": "sha512-p6GLdY383i7h5b0Qrfbix3Vc3+J2k6QWw6UMUeY5JGfm3C5LbZ4QIZzJNoNOfgyRe0uuYKjvVOsO/jD4SJO+xg==", 2071 | "dev": true, 2072 | "requires": { 2073 | "@eslint-community/eslint-utils": "^4.4.0", 2074 | "@typescript-eslint/scope-manager": "8.18.0", 2075 | "@typescript-eslint/types": "8.18.0", 2076 | "@typescript-eslint/typescript-estree": "8.18.0" 2077 | } 2078 | }, 2079 | "@typescript-eslint/visitor-keys": { 2080 | "version": "8.18.0", 2081 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-8.18.0.tgz", 2082 | "integrity": "sha512-pCh/qEA8Lb1wVIqNvBke8UaRjJ6wrAWkJO5yyIbs8Yx6TNGYyfNjOo61tLv+WwLvoLPp4BQ8B7AHKijl8NGUfw==", 2083 | "dev": true, 2084 | "requires": { 2085 | "@typescript-eslint/types": "8.18.0", 2086 | "eslint-visitor-keys": "^4.2.0" 2087 | } 2088 | }, 2089 | "acorn": { 2090 | "version": "8.14.0", 2091 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.14.0.tgz", 2092 | "integrity": "sha512-cl669nCJTZBsL97OF4kUQm5g5hC2uihk0NxY3WENAC0TYdILVkAyHymAntgxGkl7K+t0cXIrH5siy5S4XkFycA==", 2093 | "dev": true 2094 | }, 2095 | "acorn-jsx": { 2096 | "version": "5.3.2", 2097 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 2098 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 2099 | "dev": true, 2100 | "requires": {} 2101 | }, 2102 | "ajv": { 2103 | "version": "6.12.6", 2104 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 2105 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 2106 | "dev": true, 2107 | "requires": { 2108 | "fast-deep-equal": "^3.1.1", 2109 | "fast-json-stable-stringify": "^2.0.0", 2110 | "json-schema-traverse": "^0.4.1", 2111 | "uri-js": "^4.2.2" 2112 | } 2113 | }, 2114 | "ansi-regex": { 2115 | "version": "5.0.1", 2116 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2117 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==" 2118 | }, 2119 | "ansi-styles": { 2120 | "version": "4.3.0", 2121 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2122 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2123 | "requires": { 2124 | "color-convert": "^2.0.1" 2125 | } 2126 | }, 2127 | "argparse": { 2128 | "version": "2.0.1", 2129 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 2130 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 2131 | "dev": true 2132 | }, 2133 | "balanced-match": { 2134 | "version": "1.0.2", 2135 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2136 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 2137 | "dev": true 2138 | }, 2139 | "brace-expansion": { 2140 | "version": "1.1.11", 2141 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2142 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2143 | "dev": true, 2144 | "requires": { 2145 | "balanced-match": "^1.0.0", 2146 | "concat-map": "0.0.1" 2147 | } 2148 | }, 2149 | "braces": { 2150 | "version": "3.0.3", 2151 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", 2152 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", 2153 | "dev": true, 2154 | "requires": { 2155 | "fill-range": "^7.1.1" 2156 | } 2157 | }, 2158 | "callsites": { 2159 | "version": "3.1.0", 2160 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 2161 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 2162 | "dev": true 2163 | }, 2164 | "chalk": { 2165 | "version": "4.1.2", 2166 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2167 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2168 | "dev": true, 2169 | "requires": { 2170 | "ansi-styles": "^4.1.0", 2171 | "supports-color": "^7.1.0" 2172 | } 2173 | }, 2174 | "cliui": { 2175 | "version": "8.0.1", 2176 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", 2177 | "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", 2178 | "requires": { 2179 | "string-width": "^4.2.0", 2180 | "strip-ansi": "^6.0.1", 2181 | "wrap-ansi": "^7.0.0" 2182 | } 2183 | }, 2184 | "color-convert": { 2185 | "version": "2.0.1", 2186 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2187 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2188 | "requires": { 2189 | "color-name": "~1.1.4" 2190 | } 2191 | }, 2192 | "color-name": { 2193 | "version": "1.1.4", 2194 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2195 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 2196 | }, 2197 | "concat-map": { 2198 | "version": "0.0.1", 2199 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2200 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 2201 | "dev": true 2202 | }, 2203 | "cross-spawn": { 2204 | "version": "7.0.6", 2205 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz", 2206 | "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==", 2207 | "dev": true, 2208 | "requires": { 2209 | "path-key": "^3.1.0", 2210 | "shebang-command": "^2.0.0", 2211 | "which": "^2.0.1" 2212 | } 2213 | }, 2214 | "debug": { 2215 | "version": "4.4.0", 2216 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", 2217 | "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", 2218 | "dev": true, 2219 | "requires": { 2220 | "ms": "^2.1.3" 2221 | } 2222 | }, 2223 | "deep-is": { 2224 | "version": "0.1.4", 2225 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 2226 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 2227 | "dev": true 2228 | }, 2229 | "emoji-regex": { 2230 | "version": "8.0.0", 2231 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2232 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 2233 | }, 2234 | "escalade": { 2235 | "version": "3.2.0", 2236 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", 2237 | "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==" 2238 | }, 2239 | "escape-string-regexp": { 2240 | "version": "4.0.0", 2241 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2242 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2243 | "dev": true 2244 | }, 2245 | "eslint": { 2246 | "version": "9.17.0", 2247 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.17.0.tgz", 2248 | "integrity": "sha512-evtlNcpJg+cZLcnVKwsai8fExnqjGPicK7gnUtlNuzu+Fv9bI0aLpND5T44VLQtoMEnI57LoXO9XAkIXwohKrA==", 2249 | "dev": true, 2250 | "requires": { 2251 | "@eslint-community/eslint-utils": "^4.2.0", 2252 | "@eslint-community/regexpp": "^4.12.1", 2253 | "@eslint/config-array": "^0.19.0", 2254 | "@eslint/core": "^0.9.0", 2255 | "@eslint/eslintrc": "^3.2.0", 2256 | "@eslint/js": "9.17.0", 2257 | "@eslint/plugin-kit": "^0.2.3", 2258 | "@humanfs/node": "^0.16.6", 2259 | "@humanwhocodes/module-importer": "^1.0.1", 2260 | "@humanwhocodes/retry": "^0.4.1", 2261 | "@types/estree": "^1.0.6", 2262 | "@types/json-schema": "^7.0.15", 2263 | "ajv": "^6.12.4", 2264 | "chalk": "^4.0.0", 2265 | "cross-spawn": "^7.0.6", 2266 | "debug": "^4.3.2", 2267 | "escape-string-regexp": "^4.0.0", 2268 | "eslint-scope": "^8.2.0", 2269 | "eslint-visitor-keys": "^4.2.0", 2270 | "espree": "^10.3.0", 2271 | "esquery": "^1.5.0", 2272 | "esutils": "^2.0.2", 2273 | "fast-deep-equal": "^3.1.3", 2274 | "file-entry-cache": "^8.0.0", 2275 | "find-up": "^5.0.0", 2276 | "glob-parent": "^6.0.2", 2277 | "ignore": "^5.2.0", 2278 | "imurmurhash": "^0.1.4", 2279 | "is-glob": "^4.0.0", 2280 | "json-stable-stringify-without-jsonify": "^1.0.1", 2281 | "lodash.merge": "^4.6.2", 2282 | "minimatch": "^3.1.2", 2283 | "natural-compare": "^1.4.0", 2284 | "optionator": "^0.9.3" 2285 | } 2286 | }, 2287 | "eslint-scope": { 2288 | "version": "8.2.0", 2289 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-8.2.0.tgz", 2290 | "integrity": "sha512-PHlWUfG6lvPc3yvP5A4PNyBL1W8fkDUccmI21JUu/+GKZBoH/W5u6usENXUrWFRsyoW5ACUjFGgAFQp5gUlb/A==", 2291 | "dev": true, 2292 | "requires": { 2293 | "esrecurse": "^4.3.0", 2294 | "estraverse": "^5.2.0" 2295 | } 2296 | }, 2297 | "eslint-visitor-keys": { 2298 | "version": "4.2.0", 2299 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.0.tgz", 2300 | "integrity": "sha512-UyLnSehNt62FFhSwjZlHmeokpRK59rcz29j+F1/aDgbkbRTk7wIc9XzdoasMUbRNKDM0qQt/+BJ4BrpFeABemw==", 2301 | "dev": true 2302 | }, 2303 | "espree": { 2304 | "version": "10.3.0", 2305 | "resolved": "https://registry.npmjs.org/espree/-/espree-10.3.0.tgz", 2306 | "integrity": "sha512-0QYC8b24HWY8zjRnDTL6RiHfDbAWn63qb4LMj1Z4b076A4une81+z03Kg7l7mn/48PUTqoLptSXez8oknU8Clg==", 2307 | "dev": true, 2308 | "requires": { 2309 | "acorn": "^8.14.0", 2310 | "acorn-jsx": "^5.3.2", 2311 | "eslint-visitor-keys": "^4.2.0" 2312 | } 2313 | }, 2314 | "esquery": { 2315 | "version": "1.6.0", 2316 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.6.0.tgz", 2317 | "integrity": "sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg==", 2318 | "dev": true, 2319 | "requires": { 2320 | "estraverse": "^5.1.0" 2321 | } 2322 | }, 2323 | "esrecurse": { 2324 | "version": "4.3.0", 2325 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2326 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2327 | "dev": true, 2328 | "requires": { 2329 | "estraverse": "^5.2.0" 2330 | } 2331 | }, 2332 | "estraverse": { 2333 | "version": "5.3.0", 2334 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 2335 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 2336 | "dev": true 2337 | }, 2338 | "esutils": { 2339 | "version": "2.0.3", 2340 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2341 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2342 | "dev": true 2343 | }, 2344 | "fast-deep-equal": { 2345 | "version": "3.1.3", 2346 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2347 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2348 | "dev": true 2349 | }, 2350 | "fast-glob": { 2351 | "version": "3.3.2", 2352 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", 2353 | "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", 2354 | "dev": true, 2355 | "requires": { 2356 | "@nodelib/fs.stat": "^2.0.2", 2357 | "@nodelib/fs.walk": "^1.2.3", 2358 | "glob-parent": "^5.1.2", 2359 | "merge2": "^1.3.0", 2360 | "micromatch": "^4.0.4" 2361 | }, 2362 | "dependencies": { 2363 | "glob-parent": { 2364 | "version": "5.1.2", 2365 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2366 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2367 | "dev": true, 2368 | "requires": { 2369 | "is-glob": "^4.0.1" 2370 | } 2371 | } 2372 | } 2373 | }, 2374 | "fast-json-stable-stringify": { 2375 | "version": "2.1.0", 2376 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 2377 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 2378 | "dev": true 2379 | }, 2380 | "fast-levenshtein": { 2381 | "version": "2.0.6", 2382 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2383 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 2384 | "dev": true 2385 | }, 2386 | "fastq": { 2387 | "version": "1.17.1", 2388 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", 2389 | "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", 2390 | "dev": true, 2391 | "requires": { 2392 | "reusify": "^1.0.4" 2393 | } 2394 | }, 2395 | "file-entry-cache": { 2396 | "version": "8.0.0", 2397 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-8.0.0.tgz", 2398 | "integrity": "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==", 2399 | "dev": true, 2400 | "requires": { 2401 | "flat-cache": "^4.0.0" 2402 | } 2403 | }, 2404 | "fill-range": { 2405 | "version": "7.1.1", 2406 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", 2407 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", 2408 | "dev": true, 2409 | "requires": { 2410 | "to-regex-range": "^5.0.1" 2411 | } 2412 | }, 2413 | "find-up": { 2414 | "version": "5.0.0", 2415 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2416 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2417 | "dev": true, 2418 | "requires": { 2419 | "locate-path": "^6.0.0", 2420 | "path-exists": "^4.0.0" 2421 | } 2422 | }, 2423 | "flat-cache": { 2424 | "version": "4.0.1", 2425 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-4.0.1.tgz", 2426 | "integrity": "sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw==", 2427 | "dev": true, 2428 | "requires": { 2429 | "flatted": "^3.2.9", 2430 | "keyv": "^4.5.4" 2431 | } 2432 | }, 2433 | "flatted": { 2434 | "version": "3.3.2", 2435 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.2.tgz", 2436 | "integrity": "sha512-AiwGJM8YcNOaobumgtng+6NHuOqC3A7MixFeDafM3X9cIUM+xUXoS5Vfgf+OihAYe20fxqNM9yPBXJzRtZ/4eA==", 2437 | "dev": true 2438 | }, 2439 | "get-caller-file": { 2440 | "version": "2.0.5", 2441 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 2442 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==" 2443 | }, 2444 | "glob-parent": { 2445 | "version": "6.0.2", 2446 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 2447 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 2448 | "dev": true, 2449 | "requires": { 2450 | "is-glob": "^4.0.3" 2451 | } 2452 | }, 2453 | "globals": { 2454 | "version": "15.13.0", 2455 | "resolved": "https://registry.npmjs.org/globals/-/globals-15.13.0.tgz", 2456 | "integrity": "sha512-49TewVEz0UxZjr1WYYsWpPrhyC/B/pA8Bq0fUmet2n+eR7yn0IvNzNaoBwnK6mdkzcN+se7Ez9zUgULTz2QH4g==", 2457 | "dev": true 2458 | }, 2459 | "graphemer": { 2460 | "version": "1.4.0", 2461 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 2462 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 2463 | "dev": true 2464 | }, 2465 | "has-flag": { 2466 | "version": "4.0.0", 2467 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2468 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2469 | "dev": true 2470 | }, 2471 | "ignore": { 2472 | "version": "5.3.2", 2473 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz", 2474 | "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==", 2475 | "dev": true 2476 | }, 2477 | "import-fresh": { 2478 | "version": "3.3.0", 2479 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2480 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2481 | "dev": true, 2482 | "requires": { 2483 | "parent-module": "^1.0.0", 2484 | "resolve-from": "^4.0.0" 2485 | } 2486 | }, 2487 | "imurmurhash": { 2488 | "version": "0.1.4", 2489 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2490 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 2491 | "dev": true 2492 | }, 2493 | "is-extglob": { 2494 | "version": "2.1.1", 2495 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2496 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2497 | "dev": true 2498 | }, 2499 | "is-fullwidth-code-point": { 2500 | "version": "3.0.0", 2501 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2502 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" 2503 | }, 2504 | "is-glob": { 2505 | "version": "4.0.3", 2506 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2507 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2508 | "dev": true, 2509 | "requires": { 2510 | "is-extglob": "^2.1.1" 2511 | } 2512 | }, 2513 | "is-number": { 2514 | "version": "7.0.0", 2515 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2516 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2517 | "dev": true 2518 | }, 2519 | "isexe": { 2520 | "version": "2.0.0", 2521 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2522 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2523 | "dev": true 2524 | }, 2525 | "js-yaml": { 2526 | "version": "4.1.0", 2527 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2528 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2529 | "dev": true, 2530 | "requires": { 2531 | "argparse": "^2.0.1" 2532 | } 2533 | }, 2534 | "json-buffer": { 2535 | "version": "3.0.1", 2536 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 2537 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 2538 | "dev": true 2539 | }, 2540 | "json-schema-traverse": { 2541 | "version": "0.4.1", 2542 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2543 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2544 | "dev": true 2545 | }, 2546 | "json-stable-stringify-without-jsonify": { 2547 | "version": "1.0.1", 2548 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2549 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 2550 | "dev": true 2551 | }, 2552 | "keyv": { 2553 | "version": "4.5.4", 2554 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 2555 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 2556 | "dev": true, 2557 | "requires": { 2558 | "json-buffer": "3.0.1" 2559 | } 2560 | }, 2561 | "levn": { 2562 | "version": "0.4.1", 2563 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2564 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2565 | "dev": true, 2566 | "requires": { 2567 | "prelude-ls": "^1.2.1", 2568 | "type-check": "~0.4.0" 2569 | } 2570 | }, 2571 | "locate-path": { 2572 | "version": "6.0.0", 2573 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2574 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2575 | "dev": true, 2576 | "requires": { 2577 | "p-locate": "^5.0.0" 2578 | } 2579 | }, 2580 | "lodash.merge": { 2581 | "version": "4.6.2", 2582 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2583 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2584 | "dev": true 2585 | }, 2586 | "merge2": { 2587 | "version": "1.4.1", 2588 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 2589 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 2590 | "dev": true 2591 | }, 2592 | "micromatch": { 2593 | "version": "4.0.8", 2594 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.8.tgz", 2595 | "integrity": "sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==", 2596 | "dev": true, 2597 | "requires": { 2598 | "braces": "^3.0.3", 2599 | "picomatch": "^2.3.1" 2600 | } 2601 | }, 2602 | "minimatch": { 2603 | "version": "3.1.2", 2604 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2605 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2606 | "dev": true, 2607 | "requires": { 2608 | "brace-expansion": "^1.1.7" 2609 | } 2610 | }, 2611 | "ms": { 2612 | "version": "2.1.3", 2613 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2614 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 2615 | "dev": true 2616 | }, 2617 | "natural-compare": { 2618 | "version": "1.4.0", 2619 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2620 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2621 | "dev": true 2622 | }, 2623 | "optionator": { 2624 | "version": "0.9.4", 2625 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz", 2626 | "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==", 2627 | "dev": true, 2628 | "requires": { 2629 | "deep-is": "^0.1.3", 2630 | "fast-levenshtein": "^2.0.6", 2631 | "levn": "^0.4.1", 2632 | "prelude-ls": "^1.2.1", 2633 | "type-check": "^0.4.0", 2634 | "word-wrap": "^1.2.5" 2635 | } 2636 | }, 2637 | "p-limit": { 2638 | "version": "3.1.0", 2639 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2640 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2641 | "dev": true, 2642 | "requires": { 2643 | "yocto-queue": "^0.1.0" 2644 | } 2645 | }, 2646 | "p-locate": { 2647 | "version": "5.0.0", 2648 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2649 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2650 | "dev": true, 2651 | "requires": { 2652 | "p-limit": "^3.0.2" 2653 | } 2654 | }, 2655 | "parent-module": { 2656 | "version": "1.0.1", 2657 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2658 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2659 | "dev": true, 2660 | "requires": { 2661 | "callsites": "^3.0.0" 2662 | } 2663 | }, 2664 | "path-exists": { 2665 | "version": "4.0.0", 2666 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2667 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2668 | "dev": true 2669 | }, 2670 | "path-key": { 2671 | "version": "3.1.1", 2672 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2673 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2674 | "dev": true 2675 | }, 2676 | "picomatch": { 2677 | "version": "2.3.1", 2678 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2679 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2680 | "dev": true 2681 | }, 2682 | "prelude-ls": { 2683 | "version": "1.2.1", 2684 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2685 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2686 | "dev": true 2687 | }, 2688 | "prettier": { 2689 | "version": "3.4.2", 2690 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.4.2.tgz", 2691 | "integrity": "sha512-e9MewbtFo+Fevyuxn/4rrcDAaq0IYxPGLvObpQjiZBMAzB9IGmzlnG9RZy3FFas+eBMu2vA0CszMeduow5dIuQ==", 2692 | "dev": true 2693 | }, 2694 | "punycode": { 2695 | "version": "2.3.1", 2696 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 2697 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 2698 | "dev": true 2699 | }, 2700 | "queue-microtask": { 2701 | "version": "1.2.3", 2702 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2703 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2704 | "dev": true 2705 | }, 2706 | "require-directory": { 2707 | "version": "2.1.1", 2708 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2709 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==" 2710 | }, 2711 | "resolve-from": { 2712 | "version": "4.0.0", 2713 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2714 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2715 | "dev": true 2716 | }, 2717 | "reusify": { 2718 | "version": "1.0.4", 2719 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2720 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2721 | "dev": true 2722 | }, 2723 | "run-parallel": { 2724 | "version": "1.2.0", 2725 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2726 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2727 | "dev": true, 2728 | "requires": { 2729 | "queue-microtask": "^1.2.2" 2730 | } 2731 | }, 2732 | "semver": { 2733 | "version": "7.6.3", 2734 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 2735 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 2736 | "dev": true 2737 | }, 2738 | "shebang-command": { 2739 | "version": "2.0.0", 2740 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2741 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2742 | "dev": true, 2743 | "requires": { 2744 | "shebang-regex": "^3.0.0" 2745 | } 2746 | }, 2747 | "shebang-regex": { 2748 | "version": "3.0.0", 2749 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2750 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2751 | "dev": true 2752 | }, 2753 | "string-width": { 2754 | "version": "4.2.3", 2755 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2756 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2757 | "requires": { 2758 | "emoji-regex": "^8.0.0", 2759 | "is-fullwidth-code-point": "^3.0.0", 2760 | "strip-ansi": "^6.0.1" 2761 | } 2762 | }, 2763 | "strip-ansi": { 2764 | "version": "6.0.1", 2765 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2766 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2767 | "requires": { 2768 | "ansi-regex": "^5.0.1" 2769 | } 2770 | }, 2771 | "strip-json-comments": { 2772 | "version": "3.1.1", 2773 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2774 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2775 | "dev": true 2776 | }, 2777 | "supports-color": { 2778 | "version": "7.2.0", 2779 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2780 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2781 | "dev": true, 2782 | "requires": { 2783 | "has-flag": "^4.0.0" 2784 | } 2785 | }, 2786 | "to-regex-range": { 2787 | "version": "5.0.1", 2788 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2789 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2790 | "dev": true, 2791 | "requires": { 2792 | "is-number": "^7.0.0" 2793 | } 2794 | }, 2795 | "ts-api-utils": { 2796 | "version": "1.4.3", 2797 | "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.4.3.tgz", 2798 | "integrity": "sha512-i3eMG77UTMD0hZhgRS562pv83RC6ukSAC2GMNWc+9dieh/+jDM5u5YG+NHX6VNDRHQcHwmsTHctP9LhbC3WxVw==", 2799 | "dev": true, 2800 | "requires": {} 2801 | }, 2802 | "type-check": { 2803 | "version": "0.4.0", 2804 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2805 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2806 | "dev": true, 2807 | "requires": { 2808 | "prelude-ls": "^1.2.1" 2809 | } 2810 | }, 2811 | "typescript": { 2812 | "version": "5.7.2", 2813 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.7.2.tgz", 2814 | "integrity": "sha512-i5t66RHxDvVN40HfDd1PsEThGNnlMCMT3jMUuoh9/0TaqWevNontacunWyN02LA9/fIbEWlcHZcgTKb9QoaLfg==", 2815 | "dev": true 2816 | }, 2817 | "typescript-eslint": { 2818 | "version": "8.18.0", 2819 | "resolved": "https://registry.npmjs.org/typescript-eslint/-/typescript-eslint-8.18.0.tgz", 2820 | "integrity": "sha512-Xq2rRjn6tzVpAyHr3+nmSg1/9k9aIHnJ2iZeOH7cfGOWqTkXTm3kwpQglEuLGdNrYvPF+2gtAs+/KF5rjVo+WQ==", 2821 | "dev": true, 2822 | "requires": { 2823 | "@typescript-eslint/eslint-plugin": "8.18.0", 2824 | "@typescript-eslint/parser": "8.18.0", 2825 | "@typescript-eslint/utils": "8.18.0" 2826 | } 2827 | }, 2828 | "undici-types": { 2829 | "version": "6.20.0", 2830 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-6.20.0.tgz", 2831 | "integrity": "sha512-Ny6QZ2Nju20vw1SRHe3d9jVu6gJ+4e3+MMpqu7pqE5HT6WsTSlce++GQmK5UXS8mzV8DSYHrQH+Xrf2jVcuKNg==", 2832 | "dev": true 2833 | }, 2834 | "uri-js": { 2835 | "version": "4.4.1", 2836 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 2837 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 2838 | "dev": true, 2839 | "requires": { 2840 | "punycode": "^2.1.0" 2841 | } 2842 | }, 2843 | "which": { 2844 | "version": "2.0.2", 2845 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2846 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2847 | "dev": true, 2848 | "requires": { 2849 | "isexe": "^2.0.0" 2850 | } 2851 | }, 2852 | "word-wrap": { 2853 | "version": "1.2.5", 2854 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", 2855 | "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", 2856 | "dev": true 2857 | }, 2858 | "wrap-ansi": { 2859 | "version": "7.0.0", 2860 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2861 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2862 | "requires": { 2863 | "ansi-styles": "^4.0.0", 2864 | "string-width": "^4.1.0", 2865 | "strip-ansi": "^6.0.0" 2866 | } 2867 | }, 2868 | "y18n": { 2869 | "version": "5.0.8", 2870 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 2871 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==" 2872 | }, 2873 | "yargs": { 2874 | "version": "17.7.2", 2875 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", 2876 | "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", 2877 | "requires": { 2878 | "cliui": "^8.0.1", 2879 | "escalade": "^3.1.1", 2880 | "get-caller-file": "^2.0.5", 2881 | "require-directory": "^2.1.1", 2882 | "string-width": "^4.2.3", 2883 | "y18n": "^5.0.5", 2884 | "yargs-parser": "^21.1.1" 2885 | } 2886 | }, 2887 | "yargs-parser": { 2888 | "version": "21.1.1", 2889 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", 2890 | "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==" 2891 | }, 2892 | "yocto-queue": { 2893 | "version": "0.1.0", 2894 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 2895 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 2896 | "dev": true 2897 | } 2898 | } 2899 | } 2900 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "pseudo-localization", 3 | "version": "3.1.1", 4 | "description": "pseudo-localization for internationalization testing", 5 | "files": [ 6 | "dist", 7 | "src" 8 | ], 9 | "type": "module", 10 | "sideEffects": false, 11 | "exports": { 12 | ".": { 13 | "types": "./dist/localize.d.ts", 14 | "import": "./dist/localize.js" 15 | }, 16 | "./dom": { 17 | "types": "./dist/dom.d.ts", 18 | "import": "./dist/dom.js" 19 | } 20 | }, 21 | "bin": { 22 | "pseudo-localization": "./dist/bin/pseudo-localize.js" 23 | }, 24 | "engines": { 25 | "node": "^23" 26 | }, 27 | "scripts": { 28 | "build": "tsc -p tsconfig.lib.json", 29 | "check-formatting": "prettier --list-different src/**/*.ts", 30 | "format": "prettier --write src/**/*.ts", 31 | "lint": "eslint src/**/*.ts", 32 | "start": "node devserver.mjs", 33 | "test-js": "node --experimental-strip-types --disable-warning=ExperimentalWarning --test './src/**/*.test.ts'", 34 | "test": "npm run test-js && npm run check-formatting && npm run typecheck && npm run lint", 35 | "typecheck": "tsc -p tsconfig.lib.json --noEmit" 36 | }, 37 | "author": "Tryggvi Gylfason (http://twitter.com/tryggvigy)", 38 | "keywords": [ 39 | "internationalization", 40 | "localization", 41 | "pseudo-localization", 42 | "l10n", 43 | "i18n", 44 | "pseudo", 45 | "language", 46 | "translation", 47 | "pseudo-localize" 48 | ], 49 | "repository": { 50 | "type": "git", 51 | "url": "git+https://github.com/tryggvigy/pseudo-localization.git" 52 | }, 53 | "license": "MIT", 54 | "devDependencies": { 55 | "@eslint/js": "^9.17.0", 56 | "@types/node": "^22.10.2", 57 | "eslint": "^9.17.0", 58 | "globals": "^15.13.0", 59 | "prettier": "^3.4.2", 60 | "typescript": "^5.7.2", 61 | "typescript-eslint": "^8.18.0" 62 | } 63 | } 64 | -------------------------------------------------------------------------------- /src/bin/pseudo-localize.ts: -------------------------------------------------------------------------------- 1 | #! /usr/bin/env node 2 | 3 | import { pseudoLocalizeString, type Strategy } from '../localize.ts'; 4 | 5 | type Args = { 6 | string: string; 7 | strategy: 'accented' | 'bidi'; 8 | }; 9 | 10 | function isStrategy(str: string): str is Strategy { 11 | return ['accented', 'bidi'].includes(str); 12 | } 13 | 14 | function parseArgs(argv: string[]): Args { 15 | const options: Args = { 16 | string: '', 17 | strategy: 'accented', // Default strategy 18 | }; 19 | 20 | const args = argv.slice(2); // Skip node and script name 21 | let i = 0; 22 | 23 | while (i < args.length) { 24 | const arg = args[i]; 25 | 26 | if (arg === '--strategy' || arg === '-s') { 27 | // Handle the `--strategy` or `-s` flag 28 | const value = args[i + 1]; 29 | if (!isStrategy(value)) { 30 | throw new Error( 31 | `Invalid value for --strategy. Choose 'accented' or 'bidi'.` 32 | ); 33 | } 34 | options.strategy = value; 35 | i += 2; // Skip the flag and its value 36 | } else if (!arg.startsWith('--') && !arg.startsWith('-')) { 37 | // Assume it's the positional `string` argument 38 | if (!options.string) { 39 | options.string = arg; 40 | } else { 41 | throw new Error('Unexpected additional argument: ' + arg); 42 | } 43 | i += 1; 44 | } else { 45 | throw new Error(`Unknown argument: ${arg}`); 46 | } 47 | } 48 | 49 | if (!options.string) { 50 | throw new Error('The argument is required.'); 51 | } 52 | 53 | return options; 54 | } 55 | 56 | function displayHelp() { 57 | console.log(` 58 | Usage: