From c4f94b084640432b30985faea21840b84b6c69b6 Mon Sep 17 00:00:00 2001 From: Aliaksandr Kalenik Date: Tue, 14 Mar 2023 12:02:33 +0300 Subject: [PATCH] LibWeb: Introduce AbstractBrowsingContext Introducing class for abstract browsing context is going to make it possible to have separate implementations for: 1) Local browsing context (Top level BC of current page and iframes) 2) Remote browsing context (BC of a page that lives in another WebContent process) --- .../LibWeb/HTML/AbstractBrowsingContext.h | 56 +++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 Userland/Libraries/LibWeb/HTML/AbstractBrowsingContext.h diff --git a/Userland/Libraries/LibWeb/HTML/AbstractBrowsingContext.h b/Userland/Libraries/LibWeb/HTML/AbstractBrowsingContext.h new file mode 100644 index 0000000000..dfae19224d --- /dev/null +++ b/Userland/Libraries/LibWeb/HTML/AbstractBrowsingContext.h @@ -0,0 +1,56 @@ +/* + * Copyright (c) 2023, Aliaksandr Kalenik + * + * SPDX-License-Identifier: BSD-2-Clause + */ + +#pragma once + +#include +#include +#include +#include +#include + +namespace Web::HTML { + +class AbstractBrowsingContext : public JS::Cell { + JS_CELL(AbstractBrowsingContext, Cell); + +public: + virtual HTML::WindowProxy* window_proxy() = 0; + virtual HTML::WindowProxy const* window_proxy() const = 0; + + DeprecatedString const& name() const { return m_name; } + void set_name(DeprecatedString const& name) { m_name = name; } + + JS::GCPtr opener_browsing_context() const { return m_opener_browsing_context; } + void set_opener_browsing_context(JS::GCPtr browsing_context) { m_opener_browsing_context = browsing_context; } + + virtual WebIDL::ExceptionOr navigate( + JS::NonnullGCPtr resource, + BrowsingContext& source_browsing_context, + bool exceptions_enabled = false, + HistoryHandlingBehavior history_handling = HistoryHandlingBehavior::Default, + Optional history_policy_container = {}, + DeprecatedString navigation_type = "other", + Optional navigation_id = {}, + Function)> process_response_end_of_body = {}) + = 0; + + void set_is_popup(bool is_popup) { m_is_popup = is_popup; } + + virtual String const& window_handle() const = 0; + virtual void set_window_handle(String handle) = 0; + +protected: + DeprecatedString m_name; + + // https://html.spec.whatwg.org/multipage/browsers.html#is-popup + bool m_is_popup { false }; + + // https://html.spec.whatwg.org/multipage/browsers.html#opener-browsing-context + JS::GCPtr m_opener_browsing_context; +}; + +}