mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-10-24 17:09:43 +00:00
LibDevTools: Pull DOMNode type and related code into new Node.h
Accessibility nodes will share this code, so make it available, and rename DOMNode to Node.
This commit is contained in:
parent
eeb5446c1b
commit
d5fe7f7a98
Notes:
github-actions[bot]
2025-10-20 09:52:37 +00:00
Author: https://github.com/AtkinsSJ
Commit: d5fe7f7a98
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/6462
Reviewed-by: https://github.com/trflynn89
5 changed files with 57 additions and 34 deletions
|
@ -11,20 +11,12 @@
|
|||
#include <AK/Traits.h>
|
||||
#include <LibDevTools/Actor.h>
|
||||
#include <LibDevTools/Forward.h>
|
||||
#include <LibDevTools/Node.h>
|
||||
#include <LibWeb/CSS/Selector.h>
|
||||
#include <LibWeb/Forward.h>
|
||||
|
||||
namespace DevTools {
|
||||
|
||||
struct DEVTOOLS_API NodeIdentifier {
|
||||
static NodeIdentifier for_node(JsonObject const& node);
|
||||
|
||||
bool operator==(NodeIdentifier const&) const = default;
|
||||
|
||||
Web::UniqueNodeID id { 0 };
|
||||
Optional<Web::CSS::PseudoElement> pseudo_element;
|
||||
};
|
||||
|
||||
class NodeActor final : public Actor {
|
||||
public:
|
||||
static constexpr auto base_name = "node"sv;
|
||||
|
|
|
@ -388,19 +388,6 @@ JsonValue WalkerActor::serialize_root() const
|
|||
return serialize_node(m_dom_tree);
|
||||
}
|
||||
|
||||
static constexpr Web::DOM::NodeType parse_node_type(StringView type)
|
||||
{
|
||||
if (type == "document"sv)
|
||||
return Web::DOM::NodeType::DOCUMENT_NODE;
|
||||
if (type == "element"sv)
|
||||
return Web::DOM::NodeType::ELEMENT_NODE;
|
||||
if (type == "text"sv)
|
||||
return Web::DOM::NodeType::TEXT_NODE;
|
||||
if (type == "comment"sv)
|
||||
return Web::DOM::NodeType::COMMENT_NODE;
|
||||
return Web::DOM::NodeType::INVALID;
|
||||
}
|
||||
|
||||
JsonValue WalkerActor::serialize_node(JsonObject const& node) const
|
||||
{
|
||||
auto tab = m_tab.strong_ref();
|
||||
|
@ -414,7 +401,7 @@ JsonValue WalkerActor::serialize_node(JsonObject const& node) const
|
|||
auto name = node.get_string("name"sv).release_value();
|
||||
auto type = node.get_string("type"sv).release_value();
|
||||
|
||||
auto dom_type = parse_node_type(type);
|
||||
auto dom_type = parse_dom_node_type(type);
|
||||
JsonValue node_value;
|
||||
|
||||
auto is_top_level_document = &node == &m_dom_tree;
|
||||
|
@ -450,7 +437,7 @@ JsonValue WalkerActor::serialize_node(JsonObject const& node) const
|
|||
|
||||
if (auto parent_actor = m_dom_node_id_to_actor_map.get(parent_id); parent_actor.has_value()) {
|
||||
if (auto parent_node = WalkerActor::dom_node_for(this, *parent_actor); parent_node.has_value()) {
|
||||
dom_type = parse_node_type(parent_node->node.get_string("type"sv).value());
|
||||
dom_type = parse_dom_node_type(parent_node->node.get_string("type"sv).value());
|
||||
is_displayed = !is_top_level_document && parent_node->node.get_bool("visible"sv).value_or(false);
|
||||
}
|
||||
}
|
||||
|
@ -518,14 +505,14 @@ JsonValue WalkerActor::serialize_node(JsonObject const& node) const
|
|||
return serialized;
|
||||
}
|
||||
|
||||
Optional<WalkerActor::DOMNode> WalkerActor::dom_node_for(WeakPtr<WalkerActor> const& weak_walker, StringView actor)
|
||||
Optional<Node> WalkerActor::dom_node_for(WeakPtr<WalkerActor> const& weak_walker, StringView actor)
|
||||
{
|
||||
if (auto walker = weak_walker.strong_ref())
|
||||
return walker->dom_node(actor);
|
||||
return {};
|
||||
}
|
||||
|
||||
Optional<WalkerActor::DOMNode> WalkerActor::dom_node(StringView actor)
|
||||
Optional<Node> WalkerActor::dom_node(StringView actor)
|
||||
{
|
||||
auto tab = m_tab.strong_ref();
|
||||
if (!tab)
|
||||
|
@ -538,7 +525,7 @@ Optional<WalkerActor::DOMNode> WalkerActor::dom_node(StringView actor)
|
|||
auto const& dom_node = *maybe_dom_node.value();
|
||||
auto identifier = NodeIdentifier::for_node(dom_node);
|
||||
|
||||
return DOMNode { .node = dom_node, .identifier = move(identifier), .tab = tab.release_nonnull() };
|
||||
return Node { .node = dom_node, .identifier = move(identifier), .tab = tab.release_nonnull() };
|
||||
}
|
||||
|
||||
Optional<JsonObject const&> WalkerActor::find_node_by_selector(JsonObject const& node, StringView selector)
|
||||
|
|
|
@ -13,6 +13,7 @@
|
|||
#include <LibDevTools/Actor.h>
|
||||
#include <LibDevTools/Actors/NodeActor.h>
|
||||
#include <LibDevTools/Forward.h>
|
||||
#include <LibDevTools/Node.h>
|
||||
#include <LibWeb/Forward.h>
|
||||
#include <LibWebView/Forward.h>
|
||||
|
||||
|
@ -28,13 +29,8 @@ public:
|
|||
static bool is_suitable_for_dom_inspection(JsonValue const&);
|
||||
JsonValue serialize_root() const;
|
||||
|
||||
struct DOMNode {
|
||||
JsonObject const& node;
|
||||
NodeIdentifier identifier;
|
||||
NonnullRefPtr<TabActor> tab;
|
||||
};
|
||||
static Optional<DOMNode> dom_node_for(WeakPtr<WalkerActor> const&, StringView actor);
|
||||
Optional<DOMNode> dom_node(StringView actor);
|
||||
static Optional<Node> dom_node_for(WeakPtr<WalkerActor> const&, StringView actor);
|
||||
Optional<Node> dom_node(StringView actor);
|
||||
|
||||
private:
|
||||
WalkerActor(DevToolsServer&, String name, WeakPtr<TabActor>, JsonObject dom_tree);
|
||||
|
|
|
@ -35,6 +35,7 @@ class WalkerActor;
|
|||
class WatcherActor;
|
||||
|
||||
struct CSSProperty;
|
||||
struct Node;
|
||||
struct ProcessDescription;
|
||||
struct TabDescription;
|
||||
|
||||
|
|
47
Libraries/LibDevTools/Node.h
Normal file
47
Libraries/LibDevTools/Node.h
Normal file
|
@ -0,0 +1,47 @@
|
|||
/*
|
||||
* Copyright (c) 2025, Tim Flynn <trflynn89@ladybird.org>
|
||||
* Copyright (c) 2025, Sam Atkins <sam@ladybird.org>
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <AK/JsonObject.h>
|
||||
#include <LibDevTools/Actors/TabActor.h>
|
||||
#include <LibDevTools/Forward.h>
|
||||
#include <LibWeb/CSS/PseudoElement.h>
|
||||
#include <LibWeb/DOM/NodeType.h>
|
||||
#include <LibWeb/Forward.h>
|
||||
|
||||
namespace DevTools {
|
||||
|
||||
struct DEVTOOLS_API NodeIdentifier {
|
||||
static NodeIdentifier for_node(JsonObject const& node);
|
||||
|
||||
bool operator==(NodeIdentifier const&) const = default;
|
||||
|
||||
Web::UniqueNodeID id { 0 };
|
||||
Optional<Web::CSS::PseudoElement> pseudo_element;
|
||||
};
|
||||
|
||||
struct DEVTOOLS_API Node {
|
||||
JsonObject const& node;
|
||||
NodeIdentifier identifier;
|
||||
NonnullRefPtr<TabActor> tab;
|
||||
};
|
||||
|
||||
static constexpr Web::DOM::NodeType parse_dom_node_type(StringView type)
|
||||
{
|
||||
if (type == "document"sv)
|
||||
return Web::DOM::NodeType::DOCUMENT_NODE;
|
||||
if (type == "element"sv)
|
||||
return Web::DOM::NodeType::ELEMENT_NODE;
|
||||
if (type == "text"sv)
|
||||
return Web::DOM::NodeType::TEXT_NODE;
|
||||
if (type == "comment"sv)
|
||||
return Web::DOM::NodeType::COMMENT_NODE;
|
||||
return Web::DOM::NodeType::INVALID;
|
||||
}
|
||||
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue