Browse Source

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)
Aliaksandr Kalenik 2 years ago
parent
commit
c4f94b0846
1 changed files with 56 additions and 0 deletions
  1. 56 0
      Userland/Libraries/LibWeb/HTML/AbstractBrowsingContext.h

+ 56 - 0
Userland/Libraries/LibWeb/HTML/AbstractBrowsingContext.h

@@ -0,0 +1,56 @@
+/*
+ * Copyright (c) 2023, Aliaksandr Kalenik <kalenik.aliaksandr@gmail.com>
+ *
+ * SPDX-License-Identifier: BSD-2-Clause
+ */
+
+#pragma once
+
+#include <LibJS/Forward.h>
+#include <LibJS/Heap/Cell.h>
+#include <LibWeb/HTML/HistoryHandlingBehavior.h>
+#include <LibWeb/HTML/PolicyContainers.h>
+#include <LibWeb/HTML/WindowProxy.h>
+
+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<BrowsingContext> opener_browsing_context() const { return m_opener_browsing_context; }
+    void set_opener_browsing_context(JS::GCPtr<BrowsingContext> browsing_context) { m_opener_browsing_context = browsing_context; }
+
+    virtual WebIDL::ExceptionOr<void> navigate(
+        JS::NonnullGCPtr<Fetch::Infrastructure::Request> resource,
+        BrowsingContext& source_browsing_context,
+        bool exceptions_enabled = false,
+        HistoryHandlingBehavior history_handling = HistoryHandlingBehavior::Default,
+        Optional<PolicyContainer> history_policy_container = {},
+        DeprecatedString navigation_type = "other",
+        Optional<DeprecatedString> navigation_id = {},
+        Function<void(JS::NonnullGCPtr<Fetch::Infrastructure::Response>)> 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<BrowsingContext> m_opener_browsing_context;
+};
+
+}