mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-05-01 08:48:49 +00:00
The goal here is to move the parser-internal classes into this namespace so they can have more convenient names without causing collisions. The Parser itself won't collide, and would be more convenient to just remain `CSS::Parser`, but having a namespace and a class with the same name makes C++ unhappy.
35 lines
821 B
C++
35 lines
821 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>
|
|
#include <LibWeb/Forward.h>
|
|
|
|
namespace Web::CSS {
|
|
|
|
class StyleFunctionRule : public RefCounted<StyleFunctionRule> {
|
|
friend class Parser::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;
|
|
};
|
|
}
|