Skip to content

Commit

Permalink
refactor: unexpected should not always rely on
Browse files Browse the repository at this point in the history
  • Loading branch information
h-a-n-a committed Dec 8, 2023
1 parent 62886d7 commit 361c3fe
Show file tree
Hide file tree
Showing 30 changed files with 120 additions and 174 deletions.
89 changes: 41 additions & 48 deletions crates/node_binding/src/plugins/mod.rs

Large diffs are not rendered by default.

16 changes: 0 additions & 16 deletions crates/rspack_ast/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
mod ast;

use rspack_error::{internal_error, Result};

pub use crate::ast::css;
use crate::ast::css::Ast as CssAst;
pub use crate::ast::javascript;
Expand All @@ -17,20 +15,6 @@ pub enum RspackAst {
}

impl RspackAst {
pub fn try_into_javascript(self) -> Result<JsAst> {
match self {
RspackAst::JavaScript(program) => Ok(program),
RspackAst::Css(_) => Err(internal_error!("Failed to cast `CSS` AST to `JavaScript`")),
}
}

pub fn try_into_css(self) -> Result<CssAst> {
match self {
RspackAst::Css(stylesheet) => Ok(stylesheet),
RspackAst::JavaScript(_) => Err(internal_error!("Failed to cast `JavaScript` AST to `CSS`")),
}
}

pub fn as_javascript(&self) -> Option<&JsAst> {
match self {
RspackAst::JavaScript(program) => Some(program),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ impl TryFrom<RawBannerContentWrapper> for BannerContent {
.call(ctx.into(), ThreadsafeFunctionCallMode::NonBlocking)
.into_rspack_result()?
.await
.map_err(|err| internal_error!("Failed to call rule.use function: {err}"))?
.unwrap_or_else(|err| panic!("Failed to call rule.use function: {err}"))
})
},
)))
Expand Down
2 changes: 1 addition & 1 deletion crates/rspack_binding_options/src/options/raw_external.rs
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,7 @@ impl TryFrom<RawExternalItemWrapper> for ExternalItem {
.call(ctx.into(), ThreadsafeFunctionCallMode::NonBlocking)
.into_rspack_result()?
.await
.map_err(|err| internal_error!("Failed to call external function: {err}"))?
.unwrap_or_else(|err| panic!("Failed to call external function: {err}"))
.map(|r| r.into())
})
})))
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -133,7 +133,7 @@ impl Loader<LoaderRunnerContext> for JsLoaderAdapter {
.call(js_loader_context, ThreadsafeFunctionCallMode::NonBlocking)
.into_rspack_result()?
.await
.map_err(|err| internal_error!("Failed to call loader: {err}"))??;
.unwrap_or_else(|err| panic!("Failed to call loader: {err}"))?;

if let Some(loader_result) = loader_result {
// This indicate that the JS loaders pitched(return something) successfully
Expand Down Expand Up @@ -163,7 +163,7 @@ impl Loader<LoaderRunnerContext> for JsLoaderAdapter {
.call(js_loader_context, ThreadsafeFunctionCallMode::NonBlocking)
.into_rspack_result()?
.await
.map_err(|err| internal_error!("Failed to call loader: {err}"))??;
.unwrap_or_else(|err| panic!("Failed to call loader: {err}"))?;

if let Some(loader_result) = loader_result {
sync_loader_context(loader_result, loader_context)?;
Expand Down
8 changes: 4 additions & 4 deletions crates/rspack_binding_options/src/options/raw_module/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -239,9 +239,9 @@ impl TryFrom<RawRuleSetCondition> for rspack_core::RuleSetCondition {
.call(data, ThreadsafeFunctionCallMode::NonBlocking)
.into_rspack_result()?
.await
.map_err(|err| {
internal_error!("Failed to call RuleSetCondition func_matcher: {err}")
})?
.unwrap_or_else(|err| {
panic!("Failed to call RuleSetCondition func_matcher: {err}")
})
})
}))
}
Expand Down Expand Up @@ -609,7 +609,7 @@ impl RawOptionsApply for RawModuleRule {
.call(ctx.into(), ThreadsafeFunctionCallMode::NonBlocking)
.into_rspack_result()?
.await
.map_err(|err| internal_error!("Failed to call rule.use function: {err}"))?
.unwrap_or_else(|err| panic!("Failed to call rule.use function: {err}"))
.map(|uses| {
uses
.into_iter()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ use napi::bindgen_prelude::Either3;
use napi::{Env, JsFunction};
use napi_derive::napi;
use rspack_binding_values::{JsModule, ToJsModule};
use rspack_error::internal_error;
use rspack_napi_shared::threadsafe_function::{ThreadsafeFunction, ThreadsafeFunctionCallMode};
use rspack_napi_shared::{get_napi_env, JsRegExp, JsRegExpExt, NapiResultExt};
use rspack_plugin_split_chunks_new::{CacheGroupTest, CacheGroupTestFnCtx};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ use napi::bindgen_prelude::Either3;
use napi::{Env, JsFunction};
use napi_derive::napi;
use rspack_binding_values::{JsModule, ToJsModule};
use rspack_error::internal_error;
use rspack_napi_shared::threadsafe_function::{ThreadsafeFunction, ThreadsafeFunctionCallMode};
use rspack_napi_shared::{get_napi_env, NapiResultExt};
use rspack_plugin_split_chunks_new::{ChunkNameGetter, ChunkNameGetterFnCtx};
Expand Down
31 changes: 11 additions & 20 deletions crates/rspack_core/src/code_generation_results.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ use std::ops::{Deref, DerefMut};
use std::sync::atomic::AtomicU32;

use anymap::CloneAny;
use rspack_error::{internal_error, Result};
use rspack_hash::{HashDigest, HashFunction, HashSalt, RspackHash, RspackHashDigest};
use rspack_identifier::IdentifierMap;
use rspack_sources::BoxSource;
Expand Down Expand Up @@ -182,48 +181,48 @@ impl CodeGenerationResults {
&self,
module_identifier: &ModuleIdentifier,
runtime: Option<&RuntimeSpec>,
) -> Result<&CodeGenerationResult> {
) -> &CodeGenerationResult {
if let Some(entry) = self.map.get(module_identifier) {
if let Some(runtime) = runtime {
entry
.get(runtime)
.and_then(|m| {
self.module_generation_result_map.get(m)
})
.ok_or_else(|| {
internal_error!(
.unwrap_or_else(|| {
panic!(
"Failed to code generation result for {module_identifier} with runtime {runtime:?} \n {entry:?}"
)
})
} else {
if entry.size() > 1 {
let results = entry.get_values();
if results.len() != 1 {
return Err(internal_error!(
panic!(
"No unique code generation entry for unspecified runtime for {module_identifier} ",
));
);
}

return results
.first()
.copied()
.and_then(|m| self.module_generation_result_map.get(m))
.ok_or_else(|| internal_error!("Expected value exists"));
.unwrap_or_else(|| panic!("Expected value exists"));
}

entry
.get_values()
.first()
.copied()
.and_then(|m| self.module_generation_result_map.get(m))
.ok_or_else(|| internal_error!("Expected value exists"))
.unwrap_or_else(|| panic!("Expected value exists"))
}
} else {
Err(internal_error!(
panic!(
"No code generation entry for {} (existing entries: {:?})",
module_identifier,
self.map.keys().collect::<Vec<_>>()
))
)
}
}

Expand All @@ -250,13 +249,7 @@ impl CodeGenerationResults {
module_identifier: &ModuleIdentifier,
runtime: Option<&RuntimeSpec>,
) -> RuntimeGlobals {
match self.get(module_identifier, runtime) {
Ok(result) => result.runtime_requirements,
Err(_) => {
eprintln!("Failed to get runtime requirements for {module_identifier}");
Default::default()
}
}
self.get(module_identifier, runtime).runtime_requirements
}

#[allow(clippy::unwrap_in_result)]
Expand All @@ -265,9 +258,7 @@ impl CodeGenerationResults {
module_identifier: &ModuleIdentifier,
runtime: Option<&RuntimeSpec>,
) -> Option<&RspackHashDigest> {
let code_generation_result = self
.get(module_identifier, runtime)
.expect("should have code generation result");
let code_generation_result = self.get(module_identifier, runtime);

code_generation_result.hash.as_ref()
}
Expand Down
22 changes: 9 additions & 13 deletions crates/rspack_core/src/context_module.rs
Original file line number Diff line number Diff line change
Expand Up @@ -360,18 +360,18 @@ impl ContextModule {
}

#[inline]
fn get_source_string(&self, compilation: &Compilation) -> Result<BoxSource> {
fn get_source_string(&self, compilation: &Compilation) -> BoxSource {
match self.options.context_options.mode {
ContextMode::Lazy => Ok(self.get_lazy_source(compilation)),
ContextMode::Lazy => self.get_lazy_source(compilation),
ContextMode::LazyOnce => {
let block = self
.get_blocks()
.first()
.ok_or_else(|| internal_error!("LazyOnce ContextModule should have first block"))?;
.expect("LazyOnce ContextModule should have first block");
let block = compilation
.module_graph
.block_by_id(block)
.ok_or_else(|| internal_error!("should have block"))?;
.expect("should have block");
self.generate_source(block.get_dependencies(), compilation)
}
_ => self.generate_source(self.get_dependencies(), compilation),
Expand Down Expand Up @@ -430,11 +430,7 @@ impl ContextModule {
source.boxed()
}

fn generate_source(
&self,
dependencies: &[DependencyId],
compilation: &Compilation,
) -> Result<BoxSource> {
fn generate_source(&self, dependencies: &[DependencyId], compilation: &Compilation) -> BoxSource {
let map = self.get_user_request_map(dependencies, compilation);
let fake_map = self.get_fake_map(dependencies, compilation);
let mode = &self.options.context_options.mode;
Expand Down Expand Up @@ -522,7 +518,7 @@ impl ContextModule {
source.add(RawSource::from(format!(
"webpackContext.id = '{}';\n",
serde_json::to_string(self.id(&compilation.chunk_graph))
.map_err(|e| internal_error!(e.to_string()))?
.unwrap_or_else(|e| panic!("{}", e.to_string()))
)));
source.add(RawSource::from(
r#"
Expand All @@ -533,7 +529,7 @@ impl ContextModule {
module.exports = webpackContext;
"#,
));
Ok(source.boxed())
source.boxed()
}
}

Expand Down Expand Up @@ -640,7 +636,7 @@ impl Module for ContextModule {
let block = compilation
.module_graph
.block_by_id(block)
.ok_or_else(|| internal_error!("should have block in ContextModule code_generation"))?;
.expect("should have block in ContextModule code_generation");
all_deps.extend(block.get_dependencies());
}
let fake_map = self.get_fake_map(all_deps.iter(), compilation);
Expand All @@ -649,7 +645,7 @@ impl Module for ContextModule {
.runtime_requirements
.insert(RuntimeGlobals::CREATE_FAKE_NAMESPACE_OBJECT);
}
code_generation_result.add(SourceType::JavaScript, self.get_source_string(compilation)?);
code_generation_result.add(SourceType::JavaScript, self.get_source_string(compilation));
code_generation_result.set_hash(
&compilation.options.output.hash_function,
&compilation.options.output.hash_digest,
Expand Down
8 changes: 4 additions & 4 deletions crates/rspack_core/src/module_graph/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ use std::collections::hash_map::Entry;
use std::path::PathBuf;

use dashmap::DashMap;
use rspack_error::{internal_error, Result};
use rspack_error::Result;
use rspack_hash::RspackHashDigest;
use rspack_identifier::{Identifiable, IdentifierMap};
use rustc_hash::{FxHashMap as HashMap, FxHashSet as HashSet};
Expand Down Expand Up @@ -230,11 +230,11 @@ impl ModuleGraph {
{
let mgm = self
.module_graph_module_by_identifier_mut(&module_identifier)
.ok_or_else(|| {
internal_error!(
.unwrap_or_else(|| {
panic!(
"Failed to set resolved module: Module linked to module identifier {module_identifier} cannot be found"
)
})?;
});

mgm.add_incoming_connection(connection_id);
}
Expand Down
18 changes: 7 additions & 11 deletions crates/rspack_core/src/module_graph_module.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
use rspack_error::{internal_error, Result};
use rspack_error::Result;
use rustc_hash::FxHashSet as HashSet;

use crate::ExportsInfoId;
Expand Down Expand Up @@ -83,13 +83,11 @@ impl ModuleGraphModule {
.map(|connection_id| {
module_graph
.connection_by_connection_id(connection_id)
.ok_or_else(|| {
internal_error!(
"connection_id_to_connection does not have connection_id: {connection_id:?}"
)
.unwrap_or_else(|| {
panic!("connection_id_to_connection does not have connection_id: {connection_id:?}")
})
})
.collect::<Result<Vec<_>>>()?
.collect::<Vec<_>>()
.into_iter();

Ok(result)
Expand All @@ -105,13 +103,11 @@ impl ModuleGraphModule {
.map(|connection_id| {
module_graph
.connection_by_connection_id(connection_id)
.ok_or_else(|| {
internal_error!(
"connection_id_to_connection does not have connection_id: {connection_id:?}"
)
.unwrap_or_else(|| {
panic!("connection_id_to_connection does not have connection_id: {connection_id:?}")
})
})
.collect::<Result<Vec<_>>>()?
.collect::<Vec<_>>()
.into_iter();

Ok(result)
Expand Down
6 changes: 2 additions & 4 deletions crates/rspack_loader_react_refresh/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use rspack_core::LoaderRunnerContext;
use rspack_error::{internal_error, Result};
use rspack_error::Result;
use rspack_loader_runner::{Identifiable, Identifier, Loader, LoaderContext};

pub struct ReactRefreshLoader {
Expand Down Expand Up @@ -27,9 +27,7 @@ impl ReactRefreshLoader {
#[async_trait::async_trait]
impl Loader<LoaderRunnerContext> for ReactRefreshLoader {
async fn run(&self, loader_context: &mut LoaderContext<'_, LoaderRunnerContext>) -> Result<()> {
let Some(content) = std::mem::take(&mut loader_context.content) else {
return Err(internal_error!("Content should be available"));
};
let content = std::mem::take(&mut loader_context.content).expect("Content should be available");
let mut source = content.try_into_string()?;
source += r#"
function $RefreshSig$() {
Expand Down
2 changes: 1 addition & 1 deletion crates/rspack_loader_runner/src/runner.rs
Original file line number Diff line number Diff line change
Expand Up @@ -378,7 +378,7 @@ impl<C> TryFrom<LoaderContext<'_, C>> for TWithDiagnosticArray<LoaderResult> {
let loader = loader_context.__loader_items[0].to_string();
internal_error!("Final loader({loader}) didn't return a Buffer or String")
} else {
internal_error!("Content is not available, it is a bug")
panic!("content should be available");
}
})?;

Expand Down
29 changes: 13 additions & 16 deletions crates/rspack_loader_sass/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -486,23 +486,20 @@ impl Loader<LoaderRunnerContext> for SassLoader {
})?
.render(sass_options)
.map_err(sass_exception_to_error)?;
let source_map = result
.map
.map(|map| -> Result<SourceMap> {
let mut map = SourceMap::from_slice(&map).map_err(|e| internal_error!(e.to_string()))?;
for source in map.sources_mut() {
if source.starts_with("file:") {
*source = Url::parse(source)
.expect("TODO:")
.to_file_path()
.expect("TODO:")
.display()
.to_string();
}
let source_map = result.map.map(|map| {
let mut map = SourceMap::from_slice(&map).expect("should be able to generate source-map");
for source in map.sources_mut() {
if source.starts_with("file:") {
*source = Url::parse(source)
.expect("TODO:")
.to_file_path()
.expect("TODO:")
.display()
.to_string();
}
Ok(map)
})
.transpose()?;
}
map
});

loader_context.content = Some(result.css.into());
loader_context.source_map = source_map;
Expand Down
Loading

0 comments on commit 361c3fe

Please sign in to comment.