
This will make it easier to support both string types at the same time while we convert code, and tracking down remaining uses. One big exception is Value::to_string() in LibJS, where the name is dictated by the ToString AO.
62 lines
1.5 KiB
C++
62 lines
1.5 KiB
C++
/*
|
|
* Copyright (c) 2022, Sam Atkins <atkinssj@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/DeprecatedString.h>
|
|
#include <AK/RefPtr.h>
|
|
#include <LibWeb/Forward.h>
|
|
|
|
namespace Web::CSS {
|
|
|
|
class Angle {
|
|
public:
|
|
enum class Type {
|
|
Calculated,
|
|
Deg,
|
|
Grad,
|
|
Rad,
|
|
Turn,
|
|
};
|
|
|
|
static Optional<Type> unit_from_name(StringView);
|
|
|
|
Angle(int value, Type type);
|
|
Angle(float value, Type type);
|
|
static Angle make_calculated(NonnullRefPtr<CalculatedStyleValue>);
|
|
static Angle make_degrees(float);
|
|
Angle percentage_of(Percentage const&) const;
|
|
|
|
bool is_calculated() const { return m_type == Type::Calculated; }
|
|
NonnullRefPtr<CalculatedStyleValue> calculated_style_value() const;
|
|
|
|
DeprecatedString to_deprecated_string() const;
|
|
float to_degrees() const;
|
|
|
|
bool operator==(Angle const& other) const
|
|
{
|
|
if (is_calculated())
|
|
return m_calculated_style == other.m_calculated_style;
|
|
return m_type == other.m_type && m_value == other.m_value;
|
|
}
|
|
|
|
private:
|
|
StringView unit_name() const;
|
|
|
|
Type m_type;
|
|
float m_value { 0 };
|
|
RefPtr<CalculatedStyleValue> m_calculated_style;
|
|
};
|
|
|
|
}
|
|
|
|
template<>
|
|
struct AK::Formatter<Web::CSS::Angle> : Formatter<StringView> {
|
|
ErrorOr<void> format(FormatBuilder& builder, Web::CSS::Angle const& angle)
|
|
{
|
|
return Formatter<StringView>::format(builder, angle.to_deprecated_string());
|
|
}
|
|
};
|