mirror of
https://github.com/denoland/deno.git
synced 2025-01-12 00:54:02 -05:00
refactor: remove module graph setup from ModuleLoader (#22442)
`ModuleLoader` was doing too much duplicate work.
This commit is contained in:
parent
67a4231bb6
commit
828d9b8485
4 changed files with 72 additions and 124 deletions
|
@ -657,12 +657,8 @@ impl CliFactory {
|
||||||
self.fs().clone(),
|
self.fs().clone(),
|
||||||
self.graph_container().clone(),
|
self.graph_container().clone(),
|
||||||
self.maybe_lockfile().clone(),
|
self.maybe_lockfile().clone(),
|
||||||
self.maybe_file_watcher_reporter().clone(),
|
|
||||||
self.module_graph_builder().await?.clone(),
|
self.module_graph_builder().await?.clone(),
|
||||||
self.module_info_cache()?.clone(),
|
|
||||||
self.parsed_source_cache().clone(),
|
|
||||||
self.text_only_progress_bar().clone(),
|
self.text_only_progress_bar().clone(),
|
||||||
self.resolver().await?.clone(),
|
|
||||||
self.type_checker().await?.clone(),
|
self.type_checker().await?.clone(),
|
||||||
)))
|
)))
|
||||||
})
|
})
|
||||||
|
|
|
@ -206,6 +206,7 @@ pub fn graph_lock_or_exit(graph: &ModuleGraph, lockfile: &mut Lockfile) {
|
||||||
pub struct CreateGraphOptions<'a> {
|
pub struct CreateGraphOptions<'a> {
|
||||||
pub graph_kind: GraphKind,
|
pub graph_kind: GraphKind,
|
||||||
pub roots: Vec<ModuleSpecifier>,
|
pub roots: Vec<ModuleSpecifier>,
|
||||||
|
pub is_dynamic: bool,
|
||||||
/// Whether to do fast check on workspace members. This is mostly only
|
/// Whether to do fast check on workspace members. This is mostly only
|
||||||
/// useful when publishing.
|
/// useful when publishing.
|
||||||
pub workspace_fast_check: bool,
|
pub workspace_fast_check: bool,
|
||||||
|
@ -279,6 +280,7 @@ impl ModuleGraphBuilder {
|
||||||
) -> Result<deno_graph::ModuleGraph, AnyError> {
|
) -> Result<deno_graph::ModuleGraph, AnyError> {
|
||||||
self
|
self
|
||||||
.create_graph_with_options(CreateGraphOptions {
|
.create_graph_with_options(CreateGraphOptions {
|
||||||
|
is_dynamic: false,
|
||||||
graph_kind,
|
graph_kind,
|
||||||
roots,
|
roots,
|
||||||
loader: Some(loader),
|
loader: Some(loader),
|
||||||
|
@ -291,54 +293,10 @@ impl ModuleGraphBuilder {
|
||||||
&self,
|
&self,
|
||||||
options: CreateGraphOptions<'_>,
|
options: CreateGraphOptions<'_>,
|
||||||
) -> Result<deno_graph::ModuleGraph, AnyError> {
|
) -> Result<deno_graph::ModuleGraph, AnyError> {
|
||||||
enum MutLoaderRef<'a> {
|
|
||||||
Borrowed(&'a mut dyn Loader),
|
|
||||||
Owned(cache::FetchCacher),
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'a> MutLoaderRef<'a> {
|
|
||||||
pub fn as_mut_loader(&mut self) -> &mut dyn Loader {
|
|
||||||
match self {
|
|
||||||
Self::Borrowed(loader) => *loader,
|
|
||||||
Self::Owned(loader) => loader,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let parser = self.parsed_source_cache.as_capturing_parser();
|
|
||||||
let analyzer = self.module_info_cache.as_module_analyzer(&parser);
|
|
||||||
let maybe_imports = self.options.to_maybe_imports()?;
|
|
||||||
let cli_resolver = self.resolver.clone();
|
|
||||||
let graph_resolver = cli_resolver.as_graph_resolver();
|
|
||||||
let graph_npm_resolver = cli_resolver.as_graph_npm_resolver();
|
|
||||||
let maybe_file_watcher_reporter = self
|
|
||||||
.maybe_file_watcher_reporter
|
|
||||||
.as_ref()
|
|
||||||
.map(|r| r.as_reporter());
|
|
||||||
let mut loader = match options.loader {
|
|
||||||
Some(loader) => MutLoaderRef::Borrowed(loader),
|
|
||||||
None => MutLoaderRef::Owned(self.create_graph_loader()),
|
|
||||||
};
|
|
||||||
|
|
||||||
let mut graph = ModuleGraph::new(options.graph_kind);
|
let mut graph = ModuleGraph::new(options.graph_kind);
|
||||||
|
|
||||||
self
|
self
|
||||||
.build_graph_with_npm_resolution(
|
.build_graph_with_npm_resolution(&mut graph, options)
|
||||||
&mut graph,
|
|
||||||
options.roots,
|
|
||||||
loader.as_mut_loader(),
|
|
||||||
deno_graph::BuildOptions {
|
|
||||||
is_dynamic: false,
|
|
||||||
imports: maybe_imports,
|
|
||||||
resolver: Some(graph_resolver),
|
|
||||||
file_system: Some(&DenoGraphFsAdapter(self.fs.as_ref())),
|
|
||||||
npm_resolver: Some(graph_npm_resolver),
|
|
||||||
module_analyzer: Some(&analyzer),
|
|
||||||
module_parser: Some(&parser),
|
|
||||||
reporter: maybe_file_watcher_reporter,
|
|
||||||
workspace_fast_check: options.workspace_fast_check,
|
|
||||||
workspace_members: self.get_deno_graph_workspace_members()?,
|
|
||||||
},
|
|
||||||
)
|
|
||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
if let Some(npm_resolver) = self.npm_resolver.as_managed() {
|
if let Some(npm_resolver) = self.npm_resolver.as_managed() {
|
||||||
|
@ -354,38 +312,16 @@ impl ModuleGraphBuilder {
|
||||||
&self,
|
&self,
|
||||||
roots: Vec<ModuleSpecifier>,
|
roots: Vec<ModuleSpecifier>,
|
||||||
) -> Result<Arc<deno_graph::ModuleGraph>, AnyError> {
|
) -> Result<Arc<deno_graph::ModuleGraph>, AnyError> {
|
||||||
let mut cache = self.create_graph_loader();
|
|
||||||
let maybe_imports = self.options.to_maybe_imports()?;
|
|
||||||
let cli_resolver = self.resolver.clone();
|
|
||||||
let graph_resolver = cli_resolver.as_graph_resolver();
|
|
||||||
let graph_npm_resolver = cli_resolver.as_graph_npm_resolver();
|
|
||||||
let parser = self.parsed_source_cache.as_capturing_parser();
|
|
||||||
let analyzer = self.module_info_cache.as_module_analyzer(&parser);
|
|
||||||
let graph_kind = self.options.type_check_mode().as_graph_kind();
|
let graph_kind = self.options.type_check_mode().as_graph_kind();
|
||||||
let mut graph = ModuleGraph::new(graph_kind);
|
|
||||||
let maybe_file_watcher_reporter = self
|
|
||||||
.maybe_file_watcher_reporter
|
|
||||||
.as_ref()
|
|
||||||
.map(|r| r.as_reporter());
|
|
||||||
|
|
||||||
self
|
let graph = self
|
||||||
.build_graph_with_npm_resolution(
|
.create_graph_with_options(CreateGraphOptions {
|
||||||
&mut graph,
|
|
||||||
roots,
|
|
||||||
&mut cache,
|
|
||||||
deno_graph::BuildOptions {
|
|
||||||
is_dynamic: false,
|
is_dynamic: false,
|
||||||
imports: maybe_imports,
|
graph_kind,
|
||||||
file_system: Some(&DenoGraphFsAdapter(self.fs.as_ref())),
|
roots,
|
||||||
resolver: Some(graph_resolver),
|
loader: None,
|
||||||
npm_resolver: Some(graph_npm_resolver),
|
|
||||||
module_analyzer: Some(&analyzer),
|
|
||||||
module_parser: Some(&parser),
|
|
||||||
reporter: maybe_file_watcher_reporter,
|
|
||||||
workspace_fast_check: false,
|
workspace_fast_check: false,
|
||||||
workspace_members: self.get_deno_graph_workspace_members()?,
|
})
|
||||||
},
|
|
||||||
)
|
|
||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
let graph = Arc::new(graph);
|
let graph = Arc::new(graph);
|
||||||
|
@ -441,6 +377,60 @@ impl ModuleGraphBuilder {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn build_graph_with_npm_resolution<'a>(
|
pub async fn build_graph_with_npm_resolution<'a>(
|
||||||
|
&self,
|
||||||
|
graph: &mut ModuleGraph,
|
||||||
|
options: CreateGraphOptions<'a>,
|
||||||
|
) -> Result<(), AnyError> {
|
||||||
|
enum MutLoaderRef<'a> {
|
||||||
|
Borrowed(&'a mut dyn Loader),
|
||||||
|
Owned(cache::FetchCacher),
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> MutLoaderRef<'a> {
|
||||||
|
pub fn as_mut_loader(&mut self) -> &mut dyn Loader {
|
||||||
|
match self {
|
||||||
|
Self::Borrowed(loader) => *loader,
|
||||||
|
Self::Owned(loader) => loader,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let maybe_imports = self.options.to_maybe_imports()?;
|
||||||
|
let parser = self.parsed_source_cache.as_capturing_parser();
|
||||||
|
let analyzer = self.module_info_cache.as_module_analyzer(&parser);
|
||||||
|
let mut loader = match options.loader {
|
||||||
|
Some(loader) => MutLoaderRef::Borrowed(loader),
|
||||||
|
None => MutLoaderRef::Owned(self.create_graph_loader()),
|
||||||
|
};
|
||||||
|
let cli_resolver = self.resolver.clone();
|
||||||
|
let graph_resolver = cli_resolver.as_graph_resolver();
|
||||||
|
let graph_npm_resolver = cli_resolver.as_graph_npm_resolver();
|
||||||
|
let maybe_file_watcher_reporter = self
|
||||||
|
.maybe_file_watcher_reporter
|
||||||
|
.as_ref()
|
||||||
|
.map(|r| r.as_reporter());
|
||||||
|
self
|
||||||
|
.build_graph_with_npm_resolution_and_build_options(
|
||||||
|
graph,
|
||||||
|
options.roots,
|
||||||
|
loader.as_mut_loader(),
|
||||||
|
deno_graph::BuildOptions {
|
||||||
|
is_dynamic: options.is_dynamic,
|
||||||
|
imports: maybe_imports,
|
||||||
|
resolver: Some(graph_resolver),
|
||||||
|
file_system: Some(&DenoGraphFsAdapter(self.fs.as_ref())),
|
||||||
|
npm_resolver: Some(graph_npm_resolver),
|
||||||
|
module_analyzer: Some(&analyzer),
|
||||||
|
module_parser: Some(&parser),
|
||||||
|
reporter: maybe_file_watcher_reporter,
|
||||||
|
workspace_fast_check: options.workspace_fast_check,
|
||||||
|
workspace_members: self.get_deno_graph_workspace_members()?,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
.await
|
||||||
|
}
|
||||||
|
|
||||||
|
async fn build_graph_with_npm_resolution_and_build_options<'a>(
|
||||||
&self,
|
&self,
|
||||||
graph: &mut ModuleGraph,
|
graph: &mut ModuleGraph,
|
||||||
roots: Vec<ModuleSpecifier>,
|
roots: Vec<ModuleSpecifier>,
|
||||||
|
@ -841,7 +831,7 @@ impl deno_graph::source::Reporter for FileWatcherReporter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn workspace_config_to_workspace_members(
|
fn workspace_config_to_workspace_members(
|
||||||
workspace_config: &deno_config::WorkspaceConfig,
|
workspace_config: &deno_config::WorkspaceConfig,
|
||||||
) -> Result<Vec<deno_graph::WorkspaceMember>, AnyError> {
|
) -> Result<Vec<deno_graph::WorkspaceMember>, AnyError> {
|
||||||
workspace_config
|
workspace_config
|
||||||
|
|
|
@ -3,14 +3,11 @@
|
||||||
use crate::args::CliOptions;
|
use crate::args::CliOptions;
|
||||||
use crate::args::DenoSubcommand;
|
use crate::args::DenoSubcommand;
|
||||||
use crate::args::TsTypeLib;
|
use crate::args::TsTypeLib;
|
||||||
use crate::cache::ModuleInfoCache;
|
|
||||||
use crate::cache::ParsedSourceCache;
|
use crate::cache::ParsedSourceCache;
|
||||||
use crate::emit::Emitter;
|
use crate::emit::Emitter;
|
||||||
use crate::graph_util::graph_lock_or_exit;
|
use crate::graph_util::graph_lock_or_exit;
|
||||||
use crate::graph_util::graph_valid_with_cli_options;
|
use crate::graph_util::graph_valid_with_cli_options;
|
||||||
use crate::graph_util::workspace_config_to_workspace_members;
|
use crate::graph_util::CreateGraphOptions;
|
||||||
use crate::graph_util::DenoGraphFsAdapter;
|
|
||||||
use crate::graph_util::FileWatcherReporter;
|
|
||||||
use crate::graph_util::ModuleGraphBuilder;
|
use crate::graph_util::ModuleGraphBuilder;
|
||||||
use crate::graph_util::ModuleGraphContainer;
|
use crate::graph_util::ModuleGraphContainer;
|
||||||
use crate::node;
|
use crate::node;
|
||||||
|
@ -68,12 +65,8 @@ pub struct ModuleLoadPreparer {
|
||||||
fs: Arc<dyn deno_fs::FileSystem>,
|
fs: Arc<dyn deno_fs::FileSystem>,
|
||||||
graph_container: Arc<ModuleGraphContainer>,
|
graph_container: Arc<ModuleGraphContainer>,
|
||||||
lockfile: Option<Arc<Mutex<Lockfile>>>,
|
lockfile: Option<Arc<Mutex<Lockfile>>>,
|
||||||
maybe_file_watcher_reporter: Option<FileWatcherReporter>,
|
|
||||||
module_graph_builder: Arc<ModuleGraphBuilder>,
|
module_graph_builder: Arc<ModuleGraphBuilder>,
|
||||||
module_info_cache: Arc<ModuleInfoCache>,
|
|
||||||
parsed_source_cache: Arc<ParsedSourceCache>,
|
|
||||||
progress_bar: ProgressBar,
|
progress_bar: ProgressBar,
|
||||||
resolver: Arc<CliGraphResolver>,
|
|
||||||
type_checker: Arc<TypeChecker>,
|
type_checker: Arc<TypeChecker>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -84,12 +77,8 @@ impl ModuleLoadPreparer {
|
||||||
fs: Arc<dyn deno_fs::FileSystem>,
|
fs: Arc<dyn deno_fs::FileSystem>,
|
||||||
graph_container: Arc<ModuleGraphContainer>,
|
graph_container: Arc<ModuleGraphContainer>,
|
||||||
lockfile: Option<Arc<Mutex<Lockfile>>>,
|
lockfile: Option<Arc<Mutex<Lockfile>>>,
|
||||||
maybe_file_watcher_reporter: Option<FileWatcherReporter>,
|
|
||||||
module_graph_builder: Arc<ModuleGraphBuilder>,
|
module_graph_builder: Arc<ModuleGraphBuilder>,
|
||||||
module_info_cache: Arc<ModuleInfoCache>,
|
|
||||||
parsed_source_cache: Arc<ParsedSourceCache>,
|
|
||||||
progress_bar: ProgressBar,
|
progress_bar: ProgressBar,
|
||||||
resolver: Arc<CliGraphResolver>,
|
|
||||||
type_checker: Arc<TypeChecker>,
|
type_checker: Arc<TypeChecker>,
|
||||||
) -> Self {
|
) -> Self {
|
||||||
Self {
|
Self {
|
||||||
|
@ -97,12 +86,8 @@ impl ModuleLoadPreparer {
|
||||||
fs,
|
fs,
|
||||||
graph_container,
|
graph_container,
|
||||||
lockfile,
|
lockfile,
|
||||||
maybe_file_watcher_reporter,
|
|
||||||
module_graph_builder,
|
module_graph_builder,
|
||||||
module_info_cache,
|
|
||||||
parsed_source_cache,
|
|
||||||
progress_bar,
|
progress_bar,
|
||||||
resolver,
|
|
||||||
type_checker,
|
type_checker,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -123,23 +108,6 @@ impl ModuleLoadPreparer {
|
||||||
let _pb_clear_guard = self.progress_bar.clear_guard();
|
let _pb_clear_guard = self.progress_bar.clear_guard();
|
||||||
|
|
||||||
let mut cache = self.module_graph_builder.create_fetch_cacher(permissions);
|
let mut cache = self.module_graph_builder.create_fetch_cacher(permissions);
|
||||||
let maybe_imports = self.options.to_maybe_imports()?;
|
|
||||||
let maybe_workspace_config = self.options.maybe_workspace_config();
|
|
||||||
let workspace_members = if let Some(wc) = maybe_workspace_config {
|
|
||||||
workspace_config_to_workspace_members(wc)?
|
|
||||||
} else {
|
|
||||||
vec![]
|
|
||||||
};
|
|
||||||
let graph_resolver = self.resolver.as_graph_resolver();
|
|
||||||
let graph_npm_resolver = self.resolver.as_graph_npm_resolver();
|
|
||||||
let maybe_file_watcher_reporter = self
|
|
||||||
.maybe_file_watcher_reporter
|
|
||||||
.as_ref()
|
|
||||||
.map(|r| r.as_reporter());
|
|
||||||
|
|
||||||
let parser = self.parsed_source_cache.as_capturing_parser();
|
|
||||||
let analyzer = self.module_info_cache.as_module_analyzer(&parser);
|
|
||||||
|
|
||||||
log::debug!("Creating module graph.");
|
log::debug!("Creating module graph.");
|
||||||
let mut graph_update_permit =
|
let mut graph_update_permit =
|
||||||
self.graph_container.acquire_update_permit().await;
|
self.graph_container.acquire_update_permit().await;
|
||||||
|
@ -154,19 +122,12 @@ impl ModuleLoadPreparer {
|
||||||
.module_graph_builder
|
.module_graph_builder
|
||||||
.build_graph_with_npm_resolution(
|
.build_graph_with_npm_resolution(
|
||||||
graph,
|
graph,
|
||||||
roots.clone(),
|
CreateGraphOptions {
|
||||||
&mut cache,
|
|
||||||
deno_graph::BuildOptions {
|
|
||||||
is_dynamic,
|
is_dynamic,
|
||||||
imports: maybe_imports,
|
graph_kind: graph.graph_kind(),
|
||||||
file_system: Some(&DenoGraphFsAdapter(self.fs.as_ref())),
|
roots: roots.clone(),
|
||||||
resolver: Some(graph_resolver),
|
loader: Some(&mut cache),
|
||||||
npm_resolver: Some(graph_npm_resolver),
|
|
||||||
module_parser: Some(&parser),
|
|
||||||
module_analyzer: Some(&analyzer),
|
|
||||||
reporter: maybe_file_watcher_reporter,
|
|
||||||
workspace_fast_check: false,
|
workspace_fast_check: false,
|
||||||
workspace_members,
|
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
.await?;
|
.await?;
|
||||||
|
|
|
@ -768,6 +768,7 @@ async fn build_and_check_graph_for_publish(
|
||||||
let graph = Arc::new(
|
let graph = Arc::new(
|
||||||
module_graph_builder
|
module_graph_builder
|
||||||
.create_graph_with_options(crate::graph_util::CreateGraphOptions {
|
.create_graph_with_options(crate::graph_util::CreateGraphOptions {
|
||||||
|
is_dynamic: false,
|
||||||
// All because we're going to use this same graph to determine the publish order later
|
// All because we're going to use this same graph to determine the publish order later
|
||||||
graph_kind: deno_graph::GraphKind::All,
|
graph_kind: deno_graph::GraphKind::All,
|
||||||
roots: packages
|
roots: packages
|
||||||
|
|
Loading…
Reference in a new issue