summaryrefslogtreecommitdiff
path: root/Userland/Libraries/LibWeb/CSS/StyleValues/UnresolvedStyleValue.h
diff options
context:
space:
mode:
Diffstat (limited to 'Userland/Libraries/LibWeb/CSS/StyleValues/UnresolvedStyleValue.h')
-rw-r--r--Userland/Libraries/LibWeb/CSS/StyleValues/UnresolvedStyleValue.h45
1 files changed, 45 insertions, 0 deletions
diff --git a/Userland/Libraries/LibWeb/CSS/StyleValues/UnresolvedStyleValue.h b/Userland/Libraries/LibWeb/CSS/StyleValues/UnresolvedStyleValue.h
new file mode 100644
index 0000000000..4fa6e1cf08
--- /dev/null
+++ b/Userland/Libraries/LibWeb/CSS/StyleValues/UnresolvedStyleValue.h
@@ -0,0 +1,45 @@
+/*
+ * Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
+ * Copyright (c) 2021, Tobias Christiansen <tobyase@serenityos.org>
+ * Copyright (c) 2021-2023, Sam Atkins <atkinssj@serenityos.org>
+ * Copyright (c) 2022-2023, MacDue <macdue@dueutil.tech>
+ *
+ * SPDX-License-Identifier: BSD-2-Clause
+ */
+
+#pragma once
+
+#include <AK/Vector.h>
+#include <LibWeb/CSS/Parser/ComponentValue.h>
+#include <LibWeb/CSS/StyleValue.h>
+
+namespace Web::CSS {
+
+class UnresolvedStyleValue final : public StyleValue {
+public:
+ static ValueComparingNonnullRefPtr<UnresolvedStyleValue> create(Vector<Parser::ComponentValue>&& values, bool contains_var_or_attr)
+ {
+ return adopt_ref(*new UnresolvedStyleValue(move(values), contains_var_or_attr));
+ }
+ virtual ~UnresolvedStyleValue() override = default;
+
+ virtual ErrorOr<String> to_string() const override;
+
+ Vector<Parser::ComponentValue> const& values() const { return m_values; }
+ bool contains_var_or_attr() const { return m_contains_var_or_attr; }
+
+ virtual bool equals(StyleValue const& other) const override;
+
+private:
+ UnresolvedStyleValue(Vector<Parser::ComponentValue>&& values, bool contains_var_or_attr)
+ : StyleValue(Type::Unresolved)
+ , m_values(move(values))
+ , m_contains_var_or_attr(contains_var_or_attr)
+ {
+ }
+
+ Vector<Parser::ComponentValue> m_values;
+ bool m_contains_var_or_attr { false };
+};
+
+}