
DeprecatedFlyString relies heavily on DeprecatedString's StringImpl, so let's rename it to A) match the name of DeprecatedString, B) write a new FlyString class that is tied to String.
55 lines
1.5 KiB
C++
55 lines
1.5 KiB
C++
/*
|
|
* Copyright (c) 2020-2021, the SerenityOS developers.
|
|
* Copyright (c) 2021, Sam Atkins <atkinssj@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/DeprecatedFlyString.h>
|
|
#include <AK/RefCounted.h>
|
|
#include <AK/Vector.h>
|
|
#include <LibWeb/CSS/Parser/Block.h>
|
|
#include <LibWeb/CSS/Parser/ComponentValue.h>
|
|
|
|
namespace Web::CSS::Parser {
|
|
|
|
class Rule : public RefCounted<Rule> {
|
|
public:
|
|
enum class Type {
|
|
At,
|
|
Qualified,
|
|
};
|
|
|
|
static NonnullRefPtr<Rule> make_at_rule(DeprecatedFlyString name, Vector<ComponentValue> prelude, RefPtr<Block> block)
|
|
{
|
|
return adopt_ref(*new Rule(Type::At, move(name), move(prelude), move(block)));
|
|
}
|
|
|
|
static NonnullRefPtr<Rule> make_qualified_rule(Vector<ComponentValue> prelude, RefPtr<Block> block)
|
|
{
|
|
return adopt_ref(*new Rule(Type::Qualified, {}, move(prelude), move(block)));
|
|
}
|
|
|
|
~Rule();
|
|
|
|
bool is_qualified_rule() const { return m_type == Type::Qualified; }
|
|
bool is_at_rule() const { return m_type == Type::At; }
|
|
|
|
Vector<ComponentValue> const& prelude() const { return m_prelude; }
|
|
RefPtr<Block const> block() const { return m_block; }
|
|
StringView at_rule_name() const { return m_at_rule_name; }
|
|
|
|
DeprecatedString to_deprecated_string() const;
|
|
|
|
private:
|
|
Rule(Type, DeprecatedFlyString name, Vector<ComponentValue> prelude, RefPtr<Block>);
|
|
|
|
Type const m_type;
|
|
DeprecatedFlyString m_at_rule_name;
|
|
Vector<ComponentValue> m_prelude;
|
|
RefPtr<Block> m_block;
|
|
};
|
|
|
|
}
|