1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-08 15:19:40 -05:00

refactor(core): remove "resolve_url_or_path_deprecated" (#18174)

Remove remaining usages of "resolve_url_or_path_deprecated" in favor
of "resolve_url_or_path" with explicit calls to
"std::env::current_dir()".

Towards landing https://github.com/denoland/deno/pull/15454
This commit is contained in:
Bartek Iwańczuk 2023-03-14 13:18:01 -04:00 committed by GitHub
parent 485e12062c
commit 1930c09b04
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 46 additions and 39 deletions

View file

@ -495,13 +495,18 @@ impl ProcState {
referrer: &str, referrer: &str,
permissions: &mut PermissionsContainer, permissions: &mut PermissionsContainer,
) -> Result<ModuleSpecifier, AnyError> { ) -> Result<ModuleSpecifier, AnyError> {
if let Ok(referrer) = deno_core::resolve_url_or_path_deprecated(referrer) { // TODO(bartlomieju): ideally we shouldn't need to call `current_dir()` on each
if self.npm_resolver.in_npm_package(&referrer) { // call - maybe it should be caller's responsibility to pass it as an arg?
let cwd = std::env::current_dir().context("Unable to get CWD")?;
let referrer_result = deno_core::resolve_url_or_path(referrer, &cwd);
if let Ok(referrer) = referrer_result.as_ref() {
if self.npm_resolver.in_npm_package(referrer) {
// we're in an npm package, so use node resolution // we're in an npm package, so use node resolution
return self return self
.handle_node_resolve_result(node::node_resolve( .handle_node_resolve_result(node::node_resolve(
specifier, specifier,
&referrer, referrer,
NodeResolutionMode::Execution, NodeResolutionMode::Execution,
&self.npm_resolver, &self.npm_resolver,
permissions, permissions,
@ -512,7 +517,7 @@ impl ProcState {
} }
let graph = self.graph_container.graph(); let graph = self.graph_container.graph();
let maybe_resolved = match graph.get(&referrer) { let maybe_resolved = match graph.get(referrer) {
Some(Module::Esm(module)) => { Some(Module::Esm(module)) => {
module.dependencies.get(specifier).map(|d| &d.maybe_code) module.dependencies.get(specifier).map(|d| &d.maybe_code)
} }
@ -565,9 +570,9 @@ impl ProcState {
// but sadly that's not the case due to missing APIs in V8. // but sadly that's not the case due to missing APIs in V8.
let is_repl = matches!(self.options.sub_command(), DenoSubcommand::Repl(_)); let is_repl = matches!(self.options.sub_command(), DenoSubcommand::Repl(_));
let referrer = if referrer.is_empty() && is_repl { let referrer = if referrer.is_empty() && is_repl {
deno_core::resolve_path("./$deno$repl.ts", self.options.initial_cwd())? deno_core::resolve_path("./$deno$repl.ts", &cwd)?
} else { } else {
deno_core::resolve_url_or_path_deprecated(referrer)? referrer_result?
}; };
// FIXME(bartlomieju): this is another hack way to provide NPM specifier // FIXME(bartlomieju): this is another hack way to provide NPM specifier

View file

@ -140,9 +140,12 @@ impl ModuleLoader for EmbeddedModuleLoader {
// Try to follow redirects when resolving. // Try to follow redirects when resolving.
let referrer = match self.eszip.get_module(referrer) { let referrer = match self.eszip.get_module(referrer) {
Some(eszip::Module { ref specifier, .. }) => { Some(eszip::Module { ref specifier, .. }) => {
deno_core::resolve_url_or_path_deprecated(specifier)? ModuleSpecifier::parse(specifier)?
}
None => {
let cwd = std::env::current_dir().context("Unable to get CWD")?;
deno_core::resolve_url_or_path(referrer, &cwd)?
} }
None => deno_core::resolve_url_or_path_deprecated(referrer)?,
}; };
self.maybe_import_map_resolver.as_ref().map_or_else( self.maybe_import_map_resolver.as_ref().map_or_else(

View file

@ -13,7 +13,7 @@ use deno_core::anyhow::Context;
use deno_core::error::AnyError; use deno_core::error::AnyError;
use deno_core::located_script_name; use deno_core::located_script_name;
use deno_core::op; use deno_core::op;
use deno_core::resolve_url_or_path_deprecated; use deno_core::resolve_url_or_path;
use deno_core::serde::Deserialize; use deno_core::serde::Deserialize;
use deno_core::serde::Deserializer; use deno_core::serde::Deserializer;
use deno_core::serde::Serialize; use deno_core::serde::Serialize;
@ -39,6 +39,7 @@ use once_cell::sync::Lazy;
use std::borrow::Cow; use std::borrow::Cow;
use std::collections::HashMap; use std::collections::HashMap;
use std::fmt; use std::fmt;
use std::path::Path;
use std::path::PathBuf; use std::path::PathBuf;
use std::sync::Arc; use std::sync::Arc;
@ -378,6 +379,7 @@ struct State {
maybe_npm_resolver: Option<NpmPackageResolver>, maybe_npm_resolver: Option<NpmPackageResolver>,
remapped_specifiers: HashMap<String, ModuleSpecifier>, remapped_specifiers: HashMap<String, ModuleSpecifier>,
root_map: HashMap<String, ModuleSpecifier>, root_map: HashMap<String, ModuleSpecifier>,
current_dir: PathBuf,
} }
impl State { impl State {
@ -388,6 +390,7 @@ impl State {
maybe_tsbuildinfo: Option<String>, maybe_tsbuildinfo: Option<String>,
root_map: HashMap<String, ModuleSpecifier>, root_map: HashMap<String, ModuleSpecifier>,
remapped_specifiers: HashMap<String, ModuleSpecifier>, remapped_specifiers: HashMap<String, ModuleSpecifier>,
current_dir: PathBuf,
) -> Self { ) -> Self {
State { State {
hash_data, hash_data,
@ -397,12 +400,16 @@ impl State {
maybe_response: None, maybe_response: None,
remapped_specifiers, remapped_specifiers,
root_map, root_map,
current_dir,
} }
} }
} }
fn normalize_specifier(specifier: &str) -> Result<ModuleSpecifier, AnyError> { fn normalize_specifier(
resolve_url_or_path_deprecated(specifier).map_err(|err| err.into()) specifier: &str,
current_dir: &Path,
) -> Result<ModuleSpecifier, AnyError> {
resolve_url_or_path(specifier, current_dir).map_err(|err| err.into())
} }
#[derive(Debug, Deserialize)] #[derive(Debug, Deserialize)]
@ -481,7 +488,7 @@ fn op_load(state: &mut OpState, args: Value) -> Result<Value, AnyError> {
let state = state.borrow_mut::<State>(); let state = state.borrow_mut::<State>();
let v: LoadArgs = serde_json::from_value(args) let v: LoadArgs = serde_json::from_value(args)
.context("Invalid request from JavaScript for \"op_load\".")?; .context("Invalid request from JavaScript for \"op_load\".")?;
let specifier = normalize_specifier(&v.specifier) let specifier = normalize_specifier(&v.specifier, &state.current_dir)
.context("Error converting a string module specifier for \"op_load\".")?; .context("Error converting a string module specifier for \"op_load\".")?;
let mut hash: Option<String> = None; let mut hash: Option<String> = None;
let mut media_type = MediaType::Unknown; let mut media_type = MediaType::Unknown;
@ -584,7 +591,7 @@ fn op_resolve(
} else if let Some(remapped_base) = state.root_map.get(&args.base) { } else if let Some(remapped_base) = state.root_map.get(&args.base) {
remapped_base.clone() remapped_base.clone()
} else { } else {
normalize_specifier(&args.base).context( normalize_specifier(&args.base, &state.current_dir).context(
"Error converting a string module specifier for \"op_resolve\".", "Error converting a string module specifier for \"op_resolve\".",
)? )?
}; };
@ -831,6 +838,9 @@ pub fn exec(request: Request) -> Result<Response, AnyError> {
request.maybe_tsbuildinfo.clone(), request.maybe_tsbuildinfo.clone(),
root_map.clone(), root_map.clone(),
remapped_specifiers.clone(), remapped_specifiers.clone(),
std::env::current_dir()
.context("Unable to get CWD")
.unwrap(),
)); ));
}) })
.build()], .build()],
@ -943,6 +953,9 @@ mod tests {
maybe_tsbuildinfo, maybe_tsbuildinfo,
HashMap::new(), HashMap::new(),
HashMap::new(), HashMap::new(),
std::env::current_dir()
.context("Unable to get CWD")
.unwrap(),
); );
let mut op_state = OpState::new(1); let mut op_state = OpState::new(1);
op_state.put(state); op_state.put(state);

View file

@ -72,7 +72,6 @@ pub use crate::module_specifier::resolve_import;
pub use crate::module_specifier::resolve_path; pub use crate::module_specifier::resolve_path;
pub use crate::module_specifier::resolve_url; pub use crate::module_specifier::resolve_url;
pub use crate::module_specifier::resolve_url_or_path; pub use crate::module_specifier::resolve_url_or_path;
pub use crate::module_specifier::resolve_url_or_path_deprecated;
pub use crate::module_specifier::ModuleResolutionError; pub use crate::module_specifier::ModuleResolutionError;
pub use crate::module_specifier::ModuleSpecifier; pub use crate::module_specifier::ModuleSpecifier;
pub use crate::module_specifier::DUMMY_SPECIFIER; pub use crate::module_specifier::DUMMY_SPECIFIER;

View file

@ -117,24 +117,6 @@ pub fn resolve_url(
Url::parse(url_str).map_err(ModuleResolutionError::InvalidUrl) Url::parse(url_str).map_err(ModuleResolutionError::InvalidUrl)
} }
/// Takes a string representing either an absolute URL or a file path,
/// as it may be passed to deno as a command line argument.
/// The string is interpreted as a URL if it starts with a valid URI scheme,
/// e.g. 'http:' or 'file:' or 'git+ssh:'. If not, it's interpreted as a
/// file path; if it is a relative path it's resolved relative to the current
/// working directory.
pub fn resolve_url_or_path_deprecated(
specifier: &str,
) -> Result<ModuleSpecifier, ModuleResolutionError> {
if specifier_has_uri_scheme(specifier) {
resolve_url(specifier)
} else {
let cwd = current_dir()
.map_err(|_| ModuleResolutionError::InvalidPath(specifier.into()))?;
resolve_path(specifier, &cwd)
}
}
/// Takes a string representing either an absolute URL or a file path, /// Takes a string representing either an absolute URL or a file path,
/// as it may be passed to deno as a command line argument. /// as it may be passed to deno as a command line argument.
/// The string is interpreted as a URL if it starts with a valid URI scheme, /// The string is interpreted as a URL if it starts with a valid URI scheme,
@ -361,7 +343,7 @@ mod tests {
} }
#[test] #[test]
fn test_resolve_url_or_path_deprecated() { fn test_resolve_url_or_path() {
// Absolute URL. // Absolute URL.
let mut tests: Vec<(&str, String)> = vec![ let mut tests: Vec<(&str, String)> = vec![
( (
@ -457,9 +439,7 @@ mod tests {
} }
for (specifier, expected_url) in tests { for (specifier, expected_url) in tests {
let url = resolve_url_or_path_deprecated(specifier) let url = resolve_url_or_path(specifier, &cwd).unwrap().to_string();
.unwrap()
.to_string();
assert_eq!(url, expected_url); assert_eq!(url, expected_url);
} }
} }
@ -479,7 +459,8 @@ mod tests {
} }
for (specifier, expected_err) in tests { for (specifier, expected_err) in tests {
let err = resolve_url_or_path_deprecated(specifier).unwrap_err(); let err =
resolve_url_or_path(specifier, &PathBuf::from("/")).unwrap_err();
assert_eq!(err, expected_err); assert_eq!(err, expected_err);
} }
} }

View file

@ -6,13 +6,14 @@ use crate::error::range_error;
use crate::error::type_error; use crate::error::type_error;
use crate::error::JsError; use crate::error::JsError;
use crate::ops_builtin::WasmStreamingResource; use crate::ops_builtin::WasmStreamingResource;
use crate::resolve_url_or_path_deprecated; use crate::resolve_url_or_path;
use crate::serde_v8::from_v8; use crate::serde_v8::from_v8;
use crate::source_map::apply_source_map as apply_source_map_; use crate::source_map::apply_source_map as apply_source_map_;
use crate::JsRealm; use crate::JsRealm;
use crate::JsRuntime; use crate::JsRuntime;
use crate::OpDecl; use crate::OpDecl;
use crate::ZeroCopyBuf; use crate::ZeroCopyBuf;
use anyhow::Context;
use anyhow::Error; use anyhow::Error;
use deno_ops::op; use deno_ops::op;
use serde::Deserialize; use serde::Deserialize;
@ -165,7 +166,12 @@ fn op_eval_context<'a>(
let source = v8::Local::<v8::String>::try_from(source.v8_value) let source = v8::Local::<v8::String>::try_from(source.v8_value)
.map_err(|_| type_error("Invalid source"))?; .map_err(|_| type_error("Invalid source"))?;
let specifier = match specifier { let specifier = match specifier {
Some(s) => resolve_url_or_path_deprecated(&s)?.to_string(), Some(s) => {
// TODO(bartlomieju): ideally we shouldn't need to call `current_dir()` on each
// call - maybe it should be caller's responsibility to pass fully resolved URL?
let cwd = std::env::current_dir().context("Unable to get CWD")?;
resolve_url_or_path(&s, &cwd)?.to_string()
}
None => crate::DUMMY_SPECIFIER.to_string(), None => crate::DUMMY_SPECIFIER.to_string(),
}; };
let specifier = v8::String::new(tc_scope, &specifier).unwrap(); let specifier = v8::String::new(tc_scope, &specifier).unwrap();