mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-10-24 17:09:43 +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. 😅
34 lines
898 B
C++
34 lines
898 B
C++
/*
|
|
* Copyright (c) 2025, Sam Atkins <sam@ladybird.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <LibGfx/Font/UnicodeRange.h>
|
|
#include <LibWeb/CSS/StyleValues/StyleValue.h>
|
|
|
|
namespace Web::CSS {
|
|
|
|
class UnicodeRangeStyleValue final : public StyleValueWithDefaultOperators<UnicodeRangeStyleValue> {
|
|
public:
|
|
static ValueComparingNonnullRefPtr<UnicodeRangeStyleValue const> create(Gfx::UnicodeRange unicode_range)
|
|
{
|
|
return adopt_ref(*new (nothrow) UnicodeRangeStyleValue(unicode_range));
|
|
}
|
|
virtual ~UnicodeRangeStyleValue() override;
|
|
|
|
Gfx::UnicodeRange const& unicode_range() const { return m_unicode_range; }
|
|
|
|
virtual String to_string(SerializationMode) const override;
|
|
|
|
bool properties_equal(UnicodeRangeStyleValue const&) const;
|
|
|
|
private:
|
|
UnicodeRangeStyleValue(Gfx::UnicodeRange);
|
|
|
|
Gfx::UnicodeRange m_unicode_range;
|
|
};
|
|
|
|
}
|