Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "config.h" | 5 #include "config.h" |
| 6 #include "core/css/parser/CSSPropertyParser.h" | 6 #include "core/css/parser/CSSPropertyParser.h" |
| 7 | 7 |
| 8 #include "core/StylePropertyShorthand.h" | 8 #include "core/StylePropertyShorthand.h" |
| 9 #include "core/css/CSSCalculationValue.h" | 9 #include "core/css/CSSCalculationValue.h" |
| 10 #include "core/css/CSSCustomIdentValue.h" | 10 #include "core/css/CSSCustomIdentValue.h" |
| 11 #include "core/css/CSSFontFaceSrcValue.h" | 11 #include "core/css/CSSFontFaceSrcValue.h" |
| 12 #include "core/css/CSSFontFeatureValue.h" | 12 #include "core/css/CSSFontFeatureValue.h" |
| 13 #include "core/css/CSSPrimitiveValueMappings.h" | 13 #include "core/css/CSSPrimitiveValueMappings.h" |
| 14 #include "core/css/CSSStringValue.h" | 14 #include "core/css/CSSStringValue.h" |
| 15 #include "core/css/CSSURIValue.h" | 15 #include "core/css/CSSURIValue.h" |
| 16 #include "core/css/CSSUnicodeRangeValue.h" | 16 #include "core/css/CSSUnicodeRangeValue.h" |
| 17 #include "core/css/CSSValuePair.h" | |
| 17 #include "core/css/CSSValuePool.h" | 18 #include "core/css/CSSValuePool.h" |
| 18 #include "core/css/FontFace.h" | 19 #include "core/css/FontFace.h" |
| 19 #include "core/css/parser/CSSParserFastPaths.h" | 20 #include "core/css/parser/CSSParserFastPaths.h" |
| 20 #include "core/css/parser/CSSParserValues.h" | 21 #include "core/css/parser/CSSParserValues.h" |
| 21 #include "core/frame/UseCounter.h" | 22 #include "core/frame/UseCounter.h" |
| 22 #include "core/layout/LayoutTheme.h" | 23 #include "core/layout/LayoutTheme.h" |
| 23 #include "wtf/text/StringBuilder.h" | 24 #include "wtf/text/StringBuilder.h" |
| 24 | 25 |
| 25 namespace blink { | 26 namespace blink { |
| 26 | 27 |
| (...skipping 134 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 161 CSSPrimitiveValue::UnitType unitType = m_calcValue->isInt() ? CSSPrimiti veValue::UnitType::Integer : CSSPrimitiveValue::UnitType::Number; | 162 CSSPrimitiveValue::UnitType unitType = m_calcValue->isInt() ? CSSPrimiti veValue::UnitType::Integer : CSSPrimitiveValue::UnitType::Number; |
| 162 return cssValuePool().createValue(m_calcValue->doubleValue(), unitType); | 163 return cssValuePool().createValue(m_calcValue->doubleValue(), unitType); |
| 163 } | 164 } |
| 164 | 165 |
| 165 private: | 166 private: |
| 166 CSSParserTokenRange& m_sourceRange; | 167 CSSParserTokenRange& m_sourceRange; |
| 167 CSSParserTokenRange m_range; | 168 CSSParserTokenRange m_range; |
| 168 RefPtrWillBeMember<CSSCalcValue> m_calcValue; | 169 RefPtrWillBeMember<CSSCalcValue> m_calcValue; |
| 169 }; | 170 }; |
| 170 | 171 |
| 171 static PassRefPtrWillBeRawPtr<CSSPrimitiveValue> consumeInteger(CSSParserTokenRa nge& range, CSSParserMode cssParserMode, double minimumValue = std::numeric_limi ts<int>::min()) | 172 static PassRefPtrWillBeRawPtr<CSSPrimitiveValue> consumeInteger(CSSParserTokenRa nge& range, CSSParserMode cssParserMode, double minimumValue = std::numeric_limi ts<int>::lowest()) |
| 172 { | 173 { |
| 173 const CSSParserToken& token = range.peek(); | 174 const CSSParserToken& token = range.peek(); |
| 174 if (token.type() == NumberToken) { | 175 if (token.type() == NumberToken) { |
| 175 if (token.numericValueType() == NumberValueType || token.numericValue() < minimumValue) | 176 if (token.numericValueType() == NumberValueType || token.numericValue() < minimumValue) |
| 176 return nullptr; | 177 return nullptr; |
| 177 return cssValuePool().createValue(range.consumeIncludingWhitespace().num ericValue(), token.unitType()); | 178 return cssValuePool().createValue(range.consumeIncludingWhitespace().num ericValue(), token.unitType()); |
| 178 } | 179 } |
| 179 CalcParser calcParser(range); | 180 CalcParser calcParser(range); |
| 180 if (const CSSCalcValue* calculation = calcParser.value()) { | 181 if (const CSSCalcValue* calculation = calcParser.value()) { |
| 181 if (calculation->category() != CalcNumber || !calculation->isInt()) | 182 if (calculation->category() != CalcNumber || !calculation->isInt()) |
| (...skipping 439 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 621 for (unsigned i = 0; i < 3; i++) { // 3 dimensions of rotation | 622 for (unsigned i = 0; i < 3; i++) { // 3 dimensions of rotation |
| 622 RefPtrWillBeRawPtr<CSSValue> dimension = consumeNumber(range, ValueRange All); | 623 RefPtrWillBeRawPtr<CSSValue> dimension = consumeNumber(range, ValueRange All); |
| 623 if (!dimension) | 624 if (!dimension) |
| 624 return nullptr; | 625 return nullptr; |
| 625 list->append(dimension.release()); | 626 list->append(dimension.release()); |
| 626 } | 627 } |
| 627 | 628 |
| 628 return list.release(); | 629 return list.release(); |
| 629 } | 630 } |
| 630 | 631 |
| 632 static PassRefPtrWillBeRawPtr<CSSValue> consumeCounter(CSSParserTokenRange& rang e, CSSParserMode cssParserMode, int defaultValue) | |
| 633 { | |
| 634 if (range.peek().id() == CSSValueNone) | |
| 635 return consumeIdent(range); | |
| 636 | |
| 637 RefPtrWillBeRawPtr<CSSValueList> list = CSSValueList::createCommaSeparated() ; | |
|
Timothy Loh
2015/10/08 23:13:56
TODO to create a space-separated value list here :
| |
| 638 do { | |
| 639 if (range.peek().type() != IdentToken) | |
|
Timothy Loh
2015/10/08 23:13:56
btw I'd prefer this as follows
RefPtr..<CSSCustom
| |
| 640 return nullptr; | |
| 641 RefPtrWillBeRawPtr<CSSCustomIdentValue> counterName = consumeCustomIdent (range); | |
| 642 int i = defaultValue; | |
| 643 if (RefPtrWillBeRawPtr<CSSPrimitiveValue> counterValue = consumeInteger( range, cssParserMode, std::numeric_limits<double>::lowest())) | |
|
Timothy Loh
2015/10/08 23:13:56
How about (don't need to pass in the limit if it's
rwlbuis
2015/10/09 02:31:12
Sorry, should have mentioned the s/min/lowest chan
| |
| 644 i = clampTo<int>(counterValue->getDoubleValue()); | |
| 645 list->append(CSSValuePair::create(counterName.release(), | |
| 646 cssValuePool().createValue(i, CSSPrimitiveValue::UnitType::Number), | |
| 647 CSSValuePair::DropIdenticalValues)); | |
| 648 } while (!range.atEnd()); | |
| 649 return list.release(); | |
| 650 } | |
| 651 | |
| 631 PassRefPtrWillBeRawPtr<CSSValue> CSSPropertyParser::parseSingleValue(CSSProperty ID propId) | 652 PassRefPtrWillBeRawPtr<CSSValue> CSSPropertyParser::parseSingleValue(CSSProperty ID propId) |
| 632 { | 653 { |
| 633 m_range.consumeWhitespace(); | 654 m_range.consumeWhitespace(); |
| 634 switch (propId) { | 655 switch (propId) { |
| 635 case CSSPropertyWillChange: | 656 case CSSPropertyWillChange: |
| 636 return consumeWillChange(m_range); | 657 return consumeWillChange(m_range); |
| 637 case CSSPropertyPage: | 658 case CSSPropertyPage: |
| 638 return consumePage(m_range); | 659 return consumePage(m_range); |
| 639 case CSSPropertyQuotes: | 660 case CSSPropertyQuotes: |
| 640 return consumeQuotes(m_range); | 661 return consumeQuotes(m_range); |
| (...skipping 16 matching lines...) Expand all Loading... | |
| 657 return consumeTabSize(m_range, m_context.mode()); | 678 return consumeTabSize(m_range, m_context.mode()); |
| 658 case CSSPropertyFontSize: | 679 case CSSPropertyFontSize: |
| 659 return consumeFontSize(m_range, m_context.mode(), UnitlessQuirk::Allow); | 680 return consumeFontSize(m_range, m_context.mode(), UnitlessQuirk::Allow); |
| 660 case CSSPropertyLineHeight: | 681 case CSSPropertyLineHeight: |
| 661 return consumeLineHeight(m_range, m_context.mode()); | 682 return consumeLineHeight(m_range, m_context.mode()); |
| 662 case CSSPropertyRotate: | 683 case CSSPropertyRotate: |
| 663 return consumeRotation(m_range); | 684 return consumeRotation(m_range); |
| 664 case CSSPropertyWebkitBorderHorizontalSpacing: | 685 case CSSPropertyWebkitBorderHorizontalSpacing: |
| 665 case CSSPropertyWebkitBorderVerticalSpacing: | 686 case CSSPropertyWebkitBorderVerticalSpacing: |
| 666 return consumeLength(m_range, m_context.mode(), ValueRangeNonNegative); | 687 return consumeLength(m_range, m_context.mode(), ValueRangeNonNegative); |
| 688 case CSSPropertyCounterIncrement: | |
| 689 case CSSPropertyCounterReset: | |
| 690 return consumeCounter(m_range, m_context.mode(), propId == CSSPropertyCo unterIncrement ? 1 : 0); | |
| 667 default: | 691 default: |
| 668 return nullptr; | 692 return nullptr; |
| 669 } | 693 } |
| 670 } | 694 } |
| 671 | 695 |
| 672 static PassRefPtrWillBeRawPtr<CSSValueList> consumeFontFaceUnicodeRange(CSSParse rTokenRange& range) | 696 static PassRefPtrWillBeRawPtr<CSSValueList> consumeFontFaceUnicodeRange(CSSParse rTokenRange& range) |
| 673 { | 697 { |
| 674 RefPtrWillBeRawPtr<CSSValueList> values = CSSValueList::createCommaSeparated (); | 698 RefPtrWillBeRawPtr<CSSValueList> values = CSSValueList::createCommaSeparated (); |
| 675 | 699 |
| 676 do { | 700 do { |
| (...skipping 284 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 961 } | 985 } |
| 962 case CSSPropertyBorderSpacing: | 986 case CSSPropertyBorderSpacing: |
| 963 return consumeBorderSpacing(important); | 987 return consumeBorderSpacing(important); |
| 964 default: | 988 default: |
| 965 m_currentShorthand = oldShorthand; | 989 m_currentShorthand = oldShorthand; |
| 966 return false; | 990 return false; |
| 967 } | 991 } |
| 968 } | 992 } |
| 969 | 993 |
| 970 } // namespace blink | 994 } // namespace blink |
| OLD | NEW |