ladybird/Userland/Libraries/LibWeb/SVG/SVGLength.cpp
Shannon Booth bad44f8fc9 LibWeb: Remove Bindings/Forward.h from LibWeb/Forward.h
This was resulting in a whole lot of rebuilding whenever a new IDL
interface was added.

Instead, just directly include the prototype in every C++ file which
needs it. While we only really need a forward declaration in each cpp
file; including the full prototype header (which itself only includes
LibJS/Object.h, which is already transitively brought in by
PlatformObject) - it seems like a small price to pay compared to what
feels like a full rebuild of LibWeb whenever a new IDL file is added.

Given all of these includes are only needed for the ::initialize
method, there is probably a smart way of avoiding this problem
altogether. I've considered both using some macro trickery or generating
these functions somehow instead.
2024-04-27 18:29:35 -04:00

79 lines
2.5 KiB
C++

/*
* Copyright (c) 2022, Tim Flynn <trflynn89@serenityos.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#include <LibWeb/Bindings/Intrinsics.h>
#include <LibWeb/Bindings/SVGLengthPrototype.h>
#include <LibWeb/CSS/PercentageOr.h>
#include <LibWeb/SVG/SVGLength.h>
namespace Web::SVG {
JS_DEFINE_ALLOCATOR(SVGLength);
JS::NonnullGCPtr<SVGLength> SVGLength::create(JS::Realm& realm, u8 unit_type, float value)
{
return realm.heap().allocate<SVGLength>(realm, realm, unit_type, value);
}
JS::NonnullGCPtr<SVGLength> SVGLength::from_length_percentage(JS::Realm& realm, CSS::LengthPercentage const& length_percentage)
{
// FIXME: We can't tell if a CSS::LengthPercentage was a unitless length.
(void)SVG_LENGTHTYPE_NUMBER;
if (length_percentage.is_percentage())
return SVGLength::create(realm, SVG_LENGTHTYPE_PERCENTAGE, length_percentage.percentage().value());
if (length_percentage.is_length())
return SVGLength::create(
realm, [&] {
switch (length_percentage.length().type()) {
case CSS::Length::Type::Em:
return SVG_LENGTHTYPE_EMS;
case CSS::Length::Type::Ex:
return SVG_LENGTHTYPE_EXS;
case CSS::Length::Type::Px:
return SVG_LENGTHTYPE_PX;
case CSS::Length::Type::Cm:
return SVG_LENGTHTYPE_CM;
case CSS::Length::Type::Mm:
return SVG_LENGTHTYPE_MM;
case CSS::Length::Type::In:
return SVG_LENGTHTYPE_IN;
case CSS::Length::Type::Pt:
return SVG_LENGTHTYPE_PT;
case CSS::Length::Type::Pc:
return SVG_LENGTHTYPE_PC;
default:
return SVG_LENGTHTYPE_UNKNOWN;
}
}(),
length_percentage.length().raw_value());
return SVGLength::create(realm, SVG_LENGTHTYPE_UNKNOWN, 0);
}
SVGLength::SVGLength(JS::Realm& realm, u8 unit_type, float value)
: PlatformObject(realm)
, m_unit_type(unit_type)
, m_value(value)
{
}
void SVGLength::initialize(JS::Realm& realm)
{
Base::initialize(realm);
WEB_SET_PROTOTYPE_FOR_INTERFACE(SVGLength);
}
SVGLength::~SVGLength() = default;
// https://www.w3.org/TR/SVG11/types.html#__svg__SVGLength__value
WebIDL::ExceptionOr<void> SVGLength::set_value(float value)
{
// FIXME: Raise an exception if this <length> is read-only.
m_value = value;
return {};
}
}