mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-24 23:42:37 +00:00 
			
		
		
		
	 02b316fd5c
			
		
	
	
		02b316fd5c
		
	
	
	
	
		
			
			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.
		
	
			
		
			
				
	
	
		
			28 lines
		
	
	
	
		
			702 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			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(); }
 | |
| 
 | |
| }
 |