
"Component value" is the term used in the spec, and it doesn't conflict with any other types, so let's use the shorter name. :^) Also, this doesn't need to be friends with the Parser any more.
36 lines
808 B
C++
36 lines
808 B
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/RefCounted.h>
|
|
#include <AK/String.h>
|
|
#include <AK/Vector.h>
|
|
#include <LibWeb/CSS/Parser/ComponentValue.h>
|
|
|
|
namespace Web::CSS {
|
|
|
|
class ComponentValue;
|
|
|
|
class StyleFunctionRule : public RefCounted<StyleFunctionRule> {
|
|
friend class Parser;
|
|
|
|
public:
|
|
explicit StyleFunctionRule(String name);
|
|
StyleFunctionRule(String name, Vector<ComponentValue>&& values);
|
|
~StyleFunctionRule();
|
|
|
|
String const& name() const { return m_name; }
|
|
Vector<ComponentValue> const& values() const { return m_values; }
|
|
|
|
String to_string() const;
|
|
|
|
private:
|
|
String m_name;
|
|
Vector<ComponentValue> m_values;
|
|
};
|
|
}
|