From 443b6d1e86cbd7dd2394395211bea2caea7caf59 Mon Sep 17 00:00:00 2001 From: sapphi-red <49056869+sapphi-red@users.noreply.github.com> Date: Fri, 22 Nov 2024 20:10:33 +0900 Subject: [PATCH 1/5] refactor: convert to callableBuiltinPlugin when creating environment plugin container --- packages/vite/src/node/server/environment.ts | 10 +--------- packages/vite/src/node/server/pluginContainer.ts | 10 +++++++++- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/packages/vite/src/node/server/environment.ts b/packages/vite/src/node/server/environment.ts index 6971a43411cf16..39e363931d93c4 100644 --- a/packages/vite/src/node/server/environment.ts +++ b/packages/vite/src/node/server/environment.ts @@ -1,10 +1,6 @@ import type { FetchFunctionOptions, FetchResult } from 'vite/module-runner' import type { FSWatcher } from 'dep-types/chokidar' import colors from 'picocolors' -import { - isCallableCompatibleBuiltinPlugin, - makeBuiltinPluginCallable, -} from 'rolldown/experimental' import { BaseEnvironment, getDefaultResolvedEnvironmentOptions, @@ -171,11 +167,7 @@ export class DevEnvironment extends BaseEnvironment { return } this._initiated = true - this._plugins = (await resolveEnvironmentPlugins(this)).map((plugin) => - isCallableCompatibleBuiltinPlugin(plugin) - ? makeBuiltinPluginCallable(plugin) - : plugin, - ) + this._plugins = await resolveEnvironmentPlugins(this) this._pluginContainer = await createEnvironmentPluginContainer( this, this._plugins, diff --git a/packages/vite/src/node/server/pluginContainer.ts b/packages/vite/src/node/server/pluginContainer.ts index 3f1e06811be85c..bf4cfe28f27f24 100644 --- a/packages/vite/src/node/server/pluginContainer.ts +++ b/packages/vite/src/node/server/pluginContainer.ts @@ -62,6 +62,10 @@ import { TraceMap, originalPositionFor } from '@jridgewell/trace-mapping' import MagicString from 'magic-string' import type { FSWatcher } from 'dep-types/chokidar' import colors from 'picocolors' +import { + isCallableCompatibleBuiltinPlugin, + makeBuiltinPluginCallable, +} from 'rolldown/experimental' import type { Plugin } from '../plugin' import { combineSourcemaps, @@ -138,7 +142,11 @@ export async function createEnvironmentPluginContainer( ): Promise { const container = new EnvironmentPluginContainer( environment, - plugins, + plugins.map((plugin) => + isCallableCompatibleBuiltinPlugin(plugin) + ? makeBuiltinPluginCallable(plugin) + : plugin, + ), watcher, ) await container.resolveRollupOptions() From 456e17ad533106d9338e5ca9d5555ab5e54f2a40 Mon Sep 17 00:00:00 2001 From: sapphi-red <49056869+sapphi-red@users.noreply.github.com> Date: Fri, 22 Nov 2024 20:11:39 +0900 Subject: [PATCH 2/5] refactor: pass env options to oxcResolvePlugin --- packages/vite/src/node/plugins/index.ts | 2 +- packages/vite/src/node/plugins/resolve.ts | 10 +++++----- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/packages/vite/src/node/plugins/index.ts b/packages/vite/src/node/plugins/index.ts index 097d790e4aed04..b198d992d43c88 100644 --- a/packages/vite/src/node/plugins/index.ts +++ b/packages/vite/src/node/plugins/index.ts @@ -107,7 +107,7 @@ export async function resolvePlugins( optimizeDeps: true, externalize: true, }, - isWorker ? config : undefined, + isWorker ? { ...config, consumer: 'client' } : undefined, ) : [ resolvePlugin({ diff --git a/packages/vite/src/node/plugins/resolve.ts b/packages/vite/src/node/plugins/resolve.ts index b6e376d2b0590b..c406772de4a89e 100644 --- a/packages/vite/src/node/plugins/resolve.ts +++ b/packages/vite/src/node/plugins/resolve.ts @@ -182,16 +182,16 @@ export interface ResolvePluginOptionsWithOverrides const perEnvironmentOrWorkerPlugin = ( name: string, - configIfWorker: ResolvedConfig | undefined, + overrideEnvConfig: (ResolvedConfig & ResolvedEnvironmentOptions) | undefined, f: (env: { name: string config: ResolvedConfig & ResolvedEnvironmentOptions }) => Plugin, ): Plugin => { - if (configIfWorker) { + if (overrideEnvConfig) { return f({ name: 'client', - config: { ...configIfWorker, consumer: 'client' }, + config: overrideEnvConfig, }) } return perEnvironmentPlugin(name, f) @@ -199,14 +199,14 @@ const perEnvironmentOrWorkerPlugin = ( export function oxcResolvePlugin( resolveOptions: ResolvePluginOptionsWithOverrides, - configIfWorker: ResolvedConfig | undefined, + overrideEnvConfig: (ResolvedConfig & ResolvedEnvironmentOptions) | undefined, ): (RolldownPlugin | Plugin)[] { return [ optimizerResolvePlugin(resolveOptions), importGlobSubpathImportsResolvePlugin(resolveOptions), perEnvironmentOrWorkerPlugin( 'vite:resolve-builtin', - configIfWorker, + overrideEnvConfig, (env) => { const environment = env as Environment // The resolve plugin is used for createIdResolver and the depsOptimizer should be From 7edff8d24345e4565b71c7dad649fe04f1ce1172 Mon Sep 17 00:00:00 2001 From: sapphi-red <49056869+sapphi-red@users.noreply.github.com> Date: Fri, 22 Nov 2024 20:12:14 +0900 Subject: [PATCH 3/5] feat: add skipMainField option --- packages/vite/src/node/plugins/css.ts | 1 + packages/vite/src/node/plugins/resolve.ts | 8 +++++++- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/packages/vite/src/node/plugins/css.ts b/packages/vite/src/node/plugins/css.ts index 57e94207e441ef..9b383ba4641d2f 100644 --- a/packages/vite/src/node/plugins/css.ts +++ b/packages/vite/src/node/plugins/css.ts @@ -1182,6 +1182,7 @@ function createCSSResolvers(config: ResolvedConfig): CSSAtImportResolvers { tryIndex: true, tryPrefix: '_', preferRelative: true, + skipMainField: true, }) sassResolve = async (...args) => { if (args[1].startsWith('file://')) { diff --git a/packages/vite/src/node/plugins/resolve.ts b/packages/vite/src/node/plugins/resolve.ts index c406772de4a89e..d7cb690d74676f 100644 --- a/packages/vite/src/node/plugins/resolve.ts +++ b/packages/vite/src/node/plugins/resolve.ts @@ -129,6 +129,10 @@ interface ResolvePluginOptions { isFromTsImporter?: boolean // True when resolving during the scan phase to discover dependencies scan?: boolean + /** + * @internal + */ + skipMainField?: boolean /** * Optimize deps during dev, defaults to false // TODO: Review default @@ -242,7 +246,9 @@ export function oxcResolvePlugin( root: options.root, scan: options.scan ?? false, - mainFields: options.mainFields.concat(['main']), + mainFields: options.skipMainField + ? options.mainFields + : options.mainFields.concat(['main']), conditions: options.conditions, externalConditions: options.externalConditions, extensions: options.extensions, From 1d8282b29a93081b5590535bca576ebc9ec0b937 Mon Sep 17 00:00:00 2001 From: sapphi-red <49056869+sapphi-red@users.noreply.github.com> Date: Fri, 22 Nov 2024 20:14:40 +0900 Subject: [PATCH 4/5] feat: use the native plugin for `createIdResolver` --- packages/vite/src/node/idResolver.ts | 43 +++++++++++++++++++--------- 1 file changed, 30 insertions(+), 13 deletions(-) diff --git a/packages/vite/src/node/idResolver.ts b/packages/vite/src/node/idResolver.ts index 98472094c588dc..0e130160401fec 100644 --- a/packages/vite/src/node/idResolver.ts +++ b/packages/vite/src/node/idResolver.ts @@ -3,10 +3,11 @@ import aliasPlugin from '@rollup/plugin-alias' import type { ResolvedConfig } from './config' import type { EnvironmentPluginContainer } from './server/pluginContainer' import { createEnvironmentPluginContainer } from './server/pluginContainer' -import { resolvePlugin } from './plugins/resolve' +import { oxcResolvePlugin, resolvePlugin } from './plugins/resolve' import type { InternalResolveOptions } from './plugins/resolve' import type { Environment } from './environment' import type { PartialEnvironment } from './baseEnvironment' +import type { Plugin } from './plugin' export type ResolveIdFn = ( environment: PartialEnvironment, @@ -61,18 +62,34 @@ export function createIdResolver( [ // @ts-expect-error the aliasPlugin uses rollup types aliasPlugin({ entries: environment.config.resolve.alias }), - // TODO: use oxcResolvePlugin here as well - resolvePlugin({ - root: config.root, - isProduction: config.isProduction, - isBuild: config.command === 'build', - asSrc: true, - preferRelative: false, - tryIndex: true, - ...options, - // Ignore sideEffects and other computations as we only need the id - idOnly: true, - }), + ...(config.experimental.enableNativePlugin + ? (oxcResolvePlugin( + { + root: config.root, + isProduction: config.isProduction, + isBuild: config.command === 'build', + asSrc: true, + preferRelative: false, + tryIndex: true, + ...options, + // Ignore sideEffects and other computations as we only need the id + idOnly: true, + }, + environment.config, + ) as Plugin[]) + : [ + resolvePlugin({ + root: config.root, + isProduction: config.isProduction, + isBuild: config.command === 'build', + asSrc: true, + preferRelative: false, + tryIndex: true, + ...options, + // Ignore sideEffects and other computations as we only need the id + idOnly: true, + }), + ]), ], ) pluginContainerMap.set(environment, pluginContainer) From e43e05ba409e438e610016a4f95456b85ec9dad6 Mon Sep 17 00:00:00 2001 From: sapphi-red <49056869+sapphi-red@users.noreply.github.com> Date: Fri, 22 Nov 2024 20:16:07 +0900 Subject: [PATCH 5/5] perf: pass finalizeOtherSpecifiers when only needed --- packages/vite/src/node/plugins/resolve.ts | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/packages/vite/src/node/plugins/resolve.ts b/packages/vite/src/node/plugins/resolve.ts index d7cb690d74676f..1ebf572cc26762 100644 --- a/packages/vite/src/node/plugins/resolve.ts +++ b/packages/vite/src/node/plugins/resolve.ts @@ -308,9 +308,17 @@ export function oxcResolvePlugin( } return newId }, - finalizeOtherSpecifiers(resolvedId, rawId) { - return ensureVersionQuery(resolvedId, rawId, options, depsOptimizer) - }, + finalizeOtherSpecifiers: !depsOptimizer + ? undefined + : (resolvedId, rawId) => { + const newResolvedId = ensureVersionQuery( + resolvedId, + rawId, + options, + depsOptimizer, + ) + return newResolvedId === resolvedId ? undefined : newResolvedId + }, }) as unknown as Plugin }, ),