From c94fd9b8753da2e5f91c55ddff7f4a22cb56d16d Mon Sep 17 00:00:00 2001 From: jerrykingxyz Date: Tue, 17 Dec 2024 19:30:47 +0800 Subject: [PATCH] fix: incremental stage are compatible with empty artifact --- crates/rspack_core/src/cgm_hash_results.rs | 4 ++++ .../src/cgm_runtime_requirement_results.rs | 4 ++++ crates/rspack_core/src/code_generation_results.rs | 4 ++++ crates/rspack_core/src/compiler/compilation.rs | 14 ++++++++++++-- crates/rspack_ids/src/named_module_ids_plugin.rs | 1 + 5 files changed, 25 insertions(+), 2 deletions(-) diff --git a/crates/rspack_core/src/cgm_hash_results.rs b/crates/rspack_core/src/cgm_hash_results.rs index b4652b901da..8699c76133e 100644 --- a/crates/rspack_core/src/cgm_hash_results.rs +++ b/crates/rspack_core/src/cgm_hash_results.rs @@ -9,6 +9,10 @@ pub struct CgmHashResults { } impl CgmHashResults { + pub fn is_empty(&self) -> bool { + self.module_to_hashes.is_empty() + } + pub fn get(&self, module: &ModuleIdentifier, runtime: &RuntimeSpec) -> Option<&RspackHashDigest> { let hashes = self.module_to_hashes.get(module)?; hashes.get(runtime) diff --git a/crates/rspack_core/src/cgm_runtime_requirement_results.rs b/crates/rspack_core/src/cgm_runtime_requirement_results.rs index 4c54e4f6165..ecd1e4457c9 100644 --- a/crates/rspack_core/src/cgm_runtime_requirement_results.rs +++ b/crates/rspack_core/src/cgm_runtime_requirement_results.rs @@ -8,6 +8,10 @@ pub struct CgmRuntimeRequirementsResults { } impl CgmRuntimeRequirementsResults { + pub fn is_empty(&self) -> bool { + self.module_to_runtime_requirements.is_empty() + } + pub fn get(&self, module: &ModuleIdentifier, runtime: &RuntimeSpec) -> Option<&RuntimeGlobals> { let requirements = self.module_to_runtime_requirements.get(module)?; requirements.get(runtime) diff --git a/crates/rspack_core/src/code_generation_results.rs b/crates/rspack_core/src/code_generation_results.rs index 1eef745e7ed..68ef01bd572 100644 --- a/crates/rspack_core/src/code_generation_results.rs +++ b/crates/rspack_core/src/code_generation_results.rs @@ -194,6 +194,10 @@ pub struct CodeGenerationResults { } impl CodeGenerationResults { + pub fn is_empty(&self) -> bool { + self.module_generation_result_map.is_empty() && self.map.is_empty() + } + pub fn get_one(&self, module_identifier: &ModuleIdentifier) -> Option<&CodeGenerationResult> { self .map diff --git a/crates/rspack_core/src/compiler/compilation.rs b/crates/rspack_core/src/compiler/compilation.rs index 8c4a02b8503..9f03792fe9d 100644 --- a/crates/rspack_core/src/compiler/compilation.rs +++ b/crates/rspack_core/src/compiler/compilation.rs @@ -1021,7 +1021,9 @@ impl Compilation { let mutations = self .incremental .mutations_read(IncrementalPasses::CHUNKS_RENDER); - let chunks = if let Some(mutations) = mutations { + let chunks = if let Some(mutations) = mutations + && !self.chunk_render_results.is_empty() + { let removed_chunks = mutations.iter().filter_map(|mutation| match mutation { Mutation::ChunkRemove { chunk } => Some(*chunk), _ => None, @@ -1222,7 +1224,10 @@ impl Compilation { let mutations = self .incremental .mutations_read(IncrementalPasses::DEPENDENCIES_DIAGNOSTICS); - let modules = if let Some(mutations) = mutations { + // TODO move diagnostic collect to make + let modules = if let Some(mutations) = mutations + && !self.dependencies_diagnostics.is_empty() + { let revoked_modules = mutations.iter().filter_map(|mutation| match mutation { Mutation::ModuleRemove { module } => Some(*module), _ => None, @@ -1349,6 +1354,7 @@ impl Compilation { let create_module_hashes_modules = if let Some(mutations) = self .incremental .mutations_read(IncrementalPasses::MODULES_HASHES) + && !self.cgm_hash_results.is_empty() { let revoked_modules = mutations.iter().filter_map(|mutation| match mutation { Mutation::ModuleRemove { module } => Some(*module), @@ -1381,6 +1387,7 @@ impl Compilation { let code_generation_modules = if let Some(mutations) = self .incremental .mutations_read(IncrementalPasses::MODULES_CODEGEN) + && !self.code_generation_results.is_empty() { let revoked_modules = mutations.iter().filter_map(|mutation| match mutation { Mutation::ModuleRemove { module } => Some(*module), @@ -1407,6 +1414,7 @@ impl Compilation { let process_runtime_requirements_modules = if let Some(mutations) = self .incremental .mutations_read(IncrementalPasses::MODULES_RUNTIME_REQUIREMENTS) + && !self.cgm_runtime_requirements_results.is_empty() { let revoked_modules = mutations.iter().filter_map(|mutation| match mutation { Mutation::ModuleRemove { module } => Some(*module), @@ -1438,6 +1446,7 @@ impl Compilation { let process_runtime_requirements_chunks = if let Some(mutations) = self .incremental .mutations_read(IncrementalPasses::CHUNKS_RUNTIME_REQUIREMENTS) + && !self.cgc_runtime_requirements_results.is_empty() { let removed_chunks = mutations.iter().filter_map(|mutation| match mutation { Mutation::ChunkRemove { chunk } => Some(chunk), @@ -1479,6 +1488,7 @@ impl Compilation { let create_hash_chunks = if let Some(mutations) = self .incremental .mutations_read(IncrementalPasses::CHUNKS_HASHES) + && !self.chunk_hashes_results.is_empty() { let removed_chunks = mutations.iter().filter_map(|mutation| match mutation { Mutation::ChunkRemove { chunk } => Some(*chunk), diff --git a/crates/rspack_ids/src/named_module_ids_plugin.rs b/crates/rspack_ids/src/named_module_ids_plugin.rs index 8029c3626ee..71975d75087 100644 --- a/crates/rspack_ids/src/named_module_ids_plugin.rs +++ b/crates/rspack_ids/src/named_module_ids_plugin.rs @@ -132,6 +132,7 @@ fn module_ids(&self, compilation: &mut rspack_core::Compilation) -> Result<()> { let mut modules: IdentifierSet = if let Some(mutations) = compilation .incremental .mutations_read(IncrementalPasses::MODULE_IDS) + && !module_ids.is_empty() { mutations .iter()