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

Side by Side Diff: Source/core/rendering/svg/RenderSVGResourceContainer.h

Issue 898783003: Move rendering/RenderLayer* to layout/ (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Created 5 years, 10 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 | Annotate | Revision Log
OLDNEW
1 /* 1 /*
2 * Copyright (C) Research In Motion Limited 2010. All rights reserved. 2 * Copyright (C) Research In Motion Limited 2010. All rights reserved.
3 * 3 *
4 * This library is free software; you can redistribute it and/or 4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Library General Public 5 * modify it under the terms of the GNU Library General Public
6 * License as published by the Free Software Foundation; either 6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version. 7 * version 2 of the License, or (at your option) any later version.
8 * 8 *
9 * This library is distributed in the hope that it will be useful, 9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
(...skipping 17 matching lines...) Expand all
28 enum RenderSVGResourceType { 28 enum RenderSVGResourceType {
29 MaskerResourceType, 29 MaskerResourceType,
30 MarkerResourceType, 30 MarkerResourceType,
31 PatternResourceType, 31 PatternResourceType,
32 LinearGradientResourceType, 32 LinearGradientResourceType,
33 RadialGradientResourceType, 33 RadialGradientResourceType,
34 FilterResourceType, 34 FilterResourceType,
35 ClipperResourceType 35 ClipperResourceType
36 }; 36 };
37 37
38 class RenderLayer; 38 class Layer;
39 39
40 class RenderSVGResourceContainer : public RenderSVGHiddenContainer { 40 class RenderSVGResourceContainer : public RenderSVGHiddenContainer {
41 public: 41 public:
42 explicit RenderSVGResourceContainer(SVGElement*); 42 explicit RenderSVGResourceContainer(SVGElement*);
43 virtual ~RenderSVGResourceContainer(); 43 virtual ~RenderSVGResourceContainer();
44 44
45 virtual void removeAllClientsFromCache(bool markForInvalidation = true) = 0; 45 virtual void removeAllClientsFromCache(bool markForInvalidation = true) = 0;
46 virtual void removeClientFromCache(RenderObject*, bool markForInvalidation = true) = 0; 46 virtual void removeClientFromCache(RenderObject*, bool markForInvalidation = true) = 0;
47 47
48 virtual void layout() override; 48 virtual void layout() override;
49 virtual void styleDidChange(StyleDifference, const RenderStyle* oldStyle) ov erride final; 49 virtual void styleDidChange(StyleDifference, const RenderStyle* oldStyle) ov erride final;
50 virtual bool isOfType(RenderObjectType type) const override { return type == RenderObjectSVGResourceContainer || RenderSVGHiddenContainer::isOfType(type); } 50 virtual bool isOfType(RenderObjectType type) const override { return type == RenderObjectSVGResourceContainer || RenderSVGHiddenContainer::isOfType(type); }
51 51
52 virtual RenderSVGResourceType resourceType() const = 0; 52 virtual RenderSVGResourceType resourceType() const = 0;
53 53
54 bool isSVGPaintServer() const 54 bool isSVGPaintServer() const
55 { 55 {
56 RenderSVGResourceType resourceType = this->resourceType(); 56 RenderSVGResourceType resourceType = this->resourceType();
57 return resourceType == PatternResourceType 57 return resourceType == PatternResourceType
58 || resourceType == LinearGradientResourceType 58 || resourceType == LinearGradientResourceType
59 || resourceType == RadialGradientResourceType; 59 || resourceType == RadialGradientResourceType;
60 } 60 }
61 61
62 void idChanged(); 62 void idChanged();
63 void addClientRenderLayer(Node*); 63 void addClientLayer(Node*);
64 void addClientRenderLayer(RenderLayer*); 64 void addClientLayer(Layer*);
65 void removeClientRenderLayer(RenderLayer*); 65 void removeClientLayer(Layer*);
66 66
67 void invalidateCacheAndMarkForLayout(SubtreeLayoutScope* = 0); 67 void invalidateCacheAndMarkForLayout(SubtreeLayoutScope* = 0);
68 68
69 static void markForLayoutAndParentResourceInvalidation(RenderObject*, bool n eedsLayout = true); 69 static void markForLayoutAndParentResourceInvalidation(RenderObject*, bool n eedsLayout = true);
70 70
71 protected: 71 protected:
72 // When adding modes, make sure we don't overflow m_invalidationMask below. 72 // When adding modes, make sure we don't overflow m_invalidationMask below.
73 enum InvalidationMode { 73 enum InvalidationMode {
74 LayoutAndBoundariesInvalidation = 1 << 0, 74 LayoutAndBoundariesInvalidation = 1 << 0,
75 BoundariesInvalidation = 1 << 1, 75 BoundariesInvalidation = 1 << 1,
(...skipping 20 matching lines...) Expand all
96 96
97 AtomicString m_id; 97 AtomicString m_id;
98 // Track global (markAllClientsForInvalidation) invals to avoid redundant cr awls. 98 // Track global (markAllClientsForInvalidation) invals to avoid redundant cr awls.
99 unsigned m_invalidationMask : 8; 99 unsigned m_invalidationMask : 8;
100 100
101 unsigned m_registered : 1; 101 unsigned m_registered : 1;
102 unsigned m_isInvalidating : 1; 102 unsigned m_isInvalidating : 1;
103 // 22 padding bits available 103 // 22 padding bits available
104 104
105 HashSet<RenderObject*> m_clients; 105 HashSet<RenderObject*> m_clients;
106 HashSet<RenderLayer*> m_clientLayers; 106 HashSet<Layer*> m_clientLayers;
107 }; 107 };
108 108
109 inline RenderSVGResourceContainer* getRenderSVGResourceContainerById(TreeScope& treeScope, const AtomicString& id) 109 inline RenderSVGResourceContainer* getRenderSVGResourceContainerById(TreeScope& treeScope, const AtomicString& id)
110 { 110 {
111 if (id.isEmpty()) 111 if (id.isEmpty())
112 return 0; 112 return 0;
113 113
114 if (RenderSVGResourceContainer* renderResource = treeScope.document().access SVGExtensions().resourceById(id)) 114 if (RenderSVGResourceContainer* renderResource = treeScope.document().access SVGExtensions().resourceById(id))
115 return renderResource; 115 return renderResource;
116 116
(...skipping 11 matching lines...) Expand all
128 } 128 }
129 129
130 DEFINE_RENDER_OBJECT_TYPE_CASTS(RenderSVGResourceContainer, isSVGResourceContain er()); 130 DEFINE_RENDER_OBJECT_TYPE_CASTS(RenderSVGResourceContainer, isSVGResourceContain er());
131 131
132 #define DEFINE_RENDER_SVG_RESOURCE_TYPE_CASTS(thisType, typeName) \ 132 #define DEFINE_RENDER_SVG_RESOURCE_TYPE_CASTS(thisType, typeName) \
133 DEFINE_TYPE_CASTS(thisType, RenderSVGResourceContainer, resource, resource-> resourceType() == typeName, resource.resourceType() == typeName) 133 DEFINE_TYPE_CASTS(thisType, RenderSVGResourceContainer, resource, resource-> resourceType() == typeName, resource.resourceType() == typeName)
134 134
135 } 135 }
136 136
137 #endif 137 #endif
OLDNEW
« no previous file with comments | « Source/core/rendering/svg/RenderSVGModelObject.cpp ('k') | Source/core/rendering/svg/RenderSVGResourceContainer.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698