Use "= default" to denote default constructor or destructor
[WebKit-https.git] / Source / WebCore / svg / SVGAnimatedTypeAnimator.cpp
1 /*
2  * Copyright (C) Research In Motion Limited 2011-2012. All rights reserved.
3  * Copyright (C) 2013 Samsung Electronics. All rights reserved.
4  *
5  * This library is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU Library General Public
7  * License as published by the Free Software Foundation; either
8  * version 2 of the License, or (at your option) any later version.
9  *
10  * This library is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13  * Library General Public License for more details.
14  *
15  * You should have received a copy of the GNU Library General Public License
16  * along with this library; see the file COPYING.LIB.  If not, write to
17  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
18  * Boston, MA 02110-1301, USA.
19  */
20
21
22 #include "config.h"
23 #include "SVGAnimatedTypeAnimator.h"
24
25 #include "SVGAttributeToPropertyMap.h"
26 #include "SVGElement.h"
27
28 namespace WebCore {
29
30 SVGAnimatedTypeAnimator::SVGAnimatedTypeAnimator(AnimatedPropertyType type, SVGAnimationElement* animationElement, SVGElement* contextElement)
31     : m_type(type)
32     , m_animationElement(animationElement)
33     , m_contextElement(contextElement)
34 {
35 }
36
37 SVGAnimatedTypeAnimator::~SVGAnimatedTypeAnimator() = default;
38
39 void SVGAnimatedTypeAnimator::calculateFromAndToValues(std::unique_ptr<SVGAnimatedType>& from, std::unique_ptr<SVGAnimatedType>& to, const String& fromString, const String& toString)
40 {
41     from = constructFromString(fromString);
42     to = constructFromString(toString);
43 }
44
45 void SVGAnimatedTypeAnimator::calculateFromAndByValues(std::unique_ptr<SVGAnimatedType>& from, std::unique_ptr<SVGAnimatedType>& to, const String& fromString, const String& byString)
46 {
47     from = constructFromString(fromString);
48     to = constructFromString(byString);
49     addAnimatedTypes(from.get(), to.get());
50 }
51
52 SVGElementAnimatedPropertyList SVGAnimatedTypeAnimator::findAnimatedPropertiesForAttributeName(SVGElement& targetElement, const QualifiedName& attributeName)
53 {
54     SVGElementAnimatedPropertyList result;
55
56     if (!SVGAnimatedType::supportsAnimVal(m_type))
57         return result;
58
59     auto& propertyMap = targetElement.localAttributeToPropertyMap();
60     auto targetProperties = propertyMap.properties(targetElement, attributeName);
61
62     if (targetProperties.isEmpty())
63         return result;
64
65     result.append(SVGElementAnimatedProperties { &targetElement, WTFMove(targetProperties) });
66
67     for (SVGElement* instance : targetElement.instances())
68         result.append(SVGElementAnimatedProperties { instance, propertyMap.properties(*instance, attributeName) });
69
70 #if !ASSERT_DISABLED
71     for (auto& animatedProperties : result) {
72         for (auto& property : animatedProperties.properties) {
73             if (property->animatedPropertyType() != m_type) {
74                 ASSERT(m_type == AnimatedAngle);
75                 ASSERT(property->animatedPropertyType() == AnimatedEnumeration);
76             }
77         }
78     }
79 #endif
80
81     return result;
82 }
83
84 void SVGAnimatedTypeAnimator::setInstanceUpdatesBlocked(SVGElement& element, bool blocked)
85 {
86     element.setInstanceUpdatesBlocked(blocked);
87 }
88
89 } // namespace WebCore