├── .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 | |  |  |
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 | 
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 | 
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: