Use #pragma once in WebCore
[WebKit-https.git] / Source / WebCore / svg / SVGGraphicsElement.h
1 /*
2  * Copyright (C) 2004, 2005, 2008 Nikolas Zimmermann <zimmermann@kde.org>
3  * Copyright (C) 2004, 2005, 2006, 2007 Rob Buis <buis@kde.org>
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 #pragma once
22
23 #include "SVGAnimatedTransformList.h"
24 #include "SVGElement.h"
25 #include "SVGTests.h"
26 #include "SVGTransformable.h"
27
28 namespace WebCore {
29
30 class AffineTransform;
31 class Path;
32
33 class SVGGraphicsElement : public SVGElement, public SVGTransformable, public SVGTests {
34 public:
35     virtual ~SVGGraphicsElement();
36
37     AffineTransform getCTM(StyleUpdateStrategy = AllowStyleUpdate) override;
38     AffineTransform getScreenCTM(StyleUpdateStrategy = AllowStyleUpdate) override;
39     SVGElement* nearestViewportElement() const override;
40     SVGElement* farthestViewportElement() const override;
41
42     AffineTransform localCoordinateSpaceTransform(SVGLocatable::CTMScope mode) const override { return SVGTransformable::localCoordinateSpaceTransform(mode); }
43     AffineTransform animatedLocalTransform() const override;
44     AffineTransform* supplementalTransform() override;
45
46     FloatRect getBBox(StyleUpdateStrategy = AllowStyleUpdate) override;
47
48     bool shouldIsolateBlending() const { return m_shouldIsolateBlending; }
49     void setShouldIsolateBlending(bool isolate) { m_shouldIsolateBlending = isolate; }
50
51     // "base class" methods for all the elements which render as paths
52     virtual void toClipPath(Path&);
53     RenderPtr<RenderElement> createElementRenderer(RenderStyle&&, const RenderTreePosition&) override;
54
55     size_t approximateMemoryCost() const override { return sizeof(*this); }
56
57 protected:
58     SVGGraphicsElement(const QualifiedName&, Document&);
59
60     bool supportsFocus() const override { return Element::supportsFocus() || hasFocusEventListeners(); }
61
62     void parseAttribute(const QualifiedName&, const AtomicString&) override;
63     void svgAttributeChanged(const QualifiedName&) override;
64
65     BEGIN_DECLARE_ANIMATED_PROPERTIES(SVGGraphicsElement)
66         DECLARE_ANIMATED_TRANSFORM_LIST(Transform, transform)
67     END_DECLARE_ANIMATED_PROPERTIES
68
69 private:
70     bool isSVGGraphicsElement() const override { return true; }
71
72     static bool isSupportedAttribute(const QualifiedName&);
73
74     // SVGTests
75     void synchronizeRequiredFeatures() override { SVGTests::synchronizeRequiredFeatures(this); }
76     void synchronizeRequiredExtensions() override { SVGTests::synchronizeRequiredExtensions(this); }
77     void synchronizeSystemLanguage() override { SVGTests::synchronizeSystemLanguage(this); }
78
79     // Used by <animateMotion>
80     std::unique_ptr<AffineTransform> m_supplementalTransform;
81
82     // Used to isolate blend operations caused by masking.
83     bool m_shouldIsolateBlending;
84 };
85
86 } // namespace WebCore
87
88 SPECIALIZE_TYPE_TRAITS_BEGIN(WebCore::SVGGraphicsElement)
89     static bool isType(const WebCore::SVGElement& element) { return element.isSVGGraphicsElement(); }
90     static bool isType(const WebCore::Node& node) { return is<WebCore::SVGElement>(node) && isType(downcast<WebCore::SVGElement>(node)); }
91 SPECIALIZE_TYPE_TRAITS_END()