ladybird/Libraries/LibWeb/CSS/Resolution.cpp
Sam Atkins b3e32445d3 LibWeb/CSS: Use generated FooUnit types instead of Foo::Type
I've also renamed the `m_type` and `type()` members to be `m_unit` and
`unit()` instead, to match what they actually are.
2025-09-11 17:06:44 +01:00

57 lines
1.6 KiB
C++

/*
* Copyright (c) 2022-2025, Sam Atkins <sam@ladybird.org>
* Copyright (c) 2024, Glenn Skrzypczak <glenn.skrzypczak@gmail.com>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#include <LibWeb/CSS/Resolution.h>
#include <LibWeb/CSS/Serialize.h>
namespace Web::CSS {
Resolution::Resolution(double value, ResolutionUnit unit)
: m_unit(unit)
, m_value(value)
{
}
Resolution Resolution::make_dots_per_pixel(double value)
{
return { value, ResolutionUnit::Dppx };
}
String Resolution::to_string(SerializationMode serialization_mode) const
{
// https://drafts.csswg.org/cssom/#serialize-a-css-value
// -> <resolution>
// The resolution in dots per CSS pixel serialized as per <number> followed by the literal string "dppx".
// AD-HOC: WPT expects us to serialize using the actual unit, like for other dimensions.
// https://github.com/w3c/csswg-drafts/issues/12616
if (serialization_mode == SerializationMode::ResolvedValue) {
StringBuilder builder;
serialize_a_number(builder, to_dots_per_pixel());
builder.append("dppx"sv);
return builder.to_string_without_validation();
}
StringBuilder builder;
serialize_a_number(builder, raw_value());
builder.append(unit_name());
return builder.to_string_without_validation();
}
double Resolution::to_dots_per_pixel() const
{
switch (m_unit) {
case ResolutionUnit::Dpi:
return m_value / 96; // 1in = 2.54cm = 96px
case ResolutionUnit::Dpcm:
return m_value / (96.0 / 2.54); // 1cm = 96px/2.54
case ResolutionUnit::Dppx:
case ResolutionUnit::X:
return m_value;
}
VERIFY_NOT_REACHED();
}
}