1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-10-20 21:42:30 +00:00
serenity/Userland/Libraries/LibWeb/CSS/Frequency.h
Sam Atkins 5f2f780662 LibWeb: Expose type and raw values of basic CSS types
This makes it possible to do arithmetic on them without having to
resolve to their canonical unit, which often requires context
information that is not available until the last minute. For example, a
Length cannot be resolved to px without knowing the font size, parent
element's size, etc.

Only Length currently requires such context, but treating all these
types the same means that code that manipulates them does not need to
know or care if a new unit gets added that does require contextual
information.
2023-04-13 09:53:47 +02:00

53 lines
1.1 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(float value, Type type);
static Frequency make_hertz(float);
Frequency percentage_of(Percentage const&) const;
ErrorOr<String> to_string() const;
float to_hertz() const;
Type type() const { return m_type; }
float raw_value() const { return m_value; }
bool operator==(Frequency const& other) const
{
return m_type == other.m_type && m_value == other.m_value;
}
private:
StringView unit_name() const;
Type m_type;
float 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()));
}
};