mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-25 01:19:45 +00:00 
			
		
		
		
	This reverts 0e3487b9ab.
Back when I made that change, I thought we could make our StyleValue
classes match the typed-om definitions directly. However, they have
different requirements. Typed-om types need to be mutable and GCed,
whereas StyleValues are immutable and ideally wouldn't require a JS VM.
While I was already making such a cataclysmic change, I've moved it into
the StyleValues directory, because it *not* being there has bothered me
for a long time. 😅
		
	
			
		
			
				
	
	
		
			52 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2023, Sam Atkins <atkinssj@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include "MathDepthStyleValue.h"
 | |
| 
 | |
| namespace Web::CSS {
 | |
| 
 | |
| ValueComparingNonnullRefPtr<MathDepthStyleValue const> MathDepthStyleValue::create_auto_add()
 | |
| {
 | |
|     return adopt_ref(*new (nothrow) MathDepthStyleValue(MathDepthType::AutoAdd));
 | |
| }
 | |
| 
 | |
| ValueComparingNonnullRefPtr<MathDepthStyleValue const> MathDepthStyleValue::create_add(ValueComparingNonnullRefPtr<StyleValue const> integer_value)
 | |
| {
 | |
|     return adopt_ref(*new (nothrow) MathDepthStyleValue(MathDepthType::Add, move(integer_value)));
 | |
| }
 | |
| 
 | |
| ValueComparingNonnullRefPtr<MathDepthStyleValue const> MathDepthStyleValue::create_integer(ValueComparingNonnullRefPtr<StyleValue const> integer_value)
 | |
| {
 | |
|     return adopt_ref(*new (nothrow) MathDepthStyleValue(MathDepthType::Integer, move(integer_value)));
 | |
| }
 | |
| 
 | |
| MathDepthStyleValue::MathDepthStyleValue(MathDepthType type, ValueComparingRefPtr<StyleValue const> integer_value)
 | |
|     : StyleValueWithDefaultOperators(Type::MathDepth)
 | |
|     , m_type(type)
 | |
|     , m_integer_value(move(integer_value))
 | |
| {
 | |
| }
 | |
| 
 | |
| bool MathDepthStyleValue::properties_equal(MathDepthStyleValue const& other) const
 | |
| {
 | |
|     return m_type == other.m_type
 | |
|         && m_integer_value == other.m_integer_value;
 | |
| }
 | |
| 
 | |
| String MathDepthStyleValue::to_string(SerializationMode mode) const
 | |
| {
 | |
|     switch (m_type) {
 | |
|     case MathDepthType::AutoAdd:
 | |
|         return "auto-add"_string;
 | |
|     case MathDepthType::Add:
 | |
|         return MUST(String::formatted("add({})", m_integer_value->to_string(mode)));
 | |
|     case MathDepthType::Integer:
 | |
|         return m_integer_value->to_string(mode);
 | |
|     }
 | |
|     VERIFY_NOT_REACHED();
 | |
| }
 | |
| 
 | |
| }
 |