mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-26 09:59:43 +00:00 
			
		
		
		
	Because we store calculations as a tree of CalculationNodes inside a CalculatedStyleValue, instead of a tree of StyleValues directly, this implements a create_calculation_node() method on CSSNumericValue. CSSMathValue::create_an_internal_representation() then calls create_calculation_node() on itself, and wraps it in a CalculatedStyleValue. Lots of WPT passes again! Some regressions, which are expected: `cursor` fails a test for the same reason it fails other that set it to some kind of numeric value: We don't distinguish between "can contain a number" and "can accept a number by itself". This will affect any similar properties, but overall this is a big improvement.
		
			
				
	
	
		
			40 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2025, Sam Atkins <sam@ladybird.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <LibWeb/CSS/CSSMathValue.h>
 | |
| 
 | |
| namespace Web::CSS {
 | |
| 
 | |
| // https://drafts.css-houdini.org/css-typed-om-1/#cssmathproduct
 | |
| class CSSMathProduct final : public CSSMathValue {
 | |
|     WEB_PLATFORM_OBJECT(CSSMathProduct, CSSMathValue);
 | |
|     GC_DECLARE_ALLOCATOR(CSSMathProduct);
 | |
| 
 | |
| public:
 | |
|     [[nodiscard]] static GC::Ref<CSSMathProduct> create(JS::Realm&, NumericType, GC::Ref<CSSNumericArray>);
 | |
|     static WebIDL::ExceptionOr<GC::Ref<CSSMathProduct>> construct_impl(JS::Realm&, Vector<CSSNumberish>);
 | |
| 
 | |
|     virtual ~CSSMathProduct() override;
 | |
| 
 | |
|     virtual void initialize(JS::Realm&) override;
 | |
|     virtual void visit_edges(Visitor&) override;
 | |
| 
 | |
|     GC::Ref<CSSNumericArray> values() const;
 | |
| 
 | |
|     virtual String serialize_math_value(Nested, Parens) const override;
 | |
|     virtual bool is_equal_numeric_value(GC::Ref<CSSNumericValue> other) const override;
 | |
|     virtual Optional<SumValue> create_a_sum_value() const override;
 | |
| 
 | |
|     virtual WebIDL::ExceptionOr<NonnullRefPtr<CalculationNode const>> create_calculation_node(CalculationContext const&) const override;
 | |
| 
 | |
| private:
 | |
|     CSSMathProduct(JS::Realm&, NumericType, GC::Ref<CSSNumericArray>);
 | |
|     GC::Ref<CSSNumericArray> m_values;
 | |
| };
 | |
| 
 | |
| }
 |