├── .python-version ├── dependencies.json ├── .gitattributes ├── chokidar ├── package.json ├── tsconfig.json ├── chokidar-cli │ ├── README.md │ ├── types.d.ts │ ├── LICENSE │ └── index.js ├── .eslintrc.js └── package-lock.json ├── LICENSE ├── README.md └── watcher.py /.python-version: -------------------------------------------------------------------------------- 1 | 3.8 2 | -------------------------------------------------------------------------------- /dependencies.json: -------------------------------------------------------------------------------- 1 | { 2 | "*": { 3 | "*": [ 4 | "lsp_utils", 5 | "sublime_lib" 6 | ] 7 | } 8 | } 9 | -------------------------------------------------------------------------------- /.gitattributes: -------------------------------------------------------------------------------- 1 | .github/ export-ignore 2 | .gitignore export-ignore 3 | pyrightconfig.json export-ignore 4 | renovate.json export-ignore 5 | tox.ini export-ignore 6 | -------------------------------------------------------------------------------- /chokidar/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "chokidar-bundle", 3 | "private": true, 4 | "scripts": { 5 | "lint": "eslint ." 6 | }, 7 | "dependencies": { 8 | "chokidar": "3.6.0", 9 | "lodash.debounce": "4.0.8", 10 | "lodash.throttle": "4.1.1" 11 | }, 12 | "devDependencies": { 13 | "@types/lodash.debounce": "4.0.9", 14 | "@types/lodash.throttle": "4.1.9", 15 | "@types/node": "24.10.1", 16 | "eslint": "8.57.1", 17 | "typescript": "5.9.3" 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /chokidar/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "esnext", 4 | "module": "commonjs", 5 | "esModuleInterop": true, 6 | "moduleResolution": "node", 7 | "noEmit": true, 8 | "allowJs": true, 9 | "checkJs": true, 10 | "allowSyntheticDefaultImports": true, 11 | "strict": true, 12 | "resolveJsonModule": true, 13 | "lib": [ 14 | "dom", 15 | "esnext", 16 | ], 17 | }, 18 | } 19 | -------------------------------------------------------------------------------- /chokidar/chokidar-cli/README.md: -------------------------------------------------------------------------------- 1 | # Chokidar CLI 2 | 3 | Fast cross-platform command line utility to watch file system changes based on https://github.com/open-cli-tools/chokidar-cli, rewritten to be controlled through `stdin` rather than a command line arguments and with some changes to cater for its intended use in a LSP file watcher. 4 | 5 | The underlying watch library is [Chokidar](https://github.com/paulmillr/chokidar). 6 | 7 | ## Prerequisites 8 | 9 | - Node.js v8.10.0 or newer 10 | 11 | ## License 12 | 13 | MIT 14 | -------------------------------------------------------------------------------- /chokidar/chokidar-cli/types.d.ts: -------------------------------------------------------------------------------- 1 | declare namespace ChokidarCli { 2 | type ChokidarEventType = 'add' | 'addDir' | 'change' | 'unlink' | 'unlinkDir' 3 | 4 | type InputCommand = { 5 | register?: RegisterWatcherOptions 6 | unregister?: RegisterWatcherOptions['uid'] 7 | } 8 | type LspEventType = 'create' | 'change' | 'delete' 9 | 10 | type RegisterWatcherOptions = { 11 | cwd: string 12 | debounceChanges: number 13 | debug: boolean 14 | events: LspEventType[] 15 | followSymlinks: boolean 16 | ignores: string[] | null 17 | initial: boolean 18 | patterns: string[] 19 | polling: boolean 20 | pollInterval: number 21 | pollIntervalBinary: number 22 | uid: number 23 | } 24 | } 25 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2021 SublimeLSP 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 | -------------------------------------------------------------------------------- /chokidar/chokidar-cli/LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2021 Rafal Chlodnicki 4 | Copyright (c) 2015 Kimmo Brunfeldt 5 | 6 | Permission is hereby granted, free of charge, to any person obtaining a copy 7 | of this software and associated documentation files (the "Software"), to deal 8 | in the Software without restriction, including without limitation the rights 9 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 10 | copies of the Software, and to permit persons to whom the Software is 11 | furnished to do so, subject to the following conditions: 12 | 13 | The above copyright notice and this permission notice shall be included in all 14 | copies or substantial portions of the Software. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 17 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 19 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 20 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 21 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 22 | SOFTWARE. 23 | -------------------------------------------------------------------------------- /chokidar/.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { 3 | commonjs: true, 4 | es2020: true, 5 | node: true, 6 | }, 7 | extends: 'eslint:recommended', 8 | parserOptions: { 9 | sourceType: 'module', 10 | }, 11 | rules: { 12 | 'array-bracket-spacing': 'error', 13 | 'brace-style': 'error', 14 | 'comma-dangle': ['error', 'always-multiline'], 15 | 'comma-spacing': 'error', 16 | 'computed-property-spacing': 'error', 17 | curly: 'error', 18 | 'dot-notation': 'error', 19 | 'eol-last': 'error', 20 | eqeqeq: 'error', 21 | 'func-call-spacing': 'error', 22 | indent: [ 23 | 'error', 4, { 24 | SwitchCase: 1, 25 | }, 26 | ], 27 | 'keyword-spacing': 'error', 28 | 'linebreak-style': 'error', 29 | 'no-constructor-return': 'error', 30 | 'no-multi-spaces': ['error', { ignoreEOLComments: true }], 31 | 'no-multiple-empty-lines': ['error', { max: 1 }], 32 | 'no-tabs': 'error', 33 | 'no-template-curly-in-string': 'error', 34 | 'no-trailing-spaces': 'error', 35 | 'no-var': 'error', 36 | 'no-whitespace-before-property': 'error', 37 | 'object-curly-spacing': ['error', 'always'], 38 | 'one-var-declaration-per-line': ['error', 'always'], 39 | 'prefer-const': 'error', 40 | 'quote-props': ['error', 'as-needed'], 41 | quotes: ['error', 'single'], 42 | 'padded-blocks': ['error', 'never'], 43 | semi: ['error', 'always'], 44 | 'space-before-blocks': 'error', 45 | 'space-before-function-paren': ['error', 'never'], 46 | 'space-in-parens': 'error', 47 | 'space-infix-ops': 'error', 48 | }, 49 | }; 50 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # LSP-file-watcher-chokidar 2 | 3 | A non-native file watcher implementation for [LSP](https://packagecontrol.io/packages/LSP) that enables support for the `workspace/didChangeWatchedFiles` LSP notification. 4 | 5 | ## Installation 6 | 7 | * Install `LSP-file-watcher-chokidar` from Package Control 8 | * Restart Sublime. 9 | 10 | ## Usage 11 | 12 | Having this package installed alongside LSP enables the `workspace.didChangeWatchedFiles` capability and support for the `workspace/didChangeWatchedFiles` notification. The servers can also dynamically register file watchers. 13 | 14 | For `LSP-*` packages that are within the `sublimelsp` organization it should be enough to just install this package and file watching should work without any extra configuration. 15 | 16 | In other cases, it might "just work" (if the server registers watchers dynamically) or it might require manual configuration using the the `file_watcher` object on the [Client configuration](https://lsp.sublimetext.io/guides/client_configuration/) object. 17 | 18 | `file_watcher` object properties: 19 | 20 | | Name | Optional | Description | 21 | |:---------|:---------|:------------| 22 | | patterns | No | An array of `glob` patterns defining which files within the workspace should be watched. The patterns are relative to the workspace root. Example: `["{**/*.js,**/*.ts,**/*.json}"]`. See also [supported pattern syntax](https://microsoft.github.io/language-server-protocol/specifications/specification-3-17/#fileSystemWatcher). | 23 | | events | Yes | An array with the type of events to watch. Default: `["create", "change", "delete"]` (all supported types). | 24 | | ignores | Yes | An array of `glob` exclude patterns. By default this includes patterns from Sublime Text's `folder_exclude_patterns` and `file_exclude_patterns` settings and additionally the `'**/node_modules/**'` pattern. When overriding this option the defaults are not included anymore. | 25 | 26 | ## Implementation 27 | 28 | Registering a watcher creates a new Node process behind the scenes. The current implementation creates at most one process for any number of registrations (even through different language servers). 29 | 30 | The reason that this is implemented as a separate package, and not natively within the LSP package, is that this relies on a separate process that does the file watching and for the built-in implementation we would like to use a native API provided by Sublime Text that it [doesn't provide](https://github.com/sublimehq/sublime_text/issues/2669) at the moment. See the [LSP issue #892](https://github.com/sublimelsp/LSP/issues/892) for supporting it natively within the LSP package. 31 | -------------------------------------------------------------------------------- /chokidar/chokidar-cli/index.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | const { resolve } = require('path'); 4 | const readline = require('readline'); 5 | const debounce = require('lodash.debounce'); 6 | const chokidar = require('chokidar'); 7 | 8 | /** @type {Record} */ 9 | const CHOKIDAR_EVENT_TYPE_TO_LSP = { 10 | add: 'create', 11 | addDir: 'create', 12 | change: 'change', 13 | unlink: 'delete', 14 | unlinkDir: 'delete', 15 | }; 16 | 17 | /** @type {Partial} */ 18 | const defaultOpts = { 19 | debounceChanges: 400, 20 | debug: false, 21 | events: [], 22 | followSymlinks: false, 23 | ignores: null, 24 | initial: false, 25 | polling: false, 26 | pollInterval: 100, 27 | pollIntervalBinary: 300, 28 | }; 29 | 30 | /** @type {Map} */ 31 | const watchers = new Map(); 32 | /** @type {import('readline').ReadLine | null} */ 33 | let rl = null; 34 | 35 | function main() { 36 | rl = readline.createInterface({ 37 | input: process.stdin, 38 | output: process.stdout, 39 | }); 40 | 41 | rl.on('line', handleInput); 42 | } 43 | 44 | /** @param {string} line */ 45 | function handleInput(line) { 46 | if (!line) { 47 | if (rl) { 48 | console.error('Closing readline interface due to empty input.'); 49 | rl.close(); 50 | rl = null; 51 | } 52 | return; 53 | } 54 | 55 | /** @type {ChokidarCli.InputCommand} */ 56 | let data; 57 | 58 | try { 59 | data = JSON.parse(line); 60 | } catch (error) { 61 | console.error(`Failed parsing input: "${line}"`); 62 | return; 63 | } 64 | 65 | if (!data.register && !data.unregister) { 66 | console.error('Input data must contain either "register" or "unregister" property.'); 67 | return; 68 | } 69 | 70 | if (data.unregister) { 71 | const watcher = watchers.get(data.unregister); 72 | if (watcher) { 73 | watcher.close(); 74 | watchers.delete(data.unregister); 75 | } else { 76 | console.error(`Unregistering watcher with ID "${data.unregister}" failed. No watcher registered.`); 77 | } 78 | } 79 | 80 | if (data.register) { 81 | const userOpts = data.register; 82 | const opts = Object.assign({}, defaultOpts, userOpts); 83 | if (!opts.uid || !opts.cwd) { 84 | console.error('Failed registering watcher. Missing "uid" or "cwd".'); 85 | return; 86 | } 87 | registerWatcher(opts); 88 | } 89 | } 90 | 91 | /** @param {ChokidarCli.RegisterWatcherOptions} opts */ 92 | function registerWatcher(opts) { 93 | const chokidarOpts = createChokidarOpts(opts); 94 | const watcher = chokidar.watch(opts.patterns, chokidarOpts); 95 | if (watchers.has(opts.uid)) { 96 | console.error(`Failed registering watcher. Watcher with ID "${opts.uid}" already exists.`); 97 | return; 98 | } 99 | watchers.set(opts.uid, watcher); 100 | 101 | const debouncedChangesRun = debounce(reportDebouncedChanges, opts.debounceChanges); 102 | /** @type {string[]} */ 103 | let debouncedChangesQueue = []; 104 | 105 | function reportDebouncedChanges() { 106 | if (debouncedChangesQueue.length) { 107 | console.log(debouncedChangesQueue.join('\n')); 108 | console.log(''); 109 | debouncedChangesQueue = []; 110 | } 111 | } 112 | 113 | watcher.on('all', (event, path) => { 114 | const lspEvent = CHOKIDAR_EVENT_TYPE_TO_LSP[event]; 115 | 116 | if (!lspEvent) { 117 | if (opts.debug) { 118 | console.error(`Unsupported event type "${event}".`); 119 | } 120 | return; 121 | } 122 | 123 | if (!opts.events.includes(lspEvent)) { 124 | return; 125 | } 126 | 127 | const eventString = `${opts.uid}:${lspEvent}:${path}`; 128 | 129 | if (opts.debounceChanges > 0) { 130 | debouncedChangesQueue.push(eventString); 131 | debouncedChangesRun(); 132 | } else { 133 | console.log(eventString); 134 | console.log(''); 135 | } 136 | }); 137 | 138 | watcher.on('error', error => { 139 | console.error('Error:', error); 140 | console.error(error.stack); 141 | }); 142 | 143 | watcher.once('ready', () => { 144 | const list = opts.patterns.map(pattern => resolve(pattern)).join('", "'); 145 | if (opts.debug) { 146 | console.error('Watching', `"${list}" ..`); 147 | } 148 | }); 149 | } 150 | 151 | /** 152 | * @param {ChokidarCli.RegisterWatcherOptions} opts 153 | * @return {chokidar.WatchOptions} 154 | */ 155 | function createChokidarOpts(opts) { 156 | /** @type {chokidar.WatchOptions} */ 157 | const chokidarOpts = { 158 | cwd: opts.cwd, 159 | followSymlinks: opts.followSymlinks, 160 | usePolling: opts.polling, 161 | interval: opts.pollInterval, 162 | binaryInterval: opts.pollIntervalBinary, 163 | ignoreInitial: !opts.initial, 164 | }; 165 | 166 | if (opts.ignores) { 167 | chokidarOpts.ignored = opts.ignores; 168 | } 169 | 170 | return chokidarOpts; 171 | } 172 | 173 | main(); 174 | 175 | // Set up a parent-process watchdog. 176 | // Based on https://github.com/microsoft/vscode-languageserver-node/blob/54b686f0a1817a845f34bda19d5b1651c445f2cf/server/src/node/main.ts#L78-L93 177 | const parentProcessPid = process.ppid; 178 | if (Number.isInteger(parentProcessPid)) { 179 | // Set up a timer to periodically check if the parent is still alive. 180 | setInterval(() => { 181 | try { 182 | process.kill(parentProcessPid, 0); 183 | } catch (ex) { 184 | // Parent process doesn't exist anymore. Exit the server. 185 | if (rl) { 186 | rl.close(); 187 | } 188 | process.exit(1); 189 | } 190 | }, 3000); 191 | } 192 | -------------------------------------------------------------------------------- /watcher.py: -------------------------------------------------------------------------------- 1 | from __future__ import annotations 2 | from hashlib import md5 3 | from json import dumps 4 | from LSP.plugin import FileWatcher 5 | from LSP.plugin import FileWatcherEvent 6 | from LSP.plugin import FileWatcherEventType 7 | from LSP.plugin import FileWatcherProtocol 8 | from LSP.plugin import register_file_watcher_implementation 9 | from LSP.plugin.core.transports import AbstractProcessor 10 | from LSP.plugin.core.transports import ProcessTransport 11 | from LSP.plugin.core.transports import StopLoopError 12 | from LSP.plugin.core.transports import Transport 13 | from LSP.plugin.core.transports import TransportCallbacks 14 | from lsp_utils import NodeRuntime 15 | from os import makedirs 16 | from os import path 17 | from os import remove 18 | from shutil import rmtree 19 | from sublime_lib import ActivityIndicator 20 | from sublime_lib import ResourcePath 21 | from typing import TYPE_CHECKING, cast, Protocol 22 | import sublime 23 | import subprocess 24 | import weakref 25 | 26 | 27 | if TYPE_CHECKING: 28 | from collections.abc import Callable 29 | from types import TracebackType 30 | from typing import IO, Self 31 | 32 | 33 | PACKAGE_NAME = str(__package__) 34 | PACKAGE_STORAGE = path.abspath(path.join(sublime.cache_path(), "..", "Package Storage")) 35 | VIRTUAL_CHOKIDAR_PATH = 'Packages/{}/{}/'.format(PACKAGE_NAME, 'chokidar') 36 | CHOKIDAR_PACKAGE_STORAGE = path.join(PACKAGE_STORAGE, PACKAGE_NAME) 37 | CHOKIDAR_INSTALATION_MARKER = path.join(CHOKIDAR_PACKAGE_STORAGE, '.installing') 38 | CHOKIDAR_CLI_PATH = path.join(CHOKIDAR_PACKAGE_STORAGE, 'chokidar', 'chokidar-cli', 'index.js') 39 | 40 | Uid = str 41 | 42 | 43 | def log(message: str) -> None: 44 | print(f'{PACKAGE_NAME}: {message}') 45 | 46 | 47 | class TemporaryInstallationMarker: 48 | """ 49 | Create temporary file for the duration of the context. 50 | 51 | The temporary file is not removed if an exception triggeres within the context. 52 | 53 | Usage: 54 | ``` 55 | with TemporaryInstallationMarker('/foo/file'): 56 | ... 57 | ``` 58 | """ 59 | 60 | def __init__(self, marker_path: str) -> None: 61 | self._marker_path = marker_path 62 | 63 | def __enter__(self) -> Self: 64 | makedirs(path.dirname(self._marker_path), exist_ok=True) 65 | open(self._marker_path, 'a').close() 66 | return self 67 | 68 | def __exit__( 69 | self, exc_type: type[BaseException] | None, exc_value: BaseException | None, traceback: TracebackType | None 70 | ) -> None: 71 | if exc_type: 72 | # Don't remove the marker on exception. 73 | return 74 | remove(self._marker_path) 75 | 76 | 77 | class EventCollector(Protocol): 78 | 79 | def on_events(self, uid: Uid, events: list[FileWatcherEvent]) -> None: 80 | ... 81 | 82 | 83 | class StringTransportHandler(AbstractProcessor[str]): 84 | 85 | def write_data(self, writer: IO[bytes], data: str) -> None: 86 | writer.write(f'{data}\n'.encode()) 87 | 88 | def read_data(self, reader: IO[bytes]) -> str | None: 89 | data = reader.readline() 90 | text = None 91 | try: 92 | text = data.decode('utf-8').strip() 93 | except Exception as ex: 94 | log(f"decode error: {ex}") 95 | if not text: 96 | raise StopLoopError 97 | return text 98 | 99 | 100 | class ProcessHandler(TransportCallbacks[str]): 101 | def __init__(self, event_collector: EventCollector) -> None: 102 | self._transport: Transport[str] | None = None 103 | self._pending_events: dict[Uid, list[FileWatcherEvent]] = {} 104 | self._event_collector = event_collector 105 | self._node_runtime: NodeRuntime | None = None 106 | self._start_process() 107 | 108 | def _start_process(self) -> None: 109 | # log('Starting watcher process') 110 | node_runtime = self._resolve_node_runtime() 111 | node_bin = node_runtime.node_bin() 112 | if not node_bin: 113 | raise Exception('Node binary not resolved') 114 | self._initialize_storage(node_runtime) 115 | process = node_runtime.run_node( 116 | [CHOKIDAR_CLI_PATH], stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE) 117 | if not process or not process.stdin or not process.stdout: 118 | raise RuntimeError('Failed initializing watcher process') 119 | self._transport = ProcessTransport( 120 | 'lspwatcher', process, None, process.stdout, process.stdin, process.stderr, StringTransportHandler(), self) 121 | 122 | def _resolve_node_runtime(self) -> NodeRuntime: 123 | if self._node_runtime: 124 | return self._node_runtime 125 | self._node_runtime = NodeRuntime.get(PACKAGE_NAME, PACKAGE_STORAGE, (12, 0, 0)) 126 | if not self._node_runtime: 127 | raise Exception(f'{PACKAGE_NAME}: Failed to locate the Node.js Runtime') 128 | return self._node_runtime 129 | 130 | def _initialize_storage(self, node_runtime: NodeRuntime) -> None: 131 | destination_dir = path.join(CHOKIDAR_PACKAGE_STORAGE, 'chokidar') 132 | installed = False 133 | if path.isdir(path.join(destination_dir, 'node_modules')): 134 | # Dependencies already installed. Check if the version has changed or last installation did not complete. 135 | try: 136 | src_hash = md5(ResourcePath(VIRTUAL_CHOKIDAR_PATH, 'package.json').read_bytes()).hexdigest() 137 | with open(path.join(destination_dir, 'package.json'), 'rb') as file: 138 | dst_hash = md5(file.read()).hexdigest() 139 | if src_hash == dst_hash and not path.isfile(CHOKIDAR_INSTALATION_MARKER): 140 | installed = True 141 | except FileNotFoundError: 142 | # Needs to be re-installed. 143 | pass 144 | 145 | if not installed: 146 | with TemporaryInstallationMarker(CHOKIDAR_INSTALATION_MARKER): 147 | if path.isdir(destination_dir): 148 | rmtree(destination_dir) 149 | ResourcePath(VIRTUAL_CHOKIDAR_PATH).copytree(destination_dir, exist_ok=True) 150 | with ActivityIndicator(sublime.active_window(), 'Installing file watcher'): 151 | node_runtime.run_install(destination_dir) 152 | 153 | def send(self, payload: str) -> None: 154 | if self._transport: 155 | self._transport.send(payload) 156 | 157 | def end_process(self, exit_code: int, exception: Exception | None = None) -> None: 158 | if self._transport: 159 | self._transport.close() 160 | self._transport = None 161 | if exit_code != 0: 162 | log(f'Watcher process ended. Exit code: {exit_code}, Exception: {exception}') 163 | 164 | # --- TransportCallbacks ------------------------------------------------------------------------------------------- 165 | 166 | def on_payload(self, payload: str) -> None: 167 | # Chokidar debounces the events and sends them in batches but Transport notifies us for each new line 168 | # separately so we don't get the benefit of batching by default. To optimize the `on_file_event_async` 169 | # notifications we'll batch the events on our side and only notify when chokidar reports end of the batch 170 | # using the `` line. 171 | if payload == '': 172 | for uid, events in self._pending_events.items(): 173 | self._event_collector.on_events(uid, events) 174 | self._pending_events.clear() 175 | return 176 | if ':' not in payload: 177 | log(f'Invalid watcher output: {payload}') 178 | return 179 | # Queue event. 180 | uid, event_type, path = payload.split(':', 2) 181 | if uid not in self._pending_events: 182 | self._pending_events[uid] = [] 183 | event_kind = cast('FileWatcherEventType', event_type) 184 | self._pending_events[uid].append((event_kind, path)) 185 | 186 | def on_stderr_message(self, message: str) -> None: 187 | log(f'ERROR: {message}') 188 | 189 | def on_transport_close(self, exit_code: int, exception: Exception | None) -> None: 190 | self.end_process(exit_code, exception) 191 | 192 | 193 | class FileWatcherController(FileWatcher): 194 | 195 | @classmethod 196 | def create( 197 | cls, 198 | root_path: str, 199 | patterns: list[str], 200 | events: list[FileWatcherEventType], 201 | ignores: list[str], 202 | handler: FileWatcherProtocol 203 | ) -> FileWatcher: 204 | return file_watcher.register_watcher(root_path, patterns, events, ignores, handler) 205 | 206 | def __init__(self, on_destroy: Callable[[], None]) -> None: 207 | self._on_destroy = on_destroy 208 | 209 | def destroy(self) -> None: 210 | self._on_destroy() 211 | 212 | 213 | class FileWatcherChokidar(EventCollector): 214 | 215 | def __init__(self) -> None: 216 | self._last_controller_id = 0 217 | self._handlers: dict[str, tuple[weakref.ref[FileWatcherProtocol], str]] = {} 218 | self._process_handler: ProcessHandler | None = None 219 | 220 | def register_watcher( 221 | self, 222 | root_path: str, 223 | patterns: list[str], 224 | events: list[FileWatcherEventType], 225 | ignores: list[str], 226 | handler: FileWatcherProtocol 227 | ) -> FileWatcherController: 228 | self._last_controller_id += 1 229 | controller_id = self._last_controller_id 230 | controller = FileWatcherController(on_destroy=lambda: self._on_watcher_removed(controller_id)) 231 | self._on_watcher_added(controller_id, root_path, patterns, events, ignores, handler) 232 | return controller 233 | 234 | def _on_watcher_added( 235 | self, 236 | controller_id: int, 237 | root_path: str, 238 | patterns: list[str], 239 | events: list[FileWatcherEventType], 240 | ignores: list[str], 241 | handler: FileWatcherProtocol 242 | ) -> None: 243 | self._handlers[str(controller_id)] = (weakref.ref(handler), root_path) 244 | if not self._process_handler: 245 | self._process_handler = ProcessHandler(self) 246 | # log('Starting watcher for directory "{}". Pattern: {}. Ignores: {}'.format(root_path, patterns, ignores)) 247 | register_data = { 248 | 'register': { 249 | 'cwd': root_path, 250 | 'events': events, 251 | 'ignores': ignores, 252 | 'patterns': patterns, 253 | 'uid': controller_id, 254 | } 255 | } 256 | self._process_handler.send(self._to_json(register_data)) 257 | 258 | def _on_watcher_removed(self, controller_id: int) -> None: 259 | # log('Removing watcher with id "{}"'.format(controller_id)) 260 | self._handlers.pop(str(controller_id)) 261 | if not self._process_handler: 262 | log('ERROR: Watcher process does not exist') 263 | return 264 | self._process_handler.send(self._to_json({'unregister': controller_id})) 265 | if not len(self._handlers) and self._process_handler: 266 | self._process_handler.end_process(0) 267 | self._process_handler = None 268 | 269 | def _to_json(self, obj: object) -> str: 270 | return dumps( 271 | obj, 272 | ensure_ascii=False, 273 | sort_keys=False, 274 | check_circular=False, 275 | separators=(',', ':') 276 | ) 277 | 278 | # --- EventCollector ----------------------------------------------------------------------------------------------- 279 | 280 | def on_events(self, uid: Uid, events: list[FileWatcherEvent]) -> None: 281 | if uid not in self._handlers: 282 | return 283 | handler, root_path = self._handlers[uid] 284 | handler_impl = handler() 285 | if not handler_impl: 286 | log('ERROR: on_payload(): Handler already deleted') 287 | return 288 | handler_impl.on_file_event_async([(e_type, path.join(root_path, e_path)) for (e_type, e_path) in events]) 289 | 290 | 291 | file_watcher = FileWatcherChokidar() 292 | 293 | register_file_watcher_implementation(FileWatcherController) 294 | -------------------------------------------------------------------------------- /chokidar/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "chokidar-bundle", 3 | "lockfileVersion": 2, 4 | "requires": true, 5 | "packages": { 6 | "": { 7 | "name": "chokidar-bundle", 8 | "dependencies": { 9 | "chokidar": "3.6.0", 10 | "lodash.debounce": "4.0.8", 11 | "lodash.throttle": "4.1.1" 12 | }, 13 | "devDependencies": { 14 | "@types/lodash.debounce": "4.0.9", 15 | "@types/lodash.throttle": "4.1.9", 16 | "@types/node": "24.10.1", 17 | "eslint": "8.57.1", 18 | "typescript": "5.9.3" 19 | } 20 | }, 21 | "node_modules/@aashutoshrathi/word-wrap": { 22 | "version": "1.2.6", 23 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", 24 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", 25 | "dev": true, 26 | "engines": { 27 | "node": ">=0.10.0" 28 | } 29 | }, 30 | "node_modules/@eslint-community/eslint-utils": { 31 | "version": "4.4.0", 32 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 33 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 34 | "dev": true, 35 | "dependencies": { 36 | "eslint-visitor-keys": "^3.3.0" 37 | }, 38 | "engines": { 39 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 40 | }, 41 | "peerDependencies": { 42 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 43 | } 44 | }, 45 | "node_modules/@eslint-community/regexpp": { 46 | "version": "4.9.1", 47 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.9.1.tgz", 48 | "integrity": "sha512-Y27x+MBLjXa+0JWDhykM3+JE+il3kHKAEqabfEWq3SDhZjLYb6/BHL/JKFnH3fe207JaXkyDo685Oc2Glt6ifA==", 49 | "dev": true, 50 | "engines": { 51 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 52 | } 53 | }, 54 | "node_modules/@eslint/eslintrc": { 55 | "version": "2.1.4", 56 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", 57 | "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", 58 | "dev": true, 59 | "dependencies": { 60 | "ajv": "^6.12.4", 61 | "debug": "^4.3.2", 62 | "espree": "^9.6.0", 63 | "globals": "^13.19.0", 64 | "ignore": "^5.2.0", 65 | "import-fresh": "^3.2.1", 66 | "js-yaml": "^4.1.0", 67 | "minimatch": "^3.1.2", 68 | "strip-json-comments": "^3.1.1" 69 | }, 70 | "engines": { 71 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 72 | }, 73 | "funding": { 74 | "url": "https://opencollective.com/eslint" 75 | } 76 | }, 77 | "node_modules/@eslint/js": { 78 | "version": "8.57.1", 79 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.1.tgz", 80 | "integrity": "sha512-d9zaMRSTIKDLhctzH12MtXvJKSSUhaHcjV+2Z+GK+EEY7XKpP5yR4x+N3TAcHTcu963nIr+TMcCb4DBCYX1z6Q==", 81 | "dev": true, 82 | "engines": { 83 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 84 | } 85 | }, 86 | "node_modules/@humanwhocodes/config-array": { 87 | "version": "0.13.0", 88 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.13.0.tgz", 89 | "integrity": "sha512-DZLEEqFWQFiyK6h5YIeynKx7JlvCYWL0cImfSRXZ9l4Sg2efkFGTuFf6vzXjK1cq6IYkU+Eg/JizXw+TD2vRNw==", 90 | "deprecated": "Use @eslint/config-array instead", 91 | "dev": true, 92 | "dependencies": { 93 | "@humanwhocodes/object-schema": "^2.0.3", 94 | "debug": "^4.3.1", 95 | "minimatch": "^3.0.5" 96 | }, 97 | "engines": { 98 | "node": ">=10.10.0" 99 | } 100 | }, 101 | "node_modules/@humanwhocodes/module-importer": { 102 | "version": "1.0.1", 103 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 104 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 105 | "dev": true, 106 | "engines": { 107 | "node": ">=12.22" 108 | }, 109 | "funding": { 110 | "type": "github", 111 | "url": "https://github.com/sponsors/nzakas" 112 | } 113 | }, 114 | "node_modules/@humanwhocodes/object-schema": { 115 | "version": "2.0.3", 116 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.3.tgz", 117 | "integrity": "sha512-93zYdMES/c1D69yZiKDBj0V24vqNzB/koF26KPaagAfd3P/4gUlh3Dys5ogAK+Exi9QyzlD8x/08Zt7wIKcDcA==", 118 | "deprecated": "Use @eslint/object-schema instead", 119 | "dev": true 120 | }, 121 | "node_modules/@nodelib/fs.scandir": { 122 | "version": "2.1.5", 123 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 124 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 125 | "dev": true, 126 | "dependencies": { 127 | "@nodelib/fs.stat": "2.0.5", 128 | "run-parallel": "^1.1.9" 129 | }, 130 | "engines": { 131 | "node": ">= 8" 132 | } 133 | }, 134 | "node_modules/@nodelib/fs.stat": { 135 | "version": "2.0.5", 136 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 137 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 138 | "dev": true, 139 | "engines": { 140 | "node": ">= 8" 141 | } 142 | }, 143 | "node_modules/@nodelib/fs.walk": { 144 | "version": "1.2.8", 145 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 146 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 147 | "dev": true, 148 | "dependencies": { 149 | "@nodelib/fs.scandir": "2.1.5", 150 | "fastq": "^1.6.0" 151 | }, 152 | "engines": { 153 | "node": ">= 8" 154 | } 155 | }, 156 | "node_modules/@types/lodash": { 157 | "version": "4.14.172", 158 | "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.172.tgz", 159 | "integrity": "sha512-/BHF5HAx3em7/KkzVKm3LrsD6HZAXuXO1AJZQ3cRRBZj4oHZDviWPYu0aEplAqDFNHZPW6d3G7KN+ONcCCC7pw==", 160 | "dev": true 161 | }, 162 | "node_modules/@types/lodash.debounce": { 163 | "version": "4.0.9", 164 | "resolved": "https://registry.npmjs.org/@types/lodash.debounce/-/lodash.debounce-4.0.9.tgz", 165 | "integrity": "sha512-Ma5JcgTREwpLRwMM+XwBR7DaWe96nC38uCBDFKZWbNKD+osjVzdpnUSwBcqCptrp16sSOLBAUb50Car5I0TCsQ==", 166 | "dev": true, 167 | "dependencies": { 168 | "@types/lodash": "*" 169 | } 170 | }, 171 | "node_modules/@types/lodash.throttle": { 172 | "version": "4.1.9", 173 | "resolved": "https://registry.npmjs.org/@types/lodash.throttle/-/lodash.throttle-4.1.9.tgz", 174 | "integrity": "sha512-PCPVfpfueguWZQB7pJQK890F2scYKoDUL3iM522AptHWn7d5NQmeS/LTEHIcLr5PaTzl3dK2Z0xSUHHTHwaL5g==", 175 | "dev": true, 176 | "dependencies": { 177 | "@types/lodash": "*" 178 | } 179 | }, 180 | "node_modules/@types/node": { 181 | "version": "24.10.1", 182 | "resolved": "https://registry.npmjs.org/@types/node/-/node-24.10.1.tgz", 183 | "integrity": "sha512-GNWcUTRBgIRJD5zj+Tq0fKOJ5XZajIiBroOF0yvj2bSU1WvNdYS/dn9UxwsujGW4JX06dnHyjV2y9rRaybH0iQ==", 184 | "dev": true, 185 | "dependencies": { 186 | "undici-types": "~7.16.0" 187 | } 188 | }, 189 | "node_modules/@ungap/structured-clone": { 190 | "version": "1.3.0", 191 | "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.3.0.tgz", 192 | "integrity": "sha512-WmoN8qaIAo7WTYWbAZuG8PYEhn5fkz7dZrqTBZ7dtt//lL2Gwms1IcnQ5yHqjDfX8Ft5j4YzDM23f87zBfDe9g==", 193 | "dev": true 194 | }, 195 | "node_modules/acorn": { 196 | "version": "8.10.0", 197 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.10.0.tgz", 198 | "integrity": "sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==", 199 | "dev": true, 200 | "bin": { 201 | "acorn": "bin/acorn" 202 | }, 203 | "engines": { 204 | "node": ">=0.4.0" 205 | } 206 | }, 207 | "node_modules/acorn-jsx": { 208 | "version": "5.3.2", 209 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 210 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 211 | "dev": true, 212 | "peerDependencies": { 213 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 214 | } 215 | }, 216 | "node_modules/ajv": { 217 | "version": "6.12.6", 218 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 219 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 220 | "dev": true, 221 | "dependencies": { 222 | "fast-deep-equal": "^3.1.1", 223 | "fast-json-stable-stringify": "^2.0.0", 224 | "json-schema-traverse": "^0.4.1", 225 | "uri-js": "^4.2.2" 226 | }, 227 | "funding": { 228 | "type": "github", 229 | "url": "https://github.com/sponsors/epoberezkin" 230 | } 231 | }, 232 | "node_modules/ansi-regex": { 233 | "version": "5.0.1", 234 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 235 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 236 | "dev": true, 237 | "engines": { 238 | "node": ">=8" 239 | } 240 | }, 241 | "node_modules/anymatch": { 242 | "version": "3.1.3", 243 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 244 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 245 | "dependencies": { 246 | "normalize-path": "^3.0.0", 247 | "picomatch": "^2.0.4" 248 | }, 249 | "engines": { 250 | "node": ">= 8" 251 | } 252 | }, 253 | "node_modules/argparse": { 254 | "version": "2.0.1", 255 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 256 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 257 | "dev": true 258 | }, 259 | "node_modules/balanced-match": { 260 | "version": "1.0.0", 261 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 262 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 263 | "dev": true 264 | }, 265 | "node_modules/binary-extensions": { 266 | "version": "2.2.0", 267 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 268 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", 269 | "engines": { 270 | "node": ">=8" 271 | } 272 | }, 273 | "node_modules/brace-expansion": { 274 | "version": "1.1.11", 275 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 276 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 277 | "dev": true, 278 | "dependencies": { 279 | "balanced-match": "^1.0.0", 280 | "concat-map": "0.0.1" 281 | } 282 | }, 283 | "node_modules/braces": { 284 | "version": "3.0.2", 285 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 286 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 287 | "dependencies": { 288 | "fill-range": "^7.0.1" 289 | }, 290 | "engines": { 291 | "node": ">=8" 292 | } 293 | }, 294 | "node_modules/callsites": { 295 | "version": "3.1.0", 296 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 297 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 298 | "dev": true, 299 | "engines": { 300 | "node": ">=6" 301 | } 302 | }, 303 | "node_modules/chalk": { 304 | "version": "4.1.0", 305 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 306 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 307 | "dev": true, 308 | "dependencies": { 309 | "ansi-styles": "^4.1.0", 310 | "supports-color": "^7.1.0" 311 | }, 312 | "engines": { 313 | "node": ">=10" 314 | }, 315 | "funding": { 316 | "url": "https://github.com/chalk/chalk?sponsor=1" 317 | } 318 | }, 319 | "node_modules/chalk/node_modules/ansi-styles": { 320 | "version": "4.3.0", 321 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 322 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 323 | "dev": true, 324 | "dependencies": { 325 | "color-convert": "^2.0.1" 326 | }, 327 | "engines": { 328 | "node": ">=8" 329 | }, 330 | "funding": { 331 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 332 | } 333 | }, 334 | "node_modules/chalk/node_modules/color-convert": { 335 | "version": "2.0.1", 336 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 337 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 338 | "dev": true, 339 | "dependencies": { 340 | "color-name": "~1.1.4" 341 | }, 342 | "engines": { 343 | "node": ">=7.0.0" 344 | } 345 | }, 346 | "node_modules/chalk/node_modules/color-name": { 347 | "version": "1.1.4", 348 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 349 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 350 | "dev": true 351 | }, 352 | "node_modules/chalk/node_modules/has-flag": { 353 | "version": "4.0.0", 354 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 355 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 356 | "dev": true, 357 | "engines": { 358 | "node": ">=8" 359 | } 360 | }, 361 | "node_modules/chalk/node_modules/supports-color": { 362 | "version": "7.2.0", 363 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 364 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 365 | "dev": true, 366 | "dependencies": { 367 | "has-flag": "^4.0.0" 368 | }, 369 | "engines": { 370 | "node": ">=8" 371 | } 372 | }, 373 | "node_modules/chokidar": { 374 | "version": "3.6.0", 375 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", 376 | "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", 377 | "dependencies": { 378 | "anymatch": "~3.1.2", 379 | "braces": "~3.0.2", 380 | "glob-parent": "~5.1.2", 381 | "is-binary-path": "~2.1.0", 382 | "is-glob": "~4.0.1", 383 | "normalize-path": "~3.0.0", 384 | "readdirp": "~3.6.0" 385 | }, 386 | "engines": { 387 | "node": ">= 8.10.0" 388 | }, 389 | "funding": { 390 | "url": "https://paulmillr.com/funding/" 391 | }, 392 | "optionalDependencies": { 393 | "fsevents": "~2.3.2" 394 | } 395 | }, 396 | "node_modules/concat-map": { 397 | "version": "0.0.1", 398 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 399 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 400 | "dev": true 401 | }, 402 | "node_modules/cross-spawn": { 403 | "version": "7.0.3", 404 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 405 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 406 | "dev": true, 407 | "dependencies": { 408 | "path-key": "^3.1.0", 409 | "shebang-command": "^2.0.0", 410 | "which": "^2.0.1" 411 | }, 412 | "engines": { 413 | "node": ">= 8" 414 | } 415 | }, 416 | "node_modules/debug": { 417 | "version": "4.3.4", 418 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 419 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 420 | "dev": true, 421 | "dependencies": { 422 | "ms": "2.1.2" 423 | }, 424 | "engines": { 425 | "node": ">=6.0" 426 | }, 427 | "peerDependenciesMeta": { 428 | "supports-color": { 429 | "optional": true 430 | } 431 | } 432 | }, 433 | "node_modules/deep-is": { 434 | "version": "0.1.4", 435 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 436 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 437 | "dev": true 438 | }, 439 | "node_modules/doctrine": { 440 | "version": "3.0.0", 441 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 442 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 443 | "dev": true, 444 | "dependencies": { 445 | "esutils": "^2.0.2" 446 | }, 447 | "engines": { 448 | "node": ">=6.0.0" 449 | } 450 | }, 451 | "node_modules/escape-string-regexp": { 452 | "version": "4.0.0", 453 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 454 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 455 | "dev": true, 456 | "engines": { 457 | "node": ">=10" 458 | }, 459 | "funding": { 460 | "url": "https://github.com/sponsors/sindresorhus" 461 | } 462 | }, 463 | "node_modules/eslint": { 464 | "version": "8.57.1", 465 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.1.tgz", 466 | "integrity": "sha512-ypowyDxpVSYpkXr9WPv2PAZCtNip1Mv5KTW0SCurXv/9iOpcrH9PaqUElksqEB6pChqHGDRCFTyrZlGhnLNGiA==", 467 | "deprecated": "This version is no longer supported. Please see https://eslint.org/version-support for other options.", 468 | "dev": true, 469 | "dependencies": { 470 | "@eslint-community/eslint-utils": "^4.2.0", 471 | "@eslint-community/regexpp": "^4.6.1", 472 | "@eslint/eslintrc": "^2.1.4", 473 | "@eslint/js": "8.57.1", 474 | "@humanwhocodes/config-array": "^0.13.0", 475 | "@humanwhocodes/module-importer": "^1.0.1", 476 | "@nodelib/fs.walk": "^1.2.8", 477 | "@ungap/structured-clone": "^1.2.0", 478 | "ajv": "^6.12.4", 479 | "chalk": "^4.0.0", 480 | "cross-spawn": "^7.0.2", 481 | "debug": "^4.3.2", 482 | "doctrine": "^3.0.0", 483 | "escape-string-regexp": "^4.0.0", 484 | "eslint-scope": "^7.2.2", 485 | "eslint-visitor-keys": "^3.4.3", 486 | "espree": "^9.6.1", 487 | "esquery": "^1.4.2", 488 | "esutils": "^2.0.2", 489 | "fast-deep-equal": "^3.1.3", 490 | "file-entry-cache": "^6.0.1", 491 | "find-up": "^5.0.0", 492 | "glob-parent": "^6.0.2", 493 | "globals": "^13.19.0", 494 | "graphemer": "^1.4.0", 495 | "ignore": "^5.2.0", 496 | "imurmurhash": "^0.1.4", 497 | "is-glob": "^4.0.0", 498 | "is-path-inside": "^3.0.3", 499 | "js-yaml": "^4.1.0", 500 | "json-stable-stringify-without-jsonify": "^1.0.1", 501 | "levn": "^0.4.1", 502 | "lodash.merge": "^4.6.2", 503 | "minimatch": "^3.1.2", 504 | "natural-compare": "^1.4.0", 505 | "optionator": "^0.9.3", 506 | "strip-ansi": "^6.0.1", 507 | "text-table": "^0.2.0" 508 | }, 509 | "bin": { 510 | "eslint": "bin/eslint.js" 511 | }, 512 | "engines": { 513 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 514 | }, 515 | "funding": { 516 | "url": "https://opencollective.com/eslint" 517 | } 518 | }, 519 | "node_modules/eslint-scope": { 520 | "version": "7.2.2", 521 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 522 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 523 | "dev": true, 524 | "dependencies": { 525 | "esrecurse": "^4.3.0", 526 | "estraverse": "^5.2.0" 527 | }, 528 | "engines": { 529 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 530 | }, 531 | "funding": { 532 | "url": "https://opencollective.com/eslint" 533 | } 534 | }, 535 | "node_modules/eslint-visitor-keys": { 536 | "version": "3.4.3", 537 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 538 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 539 | "dev": true, 540 | "engines": { 541 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 542 | }, 543 | "funding": { 544 | "url": "https://opencollective.com/eslint" 545 | } 546 | }, 547 | "node_modules/eslint/node_modules/glob-parent": { 548 | "version": "6.0.2", 549 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 550 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 551 | "dev": true, 552 | "dependencies": { 553 | "is-glob": "^4.0.3" 554 | }, 555 | "engines": { 556 | "node": ">=10.13.0" 557 | } 558 | }, 559 | "node_modules/espree": { 560 | "version": "9.6.1", 561 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 562 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 563 | "dev": true, 564 | "dependencies": { 565 | "acorn": "^8.9.0", 566 | "acorn-jsx": "^5.3.2", 567 | "eslint-visitor-keys": "^3.4.1" 568 | }, 569 | "engines": { 570 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 571 | }, 572 | "funding": { 573 | "url": "https://opencollective.com/eslint" 574 | } 575 | }, 576 | "node_modules/esquery": { 577 | "version": "1.5.0", 578 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 579 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 580 | "dev": true, 581 | "dependencies": { 582 | "estraverse": "^5.1.0" 583 | }, 584 | "engines": { 585 | "node": ">=0.10" 586 | } 587 | }, 588 | "node_modules/esrecurse": { 589 | "version": "4.3.0", 590 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 591 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 592 | "dev": true, 593 | "dependencies": { 594 | "estraverse": "^5.2.0" 595 | }, 596 | "engines": { 597 | "node": ">=4.0" 598 | } 599 | }, 600 | "node_modules/estraverse": { 601 | "version": "5.3.0", 602 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 603 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 604 | "dev": true, 605 | "engines": { 606 | "node": ">=4.0" 607 | } 608 | }, 609 | "node_modules/esutils": { 610 | "version": "2.0.3", 611 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 612 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 613 | "dev": true, 614 | "engines": { 615 | "node": ">=0.10.0" 616 | } 617 | }, 618 | "node_modules/fast-deep-equal": { 619 | "version": "3.1.3", 620 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 621 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 622 | "dev": true 623 | }, 624 | "node_modules/fast-json-stable-stringify": { 625 | "version": "2.1.0", 626 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 627 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 628 | "dev": true 629 | }, 630 | "node_modules/fast-levenshtein": { 631 | "version": "2.0.6", 632 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 633 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 634 | "dev": true 635 | }, 636 | "node_modules/fastq": { 637 | "version": "1.15.0", 638 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz", 639 | "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==", 640 | "dev": true, 641 | "dependencies": { 642 | "reusify": "^1.0.4" 643 | } 644 | }, 645 | "node_modules/file-entry-cache": { 646 | "version": "6.0.1", 647 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 648 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 649 | "dev": true, 650 | "dependencies": { 651 | "flat-cache": "^3.0.4" 652 | }, 653 | "engines": { 654 | "node": "^10.12.0 || >=12.0.0" 655 | } 656 | }, 657 | "node_modules/fill-range": { 658 | "version": "7.0.1", 659 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 660 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 661 | "dependencies": { 662 | "to-regex-range": "^5.0.1" 663 | }, 664 | "engines": { 665 | "node": ">=8" 666 | } 667 | }, 668 | "node_modules/find-up": { 669 | "version": "5.0.0", 670 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 671 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 672 | "dev": true, 673 | "dependencies": { 674 | "locate-path": "^6.0.0", 675 | "path-exists": "^4.0.0" 676 | }, 677 | "engines": { 678 | "node": ">=10" 679 | }, 680 | "funding": { 681 | "url": "https://github.com/sponsors/sindresorhus" 682 | } 683 | }, 684 | "node_modules/flat-cache": { 685 | "version": "3.0.4", 686 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 687 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 688 | "dev": true, 689 | "dependencies": { 690 | "flatted": "^3.1.0", 691 | "rimraf": "^3.0.2" 692 | }, 693 | "engines": { 694 | "node": "^10.12.0 || >=12.0.0" 695 | } 696 | }, 697 | "node_modules/flatted": { 698 | "version": "3.1.1", 699 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.1.1.tgz", 700 | "integrity": "sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA==", 701 | "dev": true 702 | }, 703 | "node_modules/fs.realpath": { 704 | "version": "1.0.0", 705 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 706 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 707 | "dev": true 708 | }, 709 | "node_modules/fsevents": { 710 | "version": "2.3.2", 711 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 712 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 713 | "hasInstallScript": true, 714 | "optional": true, 715 | "os": [ 716 | "darwin" 717 | ], 718 | "engines": { 719 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 720 | } 721 | }, 722 | "node_modules/glob": { 723 | "version": "7.1.6", 724 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 725 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 726 | "dev": true, 727 | "dependencies": { 728 | "fs.realpath": "^1.0.0", 729 | "inflight": "^1.0.4", 730 | "inherits": "2", 731 | "minimatch": "^3.0.4", 732 | "once": "^1.3.0", 733 | "path-is-absolute": "^1.0.0" 734 | }, 735 | "engines": { 736 | "node": "*" 737 | }, 738 | "funding": { 739 | "url": "https://github.com/sponsors/isaacs" 740 | } 741 | }, 742 | "node_modules/glob-parent": { 743 | "version": "5.1.2", 744 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 745 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 746 | "dependencies": { 747 | "is-glob": "^4.0.1" 748 | }, 749 | "engines": { 750 | "node": ">= 6" 751 | } 752 | }, 753 | "node_modules/globals": { 754 | "version": "13.23.0", 755 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.23.0.tgz", 756 | "integrity": "sha512-XAmF0RjlrjY23MA51q3HltdlGxUpXPvg0GioKiD9X6HD28iMjo2dKC8Vqwm7lne4GNr78+RHTfliktR6ZH09wA==", 757 | "dev": true, 758 | "dependencies": { 759 | "type-fest": "^0.20.2" 760 | }, 761 | "engines": { 762 | "node": ">=8" 763 | }, 764 | "funding": { 765 | "url": "https://github.com/sponsors/sindresorhus" 766 | } 767 | }, 768 | "node_modules/graphemer": { 769 | "version": "1.4.0", 770 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 771 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 772 | "dev": true 773 | }, 774 | "node_modules/ignore": { 775 | "version": "5.2.4", 776 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", 777 | "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", 778 | "dev": true, 779 | "engines": { 780 | "node": ">= 4" 781 | } 782 | }, 783 | "node_modules/import-fresh": { 784 | "version": "3.3.0", 785 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 786 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 787 | "dev": true, 788 | "dependencies": { 789 | "parent-module": "^1.0.0", 790 | "resolve-from": "^4.0.0" 791 | }, 792 | "engines": { 793 | "node": ">=6" 794 | }, 795 | "funding": { 796 | "url": "https://github.com/sponsors/sindresorhus" 797 | } 798 | }, 799 | "node_modules/imurmurhash": { 800 | "version": "0.1.4", 801 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 802 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 803 | "dev": true, 804 | "engines": { 805 | "node": ">=0.8.19" 806 | } 807 | }, 808 | "node_modules/inflight": { 809 | "version": "1.0.6", 810 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 811 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 812 | "dev": true, 813 | "dependencies": { 814 | "once": "^1.3.0", 815 | "wrappy": "1" 816 | } 817 | }, 818 | "node_modules/inherits": { 819 | "version": "2.0.4", 820 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 821 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 822 | "dev": true 823 | }, 824 | "node_modules/is-binary-path": { 825 | "version": "2.1.0", 826 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 827 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 828 | "dependencies": { 829 | "binary-extensions": "^2.0.0" 830 | }, 831 | "engines": { 832 | "node": ">=8" 833 | } 834 | }, 835 | "node_modules/is-extglob": { 836 | "version": "2.1.1", 837 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 838 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 839 | "engines": { 840 | "node": ">=0.10.0" 841 | } 842 | }, 843 | "node_modules/is-glob": { 844 | "version": "4.0.3", 845 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 846 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 847 | "dependencies": { 848 | "is-extglob": "^2.1.1" 849 | }, 850 | "engines": { 851 | "node": ">=0.10.0" 852 | } 853 | }, 854 | "node_modules/is-number": { 855 | "version": "7.0.0", 856 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 857 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 858 | "engines": { 859 | "node": ">=0.12.0" 860 | } 861 | }, 862 | "node_modules/is-path-inside": { 863 | "version": "3.0.3", 864 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 865 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 866 | "dev": true, 867 | "engines": { 868 | "node": ">=8" 869 | } 870 | }, 871 | "node_modules/isexe": { 872 | "version": "2.0.0", 873 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 874 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 875 | "dev": true 876 | }, 877 | "node_modules/js-yaml": { 878 | "version": "4.1.0", 879 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 880 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 881 | "dev": true, 882 | "dependencies": { 883 | "argparse": "^2.0.1" 884 | }, 885 | "bin": { 886 | "js-yaml": "bin/js-yaml.js" 887 | } 888 | }, 889 | "node_modules/json-schema-traverse": { 890 | "version": "0.4.1", 891 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 892 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 893 | "dev": true 894 | }, 895 | "node_modules/json-stable-stringify-without-jsonify": { 896 | "version": "1.0.1", 897 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 898 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 899 | "dev": true 900 | }, 901 | "node_modules/levn": { 902 | "version": "0.4.1", 903 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 904 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 905 | "dev": true, 906 | "dependencies": { 907 | "prelude-ls": "^1.2.1", 908 | "type-check": "~0.4.0" 909 | }, 910 | "engines": { 911 | "node": ">= 0.8.0" 912 | } 913 | }, 914 | "node_modules/locate-path": { 915 | "version": "6.0.0", 916 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 917 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 918 | "dev": true, 919 | "dependencies": { 920 | "p-locate": "^5.0.0" 921 | }, 922 | "engines": { 923 | "node": ">=10" 924 | }, 925 | "funding": { 926 | "url": "https://github.com/sponsors/sindresorhus" 927 | } 928 | }, 929 | "node_modules/lodash.debounce": { 930 | "version": "4.0.8", 931 | "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", 932 | "integrity": "sha1-gteb/zCmfEAF/9XiUVMArZyk168=" 933 | }, 934 | "node_modules/lodash.merge": { 935 | "version": "4.6.2", 936 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 937 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 938 | "dev": true 939 | }, 940 | "node_modules/lodash.throttle": { 941 | "version": "4.1.1", 942 | "resolved": "https://registry.npmjs.org/lodash.throttle/-/lodash.throttle-4.1.1.tgz", 943 | "integrity": "sha1-wj6RtxAkKscMN/HhzaknTMOb8vQ=" 944 | }, 945 | "node_modules/minimatch": { 946 | "version": "3.1.2", 947 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 948 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 949 | "dev": true, 950 | "dependencies": { 951 | "brace-expansion": "^1.1.7" 952 | }, 953 | "engines": { 954 | "node": "*" 955 | } 956 | }, 957 | "node_modules/ms": { 958 | "version": "2.1.2", 959 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 960 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 961 | "dev": true 962 | }, 963 | "node_modules/natural-compare": { 964 | "version": "1.4.0", 965 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 966 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 967 | "dev": true 968 | }, 969 | "node_modules/normalize-path": { 970 | "version": "3.0.0", 971 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 972 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 973 | "engines": { 974 | "node": ">=0.10.0" 975 | } 976 | }, 977 | "node_modules/once": { 978 | "version": "1.4.0", 979 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 980 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 981 | "dev": true, 982 | "dependencies": { 983 | "wrappy": "1" 984 | } 985 | }, 986 | "node_modules/optionator": { 987 | "version": "0.9.3", 988 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", 989 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", 990 | "dev": true, 991 | "dependencies": { 992 | "@aashutoshrathi/word-wrap": "^1.2.3", 993 | "deep-is": "^0.1.3", 994 | "fast-levenshtein": "^2.0.6", 995 | "levn": "^0.4.1", 996 | "prelude-ls": "^1.2.1", 997 | "type-check": "^0.4.0" 998 | }, 999 | "engines": { 1000 | "node": ">= 0.8.0" 1001 | } 1002 | }, 1003 | "node_modules/p-limit": { 1004 | "version": "3.1.0", 1005 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1006 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1007 | "dev": true, 1008 | "dependencies": { 1009 | "yocto-queue": "^0.1.0" 1010 | }, 1011 | "engines": { 1012 | "node": ">=10" 1013 | }, 1014 | "funding": { 1015 | "url": "https://github.com/sponsors/sindresorhus" 1016 | } 1017 | }, 1018 | "node_modules/p-locate": { 1019 | "version": "5.0.0", 1020 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1021 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1022 | "dev": true, 1023 | "dependencies": { 1024 | "p-limit": "^3.0.2" 1025 | }, 1026 | "engines": { 1027 | "node": ">=10" 1028 | }, 1029 | "funding": { 1030 | "url": "https://github.com/sponsors/sindresorhus" 1031 | } 1032 | }, 1033 | "node_modules/parent-module": { 1034 | "version": "1.0.1", 1035 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1036 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1037 | "dev": true, 1038 | "dependencies": { 1039 | "callsites": "^3.0.0" 1040 | }, 1041 | "engines": { 1042 | "node": ">=6" 1043 | } 1044 | }, 1045 | "node_modules/path-exists": { 1046 | "version": "4.0.0", 1047 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1048 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1049 | "dev": true, 1050 | "engines": { 1051 | "node": ">=8" 1052 | } 1053 | }, 1054 | "node_modules/path-is-absolute": { 1055 | "version": "1.0.1", 1056 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1057 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1058 | "dev": true, 1059 | "engines": { 1060 | "node": ">=0.10.0" 1061 | } 1062 | }, 1063 | "node_modules/path-key": { 1064 | "version": "3.1.1", 1065 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1066 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1067 | "dev": true, 1068 | "engines": { 1069 | "node": ">=8" 1070 | } 1071 | }, 1072 | "node_modules/picomatch": { 1073 | "version": "2.3.1", 1074 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1075 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1076 | "engines": { 1077 | "node": ">=8.6" 1078 | }, 1079 | "funding": { 1080 | "url": "https://github.com/sponsors/jonschlinkert" 1081 | } 1082 | }, 1083 | "node_modules/prelude-ls": { 1084 | "version": "1.2.1", 1085 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1086 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1087 | "dev": true, 1088 | "engines": { 1089 | "node": ">= 0.8.0" 1090 | } 1091 | }, 1092 | "node_modules/punycode": { 1093 | "version": "2.3.0", 1094 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", 1095 | "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==", 1096 | "dev": true, 1097 | "engines": { 1098 | "node": ">=6" 1099 | } 1100 | }, 1101 | "node_modules/queue-microtask": { 1102 | "version": "1.2.3", 1103 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 1104 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 1105 | "dev": true, 1106 | "funding": [ 1107 | { 1108 | "type": "github", 1109 | "url": "https://github.com/sponsors/feross" 1110 | }, 1111 | { 1112 | "type": "patreon", 1113 | "url": "https://www.patreon.com/feross" 1114 | }, 1115 | { 1116 | "type": "consulting", 1117 | "url": "https://feross.org/support" 1118 | } 1119 | ] 1120 | }, 1121 | "node_modules/readdirp": { 1122 | "version": "3.6.0", 1123 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 1124 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 1125 | "dependencies": { 1126 | "picomatch": "^2.2.1" 1127 | }, 1128 | "engines": { 1129 | "node": ">=8.10.0" 1130 | } 1131 | }, 1132 | "node_modules/resolve-from": { 1133 | "version": "4.0.0", 1134 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1135 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1136 | "dev": true, 1137 | "engines": { 1138 | "node": ">=4" 1139 | } 1140 | }, 1141 | "node_modules/reusify": { 1142 | "version": "1.0.4", 1143 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 1144 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 1145 | "dev": true, 1146 | "engines": { 1147 | "iojs": ">=1.0.0", 1148 | "node": ">=0.10.0" 1149 | } 1150 | }, 1151 | "node_modules/rimraf": { 1152 | "version": "3.0.2", 1153 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1154 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1155 | "dev": true, 1156 | "dependencies": { 1157 | "glob": "^7.1.3" 1158 | }, 1159 | "bin": { 1160 | "rimraf": "bin.js" 1161 | }, 1162 | "funding": { 1163 | "url": "https://github.com/sponsors/isaacs" 1164 | } 1165 | }, 1166 | "node_modules/run-parallel": { 1167 | "version": "1.2.0", 1168 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 1169 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 1170 | "dev": true, 1171 | "funding": [ 1172 | { 1173 | "type": "github", 1174 | "url": "https://github.com/sponsors/feross" 1175 | }, 1176 | { 1177 | "type": "patreon", 1178 | "url": "https://www.patreon.com/feross" 1179 | }, 1180 | { 1181 | "type": "consulting", 1182 | "url": "https://feross.org/support" 1183 | } 1184 | ], 1185 | "dependencies": { 1186 | "queue-microtask": "^1.2.2" 1187 | } 1188 | }, 1189 | "node_modules/shebang-command": { 1190 | "version": "2.0.0", 1191 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1192 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1193 | "dev": true, 1194 | "dependencies": { 1195 | "shebang-regex": "^3.0.0" 1196 | }, 1197 | "engines": { 1198 | "node": ">=8" 1199 | } 1200 | }, 1201 | "node_modules/shebang-regex": { 1202 | "version": "3.0.0", 1203 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1204 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1205 | "dev": true, 1206 | "engines": { 1207 | "node": ">=8" 1208 | } 1209 | }, 1210 | "node_modules/strip-ansi": { 1211 | "version": "6.0.1", 1212 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1213 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1214 | "dev": true, 1215 | "dependencies": { 1216 | "ansi-regex": "^5.0.1" 1217 | }, 1218 | "engines": { 1219 | "node": ">=8" 1220 | } 1221 | }, 1222 | "node_modules/strip-json-comments": { 1223 | "version": "3.1.1", 1224 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1225 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1226 | "dev": true, 1227 | "engines": { 1228 | "node": ">=8" 1229 | }, 1230 | "funding": { 1231 | "url": "https://github.com/sponsors/sindresorhus" 1232 | } 1233 | }, 1234 | "node_modules/text-table": { 1235 | "version": "0.2.0", 1236 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1237 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1238 | "dev": true 1239 | }, 1240 | "node_modules/to-regex-range": { 1241 | "version": "5.0.1", 1242 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1243 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1244 | "dependencies": { 1245 | "is-number": "^7.0.0" 1246 | }, 1247 | "engines": { 1248 | "node": ">=8.0" 1249 | } 1250 | }, 1251 | "node_modules/type-check": { 1252 | "version": "0.4.0", 1253 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1254 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1255 | "dev": true, 1256 | "dependencies": { 1257 | "prelude-ls": "^1.2.1" 1258 | }, 1259 | "engines": { 1260 | "node": ">= 0.8.0" 1261 | } 1262 | }, 1263 | "node_modules/type-fest": { 1264 | "version": "0.20.2", 1265 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 1266 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 1267 | "dev": true, 1268 | "engines": { 1269 | "node": ">=10" 1270 | }, 1271 | "funding": { 1272 | "url": "https://github.com/sponsors/sindresorhus" 1273 | } 1274 | }, 1275 | "node_modules/typescript": { 1276 | "version": "5.9.3", 1277 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.9.3.tgz", 1278 | "integrity": "sha512-jl1vZzPDinLr9eUt3J/t7V6FgNEw9QjvBPdysz9KfQDD41fQrC2Y4vKQdiaUpFT4bXlb1RHhLpp8wtm6M5TgSw==", 1279 | "dev": true, 1280 | "bin": { 1281 | "tsc": "bin/tsc", 1282 | "tsserver": "bin/tsserver" 1283 | }, 1284 | "engines": { 1285 | "node": ">=14.17" 1286 | } 1287 | }, 1288 | "node_modules/undici-types": { 1289 | "version": "7.16.0", 1290 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-7.16.0.tgz", 1291 | "integrity": "sha512-Zz+aZWSj8LE6zoxD+xrjh4VfkIG8Ya6LvYkZqtUQGJPZjYl53ypCaUwWqo7eI0x66KBGeRo+mlBEkMSeSZ38Nw==", 1292 | "dev": true 1293 | }, 1294 | "node_modules/uri-js": { 1295 | "version": "4.4.1", 1296 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1297 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1298 | "dev": true, 1299 | "dependencies": { 1300 | "punycode": "^2.1.0" 1301 | } 1302 | }, 1303 | "node_modules/which": { 1304 | "version": "2.0.2", 1305 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1306 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1307 | "dev": true, 1308 | "dependencies": { 1309 | "isexe": "^2.0.0" 1310 | }, 1311 | "bin": { 1312 | "node-which": "bin/node-which" 1313 | }, 1314 | "engines": { 1315 | "node": ">= 8" 1316 | } 1317 | }, 1318 | "node_modules/wrappy": { 1319 | "version": "1.0.2", 1320 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1321 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1322 | "dev": true 1323 | }, 1324 | "node_modules/yocto-queue": { 1325 | "version": "0.1.0", 1326 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1327 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1328 | "dev": true, 1329 | "engines": { 1330 | "node": ">=10" 1331 | }, 1332 | "funding": { 1333 | "url": "https://github.com/sponsors/sindresorhus" 1334 | } 1335 | } 1336 | }, 1337 | "dependencies": { 1338 | "@aashutoshrathi/word-wrap": { 1339 | "version": "1.2.6", 1340 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", 1341 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", 1342 | "dev": true 1343 | }, 1344 | "@eslint-community/eslint-utils": { 1345 | "version": "4.4.0", 1346 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 1347 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 1348 | "dev": true, 1349 | "requires": { 1350 | "eslint-visitor-keys": "^3.3.0" 1351 | } 1352 | }, 1353 | "@eslint-community/regexpp": { 1354 | "version": "4.9.1", 1355 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.9.1.tgz", 1356 | "integrity": "sha512-Y27x+MBLjXa+0JWDhykM3+JE+il3kHKAEqabfEWq3SDhZjLYb6/BHL/JKFnH3fe207JaXkyDo685Oc2Glt6ifA==", 1357 | "dev": true 1358 | }, 1359 | "@eslint/eslintrc": { 1360 | "version": "2.1.4", 1361 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", 1362 | "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", 1363 | "dev": true, 1364 | "requires": { 1365 | "ajv": "^6.12.4", 1366 | "debug": "^4.3.2", 1367 | "espree": "^9.6.0", 1368 | "globals": "^13.19.0", 1369 | "ignore": "^5.2.0", 1370 | "import-fresh": "^3.2.1", 1371 | "js-yaml": "^4.1.0", 1372 | "minimatch": "^3.1.2", 1373 | "strip-json-comments": "^3.1.1" 1374 | } 1375 | }, 1376 | "@eslint/js": { 1377 | "version": "8.57.1", 1378 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.1.tgz", 1379 | "integrity": "sha512-d9zaMRSTIKDLhctzH12MtXvJKSSUhaHcjV+2Z+GK+EEY7XKpP5yR4x+N3TAcHTcu963nIr+TMcCb4DBCYX1z6Q==", 1380 | "dev": true 1381 | }, 1382 | "@humanwhocodes/config-array": { 1383 | "version": "0.13.0", 1384 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.13.0.tgz", 1385 | "integrity": "sha512-DZLEEqFWQFiyK6h5YIeynKx7JlvCYWL0cImfSRXZ9l4Sg2efkFGTuFf6vzXjK1cq6IYkU+Eg/JizXw+TD2vRNw==", 1386 | "dev": true, 1387 | "requires": { 1388 | "@humanwhocodes/object-schema": "^2.0.3", 1389 | "debug": "^4.3.1", 1390 | "minimatch": "^3.0.5" 1391 | } 1392 | }, 1393 | "@humanwhocodes/module-importer": { 1394 | "version": "1.0.1", 1395 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 1396 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 1397 | "dev": true 1398 | }, 1399 | "@humanwhocodes/object-schema": { 1400 | "version": "2.0.3", 1401 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.3.tgz", 1402 | "integrity": "sha512-93zYdMES/c1D69yZiKDBj0V24vqNzB/koF26KPaagAfd3P/4gUlh3Dys5ogAK+Exi9QyzlD8x/08Zt7wIKcDcA==", 1403 | "dev": true 1404 | }, 1405 | "@nodelib/fs.scandir": { 1406 | "version": "2.1.5", 1407 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 1408 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 1409 | "dev": true, 1410 | "requires": { 1411 | "@nodelib/fs.stat": "2.0.5", 1412 | "run-parallel": "^1.1.9" 1413 | } 1414 | }, 1415 | "@nodelib/fs.stat": { 1416 | "version": "2.0.5", 1417 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 1418 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 1419 | "dev": true 1420 | }, 1421 | "@nodelib/fs.walk": { 1422 | "version": "1.2.8", 1423 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 1424 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 1425 | "dev": true, 1426 | "requires": { 1427 | "@nodelib/fs.scandir": "2.1.5", 1428 | "fastq": "^1.6.0" 1429 | } 1430 | }, 1431 | "@types/lodash": { 1432 | "version": "4.14.172", 1433 | "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.172.tgz", 1434 | "integrity": "sha512-/BHF5HAx3em7/KkzVKm3LrsD6HZAXuXO1AJZQ3cRRBZj4oHZDviWPYu0aEplAqDFNHZPW6d3G7KN+ONcCCC7pw==", 1435 | "dev": true 1436 | }, 1437 | "@types/lodash.debounce": { 1438 | "version": "4.0.9", 1439 | "resolved": "https://registry.npmjs.org/@types/lodash.debounce/-/lodash.debounce-4.0.9.tgz", 1440 | "integrity": "sha512-Ma5JcgTREwpLRwMM+XwBR7DaWe96nC38uCBDFKZWbNKD+osjVzdpnUSwBcqCptrp16sSOLBAUb50Car5I0TCsQ==", 1441 | "dev": true, 1442 | "requires": { 1443 | "@types/lodash": "*" 1444 | } 1445 | }, 1446 | "@types/lodash.throttle": { 1447 | "version": "4.1.9", 1448 | "resolved": "https://registry.npmjs.org/@types/lodash.throttle/-/lodash.throttle-4.1.9.tgz", 1449 | "integrity": "sha512-PCPVfpfueguWZQB7pJQK890F2scYKoDUL3iM522AptHWn7d5NQmeS/LTEHIcLr5PaTzl3dK2Z0xSUHHTHwaL5g==", 1450 | "dev": true, 1451 | "requires": { 1452 | "@types/lodash": "*" 1453 | } 1454 | }, 1455 | "@types/node": { 1456 | "version": "24.10.1", 1457 | "resolved": "https://registry.npmjs.org/@types/node/-/node-24.10.1.tgz", 1458 | "integrity": "sha512-GNWcUTRBgIRJD5zj+Tq0fKOJ5XZajIiBroOF0yvj2bSU1WvNdYS/dn9UxwsujGW4JX06dnHyjV2y9rRaybH0iQ==", 1459 | "dev": true, 1460 | "requires": { 1461 | "undici-types": "~7.16.0" 1462 | } 1463 | }, 1464 | "@ungap/structured-clone": { 1465 | "version": "1.3.0", 1466 | "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.3.0.tgz", 1467 | "integrity": "sha512-WmoN8qaIAo7WTYWbAZuG8PYEhn5fkz7dZrqTBZ7dtt//lL2Gwms1IcnQ5yHqjDfX8Ft5j4YzDM23f87zBfDe9g==", 1468 | "dev": true 1469 | }, 1470 | "acorn": { 1471 | "version": "8.10.0", 1472 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.10.0.tgz", 1473 | "integrity": "sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==", 1474 | "dev": true 1475 | }, 1476 | "acorn-jsx": { 1477 | "version": "5.3.2", 1478 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 1479 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 1480 | "dev": true, 1481 | "requires": {} 1482 | }, 1483 | "ajv": { 1484 | "version": "6.12.6", 1485 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 1486 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 1487 | "dev": true, 1488 | "requires": { 1489 | "fast-deep-equal": "^3.1.1", 1490 | "fast-json-stable-stringify": "^2.0.0", 1491 | "json-schema-traverse": "^0.4.1", 1492 | "uri-js": "^4.2.2" 1493 | } 1494 | }, 1495 | "ansi-regex": { 1496 | "version": "5.0.1", 1497 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1498 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1499 | "dev": true 1500 | }, 1501 | "anymatch": { 1502 | "version": "3.1.3", 1503 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 1504 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 1505 | "requires": { 1506 | "normalize-path": "^3.0.0", 1507 | "picomatch": "^2.0.4" 1508 | } 1509 | }, 1510 | "argparse": { 1511 | "version": "2.0.1", 1512 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 1513 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 1514 | "dev": true 1515 | }, 1516 | "balanced-match": { 1517 | "version": "1.0.0", 1518 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 1519 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 1520 | "dev": true 1521 | }, 1522 | "binary-extensions": { 1523 | "version": "2.2.0", 1524 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", 1525 | "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==" 1526 | }, 1527 | "brace-expansion": { 1528 | "version": "1.1.11", 1529 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1530 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1531 | "dev": true, 1532 | "requires": { 1533 | "balanced-match": "^1.0.0", 1534 | "concat-map": "0.0.1" 1535 | } 1536 | }, 1537 | "braces": { 1538 | "version": "3.0.2", 1539 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 1540 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 1541 | "requires": { 1542 | "fill-range": "^7.0.1" 1543 | } 1544 | }, 1545 | "callsites": { 1546 | "version": "3.1.0", 1547 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1548 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 1549 | "dev": true 1550 | }, 1551 | "chalk": { 1552 | "version": "4.1.0", 1553 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 1554 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 1555 | "dev": true, 1556 | "requires": { 1557 | "ansi-styles": "^4.1.0", 1558 | "supports-color": "^7.1.0" 1559 | }, 1560 | "dependencies": { 1561 | "ansi-styles": { 1562 | "version": "4.3.0", 1563 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1564 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1565 | "dev": true, 1566 | "requires": { 1567 | "color-convert": "^2.0.1" 1568 | } 1569 | }, 1570 | "color-convert": { 1571 | "version": "2.0.1", 1572 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1573 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1574 | "dev": true, 1575 | "requires": { 1576 | "color-name": "~1.1.4" 1577 | } 1578 | }, 1579 | "color-name": { 1580 | "version": "1.1.4", 1581 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1582 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1583 | "dev": true 1584 | }, 1585 | "has-flag": { 1586 | "version": "4.0.0", 1587 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1588 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1589 | "dev": true 1590 | }, 1591 | "supports-color": { 1592 | "version": "7.2.0", 1593 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 1594 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 1595 | "dev": true, 1596 | "requires": { 1597 | "has-flag": "^4.0.0" 1598 | } 1599 | } 1600 | } 1601 | }, 1602 | "chokidar": { 1603 | "version": "3.6.0", 1604 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", 1605 | "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", 1606 | "requires": { 1607 | "anymatch": "~3.1.2", 1608 | "braces": "~3.0.2", 1609 | "fsevents": "~2.3.2", 1610 | "glob-parent": "~5.1.2", 1611 | "is-binary-path": "~2.1.0", 1612 | "is-glob": "~4.0.1", 1613 | "normalize-path": "~3.0.0", 1614 | "readdirp": "~3.6.0" 1615 | } 1616 | }, 1617 | "concat-map": { 1618 | "version": "0.0.1", 1619 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1620 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 1621 | "dev": true 1622 | }, 1623 | "cross-spawn": { 1624 | "version": "7.0.3", 1625 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1626 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1627 | "dev": true, 1628 | "requires": { 1629 | "path-key": "^3.1.0", 1630 | "shebang-command": "^2.0.0", 1631 | "which": "^2.0.1" 1632 | } 1633 | }, 1634 | "debug": { 1635 | "version": "4.3.4", 1636 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1637 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1638 | "dev": true, 1639 | "requires": { 1640 | "ms": "2.1.2" 1641 | } 1642 | }, 1643 | "deep-is": { 1644 | "version": "0.1.4", 1645 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 1646 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 1647 | "dev": true 1648 | }, 1649 | "doctrine": { 1650 | "version": "3.0.0", 1651 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 1652 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 1653 | "dev": true, 1654 | "requires": { 1655 | "esutils": "^2.0.2" 1656 | } 1657 | }, 1658 | "escape-string-regexp": { 1659 | "version": "4.0.0", 1660 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 1661 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 1662 | "dev": true 1663 | }, 1664 | "eslint": { 1665 | "version": "8.57.1", 1666 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.1.tgz", 1667 | "integrity": "sha512-ypowyDxpVSYpkXr9WPv2PAZCtNip1Mv5KTW0SCurXv/9iOpcrH9PaqUElksqEB6pChqHGDRCFTyrZlGhnLNGiA==", 1668 | "dev": true, 1669 | "requires": { 1670 | "@eslint-community/eslint-utils": "^4.2.0", 1671 | "@eslint-community/regexpp": "^4.6.1", 1672 | "@eslint/eslintrc": "^2.1.4", 1673 | "@eslint/js": "8.57.1", 1674 | "@humanwhocodes/config-array": "^0.13.0", 1675 | "@humanwhocodes/module-importer": "^1.0.1", 1676 | "@nodelib/fs.walk": "^1.2.8", 1677 | "@ungap/structured-clone": "^1.2.0", 1678 | "ajv": "^6.12.4", 1679 | "chalk": "^4.0.0", 1680 | "cross-spawn": "^7.0.2", 1681 | "debug": "^4.3.2", 1682 | "doctrine": "^3.0.0", 1683 | "escape-string-regexp": "^4.0.0", 1684 | "eslint-scope": "^7.2.2", 1685 | "eslint-visitor-keys": "^3.4.3", 1686 | "espree": "^9.6.1", 1687 | "esquery": "^1.4.2", 1688 | "esutils": "^2.0.2", 1689 | "fast-deep-equal": "^3.1.3", 1690 | "file-entry-cache": "^6.0.1", 1691 | "find-up": "^5.0.0", 1692 | "glob-parent": "^6.0.2", 1693 | "globals": "^13.19.0", 1694 | "graphemer": "^1.4.0", 1695 | "ignore": "^5.2.0", 1696 | "imurmurhash": "^0.1.4", 1697 | "is-glob": "^4.0.0", 1698 | "is-path-inside": "^3.0.3", 1699 | "js-yaml": "^4.1.0", 1700 | "json-stable-stringify-without-jsonify": "^1.0.1", 1701 | "levn": "^0.4.1", 1702 | "lodash.merge": "^4.6.2", 1703 | "minimatch": "^3.1.2", 1704 | "natural-compare": "^1.4.0", 1705 | "optionator": "^0.9.3", 1706 | "strip-ansi": "^6.0.1", 1707 | "text-table": "^0.2.0" 1708 | }, 1709 | "dependencies": { 1710 | "glob-parent": { 1711 | "version": "6.0.2", 1712 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 1713 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 1714 | "dev": true, 1715 | "requires": { 1716 | "is-glob": "^4.0.3" 1717 | } 1718 | } 1719 | } 1720 | }, 1721 | "eslint-scope": { 1722 | "version": "7.2.2", 1723 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 1724 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 1725 | "dev": true, 1726 | "requires": { 1727 | "esrecurse": "^4.3.0", 1728 | "estraverse": "^5.2.0" 1729 | } 1730 | }, 1731 | "eslint-visitor-keys": { 1732 | "version": "3.4.3", 1733 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 1734 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 1735 | "dev": true 1736 | }, 1737 | "espree": { 1738 | "version": "9.6.1", 1739 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 1740 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 1741 | "dev": true, 1742 | "requires": { 1743 | "acorn": "^8.9.0", 1744 | "acorn-jsx": "^5.3.2", 1745 | "eslint-visitor-keys": "^3.4.1" 1746 | } 1747 | }, 1748 | "esquery": { 1749 | "version": "1.5.0", 1750 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 1751 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 1752 | "dev": true, 1753 | "requires": { 1754 | "estraverse": "^5.1.0" 1755 | } 1756 | }, 1757 | "esrecurse": { 1758 | "version": "4.3.0", 1759 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 1760 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 1761 | "dev": true, 1762 | "requires": { 1763 | "estraverse": "^5.2.0" 1764 | } 1765 | }, 1766 | "estraverse": { 1767 | "version": "5.3.0", 1768 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 1769 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 1770 | "dev": true 1771 | }, 1772 | "esutils": { 1773 | "version": "2.0.3", 1774 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1775 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1776 | "dev": true 1777 | }, 1778 | "fast-deep-equal": { 1779 | "version": "3.1.3", 1780 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1781 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1782 | "dev": true 1783 | }, 1784 | "fast-json-stable-stringify": { 1785 | "version": "2.1.0", 1786 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1787 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1788 | "dev": true 1789 | }, 1790 | "fast-levenshtein": { 1791 | "version": "2.0.6", 1792 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1793 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 1794 | "dev": true 1795 | }, 1796 | "fastq": { 1797 | "version": "1.15.0", 1798 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz", 1799 | "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==", 1800 | "dev": true, 1801 | "requires": { 1802 | "reusify": "^1.0.4" 1803 | } 1804 | }, 1805 | "file-entry-cache": { 1806 | "version": "6.0.1", 1807 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 1808 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 1809 | "dev": true, 1810 | "requires": { 1811 | "flat-cache": "^3.0.4" 1812 | } 1813 | }, 1814 | "fill-range": { 1815 | "version": "7.0.1", 1816 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1817 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1818 | "requires": { 1819 | "to-regex-range": "^5.0.1" 1820 | } 1821 | }, 1822 | "find-up": { 1823 | "version": "5.0.0", 1824 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1825 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1826 | "dev": true, 1827 | "requires": { 1828 | "locate-path": "^6.0.0", 1829 | "path-exists": "^4.0.0" 1830 | } 1831 | }, 1832 | "flat-cache": { 1833 | "version": "3.0.4", 1834 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 1835 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 1836 | "dev": true, 1837 | "requires": { 1838 | "flatted": "^3.1.0", 1839 | "rimraf": "^3.0.2" 1840 | } 1841 | }, 1842 | "flatted": { 1843 | "version": "3.1.1", 1844 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.1.1.tgz", 1845 | "integrity": "sha512-zAoAQiudy+r5SvnSw3KJy5os/oRJYHzrzja/tBDqrZtNhUw8bt6y8OBzMWcjWr+8liV8Eb6yOhw8WZ7VFZ5ZzA==", 1846 | "dev": true 1847 | }, 1848 | "fs.realpath": { 1849 | "version": "1.0.0", 1850 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1851 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1852 | "dev": true 1853 | }, 1854 | "fsevents": { 1855 | "version": "2.3.2", 1856 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1857 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1858 | "optional": true 1859 | }, 1860 | "glob": { 1861 | "version": "7.1.6", 1862 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1863 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1864 | "dev": true, 1865 | "requires": { 1866 | "fs.realpath": "^1.0.0", 1867 | "inflight": "^1.0.4", 1868 | "inherits": "2", 1869 | "minimatch": "^3.0.4", 1870 | "once": "^1.3.0", 1871 | "path-is-absolute": "^1.0.0" 1872 | } 1873 | }, 1874 | "glob-parent": { 1875 | "version": "5.1.2", 1876 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1877 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1878 | "requires": { 1879 | "is-glob": "^4.0.1" 1880 | } 1881 | }, 1882 | "globals": { 1883 | "version": "13.23.0", 1884 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.23.0.tgz", 1885 | "integrity": "sha512-XAmF0RjlrjY23MA51q3HltdlGxUpXPvg0GioKiD9X6HD28iMjo2dKC8Vqwm7lne4GNr78+RHTfliktR6ZH09wA==", 1886 | "dev": true, 1887 | "requires": { 1888 | "type-fest": "^0.20.2" 1889 | } 1890 | }, 1891 | "graphemer": { 1892 | "version": "1.4.0", 1893 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 1894 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 1895 | "dev": true 1896 | }, 1897 | "ignore": { 1898 | "version": "5.2.4", 1899 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", 1900 | "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", 1901 | "dev": true 1902 | }, 1903 | "import-fresh": { 1904 | "version": "3.3.0", 1905 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1906 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1907 | "dev": true, 1908 | "requires": { 1909 | "parent-module": "^1.0.0", 1910 | "resolve-from": "^4.0.0" 1911 | } 1912 | }, 1913 | "imurmurhash": { 1914 | "version": "0.1.4", 1915 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1916 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1917 | "dev": true 1918 | }, 1919 | "inflight": { 1920 | "version": "1.0.6", 1921 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1922 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1923 | "dev": true, 1924 | "requires": { 1925 | "once": "^1.3.0", 1926 | "wrappy": "1" 1927 | } 1928 | }, 1929 | "inherits": { 1930 | "version": "2.0.4", 1931 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1932 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1933 | "dev": true 1934 | }, 1935 | "is-binary-path": { 1936 | "version": "2.1.0", 1937 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1938 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1939 | "requires": { 1940 | "binary-extensions": "^2.0.0" 1941 | } 1942 | }, 1943 | "is-extglob": { 1944 | "version": "2.1.1", 1945 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1946 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=" 1947 | }, 1948 | "is-glob": { 1949 | "version": "4.0.3", 1950 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1951 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1952 | "requires": { 1953 | "is-extglob": "^2.1.1" 1954 | } 1955 | }, 1956 | "is-number": { 1957 | "version": "7.0.0", 1958 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1959 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==" 1960 | }, 1961 | "is-path-inside": { 1962 | "version": "3.0.3", 1963 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 1964 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 1965 | "dev": true 1966 | }, 1967 | "isexe": { 1968 | "version": "2.0.0", 1969 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1970 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1971 | "dev": true 1972 | }, 1973 | "js-yaml": { 1974 | "version": "4.1.0", 1975 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1976 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1977 | "dev": true, 1978 | "requires": { 1979 | "argparse": "^2.0.1" 1980 | } 1981 | }, 1982 | "json-schema-traverse": { 1983 | "version": "0.4.1", 1984 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1985 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1986 | "dev": true 1987 | }, 1988 | "json-stable-stringify-without-jsonify": { 1989 | "version": "1.0.1", 1990 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1991 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1992 | "dev": true 1993 | }, 1994 | "levn": { 1995 | "version": "0.4.1", 1996 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1997 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1998 | "dev": true, 1999 | "requires": { 2000 | "prelude-ls": "^1.2.1", 2001 | "type-check": "~0.4.0" 2002 | } 2003 | }, 2004 | "locate-path": { 2005 | "version": "6.0.0", 2006 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2007 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2008 | "dev": true, 2009 | "requires": { 2010 | "p-locate": "^5.0.0" 2011 | } 2012 | }, 2013 | "lodash.debounce": { 2014 | "version": "4.0.8", 2015 | "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", 2016 | "integrity": "sha1-gteb/zCmfEAF/9XiUVMArZyk168=" 2017 | }, 2018 | "lodash.merge": { 2019 | "version": "4.6.2", 2020 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2021 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2022 | "dev": true 2023 | }, 2024 | "lodash.throttle": { 2025 | "version": "4.1.1", 2026 | "resolved": "https://registry.npmjs.org/lodash.throttle/-/lodash.throttle-4.1.1.tgz", 2027 | "integrity": "sha1-wj6RtxAkKscMN/HhzaknTMOb8vQ=" 2028 | }, 2029 | "minimatch": { 2030 | "version": "3.1.2", 2031 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2032 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2033 | "dev": true, 2034 | "requires": { 2035 | "brace-expansion": "^1.1.7" 2036 | } 2037 | }, 2038 | "ms": { 2039 | "version": "2.1.2", 2040 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2041 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2042 | "dev": true 2043 | }, 2044 | "natural-compare": { 2045 | "version": "1.4.0", 2046 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2047 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2048 | "dev": true 2049 | }, 2050 | "normalize-path": { 2051 | "version": "3.0.0", 2052 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2053 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==" 2054 | }, 2055 | "once": { 2056 | "version": "1.4.0", 2057 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2058 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2059 | "dev": true, 2060 | "requires": { 2061 | "wrappy": "1" 2062 | } 2063 | }, 2064 | "optionator": { 2065 | "version": "0.9.3", 2066 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", 2067 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", 2068 | "dev": true, 2069 | "requires": { 2070 | "@aashutoshrathi/word-wrap": "^1.2.3", 2071 | "deep-is": "^0.1.3", 2072 | "fast-levenshtein": "^2.0.6", 2073 | "levn": "^0.4.1", 2074 | "prelude-ls": "^1.2.1", 2075 | "type-check": "^0.4.0" 2076 | } 2077 | }, 2078 | "p-limit": { 2079 | "version": "3.1.0", 2080 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2081 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2082 | "dev": true, 2083 | "requires": { 2084 | "yocto-queue": "^0.1.0" 2085 | } 2086 | }, 2087 | "p-locate": { 2088 | "version": "5.0.0", 2089 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2090 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2091 | "dev": true, 2092 | "requires": { 2093 | "p-limit": "^3.0.2" 2094 | } 2095 | }, 2096 | "parent-module": { 2097 | "version": "1.0.1", 2098 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2099 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2100 | "dev": true, 2101 | "requires": { 2102 | "callsites": "^3.0.0" 2103 | } 2104 | }, 2105 | "path-exists": { 2106 | "version": "4.0.0", 2107 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2108 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2109 | "dev": true 2110 | }, 2111 | "path-is-absolute": { 2112 | "version": "1.0.1", 2113 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2114 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2115 | "dev": true 2116 | }, 2117 | "path-key": { 2118 | "version": "3.1.1", 2119 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2120 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2121 | "dev": true 2122 | }, 2123 | "picomatch": { 2124 | "version": "2.3.1", 2125 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2126 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==" 2127 | }, 2128 | "prelude-ls": { 2129 | "version": "1.2.1", 2130 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2131 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2132 | "dev": true 2133 | }, 2134 | "punycode": { 2135 | "version": "2.3.0", 2136 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.0.tgz", 2137 | "integrity": "sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==", 2138 | "dev": true 2139 | }, 2140 | "queue-microtask": { 2141 | "version": "1.2.3", 2142 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2143 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2144 | "dev": true 2145 | }, 2146 | "readdirp": { 2147 | "version": "3.6.0", 2148 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 2149 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 2150 | "requires": { 2151 | "picomatch": "^2.2.1" 2152 | } 2153 | }, 2154 | "resolve-from": { 2155 | "version": "4.0.0", 2156 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2157 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2158 | "dev": true 2159 | }, 2160 | "reusify": { 2161 | "version": "1.0.4", 2162 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2163 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2164 | "dev": true 2165 | }, 2166 | "rimraf": { 2167 | "version": "3.0.2", 2168 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2169 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2170 | "dev": true, 2171 | "requires": { 2172 | "glob": "^7.1.3" 2173 | } 2174 | }, 2175 | "run-parallel": { 2176 | "version": "1.2.0", 2177 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2178 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2179 | "dev": true, 2180 | "requires": { 2181 | "queue-microtask": "^1.2.2" 2182 | } 2183 | }, 2184 | "shebang-command": { 2185 | "version": "2.0.0", 2186 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2187 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2188 | "dev": true, 2189 | "requires": { 2190 | "shebang-regex": "^3.0.0" 2191 | } 2192 | }, 2193 | "shebang-regex": { 2194 | "version": "3.0.0", 2195 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2196 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2197 | "dev": true 2198 | }, 2199 | "strip-ansi": { 2200 | "version": "6.0.1", 2201 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2202 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2203 | "dev": true, 2204 | "requires": { 2205 | "ansi-regex": "^5.0.1" 2206 | } 2207 | }, 2208 | "strip-json-comments": { 2209 | "version": "3.1.1", 2210 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2211 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2212 | "dev": true 2213 | }, 2214 | "text-table": { 2215 | "version": "0.2.0", 2216 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2217 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2218 | "dev": true 2219 | }, 2220 | "to-regex-range": { 2221 | "version": "5.0.1", 2222 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2223 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2224 | "requires": { 2225 | "is-number": "^7.0.0" 2226 | } 2227 | }, 2228 | "type-check": { 2229 | "version": "0.4.0", 2230 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2231 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2232 | "dev": true, 2233 | "requires": { 2234 | "prelude-ls": "^1.2.1" 2235 | } 2236 | }, 2237 | "type-fest": { 2238 | "version": "0.20.2", 2239 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 2240 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 2241 | "dev": true 2242 | }, 2243 | "typescript": { 2244 | "version": "5.9.3", 2245 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.9.3.tgz", 2246 | "integrity": "sha512-jl1vZzPDinLr9eUt3J/t7V6FgNEw9QjvBPdysz9KfQDD41fQrC2Y4vKQdiaUpFT4bXlb1RHhLpp8wtm6M5TgSw==", 2247 | "dev": true 2248 | }, 2249 | "undici-types": { 2250 | "version": "7.16.0", 2251 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-7.16.0.tgz", 2252 | "integrity": "sha512-Zz+aZWSj8LE6zoxD+xrjh4VfkIG8Ya6LvYkZqtUQGJPZjYl53ypCaUwWqo7eI0x66KBGeRo+mlBEkMSeSZ38Nw==", 2253 | "dev": true 2254 | }, 2255 | "uri-js": { 2256 | "version": "4.4.1", 2257 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 2258 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 2259 | "dev": true, 2260 | "requires": { 2261 | "punycode": "^2.1.0" 2262 | } 2263 | }, 2264 | "which": { 2265 | "version": "2.0.2", 2266 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2267 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2268 | "dev": true, 2269 | "requires": { 2270 | "isexe": "^2.0.0" 2271 | } 2272 | }, 2273 | "wrappy": { 2274 | "version": "1.0.2", 2275 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2276 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2277 | "dev": true 2278 | }, 2279 | "yocto-queue": { 2280 | "version": "0.1.0", 2281 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 2282 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 2283 | "dev": true 2284 | } 2285 | } 2286 | } 2287 | --------------------------------------------------------------------------------