Chromium Code Reviews| Index: third_party/WebKit/Source/core/css/cssom/CSSTokenStreamValue.cpp |
| diff --git a/third_party/WebKit/Source/core/css/cssom/CSSTokenStreamValue.cpp b/third_party/WebKit/Source/core/css/cssom/CSSTokenStreamValue.cpp |
| index fdb62cc2379dda0c5debdeedf8735653af398397..6d511b5162c32c9310f44fa621b548570777b76d 100644 |
| --- a/third_party/WebKit/Source/core/css/cssom/CSSTokenStreamValue.cpp |
| +++ b/third_party/WebKit/Source/core/css/cssom/CSSTokenStreamValue.cpp |
| @@ -4,7 +4,6 @@ |
| #include "core/css/cssom/CSSTokenStreamValue.h" |
| -#include "core/css/CSSVariableReferenceValue.h" |
| #include "core/css/cssom/CSSStyleVariableReferenceValue.h" |
| #include "core/css/parser/CSSTokenizer.h" |
| #include "wtf/text/StringBuilder.h" |
| @@ -38,6 +37,52 @@ private: |
| const Member<CSSTokenStreamValue> m_tokenStreamValue; |
| }; |
| +HeapVector<StringOrCSSVariableReferenceValue> parserTokenRangeToFragments(CSSParserTokenRange); |
|
meade_UTC10
2016/08/25 01:00:01
You shouldn't need to have so complicated a functi
|
| + |
| +CSSTokenStreamValue* fromParserTokenRangeToCSSTokenStreamValue(const CSSParserTokenRange& range) |
|
meade_UTC10
2016/08/25 01:00:02
Still don't need to have "from" in the method name
|
| +{ |
| + const HeapVector<StringOrCSSVariableReferenceValue>& fragments = parserTokenRangeToFragments(range); |
| + // return undefined if there is no value following the variable's name |
|
meade_UTC10
2016/08/25 01:00:01
s/undefined/null
anthonyhkf
2016/08/25 03:48:31
Done.
|
| + if (fragments.size() == 0) |
| + return nullptr; |
| + return CSSTokenStreamValue::create(fragments); |
| +} |
| + |
| +StringView findVariableName(CSSParserTokenRange& range) |
| +{ |
| + while (range.peek().type() != CSSParserTokenType::IdentToken) |
|
meade_UTC10
2016/08/25 01:00:01
You shouldn't need to do this. At most you'd need
anthonyhkf
2016/08/25 03:48:31
Done.
|
| + range.consume(); |
| + return range.consume().value(); |
| +} |
| + |
| +CSSStyleVariableReferenceValue* variableReferenceValue(CSSParserTokenRange range) |
|
meade_UTC10
2016/08/25 01:00:01
It would be clearer if this function took (StringV
|
| +{ |
| + StringView variableName = findVariableName(range); |
| + // skip the first comma token |
| + while (!range.atEnd() && range.consume().type() != CSSParserTokenType::CommaToken) { } |
|
meade_UTC10
2016/08/25 01:00:01
If there's no comma, this will just skip a bunch o
anthonyhkf
2016/08/25 03:48:31
Hmm.. I think if there's no comma, it will go to r
|
| + CSSTokenStreamValue* tokenStreamValue = fromParserTokenRangeToCSSTokenStreamValue(range); |
| + return CSSStyleVariableReferenceValue::create(variableName.toString(), tokenStreamValue); |
| +} |
| + |
| +HeapVector<StringOrCSSVariableReferenceValue> parserTokenRangeToFragments(CSSParserTokenRange range) |
| +{ |
| + HeapVector<StringOrCSSVariableReferenceValue> fragments; |
| + do { |
| + const CSSParserToken* start = &range.peek(); |
| + while (!range.atEnd() && (range.peek().functionId() != CSSValueVar)) |
| + range.consume(); |
| + if (start != &range.peek()) { |
| + fragments.append(StringOrCSSVariableReferenceValue::fromString(range.makeSubRange(start, &range.peek()).serialize())); |
| + } else if (!range.atEnd()) { |
| + if (range.peek().functionId() == CSSValueVar) |
| + fragments.append(StringOrCSSVariableReferenceValue::fromCSSVariableReferenceValue(variableReferenceValue(range.consumeBlock()))); |
| + else |
| + NOTREACHED(); |
| + } |
| + } while (!range.atEnd()); |
|
meade_UTC10
2016/08/25 01:00:01
This doesn't need to be a do/while loop, nor does
anthonyhkf
2016/08/25 03:48:31
Done.
|
| + return fragments; |
| +} |
| + |
| } // namespace |
| ValueIterable<StringOrCSSVariableReferenceValue>::IterationSource* CSSTokenStreamValue::startIteration(ScriptState*, ExceptionState&) |
| @@ -45,6 +90,11 @@ ValueIterable<StringOrCSSVariableReferenceValue>::IterationSource* CSSTokenStrea |
| return new TokenStreamValueIterationSource(this); |
| } |
| +CSSTokenStreamValue* CSSTokenStreamValue::fromCSSValue(const CSSVariableReferenceValue& cssVariableReferenceValue) |
| +{ |
| + return fromParserTokenRangeToCSSTokenStreamValue(cssVariableReferenceValue.variableDataValue()->tokenRange()); |
| +} |
| + |
| CSSValue* CSSTokenStreamValue::toCSSValue() const |
| { |
| StringBuilder tokens; |