
This is a bit of a chonkier commit as it results in both: clean_up_after_running_callback and prepare_to_run_callback being changed to accept a realm instead of an environment settings object, which has a bunch of fallout, particuarly for IDL abstract operations.
28 lines
923 B
C++
28 lines
923 B
C++
/*
|
|
* Copyright (c) 2023, Tim Flynn <trflynn89@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <LibWeb/HTML/Scripting/Environments.h>
|
|
#include <LibWeb/HTML/Scripting/TemporaryExecutionContext.h>
|
|
|
|
namespace Web::HTML {
|
|
|
|
TemporaryExecutionContext::TemporaryExecutionContext(EnvironmentSettingsObject& environment_settings, CallbacksEnabled callbacks_enabled)
|
|
: m_environment_settings(environment_settings)
|
|
, m_callbacks_enabled(callbacks_enabled)
|
|
{
|
|
prepare_to_run_script(m_environment_settings->realm());
|
|
if (m_callbacks_enabled == CallbacksEnabled::Yes)
|
|
prepare_to_run_callback(m_environment_settings->realm());
|
|
}
|
|
|
|
TemporaryExecutionContext::~TemporaryExecutionContext()
|
|
{
|
|
clean_up_after_running_script(m_environment_settings->realm());
|
|
if (m_callbacks_enabled == CallbacksEnabled::Yes)
|
|
clean_up_after_running_callback(m_environment_settings->realm());
|
|
}
|
|
|
|
}
|