Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "core/css/cssom/CSSTokenStreamValue.h" | 5 #include "core/css/cssom/CSSTokenStreamValue.h" |
| 6 | 6 |
| 7 #include "core/css/CSSVariableReferenceValue.h" | |
| 8 #include "core/css/cssom/CSSStyleVariableReferenceValue.h" | 7 #include "core/css/cssom/CSSStyleVariableReferenceValue.h" |
| 9 #include "core/css/parser/CSSTokenizer.h" | 8 #include "core/css/parser/CSSTokenizer.h" |
| 10 #include "wtf/text/StringBuilder.h" | 9 #include "wtf/text/StringBuilder.h" |
| 11 | 10 |
| 12 namespace blink { | 11 namespace blink { |
| 13 | 12 |
| 14 namespace { | 13 namespace { |
| 15 | 14 |
| 16 class TokenStreamValueIterationSource final : public ValueIterable<StringOrCSSVa riableReferenceValue>::IterationSource { | 15 class TokenStreamValueIterationSource final : public ValueIterable<StringOrCSSVa riableReferenceValue>::IterationSource { |
| 17 public: | 16 public: |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 31 DEFINE_INLINE_VIRTUAL_TRACE() | 30 DEFINE_INLINE_VIRTUAL_TRACE() |
| 32 { | 31 { |
| 33 visitor->trace(m_tokenStreamValue); | 32 visitor->trace(m_tokenStreamValue); |
| 34 ValueIterable<StringOrCSSVariableReferenceValue>::IterationSource::trace (visitor); | 33 ValueIterable<StringOrCSSVariableReferenceValue>::IterationSource::trace (visitor); |
| 35 } | 34 } |
| 36 | 35 |
| 37 private: | 36 private: |
| 38 const Member<CSSTokenStreamValue> m_tokenStreamValue; | 37 const Member<CSSTokenStreamValue> m_tokenStreamValue; |
| 39 }; | 38 }; |
| 40 | 39 |
| 40 HeapVector<StringOrCSSVariableReferenceValue> parserTokenRangeToFragments(CSSPar serTokenRange); | |
|
meade_UTC10
2016/08/25 01:00:01
You shouldn't need to have so complicated a functi
| |
| 41 | |
| 42 CSSTokenStreamValue* fromParserTokenRangeToCSSTokenStreamValue(const CSSParserTo kenRange& range) | |
|
meade_UTC10
2016/08/25 01:00:02
Still don't need to have "from" in the method name
| |
| 43 { | |
| 44 const HeapVector<StringOrCSSVariableReferenceValue>& fragments = parserToken RangeToFragments(range); | |
| 45 // 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.
| |
| 46 if (fragments.size() == 0) | |
| 47 return nullptr; | |
| 48 return CSSTokenStreamValue::create(fragments); | |
| 49 } | |
| 50 | |
| 51 StringView findVariableName(CSSParserTokenRange& range) | |
| 52 { | |
| 53 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.
| |
| 54 range.consume(); | |
| 55 return range.consume().value(); | |
| 56 } | |
| 57 | |
| 58 CSSStyleVariableReferenceValue* variableReferenceValue(CSSParserTokenRange range ) | |
|
meade_UTC10
2016/08/25 01:00:01
It would be clearer if this function took (StringV
| |
| 59 { | |
| 60 StringView variableName = findVariableName(range); | |
| 61 // skip the first comma token | |
| 62 while (!range.atEnd() && range.consume().type() != CSSParserTokenType::Comma Token) { } | |
|
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
| |
| 63 CSSTokenStreamValue* tokenStreamValue = fromParserTokenRangeToCSSTokenStream Value(range); | |
| 64 return CSSStyleVariableReferenceValue::create(variableName.toString(), token StreamValue); | |
| 65 } | |
| 66 | |
| 67 HeapVector<StringOrCSSVariableReferenceValue> parserTokenRangeToFragments(CSSPar serTokenRange range) | |
| 68 { | |
| 69 HeapVector<StringOrCSSVariableReferenceValue> fragments; | |
| 70 do { | |
| 71 const CSSParserToken* start = &range.peek(); | |
| 72 while (!range.atEnd() && (range.peek().functionId() != CSSValueVar)) | |
| 73 range.consume(); | |
| 74 if (start != &range.peek()) { | |
| 75 fragments.append(StringOrCSSVariableReferenceValue::fromString(range .makeSubRange(start, &range.peek()).serialize())); | |
| 76 } else if (!range.atEnd()) { | |
| 77 if (range.peek().functionId() == CSSValueVar) | |
| 78 fragments.append(StringOrCSSVariableReferenceValue::fromCSSVaria bleReferenceValue(variableReferenceValue(range.consumeBlock()))); | |
| 79 else | |
| 80 NOTREACHED(); | |
| 81 } | |
| 82 } 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.
| |
| 83 return fragments; | |
| 84 } | |
| 85 | |
| 41 } // namespace | 86 } // namespace |
| 42 | 87 |
| 43 ValueIterable<StringOrCSSVariableReferenceValue>::IterationSource* CSSTokenStrea mValue::startIteration(ScriptState*, ExceptionState&) | 88 ValueIterable<StringOrCSSVariableReferenceValue>::IterationSource* CSSTokenStrea mValue::startIteration(ScriptState*, ExceptionState&) |
| 44 { | 89 { |
| 45 return new TokenStreamValueIterationSource(this); | 90 return new TokenStreamValueIterationSource(this); |
| 46 } | 91 } |
| 47 | 92 |
| 93 CSSTokenStreamValue* CSSTokenStreamValue::fromCSSValue(const CSSVariableReferenc eValue& cssVariableReferenceValue) | |
| 94 { | |
| 95 return fromParserTokenRangeToCSSTokenStreamValue(cssVariableReferenceValue.v ariableDataValue()->tokenRange()); | |
| 96 } | |
| 97 | |
| 48 CSSValue* CSSTokenStreamValue::toCSSValue() const | 98 CSSValue* CSSTokenStreamValue::toCSSValue() const |
| 49 { | 99 { |
| 50 StringBuilder tokens; | 100 StringBuilder tokens; |
| 51 | 101 |
| 52 for (unsigned i = 0; i < m_fragments.size(); i++) { | 102 for (unsigned i = 0; i < m_fragments.size(); i++) { |
| 53 if (i) | 103 if (i) |
| 54 tokens.append("/**/"); | 104 tokens.append("/**/"); |
| 55 if (m_fragments[i].isString()) | 105 if (m_fragments[i].isString()) |
| 56 tokens.append(m_fragments[i].getAsString()); | 106 tokens.append(m_fragments[i].getAsString()); |
| 57 else if (m_fragments[i].isCSSVariableReferenceValue()) | 107 else if (m_fragments[i].isCSSVariableReferenceValue()) |
| 58 tokens.append(m_fragments[i].getAsCSSVariableReferenceValue()->varia ble()); | 108 tokens.append(m_fragments[i].getAsCSSVariableReferenceValue()->varia ble()); |
| 59 else | 109 else |
| 60 NOTREACHED(); | 110 NOTREACHED(); |
| 61 } | 111 } |
| 62 | 112 |
| 63 CSSTokenizer::Scope scope(tokens.toString()); | 113 CSSTokenizer::Scope scope(tokens.toString()); |
| 64 | 114 |
| 65 return CSSVariableReferenceValue::create(CSSVariableData::create(scope.token Range())); | 115 return CSSVariableReferenceValue::create(CSSVariableData::create(scope.token Range())); |
| 66 } | 116 } |
| 67 | 117 |
| 68 } // namespace blink | 118 } // namespace blink |
| OLD | NEW |