Index: third_party/WebKit/Source/core/css/properties/CSSPropertyCounterUtils.cpp |
diff --git a/third_party/WebKit/Source/core/css/properties/CSSPropertyCounterUtils.cpp b/third_party/WebKit/Source/core/css/properties/CSSPropertyCounterUtils.cpp |
new file mode 100644 |
index 0000000000000000000000000000000000000000..c93ca91a6d66a5301b8d99ac63999daf4f308d6d |
--- /dev/null |
+++ b/third_party/WebKit/Source/core/css/properties/CSSPropertyCounterUtils.cpp |
@@ -0,0 +1,38 @@ |
+// Copyright 2017 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. |
+ |
+#include "core/css/properties/CSSPropertyCounterUtils.h" |
+ |
+#include "core/css/CSSValueList.h" |
+#include "core/css/CSSValuePair.h" |
+#include "core/css/parser/CSSParserTokenRange.h" |
+#include "core/css/parser/CSSPropertyParserHelpers.h" |
+ |
+namespace blink { |
+ |
+CSSValue* CSSPropertyCounterUtils::consumeCounter( |
+ CSSParserTokenRange& range, |
+ CounterDefaultValue defaultValue) { |
+ if (range.peek().id() == CSSValueNone) |
+ return CSSPropertyParserHelpers::consumeIdent(range); |
+ |
+ CSSValueList* list = CSSValueList::createSpaceSeparated(); |
+ do { |
+ CSSCustomIdentValue* counterName = |
+ CSSPropertyParserHelpers::consumeCustomIdent(range); |
+ if (!counterName) |
+ return nullptr; |
+ int value = static_cast<int>(defaultValue); |
suzyh_UTC10 (ex-contributor)
2017/03/28 02:26:08
This int-iness enum-iness arrangement is a bit wei
|
+ if (CSSPrimitiveValue* counterValue = |
+ CSSPropertyParserHelpers::consumeInteger(range)) |
+ value = clampTo<int>(counterValue->getDoubleValue()); |
suzyh_UTC10 (ex-contributor)
2017/03/28 02:26:08
Would it make sense to use getIntValue() instead t
Bugs Nash
2017/03/28 02:32:50
I think we're experiencing creep here? This is a r
|
+ list->append(*CSSValuePair::create( |
+ counterName, |
+ CSSPrimitiveValue::create(value, CSSPrimitiveValue::UnitType::Integer), |
+ CSSValuePair::DropIdenticalValues)); |
+ } while (!range.atEnd()); |
+ return list; |
+} |
+ |
+} // namespace blink |