mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-04-27 23:09:08 +00:00
LibJS: Implement GetImportedModule and call it where appropriate
This breaks module loading temporarily while transitioning.
This commit is contained in:
parent
a24c543921
commit
82977ab44b
Notes:
sideshowbarker
2024-07-17 01:10:58 +09:00
Author: https://github.com/awesomekling
Commit: 82977ab44b
Pull-request: https://github.com/SerenityOS/serenity/pull/21967
Issue: https://github.com/SerenityOS/serenity/issues/21737
Issue: https://github.com/SerenityOS/serenity/issues/21899
3 changed files with 41 additions and 17 deletions
|
@ -314,8 +314,8 @@ ThrowCompletionOr<Vector<DeprecatedFlyString>> SourceTextModule::get_exported_na
|
|||
// 8. For each ExportEntry Record e of module.[[StarExportEntries]], do
|
||||
for (auto& entry : m_star_export_entries) {
|
||||
// a. Assert: e.[[ModuleRequest]] is not null.
|
||||
// b. Let requestedModule be ? HostResolveImportedModule(module, e.[[ModuleRequest]]).
|
||||
auto requested_module = TRY(vm.host_resolve_imported_module(NonnullGCPtr<Module>(*this), entry.module_request()));
|
||||
// b. Let requestedModule be GetImportedModule(module, e.[[ModuleRequest]]).
|
||||
auto requested_module = get_imported_module(entry.module_request());
|
||||
|
||||
// c. Let starNames be ? requestedModule.GetExportedNames(exportStarSet).
|
||||
auto star_names = TRY(requested_module->get_exported_names(vm, export_star_set));
|
||||
|
@ -368,8 +368,8 @@ ThrowCompletionOr<void> SourceTextModule::initialize_environment(VM& vm)
|
|||
|
||||
// 7. For each ImportEntry Record in of module.[[ImportEntries]], do
|
||||
for (auto& import_entry : m_import_entries) {
|
||||
// a. Let importedModule be ! HostResolveImportedModule(module, in.[[ModuleRequest]]).
|
||||
auto imported_module = MUST(vm.host_resolve_imported_module(NonnullGCPtr<Module>(*this), import_entry.module_request()));
|
||||
// a. Let importedModule be GetImportedModule(module, in.[[ModuleRequest]]).
|
||||
auto imported_module = get_imported_module(import_entry.module_request());
|
||||
// b. NOTE: The above call cannot fail because imported module requests are a subset of module.[[RequestedModules]], and these have been resolved earlier in this algorithm.
|
||||
|
||||
// c. If in.[[ImportName]] is namespace-object, then
|
||||
|
@ -584,8 +584,8 @@ ThrowCompletionOr<ResolvedBinding> SourceTextModule::resolve_export(VM& vm, Depr
|
|||
continue;
|
||||
|
||||
// i. Assert: e.[[ModuleRequest]] is not null.
|
||||
// ii. Let importedModule be ? HostResolveImportedModule(module, e.[[ModuleRequest]]).
|
||||
auto imported_module = TRY(vm.host_resolve_imported_module(NonnullGCPtr<Module>(*this), entry.module_request()));
|
||||
// ii. Let importedModule be GetImportedModule(module, e.[[ModuleRequest]]).
|
||||
auto imported_module = get_imported_module(entry.module_request());
|
||||
|
||||
// iii. If e.[[ImportName]] is all, then
|
||||
if (entry.kind == ExportEntry::Kind::ModuleRequestAll) {
|
||||
|
@ -625,8 +625,8 @@ ThrowCompletionOr<ResolvedBinding> SourceTextModule::resolve_export(VM& vm, Depr
|
|||
// 9. For each ExportEntry Record e of module.[[StarExportEntries]], do
|
||||
for (auto& entry : m_star_export_entries) {
|
||||
// a. Assert: e.[[ModuleRequest]] is not null.
|
||||
// b. Let importedModule be ? HostResolveImportedModule(module, e.[[ModuleRequest]]).
|
||||
auto imported_module = TRY(vm.host_resolve_imported_module(NonnullGCPtr<Module>(*this), entry.module_request()));
|
||||
// b. Let importedModule be GetImportedModule(module, e.[[ModuleRequest]]).
|
||||
auto imported_module = get_imported_module(entry.module_request());
|
||||
|
||||
// c. Let resolution be ? importedModule.ResolveExport(exportName, resolveSet).
|
||||
auto resolution = TRY(imported_module->resolve_export(vm, export_name, resolve_set));
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue