/* * Copyright (C) 2015-2021 Apple Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #pragma once #include "CSSValue.h" #include "CSSVariableData.h" #include "CSSVariableReferenceValue.h" #include "Length.h" #include "StyleImage.h" #include namespace WebCore { class CSSParserToken; class CSSCustomPropertyValue final : public CSSValue { public: using VariantValue = Variant, CSSValueID, Ref, Length, Ref>; static Ref createEmpty(const AtomString& name); static Ref createUnresolved(const AtomString& name, Ref&& value) { return adoptRef(*new CSSCustomPropertyValue(name, { WTFMove(value) })); } static Ref createUnresolved(const AtomString& name, CSSValueID value) { return adoptRef(*new CSSCustomPropertyValue(name, { value })); } static Ref createWithID(const AtomString& name, CSSValueID id) { ASSERT(id == CSSValueInherit || id == CSSValueInitial || id == CSSValueUnset || id == CSSValueRevert || id == CSSValueInvalid); return adoptRef(*new CSSCustomPropertyValue(name, { id })); } static Ref createSyntaxAll(const AtomString& name, Ref&& value) { return adoptRef(*new CSSCustomPropertyValue(name, { WTFMove(value) })); } static Ref createSyntaxLength(const AtomString& name, Length value) { ASSERT(!value.isUndefined()); ASSERT(!value.isCalculated()); return adoptRef(*new CSSCustomPropertyValue(name, { WTFMove(value) })); } static Ref createSyntaxImage(const AtomString& name, Ref&& value) { return adoptRef(*new CSSCustomPropertyValue(name, { WTFMove(value) })); } static Ref create(const CSSCustomPropertyValue& other) { return adoptRef(*new CSSCustomPropertyValue(other)); } String customCSSText() const; const AtomString& name() const { return m_name; } bool isResolved() const { return !WTF::holds_alternative>(m_value); } bool isUnset() const { return WTF::holds_alternative(m_value) && WTF::get(m_value) == CSSValueUnset; } bool isInvalid() const { return WTF::holds_alternative(m_value) && WTF::get(m_value) == CSSValueInvalid; } const VariantValue& value() const { return m_value; } Vector tokens() const; bool equals(const CSSCustomPropertyValue&) const; private: CSSCustomPropertyValue(const AtomString& name, VariantValue&& value) : CSSValue(CustomPropertyClass) , m_name(name) , m_value(WTFMove(value)) { } CSSCustomPropertyValue(const CSSCustomPropertyValue& other) : CSSValue(CustomPropertyClass) , m_name(other.m_name) , m_value(other.m_value) , m_stringValue(other.m_stringValue) { } const AtomString m_name; const VariantValue m_value; mutable String m_stringValue; }; } // namespace WebCore SPECIALIZE_TYPE_TRAITS_CSS_VALUE(CSSCustomPropertyValue, isCustomPropertyValue())