mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 03:52:43 +00:00 
			
		
		
		
	 ad7e6878fe
			
		
	
	
		ad7e6878fe
		
	
	
	
	
		
			
			This makes them cheap to move around, since we can store them in a NonnullOwnPtr instead of memcopying 2584(!) bytes. Drastically reduces the chance of stack overflow while building the layout tree for deeply nested DOMs (since tree building was putting these things on the stack). This change also exposed a completely unnecessary ComputedValues deep copy in block layout.
		
			
				
	
	
		
			28 lines
		
	
	
	
		
			679 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			28 lines
		
	
	
	
		
			679 B
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2023, Aliaksandr Kalenik <kalenik.aliaksandr@gmail.com>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <LibWeb/Layout/BlockContainer.h>
 | |
| 
 | |
| namespace Web::Layout {
 | |
| 
 | |
| class TableWrapper : public BlockContainer {
 | |
|     JS_CELL(TableWrapper, BlockContainer);
 | |
| 
 | |
| public:
 | |
|     TableWrapper(DOM::Document&, DOM::Node*, NonnullRefPtr<CSS::StyleProperties>);
 | |
|     TableWrapper(DOM::Document&, DOM::Node*, NonnullOwnPtr<CSS::ComputedValues>);
 | |
|     virtual ~TableWrapper() override;
 | |
| 
 | |
| private:
 | |
|     virtual bool is_table_wrapper() const final { return true; }
 | |
| };
 | |
| 
 | |
| template<>
 | |
| inline bool Node::fast_is<TableWrapper>() const { return is_table_wrapper(); }
 | |
| 
 | |
| }
 |