2024-01-01 14:58:21 -05:00
|
|
|
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
2023-05-01 14:35:23 -04:00
|
|
|
|
2024-09-04 17:39:30 +02:00
|
|
|
use crate::args::check_warn_tsconfig;
|
2024-12-05 08:04:31 +00:00
|
|
|
use crate::args::discover_npmrc_from_workspace;
|
2024-07-23 19:00:48 -04:00
|
|
|
use crate::args::get_root_cert_store;
|
|
|
|
use crate::args::CaData;
|
2024-12-05 08:04:31 +00:00
|
|
|
use crate::args::CliLockfile;
|
2023-05-01 14:35:23 -04:00
|
|
|
use crate::args::CliOptions;
|
|
|
|
use crate::args::DenoSubcommand;
|
|
|
|
use crate::args::Flags;
|
2024-09-04 16:00:44 +02:00
|
|
|
use crate::args::NpmInstallDepsProvider;
|
2024-12-05 08:04:31 +00:00
|
|
|
use crate::args::ScopeOptions;
|
2023-05-01 14:35:23 -04:00
|
|
|
use crate::args::StorageKeyResolver;
|
|
|
|
use crate::args::TsConfigType;
|
|
|
|
use crate::cache::Caches;
|
2024-04-17 07:19:55 -07:00
|
|
|
use crate::cache::CodeCache;
|
2024-11-01 12:27:00 -04:00
|
|
|
use crate::cache::DenoCacheEnvFsAdapter;
|
2023-05-01 14:35:23 -04:00
|
|
|
use crate::cache::DenoDir;
|
2023-05-25 14:27:45 -04:00
|
|
|
use crate::cache::DenoDirProvider;
|
2023-05-01 14:35:23 -04:00
|
|
|
use crate::cache::EmitCache;
|
2023-08-01 20:49:09 -04:00
|
|
|
use crate::cache::GlobalHttpCache;
|
2023-05-01 14:35:23 -04:00
|
|
|
use crate::cache::HttpCache;
|
2023-08-01 20:49:09 -04:00
|
|
|
use crate::cache::LocalHttpCache;
|
2023-10-25 18:13:22 -04:00
|
|
|
use crate::cache::ModuleInfoCache;
|
2023-05-01 14:35:23 -04:00
|
|
|
use crate::cache::NodeAnalysisCache;
|
|
|
|
use crate::cache::ParsedSourceCache;
|
|
|
|
use crate::emit::Emitter;
|
|
|
|
use crate::file_fetcher::FileFetcher;
|
2024-05-16 00:09:35 -07:00
|
|
|
use crate::graph_container::MainModuleGraphContainer;
|
2023-06-14 18:29:19 -04:00
|
|
|
use crate::graph_util::FileWatcherReporter;
|
2023-05-01 14:35:23 -04:00
|
|
|
use crate::graph_util::ModuleGraphBuilder;
|
2024-02-20 16:29:57 -05:00
|
|
|
use crate::graph_util::ModuleGraphCreator;
|
2024-06-03 17:17:08 -04:00
|
|
|
use crate::http_util::HttpClientProvider;
|
2023-05-01 14:35:23 -04:00
|
|
|
use crate::module_loader::CliModuleLoaderFactory;
|
|
|
|
use crate::module_loader::ModuleLoadPreparer;
|
2023-07-19 10:30:04 +02:00
|
|
|
use crate::node::CliCjsCodeAnalyzer;
|
2023-05-01 14:35:23 -04:00
|
|
|
use crate::node::CliNodeCodeTranslator;
|
2023-10-02 17:53:55 -04:00
|
|
|
use crate::npm::create_cli_npm_resolver;
|
2024-11-01 12:27:00 -04:00
|
|
|
use crate::npm::create_in_npm_pkg_checker;
|
2024-09-30 09:33:32 -04:00
|
|
|
use crate::npm::CliByonmNpmResolverCreateOptions;
|
2024-11-01 12:27:00 -04:00
|
|
|
use crate::npm::CliManagedInNpmPkgCheckerCreateOptions;
|
|
|
|
use crate::npm::CliManagedNpmResolverCreateOptions;
|
2023-05-01 14:35:23 -04:00
|
|
|
use crate::npm::CliNpmResolver;
|
2023-10-02 17:53:55 -04:00
|
|
|
use crate::npm::CliNpmResolverCreateOptions;
|
|
|
|
use crate::npm::CliNpmResolverManagedSnapshotOption;
|
2024-11-01 12:27:00 -04:00
|
|
|
use crate::npm::CreateInNpmPkgCheckerOptions;
|
|
|
|
use crate::resolver::CjsTracker;
|
2024-11-14 15:24:25 -05:00
|
|
|
use crate::resolver::CliDenoResolver;
|
2024-09-30 09:33:32 -04:00
|
|
|
use crate::resolver::CliDenoResolverFs;
|
2024-11-14 15:24:25 -05:00
|
|
|
use crate::resolver::CliNpmReqResolver;
|
2024-11-13 10:10:09 -05:00
|
|
|
use crate::resolver::CliResolver;
|
|
|
|
use crate::resolver::CliResolverOptions;
|
2024-09-28 19:17:48 -04:00
|
|
|
use crate::resolver::CliSloppyImportsResolver;
|
2024-01-27 22:40:36 +05:30
|
|
|
use crate::resolver::NpmModuleLoader;
|
2024-09-28 19:17:48 -04:00
|
|
|
use crate::resolver::SloppyImportsCachedFs;
|
2023-05-10 20:06:59 -04:00
|
|
|
use crate::standalone::DenoCompileBinaryWriter;
|
2024-12-05 08:04:31 +00:00
|
|
|
use crate::tools::check::MaybeDiagnostics;
|
2023-05-01 14:35:23 -04:00
|
|
|
use crate::tools::check::TypeChecker;
|
2024-02-13 21:52:30 +05:30
|
|
|
use crate::tools::coverage::CoverageCollector;
|
2024-07-25 09:07:59 -04:00
|
|
|
use crate::tools::lint::LintRuleProvider;
|
2024-02-13 21:52:30 +05:30
|
|
|
use crate::tools::run::hmr::HmrRunner;
|
2024-12-05 08:04:31 +00:00
|
|
|
use crate::tsc::Diagnostics;
|
2024-11-01 12:27:00 -04:00
|
|
|
use crate::tsc::TypeCheckingCjsTracker;
|
2024-12-05 08:04:31 +00:00
|
|
|
use crate::util::extract;
|
2023-10-19 07:05:00 +02:00
|
|
|
use crate::util::file_watcher::WatcherCommunicator;
|
2023-11-29 09:32:23 -05:00
|
|
|
use crate::util::fs::canonicalize_path_maybe_not_exists;
|
2023-05-01 14:35:23 -04:00
|
|
|
use crate::util::progress_bar::ProgressBar;
|
|
|
|
use crate::util::progress_bar::ProgressBarStyle;
|
|
|
|
use crate::worker::CliMainWorkerFactory;
|
|
|
|
use crate::worker::CliMainWorkerOptions;
|
2024-12-05 08:04:31 +00:00
|
|
|
use std::collections::BTreeSet;
|
2024-02-13 21:52:30 +05:30
|
|
|
use std::path::PathBuf;
|
2023-05-01 14:35:23 -04:00
|
|
|
|
2024-12-05 08:04:31 +00:00
|
|
|
use deno_ast::ModuleSpecifier;
|
2024-11-01 12:27:00 -04:00
|
|
|
use deno_cache_dir::npm::NpmCacheDir;
|
2024-12-05 08:04:31 +00:00
|
|
|
use deno_config::glob::FilePatterns;
|
2024-07-04 20:41:01 -04:00
|
|
|
use deno_config::workspace::PackageJsonDepResolution;
|
2024-12-05 08:04:31 +00:00
|
|
|
use deno_config::workspace::WorkspaceDirectory;
|
2024-07-03 20:54:33 -04:00
|
|
|
use deno_config::workspace::WorkspaceResolver;
|
2024-12-05 08:04:31 +00:00
|
|
|
use deno_core::anyhow::anyhow;
|
2023-05-01 14:35:23 -04:00
|
|
|
use deno_core::error::AnyError;
|
2024-02-20 16:29:57 -05:00
|
|
|
use deno_core::futures::FutureExt;
|
2023-10-12 17:55:50 +02:00
|
|
|
use deno_core::FeatureChecker;
|
2023-05-01 14:35:23 -04:00
|
|
|
|
2024-11-27 09:50:38 -05:00
|
|
|
use deno_resolver::cjs::IsCjsResolutionMode;
|
2024-11-14 15:24:25 -05:00
|
|
|
use deno_resolver::npm::NpmReqResolverOptions;
|
|
|
|
use deno_resolver::DenoResolverOptions;
|
|
|
|
use deno_resolver::NodeAndNpmReqResolver;
|
2023-05-04 14:28:42 -04:00
|
|
|
use deno_runtime::deno_fs;
|
2024-07-25 19:08:14 -04:00
|
|
|
use deno_runtime::deno_node::DenoFsNodeResolverEnv;
|
2023-05-01 14:35:23 -04:00
|
|
|
use deno_runtime::deno_node::NodeResolver;
|
2024-11-01 12:27:00 -04:00
|
|
|
use deno_runtime::deno_node::PackageJsonResolver;
|
2024-09-16 21:39:37 +01:00
|
|
|
use deno_runtime::deno_permissions::Permissions;
|
|
|
|
use deno_runtime::deno_permissions::PermissionsContainer;
|
2024-07-23 19:00:48 -04:00
|
|
|
use deno_runtime::deno_tls::rustls::RootCertStore;
|
2023-05-01 16:42:05 -04:00
|
|
|
use deno_runtime::deno_tls::RootCertStoreProvider;
|
2023-05-01 14:35:23 -04:00
|
|
|
use deno_runtime::deno_web::BlobStore;
|
|
|
|
use deno_runtime::inspector_server::InspectorServer;
|
2024-09-16 21:39:37 +01:00
|
|
|
use deno_runtime::permissions::RuntimePermissionDescriptorParser;
|
2023-05-01 14:35:23 -04:00
|
|
|
use log::warn;
|
2024-07-25 19:08:14 -04:00
|
|
|
use node_resolver::analyze::NodeCodeTranslator;
|
2024-11-01 12:27:00 -04:00
|
|
|
use node_resolver::InNpmPackageChecker;
|
2024-07-23 19:00:48 -04:00
|
|
|
use once_cell::sync::OnceCell;
|
2023-05-01 14:35:23 -04:00
|
|
|
use std::future::Future;
|
|
|
|
use std::sync::Arc;
|
|
|
|
|
2024-07-23 19:00:48 -04:00
|
|
|
struct CliRootCertStoreProvider {
|
|
|
|
cell: OnceCell<RootCertStore>,
|
|
|
|
maybe_root_path: Option<PathBuf>,
|
|
|
|
maybe_ca_stores: Option<Vec<String>>,
|
|
|
|
maybe_ca_data: Option<CaData>,
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
|
|
|
|
2024-07-23 19:00:48 -04:00
|
|
|
impl CliRootCertStoreProvider {
|
|
|
|
pub fn new(
|
|
|
|
maybe_root_path: Option<PathBuf>,
|
|
|
|
maybe_ca_stores: Option<Vec<String>>,
|
|
|
|
maybe_ca_data: Option<CaData>,
|
|
|
|
) -> Self {
|
2023-10-19 07:05:00 +02:00
|
|
|
Self {
|
2024-07-23 19:00:48 -04:00
|
|
|
cell: Default::default(),
|
|
|
|
maybe_root_path,
|
|
|
|
maybe_ca_stores,
|
|
|
|
maybe_ca_data,
|
2023-10-19 07:05:00 +02:00
|
|
|
}
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
2024-07-23 19:00:48 -04:00
|
|
|
}
|
2023-05-01 14:35:23 -04:00
|
|
|
|
2024-07-23 19:00:48 -04:00
|
|
|
impl RootCertStoreProvider for CliRootCertStoreProvider {
|
|
|
|
fn get_or_try_init(&self) -> Result<&RootCertStore, AnyError> {
|
|
|
|
self
|
|
|
|
.cell
|
|
|
|
.get_or_try_init(|| {
|
|
|
|
get_root_cert_store(
|
|
|
|
self.maybe_root_path.clone(),
|
|
|
|
self.maybe_ca_stores.clone(),
|
|
|
|
self.maybe_ca_data.clone(),
|
|
|
|
)
|
|
|
|
})
|
|
|
|
.map_err(|e| e.into())
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-11-14 15:24:25 -05:00
|
|
|
pub struct Deferred<T>(once_cell::unsync::OnceCell<T>);
|
2023-05-01 14:35:23 -04:00
|
|
|
|
|
|
|
impl<T> Default for Deferred<T> {
|
|
|
|
fn default() -> Self {
|
|
|
|
Self(once_cell::unsync::OnceCell::default())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T> Deferred<T> {
|
2024-07-23 19:00:48 -04:00
|
|
|
pub fn from_value(value: T) -> Self {
|
|
|
|
Self(once_cell::unsync::OnceCell::from(value))
|
|
|
|
}
|
|
|
|
|
2024-02-20 16:29:57 -05:00
|
|
|
#[inline(always)]
|
2023-05-01 14:35:23 -04:00
|
|
|
pub fn get_or_try_init(
|
|
|
|
&self,
|
|
|
|
create: impl FnOnce() -> Result<T, AnyError>,
|
|
|
|
) -> Result<&T, AnyError> {
|
|
|
|
self.0.get_or_try_init(create)
|
|
|
|
}
|
|
|
|
|
2024-02-20 16:29:57 -05:00
|
|
|
#[inline(always)]
|
2023-05-01 14:35:23 -04:00
|
|
|
pub fn get_or_init(&self, create: impl FnOnce() -> T) -> &T {
|
|
|
|
self.0.get_or_init(create)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn get_or_try_init_async(
|
|
|
|
&self,
|
2024-02-20 16:29:57 -05:00
|
|
|
// some futures passed here are boxed because it was discovered
|
|
|
|
// that they were called a lot, causing other futures to get
|
|
|
|
// really big causing stack overflows on Windows
|
2023-05-01 14:35:23 -04:00
|
|
|
create: impl Future<Output = Result<T, AnyError>>,
|
|
|
|
) -> Result<&T, AnyError> {
|
|
|
|
if self.0.get().is_none() {
|
|
|
|
// todo(dsherret): it would be more ideal if this enforced a
|
|
|
|
// single executor and then we could make some initialization
|
|
|
|
// concurrent
|
|
|
|
let val = create.await?;
|
|
|
|
_ = self.0.set(val);
|
|
|
|
}
|
|
|
|
Ok(self.0.get().unwrap())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Default)]
|
|
|
|
struct CliFactoryServices {
|
2024-11-01 12:27:00 -04:00
|
|
|
blob_store: Deferred<Arc<BlobStore>>,
|
2023-05-01 14:35:23 -04:00
|
|
|
caches: Deferred<Arc<Caches>>,
|
2024-11-01 12:27:00 -04:00
|
|
|
cjs_tracker: Deferred<Arc<CjsTracker>>,
|
|
|
|
cli_options: Deferred<Arc<CliOptions>>,
|
|
|
|
code_cache: Deferred<Arc<CodeCache>>,
|
2024-11-14 15:24:25 -05:00
|
|
|
deno_resolver: Deferred<Arc<CliDenoResolver>>,
|
2024-11-01 12:27:00 -04:00
|
|
|
emit_cache: Deferred<Arc<EmitCache>>,
|
|
|
|
emitter: Deferred<Arc<Emitter>>,
|
|
|
|
feature_checker: Deferred<Arc<FeatureChecker>>,
|
2023-05-01 14:35:23 -04:00
|
|
|
file_fetcher: Deferred<Arc<FileFetcher>>,
|
2024-11-01 12:27:00 -04:00
|
|
|
fs: Deferred<Arc<dyn deno_fs::FileSystem>>,
|
2023-08-01 20:49:09 -04:00
|
|
|
global_http_cache: Deferred<Arc<GlobalHttpCache>>,
|
|
|
|
http_cache: Deferred<Arc<dyn HttpCache>>,
|
2024-06-03 17:17:08 -04:00
|
|
|
http_client_provider: Deferred<Arc<HttpClientProvider>>,
|
2024-11-01 12:27:00 -04:00
|
|
|
in_npm_pkg_checker: Deferred<Arc<dyn InNpmPackageChecker>>,
|
2024-05-16 00:09:35 -07:00
|
|
|
main_graph_container: Deferred<Arc<MainModuleGraphContainer>>,
|
2023-05-01 14:35:23 -04:00
|
|
|
maybe_file_watcher_reporter: Deferred<Option<FileWatcherReporter>>,
|
2024-11-01 12:27:00 -04:00
|
|
|
maybe_inspector_server: Deferred<Option<Arc<InspectorServer>>>,
|
2023-05-01 14:35:23 -04:00
|
|
|
module_graph_builder: Deferred<Arc<ModuleGraphBuilder>>,
|
2024-02-20 16:29:57 -05:00
|
|
|
module_graph_creator: Deferred<Arc<ModuleGraphCreator>>,
|
2024-11-01 12:27:00 -04:00
|
|
|
module_info_cache: Deferred<Arc<ModuleInfoCache>>,
|
2023-05-01 14:35:23 -04:00
|
|
|
module_load_preparer: Deferred<Arc<ModuleLoadPreparer>>,
|
|
|
|
node_code_translator: Deferred<Arc<CliNodeCodeTranslator>>,
|
|
|
|
node_resolver: Deferred<Arc<NodeResolver>>,
|
2024-11-01 12:27:00 -04:00
|
|
|
npm_cache_dir: Deferred<Arc<NpmCacheDir>>,
|
2024-11-14 15:24:25 -05:00
|
|
|
npm_req_resolver: Deferred<Arc<CliNpmReqResolver>>,
|
2023-09-29 09:26:25 -04:00
|
|
|
npm_resolver: Deferred<Arc<dyn CliNpmResolver>>,
|
2024-11-01 12:27:00 -04:00
|
|
|
parsed_source_cache: Deferred<Arc<ParsedSourceCache>>,
|
2024-09-16 21:39:37 +01:00
|
|
|
permission_desc_parser: Deferred<Arc<RuntimePermissionDescriptorParser>>,
|
2024-11-01 12:27:00 -04:00
|
|
|
pkg_json_resolver: Deferred<Arc<PackageJsonResolver>>,
|
2024-11-13 10:10:09 -05:00
|
|
|
resolver: Deferred<Arc<CliResolver>>,
|
2024-11-01 12:27:00 -04:00
|
|
|
root_cert_store_provider: Deferred<Arc<dyn RootCertStoreProvider>>,
|
2024-09-26 02:50:54 +01:00
|
|
|
root_permissions_container: Deferred<PermissionsContainer>,
|
2024-09-28 19:17:48 -04:00
|
|
|
sloppy_imports_resolver: Deferred<Option<Arc<CliSloppyImportsResolver>>>,
|
2023-05-01 14:35:23 -04:00
|
|
|
text_only_progress_bar: Deferred<ProgressBar>,
|
|
|
|
type_checker: Deferred<Arc<TypeChecker>>,
|
2024-07-03 20:54:33 -04:00
|
|
|
workspace_resolver: Deferred<Arc<WorkspaceResolver>>,
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
pub struct CliFactory {
|
2023-10-31 01:25:58 +01:00
|
|
|
watcher_communicator: Option<Arc<WatcherCommunicator>>,
|
2024-07-23 19:00:48 -04:00
|
|
|
flags: Arc<Flags>,
|
2023-05-01 14:35:23 -04:00
|
|
|
services: CliFactoryServices,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl CliFactory {
|
2024-07-23 19:00:48 -04:00
|
|
|
pub fn from_flags(flags: Arc<Flags>) -> Self {
|
|
|
|
Self {
|
|
|
|
flags,
|
|
|
|
watcher_communicator: None,
|
|
|
|
services: Default::default(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn from_cli_options(cli_options: Arc<CliOptions>) -> Self {
|
|
|
|
let (cli_options, flags) = cli_options.into_self_and_flags();
|
|
|
|
CliFactory {
|
|
|
|
watcher_communicator: None,
|
|
|
|
flags,
|
|
|
|
services: CliFactoryServices {
|
|
|
|
cli_options: Deferred::from_value(cli_options),
|
|
|
|
..Default::default()
|
|
|
|
},
|
|
|
|
}
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
|
|
|
|
2024-07-23 19:00:48 -04:00
|
|
|
pub fn from_flags_for_watcher(
|
|
|
|
flags: Arc<Flags>,
|
|
|
|
watcher_communicator: Arc<WatcherCommunicator>,
|
|
|
|
) -> Self {
|
|
|
|
CliFactory {
|
|
|
|
watcher_communicator: Some(watcher_communicator),
|
|
|
|
flags,
|
|
|
|
services: Default::default(),
|
|
|
|
}
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
|
|
|
|
2024-07-23 19:00:48 -04:00
|
|
|
pub fn cli_options(&self) -> Result<&Arc<CliOptions>, AnyError> {
|
|
|
|
self.services.cli_options.get_or_try_init(|| {
|
|
|
|
CliOptions::from_flags(self.flags.clone()).map(Arc::new)
|
|
|
|
})
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
|
|
|
|
2024-07-23 19:00:48 -04:00
|
|
|
pub fn deno_dir_provider(&self) -> Result<&Arc<DenoDirProvider>, AnyError> {
|
2024-08-16 12:48:48 +09:00
|
|
|
Ok(&self.cli_options()?.deno_dir_provider)
|
2023-05-25 14:27:45 -04:00
|
|
|
}
|
|
|
|
|
2023-05-01 14:35:23 -04:00
|
|
|
pub fn deno_dir(&self) -> Result<&DenoDir, AnyError> {
|
2024-07-23 19:00:48 -04:00
|
|
|
Ok(self.deno_dir_provider()?.get_or_create()?)
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn caches(&self) -> Result<&Arc<Caches>, AnyError> {
|
|
|
|
self.services.caches.get_or_try_init(|| {
|
2024-07-23 19:00:48 -04:00
|
|
|
let cli_options = self.cli_options()?;
|
|
|
|
let caches = Arc::new(Caches::new(self.deno_dir_provider()?.clone()));
|
2023-05-01 14:35:23 -04:00
|
|
|
// Warm up the caches we know we'll likely need based on the CLI mode
|
2024-07-23 19:00:48 -04:00
|
|
|
match cli_options.sub_command() {
|
2024-02-20 16:29:57 -05:00
|
|
|
DenoSubcommand::Run(_)
|
2024-04-24 15:45:49 -04:00
|
|
|
| DenoSubcommand::Serve(_)
|
2024-02-20 16:29:57 -05:00
|
|
|
| DenoSubcommand::Bench(_)
|
|
|
|
| DenoSubcommand::Test(_)
|
|
|
|
| DenoSubcommand::Check(_) => {
|
2023-05-01 14:35:23 -04:00
|
|
|
_ = caches.dep_analysis_db();
|
|
|
|
_ = caches.node_analysis_db();
|
2024-07-23 19:00:48 -04:00
|
|
|
if cli_options.type_check_mode().is_true() {
|
2024-02-20 16:29:57 -05:00
|
|
|
_ = caches.fast_check_db();
|
|
|
|
_ = caches.type_checking_cache_db();
|
|
|
|
}
|
2024-07-23 19:00:48 -04:00
|
|
|
if cli_options.code_cache_enabled() {
|
2024-04-17 07:19:55 -07:00
|
|
|
_ = caches.code_cache_db();
|
|
|
|
}
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
|
|
|
_ => {}
|
|
|
|
}
|
|
|
|
Ok(caches)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2023-07-01 23:52:30 +01:00
|
|
|
pub fn blob_store(&self) -> &Arc<BlobStore> {
|
|
|
|
self.services.blob_store.get_or_init(Default::default)
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
|
|
|
|
2023-05-01 16:42:05 -04:00
|
|
|
pub fn root_cert_store_provider(&self) -> &Arc<dyn RootCertStoreProvider> {
|
2024-07-23 19:00:48 -04:00
|
|
|
self.services.root_cert_store_provider.get_or_init(|| {
|
|
|
|
Arc::new(CliRootCertStoreProvider::new(
|
|
|
|
None,
|
|
|
|
self.flags.ca_stores.clone(),
|
|
|
|
self.flags.ca_data.clone(),
|
|
|
|
))
|
|
|
|
})
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn text_only_progress_bar(&self) -> &ProgressBar {
|
|
|
|
self
|
|
|
|
.services
|
|
|
|
.text_only_progress_bar
|
|
|
|
.get_or_init(|| ProgressBar::new(ProgressBarStyle::TextOnly))
|
|
|
|
}
|
|
|
|
|
2023-08-01 20:49:09 -04:00
|
|
|
pub fn global_http_cache(&self) -> Result<&Arc<GlobalHttpCache>, AnyError> {
|
|
|
|
self.services.global_http_cache.get_or_try_init(|| {
|
|
|
|
Ok(Arc::new(GlobalHttpCache::new(
|
2024-10-01 14:05:40 -04:00
|
|
|
self.deno_dir()?.remote_folder_path(),
|
2023-08-08 10:23:02 -04:00
|
|
|
crate::cache::RealDenoCacheEnv,
|
2023-08-01 20:49:09 -04:00
|
|
|
)))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn http_cache(&self) -> Result<&Arc<dyn HttpCache>, AnyError> {
|
|
|
|
self.services.http_cache.get_or_try_init(|| {
|
|
|
|
let global_cache = self.global_http_cache()?.clone();
|
2024-07-23 19:00:48 -04:00
|
|
|
match self.cli_options()?.vendor_dir_path() {
|
2023-08-01 20:49:09 -04:00
|
|
|
Some(local_path) => {
|
2024-08-26 19:59:17 -04:00
|
|
|
let local_cache = LocalHttpCache::new(
|
|
|
|
local_path.clone(),
|
|
|
|
global_cache,
|
|
|
|
deno_cache_dir::GlobalToLocalCopy::Allow,
|
|
|
|
);
|
2023-08-01 20:49:09 -04:00
|
|
|
Ok(Arc::new(local_cache))
|
|
|
|
}
|
|
|
|
None => Ok(global_cache),
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-06-03 17:17:08 -04:00
|
|
|
pub fn http_client_provider(&self) -> &Arc<HttpClientProvider> {
|
|
|
|
self.services.http_client_provider.get_or_init(|| {
|
|
|
|
Arc::new(HttpClientProvider::new(
|
2023-05-01 16:42:05 -04:00
|
|
|
Some(self.root_cert_store_provider().clone()),
|
2024-07-23 19:00:48 -04:00
|
|
|
self.flags.unsafely_ignore_certificate_errors.clone(),
|
2023-05-01 16:42:05 -04:00
|
|
|
))
|
2023-05-01 14:35:23 -04:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn file_fetcher(&self) -> Result<&Arc<FileFetcher>, AnyError> {
|
|
|
|
self.services.file_fetcher.get_or_try_init(|| {
|
2024-07-23 19:00:48 -04:00
|
|
|
let cli_options = self.cli_options()?;
|
2023-05-01 14:35:23 -04:00
|
|
|
Ok(Arc::new(FileFetcher::new(
|
2023-08-01 20:49:09 -04:00
|
|
|
self.http_cache()?.clone(),
|
2024-07-23 19:00:48 -04:00
|
|
|
cli_options.cache_setting(),
|
|
|
|
!cli_options.no_remote(),
|
2024-06-03 17:17:08 -04:00
|
|
|
self.http_client_provider().clone(),
|
2023-05-01 14:35:23 -04:00
|
|
|
self.blob_store().clone(),
|
|
|
|
Some(self.text_only_progress_bar().clone()),
|
|
|
|
)))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2023-05-05 12:44:24 -04:00
|
|
|
pub fn fs(&self) -> &Arc<dyn deno_fs::FileSystem> {
|
|
|
|
self.services.fs.get_or_init(|| Arc::new(deno_fs::RealFs))
|
|
|
|
}
|
|
|
|
|
2024-11-01 12:27:00 -04:00
|
|
|
pub fn in_npm_pkg_checker(
|
|
|
|
&self,
|
|
|
|
) -> Result<&Arc<dyn InNpmPackageChecker>, AnyError> {
|
|
|
|
self.services.in_npm_pkg_checker.get_or_try_init(|| {
|
|
|
|
let cli_options = self.cli_options()?;
|
|
|
|
let options = if cli_options.use_byonm() {
|
|
|
|
CreateInNpmPkgCheckerOptions::Byonm
|
|
|
|
} else {
|
|
|
|
CreateInNpmPkgCheckerOptions::Managed(
|
|
|
|
CliManagedInNpmPkgCheckerCreateOptions {
|
|
|
|
root_cache_dir_url: self.npm_cache_dir()?.root_dir_url(),
|
|
|
|
maybe_node_modules_path: cli_options
|
|
|
|
.node_modules_dir_path()
|
|
|
|
.map(|p| p.as_path()),
|
|
|
|
},
|
|
|
|
)
|
|
|
|
};
|
|
|
|
Ok(create_in_npm_pkg_checker(options))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn npm_cache_dir(&self) -> Result<&Arc<NpmCacheDir>, AnyError> {
|
|
|
|
self.services.npm_cache_dir.get_or_try_init(|| {
|
|
|
|
let fs = self.fs();
|
|
|
|
let global_path = self.deno_dir()?.npm_folder_path();
|
|
|
|
let cli_options = self.cli_options()?;
|
|
|
|
Ok(Arc::new(NpmCacheDir::new(
|
|
|
|
&DenoCacheEnvFsAdapter(fs.as_ref()),
|
|
|
|
global_path,
|
|
|
|
cli_options.npmrc().get_all_known_registries_urls(),
|
|
|
|
)))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2023-09-29 09:26:25 -04:00
|
|
|
pub async fn npm_resolver(
|
|
|
|
&self,
|
|
|
|
) -> Result<&Arc<dyn CliNpmResolver>, AnyError> {
|
2023-05-01 14:35:23 -04:00
|
|
|
self
|
|
|
|
.services
|
|
|
|
.npm_resolver
|
2024-11-01 12:27:00 -04:00
|
|
|
.get_or_try_init_async(
|
|
|
|
async {
|
|
|
|
let fs = self.fs();
|
|
|
|
let cli_options = self.cli_options()?;
|
|
|
|
create_cli_npm_resolver(if cli_options.use_byonm() {
|
|
|
|
CliNpmResolverCreateOptions::Byonm(
|
|
|
|
CliByonmNpmResolverCreateOptions {
|
|
|
|
fs: CliDenoResolverFs(fs.clone()),
|
|
|
|
pkg_json_resolver: self.pkg_json_resolver().clone(),
|
|
|
|
root_node_modules_dir: Some(
|
|
|
|
match cli_options.node_modules_dir_path() {
|
|
|
|
Some(node_modules_path) => node_modules_path.to_path_buf(),
|
|
|
|
// path needs to be canonicalized for node resolution
|
|
|
|
// (node_modules_dir_path above is already canonicalized)
|
|
|
|
None => canonicalize_path_maybe_not_exists(
|
|
|
|
cli_options.initial_cwd(),
|
|
|
|
)?
|
|
|
|
.join("node_modules"),
|
|
|
|
},
|
|
|
|
),
|
2023-10-03 19:05:06 -04:00
|
|
|
},
|
2024-11-01 12:27:00 -04:00
|
|
|
)
|
|
|
|
} else {
|
|
|
|
CliNpmResolverCreateOptions::Managed(
|
|
|
|
CliManagedNpmResolverCreateOptions {
|
|
|
|
snapshot: match cli_options.resolve_npm_resolution_snapshot()? {
|
|
|
|
Some(snapshot) => {
|
|
|
|
CliNpmResolverManagedSnapshotOption::Specified(Some(
|
|
|
|
snapshot,
|
|
|
|
))
|
|
|
|
}
|
|
|
|
None => match cli_options.maybe_lockfile() {
|
|
|
|
Some(lockfile) => {
|
|
|
|
CliNpmResolverManagedSnapshotOption::ResolveFromLockfile(
|
|
|
|
lockfile.clone(),
|
|
|
|
)
|
|
|
|
}
|
|
|
|
None => {
|
|
|
|
CliNpmResolverManagedSnapshotOption::Specified(None)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
maybe_lockfile: cli_options.maybe_lockfile().cloned(),
|
|
|
|
fs: fs.clone(),
|
|
|
|
http_client_provider: self.http_client_provider().clone(),
|
|
|
|
npm_cache_dir: self.npm_cache_dir()?.clone(),
|
|
|
|
cache_setting: cli_options.cache_setting(),
|
|
|
|
text_only_progress_bar: self.text_only_progress_bar().clone(),
|
|
|
|
maybe_node_modules_path: cli_options
|
|
|
|
.node_modules_dir_path()
|
|
|
|
.cloned(),
|
|
|
|
npm_install_deps_provider: Arc::new(
|
|
|
|
NpmInstallDepsProvider::from_workspace(
|
|
|
|
cli_options.workspace(),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
npm_system_info: cli_options.npm_system_info(),
|
|
|
|
npmrc: cli_options.npmrc().clone(),
|
|
|
|
lifecycle_scripts: cli_options.lifecycle_scripts_config(),
|
|
|
|
},
|
|
|
|
)
|
2023-10-03 19:05:06 -04:00
|
|
|
})
|
2024-11-01 12:27:00 -04:00
|
|
|
.await
|
|
|
|
}
|
|
|
|
.boxed_local(),
|
|
|
|
)
|
2023-05-01 14:35:23 -04:00
|
|
|
.await
|
|
|
|
}
|
|
|
|
|
2024-07-25 09:07:59 -04:00
|
|
|
pub fn sloppy_imports_resolver(
|
|
|
|
&self,
|
2024-09-28 19:17:48 -04:00
|
|
|
) -> Result<Option<&Arc<CliSloppyImportsResolver>>, AnyError> {
|
2024-07-25 09:07:59 -04:00
|
|
|
self
|
|
|
|
.services
|
|
|
|
.sloppy_imports_resolver
|
|
|
|
.get_or_try_init(|| {
|
2024-09-28 19:17:48 -04:00
|
|
|
Ok(self.cli_options()?.unstable_sloppy_imports().then(|| {
|
|
|
|
Arc::new(CliSloppyImportsResolver::new(SloppyImportsCachedFs::new(
|
|
|
|
self.fs().clone(),
|
|
|
|
)))
|
|
|
|
}))
|
2024-07-25 09:07:59 -04:00
|
|
|
})
|
|
|
|
.map(|maybe| maybe.as_ref())
|
|
|
|
}
|
|
|
|
|
2024-07-03 20:54:33 -04:00
|
|
|
pub async fn workspace_resolver(
|
2023-05-01 14:35:23 -04:00
|
|
|
&self,
|
2024-07-03 20:54:33 -04:00
|
|
|
) -> Result<&Arc<WorkspaceResolver>, AnyError> {
|
2023-05-01 14:35:23 -04:00
|
|
|
self
|
|
|
|
.services
|
2024-07-03 20:54:33 -04:00
|
|
|
.workspace_resolver
|
2023-05-01 14:35:23 -04:00
|
|
|
.get_or_try_init_async(async {
|
2024-07-23 19:00:48 -04:00
|
|
|
let cli_options = self.cli_options()?;
|
|
|
|
let resolver = cli_options
|
2024-07-04 20:41:01 -04:00
|
|
|
.create_workspace_resolver(
|
|
|
|
self.file_fetcher()?,
|
2024-11-29 23:54:26 +00:00
|
|
|
if cli_options.use_byonm()
|
|
|
|
&& !matches!(
|
|
|
|
cli_options.sub_command(),
|
|
|
|
DenoSubcommand::Publish(_)
|
|
|
|
)
|
|
|
|
{
|
2024-07-04 20:41:01 -04:00
|
|
|
PackageJsonDepResolution::Disabled
|
|
|
|
} else {
|
|
|
|
// todo(dsherret): this should be false for nodeModulesDir: true
|
|
|
|
PackageJsonDepResolution::Enabled
|
|
|
|
},
|
|
|
|
)
|
2024-07-03 20:54:33 -04:00
|
|
|
.await?;
|
|
|
|
if !resolver.diagnostics().is_empty() {
|
|
|
|
warn!(
|
|
|
|
"Import map diagnostics:\n{}",
|
|
|
|
resolver
|
|
|
|
.diagnostics()
|
|
|
|
.iter()
|
|
|
|
.map(|d| format!(" - {d}"))
|
|
|
|
.collect::<Vec<_>>()
|
|
|
|
.join("\n")
|
|
|
|
);
|
|
|
|
}
|
|
|
|
Ok(Arc::new(resolver))
|
2023-05-01 14:35:23 -04:00
|
|
|
})
|
|
|
|
.await
|
|
|
|
}
|
|
|
|
|
2024-11-14 15:24:25 -05:00
|
|
|
pub async fn deno_resolver(&self) -> Result<&Arc<CliDenoResolver>, AnyError> {
|
|
|
|
self
|
|
|
|
.services
|
|
|
|
.deno_resolver
|
|
|
|
.get_or_try_init_async(async {
|
|
|
|
let cli_options = self.cli_options()?;
|
|
|
|
Ok(Arc::new(CliDenoResolver::new(DenoResolverOptions {
|
|
|
|
in_npm_pkg_checker: self.in_npm_pkg_checker()?.clone(),
|
|
|
|
node_and_req_resolver: if cli_options.no_npm() {
|
|
|
|
None
|
|
|
|
} else {
|
|
|
|
Some(NodeAndNpmReqResolver {
|
|
|
|
node_resolver: self.node_resolver().await?.clone(),
|
|
|
|
npm_req_resolver: self.npm_req_resolver().await?.clone(),
|
|
|
|
})
|
|
|
|
},
|
|
|
|
sloppy_imports_resolver: self.sloppy_imports_resolver()?.cloned(),
|
|
|
|
workspace_resolver: self.workspace_resolver().await?.clone(),
|
|
|
|
is_byonm: cli_options.use_byonm(),
|
|
|
|
maybe_vendor_dir: cli_options.vendor_dir_path(),
|
|
|
|
})))
|
|
|
|
})
|
|
|
|
.await
|
|
|
|
}
|
|
|
|
|
2024-11-13 10:10:09 -05:00
|
|
|
pub async fn resolver(&self) -> Result<&Arc<CliResolver>, AnyError> {
|
2023-05-01 14:35:23 -04:00
|
|
|
self
|
|
|
|
.services
|
|
|
|
.resolver
|
2024-02-20 16:29:57 -05:00
|
|
|
.get_or_try_init_async(
|
|
|
|
async {
|
2024-07-23 19:00:48 -04:00
|
|
|
let cli_options = self.cli_options()?;
|
2024-11-13 10:10:09 -05:00
|
|
|
Ok(Arc::new(CliResolver::new(CliResolverOptions {
|
2024-07-23 19:00:48 -04:00
|
|
|
npm_resolver: if cli_options.no_npm() {
|
2024-02-20 16:29:57 -05:00
|
|
|
None
|
|
|
|
} else {
|
|
|
|
Some(self.npm_resolver().await?.clone())
|
|
|
|
},
|
2024-07-23 19:00:48 -04:00
|
|
|
bare_node_builtins_enabled: cli_options
|
2024-07-03 20:54:33 -04:00
|
|
|
.unstable_bare_node_builtins(),
|
2024-11-14 15:24:25 -05:00
|
|
|
deno_resolver: self.deno_resolver().await?.clone(),
|
2024-02-20 16:29:57 -05:00
|
|
|
})))
|
|
|
|
}
|
|
|
|
.boxed_local(),
|
|
|
|
)
|
2023-05-01 14:35:23 -04:00
|
|
|
.await
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn maybe_file_watcher_reporter(&self) -> &Option<FileWatcherReporter> {
|
2023-10-19 07:05:00 +02:00
|
|
|
let maybe_file_watcher_reporter = self
|
|
|
|
.watcher_communicator
|
|
|
|
.as_ref()
|
|
|
|
.map(|i| FileWatcherReporter::new(i.clone()));
|
2023-05-01 14:35:23 -04:00
|
|
|
self
|
|
|
|
.services
|
|
|
|
.maybe_file_watcher_reporter
|
2023-10-19 07:05:00 +02:00
|
|
|
.get_or_init(|| maybe_file_watcher_reporter)
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
|
|
|
|
2024-08-08 11:41:30 +02:00
|
|
|
pub fn emit_cache(&self) -> Result<&Arc<EmitCache>, AnyError> {
|
2023-05-01 14:35:23 -04:00
|
|
|
self.services.emit_cache.get_or_try_init(|| {
|
2024-08-08 11:41:30 +02:00
|
|
|
Ok(Arc::new(EmitCache::new(self.deno_dir()?.gen_cache.clone())))
|
2023-05-01 14:35:23 -04:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2023-10-25 18:13:22 -04:00
|
|
|
pub fn module_info_cache(&self) -> Result<&Arc<ModuleInfoCache>, AnyError> {
|
|
|
|
self.services.module_info_cache.get_or_try_init(|| {
|
|
|
|
Ok(Arc::new(ModuleInfoCache::new(
|
2023-05-01 14:35:23 -04:00
|
|
|
self.caches()?.dep_analysis_db(),
|
2024-11-01 12:27:00 -04:00
|
|
|
self.parsed_source_cache().clone(),
|
2023-05-01 14:35:23 -04:00
|
|
|
)))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-04-17 07:19:55 -07:00
|
|
|
pub fn code_cache(&self) -> Result<&Arc<CodeCache>, AnyError> {
|
|
|
|
self.services.code_cache.get_or_try_init(|| {
|
|
|
|
Ok(Arc::new(CodeCache::new(self.caches()?.code_cache_db())))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2023-10-25 18:13:22 -04:00
|
|
|
pub fn parsed_source_cache(&self) -> &Arc<ParsedSourceCache> {
|
|
|
|
self
|
|
|
|
.services
|
|
|
|
.parsed_source_cache
|
|
|
|
.get_or_init(Default::default)
|
|
|
|
}
|
|
|
|
|
2023-05-01 14:35:23 -04:00
|
|
|
pub fn emitter(&self) -> Result<&Arc<Emitter>, AnyError> {
|
|
|
|
self.services.emitter.get_or_try_init(|| {
|
2024-07-23 19:00:48 -04:00
|
|
|
let cli_options = self.cli_options()?;
|
|
|
|
let ts_config_result =
|
|
|
|
cli_options.resolve_ts_config_for_emit(TsConfigType::Emit)?;
|
2024-09-04 17:39:30 +02:00
|
|
|
check_warn_tsconfig(&ts_config_result);
|
2024-04-11 19:00:17 -04:00
|
|
|
let (transpile_options, emit_options) =
|
|
|
|
crate::args::ts_config_to_transpile_and_emit_options(
|
|
|
|
ts_config_result.ts_config,
|
2024-04-23 08:50:50 -07:00
|
|
|
)?;
|
2023-05-01 14:35:23 -04:00
|
|
|
Ok(Arc::new(Emitter::new(
|
2024-11-01 12:27:00 -04:00
|
|
|
self.cjs_tracker()?.clone(),
|
2023-05-01 14:35:23 -04:00
|
|
|
self.emit_cache()?.clone(),
|
2023-10-25 18:13:22 -04:00
|
|
|
self.parsed_source_cache().clone(),
|
2024-04-11 19:00:17 -04:00
|
|
|
transpile_options,
|
2023-05-01 14:35:23 -04:00
|
|
|
emit_options,
|
|
|
|
)))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-07-25 09:07:59 -04:00
|
|
|
pub async fn lint_rule_provider(&self) -> Result<LintRuleProvider, AnyError> {
|
|
|
|
Ok(LintRuleProvider::new(
|
|
|
|
self.sloppy_imports_resolver()?.cloned(),
|
|
|
|
Some(self.workspace_resolver().await?.clone()),
|
|
|
|
))
|
|
|
|
}
|
|
|
|
|
2023-05-01 14:35:23 -04:00
|
|
|
pub async fn node_resolver(&self) -> Result<&Arc<NodeResolver>, AnyError> {
|
|
|
|
self
|
|
|
|
.services
|
|
|
|
.node_resolver
|
2024-02-20 16:29:57 -05:00
|
|
|
.get_or_try_init_async(
|
|
|
|
async {
|
|
|
|
Ok(Arc::new(NodeResolver::new(
|
2024-07-25 19:08:14 -04:00
|
|
|
DenoFsNodeResolverEnv::new(self.fs().clone()),
|
2024-11-01 12:27:00 -04:00
|
|
|
self.in_npm_pkg_checker()?.clone(),
|
2024-11-14 15:24:25 -05:00
|
|
|
self
|
|
|
|
.npm_resolver()
|
|
|
|
.await?
|
|
|
|
.clone()
|
|
|
|
.into_npm_pkg_folder_resolver(),
|
2024-11-01 12:27:00 -04:00
|
|
|
self.pkg_json_resolver().clone(),
|
2024-02-20 16:29:57 -05:00
|
|
|
)))
|
|
|
|
}
|
|
|
|
.boxed_local(),
|
|
|
|
)
|
2023-05-01 14:35:23 -04:00
|
|
|
.await
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn node_code_translator(
|
|
|
|
&self,
|
|
|
|
) -> Result<&Arc<CliNodeCodeTranslator>, AnyError> {
|
|
|
|
self
|
|
|
|
.services
|
|
|
|
.node_code_translator
|
|
|
|
.get_or_try_init_async(async {
|
|
|
|
let caches = self.caches()?;
|
|
|
|
let node_analysis_cache =
|
|
|
|
NodeAnalysisCache::new(caches.node_analysis_db());
|
2024-11-01 12:27:00 -04:00
|
|
|
let node_resolver = self.node_resolver().await?.clone();
|
2024-09-19 21:10:34 -07:00
|
|
|
let cjs_esm_analyzer = CliCjsCodeAnalyzer::new(
|
|
|
|
node_analysis_cache,
|
2024-11-01 12:27:00 -04:00
|
|
|
self.cjs_tracker()?.clone(),
|
2024-09-19 21:10:34 -07:00
|
|
|
self.fs().clone(),
|
2024-10-14 20:48:39 -04:00
|
|
|
Some(self.parsed_source_cache().clone()),
|
2024-09-19 21:10:34 -07:00
|
|
|
);
|
2023-05-01 14:35:23 -04:00
|
|
|
|
|
|
|
Ok(Arc::new(NodeCodeTranslator::new(
|
|
|
|
cjs_esm_analyzer,
|
2024-07-25 19:08:14 -04:00
|
|
|
DenoFsNodeResolverEnv::new(self.fs().clone()),
|
2024-11-01 12:27:00 -04:00
|
|
|
self.in_npm_pkg_checker()?.clone(),
|
|
|
|
node_resolver,
|
2024-11-14 15:24:25 -05:00
|
|
|
self
|
|
|
|
.npm_resolver()
|
|
|
|
.await?
|
|
|
|
.clone()
|
|
|
|
.into_npm_pkg_folder_resolver(),
|
2024-11-01 12:27:00 -04:00
|
|
|
self.pkg_json_resolver().clone(),
|
2023-05-01 14:35:23 -04:00
|
|
|
)))
|
|
|
|
})
|
|
|
|
.await
|
|
|
|
}
|
|
|
|
|
2024-11-14 15:24:25 -05:00
|
|
|
pub async fn npm_req_resolver(
|
|
|
|
&self,
|
|
|
|
) -> Result<&Arc<CliNpmReqResolver>, AnyError> {
|
|
|
|
self
|
|
|
|
.services
|
|
|
|
.npm_req_resolver
|
|
|
|
.get_or_try_init_async(async {
|
|
|
|
let npm_resolver = self.npm_resolver().await?;
|
|
|
|
Ok(Arc::new(CliNpmReqResolver::new(NpmReqResolverOptions {
|
|
|
|
byonm_resolver: (npm_resolver.clone()).into_maybe_byonm(),
|
|
|
|
fs: CliDenoResolverFs(self.fs().clone()),
|
|
|
|
in_npm_pkg_checker: self.in_npm_pkg_checker()?.clone(),
|
|
|
|
node_resolver: self.node_resolver().await?.clone(),
|
|
|
|
npm_req_resolver: npm_resolver.clone().into_npm_req_resolver(),
|
|
|
|
})))
|
|
|
|
})
|
|
|
|
.await
|
|
|
|
}
|
|
|
|
|
2024-11-01 12:27:00 -04:00
|
|
|
pub fn pkg_json_resolver(&self) -> &Arc<PackageJsonResolver> {
|
|
|
|
self.services.pkg_json_resolver.get_or_init(|| {
|
|
|
|
Arc::new(PackageJsonResolver::new(DenoFsNodeResolverEnv::new(
|
|
|
|
self.fs().clone(),
|
|
|
|
)))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2023-05-01 14:35:23 -04:00
|
|
|
pub async fn type_checker(&self) -> Result<&Arc<TypeChecker>, AnyError> {
|
|
|
|
self
|
|
|
|
.services
|
|
|
|
.type_checker
|
|
|
|
.get_or_try_init_async(async {
|
2024-07-23 19:00:48 -04:00
|
|
|
let cli_options = self.cli_options()?;
|
2023-05-01 14:35:23 -04:00
|
|
|
Ok(Arc::new(TypeChecker::new(
|
|
|
|
self.caches()?.clone(),
|
2024-11-01 12:27:00 -04:00
|
|
|
Arc::new(TypeCheckingCjsTracker::new(
|
|
|
|
self.cjs_tracker()?.clone(),
|
|
|
|
self.module_info_cache()?.clone(),
|
|
|
|
)),
|
2024-07-23 19:00:48 -04:00
|
|
|
cli_options.clone(),
|
2024-02-20 16:29:57 -05:00
|
|
|
self.module_graph_builder().await?.clone(),
|
2023-05-01 14:35:23 -04:00
|
|
|
self.node_resolver().await?.clone(),
|
|
|
|
self.npm_resolver().await?.clone(),
|
|
|
|
)))
|
|
|
|
})
|
|
|
|
.await
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn module_graph_builder(
|
|
|
|
&self,
|
|
|
|
) -> Result<&Arc<ModuleGraphBuilder>, AnyError> {
|
|
|
|
self
|
|
|
|
.services
|
|
|
|
.module_graph_builder
|
|
|
|
.get_or_try_init_async(async {
|
2024-07-23 19:00:48 -04:00
|
|
|
let cli_options = self.cli_options()?;
|
2023-05-01 14:35:23 -04:00
|
|
|
Ok(Arc::new(ModuleGraphBuilder::new(
|
2024-02-20 16:29:57 -05:00
|
|
|
self.caches()?.clone(),
|
2024-11-13 10:10:09 -05:00
|
|
|
self.cjs_tracker()?.clone(),
|
2024-11-01 12:27:00 -04:00
|
|
|
cli_options.clone(),
|
|
|
|
self.file_fetcher()?.clone(),
|
2023-12-01 15:12:10 -05:00
|
|
|
self.fs().clone(),
|
2024-11-01 12:27:00 -04:00
|
|
|
self.global_http_cache()?.clone(),
|
|
|
|
self.in_npm_pkg_checker()?.clone(),
|
2024-07-23 19:00:48 -04:00
|
|
|
cli_options.maybe_lockfile().cloned(),
|
2023-06-14 18:29:19 -04:00
|
|
|
self.maybe_file_watcher_reporter().clone(),
|
2024-11-01 12:27:00 -04:00
|
|
|
self.module_info_cache()?.clone(),
|
|
|
|
self.npm_resolver().await?.clone(),
|
|
|
|
self.parsed_source_cache().clone(),
|
|
|
|
self.resolver().await?.clone(),
|
2024-09-26 02:50:54 +01:00
|
|
|
self.root_permissions_container()?.clone(),
|
2024-02-20 16:29:57 -05:00
|
|
|
)))
|
|
|
|
})
|
|
|
|
.await
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn module_graph_creator(
|
|
|
|
&self,
|
|
|
|
) -> Result<&Arc<ModuleGraphCreator>, AnyError> {
|
|
|
|
self
|
|
|
|
.services
|
|
|
|
.module_graph_creator
|
|
|
|
.get_or_try_init_async(async {
|
2024-07-23 19:00:48 -04:00
|
|
|
let cli_options = self.cli_options()?;
|
2024-02-20 16:29:57 -05:00
|
|
|
Ok(Arc::new(ModuleGraphCreator::new(
|
2024-07-23 19:00:48 -04:00
|
|
|
cli_options.clone(),
|
2024-02-20 16:29:57 -05:00
|
|
|
self.npm_resolver().await?.clone(),
|
|
|
|
self.module_graph_builder().await?.clone(),
|
2023-05-01 14:35:23 -04:00
|
|
|
self.type_checker().await?.clone(),
|
|
|
|
)))
|
|
|
|
})
|
|
|
|
.await
|
|
|
|
}
|
|
|
|
|
2024-05-16 00:09:35 -07:00
|
|
|
pub async fn main_module_graph_container(
|
|
|
|
&self,
|
|
|
|
) -> Result<&Arc<MainModuleGraphContainer>, AnyError> {
|
|
|
|
self
|
|
|
|
.services
|
|
|
|
.main_graph_container
|
|
|
|
.get_or_try_init_async(async {
|
|
|
|
Ok(Arc::new(MainModuleGraphContainer::new(
|
2024-07-23 19:00:48 -04:00
|
|
|
self.cli_options()?.clone(),
|
2024-05-16 00:09:35 -07:00
|
|
|
self.module_load_preparer().await?.clone(),
|
2024-09-26 02:50:54 +01:00
|
|
|
self.root_permissions_container()?.clone(),
|
2024-05-16 00:09:35 -07:00
|
|
|
)))
|
|
|
|
})
|
|
|
|
.await
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
|
|
|
|
2024-04-12 00:17:10 +01:00
|
|
|
pub fn maybe_inspector_server(
|
|
|
|
&self,
|
|
|
|
) -> Result<&Option<Arc<InspectorServer>>, AnyError> {
|
|
|
|
self.services.maybe_inspector_server.get_or_try_init(|| {
|
2024-07-23 19:00:48 -04:00
|
|
|
let cli_options = self.cli_options()?;
|
|
|
|
match cli_options.resolve_inspector_server() {
|
2024-04-12 00:17:10 +01:00
|
|
|
Ok(server) => Ok(server.map(Arc::new)),
|
|
|
|
Err(err) => Err(err),
|
|
|
|
}
|
|
|
|
})
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn module_load_preparer(
|
|
|
|
&self,
|
|
|
|
) -> Result<&Arc<ModuleLoadPreparer>, AnyError> {
|
|
|
|
self
|
|
|
|
.services
|
|
|
|
.module_load_preparer
|
|
|
|
.get_or_try_init_async(async {
|
2024-07-23 19:00:48 -04:00
|
|
|
let cli_options = self.cli_options()?;
|
2023-05-01 14:35:23 -04:00
|
|
|
Ok(Arc::new(ModuleLoadPreparer::new(
|
2024-07-23 19:00:48 -04:00
|
|
|
cli_options.clone(),
|
|
|
|
cli_options.maybe_lockfile().cloned(),
|
2023-05-01 14:35:23 -04:00
|
|
|
self.module_graph_builder().await?.clone(),
|
|
|
|
self.text_only_progress_bar().clone(),
|
|
|
|
self.type_checker().await?.clone(),
|
|
|
|
)))
|
|
|
|
})
|
|
|
|
.await
|
|
|
|
}
|
|
|
|
|
2024-11-01 12:27:00 -04:00
|
|
|
pub fn cjs_tracker(&self) -> Result<&Arc<CjsTracker>, AnyError> {
|
|
|
|
self.services.cjs_tracker.get_or_try_init(|| {
|
|
|
|
let options = self.cli_options()?;
|
|
|
|
Ok(Arc::new(CjsTracker::new(
|
|
|
|
self.in_npm_pkg_checker()?.clone(),
|
|
|
|
self.pkg_json_resolver().clone(),
|
2024-11-27 09:50:38 -05:00
|
|
|
if options.is_node_main() || options.unstable_detect_cjs() {
|
|
|
|
IsCjsResolutionMode::ImplicitTypeCommonJs
|
|
|
|
} else if options.detect_cjs() {
|
|
|
|
IsCjsResolutionMode::ExplicitTypeCommonJs
|
|
|
|
} else {
|
|
|
|
IsCjsResolutionMode::Disabled
|
2024-11-01 12:27:00 -04:00
|
|
|
},
|
|
|
|
)))
|
|
|
|
})
|
2023-05-01 14:35:23 -04:00
|
|
|
}
|
|
|
|
|
2024-09-16 21:39:37 +01:00
|
|
|
pub fn permission_desc_parser(
|
|
|
|
&self,
|
|
|
|
) -> Result<&Arc<RuntimePermissionDescriptorParser>, AnyError> {
|
|
|
|
self.services.permission_desc_parser.get_or_try_init(|| {
|
|
|
|
let fs = self.fs().clone();
|
|
|
|
Ok(Arc::new(RuntimePermissionDescriptorParser::new(fs)))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-07-23 19:00:48 -04:00
|
|
|
pub fn feature_checker(&self) -> Result<&Arc<FeatureChecker>, AnyError> {
|
|
|
|
self.services.feature_checker.get_or_try_init(|| {
|
|
|
|
let cli_options = self.cli_options()?;
|
2023-10-12 17:55:50 +02:00
|
|
|
let mut checker = FeatureChecker::default();
|
|
|
|
checker.set_exit_cb(Box::new(crate::unstable_exit_cb));
|
2024-07-23 19:00:48 -04:00
|
|
|
let unstable_features = cli_options.unstable_features();
|
2024-08-27 14:45:27 +03:00
|
|
|
for granular_flag in crate::UNSTABLE_GRANULAR_FLAGS {
|
|
|
|
if unstable_features.contains(&granular_flag.name.to_string()) {
|
|
|
|
checker.enable_feature(granular_flag.name);
|
2023-11-01 23:15:08 +01:00
|
|
|
}
|
|
|
|
}
|
2023-10-12 17:55:50 +02:00
|
|
|
|
2024-07-23 19:00:48 -04:00
|
|
|
Ok(Arc::new(checker))
|
2023-10-12 17:55:50 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2023-05-10 20:06:59 -04:00
|
|
|
pub async fn create_compile_binary_writer(
|
|
|
|
&self,
|
|
|
|
) -> Result<DenoCompileBinaryWriter, AnyError> {
|
2024-07-23 19:00:48 -04:00
|
|
|
let cli_options = self.cli_options()?;
|
2023-05-10 20:06:59 -04:00
|
|
|
Ok(DenoCompileBinaryWriter::new(
|
2024-11-01 12:27:00 -04:00
|
|
|
self.cjs_tracker()?,
|
2024-11-19 16:19:35 -05:00
|
|
|
self.cli_options()?,
|
2023-05-10 20:06:59 -04:00
|
|
|
self.deno_dir()?,
|
2024-10-24 15:48:48 -04:00
|
|
|
self.emitter()?,
|
2024-06-03 17:17:08 -04:00
|
|
|
self.file_fetcher()?,
|
|
|
|
self.http_client_provider(),
|
2023-09-29 09:26:25 -04:00
|
|
|
self.npm_resolver().await?.as_ref(),
|
2024-07-04 20:41:01 -04:00
|
|
|
self.workspace_resolver().await?.as_ref(),
|
2024-07-23 19:00:48 -04:00
|
|
|
cli_options.npm_system_info(),
|
2023-05-10 20:06:59 -04:00
|
|
|
))
|
|
|
|
}
|
|
|
|
|
2024-09-26 02:50:54 +01:00
|
|
|
pub fn root_permissions_container(
|
2024-09-16 21:39:37 +01:00
|
|
|
&self,
|
2024-09-26 02:50:54 +01:00
|
|
|
) -> Result<&PermissionsContainer, AnyError> {
|
|
|
|
self
|
|
|
|
.services
|
|
|
|
.root_permissions_container
|
|
|
|
.get_or_try_init(|| {
|
|
|
|
let desc_parser = self.permission_desc_parser()?.clone();
|
|
|
|
let permissions = Permissions::from_options(
|
|
|
|
desc_parser.as_ref(),
|
|
|
|
&self.cli_options()?.permissions_options(),
|
|
|
|
)?;
|
|
|
|
Ok(PermissionsContainer::new(desc_parser, permissions))
|
|
|
|
})
|
2024-09-16 21:39:37 +01:00
|
|
|
}
|
|
|
|
|
2023-05-01 14:35:23 -04:00
|
|
|
pub async fn create_cli_main_worker_factory(
|
|
|
|
&self,
|
|
|
|
) -> Result<CliMainWorkerFactory, AnyError> {
|
2024-07-23 19:00:48 -04:00
|
|
|
let cli_options = self.cli_options()?;
|
2024-11-01 12:27:00 -04:00
|
|
|
let fs = self.fs();
|
2023-05-01 14:35:23 -04:00
|
|
|
let node_resolver = self.node_resolver().await?;
|
2023-09-28 16:43:45 -04:00
|
|
|
let npm_resolver = self.npm_resolver().await?;
|
2024-09-29 20:07:50 -04:00
|
|
|
let cli_npm_resolver = self.npm_resolver().await?.clone();
|
2024-11-01 12:27:00 -04:00
|
|
|
let in_npm_pkg_checker = self.in_npm_pkg_checker()?;
|
2024-07-23 19:00:48 -04:00
|
|
|
let maybe_file_watcher_communicator = if cli_options.has_hmr() {
|
2023-10-31 01:25:58 +01:00
|
|
|
Some(self.watcher_communicator.clone().unwrap())
|
|
|
|
} else {
|
|
|
|
None
|
|
|
|
};
|
2024-11-01 12:27:00 -04:00
|
|
|
let node_code_translator = self.node_code_translator().await?;
|
|
|
|
let cjs_tracker = self.cjs_tracker()?.clone();
|
|
|
|
let pkg_json_resolver = self.pkg_json_resolver().clone();
|
2024-11-14 15:24:25 -05:00
|
|
|
let npm_req_resolver = self.npm_req_resolver().await?;
|
2023-10-19 07:05:00 +02:00
|
|
|
|
2023-05-01 14:35:23 -04:00
|
|
|
Ok(CliMainWorkerFactory::new(
|
|
|
|
self.blob_store().clone(),
|
2024-09-16 21:39:37 +01:00
|
|
|
if cli_options.code_cache_enabled() {
|
|
|
|
Some(self.code_cache()?.clone())
|
|
|
|
} else {
|
|
|
|
None
|
|
|
|
},
|
|
|
|
self.feature_checker()?.clone(),
|
2024-11-01 12:27:00 -04:00
|
|
|
fs.clone(),
|
2024-09-16 21:39:37 +01:00
|
|
|
maybe_file_watcher_communicator,
|
|
|
|
self.maybe_inspector_server()?.clone(),
|
|
|
|
cli_options.maybe_lockfile().cloned(),
|
2023-05-01 14:35:23 -04:00
|
|
|
Box::new(CliModuleLoaderFactory::new(
|
2024-07-23 19:00:48 -04:00
|
|
|
cli_options,
|
2024-11-01 12:27:00 -04:00
|
|
|
cjs_tracker,
|
2024-07-23 19:00:48 -04:00
|
|
|
if cli_options.code_cache_enabled() {
|
2024-05-16 00:09:35 -07:00
|
|
|
Some(self.code_cache()?.clone())
|
|
|
|
} else {
|
|
|
|
None
|
|
|
|
},
|
2023-05-01 14:35:23 -04:00
|
|
|
self.emitter()?.clone(),
|
2024-11-01 12:27:00 -04:00
|
|
|
fs.clone(),
|
|
|
|
in_npm_pkg_checker.clone(),
|
2024-05-16 00:09:35 -07:00
|
|
|
self.main_module_graph_container().await?.clone(),
|
2023-05-01 14:35:23 -04:00
|
|
|
self.module_load_preparer().await?.clone(),
|
2024-11-01 12:27:00 -04:00
|
|
|
node_code_translator.clone(),
|
2024-11-14 15:24:25 -05:00
|
|
|
node_resolver.clone(),
|
|
|
|
npm_req_resolver.clone(),
|
2024-09-29 20:07:50 -04:00
|
|
|
cli_npm_resolver.clone(),
|
2023-05-01 14:35:23 -04:00
|
|
|
NpmModuleLoader::new(
|
2024-11-01 12:27:00 -04:00
|
|
|
self.cjs_tracker()?.clone(),
|
2023-05-10 20:06:59 -04:00
|
|
|
fs.clone(),
|
2024-11-01 12:27:00 -04:00
|
|
|
node_code_translator.clone(),
|
2023-05-01 14:35:23 -04:00
|
|
|
),
|
2024-05-16 00:09:35 -07:00
|
|
|
self.parsed_source_cache().clone(),
|
|
|
|
self.resolver().await?.clone(),
|
2023-05-01 14:35:23 -04:00
|
|
|
)),
|
2024-09-16 21:39:37 +01:00
|
|
|
node_resolver.clone(),
|
|
|
|
npm_resolver.clone(),
|
2024-11-01 12:27:00 -04:00
|
|
|
pkg_json_resolver,
|
2023-05-01 16:42:05 -04:00
|
|
|
self.root_cert_store_provider().clone(),
|
2024-09-26 02:50:54 +01:00
|
|
|
self.root_permissions_container()?.clone(),
|
2024-09-16 21:39:37 +01:00
|
|
|
StorageKeyResolver::from_options(cli_options),
|
|
|
|
cli_options.sub_command().clone(),
|
2024-08-30 17:58:24 -04:00
|
|
|
self.create_cli_main_worker_options()?,
|
2024-11-13 11:38:46 +01:00
|
|
|
self.cli_options()?.otel_config(),
|
2023-05-01 14:35:23 -04:00
|
|
|
))
|
|
|
|
}
|
|
|
|
|
|
|
|
fn create_cli_main_worker_options(
|
|
|
|
&self,
|
|
|
|
) -> Result<CliMainWorkerOptions, AnyError> {
|
2024-07-23 19:00:48 -04:00
|
|
|
let cli_options = self.cli_options()?;
|
|
|
|
let create_hmr_runner = if cli_options.has_hmr() {
|
2024-02-13 21:52:30 +05:30
|
|
|
let watcher_communicator = self.watcher_communicator.clone().unwrap();
|
|
|
|
let emitter = self.emitter()?.clone();
|
|
|
|
let fn_: crate::worker::CreateHmrRunnerCb = Box::new(move |session| {
|
|
|
|
Box::new(HmrRunner::new(
|
|
|
|
emitter.clone(),
|
|
|
|
session,
|
|
|
|
watcher_communicator.clone(),
|
|
|
|
))
|
|
|
|
});
|
|
|
|
Some(fn_)
|
|
|
|
} else {
|
|
|
|
None
|
|
|
|
};
|
|
|
|
let create_coverage_collector =
|
2024-07-23 19:00:48 -04:00
|
|
|
if let Some(coverage_dir) = cli_options.coverage_dir() {
|
2024-02-13 21:52:30 +05:30
|
|
|
let coverage_dir = PathBuf::from(coverage_dir);
|
|
|
|
let fn_: crate::worker::CreateCoverageCollectorCb =
|
|
|
|
Box::new(move |session| {
|
|
|
|
Box::new(CoverageCollector::new(coverage_dir.clone(), session))
|
|
|
|
});
|
|
|
|
Some(fn_)
|
|
|
|
} else {
|
|
|
|
None
|
|
|
|
};
|
|
|
|
|
2023-05-01 14:35:23 -04:00
|
|
|
Ok(CliMainWorkerOptions {
|
2024-07-23 19:00:48 -04:00
|
|
|
argv: cli_options.argv().clone(),
|
2023-11-11 09:01:48 -08:00
|
|
|
// This optimization is only available for "run" subcommand
|
|
|
|
// because we need to register new ops for testing and jupyter
|
|
|
|
// integration.
|
2024-07-23 19:00:48 -04:00
|
|
|
skip_op_registration: cli_options.sub_command().is_run(),
|
|
|
|
log_level: cli_options.log_level().unwrap_or(log::Level::Info).into(),
|
|
|
|
enable_op_summary_metrics: cli_options.enable_op_summary_metrics(),
|
|
|
|
enable_testing_features: cli_options.enable_testing_features(),
|
|
|
|
has_node_modules_dir: cli_options.has_node_modules_dir(),
|
|
|
|
hmr: cli_options.has_hmr(),
|
|
|
|
inspect_brk: cli_options.inspect_brk().is_some(),
|
|
|
|
inspect_wait: cli_options.inspect_wait().is_some(),
|
|
|
|
strace_ops: cli_options.strace_ops().clone(),
|
|
|
|
is_inspecting: cli_options.is_inspecting(),
|
|
|
|
location: cli_options.location_flag().clone(),
|
2023-12-06 16:36:06 -05:00
|
|
|
// if the user ran a binary command, we'll need to set process.argv[0]
|
|
|
|
// to be the name of the binary command instead of deno
|
2024-07-23 19:00:48 -04:00
|
|
|
argv0: cli_options
|
2024-02-23 22:00:29 +05:30
|
|
|
.take_binary_npm_command_name()
|
|
|
|
.or(std::env::args().next()),
|
2024-05-05 19:46:02 +05:30
|
|
|
node_debug: std::env::var("NODE_DEBUG").ok(),
|
2023-05-01 14:35:23 -04:00
|
|
|
origin_data_folder_path: Some(self.deno_dir()?.origin_data_folder_path()),
|
2024-07-23 19:00:48 -04:00
|
|
|
seed: cli_options.seed(),
|
|
|
|
unsafely_ignore_certificate_errors: cli_options
|
2023-05-01 14:35:23 -04:00
|
|
|
.unsafely_ignore_certificate_errors()
|
|
|
|
.clone(),
|
2024-02-13 21:52:30 +05:30
|
|
|
create_hmr_runner,
|
|
|
|
create_coverage_collector,
|
2024-08-30 17:58:24 -04:00
|
|
|
node_ipc: cli_options.node_ipc_fd(),
|
|
|
|
serve_port: cli_options.serve_port(),
|
|
|
|
serve_host: cli_options.serve_host(),
|
2023-05-01 14:35:23 -04:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2024-12-05 08:04:31 +00:00
|
|
|
|
|
|
|
pub struct WorkspaceFileContainerEntry<T> {
|
|
|
|
main_graph_container: Arc<MainModuleGraphContainer>,
|
|
|
|
specifiers: Vec<(ModuleSpecifier, T)>,
|
2024-12-07 02:14:20 +00:00
|
|
|
doc_snippet_specifiers: Option<Vec<ModuleSpecifier>>,
|
|
|
|
check_doc_only: bool,
|
2024-12-05 08:04:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub struct WorkspaceFileContainer<T> {
|
|
|
|
entries: Vec<WorkspaceFileContainerEntry<T>>,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T> WorkspaceFileContainer<T> {
|
|
|
|
#[allow(clippy::type_complexity)]
|
|
|
|
pub async fn from_workspace_dirs_with_files(
|
|
|
|
mut workspace_dirs_with_files: Vec<(Arc<WorkspaceDirectory>, FilePatterns)>,
|
2024-12-07 02:31:48 +00:00
|
|
|
collect_specifiers: fn(
|
2024-12-05 08:04:31 +00:00
|
|
|
FilePatterns,
|
|
|
|
Arc<CliOptions>,
|
|
|
|
Arc<FileFetcher>,
|
|
|
|
) -> std::pin::Pin<
|
|
|
|
Box<dyn Future<Output = Result<Vec<(ModuleSpecifier, T)>, AnyError>>>,
|
|
|
|
>,
|
|
|
|
cli_options: &CliOptions,
|
|
|
|
check_doc: bool,
|
2024-12-07 02:14:20 +00:00
|
|
|
check_doc_only: bool,
|
2024-12-05 08:04:31 +00:00
|
|
|
) -> Result<Self, AnyError> {
|
|
|
|
workspace_dirs_with_files.sort_by_cached_key(|(d, _)| d.dir_url().clone());
|
|
|
|
let all_scopes = Arc::new(
|
|
|
|
workspace_dirs_with_files
|
|
|
|
.iter()
|
|
|
|
.filter(|(d, _)| d.has_deno_or_pkg_json())
|
|
|
|
.map(|(d, _)| d.dir_url().clone())
|
|
|
|
.collect::<BTreeSet<_>>(),
|
|
|
|
);
|
|
|
|
let dir_count = workspace_dirs_with_files.len();
|
|
|
|
let mut entries = Vec::with_capacity(dir_count);
|
|
|
|
for (workspace_dir, files) in workspace_dirs_with_files {
|
|
|
|
let (npmrc, _) = discover_npmrc_from_workspace(&workspace_dir.workspace)?;
|
|
|
|
let lockfile =
|
|
|
|
CliLockfile::discover(&cli_options.flags, &workspace_dir.workspace)?;
|
|
|
|
let scope_options = (dir_count > 1).then(|| ScopeOptions {
|
|
|
|
scope: workspace_dir
|
|
|
|
.has_deno_or_pkg_json()
|
|
|
|
.then(|| workspace_dir.dir_url().clone()),
|
|
|
|
all_scopes: all_scopes.clone(),
|
|
|
|
});
|
|
|
|
let cli_options = Arc::new(CliOptions::new(
|
|
|
|
cli_options.flags.clone(),
|
|
|
|
cli_options.initial_cwd().to_path_buf(),
|
|
|
|
lockfile.map(Arc::new),
|
|
|
|
npmrc,
|
|
|
|
workspace_dir,
|
|
|
|
false,
|
|
|
|
scope_options.map(Arc::new),
|
|
|
|
)?);
|
|
|
|
let factory = CliFactory::from_cli_options(cli_options.clone());
|
|
|
|
let file_fetcher = factory.file_fetcher()?;
|
|
|
|
let main_graph_container =
|
|
|
|
factory.main_module_graph_container().await?.clone();
|
|
|
|
let specifiers =
|
2024-12-07 02:31:48 +00:00
|
|
|
collect_specifiers(files, cli_options, file_fetcher.clone()).await?;
|
2024-12-07 02:14:20 +00:00
|
|
|
let doc_snippet_specifiers = if check_doc || check_doc_only {
|
2024-12-05 08:04:31 +00:00
|
|
|
let root_permissions = factory.root_permissions_container()?;
|
2024-12-07 02:14:20 +00:00
|
|
|
let mut doc_snippet_specifiers = Vec::new();
|
2024-12-05 08:04:31 +00:00
|
|
|
for (s, _) in specifiers.iter() {
|
|
|
|
let file = file_fetcher.fetch(s, root_permissions).await?;
|
|
|
|
let snippet_files = extract::extract_snippet_files(file)?;
|
|
|
|
for snippet_file in snippet_files {
|
2024-12-07 02:14:20 +00:00
|
|
|
doc_snippet_specifiers.push(snippet_file.specifier.clone());
|
2024-12-05 08:04:31 +00:00
|
|
|
file_fetcher.insert_memory_files(snippet_file);
|
|
|
|
}
|
|
|
|
}
|
2024-12-07 02:14:20 +00:00
|
|
|
Some(doc_snippet_specifiers)
|
2024-12-05 08:04:31 +00:00
|
|
|
} else {
|
|
|
|
None
|
|
|
|
};
|
|
|
|
entries.push(WorkspaceFileContainerEntry {
|
|
|
|
main_graph_container,
|
|
|
|
specifiers,
|
2024-12-07 02:14:20 +00:00
|
|
|
doc_snippet_specifiers,
|
|
|
|
check_doc_only,
|
2024-12-05 08:04:31 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
Ok(Self { entries })
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn check(&self) -> Result<(), AnyError> {
|
|
|
|
let mut diagnostics = vec![];
|
|
|
|
let mut all_errors = vec![];
|
|
|
|
for entry in &self.entries {
|
2024-12-07 02:14:20 +00:00
|
|
|
let mut specifiers_for_typecheck = vec![];
|
|
|
|
if !entry.check_doc_only {
|
|
|
|
specifiers_for_typecheck
|
|
|
|
.extend(entry.specifiers.iter().map(|(s, _)| s.clone()));
|
|
|
|
}
|
|
|
|
if let Some(doc_snippet_specifiers) = &entry.doc_snippet_specifiers {
|
|
|
|
specifiers_for_typecheck.extend(doc_snippet_specifiers.clone());
|
|
|
|
}
|
2024-12-05 08:04:31 +00:00
|
|
|
if specifiers_for_typecheck.is_empty() {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if let Err(err) = entry
|
|
|
|
.main_graph_container
|
|
|
|
.check_specifiers(&specifiers_for_typecheck, None)
|
|
|
|
.await
|
|
|
|
{
|
|
|
|
match err {
|
|
|
|
MaybeDiagnostics::Diagnostics(Diagnostics(d)) => {
|
|
|
|
diagnostics.extend(d)
|
|
|
|
}
|
|
|
|
MaybeDiagnostics::Other(err) => all_errors.push(err),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if !diagnostics.is_empty() {
|
|
|
|
all_errors.push(AnyError::from(Diagnostics(diagnostics)));
|
|
|
|
}
|
|
|
|
if !all_errors.is_empty() {
|
|
|
|
return Err(anyhow!(
|
|
|
|
"{}",
|
|
|
|
all_errors
|
|
|
|
.into_iter()
|
|
|
|
.map(|e| e.to_string())
|
|
|
|
.collect::<Vec<_>>()
|
|
|
|
.join("\n\n"),
|
|
|
|
));
|
|
|
|
}
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn has_specifiers(&self) -> bool {
|
|
|
|
self.entries.iter().any(|e| !e.specifiers.is_empty())
|
|
|
|
}
|
|
|
|
}
|