Upstream version 9.37.197.0
[platform/framework/web/crosswalk.git] / src / third_party / WebKit / Source / core / animation / AnimatableValueTestHelper.cpp
1 /*
2  * Copyright (c) 2013, Google Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are
6  * met:
7  *
8  *     * Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  *     * Redistributions in binary form must reproduce the above
11  * copyright notice, this list of conditions and the following disclaimer
12  * in the documentation and/or other materials provided with the
13  * distribution.
14  *     * Neither the name of Google Inc. nor the names of its
15  * contributors may be used to endorse or promote products derived from
16  * this software without specific prior written permission.
17  *
18  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
22  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29  */
30
31 #include "config.h"
32
33 #include "core/animation/AnimatableValueTestHelper.h"
34
35 namespace WebCore {
36
37 bool operator==(const AnimatableValue& a, const AnimatableValue& b)
38 {
39     return a.equals(b);
40 }
41
42 void PrintTo(const AnimatableClipPathOperation& animValue, ::std::ostream* os)
43 {
44     *os << "AnimatableClipPathOperation@" << &animValue;
45 }
46
47 void PrintTo(const AnimatableColor& animColor, ::std::ostream* os)
48 {
49     *os << "AnimatableColor("
50         << animColor.color().serialized().utf8().data() << ", "
51         << animColor.visitedLinkColor().serialized().utf8().data() << ")";
52 }
53
54 void PrintTo(const AnimatableImage& animImage, ::std::ostream* os)
55 {
56     PrintTo(*(animImage.toCSSValue()), os, "AnimatableImage");
57 }
58
59 void PrintTo(const AnimatableNeutral& animValue, ::std::ostream* os)
60 {
61     *os << "AnimatableNeutral@" << &animValue;
62 }
63
64 void PrintTo(const AnimatableRepeatable& animValue, ::std::ostream* os)
65 {
66     *os << "AnimatableRepeatable(";
67
68     const WillBeHeapVector<RefPtrWillBeMember<AnimatableValue> > v = animValue.values();
69     for (WillBeHeapVector<RefPtrWillBeMember<AnimatableValue> >::const_iterator it = v.begin(); it != v.end(); ++it) {
70         PrintTo(*(it->get()), os);
71         if (it+1 != v.end())
72             *os << ", ";
73     }
74     *os << ")";
75 }
76
77 void PrintTo(const AnimatableSVGLength& animSVGLength, ::std::ostream* os)
78 {
79     *os << "AnimatableSVGLength("
80         << animSVGLength.toSVGLength()->valueAsString().utf8().data() << ")";
81 }
82
83 void PrintTo(const AnimatableShapeValue& animValue, ::std::ostream* os)
84 {
85     *os << "AnimatableShapeValue@" << &animValue;
86 }
87
88 void PrintTo(const AnimatableStrokeDasharrayList& animValue, ::std::ostream* os)
89 {
90     *os << "AnimatableStrokeDasharrayList(";
91     RefPtr<SVGLengthList> list = animValue.toSVGLengthList();
92     size_t length = list->length();
93     for (size_t i = 0; i < length; ++i) {
94         *os << list->at(i)->valueAsString().utf8().data();
95         if (i != length-1)
96             *os << ", ";
97     }
98     *os << ")";
99 }
100
101 void PrintTo(const AnimatableTransform& animTransform, ::std::ostream* os)
102 {
103     TransformOperations ops = animTransform.transformOperations();
104
105     *os << "AnimatableTransform(";
106     // FIXME: TransformOperations should really have it's own pretty-printer
107     // then we could just call that.
108     // FIXME: Output useful names not just the raw matrixes.
109     for (unsigned i = 0; i < ops.size(); i++) {
110         const TransformOperation* op = ops.at(i);
111
112         TransformationMatrix matrix;
113         op->apply(matrix, FloatSize(1.0, 1.0));
114
115         *os << "[";
116         if (matrix.isAffine()) {
117             *os << matrix.a();
118             *os << " " << matrix.b();
119             *os << " " << matrix.c();
120             *os << " " << matrix.d();
121             *os << " " << matrix.e();
122             *os << " " << matrix.f();
123         } else {
124             *os << matrix.m11();
125             *os << " " << matrix.m12();
126             *os << " " << matrix.m13();
127             *os << " " << matrix.m14();
128             *os << " ";
129             *os << " " << matrix.m21();
130             *os << " " << matrix.m22();
131             *os << " " << matrix.m23();
132             *os << " " << matrix.m24();
133             *os << " ";
134             *os << " " << matrix.m31();
135             *os << " " << matrix.m32();
136             *os << " " << matrix.m33();
137             *os << " " << matrix.m34();
138             *os << " ";
139             *os << " " << matrix.m41();
140             *os << " " << matrix.m42();
141             *os << " " << matrix.m43();
142             *os << " " << matrix.m44();
143         }
144         *os << "]";
145         if (i < ops.size() - 1)
146             *os << ", ";
147     }
148     *os << ")";
149 }
150
151 void PrintTo(const AnimatableUnknown& animUnknown, ::std::ostream* os)
152 {
153     PrintTo(*(animUnknown.toCSSValue().get()), os, "AnimatableUnknown");
154 }
155
156 void PrintTo(const AnimatableVisibility& animVisibility, ::std::ostream* os)
157 {
158     *os << "AnimatableVisibility(";
159     switch (animVisibility.visibility()) {
160     case VISIBLE:
161         *os << "VISIBLE";
162         break;
163     case HIDDEN:
164         *os << "HIDDEN";
165         break;
166     case COLLAPSE:
167         *os << "COLLAPSE";
168         break;
169     default:
170         *os << "Unknown Visbilility - update switch in AnimatableValueTestHelper.h";
171     }
172     *os << ")";
173 }
174
175 void PrintTo(const AnimatableValue& animValue, ::std::ostream* os)
176 {
177     if (animValue.isClipPathOperation())
178         PrintTo(*(toAnimatableClipPathOperation(&animValue)), os);
179     else if (animValue.isColor())
180         PrintTo(*(toAnimatableColor(&animValue)), os);
181     else if (animValue.isImage())
182         PrintTo(*(toAnimatableImage(&animValue)), os);
183     else if (animValue.isNeutral())
184         PrintTo(*(static_cast<const AnimatableNeutral*>(&animValue)), os);
185     else if (animValue.isRepeatable())
186         PrintTo(*(toAnimatableRepeatable(&animValue)), os);
187     else if (animValue.isSVGLength())
188         PrintTo(*(toAnimatableSVGLength(&animValue)), os);
189     else if (animValue.isSVGPaint())
190         PrintTo(*(toAnimatableSVGPaint(&animValue)), os);
191     else if (animValue.isShapeValue())
192         PrintTo(*(toAnimatableShapeValue(&animValue)), os);
193     else if (animValue.isStrokeDasharrayList())
194         PrintTo(*(toAnimatableStrokeDasharrayList(&animValue)), os);
195     else if (animValue.isTransform())
196         PrintTo(*(toAnimatableTransform(&animValue)), os);
197     else if (animValue.isUnknown())
198         PrintTo(*(toAnimatableUnknown(&animValue)), os);
199     else if (animValue.isVisibility())
200         PrintTo(*(toAnimatableVisibility(&animValue)), os);
201     else
202         *os << "Unknown AnimatableValue - update ifelse chain in AnimatableValueTestHelper.h";
203 }
204
205 } // namespace WebCore