mirror of
https://github.com/RGBCube/serenity
synced 2025-10-24 03:42:34 +00:00

This will make it easier to support both string types at the same time while we convert code, and tracking down remaining uses. One big exception is Value::to_string() in LibJS, where the name is dictated by the ToString AO.
48 lines
1,011 B
C++
48 lines
1,011 B
C++
/*
|
|
* Copyright (c) 2020-2021, the SerenityOS developers.
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <LibWeb/CSS/Parser/Declaration.h>
|
|
#include <LibWeb/CSS/Parser/Rule.h>
|
|
|
|
namespace Web::CSS::Parser {
|
|
|
|
class DeclarationOrAtRule {
|
|
public:
|
|
explicit DeclarationOrAtRule(RefPtr<Rule> at);
|
|
explicit DeclarationOrAtRule(Declaration declaration);
|
|
~DeclarationOrAtRule();
|
|
|
|
enum class DeclarationType {
|
|
At,
|
|
Declaration,
|
|
};
|
|
|
|
bool is_at_rule() const { return m_type == DeclarationType::At; }
|
|
bool is_declaration() const { return m_type == DeclarationType::Declaration; }
|
|
|
|
Rule const& at_rule() const
|
|
{
|
|
VERIFY(is_at_rule());
|
|
return *m_at;
|
|
}
|
|
|
|
Declaration const& declaration() const
|
|
{
|
|
VERIFY(is_declaration());
|
|
return *m_declaration;
|
|
}
|
|
|
|
DeprecatedString to_deprecated_string() const;
|
|
|
|
private:
|
|
DeclarationType m_type;
|
|
RefPtr<Rule> m_at;
|
|
Optional<Declaration> m_declaration;
|
|
};
|
|
|
|
}
|