mirror of
https://github.com/denoland/deno.git
synced 2025-01-08 15:19:40 -05:00
refactor(core): add AssertedModuleType enum (#14501)
Co-authored-by: Luca Casonato <hello@lcas.dev>
This commit is contained in:
parent
ff49bd9e32
commit
bcd875030a
3 changed files with 199 additions and 130 deletions
|
@ -1,5 +1,5 @@
|
||||||
[WILDCARD]
|
[WILDCARD]
|
||||||
error: Uncaught (in promise) TypeError: Expected a "JavaScript" module but loaded a "JSON" module.
|
error: Uncaught (in promise) TypeError: Expected a "JavaScriptOrWasm" module but loaded a "JSON" module.
|
||||||
const data = await import("./data.json");
|
const data = await import("./data.json");
|
||||||
^
|
^
|
||||||
at async [WILDCARD]dynamic_error.ts:1:14
|
at async [WILDCARD]dynamic_error.ts:1:14
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
use crate::error::is_instance_of_error;
|
use crate::error::is_instance_of_error;
|
||||||
use crate::error::JsError;
|
use crate::error::JsError;
|
||||||
use crate::modules::get_module_type_from_assertions;
|
use crate::modules::get_asserted_module_type_from_assertions;
|
||||||
use crate::modules::parse_import_assertions;
|
use crate::modules::parse_import_assertions;
|
||||||
use crate::modules::validate_import_assertions;
|
use crate::modules::validate_import_assertions;
|
||||||
use crate::modules::ImportAssertionsKind;
|
use crate::modules::ImportAssertionsKind;
|
||||||
|
@ -343,7 +343,8 @@ pub extern "C" fn host_import_module_dynamically_callback(
|
||||||
resolver.reject(tc_scope, e);
|
resolver.reject(tc_scope, e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
let module_type = get_module_type_from_assertions(&assertions);
|
let asserted_module_type =
|
||||||
|
get_asserted_module_type_from_assertions(&assertions);
|
||||||
|
|
||||||
let resolver_handle = v8::Global::new(scope, resolver);
|
let resolver_handle = v8::Global::new(scope, resolver);
|
||||||
{
|
{
|
||||||
|
@ -358,7 +359,7 @@ pub extern "C" fn host_import_module_dynamically_callback(
|
||||||
module_map_rc,
|
module_map_rc,
|
||||||
&specifier_str,
|
&specifier_str,
|
||||||
&referrer_name_str,
|
&referrer_name_str,
|
||||||
module_type,
|
asserted_module_type,
|
||||||
resolver_handle,
|
resolver_handle,
|
||||||
);
|
);
|
||||||
state_rc.borrow_mut().notify_new_dynamic_import();
|
state_rc.borrow_mut().notify_new_dynamic_import();
|
||||||
|
|
320
core/modules.rs
320
core/modules.rs
|
@ -100,19 +100,19 @@ pub(crate) fn parse_import_assertions(
|
||||||
assertions
|
assertions
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn get_module_type_from_assertions(
|
pub(crate) fn get_asserted_module_type_from_assertions(
|
||||||
assertions: &HashMap<String, String>,
|
assertions: &HashMap<String, String>,
|
||||||
) -> ModuleType {
|
) -> AssertedModuleType {
|
||||||
assertions
|
assertions
|
||||||
.get("type")
|
.get("type")
|
||||||
.map(|ty| {
|
.map(|ty| {
|
||||||
if ty == "json" {
|
if ty == "json" {
|
||||||
ModuleType::Json
|
AssertedModuleType::Json
|
||||||
} else {
|
} else {
|
||||||
ModuleType::JavaScript
|
AssertedModuleType::JavaScriptOrWasm
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.unwrap_or(ModuleType::JavaScript)
|
.unwrap_or(AssertedModuleType::JavaScriptOrWasm)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clippy thinks the return value doesn't need to be an Option, it's unaware
|
// Clippy thinks the return value doesn't need to be an Option, it's unaware
|
||||||
|
@ -337,7 +337,7 @@ enum LoadInit {
|
||||||
Side(String),
|
Side(String),
|
||||||
/// Dynamic import specifier with referrer and expected
|
/// Dynamic import specifier with referrer and expected
|
||||||
/// module type (which is determined by import assertion).
|
/// module type (which is determined by import assertion).
|
||||||
DynamicImport(String, String, ModuleType),
|
DynamicImport(String, String, AssertedModuleType),
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Eq, PartialEq)]
|
#[derive(Debug, Eq, PartialEq)]
|
||||||
|
@ -353,6 +353,7 @@ pub(crate) struct RecursiveModuleLoad {
|
||||||
pub id: ModuleLoadId,
|
pub id: ModuleLoadId,
|
||||||
pub root_module_id: Option<ModuleId>,
|
pub root_module_id: Option<ModuleId>,
|
||||||
init: LoadInit,
|
init: LoadInit,
|
||||||
|
root_asserted_module_type: Option<AssertedModuleType>,
|
||||||
root_module_type: Option<ModuleType>,
|
root_module_type: Option<ModuleType>,
|
||||||
state: LoadState,
|
state: LoadState,
|
||||||
module_map_rc: Rc<RefCell<ModuleMap>>,
|
module_map_rc: Rc<RefCell<ModuleMap>>,
|
||||||
|
@ -383,14 +384,14 @@ impl RecursiveModuleLoad {
|
||||||
fn dynamic_import(
|
fn dynamic_import(
|
||||||
specifier: &str,
|
specifier: &str,
|
||||||
referrer: &str,
|
referrer: &str,
|
||||||
module_type: ModuleType,
|
asserted_module_type: AssertedModuleType,
|
||||||
module_map_rc: Rc<RefCell<ModuleMap>>,
|
module_map_rc: Rc<RefCell<ModuleMap>>,
|
||||||
) -> Self {
|
) -> Self {
|
||||||
Self::new(
|
Self::new(
|
||||||
LoadInit::DynamicImport(
|
LoadInit::DynamicImport(
|
||||||
specifier.to_string(),
|
specifier.to_string(),
|
||||||
referrer.to_string(),
|
referrer.to_string(),
|
||||||
module_type,
|
asserted_module_type,
|
||||||
),
|
),
|
||||||
module_map_rc,
|
module_map_rc,
|
||||||
)
|
)
|
||||||
|
@ -405,13 +406,14 @@ impl RecursiveModuleLoad {
|
||||||
};
|
};
|
||||||
let op_state = module_map_rc.borrow().op_state.clone();
|
let op_state = module_map_rc.borrow().op_state.clone();
|
||||||
let loader = module_map_rc.borrow().loader.clone();
|
let loader = module_map_rc.borrow().loader.clone();
|
||||||
let expected_module_type = match init {
|
let asserted_module_type = match init {
|
||||||
LoadInit::DynamicImport(_, _, module_type) => module_type,
|
LoadInit::DynamicImport(_, _, module_type) => module_type,
|
||||||
_ => ModuleType::JavaScript,
|
_ => AssertedModuleType::JavaScriptOrWasm,
|
||||||
};
|
};
|
||||||
let mut load = Self {
|
let mut load = Self {
|
||||||
id,
|
id,
|
||||||
root_module_id: None,
|
root_module_id: None,
|
||||||
|
root_asserted_module_type: None,
|
||||||
root_module_type: None,
|
root_module_type: None,
|
||||||
init,
|
init,
|
||||||
state: LoadState::Init,
|
state: LoadState::Init,
|
||||||
|
@ -426,10 +428,17 @@ impl RecursiveModuleLoad {
|
||||||
if let Ok(root_specifier) = load.resolve_root() {
|
if let Ok(root_specifier) = load.resolve_root() {
|
||||||
if let Some(module_id) = module_map_rc
|
if let Some(module_id) = module_map_rc
|
||||||
.borrow()
|
.borrow()
|
||||||
.get_id(root_specifier.as_str(), expected_module_type)
|
.get_id(root_specifier.as_str(), asserted_module_type)
|
||||||
{
|
{
|
||||||
load.root_module_id = Some(module_id);
|
load.root_module_id = Some(module_id);
|
||||||
load.root_module_type = Some(expected_module_type);
|
load.root_asserted_module_type = Some(asserted_module_type);
|
||||||
|
load.root_module_type = Some(
|
||||||
|
module_map_rc
|
||||||
|
.borrow()
|
||||||
|
.get_info_by_id(&module_id)
|
||||||
|
.unwrap()
|
||||||
|
.module_type,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
load
|
load
|
||||||
|
@ -493,10 +502,11 @@ impl RecursiveModuleLoad {
|
||||||
module_request: &ModuleRequest,
|
module_request: &ModuleRequest,
|
||||||
module_source: &ModuleSource,
|
module_source: &ModuleSource,
|
||||||
) -> Result<(), ModuleError> {
|
) -> Result<(), ModuleError> {
|
||||||
if module_request.expected_module_type != module_source.module_type {
|
let expected_asserted_module_type = module_source.module_type.into();
|
||||||
|
if module_request.asserted_module_type != expected_asserted_module_type {
|
||||||
return Err(ModuleError::Other(generic_error(format!(
|
return Err(ModuleError::Other(generic_error(format!(
|
||||||
"Expected a \"{}\" module but loaded a \"{}\" module.",
|
"Expected a \"{}\" module but loaded a \"{}\" module.",
|
||||||
module_request.expected_module_type, module_source.module_type,
|
module_request.asserted_module_type, module_source.module_type,
|
||||||
))));
|
))));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -505,14 +515,14 @@ impl RecursiveModuleLoad {
|
||||||
if module_source.module_url_specified != module_source.module_url_found {
|
if module_source.module_url_specified != module_source.module_url_found {
|
||||||
self.module_map_rc.borrow_mut().alias(
|
self.module_map_rc.borrow_mut().alias(
|
||||||
&module_source.module_url_specified,
|
&module_source.module_url_specified,
|
||||||
module_source.module_type,
|
expected_asserted_module_type,
|
||||||
&module_source.module_url_found,
|
&module_source.module_url_found,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
let maybe_module_id = self
|
let maybe_module_id = self.module_map_rc.borrow().get_id(
|
||||||
.module_map_rc
|
&module_source.module_url_found,
|
||||||
.borrow()
|
expected_asserted_module_type,
|
||||||
.get_id(&module_source.module_url_found, module_source.module_type);
|
);
|
||||||
let module_id = match maybe_module_id {
|
let module_id = match maybe_module_id {
|
||||||
Some(id) => {
|
Some(id) => {
|
||||||
debug!(
|
debug!(
|
||||||
|
@ -562,7 +572,7 @@ impl RecursiveModuleLoad {
|
||||||
if !self.visited.contains(&module_request) {
|
if !self.visited.contains(&module_request) {
|
||||||
if let Some(module_id) = self.module_map_rc.borrow().get_id(
|
if let Some(module_id) = self.module_map_rc.borrow().get_id(
|
||||||
module_request.specifier.as_str(),
|
module_request.specifier.as_str(),
|
||||||
module_request.expected_module_type,
|
module_request.asserted_module_type,
|
||||||
) {
|
) {
|
||||||
already_registered.push_back((module_id, module_request.clone()));
|
already_registered.push_back((module_id, module_request.clone()));
|
||||||
} else {
|
} else {
|
||||||
|
@ -590,7 +600,7 @@ impl RecursiveModuleLoad {
|
||||||
// Update `self.state` however applicable.
|
// Update `self.state` however applicable.
|
||||||
if self.state == LoadState::LoadingRoot {
|
if self.state == LoadState::LoadingRoot {
|
||||||
self.root_module_id = Some(module_id);
|
self.root_module_id = Some(module_id);
|
||||||
self.root_module_type = Some(module_source.module_type);
|
self.root_asserted_module_type = Some(module_source.module_type.into());
|
||||||
self.state = LoadState::LoadingImports;
|
self.state = LoadState::LoadingImports;
|
||||||
}
|
}
|
||||||
if self.pending.is_empty() {
|
if self.pending.is_empty() {
|
||||||
|
@ -625,10 +635,11 @@ impl Stream for RecursiveModuleLoad {
|
||||||
// like the bottom of `RecursiveModuleLoad::register_and_recurse()`.
|
// like the bottom of `RecursiveModuleLoad::register_and_recurse()`.
|
||||||
// But the module map cannot be borrowed here. Instead fake a load
|
// But the module map cannot be borrowed here. Instead fake a load
|
||||||
// event so it gets passed to that function and recursed eventually.
|
// event so it gets passed to that function and recursed eventually.
|
||||||
|
let asserted_module_type = inner.root_asserted_module_type.unwrap();
|
||||||
let module_type = inner.root_module_type.unwrap();
|
let module_type = inner.root_module_type.unwrap();
|
||||||
let module_request = ModuleRequest {
|
let module_request = ModuleRequest {
|
||||||
specifier: module_specifier.clone(),
|
specifier: module_specifier.clone(),
|
||||||
expected_module_type: module_type,
|
asserted_module_type,
|
||||||
};
|
};
|
||||||
let module_source = ModuleSource {
|
let module_source = ModuleSource {
|
||||||
module_url_specified: module_specifier.to_string(),
|
module_url_specified: module_specifier.to_string(),
|
||||||
|
@ -646,13 +657,13 @@ impl Stream for RecursiveModuleLoad {
|
||||||
}
|
}
|
||||||
_ => None,
|
_ => None,
|
||||||
};
|
};
|
||||||
let expected_module_type = match inner.init {
|
let asserted_module_type = match inner.init {
|
||||||
LoadInit::DynamicImport(_, _, module_type) => module_type,
|
LoadInit::DynamicImport(_, _, module_type) => module_type,
|
||||||
_ => ModuleType::JavaScript,
|
_ => AssertedModuleType::JavaScriptOrWasm,
|
||||||
};
|
};
|
||||||
let module_request = ModuleRequest {
|
let module_request = ModuleRequest {
|
||||||
specifier: module_specifier.clone(),
|
specifier: module_specifier.clone(),
|
||||||
expected_module_type,
|
asserted_module_type,
|
||||||
};
|
};
|
||||||
let loader = inner.loader.clone();
|
let loader = inner.loader.clone();
|
||||||
let is_dynamic_import = inner.is_dynamic_import();
|
let is_dynamic_import = inner.is_dynamic_import();
|
||||||
|
@ -680,13 +691,38 @@ impl Stream for RecursiveModuleLoad {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Describes what is the expected type of module, usually
|
#[derive(Clone, Copy, Debug, Eq, Hash, PartialEq)]
|
||||||
/// it's `ModuleType::JavaScript`, but if there were import assertions
|
pub(crate) enum AssertedModuleType {
|
||||||
/// it might be `ModuleType::Json`.
|
JavaScriptOrWasm,
|
||||||
|
Json,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<ModuleType> for AssertedModuleType {
|
||||||
|
fn from(module_type: ModuleType) -> AssertedModuleType {
|
||||||
|
match module_type {
|
||||||
|
ModuleType::JavaScript => AssertedModuleType::JavaScriptOrWasm,
|
||||||
|
ModuleType::Json => AssertedModuleType::Json,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl std::fmt::Display for AssertedModuleType {
|
||||||
|
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
|
||||||
|
match self {
|
||||||
|
Self::JavaScriptOrWasm => write!(f, "JavaScriptOrWasm"),
|
||||||
|
Self::Json => write!(f, "JSON"),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Describes a request for a module as parsed from the source code.
|
||||||
|
/// Usually executable (`JavaScriptOrWasm`) is used, except when an
|
||||||
|
/// import assertions explicitly constrains an import to JSON, in
|
||||||
|
/// which case this will have a `AssertedModuleType::Json`.
|
||||||
#[derive(Clone, Debug, Eq, Hash, PartialEq)]
|
#[derive(Clone, Debug, Eq, Hash, PartialEq)]
|
||||||
pub(crate) struct ModuleRequest {
|
pub(crate) struct ModuleRequest {
|
||||||
pub specifier: ModuleSpecifier,
|
pub specifier: ModuleSpecifier,
|
||||||
pub expected_module_type: ModuleType,
|
pub asserted_module_type: AssertedModuleType,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) struct ModuleInfo {
|
pub(crate) struct ModuleInfo {
|
||||||
|
@ -721,7 +757,7 @@ pub(crate) struct ModuleMap {
|
||||||
ids_by_handle: HashMap<v8::Global<v8::Module>, ModuleId>,
|
ids_by_handle: HashMap<v8::Global<v8::Module>, ModuleId>,
|
||||||
handles_by_id: HashMap<ModuleId, v8::Global<v8::Module>>,
|
handles_by_id: HashMap<ModuleId, v8::Global<v8::Module>>,
|
||||||
info: HashMap<ModuleId, ModuleInfo>,
|
info: HashMap<ModuleId, ModuleInfo>,
|
||||||
by_name: HashMap<(String, ModuleType), SymbolicModule>,
|
by_name: HashMap<(String, AssertedModuleType), SymbolicModule>,
|
||||||
next_module_id: ModuleId,
|
next_module_id: ModuleId,
|
||||||
next_load_id: ModuleLoadId,
|
next_load_id: ModuleLoadId,
|
||||||
|
|
||||||
|
@ -763,11 +799,16 @@ impl ModuleMap {
|
||||||
|
|
||||||
/// Get module id, following all aliases in case of module specifier
|
/// Get module id, following all aliases in case of module specifier
|
||||||
/// that had been redirected.
|
/// that had been redirected.
|
||||||
fn get_id(&self, name: &str, module_type: ModuleType) -> Option<ModuleId> {
|
fn get_id(
|
||||||
|
&self,
|
||||||
|
name: &str,
|
||||||
|
asserted_module_type: AssertedModuleType,
|
||||||
|
) -> Option<ModuleId> {
|
||||||
let mut mod_name = name;
|
let mut mod_name = name;
|
||||||
loop {
|
loop {
|
||||||
let symbolic_module =
|
let symbolic_module = self
|
||||||
self.by_name.get(&(mod_name.to_string(), module_type))?;
|
.by_name
|
||||||
|
.get(&(mod_name.to_string(), asserted_module_type))?;
|
||||||
match symbolic_module {
|
match symbolic_module {
|
||||||
SymbolicModule::Alias(target) => {
|
SymbolicModule::Alias(target) => {
|
||||||
mod_name = target;
|
mod_name = target;
|
||||||
|
@ -883,10 +924,11 @@ impl ModuleMap {
|
||||||
Ok(s) => s,
|
Ok(s) => s,
|
||||||
Err(e) => return Err(ModuleError::Other(e)),
|
Err(e) => return Err(ModuleError::Other(e)),
|
||||||
};
|
};
|
||||||
let expected_module_type = get_module_type_from_assertions(&assertions);
|
let asserted_module_type =
|
||||||
|
get_asserted_module_type_from_assertions(&assertions);
|
||||||
let request = ModuleRequest {
|
let request = ModuleRequest {
|
||||||
specifier: module_specifier,
|
specifier: module_specifier,
|
||||||
expected_module_type,
|
asserted_module_type,
|
||||||
};
|
};
|
||||||
requests.push(request);
|
requests.push(request);
|
||||||
}
|
}
|
||||||
|
@ -924,9 +966,10 @@ impl ModuleMap {
|
||||||
) -> ModuleId {
|
) -> ModuleId {
|
||||||
let id = self.next_module_id;
|
let id = self.next_module_id;
|
||||||
self.next_module_id += 1;
|
self.next_module_id += 1;
|
||||||
self
|
self.by_name.insert(
|
||||||
.by_name
|
(name.to_string(), module_type.into()),
|
||||||
.insert((name.to_string(), module_type), SymbolicModule::Mod(id));
|
SymbolicModule::Mod(id),
|
||||||
|
);
|
||||||
self.handles_by_id.insert(id, handle.clone());
|
self.handles_by_id.insert(id, handle.clone());
|
||||||
self.ids_by_handle.insert(handle, id);
|
self.ids_by_handle.insert(handle, id);
|
||||||
self.info.insert(
|
self.info.insert(
|
||||||
|
@ -950,26 +993,35 @@ impl ModuleMap {
|
||||||
fn is_registered(
|
fn is_registered(
|
||||||
&self,
|
&self,
|
||||||
specifier: &ModuleSpecifier,
|
specifier: &ModuleSpecifier,
|
||||||
module_type: ModuleType,
|
asserted_module_type: AssertedModuleType,
|
||||||
) -> bool {
|
) -> bool {
|
||||||
if let Some(id) = self.get_id(specifier.as_str(), module_type) {
|
if let Some(id) = self.get_id(specifier.as_str(), asserted_module_type) {
|
||||||
let info = self.get_info_by_id(&id).unwrap();
|
let info = self.get_info_by_id(&id).unwrap();
|
||||||
return info.module_type == module_type;
|
return asserted_module_type == info.module_type.into();
|
||||||
}
|
}
|
||||||
|
|
||||||
false
|
false
|
||||||
}
|
}
|
||||||
|
|
||||||
fn alias(&mut self, name: &str, module_type: ModuleType, target: &str) {
|
fn alias(
|
||||||
|
&mut self,
|
||||||
|
name: &str,
|
||||||
|
asserted_module_type: AssertedModuleType,
|
||||||
|
target: &str,
|
||||||
|
) {
|
||||||
self.by_name.insert(
|
self.by_name.insert(
|
||||||
(name.to_string(), module_type),
|
(name.to_string(), asserted_module_type),
|
||||||
SymbolicModule::Alias(target.to_string()),
|
SymbolicModule::Alias(target.to_string()),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
fn is_alias(&self, name: &str, module_type: ModuleType) -> bool {
|
fn is_alias(
|
||||||
let cond = self.by_name.get(&(name.to_string(), module_type));
|
&self,
|
||||||
|
name: &str,
|
||||||
|
asserted_module_type: AssertedModuleType,
|
||||||
|
) -> bool {
|
||||||
|
let cond = self.by_name.get(&(name.to_string(), asserted_module_type));
|
||||||
matches!(cond, Some(SymbolicModule::Alias(_)))
|
matches!(cond, Some(SymbolicModule::Alias(_)))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1018,13 +1070,13 @@ impl ModuleMap {
|
||||||
module_map_rc: Rc<RefCell<ModuleMap>>,
|
module_map_rc: Rc<RefCell<ModuleMap>>,
|
||||||
specifier: &str,
|
specifier: &str,
|
||||||
referrer: &str,
|
referrer: &str,
|
||||||
module_type: ModuleType,
|
asserted_module_type: AssertedModuleType,
|
||||||
resolver_handle: v8::Global<v8::PromiseResolver>,
|
resolver_handle: v8::Global<v8::PromiseResolver>,
|
||||||
) {
|
) {
|
||||||
let load = RecursiveModuleLoad::dynamic_import(
|
let load = RecursiveModuleLoad::dynamic_import(
|
||||||
specifier,
|
specifier,
|
||||||
referrer,
|
referrer,
|
||||||
module_type,
|
asserted_module_type,
|
||||||
module_map_rc.clone(),
|
module_map_rc.clone(),
|
||||||
);
|
);
|
||||||
module_map_rc
|
module_map_rc
|
||||||
|
@ -1039,7 +1091,7 @@ impl ModuleMap {
|
||||||
Ok(module_specifier) => {
|
Ok(module_specifier) => {
|
||||||
if module_map_rc
|
if module_map_rc
|
||||||
.borrow()
|
.borrow()
|
||||||
.is_registered(&module_specifier, module_type)
|
.is_registered(&module_specifier, asserted_module_type)
|
||||||
{
|
{
|
||||||
async move { (load.id, Ok(load)) }.boxed_local()
|
async move { (load.id, Ok(load)) }.boxed_local()
|
||||||
} else {
|
} else {
|
||||||
|
@ -1073,7 +1125,8 @@ impl ModuleMap {
|
||||||
.resolve(specifier, referrer, false)
|
.resolve(specifier, referrer, false)
|
||||||
.expect("Module should have been already resolved");
|
.expect("Module should have been already resolved");
|
||||||
|
|
||||||
let module_type = get_module_type_from_assertions(&import_assertions);
|
let module_type =
|
||||||
|
get_asserted_module_type_from_assertions(&import_assertions);
|
||||||
|
|
||||||
if let Some(id) = self.get_id(resolved_specifier.as_str(), module_type) {
|
if let Some(id) = self.get_id(resolved_specifier.as_str(), module_type) {
|
||||||
if let Some(handle) = self.get_handle(id) {
|
if let Some(handle) = self.get_handle(id) {
|
||||||
|
@ -1342,28 +1395,28 @@ import "/a.js";
|
||||||
let modules = module_map_rc.borrow();
|
let modules = module_map_rc.borrow();
|
||||||
|
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
modules.get_id("file:///a.js", ModuleType::JavaScript),
|
modules.get_id("file:///a.js", AssertedModuleType::JavaScriptOrWasm),
|
||||||
Some(a_id)
|
Some(a_id)
|
||||||
);
|
);
|
||||||
let b_id = modules
|
let b_id = modules
|
||||||
.get_id("file:///b.js", ModuleType::JavaScript)
|
.get_id("file:///b.js", AssertedModuleType::JavaScriptOrWasm)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let c_id = modules
|
let c_id = modules
|
||||||
.get_id("file:///c.js", ModuleType::JavaScript)
|
.get_id("file:///c.js", AssertedModuleType::JavaScriptOrWasm)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let d_id = modules
|
let d_id = modules
|
||||||
.get_id("file:///d.js", ModuleType::JavaScript)
|
.get_id("file:///d.js", AssertedModuleType::JavaScriptOrWasm)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
modules.get_requested_modules(a_id),
|
modules.get_requested_modules(a_id),
|
||||||
Some(&vec![
|
Some(&vec![
|
||||||
ModuleRequest {
|
ModuleRequest {
|
||||||
specifier: resolve_url("file:///b.js").unwrap(),
|
specifier: resolve_url("file:///b.js").unwrap(),
|
||||||
expected_module_type: ModuleType::JavaScript,
|
asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
|
||||||
},
|
},
|
||||||
ModuleRequest {
|
ModuleRequest {
|
||||||
specifier: resolve_url("file:///c.js").unwrap(),
|
specifier: resolve_url("file:///c.js").unwrap(),
|
||||||
expected_module_type: ModuleType::JavaScript,
|
asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
|
||||||
},
|
},
|
||||||
])
|
])
|
||||||
);
|
);
|
||||||
|
@ -1371,14 +1424,14 @@ import "/a.js";
|
||||||
modules.get_requested_modules(b_id),
|
modules.get_requested_modules(b_id),
|
||||||
Some(&vec![ModuleRequest {
|
Some(&vec![ModuleRequest {
|
||||||
specifier: resolve_url("file:///c.js").unwrap(),
|
specifier: resolve_url("file:///c.js").unwrap(),
|
||||||
expected_module_type: ModuleType::JavaScript,
|
asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
|
||||||
},])
|
},])
|
||||||
);
|
);
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
modules.get_requested_modules(c_id),
|
modules.get_requested_modules(c_id),
|
||||||
Some(&vec![ModuleRequest {
|
Some(&vec![ModuleRequest {
|
||||||
specifier: resolve_url("file:///d.js").unwrap(),
|
specifier: resolve_url("file:///d.js").unwrap(),
|
||||||
expected_module_type: ModuleType::JavaScript,
|
asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
|
||||||
},])
|
},])
|
||||||
);
|
);
|
||||||
assert_eq!(modules.get_requested_modules(d_id), Some(&vec![]));
|
assert_eq!(modules.get_requested_modules(d_id), Some(&vec![]));
|
||||||
|
@ -1476,7 +1529,7 @@ import "/a.js";
|
||||||
imports,
|
imports,
|
||||||
Some(&vec![ModuleRequest {
|
Some(&vec![ModuleRequest {
|
||||||
specifier: resolve_url("file:///b.js").unwrap(),
|
specifier: resolve_url("file:///b.js").unwrap(),
|
||||||
expected_module_type: ModuleType::JavaScript,
|
asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
|
||||||
},])
|
},])
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -1581,7 +1634,7 @@ import "/a.js";
|
||||||
imports,
|
imports,
|
||||||
Some(&vec![ModuleRequest {
|
Some(&vec![ModuleRequest {
|
||||||
specifier: resolve_url("file:///b.json").unwrap(),
|
specifier: resolve_url("file:///b.json").unwrap(),
|
||||||
expected_module_type: ModuleType::Json,
|
asserted_module_type: AssertedModuleType::Json,
|
||||||
},])
|
},])
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -1900,18 +1953,19 @@ import "/a.js";
|
||||||
let modules = module_map_rc.borrow();
|
let modules = module_map_rc.borrow();
|
||||||
|
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
modules.get_id("file:///circular1.js", ModuleType::JavaScript),
|
modules
|
||||||
|
.get_id("file:///circular1.js", AssertedModuleType::JavaScriptOrWasm),
|
||||||
Some(circular1_id)
|
Some(circular1_id)
|
||||||
);
|
);
|
||||||
let circular2_id = modules
|
let circular2_id = modules
|
||||||
.get_id("file:///circular2.js", ModuleType::JavaScript)
|
.get_id("file:///circular2.js", AssertedModuleType::JavaScriptOrWasm)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
modules.get_requested_modules(circular1_id),
|
modules.get_requested_modules(circular1_id),
|
||||||
Some(&vec![ModuleRequest {
|
Some(&vec![ModuleRequest {
|
||||||
specifier: resolve_url("file:///circular2.js").unwrap(),
|
specifier: resolve_url("file:///circular2.js").unwrap(),
|
||||||
expected_module_type: ModuleType::JavaScript,
|
asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
|
||||||
}])
|
}])
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -1919,26 +1973,26 @@ import "/a.js";
|
||||||
modules.get_requested_modules(circular2_id),
|
modules.get_requested_modules(circular2_id),
|
||||||
Some(&vec![ModuleRequest {
|
Some(&vec![ModuleRequest {
|
||||||
specifier: resolve_url("file:///circular3.js").unwrap(),
|
specifier: resolve_url("file:///circular3.js").unwrap(),
|
||||||
expected_module_type: ModuleType::JavaScript,
|
asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
|
||||||
}])
|
}])
|
||||||
);
|
);
|
||||||
|
|
||||||
assert!(modules
|
assert!(modules
|
||||||
.get_id("file:///circular3.js", ModuleType::JavaScript)
|
.get_id("file:///circular3.js", AssertedModuleType::JavaScriptOrWasm)
|
||||||
.is_some());
|
.is_some());
|
||||||
let circular3_id = modules
|
let circular3_id = modules
|
||||||
.get_id("file:///circular3.js", ModuleType::JavaScript)
|
.get_id("file:///circular3.js", AssertedModuleType::JavaScriptOrWasm)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
modules.get_requested_modules(circular3_id),
|
modules.get_requested_modules(circular3_id),
|
||||||
Some(&vec![
|
Some(&vec![
|
||||||
ModuleRequest {
|
ModuleRequest {
|
||||||
specifier: resolve_url("file:///circular1.js").unwrap(),
|
specifier: resolve_url("file:///circular1.js").unwrap(),
|
||||||
expected_module_type: ModuleType::JavaScript,
|
asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
|
||||||
},
|
},
|
||||||
ModuleRequest {
|
ModuleRequest {
|
||||||
specifier: resolve_url("file:///circular2.js").unwrap(),
|
specifier: resolve_url("file:///circular2.js").unwrap(),
|
||||||
expected_module_type: ModuleType::JavaScript,
|
asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
|
||||||
}
|
}
|
||||||
])
|
])
|
||||||
);
|
);
|
||||||
|
@ -1957,61 +2011,72 @@ import "/a.js";
|
||||||
..Default::default()
|
..Default::default()
|
||||||
});
|
});
|
||||||
|
|
||||||
let fut =
|
let fut = async move {
|
||||||
async move {
|
let spec = resolve_url("file:///redirect1.js").unwrap();
|
||||||
let spec = resolve_url("file:///redirect1.js").unwrap();
|
let result = runtime.load_main_module(&spec, None).await;
|
||||||
let result = runtime.load_main_module(&spec, None).await;
|
assert!(result.is_ok());
|
||||||
assert!(result.is_ok());
|
let redirect1_id = result.unwrap();
|
||||||
let redirect1_id = result.unwrap();
|
let _ = runtime.mod_evaluate(redirect1_id);
|
||||||
let _ = runtime.mod_evaluate(redirect1_id);
|
runtime.run_event_loop(false).await.unwrap();
|
||||||
runtime.run_event_loop(false).await.unwrap();
|
let l = loads.lock();
|
||||||
let l = loads.lock();
|
assert_eq!(
|
||||||
assert_eq!(
|
l.to_vec(),
|
||||||
l.to_vec(),
|
vec![
|
||||||
vec![
|
"file:///redirect1.js",
|
||||||
"file:///redirect1.js",
|
"file:///redirect2.js",
|
||||||
"file:///redirect2.js",
|
"file:///dir/redirect3.js"
|
||||||
"file:///dir/redirect3.js"
|
]
|
||||||
]
|
);
|
||||||
);
|
|
||||||
|
|
||||||
let module_map_rc = JsRuntime::module_map(runtime.v8_isolate());
|
let module_map_rc = JsRuntime::module_map(runtime.v8_isolate());
|
||||||
let modules = module_map_rc.borrow();
|
let modules = module_map_rc.borrow();
|
||||||
|
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
modules.get_id("file:///redirect1.js", ModuleType::JavaScript),
|
modules
|
||||||
Some(redirect1_id)
|
.get_id("file:///redirect1.js", AssertedModuleType::JavaScriptOrWasm),
|
||||||
);
|
Some(redirect1_id)
|
||||||
|
);
|
||||||
|
|
||||||
let redirect2_id = modules
|
let redirect2_id = modules
|
||||||
.get_id("file:///dir/redirect2.js", ModuleType::JavaScript)
|
.get_id(
|
||||||
.unwrap();
|
"file:///dir/redirect2.js",
|
||||||
assert!(
|
AssertedModuleType::JavaScriptOrWasm,
|
||||||
modules.is_alias("file:///redirect2.js", ModuleType::JavaScript)
|
)
|
||||||
);
|
.unwrap();
|
||||||
assert!(
|
assert!(modules.is_alias(
|
||||||
!modules.is_alias("file:///dir/redirect2.js", ModuleType::JavaScript)
|
"file:///redirect2.js",
|
||||||
);
|
AssertedModuleType::JavaScriptOrWasm
|
||||||
assert_eq!(
|
));
|
||||||
modules.get_id("file:///redirect2.js", ModuleType::JavaScript),
|
assert!(!modules.is_alias(
|
||||||
Some(redirect2_id)
|
"file:///dir/redirect2.js",
|
||||||
);
|
AssertedModuleType::JavaScriptOrWasm
|
||||||
|
));
|
||||||
|
assert_eq!(
|
||||||
|
modules
|
||||||
|
.get_id("file:///redirect2.js", AssertedModuleType::JavaScriptOrWasm),
|
||||||
|
Some(redirect2_id)
|
||||||
|
);
|
||||||
|
|
||||||
let redirect3_id = modules
|
let redirect3_id = modules
|
||||||
.get_id("file:///redirect3.js", ModuleType::JavaScript)
|
.get_id("file:///redirect3.js", AssertedModuleType::JavaScriptOrWasm)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
assert!(
|
assert!(modules.is_alias(
|
||||||
modules.is_alias("file:///dir/redirect3.js", ModuleType::JavaScript)
|
"file:///dir/redirect3.js",
|
||||||
);
|
AssertedModuleType::JavaScriptOrWasm
|
||||||
assert!(
|
));
|
||||||
!modules.is_alias("file:///redirect3.js", ModuleType::JavaScript)
|
assert!(!modules.is_alias(
|
||||||
);
|
"file:///redirect3.js",
|
||||||
assert_eq!(
|
AssertedModuleType::JavaScriptOrWasm
|
||||||
modules.get_id("file:///dir/redirect3.js", ModuleType::JavaScript),
|
));
|
||||||
Some(redirect3_id)
|
assert_eq!(
|
||||||
);
|
modules.get_id(
|
||||||
}
|
"file:///dir/redirect3.js",
|
||||||
.boxed_local();
|
AssertedModuleType::JavaScriptOrWasm
|
||||||
|
),
|
||||||
|
Some(redirect3_id)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
.boxed_local();
|
||||||
|
|
||||||
futures::executor::block_on(fut);
|
futures::executor::block_on(fut);
|
||||||
}
|
}
|
||||||
|
@ -2122,17 +2187,20 @@ if (import.meta.url != 'file:///main_with_code.js') throw Error();
|
||||||
let modules = module_map_rc.borrow();
|
let modules = module_map_rc.borrow();
|
||||||
|
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
modules.get_id("file:///main_with_code.js", ModuleType::JavaScript),
|
modules.get_id(
|
||||||
|
"file:///main_with_code.js",
|
||||||
|
AssertedModuleType::JavaScriptOrWasm
|
||||||
|
),
|
||||||
Some(main_id)
|
Some(main_id)
|
||||||
);
|
);
|
||||||
let b_id = modules
|
let b_id = modules
|
||||||
.get_id("file:///b.js", ModuleType::JavaScript)
|
.get_id("file:///b.js", AssertedModuleType::JavaScriptOrWasm)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let c_id = modules
|
let c_id = modules
|
||||||
.get_id("file:///c.js", ModuleType::JavaScript)
|
.get_id("file:///c.js", AssertedModuleType::JavaScriptOrWasm)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let d_id = modules
|
let d_id = modules
|
||||||
.get_id("file:///d.js", ModuleType::JavaScript)
|
.get_id("file:///d.js", AssertedModuleType::JavaScriptOrWasm)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
|
@ -2140,11 +2208,11 @@ if (import.meta.url != 'file:///main_with_code.js') throw Error();
|
||||||
Some(&vec![
|
Some(&vec![
|
||||||
ModuleRequest {
|
ModuleRequest {
|
||||||
specifier: resolve_url("file:///b.js").unwrap(),
|
specifier: resolve_url("file:///b.js").unwrap(),
|
||||||
expected_module_type: ModuleType::JavaScript,
|
asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
|
||||||
},
|
},
|
||||||
ModuleRequest {
|
ModuleRequest {
|
||||||
specifier: resolve_url("file:///c.js").unwrap(),
|
specifier: resolve_url("file:///c.js").unwrap(),
|
||||||
expected_module_type: ModuleType::JavaScript,
|
asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
|
||||||
}
|
}
|
||||||
])
|
])
|
||||||
);
|
);
|
||||||
|
@ -2152,14 +2220,14 @@ if (import.meta.url != 'file:///main_with_code.js') throw Error();
|
||||||
modules.get_requested_modules(b_id),
|
modules.get_requested_modules(b_id),
|
||||||
Some(&vec![ModuleRequest {
|
Some(&vec![ModuleRequest {
|
||||||
specifier: resolve_url("file:///c.js").unwrap(),
|
specifier: resolve_url("file:///c.js").unwrap(),
|
||||||
expected_module_type: ModuleType::JavaScript,
|
asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
|
||||||
}])
|
}])
|
||||||
);
|
);
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
modules.get_requested_modules(c_id),
|
modules.get_requested_modules(c_id),
|
||||||
Some(&vec![ModuleRequest {
|
Some(&vec![ModuleRequest {
|
||||||
specifier: resolve_url("file:///d.js").unwrap(),
|
specifier: resolve_url("file:///d.js").unwrap(),
|
||||||
expected_module_type: ModuleType::JavaScript,
|
asserted_module_type: AssertedModuleType::JavaScriptOrWasm,
|
||||||
}])
|
}])
|
||||||
);
|
);
|
||||||
assert_eq!(modules.get_requested_modules(d_id), Some(&vec![]));
|
assert_eq!(modules.get_requested_modules(d_id), Some(&vec![]));
|
||||||
|
|
Loading…
Reference in a new issue