mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-26 09:59:43 +00:00 
			
		
		
		
	Before this change, whenever element's attributes changed, we would add a flag to "pending invalidation", indicating that all descendants whose style uses CSS custom properties needed to be recomputed. This resulted in severe overinvalidation, because we would run invalidation regardless of whether any custom property on affected element actually changed. This change takes another approach, and now we decide whether descendant's style needs to be recomputed based on whether ancestor's style recomputation results in a change of custom properties, though this approach adds a little overhead to style computation as now we have to compare old vs new hashmap of custom properties. This brings substantial improvement on discord and x.com where, before this change, advantage of using invalidation sets was lost and we had to recompute all descendants, because almost all of them use custom properties.
		
			
				
	
	
		
			33 lines
		
	
	
	
		
			905 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			33 lines
		
	
	
	
		
			905 B
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2025, Aliaksandr Kalenik <kalenik.aliaksandr@gmail.com>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <LibGC/CellAllocator.h>
 | |
| #include <LibWeb/CSS/InvalidationSet.h>
 | |
| #include <LibWeb/Forward.h>
 | |
| 
 | |
| namespace Web::DOM {
 | |
| 
 | |
| class StyleInvalidator : public GC::Cell {
 | |
|     GC_CELL(StyleInvalidator, GC::Cell);
 | |
|     GC_DECLARE_ALLOCATOR(StyleInvalidator);
 | |
| 
 | |
| public:
 | |
|     void invalidate(Node& node);
 | |
|     void add_pending_invalidation(GC::Ref<Node>, CSS::InvalidationSet&&);
 | |
|     bool has_pending_invalidations() const { return !m_pending_invalidations.is_empty(); }
 | |
| 
 | |
|     virtual void visit_edges(Cell::Visitor& visitor) override;
 | |
| 
 | |
| private:
 | |
|     void perform_pending_style_invalidations(Node& node, bool invalidate_entire_subtree);
 | |
| 
 | |
|     HashMap<GC::Ref<Node>, CSS::InvalidationSet> m_pending_invalidations;
 | |
|     Vector<CSS::InvalidationSet> m_subtree_invalidation_sets;
 | |
| };
 | |
| 
 | |
| }
 |