diff --git a/eslint.config.js b/eslint.config.js index f12bf49d1f..589548155e 100644 --- a/eslint.config.js +++ b/eslint.config.js @@ -83,10 +83,13 @@ export default [ '@typescript-eslint/no-unsafe-assignment': 'off', '@typescript-eslint/no-unsafe-call': 'off', '@typescript-eslint/no-unsafe-member-access': 'off', + '@typescript-eslint/no-unused-expressions': 'off', + '@typescript-eslint/only-throw-error': 'off', '@typescript-eslint/no-unsafe-return': 'off', '@typescript-eslint/no-unnecessary-type-assertion': 'off', '@typescript-eslint/prefer-nullish-coalescing': 'off', '@typescript-eslint/prefer-optional-chain': 'off', + '@typescript-eslint/prefer-promise-reject-errors': 'off', '@typescript-eslint/prefer-string-starts-ends-with': 'off', '@typescript-eslint/require-await': 'off', '@typescript-eslint/restrict-plus-operands': 'off', diff --git a/package.json b/package.json index 0e7eec553b..e1737eb473 100644 --- a/package.json +++ b/package.json @@ -67,7 +67,7 @@ "prettier-plugin-astro": "^0.14.1", "turbo": "^1.13.4", "typescript": "~5.5.4", - "typescript-eslint": "^7.18.0" + "typescript-eslint": "^8.0.1" }, "pnpm": { "packageExtensions": { diff --git a/packages/astro-rss/src/util.ts b/packages/astro-rss/src/util.ts index 16db5b5871..a709d942d4 100644 --- a/packages/astro-rss/src/util.ts +++ b/packages/astro-rss/src/util.ts @@ -28,7 +28,7 @@ export function isValidURL(url: string): boolean { try { new URL(url); return true; - } catch (e) {} + } catch {} return false; } diff --git a/packages/astro/astro-jsx.d.ts b/packages/astro/astro-jsx.d.ts index a20baa5086..b26507d1db 100644 --- a/packages/astro/astro-jsx.d.ts +++ b/packages/astro/astro-jsx.d.ts @@ -14,7 +14,6 @@ declare namespace astroHTML.JSX { export type Children = Child | Child[]; interface ElementChildrenAttribute { - // eslint-disable-next-line @typescript-eslint/ban-types children: {}; } diff --git a/packages/astro/astro.js b/packages/astro/astro.js index 4ba0c800d6..38bb099edc 100755 --- a/packages/astro/astro.js +++ b/packages/astro/astro.js @@ -52,6 +52,7 @@ async function errorNodeUnsupported() { Node.js v${process.versions.node} is not supported by Astro! Please upgrade Node.js to a supported version: "${engines}"\n`); + // eslint-disable-next-line @typescript-eslint/no-require-imports const ci = typeof require !== 'undefined' ? require('ci-info') : await import('ci-info'); // Special instructions for CI environments, which may have special steps needed. diff --git a/packages/astro/src/@types/astro.ts b/packages/astro/src/@types/astro.ts index 32d1cd30b0..1a3cf60bb2 100644 --- a/packages/astro/src/@types/astro.ts +++ b/packages/astro/src/@types/astro.ts @@ -123,7 +123,7 @@ export type TransitionAnimationValue = | TransitionDirectionalAnimations; // Allow users to extend this for astro-jsx.d.ts -// eslint-disable-next-line @typescript-eslint/no-empty-interface +// eslint-disable-next-line @typescript-eslint/no-empty-object-type export interface AstroClientDirectives {} export interface AstroBuiltinAttributes { @@ -459,7 +459,6 @@ export interface ViteUserConfig extends vite.UserConfig { } export interface ImageServiceConfig = Record> { - // eslint-disable-next-line @typescript-eslint/ban-types entrypoint: 'astro/assets/services/sharp' | 'astro/assets/services/squoosh' | (string & {}); config?: T; } diff --git a/packages/astro/src/assets/build/generate.ts b/packages/astro/src/assets/build/generate.ts index c363a63497..52edeafbec 100644 --- a/packages/astro/src/assets/build/generate.ts +++ b/packages/astro/src/assets/build/generate.ts @@ -123,7 +123,7 @@ export async function generateImagesForPath( ); await fs.promises.unlink(getFullImagePath(originalFilePath, env)); } - } catch (e) { + } catch { /* No-op, it's okay if we fail to delete one of the file, we're not too picky. */ } } diff --git a/packages/astro/src/assets/endpoint/generic.ts b/packages/astro/src/assets/endpoint/generic.ts index 9ef87846c0..4180bffe2c 100644 --- a/packages/astro/src/assets/endpoint/generic.ts +++ b/packages/astro/src/assets/endpoint/generic.ts @@ -19,7 +19,7 @@ async function loadRemoteImage(src: URL, headers: Headers) { } return await res.arrayBuffer(); - } catch (err: unknown) { + } catch { return undefined; } } diff --git a/packages/astro/src/assets/endpoint/node.ts b/packages/astro/src/assets/endpoint/node.ts index d50e8b1938..b9db047f86 100644 --- a/packages/astro/src/assets/endpoint/node.ts +++ b/packages/astro/src/assets/endpoint/node.ts @@ -30,7 +30,7 @@ async function loadLocalImage(src: string, url: URL) { if (!isAbsolute(filePath) || !filePath.startsWith(assetsDirPath)) { return undefined; } - } catch (err: unknown) { + } catch{ return undefined; } } @@ -39,7 +39,7 @@ async function loadLocalImage(src: string, url: URL) { try { buffer = await readFile(fileUrl); - } catch (e) { + } catch { // Fallback to try to load the file using `fetch` try { const sourceUrl = new URL(src, url.origin); @@ -62,7 +62,7 @@ async function loadRemoteImage(src: URL) { } return Buffer.from(await res.arrayBuffer()); - } catch (err: unknown) { + } catch { return undefined; } } diff --git a/packages/astro/src/assets/services/sharp.ts b/packages/astro/src/assets/services/sharp.ts index 2493c53017..c9df4c269a 100644 --- a/packages/astro/src/assets/services/sharp.ts +++ b/packages/astro/src/assets/services/sharp.ts @@ -28,7 +28,7 @@ async function loadSharp() { let sharpImport: typeof import('sharp'); try { sharpImport = (await import('sharp')).default; - } catch (e) { + } catch { throw new AstroError(AstroErrorData.MissingSharp); } diff --git a/packages/astro/src/assets/services/vendor/squoosh/avif/avif_node_dec.ts b/packages/astro/src/assets/services/vendor/squoosh/avif/avif_node_dec.ts index 9e515108e7..2c49e7a521 100644 --- a/packages/astro/src/assets/services/vendor/squoosh/avif/avif_node_dec.ts +++ b/packages/astro/src/assets/services/vendor/squoosh/avif/avif_node_dec.ts @@ -1500,7 +1500,7 @@ var Module = (function () { wasmMemory.grow((size - buffer.byteLength + 65535) >>> 16) updateGlobalBufferAndViews(wasmMemory.buffer) return 1 - } catch (e) {} + } catch {} } function _emscripten_resize_heap(requestedSize) { var oldSize = HEAPU8.length diff --git a/packages/astro/src/assets/services/vendor/squoosh/avif/avif_node_enc.ts b/packages/astro/src/assets/services/vendor/squoosh/avif/avif_node_enc.ts index 0236e494be..f67d795bef 100644 --- a/packages/astro/src/assets/services/vendor/squoosh/avif/avif_node_enc.ts +++ b/packages/astro/src/assets/services/vendor/squoosh/avif/avif_node_enc.ts @@ -1660,7 +1660,7 @@ var Module = (function () { wasmMemory.grow((size - buffer.byteLength + 65535) >>> 16) updateGlobalBufferAndViews(wasmMemory.buffer) return 1 - } catch (e) {} + } catch {} } function _emscripten_resize_heap(requestedSize) { var oldSize = HEAPU8.length diff --git a/packages/astro/src/assets/services/vendor/squoosh/mozjpeg/mozjpeg_node_dec.ts b/packages/astro/src/assets/services/vendor/squoosh/mozjpeg/mozjpeg_node_dec.ts index f9f2bc6e18..1616199516 100644 --- a/packages/astro/src/assets/services/vendor/squoosh/mozjpeg/mozjpeg_node_dec.ts +++ b/packages/astro/src/assets/services/vendor/squoosh/mozjpeg/mozjpeg_node_dec.ts @@ -1504,7 +1504,7 @@ var Module = (function () { wasmMemory.grow((size - buffer.byteLength + 65535) >>> 16) updateGlobalBufferAndViews(wasmMemory.buffer) return 1 - } catch (e) {} + } catch {} } function _emscripten_resize_heap(requestedSize) { var oldSize = HEAPU8.length diff --git a/packages/astro/src/assets/services/vendor/squoosh/mozjpeg/mozjpeg_node_enc.ts b/packages/astro/src/assets/services/vendor/squoosh/mozjpeg/mozjpeg_node_enc.ts index 6adf50e8b3..1368557b64 100644 --- a/packages/astro/src/assets/services/vendor/squoosh/mozjpeg/mozjpeg_node_enc.ts +++ b/packages/astro/src/assets/services/vendor/squoosh/mozjpeg/mozjpeg_node_enc.ts @@ -1627,7 +1627,7 @@ var Module = (function () { wasmMemory.grow((size - buffer.byteLength + 65535) >>> 16) updateGlobalBufferAndViews(wasmMemory.buffer) return 1 - } catch (e) {} + } catch {} } function _emscripten_resize_heap(requestedSize) { var oldSize = HEAPU8.length diff --git a/packages/astro/src/assets/services/vendor/squoosh/utils/workerPool.ts b/packages/astro/src/assets/services/vendor/squoosh/utils/workerPool.ts index 6f953998e2..2f5778a062 100644 --- a/packages/astro/src/assets/services/vendor/squoosh/utils/workerPool.ts +++ b/packages/astro/src/assets/services/vendor/squoosh/utils/workerPool.ts @@ -1,4 +1,3 @@ -/* tslint-disable ban-types */ import { parentPort, Worker } from 'worker_threads'; function uuid() { diff --git a/packages/astro/src/assets/services/vendor/squoosh/webp/webp_node_dec.ts b/packages/astro/src/assets/services/vendor/squoosh/webp/webp_node_dec.ts index dafa790da4..be1ebe0e06 100644 --- a/packages/astro/src/assets/services/vendor/squoosh/webp/webp_node_dec.ts +++ b/packages/astro/src/assets/services/vendor/squoosh/webp/webp_node_dec.ts @@ -1476,7 +1476,7 @@ var Module = (function () { wasmMemory.grow((size - buffer.byteLength + 65535) >>> 16) updateGlobalBufferAndViews(wasmMemory.buffer) return 1 - } catch (e) {} + } catch {} } function _emscripten_resize_heap(requestedSize) { var oldSize = HEAPU8.length diff --git a/packages/astro/src/assets/services/vendor/squoosh/webp/webp_node_enc.ts b/packages/astro/src/assets/services/vendor/squoosh/webp/webp_node_enc.ts index 88d5d267fa..37983b654d 100644 --- a/packages/astro/src/assets/services/vendor/squoosh/webp/webp_node_enc.ts +++ b/packages/astro/src/assets/services/vendor/squoosh/webp/webp_node_enc.ts @@ -1656,7 +1656,7 @@ var Module = (function () { wasmMemory.grow((size - buffer.byteLength + 65535) >>> 16) updateGlobalBufferAndViews(wasmMemory.buffer) return 1 - } catch (e) {} + } catch {} } function _emscripten_resize_heap(requestedSize) { var oldSize = HEAPU8.length diff --git a/packages/astro/src/assets/types.ts b/packages/astro/src/assets/types.ts index 98f42c045c..6de28d43c6 100644 --- a/packages/astro/src/assets/types.ts +++ b/packages/astro/src/assets/types.ts @@ -1,4 +1,3 @@ -/* eslint-disable @typescript-eslint/ban-types */ import type { WithRequired } from '../type-utils.js'; import type { VALID_INPUT_FORMATS, VALID_OUTPUT_FORMATS } from './consts.js'; import type { ImageService } from './services/service.js'; diff --git a/packages/astro/src/assets/utils/metadata.ts b/packages/astro/src/assets/utils/metadata.ts index 8076d702fa..645a2a5c66 100644 --- a/packages/astro/src/assets/utils/metadata.ts +++ b/packages/astro/src/assets/utils/metadata.ts @@ -24,7 +24,7 @@ export async function imageMetadata( format: type as ImageInputFormat, orientation, }; - } catch (e) { + } catch { throw new AstroError({ ...AstroErrorData.NoImageMetadata, message: AstroErrorData.NoImageMetadata.message(src), diff --git a/packages/astro/src/assets/utils/node/emitAsset.ts b/packages/astro/src/assets/utils/node/emitAsset.ts index 3a590e3a68..09a9475387 100644 --- a/packages/astro/src/assets/utils/node/emitAsset.ts +++ b/packages/astro/src/assets/utils/node/emitAsset.ts @@ -24,7 +24,7 @@ export async function emitESMImage( let fileData: Buffer; try { fileData = await fs.readFile(url); - } catch (err) { + } catch { return undefined; } diff --git a/packages/astro/src/assets/utils/remoteProbe.ts b/packages/astro/src/assets/utils/remoteProbe.ts index c71413069e..32e237f890 100644 --- a/packages/astro/src/assets/utils/remoteProbe.ts +++ b/packages/astro/src/assets/utils/remoteProbe.ts @@ -42,7 +42,7 @@ export async function inferRemoteSize(url: string): Promise -1) { + if (globalOptions.disabledTypes.includes(type)) { throw new TypeError('disabled file type: ' + type) } diff --git a/packages/astro/src/assets/utils/vendor/image-size/types/svg.ts b/packages/astro/src/assets/utils/vendor/image-size/types/svg.ts index a0099d0a0a..ea5a05ac10 100644 --- a/packages/astro/src/assets/utils/vendor/image-size/types/svg.ts +++ b/packages/astro/src/assets/utils/vendor/image-size/types/svg.ts @@ -1,5 +1,5 @@ /* eslint-disable @typescript-eslint/non-nullable-type-assertion-style */ -/* eslint-disable regexp/prefer-regexp-exec */ + import type { IImage, ISize } from './interface.ts' import { toUTF8String } from './utils.js' @@ -52,9 +52,9 @@ function parseViewbox(viewbox: string): IAttributes { } function parseAttributes(root: string): IAttributes { - const width = root.match(extractorRegExps.width) - const height = root.match(extractorRegExps.height) - const viewbox = root.match(extractorRegExps.viewbox) + const width = extractorRegExps.width.exec(root) + const height = extractorRegExps.height.exec(root) + const viewbox = extractorRegExps.viewbox.exec(root) return { height: height && (parseLength(height[2]) as number), viewbox: viewbox && (parseViewbox(viewbox[2]) as IAttributes), @@ -94,7 +94,7 @@ export const SVG: IImage = { validate: (input) => svgReg.test(toUTF8String(input, 0, 1000)), calculate(input) { - const root = toUTF8String(input).match(extractorRegExps.root) + const root = extractorRegExps.root.exec(toUTF8String(input)) if (root) { const attrs = parseAttributes(root[0]) if (attrs.width && attrs.height) { diff --git a/packages/astro/src/cli/info/index.ts b/packages/astro/src/cli/info/index.ts index f7e8829a30..8a253f4373 100644 --- a/packages/astro/src/cli/info/index.ts +++ b/packages/astro/src/cli/info/index.ts @@ -71,7 +71,7 @@ async function copyToClipboard(text: string) { return; } command = 'xclip -sel clipboard -l 1'; - } catch (e) { + } catch { // Did not find xclip, bail out! return; } @@ -91,7 +91,7 @@ async function copyToClipboard(text: string) { input: text.trim(), encoding: 'utf8', }); - } catch (e) { + } catch { console.error( colors.red(`\nSorry, something went wrong!`) + ` Please copy the text above manually.` ); diff --git a/packages/astro/src/cli/install-package.ts b/packages/astro/src/cli/install-package.ts index be894bcf58..46dfac4a36 100644 --- a/packages/astro/src/cli/install-package.ts +++ b/packages/astro/src/cli/install-package.ts @@ -29,7 +29,7 @@ export async function getPackage( require.resolve(packageName, { paths: [options.cwd ?? process.cwd()] }); const packageImport = await import(packageName); return packageImport as T; - } catch (e) { + } catch { if (options.optional) return undefined; let message = `To continue, Astro requires the following dependency to be installed: ${bold( packageName @@ -207,7 +207,7 @@ async function getRegistry(): Promise { _registry = stdout?.trim()?.replace(/\/$/, '') || fallback; // Detect cases where the shell command returned a non-URL (e.g. a warning) if (!new URL(_registry).host) _registry = fallback; - } catch (e) { + } catch { _registry = fallback; } return _registry; diff --git a/packages/astro/src/core/base-pipeline.ts b/packages/astro/src/core/base-pipeline.ts index 56c6a7746e..b3884b841b 100644 --- a/packages/astro/src/core/base-pipeline.ts +++ b/packages/astro/src/core/base-pipeline.ts @@ -104,5 +104,5 @@ export abstract class Pipeline { abstract getComponentByRoute(routeData: RouteData): Promise; } -// eslint-disable-next-line @typescript-eslint/no-empty-interface +// eslint-disable-next-line @typescript-eslint/no-empty-object-type export interface HeadElements extends Pick {} diff --git a/packages/astro/src/core/build/plugins/util.ts b/packages/astro/src/core/build/plugins/util.ts index f1e2bf244a..de2c53e81e 100644 --- a/packages/astro/src/core/build/plugins/util.ts +++ b/packages/astro/src/core/build/plugins/util.ts @@ -3,7 +3,7 @@ import type { BuildOptions, Rollup, Plugin as VitePlugin } from 'vite'; import type { BuildInternals } from '../internal.js'; import type { PageBuildData } from '../types.js'; -// eslint-disable-next-line @typescript-eslint/ban-types +// eslint-disable-next-line @typescript-eslint/no-unsafe-function-type type OutputOptionsHook = Extract; type OutputOptions = Parameters[0]; diff --git a/packages/astro/src/core/config/schema.ts b/packages/astro/src/core/config/schema.ts index 3a1b89ec65..60941b17b5 100644 --- a/packages/astro/src/core/config/schema.ts +++ b/packages/astro/src/core/config/schema.ts @@ -34,7 +34,7 @@ import { appendForwardSlash, prependForwardSlash, removeTrailingForwardSlash } f // Also, make sure to not index the complexified type, as it would return a simplified value type, which goes // back to the issue again. The complexified type should be the base representation that we want to expose. -// eslint-disable-next-line @typescript-eslint/no-empty-interface +// eslint-disable-next-line @typescript-eslint/no-empty-object-type interface ComplexifyUnionObj {} type ComplexifyWithUnion = T & ComplexifyUnionObj; diff --git a/packages/astro/src/core/config/tsconfig.ts b/packages/astro/src/core/config/tsconfig.ts index 25c9b01ba4..9813b200d8 100644 --- a/packages/astro/src/core/config/tsconfig.ts +++ b/packages/astro/src/core/config/tsconfig.ts @@ -53,8 +53,7 @@ export const presets = new Map([ ], ]); -// eslint-disable-next-line @typescript-eslint/ban-types -type TSConfigResult = Promise< +type TSConfigResult = Promise< (TSConfckParseResult & T) | 'invalid-config' | 'missing-config' | 'unknown-error' >; diff --git a/packages/astro/src/core/dev/dev.ts b/packages/astro/src/core/dev/dev.ts index ee1254f5fb..25165f0280 100644 --- a/packages/astro/src/core/dev/dev.ts +++ b/packages/astro/src/core/dev/dev.ts @@ -76,7 +76,7 @@ export default async function dev(inlineConfig: AstroInlineConfig): Promise {}); - } catch (e) { + } catch { // Just ignore the error, we don't want to block the dev server from starting and this is just a nice-to-have feature } } diff --git a/packages/astro/src/core/errors/dev/vite.ts b/packages/astro/src/core/errors/dev/vite.ts index b63d696f50..cc723e6493 100644 --- a/packages/astro/src/core/errors/dev/vite.ts +++ b/packages/astro/src/core/errors/dev/vite.ts @@ -66,7 +66,7 @@ export function enhanceViteSSRError({ if ( fileId && !renderers?.find((r) => r.name === '@astrojs/mdx') && - /Syntax error/.test(safeError.message) && + safeError.message.includes('Syntax error') && /.mdx$/.test(fileId) ) { safeError = new AstroError({ @@ -78,7 +78,7 @@ export function enhanceViteSSRError({ } // Since Astro.glob is a wrapper around Vite's import.meta.glob, errors don't show accurate information, let's fix that - if (/Invalid glob/.test(safeError.message)) { + if (safeError.message.includes('Invalid glob')) { const globPattern = /glob: "(.+)" \(/.exec(safeError.message)?.[1]; if (globPattern) { diff --git a/packages/astro/src/core/routing/manifest/create.ts b/packages/astro/src/core/routing/manifest/create.ts index b022c383b9..a92d089eff 100644 --- a/packages/astro/src/core/routing/manifest/create.ts +++ b/packages/astro/src/core/routing/manifest/create.ts @@ -74,7 +74,7 @@ export function getParts(part: string, file: string) { export function validateSegment(segment: string, file = '') { if (!file) file = segment; - if (/\]\[/.test(segment)) { + if (segment.includes('][')) { throw new Error(`Invalid route ${file} \u2014 parameters must be separated`); } if (countOccurrences('[', segment) !== countOccurrences(']', segment)) { @@ -293,7 +293,7 @@ function createInjectedRoutes({ settings, cwd }: CreateRouteManifestParams): Pri let resolved: string; try { resolved = require.resolve(entrypoint, { paths: [cwd || fileURLToPath(config.root)] }); - } catch (e) { + } catch { resolved = fileURLToPath(new URL(entrypoint, config.root)); } const component = slash(path.relative(cwd || fileURLToPath(config.root), resolved)); diff --git a/packages/astro/src/env/schema.ts b/packages/astro/src/env/schema.ts index 4052a1c8e1..bd88fbb46e 100644 --- a/packages/astro/src/env/schema.ts +++ b/packages/astro/src/env/schema.ts @@ -96,7 +96,6 @@ export const EnvSchema = z.record(EnvSchemaKey, z.intersection(EnvFieldMetadata, // https://www.totaltypescript.com/concepts/the-prettify-helper type Prettify = { [K in keyof T]: T[K]; - // eslint-disable-next-line @typescript-eslint/ban-types } & {}; export type EnvSchema = z.infer; diff --git a/packages/astro/src/events/error.ts b/packages/astro/src/events/error.ts index 77de088c57..97b9f49dba 100644 --- a/packages/astro/src/events/error.ts +++ b/packages/astro/src/events/error.ts @@ -82,7 +82,7 @@ export function eventError({ /** * Safely get the error message from an error, even if it's a function. */ -// eslint-disable-next-line @typescript-eslint/ban-types +// eslint-disable-next-line @typescript-eslint/no-unsafe-function-type function getSafeErrorMessage(message: string | Function): string { if (typeof message === 'string') { return message; diff --git a/packages/astro/src/events/toolbar.ts b/packages/astro/src/events/toolbar.ts index c9207a3fad..995cb463e8 100644 --- a/packages/astro/src/events/toolbar.ts +++ b/packages/astro/src/events/toolbar.ts @@ -5,7 +5,6 @@ interface AppToggledEventPayload { } export function eventAppToggled(options: { - // eslint-disable-next-line @typescript-eslint/ban-types appName: 'other' | (string & {}); }): { eventName: string; payload: AppToggledEventPayload }[] { const payload: AppToggledEventPayload = { diff --git a/packages/astro/src/runtime/client/dev-toolbar/apps/audit/index.ts b/packages/astro/src/runtime/client/dev-toolbar/apps/audit/index.ts index 251193434b..703b0a523e 100644 --- a/packages/astro/src/runtime/client/dev-toolbar/apps/audit/index.ts +++ b/packages/astro/src/runtime/client/dev-toolbar/apps/audit/index.ts @@ -21,7 +21,7 @@ export type Audit = { try { customElements.define('astro-dev-toolbar-audit-window', DevToolbarAuditListWindow); customElements.define('astro-dev-toolbar-audit-list-item', DevToolbarAuditListItem); -} catch (e) {} +} catch {} let showState = false; diff --git a/packages/astro/src/runtime/server/render/component.ts b/packages/astro/src/runtime/server/render/component.ts index 7a9eb84197..56cf8d6121 100644 --- a/packages/astro/src/runtime/server/render/component.ts +++ b/packages/astro/src/runtime/server/render/component.ts @@ -179,9 +179,9 @@ async function renderFrameworkComponent( // Attempt: can we guess the renderer from the export extension? if (!renderer) { const extname = metadata.componentUrl?.split('.').pop(); - renderer = renderers.filter( + renderer = renderers.find( ({ name }) => name === `@astrojs/${extname}` || name === extname - )[0]; + ); } } diff --git a/packages/astro/src/transitions/router.ts b/packages/astro/src/transitions/router.ts index 673eb4eb23..8f849f6aae 100644 --- a/packages/astro/src/transitions/router.ts +++ b/packages/astro/src/transitions/router.ts @@ -118,7 +118,7 @@ async function fetchHTML( redirected: res.redirected ? res.url : undefined, mediaType, }; - } catch (err) { + } catch { // can't fetch, let someone else deal with it. return null; } @@ -290,7 +290,7 @@ async function updateDOM( ) { try { await animate('old'); - } catch (err) { + } catch { // animate might reject as a consequence of a call to skipTransition() // ignored on purpose } diff --git a/packages/astro/src/type-utils.ts b/packages/astro/src/type-utils.ts index efd234b0ec..daf1052e14 100644 --- a/packages/astro/src/type-utils.ts +++ b/packages/astro/src/type-utils.ts @@ -1,4 +1,3 @@ -/* eslint-disable @typescript-eslint/ban-types */ // Q: Why is this not in @types? // A: `@types` is for types that are part of the public API. This is just a bunch of utilities we use throughout the codebase. (Mostly by Erika) @@ -12,7 +11,7 @@ export type WithRequired = T & { [P in K]-?: T[P] }; // Name is pretty self descriptive, but it removes the index signature of an object export type OmitIndexSignature = { - [KeyType in keyof ObjectType as {} extends Record + [KeyType in keyof ObjectType as object extends Record ? never : KeyType]: ObjectType[KeyType]; }; diff --git a/packages/astro/src/vite-plugin-astro-server/vite.ts b/packages/astro/src/vite-plugin-astro-server/vite.ts index eba9a81d11..bd327081b5 100644 --- a/packages/astro/src/vite-plugin-astro-server/vite.ts +++ b/packages/astro/src/vite-plugin-astro-server/vite.ts @@ -12,7 +12,6 @@ import { isCSSRequest } from './util.js'; const fileExtensionsToSSR = new Set(['.astro', '.mdoc', ...SUPPORTED_MARKDOWN_FILE_EXTENSIONS]); const STRIP_QUERY_PARAMS_REGEX = /\?.*$/; -const ASTRO_PROPAGATED_ASSET_REGEX = /\?astroPropagatedAssets/; /** recursively crawl the module graph to get all style files imported by parent id */ export async function* crawlGraph( @@ -78,7 +77,7 @@ export async function* crawlGraph( const isFileTypeNeedingSSR = fileExtensionsToSSR.has(npath.extname(importedModulePathname)); // A propagation stopping point is a module with the ?astroPropagatedAssets flag. // When we encounter one of these modules we don't want to continue traversing. - const isPropagationStoppingPoint = ASTRO_PROPAGATED_ASSET_REGEX.test(importedModule.id); + const isPropagationStoppingPoint = importedModule.id.includes('?astroPropagatedAssets'); if ( isFileTypeNeedingSSR && // Should not SSR a module with ?astroPropagatedAssets diff --git a/packages/astro/src/vite-plugin-load-fallback/index.ts b/packages/astro/src/vite-plugin-load-fallback/index.ts index 80db39edd4..8b7f42bcc2 100644 --- a/packages/astro/src/vite-plugin-load-fallback/index.ts +++ b/packages/astro/src/vite-plugin-load-fallback/index.ts @@ -27,14 +27,14 @@ export default function loadFallbackPlugin({ try { // await is necessary for the catch return await fs.promises.readFile(cleanUrl(id), 'utf-8'); - } catch (e) { + } catch{ try { return await fs.promises.readFile(id, 'utf-8'); - } catch (e2) { + } catch { try { const fullpath = new URL('.' + id, root); return await fs.promises.readFile(fullpath, 'utf-8'); - } catch (e3) { + } catch { // Let fall through to the next } } diff --git a/packages/astro/src/vite-plugin-scanner/index.ts b/packages/astro/src/vite-plugin-scanner/index.ts index 180c2b3905..ecb9c12a51 100644 --- a/packages/astro/src/vite-plugin-scanner/index.ts +++ b/packages/astro/src/vite-plugin-scanner/index.ts @@ -31,7 +31,7 @@ export default function astroScannerPlugin({ let fileURL: URL; try { fileURL = new URL(`file://${filename}`); - } catch (e) { + } catch { // If we can't construct a valid URL, exit early return; } diff --git a/packages/astro/src/vite-plugin-scripts/page-ssr.ts b/packages/astro/src/vite-plugin-scripts/page-ssr.ts index 8687bb8f87..00e907b03c 100644 --- a/packages/astro/src/vite-plugin-scripts/page-ssr.ts +++ b/packages/astro/src/vite-plugin-scripts/page-ssr.ts @@ -22,7 +22,7 @@ export default function astroScriptsPostPlugin({ let fileURL: URL; try { fileURL = new URL(`file://${filename}`); - } catch (e) { + } catch { // If we can't construct a valid URL, exit early return; } diff --git a/packages/astro/test/cli.test.js b/packages/astro/test/cli.test.js index c406ab39cb..f92ed45aa4 100644 --- a/packages/astro/test/cli.test.js +++ b/packages/astro/test/cli.test.js @@ -88,7 +88,7 @@ describe('astro cli', () => { const projectRootURL = new URL('./fixtures/astro-check-no-errors/', import.meta.url); try { proc = await cli('check', '--root', fileURLToPath(projectRootURL)); - } catch (err) {} + } catch {} assert.equal(proc?.stdout.includes('0 errors'), true); } diff --git a/packages/astro/test/config-mode.test.js b/packages/astro/test/config-mode.test.js index 99ad99e1cc..16baf95d52 100644 --- a/packages/astro/test/config-mode.test.js +++ b/packages/astro/test/config-mode.test.js @@ -75,7 +75,7 @@ describe('AstroConfig - config.output', () => { let html; try { html = await fixture.readFile('/index.html'); - } catch (err) { + } catch { assert.equal(false, true, 'Couldnt find the file, which mean it did not build.'); } assert.equal(html.length > 0, true); diff --git a/packages/astro/test/core-image.test.js b/packages/astro/test/core-image.test.js index 2943f31775..396b1e5cd9 100644 --- a/packages/astro/test/core-image.test.js +++ b/packages/astro/test/core-image.test.js @@ -1156,7 +1156,6 @@ describe('astro:image', () => { const app = await fixture.loadTestAdapterApp(); let request = new Request('http://example.com/'); let response = await app.render(request); - console.log; assert.equal(response.status, 200); const html = await response.text(); const $ = cheerio.load(html); diff --git a/packages/astro/test/css-order-layout.test.js b/packages/astro/test/css-order-layout.test.js index 3ce08a7b3f..1871e812b7 100644 --- a/packages/astro/test/css-order-layout.test.js +++ b/packages/astro/test/css-order-layout.test.js @@ -51,9 +51,9 @@ describe('CSS ordering - import order with layouts', () => { let specialButtonCSS = -1; let globalCSS = -1; for (let i = 0; i < content.length; i++) { - if (content[i].css.indexOf('.SpecialButton') !== -1) { + if (content[i].css.includes('.SpecialButton')) { specialButtonCSS = i; - } else if (content[i].css.indexOf('green') !== -1) { + } else if (content[i].css.includes('green')) { globalCSS = i; } } diff --git a/packages/astro/test/i18n-routing-manual-with-default-middleware.test.js b/packages/astro/test/i18n-routing-manual-with-default-middleware.test.js index 4c3f24489c..af900a43b5 100644 --- a/packages/astro/test/i18n-routing-manual-with-default-middleware.test.js +++ b/packages/astro/test/i18n-routing-manual-with-default-middleware.test.js @@ -61,7 +61,7 @@ describe('SSG manual routing', () => { try { await fixture.readFile('/blog.html'); assert.fail(); - } catch (e) {} + } catch {} }); it('should return a 200 because the custom middleware allows it', async () => { diff --git a/packages/astro/test/middleware.test.js b/packages/astro/test/middleware.test.js index 239a20a26e..b539b467ff 100644 --- a/packages/astro/test/middleware.test.js +++ b/packages/astro/test/middleware.test.js @@ -313,7 +313,7 @@ describe('Middleware API in PROD mode, SSR', () => { assert.equal(existsSync(path), true); const content = readFileSync(fileURLToPath(middlewarePath), 'utf-8'); assert.equal(content.length > 0, true); - } catch (e) { + } catch { assert.fail(); } }); diff --git a/packages/astro/test/types/action-return-type.ts b/packages/astro/test/types/action-return-type.ts index d0ac105623..05add9cb3f 100644 --- a/packages/astro/test/types/action-return-type.ts +++ b/packages/astro/test/types/action-return-type.ts @@ -9,6 +9,7 @@ import { z } from '../../zod.mjs'; describe('ActionReturnType', () => { it('Infers action return type', async () => { + // eslint-disable-next-line @typescript-eslint/no-unused-vars const action = defineAction({ input: z.object({ name: z.string(), diff --git a/packages/astro/test/types/call-action.ts b/packages/astro/test/types/call-action.ts index 644619132d..9161055858 100644 --- a/packages/astro/test/types/call-action.ts +++ b/packages/astro/test/types/call-action.ts @@ -15,6 +15,7 @@ describe('Astro.callAction', () => { return { name }; }, }); + // eslint-disable-next-line @typescript-eslint/no-unused-vars const result = await context.callAction(action, { name: 'Ben' }); expectTypeOf().toEqualTypeOf>(); }); @@ -30,6 +31,7 @@ describe('Astro.callAction', () => { return { name }; }, }); + // eslint-disable-next-line @typescript-eslint/no-unused-vars const result = await context.callAction(action, new FormData()); expectTypeOf().toEqualTypeOf>(); }); @@ -45,6 +47,7 @@ describe('Astro.callAction', () => { return { name }; }, }); + // eslint-disable-next-line @typescript-eslint/no-unused-vars const result = await context.callAction(action.orThrow, new FormData()); expectTypeOf().toEqualTypeOf>(); }); diff --git a/packages/astro/test/units/cookies/delete.test.js b/packages/astro/test/units/cookies/delete.test.js index 39a5d7daed..539c796b00 100644 --- a/packages/astro/test/units/cookies/delete.test.js +++ b/packages/astro/test/units/cookies/delete.test.js @@ -62,14 +62,14 @@ describe('astro/src/core/cookies', () => { let headers = Array.from(cookies.headers()); assert.equal(headers.length, 1); - assert.equal(/foo=deleted/.test(headers[0]), true); - assert.equal(/Expires=Thu, 01 Jan 1970 00:00:00 GMT/.test(headers[0]), true); + assert.equal(headers[0].includes('foo=deleted'), true); + assert.equal(headers[0].includes('Expires=Thu, 01 Jan 1970 00:00:00 GMT'), true); assert.equal(/Domain=example.com/.test(headers[0]), true); - assert.equal(/Path=\/subpath\//.test(headers[0]), true); - assert.equal(/Priority=High/.test(headers[0]), true); - assert.equal(/Secure/.test(headers[0]), true); - assert.equal(/HttpOnly/.test(headers[0]), true); - assert.equal(/SameSite=Strict/.test(headers[0]), true); + assert.equal(headers[0].includes('Path=/subpath/'), true); + assert.equal(headers[0].includes('Priority=High'), true); + assert.equal(headers[0].includes('Secure'), true); + assert.equal(headers[0].includes('HttpOnly'), true); + assert.equal(headers[0].includes('SameSite=Strict'), true); }); it('ignores expires option', () => { @@ -82,8 +82,8 @@ describe('astro/src/core/cookies', () => { let headers = Array.from(cookies.headers()); assert.equal(headers.length, 1); - assert.equal(/foo=deleted/.test(headers[0]), true); - assert.equal(/Expires=Thu, 01 Jan 1970 00:00:00 GMT/.test(headers[0]), true); + assert.equal(headers[0].includes('foo=deleted'), true); + assert.equal(headers[0].includes('Expires=Thu, 01 Jan 1970 00:00:00 GMT'), true); }); it('ignores maxAge option', () => { @@ -96,8 +96,8 @@ describe('astro/src/core/cookies', () => { let headers = Array.from(cookies.headers()); assert.equal(headers.length, 1); - assert.equal(/foo=deleted/.test(headers[0]), true); - assert.equal(/Expires=Thu, 01 Jan 1970 00:00:00 GMT/.test(headers[0]), true); + assert.equal(headers[0].includes('foo=deleted'), true); + assert.equal(headers[0].includes('Expires=Thu, 01 Jan 1970 00:00:00 GMT'), true); }); }); }); diff --git a/packages/astro/test/units/dev/dev.test.js b/packages/astro/test/units/dev/dev.test.js index 85f584e9c3..1ef0ed90b1 100644 --- a/packages/astro/test/units/dev/dev.test.js +++ b/packages/astro/test/units/dev/dev.test.js @@ -200,7 +200,7 @@ describe('dev container', () => { container.handle(r.req, r.res); await r.done; const doc = await r.text(); - assert.equal(/Regular page/.test(doc), true); + assert.equal(doc.includes('Regular page'), true); assert.equal(r.res.statusCode, 200); } { @@ -209,7 +209,7 @@ describe('dev container', () => { container.handle(r.req, r.res); await r.done; const doc = await r.text(); - assert.equal(/Custom 404/.test(doc), true); + assert.equal(doc.includes('Custom 404'), true); assert.equal(r.res.statusCode, 404); } { @@ -218,7 +218,7 @@ describe('dev container', () => { container.handle(r.req, r.res); await r.done; const doc = await r.text(); - assert.equal(/Custom 404/.test(doc), true); + assert.equal(doc.includes('Custom 404'), true); assert.equal(r.res.statusCode, 404); } } diff --git a/packages/astro/test/units/render/chunk.test.js b/packages/astro/test/units/render/chunk.test.js index f34e3d0908..176e5fa1d3 100644 --- a/packages/astro/test/units/render/chunk.test.js +++ b/packages/astro/test/units/render/chunk.test.js @@ -44,7 +44,7 @@ describe('core/render chunk', () => { assert.ok(target); assert.equal(target.text(), '[object Object]'); - } catch (e) { + } catch { assert.fail(); } } diff --git a/packages/astro/test/units/test-utils.js b/packages/astro/test/units/test-utils.js index 668e71574e..88092c891d 100644 --- a/packages/astro/test/units/test-utils.js +++ b/packages/astro/test/units/test-utils.js @@ -82,7 +82,7 @@ class VirtualVolumeWithFallback extends VirtualVolume { readFileSync(p, ...args) { try { return super.readFileSync(p, ...args); - } catch (e) { + } catch { return realFS.readFileSync(p, ...args); } } diff --git a/packages/create-astro/src/actions/git.ts b/packages/create-astro/src/actions/git.ts index bd038f3f52..d75ed18ccb 100644 --- a/packages/create-astro/src/actions/git.ts +++ b/packages/create-astro/src/actions/git.ts @@ -60,5 +60,5 @@ async function init({ cwd }: { cwd: string }) { ], { cwd, stdio: 'ignore' } ); - } catch (e) {} + } catch {} } diff --git a/packages/create-astro/src/messages.ts b/packages/create-astro/src/messages.ts index eeeba5a504..2ea25f2203 100644 --- a/packages/create-astro/src/messages.ts +++ b/packages/create-astro/src/messages.ts @@ -18,7 +18,7 @@ async function getRegistry(packageManager: string): Promise { _registry = stdout?.trim()?.replace(/\/$/, '') || fallback; // Detect cases where the shell command returned a non-URL (e.g. a warning) if (!new URL(_registry).host) _registry = fallback; - } catch (e) { + } catch { _registry = fallback; } return _registry; diff --git a/packages/create-astro/src/shell.ts b/packages/create-astro/src/shell.ts index e6f1295ea3..8ce3031bef 100644 --- a/packages/create-astro/src/shell.ts +++ b/packages/create-astro/src/shell.ts @@ -37,7 +37,7 @@ export async function shell( const done = new Promise((resolve) => child.on('close', resolve)); [stdout, stderr] = await Promise.all([text(child.stdout), text(child.stderr)]); await done; - } catch (e) { + } catch { throw { stdout, stderr, exitCode: 1 }; } const { exitCode } = child; diff --git a/packages/db/src/core/queries.ts b/packages/db/src/core/queries.ts index 200476c148..70ea0cf0e4 100644 --- a/packages/db/src/core/queries.ts +++ b/packages/db/src/core/queries.ts @@ -190,7 +190,7 @@ function getDefaultValueSql(columnName: string, column: DBColumnWithDefault): st let stringified = ''; try { stringified = JSON.stringify(column.schema.default); - } catch (e) { + } catch { // eslint-disable-next-line no-console console.log( `Invalid default value for column ${bold( diff --git a/packages/db/src/runtime/db-client.ts b/packages/db/src/runtime/db-client.ts index 8c33b20391..a43bb4d785 100644 --- a/packages/db/src/runtime/db-client.ts +++ b/packages/db/src/runtime/db-client.ts @@ -64,7 +64,7 @@ export function createRemoteDatabaseClient(appToken: string, remoteDbURL: string try { const json = await res.json(); remoteResult = remoteResultSchema.parse(json); - } catch (e) { + } catch { throw new DetailedLibsqlError({ message: await getUnexpectedResponseMessage(res), code: KNOWN_ERROR_CODES.SQL_QUERY_FAILED, @@ -125,7 +125,7 @@ export function createRemoteDatabaseClient(appToken: string, remoteDbURL: string try { const json = await res.json(); remoteResults = z.array(remoteResultSchema).parse(json); - } catch (e) { + } catch { throw new DetailedLibsqlError({ message: await getUnexpectedResponseMessage(res), code: KNOWN_ERROR_CODES.SQL_QUERY_FAILED, @@ -181,7 +181,7 @@ async function parseRemoteError(response: Response): Promise // It also might render an empty sting. - return html == '' ? false : !//.test(html); - } catch (err) { + return html == '' ? false : !html.includes(''); + } catch { return false; } } finally { @@ -108,7 +108,7 @@ function useConsoleFilter() { try { console.error = filteredConsoleError; - } catch (error) { + } catch { // If we're unable to hook `console.error`, just accept it } } diff --git a/packages/integrations/svelte/client.js b/packages/integrations/svelte/client.js index c9552c841e..056fd19c77 100644 --- a/packages/integrations/svelte/client.js +++ b/packages/integrations/svelte/client.js @@ -77,7 +77,7 @@ function useConsoleFilter() { originalConsoleWarning = console.warn; try { console.warn = filteredConsoleWarning; - } catch (error) { + } catch { // If we're unable to hook `console.warn`, just accept it } } diff --git a/packages/integrations/svelte/src/editor.cts b/packages/integrations/svelte/src/editor.cts index 2d426cf1bb..b61c0e74d4 100644 --- a/packages/integrations/svelte/src/editor.cts +++ b/packages/integrations/svelte/src/editor.cts @@ -13,7 +13,7 @@ export function toTSX(code: string, className: string): string { 'export default class extends __sveltets_2_createSvelte2TsxComponent(', `export default function ${className}__AstroComponent_(_props: typeof Component.props): any {}\nlet Component = ` ); - } catch (e: any) { + } catch { return result; } diff --git a/packages/integrations/tailwind/src/index.ts b/packages/integrations/tailwind/src/index.ts index 1da44f5dd4..c52e1f6e54 100644 --- a/packages/integrations/tailwind/src/index.ts +++ b/packages/integrations/tailwind/src/index.ts @@ -15,7 +15,7 @@ async function getPostCssConfig( const searchPath = typeof postcssInlineOptions === 'string' ? postcssInlineOptions : root!; try { postcssConfigResult = await postcssrc({}, searchPath); - } catch (e) { + } catch { postcssConfigResult = null; } } diff --git a/packages/integrations/vercel/src/image/shared.ts b/packages/integrations/vercel/src/image/shared.ts index 079186e187..f15d81516a 100644 --- a/packages/integrations/vercel/src/image/shared.ts +++ b/packages/integrations/vercel/src/image/shared.ts @@ -13,7 +13,6 @@ export function isESMImportedImage(src: ImageMetadata | string): src is ImageMet return typeof src === 'object'; } -// eslint-disable-next-line @typescript-eslint/ban-types export type DevImageService = 'sharp' | 'squoosh' | (string & {}); // https://vercel.com/docs/build-output-api/v3/configuration#images diff --git a/packages/integrations/vue/src/editor.cts b/packages/integrations/vue/src/editor.cts index 64b34b45b1..96d8f8e714 100644 --- a/packages/integrations/vue/src/editor.cts +++ b/packages/integrations/vue/src/editor.cts @@ -57,7 +57,7 @@ export function toTSX(code: string, className: string): string { } } } - } catch (e: any) { + } catch { return result; } diff --git a/packages/markdown/remark/src/index.ts b/packages/markdown/remark/src/index.ts index 00d6d64ca1..14d24f76d7 100644 --- a/packages/markdown/remark/src/index.ts +++ b/packages/markdown/remark/src/index.ts @@ -158,7 +158,7 @@ function prefixError(err: any, prefix: string) { try { err.message = `${prefix}:\n${err.message}`; return err; - } catch (error) { + } catch { // Any errors here are ok, there's fallback code below } } diff --git a/packages/studio/src/core/tokens.ts b/packages/studio/src/core/tokens.ts index cf343fb8f6..4a4ec53c18 100644 --- a/packages/studio/src/core/tokens.ts +++ b/packages/studio/src/core/tokens.ts @@ -160,7 +160,7 @@ class ManagedRemoteAppToken implements ManagedAppToken { export async function getProjectIdFromFile() { try { return await readFile(PROJECT_ID_FILE, 'utf-8'); - } catch (error) { + } catch { return undefined; } } @@ -168,7 +168,7 @@ export async function getProjectIdFromFile() { export async function getSessionIdFromFile() { try { return await readFile(SESSION_LOGIN_FILE, 'utf-8'); - } catch (error) { + } catch { return undefined; } } diff --git a/packages/upgrade/src/messages.ts b/packages/upgrade/src/messages.ts index 4fe1810940..7bc06724b2 100644 --- a/packages/upgrade/src/messages.ts +++ b/packages/upgrade/src/messages.ts @@ -20,7 +20,7 @@ export async function getRegistry(): Promise { _registry = stdout?.trim()?.replace(/\/$/, '') || fallback; // Detect cases where the shell command returned a non-URL (e.g. a warning) if (!new URL(_registry).host) _registry = fallback; - } catch (e) { + } catch { _registry = fallback; } return _registry; diff --git a/packages/upgrade/src/shell.ts b/packages/upgrade/src/shell.ts index 65a83327d8..863e26f649 100644 --- a/packages/upgrade/src/shell.ts +++ b/packages/upgrade/src/shell.ts @@ -46,7 +46,7 @@ export async function shell( const done = new Promise((resolve) => child.on('close', resolve)); [stdout, stderr] = await Promise.all([text(child.stdout), text(child.stderr)]); await done; - } catch (e) { + } catch { throw { stdout, stderr, exitCode: 1 }; } const { exitCode } = child; diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index a7b0a33ec2..fc05d67d6e 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -60,8 +60,8 @@ importers: specifier: ~5.5.4 version: 5.5.4 typescript-eslint: - specifier: ^7.18.0 - version: 7.18.0(eslint@9.8.0)(typescript@5.5.4) + specifier: ^8.0.1 + version: 8.0.1(eslint@9.8.0)(typescript@5.5.4) benchmark: dependencies: @@ -7481,63 +7481,62 @@ packages: '@types/yargs-parser@21.0.3': resolution: {integrity: sha512-I4q9QU9MQv4oEOz4tAHJtNz1cwuLxn2F3xcc2iV5WdqLPpUnj30aUuxt1mAxYTG+oe8CZMV/+6rU4S4gRDzqtQ==} - '@typescript-eslint/eslint-plugin@7.18.0': - resolution: {integrity: sha512-94EQTWZ40mzBc42ATNIBimBEDltSJ9RQHCC8vc/PDbxi4k8dVwUAv4o98dk50M1zB+JGFxp43FP7f8+FP8R6Sw==} - engines: {node: ^18.18.0 || >=20.0.0} + '@typescript-eslint/eslint-plugin@8.0.1': + resolution: {integrity: sha512-5g3Y7GDFsJAnY4Yhvk8sZtFfV6YNF2caLzjrRPUBzewjPCaj0yokePB4LJSobyCzGMzjZZYFbwuzbfDHlimXbQ==} + engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} peerDependencies: - '@typescript-eslint/parser': ^7.0.0 - eslint: ^8.56.0 + '@typescript-eslint/parser': ^8.0.0 || ^8.0.0-alpha.0 + eslint: ^8.57.0 || ^9.0.0 typescript: '*' peerDependenciesMeta: typescript: optional: true - '@typescript-eslint/parser@7.18.0': - resolution: {integrity: sha512-4Z+L8I2OqhZV8qA132M4wNL30ypZGYOQVBfMgxDH/K5UX0PNqTu1c6za9ST5r9+tavvHiTWmBnKzpCJ/GlVFtg==} - engines: {node: ^18.18.0 || >=20.0.0} + '@typescript-eslint/parser@8.0.1': + resolution: {integrity: sha512-5IgYJ9EO/12pOUwiBKFkpU7rS3IU21mtXzB81TNwq2xEybcmAZrE9qwDtsb5uQd9aVO9o0fdabFyAmKveXyujg==} + engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} peerDependencies: - eslint: ^8.56.0 + eslint: ^8.57.0 || ^9.0.0 typescript: '*' peerDependenciesMeta: typescript: optional: true - '@typescript-eslint/scope-manager@7.18.0': - resolution: {integrity: sha512-jjhdIE/FPF2B7Z1uzc6i3oWKbGcHb87Qw7AWj6jmEqNOfDFbJWtjt/XfwCpvNkpGWlcJaog5vTR+VV8+w9JflA==} - engines: {node: ^18.18.0 || >=20.0.0} + '@typescript-eslint/scope-manager@8.0.1': + resolution: {integrity: sha512-NpixInP5dm7uukMiRyiHjRKkom5RIFA4dfiHvalanD2cF0CLUuQqxfg8PtEUo9yqJI2bBhF+pcSafqnG3UBnRQ==} + engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} - '@typescript-eslint/type-utils@7.18.0': - resolution: {integrity: sha512-XL0FJXuCLaDuX2sYqZUUSOJ2sG5/i1AAze+axqmLnSkNEVMVYLF+cbwlB2w8D1tinFuSikHmFta+P+HOofrLeA==} - engines: {node: ^18.18.0 || >=20.0.0} - peerDependencies: - eslint: ^8.56.0 - typescript: '*' - peerDependenciesMeta: - typescript: - optional: true - - '@typescript-eslint/types@7.18.0': - resolution: {integrity: sha512-iZqi+Ds1y4EDYUtlOOC+aUmxnE9xS/yCigkjA7XpTKV6nCBd3Hp/PRGGmdwnfkV2ThMyYldP1wRpm/id99spTQ==} - engines: {node: ^18.18.0 || >=20.0.0} - - '@typescript-eslint/typescript-estree@7.18.0': - resolution: {integrity: sha512-aP1v/BSPnnyhMHts8cf1qQ6Q1IFwwRvAQGRvBFkWlo3/lH29OXA3Pts+c10nxRxIBrDnoMqzhgdwVe5f2D6OzA==} - engines: {node: ^18.18.0 || >=20.0.0} + '@typescript-eslint/type-utils@8.0.1': + resolution: {integrity: sha512-+/UT25MWvXeDX9YaHv1IS6KI1fiuTto43WprE7pgSMswHbn1Jm9GEM4Txp+X74ifOWV8emu2AWcbLhpJAvD5Ng==} + engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} peerDependencies: typescript: '*' peerDependenciesMeta: typescript: optional: true - '@typescript-eslint/utils@7.18.0': - resolution: {integrity: sha512-kK0/rNa2j74XuHVcoCZxdFBMF+aq/vH83CXAOHieC+2Gis4mF8jJXT5eAfyD3K0sAxtPuwxaIOIOvhwzVDt/kw==} - engines: {node: ^18.18.0 || >=20.0.0} - peerDependencies: - eslint: ^8.56.0 + '@typescript-eslint/types@8.0.1': + resolution: {integrity: sha512-PpqTVT3yCA/bIgJ12czBuE3iBlM3g4inRSC5J0QOdQFAn07TYrYEQBBKgXH1lQpglup+Zy6c1fxuwTk4MTNKIw==} + engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} - '@typescript-eslint/visitor-keys@7.18.0': - resolution: {integrity: sha512-cDF0/Gf81QpY3xYyJKDV14Zwdmid5+uuENhjH2EqFaF0ni+yAyq/LzMaIJdhNJXZI7uLzwIlA+V7oWoyn6Curg==} - engines: {node: ^18.18.0 || >=20.0.0} + '@typescript-eslint/typescript-estree@8.0.1': + resolution: {integrity: sha512-8V9hriRvZQXPWU3bbiUV4Epo7EvgM6RTs+sUmxp5G//dBGy402S7Fx0W0QkB2fb4obCF8SInoUzvTYtc3bkb5w==} + engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} + peerDependencies: + typescript: '*' + peerDependenciesMeta: + typescript: + optional: true + + '@typescript-eslint/utils@8.0.1': + resolution: {integrity: sha512-CBFR0G0sCt0+fzfnKaciu9IBsKvEKYwN9UZ+eeogK1fYHg4Qxk1yf/wLQkLXlq8wbU2dFlgAesxt8Gi76E8RTA==} + engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} + peerDependencies: + eslint: ^8.57.0 || ^9.0.0 + + '@typescript-eslint/visitor-keys@8.0.1': + resolution: {integrity: sha512-W5E+o0UfUcK5EgchLZsyVWqARmsM7v54/qEq6PY3YI5arkgmCzHiuk0zKSJJbm71V0xdRna4BGomkCTXz2/LkQ==} + engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} '@typescript/twoslash@3.1.0': resolution: {integrity: sha512-kTwMUQ8xtAZaC4wb2XuLkPqFVBj2dNBueMQ89NWEuw87k2nLBbuafeG5cob/QEr6YduxIdTVUjix0MtC7mPlmg==} @@ -9324,7 +9323,6 @@ packages: libsql@0.3.12: resolution: {integrity: sha512-to30hj8O3DjS97wpbKN6ERZ8k66MN1IaOfFLR6oHqd25GMiPJ/ZX0VaZ7w+TsPmxcFS3p71qArj/hiedCyvXCg==} - cpu: [x64, arm64, wasm32] os: [darwin, linux, win32] lilconfig@2.1.0: @@ -11110,11 +11108,10 @@ packages: typescript-auto-import-cache@0.3.3: resolution: {integrity: sha512-ojEC7+Ci1ij9eE6hp8Jl9VUNnsEKzztktP5gtYNRMrTmfXVwA1PITYYAkpxCvvupdSYa/Re51B6KMcv1CTZEUA==} - typescript-eslint@7.18.0: - resolution: {integrity: sha512-PonBkP603E3tt05lDkbOMyaxJjvKqQrXsnow72sVeOFINDE/qNmnnd+f9b4N+U7W6MXnnYyrhtmF2t08QWwUbA==} - engines: {node: ^18.18.0 || >=20.0.0} + typescript-eslint@8.0.1: + resolution: {integrity: sha512-V3Y+MdfhawxEjE16dWpb7/IOgeXnLwAEEkS7v8oDqNcR1oYlqWhGH/iHqHdKVdpWme1VPZ0SoywXAkCqawj2eQ==} + engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} peerDependencies: - eslint: ^8.56.0 typescript: '*' peerDependenciesMeta: typescript: @@ -13325,14 +13322,14 @@ snapshots: '@types/yargs-parser@21.0.3': {} - '@typescript-eslint/eslint-plugin@7.18.0(@typescript-eslint/parser@7.18.0(eslint@9.8.0)(typescript@5.5.4))(eslint@9.8.0)(typescript@5.5.4)': + '@typescript-eslint/eslint-plugin@8.0.1(@typescript-eslint/parser@8.0.1(eslint@9.8.0)(typescript@5.5.4))(eslint@9.8.0)(typescript@5.5.4)': dependencies: '@eslint-community/regexpp': 4.11.0 - '@typescript-eslint/parser': 7.18.0(eslint@9.8.0)(typescript@5.5.4) - '@typescript-eslint/scope-manager': 7.18.0 - '@typescript-eslint/type-utils': 7.18.0(eslint@9.8.0)(typescript@5.5.4) - '@typescript-eslint/utils': 7.18.0(eslint@9.8.0)(typescript@5.5.4) - '@typescript-eslint/visitor-keys': 7.18.0 + '@typescript-eslint/parser': 8.0.1(eslint@9.8.0)(typescript@5.5.4) + '@typescript-eslint/scope-manager': 8.0.1 + '@typescript-eslint/type-utils': 8.0.1(eslint@9.8.0)(typescript@5.5.4) + '@typescript-eslint/utils': 8.0.1(eslint@9.8.0)(typescript@5.5.4) + '@typescript-eslint/visitor-keys': 8.0.1 eslint: 9.8.0 graphemer: 1.4.0 ignore: 5.3.1 @@ -13343,12 +13340,12 @@ snapshots: transitivePeerDependencies: - supports-color - '@typescript-eslint/parser@7.18.0(eslint@9.8.0)(typescript@5.5.4)': + '@typescript-eslint/parser@8.0.1(eslint@9.8.0)(typescript@5.5.4)': dependencies: - '@typescript-eslint/scope-manager': 7.18.0 - '@typescript-eslint/types': 7.18.0 - '@typescript-eslint/typescript-estree': 7.18.0(typescript@5.5.4) - '@typescript-eslint/visitor-keys': 7.18.0 + '@typescript-eslint/scope-manager': 8.0.1 + '@typescript-eslint/types': 8.0.1 + '@typescript-eslint/typescript-estree': 8.0.1(typescript@5.5.4) + '@typescript-eslint/visitor-keys': 8.0.1 debug: 4.3.6 eslint: 9.8.0 optionalDependencies: @@ -13356,29 +13353,29 @@ snapshots: transitivePeerDependencies: - supports-color - '@typescript-eslint/scope-manager@7.18.0': + '@typescript-eslint/scope-manager@8.0.1': dependencies: - '@typescript-eslint/types': 7.18.0 - '@typescript-eslint/visitor-keys': 7.18.0 + '@typescript-eslint/types': 8.0.1 + '@typescript-eslint/visitor-keys': 8.0.1 - '@typescript-eslint/type-utils@7.18.0(eslint@9.8.0)(typescript@5.5.4)': + '@typescript-eslint/type-utils@8.0.1(eslint@9.8.0)(typescript@5.5.4)': dependencies: - '@typescript-eslint/typescript-estree': 7.18.0(typescript@5.5.4) - '@typescript-eslint/utils': 7.18.0(eslint@9.8.0)(typescript@5.5.4) + '@typescript-eslint/typescript-estree': 8.0.1(typescript@5.5.4) + '@typescript-eslint/utils': 8.0.1(eslint@9.8.0)(typescript@5.5.4) debug: 4.3.6 - eslint: 9.8.0 ts-api-utils: 1.3.0(typescript@5.5.4) optionalDependencies: typescript: 5.5.4 transitivePeerDependencies: + - eslint - supports-color - '@typescript-eslint/types@7.18.0': {} + '@typescript-eslint/types@8.0.1': {} - '@typescript-eslint/typescript-estree@7.18.0(typescript@5.5.4)': + '@typescript-eslint/typescript-estree@8.0.1(typescript@5.5.4)': dependencies: - '@typescript-eslint/types': 7.18.0 - '@typescript-eslint/visitor-keys': 7.18.0 + '@typescript-eslint/types': 8.0.1 + '@typescript-eslint/visitor-keys': 8.0.1 debug: 4.3.6 globby: 11.1.0 is-glob: 4.0.3 @@ -13390,20 +13387,20 @@ snapshots: transitivePeerDependencies: - supports-color - '@typescript-eslint/utils@7.18.0(eslint@9.8.0)(typescript@5.5.4)': + '@typescript-eslint/utils@8.0.1(eslint@9.8.0)(typescript@5.5.4)': dependencies: '@eslint-community/eslint-utils': 4.4.0(eslint@9.8.0) - '@typescript-eslint/scope-manager': 7.18.0 - '@typescript-eslint/types': 7.18.0 - '@typescript-eslint/typescript-estree': 7.18.0(typescript@5.5.4) + '@typescript-eslint/scope-manager': 8.0.1 + '@typescript-eslint/types': 8.0.1 + '@typescript-eslint/typescript-estree': 8.0.1(typescript@5.5.4) eslint: 9.8.0 transitivePeerDependencies: - supports-color - typescript - '@typescript-eslint/visitor-keys@7.18.0': + '@typescript-eslint/visitor-keys@8.0.1': dependencies: - '@typescript-eslint/types': 7.18.0 + '@typescript-eslint/types': 8.0.1 eslint-visitor-keys: 3.4.3 '@typescript/twoslash@3.1.0': @@ -17627,15 +17624,15 @@ snapshots: dependencies: semver: 7.6.3 - typescript-eslint@7.18.0(eslint@9.8.0)(typescript@5.5.4): + typescript-eslint@8.0.1(eslint@9.8.0)(typescript@5.5.4): dependencies: - '@typescript-eslint/eslint-plugin': 7.18.0(@typescript-eslint/parser@7.18.0(eslint@9.8.0)(typescript@5.5.4))(eslint@9.8.0)(typescript@5.5.4) - '@typescript-eslint/parser': 7.18.0(eslint@9.8.0)(typescript@5.5.4) - '@typescript-eslint/utils': 7.18.0(eslint@9.8.0)(typescript@5.5.4) - eslint: 9.8.0 + '@typescript-eslint/eslint-plugin': 8.0.1(@typescript-eslint/parser@8.0.1(eslint@9.8.0)(typescript@5.5.4))(eslint@9.8.0)(typescript@5.5.4) + '@typescript-eslint/parser': 8.0.1(eslint@9.8.0)(typescript@5.5.4) + '@typescript-eslint/utils': 8.0.1(eslint@9.8.0)(typescript@5.5.4) optionalDependencies: typescript: 5.5.4 transitivePeerDependencies: + - eslint - supports-color typescript@5.5.4: {}