From a503d79ed0e7896c84bc2323f2aedaa1e857e5d6 Mon Sep 17 00:00:00 2001 From: Simon He <57086651+Simon-He95@users.noreply.github.com> Date: Sun, 23 Jun 2024 20:37:33 +0800 Subject: [PATCH] refactor(vite): refactor optimizer --- packages/vite/src/node/optimizer/optimizer.ts | 19 +++++++++---------- 1 file changed, 9 insertions(+), 10 deletions(-) diff --git a/packages/vite/src/node/optimizer/optimizer.ts b/packages/vite/src/node/optimizer/optimizer.ts index 096d0bef2cdd54..8bd9beb95f068f 100644 --- a/packages/vite/src/node/optimizer/optimizer.ts +++ b/packages/vite/src/node/optimizer/optimizer.ts @@ -790,17 +790,16 @@ function findInteropMismatches( const needsInteropMismatch = [] for (const dep in discovered) { const discoveredDepInfo = discovered[dep] + if (discoveredDepInfo.needsInterop === undefined) continue + const depInfo = optimized[dep] - if (depInfo) { - if ( - discoveredDepInfo.needsInterop !== undefined && - depInfo.needsInterop !== discoveredDepInfo.needsInterop - ) { - // This only happens when a discovered dependency has mixed ESM and CJS syntax - // and it hasn't been manually added to optimizeDeps.needsInterop - needsInteropMismatch.push(dep) - debug?.(colors.cyan(`✨ needsInterop mismatch detected for ${dep}`)) - } + if (!depInfo) continue + + if (depInfo.needsInterop !== discoveredDepInfo.needsInterop) { + // This only happens when a discovered dependency has mixed ESM and CJS syntax + // and it hasn't been manually added to optimizeDeps.needsInterop + needsInteropMismatch.push(dep) + debug?.(colors.cyan(`✨ needsInterop mismatch detected for ${dep}`)) } } return needsInteropMismatch