
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.
39 lines
951 B
C++
39 lines
951 B
C++
/*
|
|
* Copyright (c) 2020-2021, the SerenityOS developers.
|
|
* Copyright (c) 2021-2022, Sam Atkins <atkinssj@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/DeprecatedString.h>
|
|
#include <AK/FlyString.h>
|
|
#include <AK/RefCounted.h>
|
|
#include <AK/Vector.h>
|
|
#include <LibWeb/CSS/Parser/ComponentValue.h>
|
|
#include <LibWeb/Forward.h>
|
|
|
|
namespace Web::CSS::Parser {
|
|
|
|
class Function : public RefCounted<Function> {
|
|
public:
|
|
static NonnullRefPtr<Function> create(FlyString name, Vector<ComponentValue>&& values)
|
|
{
|
|
return adopt_ref(*new Function(move(name), move(values)));
|
|
}
|
|
|
|
~Function();
|
|
|
|
StringView name() const { return m_name; }
|
|
Vector<ComponentValue> const& values() const { return m_values; }
|
|
|
|
DeprecatedString to_deprecated_string() const;
|
|
|
|
private:
|
|
Function(FlyString name, Vector<ComponentValue>&& values);
|
|
|
|
FlyString m_name;
|
|
Vector<ComponentValue> m_values;
|
|
};
|
|
}
|