mirror of
https://github.com/LadybirdBrowser/ladybird
synced 2026-04-25 17:25:08 +02:00
Previously, the LibWeb bindings generator would output multiple per interface files like Prototype/Constructor/Namespace/GlobalMixin depending on the contents of that IDL file. This complicates the build system as it means that it does not know what files will be generated without knowledge of the contents of that IDL file. Instead, for each IDL file only generate a single Bindings/<IDLFile>.h and Bindings/<IDLFile>.cpp.
92 lines
2.6 KiB
C++
92 lines
2.6 KiB
C++
/*
|
|
* Copyright (c) 2024-2025, Sam Atkins <sam@ladybird.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include "CSSNestedDeclarations.h"
|
|
#include <LibWeb/Bindings/CSSNestedDeclarations.h>
|
|
#include <LibWeb/Bindings/Intrinsics.h>
|
|
#include <LibWeb/CSS/CSSStyleRule.h>
|
|
#include <LibWeb/CSS/Parser/Parser.h>
|
|
#include <LibWeb/Dump.h>
|
|
|
|
namespace Web::CSS {
|
|
|
|
GC_DEFINE_ALLOCATOR(CSSNestedDeclarations);
|
|
|
|
GC::Ref<CSSNestedDeclarations> CSSNestedDeclarations::create(JS::Realm& realm, Parser::Parser& parser, Vector<Parser::Declaration> const& declarations)
|
|
{
|
|
return realm.create<CSSNestedDeclarations>(realm, parser.convert_to_style_declaration(declarations));
|
|
}
|
|
|
|
GC::Ref<CSSNestedDeclarations> CSSNestedDeclarations::create(JS::Realm& realm, CSSStyleProperties& declaration)
|
|
{
|
|
return realm.create<CSSNestedDeclarations>(realm, declaration);
|
|
}
|
|
|
|
CSSNestedDeclarations::CSSNestedDeclarations(JS::Realm& realm, CSSStyleProperties& declaration)
|
|
: CSSRule(realm, Type::NestedDeclarations)
|
|
, m_declaration(declaration)
|
|
{
|
|
m_declaration->set_parent_rule(*this);
|
|
}
|
|
|
|
void CSSNestedDeclarations::initialize(JS::Realm& realm)
|
|
{
|
|
WEB_SET_PROTOTYPE_FOR_INTERFACE(CSSNestedDeclarations);
|
|
Base::initialize(realm);
|
|
}
|
|
|
|
void CSSNestedDeclarations::visit_edges(Cell::Visitor& visitor)
|
|
{
|
|
Base::visit_edges(visitor);
|
|
visitor.visit(m_declaration);
|
|
visitor.visit(m_parent_style_rule);
|
|
}
|
|
|
|
GC::Ref<CSSStyleProperties> CSSNestedDeclarations::style()
|
|
{
|
|
return m_declaration;
|
|
}
|
|
|
|
CSSStyleRule const& CSSNestedDeclarations::parent_style_rule() const
|
|
{
|
|
if (m_parent_style_rule)
|
|
return *m_parent_style_rule;
|
|
|
|
for (auto* parent = parent_rule(); parent; parent = parent->parent_rule()) {
|
|
if (is<CSSStyleRule>(parent)) {
|
|
m_parent_style_rule = static_cast<CSSStyleRule const*>(parent);
|
|
return *m_parent_style_rule;
|
|
}
|
|
}
|
|
|
|
dbgln("CSSNestedDeclarations has no parent style rule!");
|
|
VERIFY_NOT_REACHED();
|
|
}
|
|
|
|
String CSSNestedDeclarations::serialized() const
|
|
{
|
|
// NOTE: There's no proper spec for this yet, only this note:
|
|
// "The CSSNestedDeclarations rule serializes as if its declaration block had been serialized directly."
|
|
// - https://drafts.csswg.org/css-nesting-1/#ref-for-cssnesteddeclarations%E2%91%A1
|
|
// So, we'll do the simple thing and hope it's good.
|
|
return m_declaration->serialized();
|
|
}
|
|
|
|
void CSSNestedDeclarations::clear_caches()
|
|
{
|
|
Base::clear_caches();
|
|
m_parent_style_rule = nullptr;
|
|
}
|
|
|
|
void CSSNestedDeclarations::dump(StringBuilder& builder, int indent_levels) const
|
|
{
|
|
Base::dump(builder, indent_levels);
|
|
|
|
dump_style_properties(builder, declaration(), indent_levels + 1);
|
|
}
|
|
|
|
}
|