diff --git a/packages/vite/src/node/plugins/importAnalysisBuild.ts b/packages/vite/src/node/plugins/importAnalysisBuild.ts index 718ff6190cfeac..d7f6491ceb7306 100644 --- a/packages/vite/src/node/plugins/importAnalysisBuild.ts +++ b/packages/vite/src/node/plugins/importAnalysisBuild.ts @@ -498,20 +498,23 @@ export function buildImportAnalysisPlugin(config: ResolvedConfig): Plugin { s.update( markerStartPos, markerStartPos + preloadMarker.length + 2, - `__vite__mapDeps([${renderedDeps.join(',')}])`, + renderedDeps.length > 0 + ? `__vite__mapDeps([${renderedDeps.join(',')}])` + : `[]`, ) rewroteMarkerStartPos.add(markerStartPos) } } } - const fileDepsCode = `[${fileDeps - .map((fileDep) => - fileDep.runtime ? fileDep.url : JSON.stringify(fileDep.url), - ) - .join(',')}]` + if (fileDeps.length > 0) { + const fileDepsCode = `[${fileDeps + .map((fileDep) => + fileDep.runtime ? fileDep.url : JSON.stringify(fileDep.url), + ) + .join(',')}]` - const mapDepsCode = `\ + const mapDepsCode = `\ function __vite__mapDeps(indexes) { if (!__vite__mapDeps.viteFileDeps) { __vite__mapDeps.viteFileDeps = ${fileDepsCode} @@ -519,11 +522,12 @@ function __vite__mapDeps(indexes) { return indexes.map((i) => __vite__mapDeps.viteFileDeps[i]) }\n` - // inject extra code at the top or next line of hashbang - if (code.startsWith('#!')) { - s.prependLeft(code.indexOf('\n') + 1, mapDepsCode) - } else { - s.prepend(mapDepsCode) + // inject extra code at the top or next line of hashbang + if (code.startsWith('#!')) { + s.prependLeft(code.indexOf('\n') + 1, mapDepsCode) + } else { + s.prepend(mapDepsCode) + } } // there may still be markers due to inlined dynamic imports, remove diff --git a/playground/js-sourcemap/__tests__/js-sourcemap.spec.ts b/playground/js-sourcemap/__tests__/js-sourcemap.spec.ts index fd5d91a26af1b1..f21ace14adab60 100644 --- a/playground/js-sourcemap/__tests__/js-sourcemap.spec.ts +++ b/playground/js-sourcemap/__tests__/js-sourcemap.spec.ts @@ -152,9 +152,22 @@ describe.runIf(isBuild)('build tests', () => { } `) // verify sourcemap comment is preserved at the last line - const js = findAssetFile(/after-preload-dynamic.*\.js$/) + const js = findAssetFile(/after-preload-dynamic-[-\w]{8}\.js$/) expect(js).toMatch( - /\n\/\/# sourceMappingURL=after-preload-dynamic.*\.js\.map\n$/, + /\n\/\/# sourceMappingURL=after-preload-dynamic-[-\w]{8}\.js\.map\n$/, ) }) + + test('__vite__mapDeps injected after banner', async () => { + const js = findAssetFile(/after-preload-dynamic-hashbang-[-\w]{8}\.js$/) + expect(js.split('\n').slice(0, 2)).toEqual([ + '#!/usr/bin/env node', + 'function __vite__mapDeps(indexes) {', + ]) + }) + + test('no unused __vite__mapDeps', async () => { + const js = findAssetFile(/after-preload-dynamic-no-dep-[-\w]{8}\.js$/) + expect(js).not.toMatch(/__vite__mapDeps/) + }) }) diff --git a/playground/js-sourcemap/after-preload-dynamic-no-dep.js b/playground/js-sourcemap/after-preload-dynamic-no-dep.js new file mode 100644 index 00000000000000..55f150702d02dc --- /dev/null +++ b/playground/js-sourcemap/after-preload-dynamic-no-dep.js @@ -0,0 +1,3 @@ +import('./dynamic/dynamic-no-dep') + +console.log('after preload dynamic no dep') diff --git a/playground/js-sourcemap/dynamic/dynamic-no-dep.js b/playground/js-sourcemap/dynamic/dynamic-no-dep.js new file mode 100644 index 00000000000000..d2291ff747319c --- /dev/null +++ b/playground/js-sourcemap/dynamic/dynamic-no-dep.js @@ -0,0 +1 @@ +console.log('dynamic/dynamic-no-dep') diff --git a/playground/js-sourcemap/index.html b/playground/js-sourcemap/index.html index 37ebf9397507c7..10afcc6c2d0807 100644 --- a/playground/js-sourcemap/index.html +++ b/playground/js-sourcemap/index.html @@ -7,5 +7,6 @@