| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2006 Nikolas Zimmermann <zimmermann@kde.org> | 2 * Copyright (C) 2006 Nikolas Zimmermann <zimmermann@kde.org> |
| 3 * Copyright (C) 2007 Rob Buis <buis@kde.org> | 3 * Copyright (C) 2007 Rob Buis <buis@kde.org> |
| 4 * Copyright (C) 2008 Dirk Schulze <krit@webkit.org> | 4 * Copyright (C) 2008 Dirk Schulze <krit@webkit.org> |
| 5 * Copyright (C) Research In Motion Limited 2010. All rights reserved. | 5 * Copyright (C) Research In Motion Limited 2010. All rights reserved. |
| 6 * | 6 * |
| 7 * This library is free software; you can redistribute it and/or | 7 * This library is free software; you can redistribute it and/or |
| 8 * modify it under the terms of the GNU Library General Public | 8 * modify it under the terms of the GNU Library General Public |
| 9 * License as published by the Free Software Foundation; either | 9 * License as published by the Free Software Foundation; either |
| 10 * version 2 of the License, or (at your option) any later version. | 10 * version 2 of the License, or (at your option) any later version. |
| (...skipping 165 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 176 | 176 |
| 177 if (RenderSVGResourceMasker* masker = resources->masker()) | 177 if (RenderSVGResourceMasker* masker = resources->masker()) |
| 178 masker->removeClientFromCache(object); | 178 masker->removeClientFromCache(object); |
| 179 | 179 |
| 180 if (RenderSVGResourceClipper* clipper = resources->clipper()) | 180 if (RenderSVGResourceClipper* clipper = resources->clipper()) |
| 181 clipper->removeClientFromCache(object); | 181 clipper->removeClientFromCache(object); |
| 182 } | 182 } |
| 183 | 183 |
| 184 if (!object->node() || !object->node()->isSVGElement()) | 184 if (!object->node() || !object->node()->isSVGElement()) |
| 185 return; | 185 return; |
| 186 SVGElementSet* dependencies = object->document().accessSVGExtensions().setOf
ElementsReferencingTarget(toSVGElement(object->node())); | 186 SVGElementSet* dependencies = toSVGElement(object->node())->setOfIncomingRef
erences(); |
| 187 if (!dependencies) | 187 if (!dependencies) |
| 188 return; | 188 return; |
| 189 | 189 |
| 190 // We allow cycles in SVGDocumentExtensions reference sets in order to avoid
expensive | 190 // We allow cycles in SVGDocumentExtensions reference sets in order to avoid
expensive |
| 191 // reference graph adjustments on changes, so we need to break possible cycl
es here. | 191 // reference graph adjustments on changes, so we need to break possible cycl
es here. |
| 192 // This strong reference is safe, as it is guaranteed that this set will be
emptied | 192 // This strong reference is safe, as it is guaranteed that this set will be
emptied |
| 193 // at the end of recursion. | 193 // at the end of recursion. |
| 194 typedef WillBeHeapHashSet<RawPtrWillBeMember<SVGElement> > SVGElementSet; | 194 typedef WillBeHeapHashSet<RawPtrWillBeMember<SVGElement> > SVGElementSet; |
| 195 DEFINE_STATIC_LOCAL(OwnPtrWillBePersistent<SVGElementSet>, invalidatingDepen
dencies, (adoptPtrWillBeNoop(new SVGElementSet))); | 195 DEFINE_STATIC_LOCAL(OwnPtrWillBePersistent<SVGElementSet>, invalidatingDepen
dencies, (adoptPtrWillBeNoop(new SVGElementSet))); |
| 196 | 196 |
| (...skipping 30 matching lines...) Expand all Loading... |
| 227 // This will process the rest of the ancestors. | 227 // This will process the rest of the ancestors. |
| 228 toRenderSVGResourceContainer(current)->removeAllClientsFromCache(); | 228 toRenderSVGResourceContainer(current)->removeAllClientsFromCache(); |
| 229 break; | 229 break; |
| 230 } | 230 } |
| 231 | 231 |
| 232 current = current->parent(); | 232 current = current->parent(); |
| 233 } | 233 } |
| 234 } | 234 } |
| 235 | 235 |
| 236 } | 236 } |
| OLD | NEW |