
Noticed while doing this that attribute selectors have two different ways of saying "starts with", and so AttributeMatchType::StartsWith needs a better name. But I'll change that when I add the missing types. These class names are a mouthful to fit in a commit message. :^)
36 lines
859 B
C++
36 lines
859 B
C++
/*
|
|
* Copyright (c) 2020-2021, the SerenityOS developers.
|
|
* Copyright (c) 2021, Sam Atkins <atkinssj@gmail.com>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/RefCounted.h>
|
|
#include <AK/Vector.h>
|
|
#include <LibWeb/CSS/Parser/StyleComponentValueRule.h>
|
|
#include <LibWeb/CSS/Parser/Token.h>
|
|
|
|
namespace Web::CSS {
|
|
|
|
class StyleBlockRule : public RefCounted<StyleBlockRule> {
|
|
friend class Parser;
|
|
|
|
public:
|
|
StyleBlockRule();
|
|
~StyleBlockRule();
|
|
|
|
bool is_curly() const { return m_token.is_open_curly(); }
|
|
bool is_paren() const { return m_token.is_open_paren(); }
|
|
bool is_square() const { return m_token.is_open_square(); }
|
|
|
|
Vector<StyleComponentValueRule> const& values() const { return m_values; }
|
|
|
|
String to_string() const;
|
|
|
|
private:
|
|
Token m_token;
|
|
Vector<StyleComponentValueRule> m_values;
|
|
};
|
|
}
|