ladybird/Libraries/LibWeb/CSS/StyleValues/FitContentStyleValue.h
Sam Atkins c57975c9fd LibWeb: Move and rename CSSStyleValue to StyleValues/StyleValue.{h,cpp}
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. 😅
2025-08-08 15:19:03 +01:00

52 lines
1.5 KiB
C++

/*
* Copyright (c) 2025, Andreas Kling <andreas@ladybird.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#pragma once
#include <LibWeb/CSS/PercentageOr.h>
#include <LibWeb/CSS/StyleValues/StyleValue.h>
namespace Web::CSS {
class FitContentStyleValue final : public StyleValue {
public:
static ValueComparingNonnullRefPtr<FitContentStyleValue const> create()
{
return adopt_ref(*new (nothrow) FitContentStyleValue(LengthPercentage { Length::make_auto() }));
}
static ValueComparingNonnullRefPtr<FitContentStyleValue const> create(LengthPercentage length_percentage)
{
return adopt_ref(*new (nothrow) FitContentStyleValue(move(length_percentage)));
}
virtual ~FitContentStyleValue() override = default;
virtual String to_string(SerializationMode mode) const override
{
if (m_length_percentage.is_auto())
return "fit-content"_string;
return MUST(String::formatted("fit-content({})", m_length_percentage.to_string(mode)));
}
bool equals(StyleValue const& other) const override
{
if (type() != other.type())
return false;
return m_length_percentage == other.as_fit_content().m_length_percentage;
}
[[nodiscard]] LengthPercentage const& length_percentage() const { return m_length_percentage; }
private:
FitContentStyleValue(LengthPercentage length_percentage)
: StyleValue(Type::FitContent)
, m_length_percentage(move(length_percentage))
{
}
LengthPercentage m_length_percentage;
};
}