
This replaces the FlyStrings for ARIA roles that were constructed in a [[gnu::constructor]] with a single enum. I came across this as the DOM inspector was crashing due to a null FlyString for an ARIA role. After fixing that, I was confused as to why these roles were not an enum. Looking at the spec there's a fixed list of roles and switching from references to static strings to an enum was pretty much an exercise in find and replace :). No functional changes (outside of fixing the mentioned crash).
38 lines
1 KiB
C++
38 lines
1 KiB
C++
/*
|
|
* Copyright (c) 2020, the SerenityOS developers.
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <AK/Assertions.h>
|
|
#include <LibWeb/Bindings/Intrinsics.h>
|
|
#include <LibWeb/DOM/ARIARoles.h>
|
|
#include <LibWeb/HTML/HTMLQuoteElement.h>
|
|
|
|
namespace Web::HTML {
|
|
|
|
HTMLQuoteElement::HTMLQuoteElement(DOM::Document& document, DOM::QualifiedName qualified_name)
|
|
: HTMLElement(document, move(qualified_name))
|
|
{
|
|
}
|
|
|
|
HTMLQuoteElement::~HTMLQuoteElement() = default;
|
|
|
|
void HTMLQuoteElement::initialize(JS::Realm& realm)
|
|
{
|
|
Base::initialize(realm);
|
|
set_prototype(&Bindings::ensure_web_prototype<Bindings::HTMLQuoteElementPrototype>(realm, "HTMLQuoteElement"));
|
|
}
|
|
|
|
Optional<DOM::ARIARoles::Role> HTMLQuoteElement::default_role() const
|
|
{
|
|
// https://www.w3.org/TR/html-aria/#el-blockquote
|
|
if (local_name() == TagNames::blockquote)
|
|
return DOM::ARIARoles::Role::blockquote;
|
|
// https://www.w3.org/TR/html-aria/#el-q
|
|
if (local_name() == TagNames::q)
|
|
return DOM::ARIARoles::Role::generic;
|
|
VERIFY_NOT_REACHED();
|
|
}
|
|
|
|
}
|