
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.
67 lines
2.1 KiB
C++
67 lines
2.1 KiB
C++
/*
|
|
* Copyright (c) 2022, Andreas Kling <kling@serenityos.org>
|
|
* Copyright (c) 2023, Aliaksandr Kalenik <kalenik.aliaksandr@gmail.com>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <AK/Utf16View.h>
|
|
#include <LibJS/Runtime/Completion.h>
|
|
#include <LibJS/Runtime/Utf16String.h>
|
|
#include <LibWeb/Bindings/SVGTextContentElementPrototype.h>
|
|
#include <LibWeb/CSS/Parser/Parser.h>
|
|
#include <LibWeb/DOM/Document.h>
|
|
#include <LibWeb/Layout/SVGTextBox.h>
|
|
#include <LibWeb/SVG/AttributeNames.h>
|
|
#include <LibWeb/SVG/AttributeParser.h>
|
|
#include <LibWeb/SVG/SVGGeometryElement.h>
|
|
#include <LibWeb/SVG/SVGTextContentElement.h>
|
|
|
|
namespace Web::SVG {
|
|
|
|
SVGTextContentElement::SVGTextContentElement(DOM::Document& document, DOM::QualifiedName qualified_name)
|
|
: SVGGraphicsElement(document, move(qualified_name))
|
|
{
|
|
}
|
|
|
|
void SVGTextContentElement::initialize(JS::Realm& realm)
|
|
{
|
|
Base::initialize(realm);
|
|
WEB_SET_PROTOTYPE_FOR_INTERFACE(SVGTextContentElement);
|
|
}
|
|
|
|
Optional<TextAnchor> SVGTextContentElement::text_anchor() const
|
|
{
|
|
if (!layout_node())
|
|
return {};
|
|
switch (layout_node()->computed_values().text_anchor()) {
|
|
case CSS::TextAnchor::Start:
|
|
return TextAnchor::Start;
|
|
case CSS::TextAnchor::Middle:
|
|
return TextAnchor::Middle;
|
|
case CSS::TextAnchor::End:
|
|
return TextAnchor::End;
|
|
default:
|
|
VERIFY_NOT_REACHED();
|
|
}
|
|
}
|
|
|
|
ByteString SVGTextContentElement::text_contents() const
|
|
{
|
|
return child_text_content().to_byte_string().trim_whitespace();
|
|
}
|
|
|
|
// https://svgwg.org/svg2-draft/text.html#__svg__SVGTextContentElement__getNumberOfChars
|
|
WebIDL::ExceptionOr<WebIDL::Long> SVGTextContentElement::get_number_of_chars() const
|
|
{
|
|
auto chars = TRY_OR_THROW_OOM(vm(), utf8_to_utf16(text_contents()));
|
|
return static_cast<WebIDL::Long>(chars.size());
|
|
}
|
|
|
|
JS::NonnullGCPtr<Geometry::DOMPoint> SVGTextContentElement::get_start_position_of_char(WebIDL::UnsignedLong charnum)
|
|
{
|
|
dbgln("(STUBBED) SVGTextContentElement::get_start_position_of_char(charnum={}). Called on: {}", charnum, debug_description());
|
|
return Geometry::DOMPoint::from_point(vm(), Geometry::DOMPointInit {});
|
|
}
|
|
|
|
}
|