Bug 196025

Summary: Remove the SVG tear off objects for SVGColorAnimator
Product: WebKit Reporter: Said Abou-Hallawa <sabouhallawa>
Component: SVGAssignee: Said Abou-Hallawa <sabouhallawa>
Status: RESOLVED FIXED    
Severity: Normal CC: jonlee, simon.fraser, webkit-bug-importer, zimmermann
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Bug Depends on: 195960    
Bug Blocks: 191237, 196037    
Attachments:
Description Flags
Patch none

Said Abou-Hallawa
Reported 2019-03-20 13:13:57 PDT
SVG attributes like "fill" and "stroke" do not have reflecting properties in SVGElement but they are animatable by SMIL. Since there is no animated properties for these attributes, a temporary variable must be created and initialized with the attribute value. This The value of this variable is progressed during the animation interval. The new progressed value has to be pushed to SVGElementRareData during the animation. When animation stops, the attribute and its animated value is removed from SVGElementRareData. Because the attribute can be animated by multiple animators, all the multiple animators must reference the same temporary variable. A new animator named SVGColorAnimator will be created. The creator SVGPropertyAnimatorCreator will keep a RefCounted object for the temporary variable in a HashMap which is indexed by the attribute name. A new entry is created and appended to this HashMap when the first animator is created. An existing entry will be removed when the last animator is removed.
Attachments
Patch (57.52 KB, patch)
2019-03-20 13:47 PDT, Said Abou-Hallawa
no flags
Said Abou-Hallawa
Comment 1 2019-03-20 13:47:22 PDT
Simon Fraser (smfr)
Comment 2 2019-03-20 16:15:12 PDT
Comment on attachment 365394 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=365394&action=review > Source/WebCore/ChangeLog:44 > + -- SVGPropertyAnimatorCreator checks its HashMap it has an entry for the checks whether its HashMap has an entry > Source/WebCore/ChangeLog:53 > + SVGElement about that which will notify its SVGPropertyAnimatorCreator. Remove "about that" > Source/WebCore/svg/properties/SVGAnimationAdditiveValueFunctionImpl.cpp:38 > + static NeverDestroyed<const AtomicString> currentColor("currentColor", AtomicString::ConstructFromLiteral); > + > + if (string != currentColor.get()) Not sure why this uses AtomicString; this code does an explicit string compare, so doesn't atomic-ness. > Source/WebCore/svg/properties/SVGPropertyAnimatorCreator.h:33 > +class SVGPropertyAnimatorCreator { Classes that make things are usually called "factories". So SVGPropertyAnimatorFactory > Source/WebCore/svg/properties/SVGPropertyAnimatorCreator.h:63 > + // If refCount = 1 (in the animator) + 1 (in m_attributeProperty) = 2, the entry can be deleted. > + if (iterator->value->refCount() == 2) > + m_attributeProperty.remove(iterator); Removing based on looking at refCounts feels a bit icky.
Said Abou-Hallawa
Comment 3 2019-03-20 16:35:56 PDT
Comment on attachment 365394 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=365394&action=review >> Source/WebCore/ChangeLog:44 >> + -- SVGPropertyAnimatorCreator checks its HashMap it has an entry for the > > checks whether its HashMap has an entry Fixed. >> Source/WebCore/svg/properties/SVGAnimationAdditiveValueFunctionImpl.cpp:38 >> + if (string != currentColor.get()) > > Not sure why this uses AtomicString; this code does an explicit string compare, so doesn't atomic-ness. static variable is converted to NeverDestroyed<const String>. >> Source/WebCore/svg/properties/SVGPropertyAnimatorCreator.h:33 >> +class SVGPropertyAnimatorCreator { > > Classes that make things are usually called "factories". So SVGPropertyAnimatorFactory Done. >> Source/WebCore/svg/properties/SVGPropertyAnimatorCreator.h:63 >> + m_attributeProperty.remove(iterator); > > Removing based on looking at refCounts feels a bit icky. I will think about it.
Radar WebKit Bug Importer
Comment 4 2019-03-20 16:38:22 PDT
Said Abou-Hallawa
Comment 5 2019-03-20 16:52:06 PDT
Note You need to log in before you can comment on or make changes to this bug.