diff options
Diffstat (limited to 'Userland/Services/WebContent/ConnectionFromClient.h')
-rw-r--r-- | Userland/Services/WebContent/ConnectionFromClient.h | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/Userland/Services/WebContent/ConnectionFromClient.h b/Userland/Services/WebContent/ConnectionFromClient.h new file mode 100644 index 0000000000..ba2bbaa072 --- /dev/null +++ b/Userland/Services/WebContent/ConnectionFromClient.h @@ -0,0 +1,90 @@ +/* + * Copyright (c) 2018-2021, Andreas Kling <kling@serenityos.org> + * + * SPDX-License-Identifier: BSD-2-Clause + */ + +#pragma once + +#include <AK/HashMap.h> +#include <LibIPC/ConnectionFromClient.h> +#include <LibJS/Forward.h> +#include <LibJS/Heap/Handle.h> +#include <LibWeb/CSS/PreferredColorScheme.h> +#include <LibWeb/Cookie/ParsedCookie.h> +#include <LibWeb/Forward.h> +#include <WebContent/Forward.h> +#include <WebContent/WebContentClientEndpoint.h> +#include <WebContent/WebContentConsoleClient.h> +#include <WebContent/WebContentServerEndpoint.h> + +namespace WebContent { + +class ConnectionFromClient final + : public IPC::ConnectionFromClient<WebContentClientEndpoint, WebContentServerEndpoint> { + C_OBJECT(ConnectionFromClient); + +public: + ~ConnectionFromClient() override; + + virtual void die() override; + + void initialize_js_console(Badge<PageHost>); + +private: + explicit ConnectionFromClient(NonnullOwnPtr<Core::Stream::LocalSocket>); + + Web::Page& page(); + const Web::Page& page() const; + + virtual void update_system_theme(Core::AnonymousBuffer const&) override; + virtual void update_system_fonts(String const&, String const&) override; + virtual void update_screen_rects(Vector<Gfx::IntRect> const&, u32) override; + virtual void load_url(URL const&) override; + virtual void load_html(String const&, URL const&) override; + virtual void paint(Gfx::IntRect const&, i32) override; + virtual void set_viewport_rect(Gfx::IntRect const&) override; + virtual void mouse_down(Gfx::IntPoint const&, unsigned, unsigned, unsigned) override; + virtual void mouse_move(Gfx::IntPoint const&, unsigned, unsigned, unsigned) override; + virtual void mouse_up(Gfx::IntPoint const&, unsigned, unsigned, unsigned) override; + virtual void mouse_wheel(Gfx::IntPoint const&, unsigned, unsigned, unsigned, i32, i32) override; + virtual void key_down(i32, unsigned, u32) override; + virtual void key_up(i32, unsigned, u32) override; + virtual void add_backing_store(i32, Gfx::ShareableBitmap const&) override; + virtual void remove_backing_store(i32) override; + virtual void debug_request(String const&, String const&) override; + virtual void get_source() override; + virtual void inspect_dom_tree() override; + virtual Messages::WebContentServer::InspectDomNodeResponse inspect_dom_node(i32) override; + virtual Messages::WebContentServer::GetHoveredNodeIdResponse get_hovered_node_id() override; + virtual Messages::WebContentServer::DumpLayoutTreeResponse dump_layout_tree() override; + virtual void set_content_filters(Vector<String> const&) override; + virtual void set_preferred_color_scheme(Web::CSS::PreferredColorScheme const&) override; + virtual void set_has_focus(bool) override; + + virtual void js_console_input(String const&) override; + virtual void run_javascript(String const&) override; + virtual void js_console_request_messages(i32) override; + + virtual Messages::WebContentServer::GetSelectedTextResponse get_selected_text() override; + virtual void select_all() override; + + void flush_pending_paint_requests(); + + NonnullOwnPtr<PageHost> m_page_host; + struct PaintRequest { + Gfx::IntRect content_rect; + NonnullRefPtr<Gfx::Bitmap> bitmap; + i32 bitmap_id { -1 }; + }; + Vector<PaintRequest> m_pending_paint_requests; + RefPtr<Core::Timer> m_paint_flush_timer; + + HashMap<i32, NonnullRefPtr<Gfx::Bitmap>> m_backing_stores; + + WeakPtr<JS::Interpreter> m_interpreter; + OwnPtr<WebContentConsoleClient> m_console_client; + JS::Handle<JS::GlobalObject> m_console_global_object; +}; + +} |