OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2004, 2005, 2007, 2008 Nikolas Zimmermann <zimmermann@kde.org> | 2 * Copyright (C) 2004, 2005, 2007, 2008 Nikolas Zimmermann <zimmermann@kde.org> |
3 * Copyright (C) 2004, 2005, 2006 Rob Buis <buis@kde.org> | 3 * Copyright (C) 2004, 2005, 2006 Rob Buis <buis@kde.org> |
4 * | 4 * |
5 * This library is free software; you can redistribute it and/or | 5 * This library is free software; you can redistribute it and/or |
6 * modify it under the terms of the GNU Library General Public | 6 * modify it under the terms of the GNU Library General Public |
7 * License as published by the Free Software Foundation; either | 7 * License as published by the Free Software Foundation; either |
8 * version 2 of the License, or (at your option) any later version. | 8 * version 2 of the License, or (at your option) any later version. |
9 * | 9 * |
10 * This library is distributed in the hope that it will be useful, | 10 * This library is distributed in the hope that it will be useful, |
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
57 ASSERT_NOT_REACHED(); | 57 ASSERT_NOT_REACHED(); |
58 } | 58 } |
59 | 59 |
60 void SVGGElement::svgAttributeChanged(const QualifiedName& attrName) | 60 void SVGGElement::svgAttributeChanged(const QualifiedName& attrName) |
61 { | 61 { |
62 if (!isSupportedAttribute(attrName)) { | 62 if (!isSupportedAttribute(attrName)) { |
63 SVGGraphicsElement::svgAttributeChanged(attrName); | 63 SVGGraphicsElement::svgAttributeChanged(attrName); |
64 return; | 64 return; |
65 } | 65 } |
66 | 66 |
67 SVGElementInstance::InvalidationGuard invalidationGuard(this); | 67 SVGElement::InvalidationGuard invalidationGuard(this); |
68 | 68 |
69 if (RenderObject* renderer = this->renderer()) | 69 if (RenderObject* renderer = this->renderer()) |
70 RenderSVGResource::markForLayoutAndParentResourceInvalidation(renderer); | 70 RenderSVGResource::markForLayoutAndParentResourceInvalidation(renderer); |
71 } | 71 } |
72 | 72 |
73 RenderObject* SVGGElement::createRenderer(RenderStyle* style) | 73 RenderObject* SVGGElement::createRenderer(RenderStyle* style) |
74 { | 74 { |
75 // SVG 1.1 testsuite explicitely uses constructs like <g display="none"><lin
earGradient> | 75 // SVG 1.1 testsuite explicitely uses constructs like <g display="none"><lin
earGradient> |
76 // We still have to create renderers for the <g> & <linearGradient> element,
though the | 76 // We still have to create renderers for the <g> & <linearGradient> element,
though the |
77 // subtree may be hidden - we only want the resource renderers to exist so t
hey can be | 77 // subtree may be hidden - we only want the resource renderers to exist so t
hey can be |
78 // referenced from somewhere else. | 78 // referenced from somewhere else. |
79 if (style->display() == NONE) | 79 if (style->display() == NONE) |
80 return new RenderSVGHiddenContainer(this); | 80 return new RenderSVGHiddenContainer(this); |
81 | 81 |
82 return new RenderSVGTransformableContainer(this); | 82 return new RenderSVGTransformableContainer(this); |
83 } | 83 } |
84 | 84 |
85 bool SVGGElement::rendererIsNeeded(const RenderStyle&) | 85 bool SVGGElement::rendererIsNeeded(const RenderStyle&) |
86 { | 86 { |
87 // Unlike SVGElement::rendererIsNeeded(), we still create renderers, even if | 87 // Unlike SVGElement::rendererIsNeeded(), we still create renderers, even if |
88 // display is set to 'none' - which is special to SVG <g> container elements
. | 88 // display is set to 'none' - which is special to SVG <g> container elements
. |
89 return parentOrShadowHostElement() && parentOrShadowHostElement()->isSVGElem
ent(); | 89 return parentOrShadowHostElement() && parentOrShadowHostElement()->isSVGElem
ent(); |
90 } | 90 } |
91 | 91 |
92 } | 92 } |
OLD | NEW |