1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-10-25 07:52:32 +00:00
serenity/Userland/Libraries/LibWeb/Layout/BreakNode.h
Andreas Kling 02b316fd5c LibWeb: Let Paintable perform the painting
This patch adds a bunch of Paintable subclasses, each corresponding to
the Layout::Node subclasses that had a paint() override. All painting
logic is moved from layout nodes into their corresponding paintables.

Paintables are now created by asking a Layout::Box to produce one:

    static NonnullOwnPtr<Paintable> Layout::Box::create_paintable()

Note that inline nodes still have their painting logic. Since they
are not boxes, and all paintables have a corresponding box, we'll need
to come up with some other solution for them.
2022-03-11 00:21:49 +01:00

28 lines
702 B
C++

/*
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#pragma once
#include <LibWeb/HTML/HTMLBRElement.h>
#include <LibWeb/Layout/Node.h>
namespace Web::Layout {
class BreakNode final : public NodeWithStyleAndBoxModelMetrics {
public:
BreakNode(DOM::Document&, HTML::HTMLBRElement&, NonnullRefPtr<CSS::StyleProperties>);
virtual ~BreakNode() override;
const HTML::HTMLBRElement& dom_node() const { return verify_cast<HTML::HTMLBRElement>(*Node::dom_node()); }
private:
virtual bool is_break_node() const final { return true; }
};
template<>
inline bool Node::fast_is<BreakNode>() const { return is_break_node(); }
}