mirror of
https://github.com/denoland/deno.git
synced 2025-01-08 15:19:40 -05:00
refactor(npm): reorganize initialization of compat layer (#16471)
Ensures that "std/node" graph is analyzed only once.
This commit is contained in:
parent
e202f890f0
commit
2c674dcd20
3 changed files with 27 additions and 23 deletions
11
cli/main.rs
11
cli/main.rs
|
@ -292,17 +292,6 @@ async fn load_and_type_check(
|
||||||
for file in files {
|
for file in files {
|
||||||
let specifier = resolve_url_or_path(file)?;
|
let specifier = resolve_url_or_path(file)?;
|
||||||
|
|
||||||
// TODO(bartlomieju): in the future (after all relevant deno subcommands
|
|
||||||
// have support for npm: specifiers), it would be good to unify this code
|
|
||||||
// in `ProcState::prepare_module_load`.
|
|
||||||
if let Ok(package_ref) = NpmPackageReference::from_specifier(&specifier) {
|
|
||||||
ps.npm_resolver
|
|
||||||
.add_package_reqs(vec![package_ref.req.clone()])
|
|
||||||
.await?;
|
|
||||||
ps.prepare_node_std_graph().await?;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
ps.prepare_module_load(
|
ps.prepare_module_load(
|
||||||
vec![specifier],
|
vec![specifier],
|
||||||
false,
|
false,
|
||||||
|
|
|
@ -61,6 +61,8 @@ use log::warn;
|
||||||
use std::collections::HashSet;
|
use std::collections::HashSet;
|
||||||
use std::ops::Deref;
|
use std::ops::Deref;
|
||||||
use std::path::PathBuf;
|
use std::path::PathBuf;
|
||||||
|
use std::sync::atomic::AtomicBool;
|
||||||
|
use std::sync::atomic::Ordering;
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
|
|
||||||
/// This structure represents state of single "deno" program.
|
/// This structure represents state of single "deno" program.
|
||||||
|
@ -93,6 +95,7 @@ pub struct Inner {
|
||||||
pub npm_resolver: NpmPackageResolver,
|
pub npm_resolver: NpmPackageResolver,
|
||||||
pub cjs_resolutions: Mutex<HashSet<ModuleSpecifier>>,
|
pub cjs_resolutions: Mutex<HashSet<ModuleSpecifier>>,
|
||||||
progress_bar: ProgressBar,
|
progress_bar: ProgressBar,
|
||||||
|
node_std_graph_prepared: AtomicBool,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Deref for ProcState {
|
impl Deref for ProcState {
|
||||||
|
@ -280,6 +283,7 @@ impl ProcState {
|
||||||
npm_resolver,
|
npm_resolver,
|
||||||
cjs_resolutions: Default::default(),
|
cjs_resolutions: Default::default(),
|
||||||
progress_bar,
|
progress_bar,
|
||||||
|
node_std_graph_prepared: AtomicBool::new(false),
|
||||||
})))
|
})))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -297,12 +301,20 @@ impl ProcState {
|
||||||
reload_on_watch: bool,
|
reload_on_watch: bool,
|
||||||
) -> Result<(), AnyError> {
|
) -> Result<(), AnyError> {
|
||||||
let _pb_clear_guard = self.progress_bar.clear_guard();
|
let _pb_clear_guard = self.progress_bar.clear_guard();
|
||||||
|
let mut npm_package_reqs = vec![];
|
||||||
|
|
||||||
|
for root in &roots {
|
||||||
|
if let Ok(package_ref) = NpmPackageReference::from_specifier(root) {
|
||||||
|
npm_package_reqs.push(package_ref.req);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
let roots = roots
|
let roots = roots
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.map(|s| (s, ModuleKind::Esm))
|
.map(|s| (s, ModuleKind::Esm))
|
||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
|
|
||||||
if !reload_on_watch {
|
if !reload_on_watch && npm_package_reqs.is_empty() {
|
||||||
let graph_data = self.graph_data.read();
|
let graph_data = self.graph_data.read();
|
||||||
if self.options.type_check_mode() == TypeCheckMode::None
|
if self.options.type_check_mode() == TypeCheckMode::None
|
||||||
|| graph_data.is_type_checked(&roots, &lib)
|
|| graph_data.is_type_checked(&roots, &lib)
|
||||||
|
@ -397,7 +409,7 @@ impl ProcState {
|
||||||
graph_data.entries().map(|(s, _)| s).cloned().collect()
|
graph_data.entries().map(|(s, _)| s).cloned().collect()
|
||||||
};
|
};
|
||||||
|
|
||||||
let npm_package_references = {
|
{
|
||||||
let mut graph_data = self.graph_data.write();
|
let mut graph_data = self.graph_data.write();
|
||||||
graph_data.add_graph(&graph, reload_on_watch);
|
graph_data.add_graph(&graph, reload_on_watch);
|
||||||
let check_js = self.options.check_js();
|
let check_js = self.options.check_js();
|
||||||
|
@ -408,14 +420,11 @@ impl ProcState {
|
||||||
check_js,
|
check_js,
|
||||||
)
|
)
|
||||||
.unwrap()?;
|
.unwrap()?;
|
||||||
graph_data.npm_package_reqs()
|
npm_package_reqs.extend(graph_data.npm_package_reqs());
|
||||||
};
|
};
|
||||||
|
|
||||||
if !npm_package_references.is_empty() {
|
if !npm_package_reqs.is_empty() {
|
||||||
self
|
self.npm_resolver.add_package_reqs(npm_package_reqs).await?;
|
||||||
.npm_resolver
|
|
||||||
.add_package_reqs(npm_package_references)
|
|
||||||
.await?;
|
|
||||||
self.prepare_node_std_graph().await?;
|
self.prepare_node_std_graph().await?;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -471,10 +480,15 @@ impl ProcState {
|
||||||
// FIXME(bartlomieju): appears this function can be called more than once
|
// FIXME(bartlomieju): appears this function can be called more than once
|
||||||
// if we have npm imports
|
// if we have npm imports
|
||||||
pub async fn prepare_node_std_graph(&self) -> Result<(), AnyError> {
|
pub async fn prepare_node_std_graph(&self) -> Result<(), AnyError> {
|
||||||
|
if self.node_std_graph_prepared.load(Ordering::Relaxed) {
|
||||||
|
return Ok(());
|
||||||
|
}
|
||||||
|
|
||||||
let node_std_graph = self
|
let node_std_graph = self
|
||||||
.create_graph(vec![(node::MODULE_ALL_URL.clone(), ModuleKind::Esm)])
|
.create_graph(vec![(node::MODULE_ALL_URL.clone(), ModuleKind::Esm)])
|
||||||
.await?;
|
.await?;
|
||||||
self.graph_data.write().add_graph(&node_std_graph, false);
|
self.graph_data.write().add_graph(&node_std_graph, false);
|
||||||
|
self.node_std_graph_prepared.store(true, Ordering::Relaxed);
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -60,6 +60,7 @@ impl CliMainWorker {
|
||||||
log::debug!("main_module {}", self.main_module);
|
log::debug!("main_module {}", self.main_module);
|
||||||
|
|
||||||
if self.is_main_cjs {
|
if self.is_main_cjs {
|
||||||
|
self.ps.prepare_node_std_graph().await?;
|
||||||
self.initialize_main_module_for_node().await?;
|
self.initialize_main_module_for_node().await?;
|
||||||
node::load_cjs_module_from_ext_node(
|
node::load_cjs_module_from_ext_node(
|
||||||
&mut self.worker.js_runtime,
|
&mut self.worker.js_runtime,
|
||||||
|
@ -280,6 +281,9 @@ impl CliMainWorker {
|
||||||
async fn execute_main_module_possibly_with_npm(
|
async fn execute_main_module_possibly_with_npm(
|
||||||
&mut self,
|
&mut self,
|
||||||
) -> Result<(), AnyError> {
|
) -> Result<(), AnyError> {
|
||||||
|
if self.ps.npm_resolver.has_packages() {
|
||||||
|
self.ps.prepare_node_std_graph().await?;
|
||||||
|
}
|
||||||
let id = self.worker.preload_main_module(&self.main_module).await?;
|
let id = self.worker.preload_main_module(&self.main_module).await?;
|
||||||
self.evaluate_module_possibly_with_npm(id).await
|
self.evaluate_module_possibly_with_npm(id).await
|
||||||
}
|
}
|
||||||
|
@ -302,6 +306,7 @@ impl CliMainWorker {
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn initialize_main_module_for_node(&mut self) -> Result<(), AnyError> {
|
async fn initialize_main_module_for_node(&mut self) -> Result<(), AnyError> {
|
||||||
|
self.ps.prepare_node_std_graph().await?;
|
||||||
node::initialize_runtime(&mut self.worker.js_runtime).await?;
|
node::initialize_runtime(&mut self.worker.js_runtime).await?;
|
||||||
if let DenoSubcommand::Run(flags) = self.ps.options.sub_command() {
|
if let DenoSubcommand::Run(flags) = self.ps.options.sub_command() {
|
||||||
if let Ok(pkg_ref) = NpmPackageReference::from_str(&flags.script) {
|
if let Ok(pkg_ref) = NpmPackageReference::from_str(&flags.script) {
|
||||||
|
@ -372,10 +377,6 @@ pub async fn create_main_worker(
|
||||||
(main_module, false)
|
(main_module, false)
|
||||||
};
|
};
|
||||||
|
|
||||||
if ps.npm_resolver.has_packages() {
|
|
||||||
ps.prepare_node_std_graph().await?;
|
|
||||||
}
|
|
||||||
|
|
||||||
let module_loader = CliModuleLoader::new(ps.clone());
|
let module_loader = CliModuleLoader::new(ps.clone());
|
||||||
|
|
||||||
let maybe_inspector_server = ps.maybe_inspector_server.clone();
|
let maybe_inspector_server = ps.maybe_inspector_server.clone();
|
||||||
|
|
Loading…
Reference in a new issue