1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167
|
/*
* (C) 1999-2003 Lars Knoll (knoll@kde.org)
* Copyright (C) 2004, 2005, 2006 Apple Inc. All rights reserved.
* Copyright (C) 2013 Intel Corporation. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#pragma once
#include "CSSPropertyNames.h"
#include "CSSValue.h"
#include "IsImportant.h"
#include "WritingMode.h"
#include <wtf/BitSet.h>
#include <wtf/RefPtr.h>
namespace WebCore {
class CSSValueList;
class Settings;
enum class IsImplicit : bool { No, Yes };
struct StylePropertyMetadata {
StylePropertyMetadata(CSSPropertyID propertyID, bool isSetFromShorthand, int indexInShorthandsVector, IsImportant important, IsImplicit implicit)
: m_propertyID(propertyID)
, m_isSetFromShorthand(isSetFromShorthand)
, m_indexInShorthandsVector(indexInShorthandsVector)
, m_important(important == IsImportant::Yes)
, m_implicit(implicit == IsImplicit::Yes)
{
ASSERT(propertyID != CSSPropertyInvalid);
ASSERT_WITH_MESSAGE(propertyID < firstShorthandProperty, "unexpected property: %d", propertyID);
}
CSSPropertyID shorthandID() const;
friend bool operator==(const StylePropertyMetadata&, const StylePropertyMetadata&) = default;
unsigned m_propertyID : 10;
unsigned m_isSetFromShorthand : 1;
unsigned m_indexInShorthandsVector : 2; // If this property was set as part of an ambiguous shorthand, gives the index in the shorthands vector.
unsigned m_important : 1;
unsigned m_implicit : 1; // Whether or not the property was set implicitly as the result of a shorthand.
// 1 bit available
};
class CSSProperty {
public:
CSSProperty(CSSPropertyID propertyID, Ref<CSSValue>&& value, IsImportant important = IsImportant::No, bool isSetFromShorthand = false, int indexInShorthandsVector = 0, IsImplicit implicit = IsImplicit::No)
: m_metadata(propertyID, isSetFromShorthand, indexInShorthandsVector, important, implicit)
, m_value(WTFMove(value))
{
}
CSSPropertyID id() const { return static_cast<CSSPropertyID>(m_metadata.m_propertyID); }
bool isSetFromShorthand() const { return m_metadata.m_isSetFromShorthand; };
CSSPropertyID shorthandID() const { return m_metadata.shorthandID(); };
bool isImportant() const { return m_metadata.m_important; }
CSSValue* value() const { return m_value.ptr(); }
Ref<CSSValue> protectedValue() const { return m_value; }
static CSSPropertyID resolveDirectionAwareProperty(CSSPropertyID, WritingMode);
static CSSPropertyID unresolvePhysicalProperty(CSSPropertyID, WritingMode);
static bool isInheritedProperty(CSSPropertyID);
static Vector<String> aliasesForProperty(CSSPropertyID);
static bool isDirectionAwareProperty(CSSPropertyID propertyID) { return isLogicalPropertyGroupLogicalProperty(propertyID); }
static bool isInLogicalPropertyGroup(CSSPropertyID);
static bool areInSameLogicalPropertyGroupWithDifferentMappingLogic(CSSPropertyID, CSSPropertyID);
static bool isDescriptorOnly(CSSPropertyID);
static char16_t listValuedPropertySeparator(CSSPropertyID);
static bool isListValuedProperty(CSSPropertyID propertyID) { return !!listValuedPropertySeparator(propertyID) || propertyID == CSSPropertyCustom; }
static bool allowsNumberOrIntegerInput(CSSPropertyID);
static bool animationUsesNonAdditiveOrCumulativeInterpolation(CSSPropertyID);
static bool animationUsesNonNormalizedDiscreteInterpolation(CSSPropertyID);
static bool animationIsAccelerated(CSSPropertyID, const Settings&);
static std::span<const CSSPropertyID> allAcceleratedAnimationProperties(const Settings&);
// Properties where <color> productions should accept <quirky-color> (e.g. hashless hex color quirk).
// https://drafts.csswg.org/css-color-4/#quirky-color
// https://quirks.spec.whatwg.org/#the-hashless-hex-color-quirk
static bool acceptsQuirkyColor(CSSPropertyID);
// Properties where <length> productions should accept <quirky-length> (e.g. unitless length quirk).
// https://drafts.csswg.org/css-values-4/#deprecated-quirky-length
// https://quirks.spec.whatwg.org/#the-unitless-length-quirk
static bool acceptsQuirkyLength(CSSPropertyID);
// Properties where <angle> productions should accept <quirky-angle> (e.g. unitless angle quirk).
// FIXME: This is not specified anywhere and other engines don't implement the properties where this is used. We should remove this quirk.
static bool acceptsQuirkyAngle(CSSPropertyID);
// Logical Property Groups.
// NOTE: These return true if the CSSPropertyID is member of the named logical
// property group or is the shorthand of a member of the logical property group.
static bool isBorderColorProperty(CSSPropertyID);
static bool isBorderRadiusProperty(CSSPropertyID);
static bool isBorderStyleProperty(CSSPropertyID);
static bool isBorderWidthProperty(CSSPropertyID);
static bool isContainIntrinsicSizeProperty(CSSPropertyID);
static bool isCornerShapeProperty(CSSPropertyID);
static bool isInsetProperty(CSSPropertyID);
static bool isMarginProperty(CSSPropertyID);
static bool isMaxSizeProperty(CSSPropertyID);
static bool isMinSizeProperty(CSSPropertyID);
static bool isOverflowProperty(CSSPropertyID);
static bool isOverscrollBehaviorProperty(CSSPropertyID);
static bool isPaddingProperty(CSSPropertyID);
static bool isScrollMarginProperty(CSSPropertyID);
static bool isScrollPaddingProperty(CSSPropertyID);
static bool isSizeProperty(CSSPropertyID);
// Check if a property is a sizing property, as defined in:
// https://drafts.csswg.org/css-sizing-3/#sizing-property
static bool isSizingProperty(CSSPropertyID);
static bool disablesNativeAppearance(CSSPropertyID);
const StylePropertyMetadata& metadata() const { return m_metadata; }
static bool isColorProperty(CSSPropertyID propertyId)
{
return colorProperties.get(propertyId);
}
static const WEBCORE_EXPORT WTF::BitSet<cssPropertyIDEnumValueCount> colorProperties;
static const WEBCORE_EXPORT WTF::BitSet<cssPropertyIDEnumValueCount> physicalProperties;
bool operator==(const CSSProperty& other) const
{
if (!(m_metadata == other.m_metadata))
return false;
return m_value->equals(other.m_value);
}
private:
StylePropertyMetadata m_metadata;
Ref<CSSValue> m_value;
};
typedef Vector<CSSProperty, 256> ParsedPropertyVector;
} // namespace WebCore
namespace WTF {
template <> struct VectorTraits<WebCore::CSSProperty> : VectorTraitsBase<false, WebCore::CSSProperty> {
static const bool canInitializeWithMemset = true;
static const bool canMoveWithMemcpy = true;
};
}
|