diff options
Diffstat (limited to 'ext')
| -rw-r--r-- | ext/node/analyze.rs | 48 | ||||
| -rw-r--r-- | ext/node/errors.rs | 1 | ||||
| -rw-r--r-- | ext/node/lib.rs | 11 | ||||
| -rw-r--r-- | ext/node/ops/require.rs | 4 | ||||
| -rw-r--r-- | ext/node/package_json.rs | 9 |
5 files changed, 51 insertions, 22 deletions
diff --git a/ext/node/analyze.rs b/ext/node/analyze.rs index c9b23211e..994295578 100644 --- a/ext/node/analyze.rs +++ b/ext/node/analyze.rs @@ -193,7 +193,6 @@ impl<TCjsCodeAnalyzer: CjsCodeAnalyzer> NodeCodeTranslator<TCjsCodeAnalyzer> { } // We've got a bare specifier or maybe bare_specifier/blah.js" - let (package_specifier, package_subpath) = parse_specifier(specifier).unwrap(); @@ -205,14 +204,13 @@ impl<TCjsCodeAnalyzer: CjsCodeAnalyzer> NodeCodeTranslator<TCjsCodeAnalyzer> { )?; let package_json_path = module_dir.join("package.json"); - if self.fs.exists_sync(&package_json_path) { - let package_json = PackageJson::load( - &*self.fs, - &*self.npm_resolver, - permissions, - package_json_path.clone(), - )?; - + let package_json = PackageJson::load( + &*self.fs, + &*self.npm_resolver, + permissions, + package_json_path.clone(), + )?; + if package_json.exists { if let Some(exports) = &package_json.exports { return self.node_resolver.package_exports_resolve( &package_json_path, @@ -232,13 +230,13 @@ impl<TCjsCodeAnalyzer: CjsCodeAnalyzer> NodeCodeTranslator<TCjsCodeAnalyzer> { if self.fs.is_dir_sync(&d) { // subdir might have a package.json that specifies the entrypoint let package_json_path = d.join("package.json"); - if self.fs.exists_sync(&package_json_path) { - let package_json = PackageJson::load( - &*self.fs, - &*self.npm_resolver, - permissions, - package_json_path, - )?; + let package_json = PackageJson::load( + &*self.fs, + &*self.npm_resolver, + permissions, + package_json_path, + )?; + if package_json.exists { if let Some(main) = package_json.main(NodeModuleKind::Cjs) { return Ok(d.join(main).clean()); } @@ -253,6 +251,24 @@ impl<TCjsCodeAnalyzer: CjsCodeAnalyzer> NodeCodeTranslator<TCjsCodeAnalyzer> { return Ok(module_dir.join("index.js").clean()); } } + + // as a fallback, attempt to resolve it via the ancestor directories + let mut last = referrer_path.as_path(); + while let Some(parent) = last.parent() { + if !self.npm_resolver.in_npm_package_at_dir_path(parent) { + break; + } + let path = if parent.ends_with("node_modules") { + parent.join(specifier) + } else { + parent.join("node_modules").join(specifier) + }; + if let Ok(path) = self.file_extension_probe(path, &referrer_path) { + return Ok(path); + } + last = parent; + } + Err(not_found(specifier, &referrer_path)) } diff --git a/ext/node/errors.rs b/ext/node/errors.rs index e07a8347a..f34707c66 100644 --- a/ext/node/errors.rs +++ b/ext/node/errors.rs @@ -45,7 +45,6 @@ pub fn err_invalid_package_config( generic_error(msg) } -#[allow(unused)] pub fn err_module_not_found(path: &str, base: &str, typ: &str) -> AnyError { generic_error(format!( "[ERR_MODULE_NOT_FOUND] Cannot find {typ} \"{path}\" imported from \"{base}\"" diff --git a/ext/node/lib.rs b/ext/node/lib.rs index 7a43fc4d4..cb395ad9a 100644 --- a/ext/node/lib.rs +++ b/ext/node/lib.rs @@ -83,7 +83,16 @@ pub trait NpmResolver: std::fmt::Debug + MaybeSend + MaybeSync { fn in_npm_package(&self, specifier: &ModuleSpecifier) -> bool; - fn in_npm_package_at_path(&self, path: &Path) -> bool { + fn in_npm_package_at_dir_path(&self, path: &Path) -> bool { + let specifier = + match ModuleSpecifier::from_directory_path(path.to_path_buf().clean()) { + Ok(p) => p, + Err(_) => return false, + }; + self.in_npm_package(&specifier) + } + + fn in_npm_package_at_file_path(&self, path: &Path) -> bool { let specifier = match ModuleSpecifier::from_file_path(path.to_path_buf().clean()) { Ok(p) => p, diff --git a/ext/node/ops/require.rs b/ext/node/ops/require.rs index ceb771bf9..8010558c5 100644 --- a/ext/node/ops/require.rs +++ b/ext/node/ops/require.rs @@ -209,7 +209,7 @@ pub fn op_require_is_deno_dir_package( #[string] path: String, ) -> bool { let resolver = state.borrow::<NpmResolverRc>(); - resolver.in_npm_package_at_path(&PathBuf::from(path)) + resolver.in_npm_package_at_file_path(&PathBuf::from(path)) } #[op2] @@ -484,7 +484,7 @@ where let permissions = state.borrow::<P>(); let pkg_path = if npm_resolver - .in_npm_package_at_path(&PathBuf::from(&modules_path)) + .in_npm_package_at_file_path(&PathBuf::from(&modules_path)) && !uses_local_node_modules_dir { modules_path diff --git a/ext/node/package_json.rs b/ext/node/package_json.rs index 104c87390..035d26ed8 100644 --- a/ext/node/package_json.rs +++ b/ext/node/package_json.rs @@ -110,8 +110,13 @@ impl PackageJson { path: PathBuf, source: String, ) -> Result<PackageJson, AnyError> { - let package_json: Value = serde_json::from_str(&source) - .map_err(|err| anyhow::anyhow!("malformed package.json {}", err))?; + let package_json: Value = serde_json::from_str(&source).map_err(|err| { + anyhow::anyhow!( + "malformed package.json: {}\n at {}", + err, + path.display() + ) + })?; Self::load_from_value(path, package_json) } |
