CyclicModule.h 3.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. /*
  2. * Copyright (c) 2022, David Tuin <davidot@serenityos.org>
  3. * Copyright (c) 2023, networkException <networkexception@serenityos.org>
  4. *
  5. * SPDX-License-Identifier: BSD-2-Clause
  6. */
  7. #pragma once
  8. #include <LibJS/Forward.h>
  9. #include <LibJS/Module.h>
  10. namespace JS {
  11. enum class ModuleStatus {
  12. New,
  13. Unlinked,
  14. Linking,
  15. Linked,
  16. Evaluating,
  17. EvaluatingAsync,
  18. Evaluated
  19. };
  20. // 16.2.1.5 Cyclic Module Records, https://tc39.es/ecma262/#cyclic-module-record
  21. class CyclicModule : public Module {
  22. GC_CELL(CyclicModule, Module);
  23. GC_DECLARE_ALLOCATOR(CyclicModule);
  24. public:
  25. virtual ~CyclicModule() override;
  26. // Note: Do not call these methods directly unless you are HostResolveImportedModule.
  27. // Badges cannot be used because other hosts must be able to call this (and it is called recursively)
  28. virtual ThrowCompletionOr<void> link(VM& vm) override final;
  29. virtual ThrowCompletionOr<Promise*> evaluate(VM& vm) override final;
  30. virtual PromiseCapability& load_requested_modules(GC::Ptr<GraphLoadingState::HostDefined>) override;
  31. virtual void inner_module_loading(GraphLoadingState& state);
  32. Vector<ModuleRequest> const& requested_modules() const { return m_requested_modules; }
  33. Vector<ModuleWithSpecifier> const& loaded_modules() const { return m_loaded_modules; }
  34. Vector<ModuleWithSpecifier>& loaded_modules() { return m_loaded_modules; }
  35. protected:
  36. CyclicModule(Realm& realm, StringView filename, bool has_top_level_await, Vector<ModuleRequest> requested_modules, Script::HostDefined* host_defined);
  37. virtual void visit_edges(Cell::Visitor&) override;
  38. virtual ThrowCompletionOr<u32> inner_module_linking(VM& vm, Vector<Module*>& stack, u32 index) override final;
  39. virtual ThrowCompletionOr<u32> inner_module_evaluation(VM& vm, Vector<Module*>& stack, u32 index) override final;
  40. virtual ThrowCompletionOr<void> initialize_environment(VM& vm);
  41. virtual ThrowCompletionOr<void> execute_module(VM& vm, GC::Ptr<PromiseCapability> capability = {});
  42. [[nodiscard]] GC::Ref<Module> get_imported_module(ModuleRequest const&);
  43. void execute_async_module(VM& vm);
  44. void gather_available_ancestors(Vector<CyclicModule*>& exec_list);
  45. void async_module_execution_fulfilled(VM& vm);
  46. void async_module_execution_rejected(VM& vm, Value error);
  47. ModuleStatus m_status { ModuleStatus::New }; // [[Status]]
  48. ThrowCompletionOr<void> m_evaluation_error; // [[EvaluationError]]
  49. Optional<u32> m_dfs_index; // [[DFSIndex]]
  50. Optional<u32> m_dfs_ancestor_index; // [[DFSAncestorIndex]]
  51. Vector<ModuleRequest> m_requested_modules; // [[RequestedModules]]
  52. Vector<ModuleWithSpecifier> m_loaded_modules; // [[LoadedModules]]
  53. GC::Ptr<CyclicModule> m_cycle_root; // [[CycleRoot]]
  54. bool m_has_top_level_await { false }; // [[HasTLA]]
  55. bool m_async_evaluation { false }; // [[AsyncEvaluation]]
  56. GC::Ptr<PromiseCapability> m_top_level_capability; // [[TopLevelCapability]]
  57. Vector<GC::Ptr<CyclicModule>> m_async_parent_modules; // [[AsyncParentModules]]
  58. Optional<u32> m_pending_async_dependencies; // [[PendingAsyncDependencies]]
  59. };
  60. void continue_module_loading(GraphLoadingState&, ThrowCompletionOr<GC::Ref<Module>> const&);
  61. void continue_dynamic_import(GC::Ref<PromiseCapability>, ThrowCompletionOr<GC::Ref<Module>> const& module_completion);
  62. }