Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(35)

Side by Side Diff: Source/core/animation/LengthBoxStyleInterpolation.cpp

Issue 1120003002: [Oilpan] Migrate most classes under core/animations to Oilpan heap. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Rebase Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/animation/LengthBoxStyleInterpolation.h" 6 #include "core/animation/LengthBoxStyleInterpolation.h"
7 7
8 #include "core/css/resolver/StyleBuilder.h" 8 #include "core/css/resolver/StyleBuilder.h"
9 9
10 namespace blink { 10 namespace blink {
11 11
12 namespace { 12 namespace {
13 13
14 bool onlyInterpolateBetweenLengthAndCSSValueAuto(Rect& startRect, Rect& endRect) 14 bool onlyInterpolateBetweenLengthAndCSSValueAuto(Rect& startRect, Rect& endRect)
15 { 15 {
16 return startRect.left()->isLength() != endRect.left()->isLength() 16 return startRect.left()->isLength() != endRect.left()->isLength()
17 && startRect.right()->isLength() != endRect.right()->isLength() 17 && startRect.right()->isLength() != endRect.right()->isLength()
18 && startRect.top()->isLength() != endRect.top()->isLength() 18 && startRect.top()->isLength() != endRect.top()->isLength()
19 && startRect.bottom()->isLength() != endRect.bottom()->isLength(); 19 && startRect.bottom()->isLength() != endRect.bottom()->isLength();
20 } 20 }
21 21
22 } // namespace 22 } // namespace
23 23
24 PassRefPtrWillBeRawPtr<LengthBoxStyleInterpolation> LengthBoxStyleInterpolation: :maybeCreateFrom(CSSValue& start, CSSValue& end, CSSPropertyID id) 24 LengthBoxStyleInterpolation* LengthBoxStyleInterpolation::maybeCreateFrom(CSSVal ue& start, CSSValue& end, CSSPropertyID id)
25 { 25 {
26 bool startRect = start.isPrimitiveValue() && toCSSPrimitiveValue(start).isRe ct(); 26 bool startRect = start.isPrimitiveValue() && toCSSPrimitiveValue(start).isRe ct();
27 bool endRect = end.isPrimitiveValue() && toCSSPrimitiveValue(end).isRect(); 27 bool endRect = end.isPrimitiveValue() && toCSSPrimitiveValue(end).isRect();
28 28
29 if (startRect && endRect) 29 if (startRect && endRect)
30 return adoptRefWillBeNoop(new LengthBoxStyleInterpolation(lengthBoxtoInt erpolableValue(start, end, false), lengthBoxtoInterpolableValue(end, start, true ), id, &start, &end)); 30 return new LengthBoxStyleInterpolation(lengthBoxtoInterpolableValue(star t, end, false), lengthBoxtoInterpolableValue(end, start, true), id, &start, &end );
31 return nullptr; 31 return nullptr;
32 } 32 }
33 33
34 PassOwnPtrWillBeRawPtr<InterpolableValue> LengthBoxStyleInterpolation::lengthBox toInterpolableValue(const CSSValue& lengthBox, const CSSValue& matchingValue, bo ol isEndInterpolation) 34 InterpolableValue* LengthBoxStyleInterpolation::lengthBoxtoInterpolableValue(con st CSSValue& lengthBox, const CSSValue& matchingValue, bool isEndInterpolation)
35 { 35 {
36 const int numberOfSides = 4; 36 const int numberOfSides = 4;
37 OwnPtrWillBeRawPtr<InterpolableList> result = InterpolableList::create(numbe rOfSides); 37 InterpolableList* result = InterpolableList::create(numberOfSides);
38 Rect* rect = toCSSPrimitiveValue(lengthBox).getRectValue(); 38 Rect* rect = toCSSPrimitiveValue(lengthBox).getRectValue();
39 Rect* matchingRect = toCSSPrimitiveValue(matchingValue).getRectValue(); 39 Rect* matchingRect = toCSSPrimitiveValue(matchingValue).getRectValue();
40 CSSPrimitiveValue* side[numberOfSides] = { rect->left(), rect->right(), rect ->top(), rect->bottom() }; 40 CSSPrimitiveValue* side[numberOfSides] = { rect->left(), rect->right(), rect ->top(), rect->bottom() };
41 CSSPrimitiveValue* matchingSide[numberOfSides] = { matchingRect->left(), mat chingRect->right(), matchingRect->top(), matchingRect->bottom() }; 41 CSSPrimitiveValue* matchingSide[numberOfSides] = { matchingRect->left(), mat chingRect->right(), matchingRect->top(), matchingRect->bottom() };
42 42
43 for (size_t i = 0; i < numberOfSides; i++) { 43 for (size_t i = 0; i < numberOfSides; i++) {
44 if (side[i]->isValueID() || matchingSide[i]->isValueID()) { 44 if (side[i]->isValueID() || matchingSide[i]->isValueID()) {
45 result->set(i, InterpolableBool::create(isEndInterpolation)); 45 result->set(i, InterpolableBool::create(isEndInterpolation));
46 } else { 46 } else {
47 ASSERT(LengthStyleInterpolation::canCreateFrom(*side[i])); 47 ASSERT(LengthStyleInterpolation::canCreateFrom(*side[i]));
48 result->set(i, LengthStyleInterpolation::toInterpolableValue(*side[i ])); 48 result->set(i, LengthStyleInterpolation::toInterpolableValue(*side[i ]));
49 } 49 }
50 } 50 }
51 return result.release(); 51 return result;
52 } 52 }
53 53
54 bool LengthBoxStyleInterpolation::usesDefaultInterpolation(const CSSValue& start , const CSSValue& end) 54 bool LengthBoxStyleInterpolation::usesDefaultInterpolation(const CSSValue& start , const CSSValue& end)
55 { 55 {
56 if (!start.isPrimitiveValue() || !end.isPrimitiveValue()) 56 if (!start.isPrimitiveValue() || !end.isPrimitiveValue())
57 return false; 57 return false;
58 const CSSPrimitiveValue& startValue = toCSSPrimitiveValue(start); 58 const CSSPrimitiveValue& startValue = toCSSPrimitiveValue(start);
59 const CSSPrimitiveValue& endValue = toCSSPrimitiveValue(end); 59 const CSSPrimitiveValue& endValue = toCSSPrimitiveValue(end);
60 if ((startValue.isValueID() && startValue.getValueID() == CSSValueAuto) 60 if ((startValue.isValueID() && startValue.getValueID() == CSSValueAuto)
61 || (endValue.isValueID() && endValue.getValueID() == CSSValueAuto)) 61 || (endValue.isValueID() && endValue.getValueID() == CSSValueAuto))
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
97 void LengthBoxStyleInterpolation::apply(StyleResolverState& state) const 97 void LengthBoxStyleInterpolation::apply(StyleResolverState& state) const
98 { 98 {
99 if (m_cachedValue.get()->isBool()) 99 if (m_cachedValue.get()->isBool())
100 StyleBuilder::applyProperty(m_id, state, toInterpolableBool(m_cachedValu e.get())->value() ? m_endCSSValue.get() : m_startCSSValue.get()); 100 StyleBuilder::applyProperty(m_id, state, toInterpolableBool(m_cachedValu e.get())->value() ? m_endCSSValue.get() : m_startCSSValue.get());
101 else 101 else
102 StyleBuilder::applyProperty(m_id, state, interpolableValueToLengthBox(m_ cachedValue.get(), *m_startCSSValue, *m_endCSSValue).get()); 102 StyleBuilder::applyProperty(m_id, state, interpolableValueToLengthBox(m_ cachedValue.get(), *m_startCSSValue, *m_endCSSValue).get());
103 } 103 }
104 104
105 DEFINE_TRACE(LengthBoxStyleInterpolation) 105 DEFINE_TRACE(LengthBoxStyleInterpolation)
106 { 106 {
107 StyleInterpolation::trace(visitor);
108 visitor->trace(m_startCSSValue); 107 visitor->trace(m_startCSSValue);
109 visitor->trace(m_endCSSValue); 108 visitor->trace(m_endCSSValue);
109
110 StyleInterpolation::trace(visitor);
110 } 111 }
111 112
112 } 113 }
OLDNEW
« no previous file with comments | « Source/core/animation/LengthBoxStyleInterpolation.h ('k') | Source/core/animation/LengthBoxStyleInterpolationTest.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698