mirror of
https://github.com/denoland/deno.git
synced 2024-11-27 16:10:57 -05:00
fix(compile): support workspace members importing other members (#24909)
This commit is contained in:
parent
4fa8869f24
commit
04473c04ed
28 changed files with 171 additions and 52 deletions
12
Cargo.lock
generated
12
Cargo.lock
generated
|
@ -1329,9 +1329,9 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "deno_config"
|
name = "deno_config"
|
||||||
version = "0.26.1"
|
version = "0.28.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "8188c39699541affc0c0f89bbba07d31212385fa0c4e1a5a9e530b0f3cbc776f"
|
checksum = "fc1f3c577bf7fdbb449cb99c2560309364c71cc3dcc7af94387ef8810b089173"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"deno_package_json",
|
"deno_package_json",
|
||||||
|
@ -1552,9 +1552,9 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "deno_graph"
|
name = "deno_graph"
|
||||||
version = "0.81.0"
|
version = "0.81.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "31f1f965754dcdbaa5c9433a8c8da4a3cb7d93f29b58aa84b5617fe887f57415"
|
checksum = "d2cada0d9fd56536d3208cff2b130096e396ee2716466850cf0b7927249e40a0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"async-trait",
|
"async-trait",
|
||||||
|
@ -1955,9 +1955,9 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "deno_semver"
|
name = "deno_semver"
|
||||||
version = "0.5.7"
|
version = "0.5.9"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "e23ce551a58eeefc05a48042a9c76d3409c96a1a6a522a82c4ced26930ece201"
|
checksum = "9fb7520ac21cb236c6f8cc81964e8bf22c72fc58c7b5f762f99b9a95abfe3212"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"monch",
|
"monch",
|
||||||
"once_cell",
|
"once_cell",
|
||||||
|
|
|
@ -65,17 +65,17 @@ winres.workspace = true
|
||||||
[dependencies]
|
[dependencies]
|
||||||
deno_ast = { workspace = true, features = ["bundler", "cjs", "codegen", "proposal", "react", "sourcemap", "transforms", "typescript", "view", "visit"] }
|
deno_ast = { workspace = true, features = ["bundler", "cjs", "codegen", "proposal", "react", "sourcemap", "transforms", "typescript", "view", "visit"] }
|
||||||
deno_cache_dir = { workspace = true }
|
deno_cache_dir = { workspace = true }
|
||||||
deno_config = { version = "=0.26.1", features = ["workspace", "sync"] }
|
deno_config = { version = "=0.28.0", features = ["workspace", "sync"] }
|
||||||
deno_core = { workspace = true, features = ["include_js_files_for_snapshotting"] }
|
deno_core = { workspace = true, features = ["include_js_files_for_snapshotting"] }
|
||||||
deno_doc = { version = "0.145.0", features = ["html", "syntect"] }
|
deno_doc = { version = "0.145.0", features = ["html", "syntect"] }
|
||||||
deno_emit = "=0.44.0"
|
deno_emit = "=0.44.0"
|
||||||
deno_graph = { version = "=0.81.0" }
|
deno_graph = { version = "=0.81.1" }
|
||||||
deno_lint = { version = "=0.62.0", features = ["docs"] }
|
deno_lint = { version = "=0.62.0", features = ["docs"] }
|
||||||
deno_lockfile.workspace = true
|
deno_lockfile.workspace = true
|
||||||
deno_npm = "=0.21.4"
|
deno_npm = "=0.21.4"
|
||||||
deno_package_json.workspace = true
|
deno_package_json.workspace = true
|
||||||
deno_runtime = { workspace = true, features = ["include_js_files_for_snapshotting"] }
|
deno_runtime = { workspace = true, features = ["include_js_files_for_snapshotting"] }
|
||||||
deno_semver = "=0.5.7"
|
deno_semver = "=0.5.9"
|
||||||
deno_task_shell = "=0.17.0"
|
deno_task_shell = "=0.17.0"
|
||||||
deno_terminal.workspace = true
|
deno_terminal.workspace = true
|
||||||
eszip = "=0.73.0"
|
eszip = "=0.73.0"
|
||||||
|
|
|
@ -1435,7 +1435,6 @@ impl CliOptions {
|
||||||
self
|
self
|
||||||
.workspace()
|
.workspace()
|
||||||
.jsr_packages()
|
.jsr_packages()
|
||||||
.into_iter()
|
|
||||||
.map(|pkg| config_to_deno_graph_workspace_member(&pkg.config_file))
|
.map(|pkg| config_to_deno_graph_workspace_member(&pkg.config_file))
|
||||||
.collect::<Result<Vec<_>, _>>()
|
.collect::<Result<Vec<_>, _>>()
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,7 +29,6 @@ fn get_diagnostic_class(_: &ParseDiagnostic) -> &'static str {
|
||||||
fn get_module_graph_error_class(err: &ModuleGraphError) -> &'static str {
|
fn get_module_graph_error_class(err: &ModuleGraphError) -> &'static str {
|
||||||
use deno_graph::JsrLoadError;
|
use deno_graph::JsrLoadError;
|
||||||
use deno_graph::NpmLoadError;
|
use deno_graph::NpmLoadError;
|
||||||
use deno_graph::WorkspaceLoadError;
|
|
||||||
|
|
||||||
match err {
|
match err {
|
||||||
ModuleGraphError::ResolutionError(err)
|
ModuleGraphError::ResolutionError(err)
|
||||||
|
@ -71,10 +70,6 @@ fn get_module_graph_error_class(err: &ModuleGraphError) -> &'static str {
|
||||||
| JsrLoadError::PackageVersionNotFound(_)
|
| JsrLoadError::PackageVersionNotFound(_)
|
||||||
| JsrLoadError::UnknownExport { .. } => "NotFound",
|
| JsrLoadError::UnknownExport { .. } => "NotFound",
|
||||||
},
|
},
|
||||||
ModuleLoadError::Workspace(err) => match err {
|
|
||||||
WorkspaceLoadError::MemberInvalidExportPath { .. } => "TypeError",
|
|
||||||
WorkspaceLoadError::MissingMemberExports { .. } => "NotFound",
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
@ -500,8 +500,6 @@ impl ModuleGraphBuilder {
|
||||||
.maybe_file_watcher_reporter
|
.maybe_file_watcher_reporter
|
||||||
.as_ref()
|
.as_ref()
|
||||||
.map(|r| r.as_reporter());
|
.map(|r| r.as_reporter());
|
||||||
let workspace_members =
|
|
||||||
self.options.resolve_deno_graph_workspace_members()?;
|
|
||||||
let mut locker = self
|
let mut locker = self
|
||||||
.lockfile
|
.lockfile
|
||||||
.as_ref()
|
.as_ref()
|
||||||
|
@ -515,7 +513,6 @@ impl ModuleGraphBuilder {
|
||||||
imports: maybe_imports,
|
imports: maybe_imports,
|
||||||
is_dynamic: options.is_dynamic,
|
is_dynamic: options.is_dynamic,
|
||||||
passthrough_jsr_specifiers: false,
|
passthrough_jsr_specifiers: false,
|
||||||
workspace_members: &workspace_members,
|
|
||||||
executor: Default::default(),
|
executor: Default::default(),
|
||||||
file_system: &DenoGraphFsAdapter(self.fs.as_ref()),
|
file_system: &DenoGraphFsAdapter(self.fs.as_ref()),
|
||||||
jsr_url_provider: &CliJsrUrlProvider,
|
jsr_url_provider: &CliJsrUrlProvider,
|
||||||
|
|
|
@ -1518,6 +1518,7 @@ impl ConfigData {
|
||||||
WorkspaceResolver::new_raw(
|
WorkspaceResolver::new_raw(
|
||||||
scope.clone(),
|
scope.clone(),
|
||||||
None,
|
None,
|
||||||
|
member_dir.workspace.resolver_jsr_pkgs().collect(),
|
||||||
member_dir.workspace.package_jsons().cloned().collect(),
|
member_dir.workspace.package_jsons().cloned().collect(),
|
||||||
pkg_json_dep_resolution,
|
pkg_json_dep_resolution,
|
||||||
)
|
)
|
||||||
|
|
|
@ -20,7 +20,6 @@ use deno_semver::package::PackageNv;
|
||||||
use deno_semver::package::PackageReq;
|
use deno_semver::package::PackageReq;
|
||||||
use deno_semver::Version;
|
use deno_semver::Version;
|
||||||
use serde::Deserialize;
|
use serde::Deserialize;
|
||||||
use std::borrow::Cow;
|
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
|
|
||||||
|
@ -157,7 +156,7 @@ impl JsrCacheResolver {
|
||||||
let maybe_nv = self.req_to_nv(&req);
|
let maybe_nv = self.req_to_nv(&req);
|
||||||
let nv = maybe_nv.as_ref()?;
|
let nv = maybe_nv.as_ref()?;
|
||||||
let info = self.package_version_info(nv)?;
|
let info = self.package_version_info(nv)?;
|
||||||
let path = info.export(&normalize_export_name(req_ref.sub_path()))?;
|
let path = info.export(&req_ref.export_name())?;
|
||||||
if let Some(workspace_scope) = self.workspace_scope_by_name.get(&nv.name) {
|
if let Some(workspace_scope) = self.workspace_scope_by_name.get(&nv.name) {
|
||||||
workspace_scope.join(path).ok()
|
workspace_scope.join(path).ok()
|
||||||
} else {
|
} else {
|
||||||
|
@ -267,30 +266,6 @@ fn read_cached_url(
|
||||||
.ok()?
|
.ok()?
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO(nayeemrmn): This is duplicated from a private function in deno_graph
|
|
||||||
// 0.65.1. Make it public or cleanup otherwise.
|
|
||||||
fn normalize_export_name(sub_path: Option<&str>) -> Cow<str> {
|
|
||||||
let Some(sub_path) = sub_path else {
|
|
||||||
return Cow::Borrowed(".");
|
|
||||||
};
|
|
||||||
if sub_path.is_empty() || matches!(sub_path, "/" | ".") {
|
|
||||||
Cow::Borrowed(".")
|
|
||||||
} else {
|
|
||||||
let sub_path = if sub_path.starts_with('/') {
|
|
||||||
Cow::Owned(format!(".{}", sub_path))
|
|
||||||
} else if !sub_path.starts_with("./") {
|
|
||||||
Cow::Owned(format!("./{}", sub_path))
|
|
||||||
} else {
|
|
||||||
Cow::Borrowed(sub_path)
|
|
||||||
};
|
|
||||||
if let Some(prefix) = sub_path.strip_suffix('/') {
|
|
||||||
Cow::Owned(prefix.to_string())
|
|
||||||
} else {
|
|
||||||
sub_path
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct CliJsrSearchApi {
|
pub struct CliJsrSearchApi {
|
||||||
file_fetcher: Arc<FileFetcher>,
|
file_fetcher: Arc<FileFetcher>,
|
||||||
|
|
|
@ -523,6 +523,7 @@ fn create_graph_resolver(
|
||||||
Arc::new(ModuleSpecifier::parse("file:///").unwrap()),
|
Arc::new(ModuleSpecifier::parse("file:///").unwrap()),
|
||||||
None,
|
None,
|
||||||
Vec::new(),
|
Vec::new(),
|
||||||
|
Vec::new(),
|
||||||
PackageJsonDepResolution::Disabled,
|
PackageJsonDepResolution::Disabled,
|
||||||
))
|
))
|
||||||
},
|
},
|
||||||
|
|
|
@ -535,6 +535,9 @@ impl Resolver for CliGraphResolver {
|
||||||
MappedResolutionError::ImportMap(err) => {
|
MappedResolutionError::ImportMap(err) => {
|
||||||
ResolveError::Other(err.into())
|
ResolveError::Other(err.into())
|
||||||
}
|
}
|
||||||
|
MappedResolutionError::Workspace(err) => {
|
||||||
|
ResolveError::Other(err.into())
|
||||||
|
}
|
||||||
});
|
});
|
||||||
let result = match result {
|
let result = match result {
|
||||||
Ok(resolution) => match resolution {
|
Ok(resolution) => match resolution {
|
||||||
|
@ -552,6 +555,9 @@ impl Resolver for CliGraphResolver {
|
||||||
Ok(specifier)
|
Ok(specifier)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
MappedResolution::WorkspaceJsrPackage { specifier, .. } => {
|
||||||
|
Ok(specifier)
|
||||||
|
}
|
||||||
MappedResolution::WorkspaceNpmPackage {
|
MappedResolution::WorkspaceNpmPackage {
|
||||||
target_pkg_json: pkg_json,
|
target_pkg_json: pkg_json,
|
||||||
sub_path,
|
sub_path,
|
||||||
|
|
|
@ -19,6 +19,7 @@ use std::process::Command;
|
||||||
|
|
||||||
use deno_ast::ModuleSpecifier;
|
use deno_ast::ModuleSpecifier;
|
||||||
use deno_config::workspace::PackageJsonDepResolution;
|
use deno_config::workspace::PackageJsonDepResolution;
|
||||||
|
use deno_config::workspace::ResolverWorkspaceJsrPackage;
|
||||||
use deno_config::workspace::Workspace;
|
use deno_config::workspace::Workspace;
|
||||||
use deno_config::workspace::WorkspaceResolver;
|
use deno_config::workspace::WorkspaceResolver;
|
||||||
use deno_core::anyhow::bail;
|
use deno_core::anyhow::bail;
|
||||||
|
@ -33,6 +34,7 @@ use deno_npm::NpmSystemInfo;
|
||||||
use deno_runtime::deno_node::PackageJson;
|
use deno_runtime::deno_node::PackageJson;
|
||||||
use deno_semver::npm::NpmVersionReqParseError;
|
use deno_semver::npm::NpmVersionReqParseError;
|
||||||
use deno_semver::package::PackageReq;
|
use deno_semver::package::PackageReq;
|
||||||
|
use deno_semver::Version;
|
||||||
use deno_semver::VersionReqSpecifierParseError;
|
use deno_semver::VersionReqSpecifierParseError;
|
||||||
use eszip::EszipRelativeFileBaseUrl;
|
use eszip::EszipRelativeFileBaseUrl;
|
||||||
use indexmap::IndexMap;
|
use indexmap::IndexMap;
|
||||||
|
@ -80,9 +82,18 @@ pub struct SerializedWorkspaceResolverImportMap {
|
||||||
pub json: String,
|
pub json: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
|
||||||
|
pub struct SerializedResolverWorkspaceJsrPackage {
|
||||||
|
pub relative_base: String,
|
||||||
|
pub name: String,
|
||||||
|
pub version: Option<Version>,
|
||||||
|
pub exports: IndexMap<String, String>,
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Deserialize, Serialize)]
|
#[derive(Deserialize, Serialize)]
|
||||||
pub struct SerializedWorkspaceResolver {
|
pub struct SerializedWorkspaceResolver {
|
||||||
pub import_map: Option<SerializedWorkspaceResolverImportMap>,
|
pub import_map: Option<SerializedWorkspaceResolverImportMap>,
|
||||||
|
pub jsr_pkgs: Vec<SerializedResolverWorkspaceJsrPackage>,
|
||||||
pub package_jsons: BTreeMap<String, serde_json::Value>,
|
pub package_jsons: BTreeMap<String, serde_json::Value>,
|
||||||
pub pkg_json_resolution: PackageJsonDepResolution,
|
pub pkg_json_resolution: PackageJsonDepResolution,
|
||||||
}
|
}
|
||||||
|
@ -620,6 +631,16 @@ impl<'a> DenoCompileBinaryWriter<'a> {
|
||||||
json: i.to_json(),
|
json: i.to_json(),
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
|
jsr_pkgs: self
|
||||||
|
.workspace_resolver
|
||||||
|
.jsr_packages()
|
||||||
|
.map(|pkg| SerializedResolverWorkspaceJsrPackage {
|
||||||
|
relative_base: root_dir_url.specifier_key(&pkg.base).into_owned(),
|
||||||
|
name: pkg.name.clone(),
|
||||||
|
version: pkg.version.clone(),
|
||||||
|
exports: pkg.exports.clone(),
|
||||||
|
})
|
||||||
|
.collect(),
|
||||||
package_jsons: self
|
package_jsons: self
|
||||||
.workspace_resolver
|
.workspace_resolver
|
||||||
.package_jsons()
|
.package_jsons()
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
use deno_ast::MediaType;
|
use deno_ast::MediaType;
|
||||||
use deno_config::workspace::MappedResolution;
|
use deno_config::workspace::MappedResolution;
|
||||||
use deno_config::workspace::MappedResolutionError;
|
use deno_config::workspace::MappedResolutionError;
|
||||||
|
use deno_config::workspace::ResolverWorkspaceJsrPackage;
|
||||||
use deno_config::workspace::WorkspaceResolver;
|
use deno_config::workspace::WorkspaceResolver;
|
||||||
use deno_core::anyhow::Context;
|
use deno_core::anyhow::Context;
|
||||||
use deno_core::error::generic_error;
|
use deno_core::error::generic_error;
|
||||||
|
@ -169,6 +170,9 @@ impl ModuleLoader for EmbeddedModuleLoader {
|
||||||
self.shared.workspace_resolver.resolve(specifier, &referrer);
|
self.shared.workspace_resolver.resolve(specifier, &referrer);
|
||||||
|
|
||||||
match mapped_resolution {
|
match mapped_resolution {
|
||||||
|
Ok(MappedResolution::WorkspaceJsrPackage { specifier, .. }) => {
|
||||||
|
Ok(specifier)
|
||||||
|
}
|
||||||
Ok(MappedResolution::WorkspaceNpmPackage {
|
Ok(MappedResolution::WorkspaceNpmPackage {
|
||||||
target_pkg_json: pkg_json,
|
target_pkg_json: pkg_json,
|
||||||
sub_path,
|
sub_path,
|
||||||
|
@ -613,6 +617,17 @@ pub async fn run(
|
||||||
WorkspaceResolver::new_raw(
|
WorkspaceResolver::new_raw(
|
||||||
root_dir_url.clone(),
|
root_dir_url.clone(),
|
||||||
import_map,
|
import_map,
|
||||||
|
metadata
|
||||||
|
.workspace_resolver
|
||||||
|
.jsr_pkgs
|
||||||
|
.iter()
|
||||||
|
.map(|pkg| ResolverWorkspaceJsrPackage {
|
||||||
|
base: root_dir_url.join(&pkg.relative_base).unwrap(),
|
||||||
|
name: pkg.name.clone(),
|
||||||
|
version: pkg.version.clone(),
|
||||||
|
exports: pkg.exports.clone(),
|
||||||
|
})
|
||||||
|
.collect(),
|
||||||
pkg_jsons,
|
pkg_jsons,
|
||||||
metadata.workspace_resolver.pkg_json_resolution,
|
metadata.workspace_resolver.pkg_json_resolution,
|
||||||
)
|
)
|
||||||
|
|
|
@ -59,7 +59,6 @@ async fn generate_doc_nodes_for_builtin_types(
|
||||||
imports: Vec::new(),
|
imports: Vec::new(),
|
||||||
is_dynamic: false,
|
is_dynamic: false,
|
||||||
passthrough_jsr_specifiers: false,
|
passthrough_jsr_specifiers: false,
|
||||||
workspace_members: &[],
|
|
||||||
executor: Default::default(),
|
executor: Default::default(),
|
||||||
file_system: &NullFileSystem,
|
file_system: &NullFileSystem,
|
||||||
jsr_url_provider: Default::default(),
|
jsr_url_provider: Default::default(),
|
||||||
|
|
|
@ -203,10 +203,14 @@ impl<'a> deno_graph::source::Resolver for SloppyImportCaptureResolver<'a> {
|
||||||
None => Ok(specifier),
|
None => Ok(specifier),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
deno_config::workspace::MappedResolution::WorkspaceNpmPackage {
|
deno_config::workspace::MappedResolution::WorkspaceJsrPackage {
|
||||||
|
..
|
||||||
|
}
|
||||||
|
| deno_config::workspace::MappedResolution::WorkspaceNpmPackage {
|
||||||
..
|
..
|
||||||
}
|
}
|
||||||
| deno_config::workspace::MappedResolution::PackageJson { .. } => {
|
| deno_config::workspace::MappedResolution::PackageJson { .. } => {
|
||||||
|
// this error is ignored
|
||||||
Err(ResolveError::Other(anyhow!("")))
|
Err(ResolveError::Other(anyhow!("")))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -75,6 +75,9 @@ impl SpecifierUnfurler {
|
||||||
match resolved {
|
match resolved {
|
||||||
MappedResolution::Normal(specifier)
|
MappedResolution::Normal(specifier)
|
||||||
| MappedResolution::ImportMap(specifier) => Some(specifier),
|
| MappedResolution::ImportMap(specifier) => Some(specifier),
|
||||||
|
MappedResolution::WorkspaceJsrPackage { pkg_req_ref, .. } => {
|
||||||
|
Some(ModuleSpecifier::parse(&pkg_req_ref.to_string()).unwrap())
|
||||||
|
}
|
||||||
MappedResolution::WorkspaceNpmPackage {
|
MappedResolution::WorkspaceNpmPackage {
|
||||||
target_pkg_json: pkg_json,
|
target_pkg_json: pkg_json,
|
||||||
pkg_name,
|
pkg_name,
|
||||||
|
@ -388,11 +391,14 @@ mod tests {
|
||||||
use super::*;
|
use super::*;
|
||||||
use deno_ast::MediaType;
|
use deno_ast::MediaType;
|
||||||
use deno_ast::ModuleSpecifier;
|
use deno_ast::ModuleSpecifier;
|
||||||
|
use deno_config::workspace::ResolverWorkspaceJsrPackage;
|
||||||
use deno_core::serde_json::json;
|
use deno_core::serde_json::json;
|
||||||
use deno_core::url::Url;
|
use deno_core::url::Url;
|
||||||
use deno_runtime::deno_fs::RealFs;
|
use deno_runtime::deno_fs::RealFs;
|
||||||
use deno_runtime::deno_node::PackageJson;
|
use deno_runtime::deno_node::PackageJson;
|
||||||
|
use deno_semver::Version;
|
||||||
use import_map::ImportMapWithDiagnostics;
|
use import_map::ImportMapWithDiagnostics;
|
||||||
|
use indexmap::IndexMap;
|
||||||
use pretty_assertions::assert_eq;
|
use pretty_assertions::assert_eq;
|
||||||
use test_util::testdata_path;
|
use test_util::testdata_path;
|
||||||
|
|
||||||
|
@ -436,6 +442,13 @@ mod tests {
|
||||||
let workspace_resolver = WorkspaceResolver::new_raw(
|
let workspace_resolver = WorkspaceResolver::new_raw(
|
||||||
Arc::new(ModuleSpecifier::from_directory_path(&cwd).unwrap()),
|
Arc::new(ModuleSpecifier::from_directory_path(&cwd).unwrap()),
|
||||||
Some(import_map),
|
Some(import_map),
|
||||||
|
vec![ResolverWorkspaceJsrPackage {
|
||||||
|
base: ModuleSpecifier::from_directory_path(cwd.join("jsr-package"))
|
||||||
|
.unwrap(),
|
||||||
|
name: "@denotest/example".to_string(),
|
||||||
|
version: Some(Version::parse_standard("1.0.0").unwrap()),
|
||||||
|
exports: IndexMap::from([(".".to_string(), "mod.ts".to_string())]),
|
||||||
|
}],
|
||||||
vec![Arc::new(package_json)],
|
vec![Arc::new(package_json)],
|
||||||
deno_config::workspace::PackageJsonDepResolution::Enabled,
|
deno_config::workspace::PackageJsonDepResolution::Enabled,
|
||||||
);
|
);
|
||||||
|
@ -458,6 +471,7 @@ import b from "./b.js";
|
||||||
import b2 from "./b";
|
import b2 from "./b";
|
||||||
import "./mod.ts";
|
import "./mod.ts";
|
||||||
import url from "url";
|
import url from "url";
|
||||||
|
import "@denotest/example";
|
||||||
// TODO: unfurl these to jsr
|
// TODO: unfurl these to jsr
|
||||||
// import "npm:@jsr/std__fs@1/file";
|
// import "npm:@jsr/std__fs@1/file";
|
||||||
// import "npm:@jsr/std__fs@1";
|
// import "npm:@jsr/std__fs@1";
|
||||||
|
@ -507,6 +521,7 @@ import b from "./b.ts";
|
||||||
import b2 from "./b.ts";
|
import b2 from "./b.ts";
|
||||||
import "./mod.ts";
|
import "./mod.ts";
|
||||||
import url from "node:url";
|
import url from "node:url";
|
||||||
|
import "jsr:@denotest/example@^1.0.0";
|
||||||
// TODO: unfurl these to jsr
|
// TODO: unfurl these to jsr
|
||||||
// import "npm:@jsr/std__fs@1/file";
|
// import "npm:@jsr/std__fs@1/file";
|
||||||
// import "npm:@jsr/std__fs@1";
|
// import "npm:@jsr/std__fs@1";
|
||||||
|
|
1
cli/tools/vendor/test.rs
vendored
1
cli/tools/vendor/test.rs
vendored
|
@ -300,6 +300,7 @@ fn build_resolver(
|
||||||
Arc::new(ModuleSpecifier::from_directory_path(root_dir).unwrap()),
|
Arc::new(ModuleSpecifier::from_directory_path(root_dir).unwrap()),
|
||||||
maybe_original_import_map,
|
maybe_original_import_map,
|
||||||
Vec::new(),
|
Vec::new(),
|
||||||
|
Vec::new(),
|
||||||
deno_config::workspace::PackageJsonDepResolution::Enabled,
|
deno_config::workspace::PackageJsonDepResolution::Enabled,
|
||||||
)),
|
)),
|
||||||
maybe_jsx_import_source_config,
|
maybe_jsx_import_source_config,
|
||||||
|
|
|
@ -14198,7 +14198,10 @@ fn lsp_deno_json_workspace_jsr_resolution() {
|
||||||
json!({
|
json!({
|
||||||
"contents": {
|
"contents": {
|
||||||
"kind": "markdown",
|
"kind": "markdown",
|
||||||
"value": format!("**Resolved Dependency**\n\n**Code**: jsr​:​@org/project1​@^1.0.0 (<{}project1/mod.ts>)\n", temp_dir.uri()),
|
"value": format!(
|
||||||
|
"**Resolved Dependency**\n\n**Code**: file​://{}\n",
|
||||||
|
temp_dir.uri().join("project1/mod.ts").unwrap().path(),
|
||||||
|
),
|
||||||
},
|
},
|
||||||
"range": {
|
"range": {
|
||||||
"start": { "line": 0, "character": 7 },
|
"start": { "line": 0, "character": 7 },
|
||||||
|
|
22
tests/specs/compile/workspace/__test__.jsonc
Normal file
22
tests/specs/compile/workspace/__test__.jsonc
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
{
|
||||||
|
"tempDir": true,
|
||||||
|
"steps": [{
|
||||||
|
"if": "unix",
|
||||||
|
"args": "compile --output main main.ts",
|
||||||
|
"output": "[WILDCARD]"
|
||||||
|
}, {
|
||||||
|
"if": "unix",
|
||||||
|
"commandName": "./main",
|
||||||
|
"args": [],
|
||||||
|
"output": "main.out"
|
||||||
|
}, {
|
||||||
|
"if": "windows",
|
||||||
|
"args": "compile --output main.exe main.ts",
|
||||||
|
"output": "[WILDCARD]"
|
||||||
|
}, {
|
||||||
|
"if": "windows",
|
||||||
|
"commandName": "./main.exe",
|
||||||
|
"args": [],
|
||||||
|
"output": "main.out"
|
||||||
|
}]
|
||||||
|
}
|
5
tests/specs/compile/workspace/add/deno.json
Normal file
5
tests/specs/compile/workspace/add/deno.json
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
{
|
||||||
|
"name": "@david/add",
|
||||||
|
"version": "0.0.1",
|
||||||
|
"exports": "./mod.ts"
|
||||||
|
}
|
6
tests/specs/compile/workspace/add/mod.test.ts
Normal file
6
tests/specs/compile/workspace/add/mod.test.ts
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
import { add } from "./mod.ts";
|
||||||
|
import { assertEquals } from "@std/assert";
|
||||||
|
|
||||||
|
Deno.test("add", () => {
|
||||||
|
assertEquals(add(1, 2), 3);
|
||||||
|
});
|
3
tests/specs/compile/workspace/add/mod.ts
Normal file
3
tests/specs/compile/workspace/add/mod.ts
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
export function add(a: number, b: number): number {
|
||||||
|
return a + b;
|
||||||
|
}
|
9
tests/specs/compile/workspace/deno.json
Normal file
9
tests/specs/compile/workspace/deno.json
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
{
|
||||||
|
"workspace": [
|
||||||
|
"./add",
|
||||||
|
"./subtract"
|
||||||
|
],
|
||||||
|
"imports": {
|
||||||
|
"@std/assert": "jsr:@std/assert@^1.0.2"
|
||||||
|
}
|
||||||
|
}
|
26
tests/specs/compile/workspace/deno.lock
Normal file
26
tests/specs/compile/workspace/deno.lock
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
{
|
||||||
|
"version": "3",
|
||||||
|
"packages": {
|
||||||
|
"specifiers": {
|
||||||
|
"jsr:@std/assert@^1.0.2": "jsr:@std/assert@1.0.2",
|
||||||
|
"jsr:@std/internal@^1.0.1": "jsr:@std/internal@1.0.1"
|
||||||
|
},
|
||||||
|
"jsr": {
|
||||||
|
"@std/assert@1.0.2": {
|
||||||
|
"integrity": "ccacec332958126deaceb5c63ff8b4eaf9f5ed0eac9feccf124110435e59e49c",
|
||||||
|
"dependencies": [
|
||||||
|
"jsr:@std/internal@^1.0.1"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"@std/internal@1.0.1": {
|
||||||
|
"integrity": "6f8c7544d06a11dd256c8d6ba54b11ed870aac6c5aeafff499892662c57673e6"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"remote": {},
|
||||||
|
"workspace": {
|
||||||
|
"dependencies": [
|
||||||
|
"jsr:@std/assert@^1.0.2"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
1
tests/specs/compile/workspace/main.out
Normal file
1
tests/specs/compile/workspace/main.out
Normal file
|
@ -0,0 +1 @@
|
||||||
|
-3
|
3
tests/specs/compile/workspace/main.ts
Normal file
3
tests/specs/compile/workspace/main.ts
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
import { subtract } from "@david/subtract";
|
||||||
|
|
||||||
|
console.log(subtract(2, 5));
|
5
tests/specs/compile/workspace/subtract/deno.json
Normal file
5
tests/specs/compile/workspace/subtract/deno.json
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
{
|
||||||
|
"name": "@david/subtract",
|
||||||
|
"version": "0.0.1",
|
||||||
|
"exports": "./mod.ts"
|
||||||
|
}
|
6
tests/specs/compile/workspace/subtract/mod.test.ts
Normal file
6
tests/specs/compile/workspace/subtract/mod.test.ts
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
import { subtract } from "./mod.ts";
|
||||||
|
import { assertEquals } from "@std/assert";
|
||||||
|
|
||||||
|
Deno.test("subtract", () => {
|
||||||
|
assertEquals(subtract(4, 2), 2);
|
||||||
|
});
|
5
tests/specs/compile/workspace/subtract/mod.ts
Normal file
5
tests/specs/compile/workspace/subtract/mod.ts
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
import { add } from "@david/add";
|
||||||
|
|
||||||
|
export function subtract(a: number, b: number): number {
|
||||||
|
return add(a, -b);
|
||||||
|
}
|
|
@ -1,11 +1,7 @@
|
||||||
[WILDCARD]Workspace config generated this import map {
|
[WILDCARD]Workspace config generated this import map {
|
||||||
"imports": {
|
"imports": {
|
||||||
"chalk": "npm:chalk",
|
"chalk": "npm:chalk",
|
||||||
"chalk/": "npm:/chalk/",
|
"chalk/": "npm:/chalk/"
|
||||||
"asdfasdfasdf": "jsr:asdfasdfasdf@^0.0.0",
|
|
||||||
"asdfasdfasdf/": "jsr:/asdfasdfasdf@^0.0.0/",
|
|
||||||
"qwerqwer": "jsr:qwerqwer@^0.0.0",
|
|
||||||
"qwerqwer/": "jsr:/qwerqwer@^0.0.0/"
|
|
||||||
},
|
},
|
||||||
"scopes": {
|
"scopes": {
|
||||||
"./bar/": {
|
"./bar/": {
|
||||||
|
|
Loading…
Reference in a new issue