Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

WIP: Rolldown build #27

Closed
wants to merge 81 commits into from
Closed
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
81 commits
Select commit Hold shift + click to select a range
6043980
feat(optimizer): using rolldown instead of esbuild
underfin Jul 5, 2024
676ce1f
chore: using latest rolldown
underfin Jul 26, 2024
a9cb34c
chore: update lock
underfin Aug 5, 2024
0253535
feat(optimizer): using rolldown instead of esbuild
underfin Jul 5, 2024
a87f6b6
chore: using latest rolldown
underfin Jul 26, 2024
49410d9
chore: rebase
underfin Jul 26, 2024
cfbe8b5
feat(optimizer): using rolldown instead of esbuild
underfin Jul 5, 2024
c411944
chore: using latest rolldown
underfin Jul 26, 2024
77b983d
refactor: avoid direct mutate chunk at metadata plugin
underfin Jul 8, 2024
1adc790
feat: build using rolldown
underfin Jul 8, 2024
f3a78cc
fix: using stable name for metadataPlugin
underfin Jul 8, 2024
fb80166
chore: enable format iife
underfin Jul 11, 2024
8899269
chore: bump rolldown 0.12.1
underfin Jul 15, 2024
0e19b80
chore: comment unsupport feature
underfin Jul 26, 2024
855f7d2
chore: make Plugin generic
underfin Jul 26, 2024
26b0739
chore: rebase
underfin Jul 26, 2024
6db40dc
chore: rebase
underfin Jul 26, 2024
c7a2aa7
fix: ssr entry names
underfin Jul 29, 2024
9ff36f1
fix: revert-resolve-options
underfin Jul 30, 2024
72ce0d3
fix: enable css devSourcemap
underfin Jul 30, 2024
f971871
fix: avoid using PluginContext#parse
underfin Aug 2, 2024
2c41e61
fix: enable css and asset addWatchFile at dev
underfin Aug 2, 2024
c2b7a0d
fix: pass transfrom-plugin
underfin Aug 2, 2024
933f3cf
chore: update lock
underfin Aug 5, 2024
6119524
chore: fix unexpected rebase error
underfin Aug 5, 2024
df523de
chore: fix unexpected rebase error
underfin Aug 5, 2024
c1ce9a1
fix: css chunk meta
underfin Aug 6, 2024
f66fcaf
fix: disable remove empty css generate chunk
underfin Aug 6, 2024
921222c
revert: remove css chunk
underfin Aug 8, 2024
46f22d8
chore: enable plugin order
underfin Aug 12, 2024
d1884f2
chore: fix manifest
underfin Aug 12, 2024
476770a
fix: transform hook typing
underfin Aug 12, 2024
d4a5f1a
fix: pass css test
underfin Aug 15, 2024
88c1252
chore: exclude failed test
underfin Aug 15, 2024
7b0fc07
chore: skip unit-test
underfin Aug 15, 2024
e69c6dc
chore: 🤖 use specific nightly
IWANABETHATGUY Aug 15, 2024
2226829
chore: 🤖 update lock
IWANABETHATGUY Aug 15, 2024
4f364a2
fix: remove unused directive (#37)
IWANABETHATGUY Aug 15, 2024
146789f
chore: 🤖 add justfile for faster dev
IWANABETHATGUY Aug 15, 2024
c6753e5
fix: json plugin using js module type
underfin Aug 16, 2024
5e8fb64
feat: add module type for url/raw flag
underfin Aug 16, 2024
996b025
fix: disable plugin-legacy build
underfin Aug 16, 2024
aaae6a9
fix: pass assets test
underfin Aug 18, 2024
c0ee10e
chore: update failed tests
underfin Aug 20, 2024
ba74784
chore: update failed tests
underfin Aug 20, 2024
21ed96d
fix: refactor browser external proxy module to avoid missing export e…
underfin Aug 20, 2024
a7dbe6c
fix: vite resolver using rolldown resolveId kind instead of plugin-co…
underfin Aug 22, 2024
5957897
chore: avoid run build tests in parallel because rolldwon exit proces…
underfin Aug 22, 2024
5e5524c
chore: enable addWatchFile
underfin Aug 22, 2024
db5ea8f
fix: optimize-deps-dev
underfin Aug 23, 2024
ab70a81
chore: skip linked vite test at loacl
underfin Aug 23, 2024
9521cd8
chore: rebase
underfin Aug 23, 2024
ee9b057
chore: fix typing
underfin Aug 23, 2024
f415bb9
chore: update test status
underfin Aug 23, 2024
9c8eaca
chore: update rolldown version and fix ci
underfin Aug 26, 2024
053bb4e
chore: disable unit test at ci
underfin Aug 26, 2024
0c64d94
chore: disable format and windows test at ci
underfin Aug 28, 2024
a516769
chore: disable type check at ci
underfin Aug 28, 2024
7668534
chore: fix ci
underfin Aug 28, 2024
c1a3b9d
chore: update rolldown
underfin Sep 2, 2024
74e649b
chore: fix ci
underfin Sep 2, 2024
3cb5984
fix: pass ssr-webwork
underfin Sep 2, 2024
c4f18e1
chore: fix css deconflict name
underfin Sep 8, 2024
24497ca
chore: revert unless change
underfin Sep 8, 2024
b884fb8
chore: revert --no-file-parallelism
underfin Sep 9, 2024
2cf0eb2
chore: 🤖 add experimental.enableNativePlugin
IWANABETHATGUY Sep 10, 2024
5f1136e
format (#42)
IWANABETHATGUY Sep 11, 2024
fe71cbc
migrate native plugin (#41)
IWANABETHATGUY Sep 11, 2024
27c3543
Native build plugin (#45)
IWANABETHATGUY Sep 12, 2024
f76bb75
perf: ⚡️ conditional disable dataurl plugin (#46)
IWANABETHATGUY Sep 12, 2024
d9e00de
fix: 🐛 allow disable buildReportPlugin (#47)
IWANABETHATGUY Sep 12, 2024
16d34d1
perf: reduce pre alias plugin in build mode
IWANABETHATGUY Sep 12, 2024
4c67d0a
chore: 🤖 asset import metal url filterable (#49)
IWANABETHATGUY Sep 13, 2024
00cd8eb
css plugin filterable (#50)
IWANABETHATGUY Sep 13, 2024
f3ffc27
feat: 🎸 html filterable (#51)
IWANABETHATGUY Sep 13, 2024
4478f31
feat: 🎸 worker filterable (#52)
IWANABETHATGUY Sep 13, 2024
5de4f1b
feat: 🎸 worker import meta url (#53)
IWANABETHATGUY Sep 13, 2024
39630a0
feat: 🎸 add an new option to disable build report
IWANABETHATGUY Sep 13, 2024
48087c6
feat: 🎸 support native define
IWANABETHATGUY Sep 13, 2024
fc9941d
chore: 🤖 bump rolldown (#55)
IWANABETHATGUY Sep 13, 2024
f597c1a
perf: ⚡️ use default resolver (#56)
IWANABETHATGUY Sep 14, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fix: using stable name for metadataPlugin
  • Loading branch information
underfin committed Aug 23, 2024
commit f3a78ccb49f10160bd55ec93bf642b4db40e6508
2 changes: 1 addition & 1 deletion packages/vite/src/node/plugins/asset.ts
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,7 @@ export function renderAssetUrlInJS(
s ||= new MagicString(code)
const [full, referenceId, postfix = ''] = match
const file = ctx.getFileName(referenceId)
getChunkMetadata(chunk.fileName)!.importedAssets.add(cleanUrl(file))
getChunkMetadata(chunk.name)!.importedAssets.add(cleanUrl(file))
const filename = file + postfix
const replacement = toOutputFilePathInJS(
filename,
Expand Down
12 changes: 6 additions & 6 deletions packages/vite/src/node/plugins/css.ts
Original file line number Diff line number Diff line change
Expand Up @@ -605,7 +605,7 @@ export function cssPostPlugin(config: ResolvedConfig): Plugin {
// replace asset url references with resolved url.
chunkCSS = chunkCSS.replace(assetUrlRE, (_, fileHash, postfix = '') => {
const filename = this.getFileName(fileHash) + postfix
getChunkMetadata(chunk.fileName)!.importedAssets.add(cleanUrl(filename))
getChunkMetadata(chunk.name)!.importedAssets.add(cleanUrl(filename))
return encodeURIPath(
toOutputFilePathInCss(
filename,
Expand Down Expand Up @@ -775,7 +775,7 @@ export function cssPostPlugin(config: ResolvedConfig): Plugin {
generatedAssets
.get(config)!
.set(referenceId, { originalName: originalFilename, isEntry })
getChunkMetadata(chunk.fileName)!.importedCss.add(this.getFileName(referenceId))
getChunkMetadata(chunk.name)!.importedCss.add(this.getFileName(referenceId))
} else if (!config.build.ssr) {
// legacy build and inline css

Expand Down Expand Up @@ -835,9 +835,9 @@ export function cssPostPlugin(config: ResolvedConfig): Plugin {
},

augmentChunkHash(chunk) {
if (getChunkMetadata(chunk.fileName)?.importedCss.size) {
if (getChunkMetadata(chunk.name)?.importedCss.size) {
let hash = ''
for (const id of getChunkMetadata(chunk.fileName)!.importedCss) {
for (const id of getChunkMetadata(chunk.name)!.importedCss) {
hash += id
}
return hash
Expand Down Expand Up @@ -930,10 +930,10 @@ export function cssPostPlugin(config: ResolvedConfig): Plugin {
if (pureCssChunkNames.includes(file)) {
const { importedCss, importedAssets } = getChunkMetadata((bundle[file] as OutputChunk).fileName)!
importedCss.forEach((file) =>
getChunkMetadata(chunk.fileName)!.importedCss.add(file),
getChunkMetadata(chunk.name)!.importedCss.add(file),
)
importedAssets.forEach((file) =>
getChunkMetadata(chunk.fileName)!.importedAssets.add(file),
getChunkMetadata(chunk.name)!.importedAssets.add(file),
)
chunkImportsPureCssChunk = true
return false
Expand Down
4 changes: 2 additions & 2 deletions packages/vite/src/node/plugins/html.ts
Original file line number Diff line number Diff line change
Expand Up @@ -759,7 +759,7 @@ export function buildHtmlPlugin(config: ResolvedConfig): Plugin {
})
}

getChunkMetadata(chunk.fileName)!.importedCss.forEach((file) => {
getChunkMetadata(chunk.name)!.importedCss.forEach((file) => {
if (!seen.has(file)) {
seen.add(file)
tags.push({
Expand Down Expand Up @@ -909,7 +909,7 @@ export function buildHtmlPlugin(config: ResolvedConfig): Plugin {
result = result.replace(assetUrlRE, (_, fileHash, postfix = '') => {
const file = this.getFileName(fileHash)
if (chunk) {
getChunkMetadata(chunk.fileName)!.importedAssets.add(cleanUrl(file))
getChunkMetadata(chunk.name)!.importedAssets.add(cleanUrl(file))
}
return encodeURIPath(toOutputAssetFilePath(file)) + postfix
})
Expand Down
6 changes: 3 additions & 3 deletions packages/vite/src/node/plugins/importAnalysisBuild.ts
Original file line number Diff line number Diff line change
Expand Up @@ -533,7 +533,7 @@ export function buildImportAnalysisPlugin(config: ResolvedConfig): Plugin {
chunk.imports.forEach(addDeps)
// Ensure that the css imported by current chunk is loaded after the dependencies.
// So the style of current chunk won't be overwritten unexpectedly.
getChunkMetadata(chunk.fileName)!.importedCss.forEach((file) => {
getChunkMetadata(chunk.name)!.importedCss.forEach((file) => {
deps.add(file)
})
}
Expand All @@ -542,8 +542,8 @@ export function buildImportAnalysisPlugin(config: ResolvedConfig): Plugin {
removedPureCssFilesCache.get(config)!
const chunk = removedPureCssFiles.get(filename)
if (chunk) {
if (getChunkMetadata(chunk.fileName)!.importedCss.size) {
getChunkMetadata(chunk.fileName)!.importedCss.forEach((file) => {
if (getChunkMetadata(chunk.name)!.importedCss.size) {
getChunkMetadata(chunk.name)!.importedCss.forEach((file) => {
deps.add(file)
})
hasRemovedPureCssChunk = true
Expand Down
8 changes: 4 additions & 4 deletions packages/vite/src/node/plugins/manifest.ts
Original file line number Diff line number Diff line change
Expand Up @@ -89,11 +89,11 @@ export function manifestPlugin(config: ResolvedConfig): Plugin {
}
}

if (getChunkMetadata(chunk.fileName)?.importedCss.size) {
manifestChunk.css = [...getChunkMetadata(chunk.fileName)!.importedCss]
if (getChunkMetadata(chunk.name)?.importedCss.size) {
manifestChunk.css = [...getChunkMetadata(chunk.name)!.importedCss]
}
if (getChunkMetadata(chunk.fileName)?.importedAssets.size) {
manifestChunk.assets = [...getChunkMetadata(chunk.fileName)!.importedAssets]
if (getChunkMetadata(chunk.name)?.importedAssets.size) {
manifestChunk.assets = [...getChunkMetadata(chunk.name)!.importedAssets]
}

return manifestChunk
Expand Down
6 changes: 3 additions & 3 deletions packages/vite/src/node/plugins/metadata.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ export function metadataPlugin(): Plugin {
async renderChunk(_code, chunk) {
// Since the chunk come from rust side, mutate it directly will not sync back to rust side.
// The next usage will lost the metadata
chunkMetadataMap.set(chunk.fileName, {
chunkMetadataMap.set(chunk.name, {
importedAssets: new Set(),
importedCss: new Set(),
})
Expand All @@ -26,6 +26,6 @@ export function metadataPlugin(): Plugin {
}
}

export function getChunkMetadata(fileName: string): ChunkMetadata | undefined {
return chunkMetadataMap.get(fileName)
export function getChunkMetadata(name: string): ChunkMetadata | undefined {
return chunkMetadataMap.get(name)
}
6 changes: 3 additions & 3 deletions packages/vite/src/node/ssr/ssrManifestPlugin.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36,11 +36,11 @@ export function ssrManifestPlugin(config: ResolvedConfig): Plugin {
mappedChunks.push(joinUrlSegments(base, chunk.fileName))
// <link> tags for entry chunks are already generated in static HTML,
// so we only need to record info for non-entry chunks.
getChunkMetadata(chunk.fileName)!.importedCss.forEach((file) => {
getChunkMetadata(chunk.name)!.importedCss.forEach((file) => {
mappedChunks.push(joinUrlSegments(base, file))
})
}
getChunkMetadata(chunk.fileName)!.importedAssets.forEach((file) => {
getChunkMetadata(chunk.name)!.importedAssets.forEach((file) => {
mappedChunks.push(joinUrlSegments(base, file))
})
}
Expand Down Expand Up @@ -78,7 +78,7 @@ export function ssrManifestPlugin(config: ResolvedConfig): Plugin {
analyzed.add(filename)
const chunk = bundle[filename] as OutputChunk | undefined
if (chunk) {
getChunkMetadata(chunk.fileName)!.importedCss.forEach((file) => {
getChunkMetadata(chunk.name)!.importedCss.forEach((file) => {
deps.push(joinUrlSegments(base, file)) // TODO:base
})
chunk.imports.forEach(addDeps)
Expand Down