mirror of
https://github.com/denoland/deno.git
synced 2025-01-21 21:50:00 -05:00
fix(bundle): explicit error when using an npm specifier with deno bundle (#16637)
This commit is contained in:
parent
1c373ce6f9
commit
191f4f16ad
2 changed files with 50 additions and 24 deletions
62
cli/main.rs
62
cli/main.rs
|
@ -68,7 +68,6 @@ use crate::emit::TsConfigType;
|
||||||
use crate::file_fetcher::File;
|
use crate::file_fetcher::File;
|
||||||
use crate::file_watcher::ResolutionResult;
|
use crate::file_watcher::ResolutionResult;
|
||||||
use crate::graph_util::graph_lock_or_exit;
|
use crate::graph_util::graph_lock_or_exit;
|
||||||
use crate::graph_util::graph_valid;
|
|
||||||
use crate::proc_state::ProcState;
|
use crate::proc_state::ProcState;
|
||||||
use crate::resolver::CliResolver;
|
use crate::resolver::CliResolver;
|
||||||
use crate::tools::check;
|
use crate::tools::check;
|
||||||
|
@ -89,6 +88,7 @@ use deno_runtime::colors;
|
||||||
use deno_runtime::fmt_errors::format_js_error;
|
use deno_runtime::fmt_errors::format_js_error;
|
||||||
use deno_runtime::permissions::Permissions;
|
use deno_runtime::permissions::Permissions;
|
||||||
use deno_runtime::tokio_util::run_local;
|
use deno_runtime::tokio_util::run_local;
|
||||||
|
use graph_util::GraphData;
|
||||||
use log::debug;
|
use log::debug;
|
||||||
use log::info;
|
use log::info;
|
||||||
use npm::NpmPackageReference;
|
use npm::NpmPackageReference;
|
||||||
|
@ -150,22 +150,10 @@ async fn compile_command(
|
||||||
generic_error("There should only be one reference to ModuleGraph")
|
generic_error("There should only be one reference to ModuleGraph")
|
||||||
})?;
|
})?;
|
||||||
|
|
||||||
graph.valid().unwrap();
|
|
||||||
|
|
||||||
// at the moment, we don't support npm specifiers in deno_compile, so show an error
|
// at the moment, we don't support npm specifiers in deno_compile, so show an error
|
||||||
let first_npm_specifier = graph
|
error_for_any_npm_specifier(&graph)?;
|
||||||
.specifiers()
|
|
||||||
.values()
|
graph.valid().unwrap();
|
||||||
.filter_map(|r| match r {
|
|
||||||
Ok((specifier, kind, _)) if *kind == deno_graph::ModuleKind::External => {
|
|
||||||
Some(specifier.clone())
|
|
||||||
}
|
|
||||||
_ => None,
|
|
||||||
})
|
|
||||||
.next();
|
|
||||||
if let Some(npm_specifier) = first_npm_specifier {
|
|
||||||
bail!("npm specifiers have not yet been implemented for deno compile (https://github.com/denoland/deno/issues/15960). Found: {}", npm_specifier)
|
|
||||||
}
|
|
||||||
|
|
||||||
let parser = ps.parsed_source_cache.as_capturing_parser();
|
let parser = ps.parsed_source_cache.as_capturing_parser();
|
||||||
let eszip = eszip::EszipV2::from_graph(graph, &parser, Default::default())?;
|
let eszip = eszip::EszipV2::from_graph(graph, &parser, Default::default())?;
|
||||||
|
@ -384,11 +372,18 @@ async fn create_graph_and_maybe_check(
|
||||||
);
|
);
|
||||||
|
|
||||||
let check_js = ps.options.check_js();
|
let check_js = ps.options.check_js();
|
||||||
graph_valid(
|
let mut graph_data = GraphData::default();
|
||||||
&graph,
|
graph_data.add_graph(&graph, false);
|
||||||
ps.options.type_check_mode() != TypeCheckMode::None,
|
graph_data
|
||||||
check_js,
|
.check(
|
||||||
)?;
|
&graph.roots,
|
||||||
|
ps.options.type_check_mode() != TypeCheckMode::None,
|
||||||
|
check_js,
|
||||||
|
)
|
||||||
|
.unwrap()?;
|
||||||
|
ps.npm_resolver
|
||||||
|
.add_package_reqs(graph_data.npm_package_reqs().clone())
|
||||||
|
.await?;
|
||||||
graph_lock_or_exit(&graph);
|
graph_lock_or_exit(&graph);
|
||||||
|
|
||||||
if ps.options.type_check_mode() != TypeCheckMode::None {
|
if ps.options.type_check_mode() != TypeCheckMode::None {
|
||||||
|
@ -403,7 +398,7 @@ async fn create_graph_and_maybe_check(
|
||||||
let cache = TypeCheckCache::new(&ps.dir.type_checking_cache_db_file_path());
|
let cache = TypeCheckCache::new(&ps.dir.type_checking_cache_db_file_path());
|
||||||
let check_result = check::check(
|
let check_result = check::check(
|
||||||
&graph.roots,
|
&graph.roots,
|
||||||
Arc::new(RwLock::new(graph.as_ref().into())),
|
Arc::new(RwLock::new(graph_data)),
|
||||||
&cache,
|
&cache,
|
||||||
ps.npm_resolver.clone(),
|
ps.npm_resolver.clone(),
|
||||||
check::CheckOptions {
|
check::CheckOptions {
|
||||||
|
@ -500,6 +495,9 @@ async fn bundle_command(
|
||||||
let operation = |(ps, graph): (ProcState, Arc<deno_graph::ModuleGraph>)| {
|
let operation = |(ps, graph): (ProcState, Arc<deno_graph::ModuleGraph>)| {
|
||||||
let out_file = bundle_flags.out_file.clone();
|
let out_file = bundle_flags.out_file.clone();
|
||||||
async move {
|
async move {
|
||||||
|
// at the moment, we don't support npm specifiers in deno bundle, so show an error
|
||||||
|
error_for_any_npm_specifier(&graph)?;
|
||||||
|
|
||||||
let bundle_output = bundle_module_graph(graph.as_ref(), &ps)?;
|
let bundle_output = bundle_module_graph(graph.as_ref(), &ps)?;
|
||||||
debug!(">>>>> bundle END");
|
debug!(">>>>> bundle END");
|
||||||
|
|
||||||
|
@ -561,6 +559,26 @@ async fn bundle_command(
|
||||||
Ok(0)
|
Ok(0)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn error_for_any_npm_specifier(
|
||||||
|
graph: &deno_graph::ModuleGraph,
|
||||||
|
) -> Result<(), AnyError> {
|
||||||
|
let first_npm_specifier = graph
|
||||||
|
.specifiers()
|
||||||
|
.values()
|
||||||
|
.filter_map(|r| match r {
|
||||||
|
Ok((specifier, kind, _)) if *kind == deno_graph::ModuleKind::External => {
|
||||||
|
Some(specifier.clone())
|
||||||
|
}
|
||||||
|
_ => None,
|
||||||
|
})
|
||||||
|
.next();
|
||||||
|
if let Some(npm_specifier) = first_npm_specifier {
|
||||||
|
bail!("npm specifiers have not yet been implemented for this sub command (https://github.com/denoland/deno/issues/15960). Found: {}", npm_specifier)
|
||||||
|
} else {
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
async fn doc_command(
|
async fn doc_command(
|
||||||
flags: Flags,
|
flags: Flags,
|
||||||
doc_flags: DocFlags,
|
doc_flags: DocFlags,
|
||||||
|
|
|
@ -719,8 +719,16 @@ fn ensure_registry_files_local() {
|
||||||
}
|
}
|
||||||
|
|
||||||
itest!(compile_errors {
|
itest!(compile_errors {
|
||||||
args: "compile -A --quiet npm/esm/main.js",
|
args: "compile -A --quiet npm/cached_only/main.ts",
|
||||||
output_str: Some("error: npm specifiers have not yet been implemented for deno compile (https://github.com/denoland/deno/issues/15960). Found: npm:chalk@5\n"),
|
output_str: Some("error: npm specifiers have not yet been implemented for this sub command (https://github.com/denoland/deno/issues/15960). Found: npm:chalk@5\n"),
|
||||||
|
exit_code: 1,
|
||||||
|
envs: env_vars(),
|
||||||
|
http_server: true,
|
||||||
|
});
|
||||||
|
|
||||||
|
itest!(bundle_errors {
|
||||||
|
args: "bundle --quiet npm/esm/main.js",
|
||||||
|
output_str: Some("error: npm specifiers have not yet been implemented for this sub command (https://github.com/denoland/deno/issues/15960). Found: npm:chalk@5\n"),
|
||||||
exit_code: 1,
|
exit_code: 1,
|
||||||
envs: env_vars(),
|
envs: env_vars(),
|
||||||
http_server: true,
|
http_server: true,
|
||||||
|
|
Loading…
Add table
Reference in a new issue