mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 08:22:45 +00:00 
			
		
		
		
	 fbfce2e73e
			
		
	
	
		fbfce2e73e
		
	
	
	
	
		
			
			This is to make it easier to bounds-check their values during parsing. Length is left out because many length units are relative to the context in which they are used, and so we cannot easily compare `10px` and `1em`, for example.
		
			
				
	
	
		
			65 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2022-2023, Sam Atkins <atkinssj@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/String.h>
 | |
| #include <LibWeb/Forward.h>
 | |
| 
 | |
| namespace Web::CSS {
 | |
| class Frequency {
 | |
| public:
 | |
|     enum class Type {
 | |
|         Hz,
 | |
|         kHz
 | |
|     };
 | |
| 
 | |
|     static Optional<Type> unit_from_name(StringView);
 | |
| 
 | |
|     Frequency(int value, Type type);
 | |
|     Frequency(double value, Type type);
 | |
|     static Frequency make_hertz(double);
 | |
|     Frequency percentage_of(Percentage const&) const;
 | |
| 
 | |
|     ErrorOr<String> to_string() const;
 | |
|     double to_hertz() const;
 | |
| 
 | |
|     Type type() const { return m_type; }
 | |
|     double raw_value() const { return m_value; }
 | |
| 
 | |
|     bool operator==(Frequency const& other) const
 | |
|     {
 | |
|         return m_type == other.m_type && m_value == other.m_value;
 | |
|     }
 | |
| 
 | |
|     int operator<=>(Frequency const& other) const
 | |
|     {
 | |
|         auto this_hertz = to_hertz();
 | |
|         auto other_hertz = other.to_hertz();
 | |
| 
 | |
|         if (this_hertz < other_hertz)
 | |
|             return -1;
 | |
|         if (this_hertz > other_hertz)
 | |
|             return 1;
 | |
|         return 0;
 | |
|     }
 | |
| 
 | |
| private:
 | |
|     StringView unit_name() const;
 | |
| 
 | |
|     Type m_type;
 | |
|     double m_value { 0 };
 | |
| };
 | |
| 
 | |
| }
 | |
| 
 | |
| template<>
 | |
| struct AK::Formatter<Web::CSS::Frequency> : Formatter<StringView> {
 | |
|     ErrorOr<void> format(FormatBuilder& builder, Web::CSS::Frequency const& frequency)
 | |
|     {
 | |
|         return Formatter<StringView>::format(builder, TRY(frequency.to_string()));
 | |
|     }
 | |
| };
 |