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
|
// Copyright 2015 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CSSVariableResolver_h
#define CSSVariableResolver_h
#include "core/CSSPropertyNames.h"
#include "core/css/parser/CSSParserToken.h"
#include "wtf/HashSet.h"
#include "wtf/text/AtomicString.h"
#include "wtf/text/AtomicStringHash.h"
namespace blink {
class CSSParserTokenRange;
class CSSPendingSubstitutionValue;
class CSSVariableData;
class CSSVariableReferenceValue;
class PropertyRegistry;
class StyleResolverState;
class StyleInheritedVariables;
class StyleNonInheritedVariables;
class CSSVariableResolver {
STACK_ALLOCATED();
public:
static void resolveVariableDefinitions(const StyleResolverState&);
// Shorthand properties are not supported.
static const CSSValue* resolveVariableReferences(
const StyleResolverState&,
CSSPropertyID,
const CSSValue&,
bool disallowAnimationTainted);
static void computeRegisteredVariables(const StyleResolverState&);
DECLARE_TRACE();
private:
CSSVariableResolver(const StyleResolverState&);
static const CSSValue* resolvePendingSubstitutions(
const StyleResolverState&,
CSSPropertyID,
const CSSPendingSubstitutionValue&,
bool disallowAnimationTainted);
static const CSSValue* resolveVariableReferences(
const StyleResolverState&,
CSSPropertyID,
const CSSVariableReferenceValue&,
bool disallowAnimationTainted);
// These return false if we encounter a reference to an invalid variable with
// no fallback.
// Resolves a range which may contain var() references or @apply rules.
bool resolveTokenRange(CSSParserTokenRange,
bool disallowAnimationTainted,
Vector<CSSParserToken>& result,
bool& resultIsAnimationTainted);
// Resolves the fallback (if present) of a var() reference, starting from the
// comma.
bool resolveFallback(CSSParserTokenRange,
bool disallowAnimationTainted,
Vector<CSSParserToken>& result,
bool& resultIsAnimationTainted);
// Resolves the contents of a var() reference.
bool resolveVariableReference(CSSParserTokenRange,
bool disallowAnimationTainted,
Vector<CSSParserToken>& result,
bool& resultIsAnimationTainted);
// Consumes and resolves an @apply rule.
void resolveApplyAtRule(CSSParserTokenRange&, Vector<CSSParserToken>& result);
// These return null if the custom property is invalid.
// Returns the CSSVariableData for a custom property, resolving and storing it
// if necessary.
CSSVariableData* valueForCustomProperty(AtomicString name);
// Resolves the CSSVariableData from a custom property declaration.
PassRefPtr<CSSVariableData> resolveCustomProperty(AtomicString name,
const CSSVariableData&);
StyleInheritedVariables* m_inheritedVariables;
StyleNonInheritedVariables* m_nonInheritedVariables;
Member<const PropertyRegistry> m_registry;
HashSet<AtomicString> m_variablesSeen;
// Resolution doesn't finish when a cycle is detected. Fallbacks still
// need to be tracked for additional cycles, and invalidation only
// applies back to cycle starts.
HashSet<AtomicString> m_cycleStartPoints;
};
} // namespace blink
#endif // CSSVariableResolver
|