ladybird/Userland/Libraries/LibWeb/CSS/Parser/StyleRules.cpp
Sam Atkins 82d12b170a LibWeb: Merge CSS Parser's QualifiedStyleRule and AtStyleRule
AtStyleRule being a subclass of QualifiedStyleRule was causing
problems when trying to distinguish between them. Combining them
and then distinguishing between them with a Type enum makes that
check simpler, and is in line with how similar checks are done
elsewhere in the parser.
2021-07-11 23:19:56 +02:00

169 lines
3.9 KiB
C++

/*
* Copyright (c) 2020-2021, the SerenityOS developers.
* Copyright (c) 2021, Sam Atkins <atkinssj@gmail.com>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#include <LibWeb/CSS/Parser/DeclarationOrAtRule.h>
#include <LibWeb/CSS/Parser/StyleBlockRule.h>
#include <LibWeb/CSS/Parser/StyleComponentValueRule.h>
#include <LibWeb/CSS/Parser/StyleDeclarationRule.h>
#include <LibWeb/CSS/Parser/StyleFunctionRule.h>
#include <LibWeb/CSS/Parser/StyleRule.h>
namespace Web::CSS {
DeclarationOrAtRule::DeclarationOrAtRule(RefPtr<StyleRule> at)
: m_type(DeclarationType::At)
, m_at(move(at))
{
}
DeclarationOrAtRule::DeclarationOrAtRule(StyleDeclarationRule declaration)
: m_type(DeclarationType::Declaration)
, m_declaration(move(declaration))
{
}
DeclarationOrAtRule::~DeclarationOrAtRule() { }
StyleRule::StyleRule(StyleRule::Type type)
: m_type(type)
{
}
StyleRule::~StyleRule() { }
StyleBlockRule::StyleBlockRule() { }
StyleBlockRule::~StyleBlockRule() { }
StyleComponentValueRule::StyleComponentValueRule(ComponentType type)
: m_type(type)
{
}
StyleComponentValueRule::~StyleComponentValueRule() { }
StyleDeclarationRule::StyleDeclarationRule() { }
StyleDeclarationRule::~StyleDeclarationRule() { }
StyleFunctionRule::StyleFunctionRule(String name)
: m_name(name)
{
}
StyleFunctionRule::~StyleFunctionRule() { }
template<class SeparatorType, class CollectionType>
void append_with_to_string(StringBuilder& builder, SeparatorType& separator, CollectionType& collection)
{
bool first = true;
for (auto& item : collection) {
if (first)
first = false;
else
builder.append(separator);
builder.append(item.to_string());
}
}
template<class SeparatorType, class CollectionType>
void append_raw(StringBuilder& builder, SeparatorType& separator, CollectionType& collection)
{
bool first = true;
for (auto& item : collection) {
if (first)
first = false;
else
builder.append(separator);
builder.append(item);
}
}
String DeclarationOrAtRule::to_string() const
{
StringBuilder builder;
switch (m_type) {
default:
case DeclarationType::At:
builder.append(m_at->to_string());
break;
case DeclarationType::Declaration:
builder.append(m_declaration.to_string());
break;
}
return builder.to_string();
}
String StyleRule::to_string() const
{
StringBuilder builder;
if (m_type == Type::At) {
builder.append("@");
builder.append(m_name);
}
append_with_to_string(builder, " ", m_prelude);
if (m_block)
builder.append(m_block->to_string());
else
builder.append(';');
return builder.to_string();
}
String StyleBlockRule::to_string() const
{
StringBuilder builder;
builder.append(m_token.bracket_string());
append_with_to_string(builder, ", ", m_values);
builder.append(m_token.bracket_mirror_string());
return builder.to_string();
}
String StyleComponentValueRule::to_string() const
{
StringBuilder builder;
switch (m_type) {
case ComponentType::Token:
builder.append(m_token.to_string());
break;
case ComponentType::Function:
builder.append(m_function->to_string());
break;
case ComponentType::Block:
builder.append(m_block->to_string());
break;
}
return builder.to_string();
}
String StyleDeclarationRule::to_string() const
{
StringBuilder builder;
builder.append(m_name);
builder.append(": ");
append_with_to_string(builder, " ", m_values);
if (m_important)
builder.append(" !important");
return builder.to_string();
}
String StyleFunctionRule::to_string() const
{
StringBuilder builder;
builder.append(m_name);
builder.append("(");
append_raw(builder, ", ", m_values);
builder.append(")");
return builder.to_string();
}
}