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

Issue 14022022: FINALizing of the Node hierarchy. (Closed)

Created:
7 years, 7 months ago by Chris Evans
Modified:
7 years, 7 months ago
CC:
blink-reviews, gavinp+prerender_chromium.org, jsbell, pdr, abarth-chromium, feature-media-reviews_chromium.org, f(malita), gavinp+loader_chromium.org, haraken, Stephen Chennney, Nate Chapin, vcarbune.chromium
Visibility:
Public.

Description

FINALizing of the Node hierarchy. A couple of the stable DOM/ microbenchmarks are perf positive on Linux clang: - CloneNodes time reduced from 162.4 to 156.5 ms. - CreateNodes time reduced from 113.9 to 104.9 ms. (Don't get too excited; official Linux builds still use GCC, v4.6 as far as I know, which does not support final yet. The GCC 4.6 scores are 170ms and 98ms. Interesting that GCC + nofinal is faster on CreateNodes that clang + final, and slower than clang + nofinal on CloneNodes). TEST=wktry compiles R=eseidel@chromium.org, esprehn@chromium.org Committed: https://src.chromium.org/viewvc/blink?view=rev&revision=149454

Patch Set 1 #

Total comments: 7

Patch Set 2 : Action review comments. #

Unified diffs Side-by-side diffs Delta from patch set Stats (+331 lines, -331 lines) Patch
M Source/bindings/v8/ScriptWrappable.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/dom/Attr.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/dom/CDATASection.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/dom/CharacterData.h View 1 chunk +5 lines, -5 lines 0 comments Download
M Source/core/dom/Comment.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/dom/ContainerNode.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/dom/DocumentType.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/dom/Element.h View 1 5 chunks +10 lines, -10 lines 0 comments Download
M Source/core/dom/EntityReference.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/dom/Notation.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/dom/ProcessingInstruction.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/dom/PseudoElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/dom/ShadowRoot.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/dom/TemplateContentDocumentFragment.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/dom/Text.h View 2 chunks +6 lines, -6 lines 0 comments Download
M Source/core/html/HTMLAppletElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLAreaElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLAudioElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLBDIElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLBRElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLBaseElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLBaseFontElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLBodyElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLButtonElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLCanvasElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLDListElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLDataListElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLDetailsElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLDialogElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLDirectoryElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLElement.h View 1 2 chunks +2 lines, -2 lines 0 comments Download
M Source/core/html/HTMLEmbedElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLFieldSetElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLFontElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLFormElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLFrameElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLFrameSetElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLHRElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLHeadElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLHeadingElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLHtmlElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLIFrameElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLKeygenElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLKeygenElement.cpp View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLLIElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLLabelElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLLegendElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLLinkElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLMapElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLMarqueeElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLMenuElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLMetaElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLMeterElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLModElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLOListElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLObjectElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLOptGroupElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLOptionElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLOutputElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLParagraphElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLParamElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLPreElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLProgressElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLQuoteElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLScriptElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLSourceElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLStyleElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLSummaryElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLTableCaptionElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLTableCellElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLTableColElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLTableElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLTableRowElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLTableSectionElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLTemplateElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLTextAreaElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLTitleElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLTrackElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLUListElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLUnknownElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLVideoElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/HTMLViewSourceDocument.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/ImageDocument.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/ImageDocument.cpp View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/MediaDocument.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/PluginDocument.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/TextDocument.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/shadow/ClearButtonElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/shadow/DateTimeEditElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/shadow/DateTimeFieldElements.h View 13 chunks +13 lines, -13 lines 0 comments Download
M Source/core/html/shadow/DetailsMarkerControl.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/shadow/HTMLContentElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/shadow/HTMLShadowElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/shadow/MediaControlElements.h View 16 chunks +16 lines, -16 lines 0 comments Download
M Source/core/html/shadow/MeterShadowElement.h View 3 chunks +3 lines, -3 lines 0 comments Download
M Source/core/html/shadow/PickerIndicatorElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/shadow/ProgressShadowElement.h View 3 chunks +3 lines, -3 lines 0 comments Download
M Source/core/html/shadow/SliderThumbElement.h View 3 chunks +3 lines, -3 lines 0 comments Download
M Source/core/html/shadow/SpinButtonElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/shadow/TextControlInnerElements.h View 6 chunks +6 lines, -6 lines 0 comments Download
M Source/core/html/shadow/TextFieldDecorationElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/track/TextTrackCueGeneric.cpp View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/html/track/WebVTTElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/loader/SinkDocument.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGAElement.h View 1 chunk +5 lines, -5 lines 0 comments Download
M Source/core/svg/SVGAltGlyphDefElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGAltGlyphElement.h View 1 chunk +2 lines, -2 lines 0 comments Download
M Source/core/svg/SVGAltGlyphItemElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGAnimateColorElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGAnimateMotionElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGAnimateTransformElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGCircleElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGClipPathElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGCursorElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGDefsElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGDescElement.h View 1 chunk +2 lines, -2 lines 0 comments Download
M Source/core/svg/SVGDocument.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGEllipseElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGFEBlendElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEColorMatrixElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEComponentTransferElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFECompositeElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEConvolveMatrixElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEDiffuseLightingElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEDisplacementMapElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEDistantLightElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEDropShadowElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEFloodElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEFuncAElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEFuncBElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEFuncGElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEFuncRElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEGaussianBlurElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEImageElement.h View 1 chunk +5 lines, -5 lines 0 comments Download
M Source/core/svg/SVGFEMergeElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEMergeNodeElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEMorphologyElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEOffsetElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFEPointLightElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFESpecularLightingElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFESpotLightElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFETileElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFETurbulenceElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFilterElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGFontElement.h View 1 chunk +2 lines, -2 lines 0 comments Download
M Source/core/svg/SVGFontFaceElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFontFaceFormatElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFontFaceNameElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFontFaceSrcElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGFontFaceUriElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGForeignObjectElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGGElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGGlyphElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGGlyphRefElement.h View 1 chunk +2 lines, -2 lines 0 comments Download
M Source/core/svg/SVGHKernElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGImageElement.h View 1 chunk +5 lines, -5 lines 0 comments Download
M Source/core/svg/SVGLineElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGLinearGradientElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGMPathElement.h View 1 chunk +3 lines, -3 lines 0 comments Download
M Source/core/svg/SVGMarkerElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGMaskElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGMetadataElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGMissingGlyphElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGPathElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGPatternElement.h View 1 chunk +6 lines, -6 lines 0 comments Download
M Source/core/svg/SVGPolygonElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGPolylineElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGRadialGradientElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGRectElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGSVGElement.h View 1 chunk +6 lines, -6 lines 0 comments Download
M Source/core/svg/SVGScriptElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGSetElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGStopElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGStyleElement.h View 1 chunk +3 lines, -3 lines 0 comments Download
M Source/core/svg/SVGSwitchElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGSymbolElement.h View 1 chunk +4 lines, -4 lines 0 comments Download
M Source/core/svg/SVGTRefElement.h View 1 chunk +2 lines, -2 lines 0 comments Download
M Source/core/svg/SVGTSpanElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGTextElement.h View 1 chunk +2 lines, -2 lines 0 comments Download
M Source/core/svg/SVGTextPathElement.h View 1 chunk +2 lines, -2 lines 0 comments Download
M Source/core/svg/SVGTitleElement.h View 1 chunk +2 lines, -2 lines 0 comments Download
M Source/core/svg/SVGUseElement.h View 1 chunk +6 lines, -6 lines 0 comments Download
M Source/core/svg/SVGVKernElement.h View 1 chunk +1 line, -1 line 0 comments Download
M Source/core/svg/SVGViewElement.h View 1 chunk +4 lines, -4 lines 0 comments Download

Messages

Total messages: 8 (0 generated)
Chris Evans
7 years, 7 months ago (2013-04-29 06:03:34 UTC) #1
Chris Evans
(Adding more reviewers; not sure Elliot is around)
7 years, 7 months ago (2013-04-29 20:50:36 UTC) #2
eseidel
All the FINAL addisions lgtm. The rest is questionable. https://codereview.chromium.org/14022022/diff/1/Source/core/dom/Element.h File Source/core/dom/Element.h (left): https://codereview.chromium.org/14022022/diff/1/Source/core/dom/Element.h#oldcode420 Source/core/dom/Element.h:420: ...
7 years, 7 months ago (2013-04-29 20:57:21 UTC) #3
esprehn
LGTM. Lets move all the devirtualization and dead code removal to a second patch though. ...
7 years, 7 months ago (2013-04-29 22:02:55 UTC) #4
Chris Evans
On 2013/04/29 22:02:55, esprehn wrote: > LGTM. Lets move all the devirtualization and dead code ...
7 years, 7 months ago (2013-04-30 10:17:14 UTC) #5
esprehn
LGTM.
7 years, 7 months ago (2013-04-30 19:13:24 UTC) #6
Chris Evans
Committed patchset #2 manually as r149454 (presubmit successful).
7 years, 7 months ago (2013-04-30 19:14:14 UTC) #7
eseidel
7 years, 7 months ago (2013-04-30 19:43:56 UTC) #8
Message was sent while issue was closed.
That sounds like something simple enough one could write a script to do! :)

Powered by Google App Engine
This is Rietveld 408576698