mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 21:57:35 +00:00
LibJS+LibWeb: Replace GlobalObject with Realm in object constructors
No functional changes - we can still very easily get to the global object via `Realm::global_object()`. This is in preparation of moving the intrinsics to the realm and no longer having to pass a global object when allocating any object. In a few (now, and many more in subsequent commits) places we get a realm using `GlobalObject::associated_realm()`, this is intended to be temporary. For example, create() functions will later receive the same treatment and are passed a realm instead of a global object.
This commit is contained in:
parent
4c300cc5e8
commit
ecd163bdf1
315 changed files with 592 additions and 554 deletions
|
@ -365,8 +365,8 @@ JS_DEFINE_NATIVE_FUNCTION(SheetGlobalObject::get_column_bound)
|
|||
return JS::Value(bounds.row);
|
||||
}
|
||||
|
||||
WorkbookObject::WorkbookObject(Workbook& workbook, JS::GlobalObject& global_object)
|
||||
: JS::Object(*JS::Object::create(global_object, global_object.object_prototype()))
|
||||
WorkbookObject::WorkbookObject(JS::Realm& realm, Workbook& workbook)
|
||||
: JS::Object(*realm.global_object().object_prototype())
|
||||
, m_workbook(workbook)
|
||||
{
|
||||
}
|
||||
|
|
|
@ -50,7 +50,7 @@ class WorkbookObject final : public JS::Object {
|
|||
JS_OBJECT(WorkbookObject, JS::Object);
|
||||
|
||||
public:
|
||||
WorkbookObject(Workbook&, JS::GlobalObject&);
|
||||
WorkbookObject(JS::Realm&, Workbook&);
|
||||
|
||||
virtual ~WorkbookObject() override = default;
|
||||
|
||||
|
|
|
@ -29,7 +29,7 @@ Workbook::Workbook(NonnullRefPtrVector<Sheet>&& sheets, GUI::Window& parent_wind
|
|||
, m_main_execution_context(m_vm->heap())
|
||||
, m_parent_window(parent_window)
|
||||
{
|
||||
m_workbook_object = m_vm->heap().allocate<WorkbookObject>(m_interpreter->global_object(), *this, m_interpreter->global_object());
|
||||
m_workbook_object = m_vm->heap().allocate<WorkbookObject>(m_interpreter->global_object(), m_interpreter->realm(), *this);
|
||||
m_interpreter->global_object().define_direct_property("workbook", workbook_object(), JS::default_attributes);
|
||||
|
||||
m_main_execution_context.current_node = nullptr;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue