Skip to content

Commit

Permalink
Revert "fix: esbuild glob import resolve error (vitejs#15140)"
Browse files Browse the repository at this point in the history
This reverts commit 676804d.
  • Loading branch information
XiSenao committed Dec 9, 2023
1 parent ed47284 commit 0685413
Showing 1 changed file with 15 additions and 31 deletions.
46 changes: 15 additions & 31 deletions packages/vite/src/node/optimizer/scan.ts
Original file line number Diff line number Diff line change
Expand Up @@ -300,11 +300,9 @@ function esbuildScanPlugin(
'@vite/env',
]

const isUnlessEntry = (path: string) => !entries.includes(path)

const externalUnlessEntry = ({ path }: { path: string }) => ({
path,
external: isUnlessEntry(path),
external: !entries.includes(path),
})

const doTransformGlobImport = async (
Expand Down Expand Up @@ -551,39 +549,25 @@ function esbuildScanPlugin(
// they are done after the bare import resolve because a package name
// may end with these extensions

const setupExternalize = (
filter: RegExp,
doExternalize: (path: string) => boolean,
) => {
build.onResolve({ filter }, ({ path }) => {
return {
path,
external: doExternalize(path),
}
})
// onResolve is not called for glob imports.
// we need to add that here as well until esbuild calls onResolve for glob imports.
// https://github.com/evanw/esbuild/issues/3317
build.onLoad({ filter, namespace: 'file' }, () => {
const externalOnLoadResult: OnLoadResult = {
loader: 'js',
contents: 'export default {}',
}
return externalOnLoadResult
})
}

// css
setupExternalize(CSS_LANGS_RE, isUnlessEntry)
build.onResolve({ filter: CSS_LANGS_RE }, externalUnlessEntry)

// json & wasm
setupExternalize(/\.(json|json5|wasm)$/, isUnlessEntry)
build.onResolve({ filter: /\.(json|json5|wasm)$/ }, externalUnlessEntry)

// known asset types
setupExternalize(
new RegExp(`\\.(${KNOWN_ASSET_TYPES.join('|')})$`),
isUnlessEntry,
build.onResolve(
{
filter: new RegExp(`\\.(${KNOWN_ASSET_TYPES.join('|')})$`),
},
externalUnlessEntry,
)

// known vite query types: ?worker, ?raw
setupExternalize(SPECIAL_QUERY_RE, () => true)
build.onResolve({ filter: SPECIAL_QUERY_RE }, ({ path }) => ({
path,
external: true,
}))

// catch all -------------------------------------------------------------

Expand Down

0 comments on commit 0685413

Please sign in to comment.