 Chromium Code Reviews
 Chromium Code Reviews Issue 666493002:
  Remove updatePaintingInfoForFragments() and per-fragment shouldPaintContent flag.  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/blink.git@master
    
  
    Issue 666493002:
  Remove updatePaintingInfoForFragments() and per-fragment shouldPaintContent flag.  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/blink.git@master| Index: Source/core/paint/LayerPainter.cpp | 
| diff --git a/Source/core/paint/LayerPainter.cpp b/Source/core/paint/LayerPainter.cpp | 
| index 6ee9a82b608de4f7c194ff0ef9ad7429b358e675..f108d37a6acd3d228334c1deec2e08b08f635259 100644 | 
| --- a/Source/core/paint/LayerPainter.cpp | 
| +++ b/Source/core/paint/LayerPainter.cpp | 
| @@ -257,12 +257,15 @@ void LayerPainter::paintLayerContents(GraphicsContext* context, const LayerPaint | 
| LayerFragments layerFragments; | 
| if (shouldPaintContent || shouldPaintOutline || isPaintingOverlayScrollbars) { | 
| - // Collect the fragments. This will compute the clip rectangles and paint offsets for each layer fragment, as well as whether or not the content of each | 
| - // fragment should paint. | 
| - m_renderLayer.collectFragments(layerFragments, localPaintingInfo.rootLayer, localPaintingInfo.paintDirtyRect, | 
| - (paintFlags & PaintLayerUncachedClipRects) ? UncachedClipRects : PaintingClipRects, IgnoreOverlayScrollbarSize, | 
| - shouldRespectOverflowClip(paintFlags, m_renderLayer.renderer()), &offsetFromRoot, localPaintingInfo.subPixelAccumulation); | 
| - updatePaintingInfoForFragments(layerFragments, localPaintingInfo, paintFlags, shouldPaintContent, &offsetFromRoot); | 
| + // Collect the fragments. This will compute the clip rectangles and paint offsets for each layer fragment. | 
| + ClipRectsCacheSlot cacheSlot = (paintFlags & PaintLayerUncachedClipRects) ? UncachedClipRects : PaintingClipRects; | 
| + ShouldRespectOverflowClip respectOverflowClip = shouldRespectOverflowClip(paintFlags, m_renderLayer.renderer()); | 
| + RenderLayer::DirtyRectIntersectionResult intersectionResult; | 
| + m_renderLayer.collectFragments(layerFragments, &intersectionResult, localPaintingInfo.rootLayer, localPaintingInfo.paintDirtyRect, cacheSlot, IgnoreOverlayScrollbarSize, respectOverflowClip, &offsetFromRoot, localPaintingInfo.subPixelAccumulation); | 
| + if (intersectionResult == RenderLayer::NotIntersectingDirtyRect && shouldPaintContent) { | 
| + if (&m_renderLayer != localPaintingInfo.rootLayer || !(paintFlags & PaintLayerPaintingOverflowContents)) | 
| + shouldPaintContent = false; | 
| + } | 
| } | 
| bool selectionOnly = localPaintingInfo.paintBehavior & PaintBehaviorSelectionOnly; | 
| @@ -421,20 +424,6 @@ void LayerPainter::applyRoundedRectClips(const LayerPaintingInfo& localPaintingI | 
| } | 
| } | 
| -void LayerPainter::updatePaintingInfoForFragments(LayerFragments& fragments, const LayerPaintingInfo& localPaintingInfo, PaintLayerFlags localPaintFlags, | 
| - bool shouldPaintContent, const LayoutPoint* offsetFromRoot) | 
| -{ | 
| - ASSERT(offsetFromRoot); | 
| - for (size_t i = 0; i < fragments.size(); ++i) { | 
| 
chrishtr
2014/10/28 18:47:42
How about just a method:
bool LayerPainter::atLea
 
mstensho (USE GERRIT)
2014/10/28 20:08:21
You mean that you don't want the extra code (and p
 
chrishtr
2014/10/28 20:18:25
Is this method hard to implement?
I was suggesti
 
mstensho (USE GERRIT)
2014/10/28 21:33:20
Done. It's kind of meaningless to loop through the
 | 
| - LayerFragment& fragment = fragments.at(i); | 
| - fragment.shouldPaintContent = shouldPaintContent; | 
| - if (&m_renderLayer != localPaintingInfo.rootLayer || !(localPaintFlags & PaintLayerPaintingOverflowContents)) { | 
| - LayoutPoint newOffsetFromRoot = *offsetFromRoot + fragment.paginationOffset; | 
| - fragment.shouldPaintContent &= m_renderLayer.intersectsDamageRect(fragment.layerBounds, fragment.backgroundRect.rect(), localPaintingInfo.rootLayer, &newOffsetFromRoot); | 
| - } | 
| - } | 
| -} | 
| - | 
| void LayerPainter::paintLayerByApplyingTransform(GraphicsContext* context, const LayerPaintingInfo& paintingInfo, PaintLayerFlags paintFlags, const LayoutPoint& translationOffset) | 
| { | 
| // This involves subtracting out the position of the layer in our current coordinate space, but preserving | 
| @@ -672,8 +661,6 @@ void LayerPainter::paintBackgroundForFragments(const LayerFragments& layerFragme | 
| { | 
| for (size_t i = 0; i < layerFragments.size(); ++i) { | 
| const LayerFragment& fragment = layerFragments.at(i); | 
| - if (!fragment.shouldPaintContent) | 
| - continue; | 
| // Begin transparency layers lazily now that we know we have to paint something. | 
| if (haveTransparency || m_renderLayer.paintsWithBlendMode()) | 
| @@ -701,7 +688,7 @@ void LayerPainter::paintForegroundForFragments(const LayerFragments& layerFragme | 
| if (haveTransparency || m_renderLayer.paintsWithBlendMode()) { | 
| for (size_t i = 0; i < layerFragments.size(); ++i) { | 
| const LayerFragment& fragment = layerFragments.at(i); | 
| - if (fragment.shouldPaintContent && !fragment.foregroundRect.isEmpty()) { | 
| + if (!fragment.foregroundRect.isEmpty()) { | 
| beginTransparencyLayers(context, localPaintingInfo.rootLayer, transparencyPaintDirtyRect, localPaintingInfo.subPixelAccumulation, localPaintingInfo.paintBehavior); | 
| break; | 
| } | 
| @@ -709,7 +696,7 @@ void LayerPainter::paintForegroundForFragments(const LayerFragments& layerFragme | 
| } | 
| // Optimize clipping for the single fragment case. | 
| - bool shouldClip = localPaintingInfo.clipToDirtyRect && layerFragments.size() == 1 && layerFragments[0].shouldPaintContent && !layerFragments[0].foregroundRect.isEmpty(); | 
| + bool shouldClip = localPaintingInfo.clipToDirtyRect && layerFragments.size() == 1 && !layerFragments[0].foregroundRect.isEmpty(); | 
| OwnPtr<ClipRecorder> clipRecorder; | 
| if (shouldClip && needsToClip(localPaintingInfo, layerFragments[0].foregroundRect)) { | 
| @@ -736,7 +723,7 @@ void LayerPainter::paintForegroundForFragmentsWithPhase(PaintPhase phase, const | 
| for (size_t i = 0; i < layerFragments.size(); ++i) { | 
| const LayerFragment& fragment = layerFragments.at(i); | 
| - if (!fragment.shouldPaintContent || fragment.foregroundRect.isEmpty()) | 
| + if (fragment.foregroundRect.isEmpty()) | 
| continue; | 
| OwnPtr<ClipRecorder> clipRecorder; | 
| @@ -796,9 +783,6 @@ void LayerPainter::paintMaskForFragments(const LayerFragments& layerFragments, G | 
| { | 
| for (size_t i = 0; i < layerFragments.size(); ++i) { | 
| const LayerFragment& fragment = layerFragments.at(i); | 
| - if (!fragment.shouldPaintContent) | 
| - continue; | 
| - | 
| OwnPtr<ClipRecorder> clipRecorder; | 
| if (localPaintingInfo.clipToDirtyRect && needsToClip(localPaintingInfo, fragment.backgroundRect)) { | 
| clipRecorder = adoptPtr(new ClipRecorder(&m_renderLayer, context, ClipDisplayItem::LayerFragmentMask, fragment.backgroundRect)); | 
| @@ -817,9 +801,6 @@ void LayerPainter::paintChildClippingMaskForFragments(const LayerFragments& laye | 
| { | 
| for (size_t i = 0; i < layerFragments.size(); ++i) { | 
| const LayerFragment& fragment = layerFragments.at(i); | 
| - if (!fragment.shouldPaintContent) | 
| - continue; | 
| - | 
| OwnPtr<ClipRecorder> clipRecorder; | 
| if (localPaintingInfo.clipToDirtyRect && needsToClip(localPaintingInfo, fragment.foregroundRect)) { | 
| clipRecorder = adoptPtr(new ClipRecorder(&m_renderLayer, context, ClipDisplayItem::LayerFragmentClippingMask, fragment.foregroundRect)); | 
| @@ -848,7 +829,7 @@ void LayerPainter::paintTransformedLayerIntoFragments(GraphicsContext* context, | 
| LayerFragments enclosingPaginationFragments; | 
| LayoutPoint offsetOfPaginationLayerFromRoot; | 
| LayoutRect transformedExtent = RenderLayer::transparencyClipBox(&m_renderLayer, m_renderLayer.enclosingPaginationLayer(), RenderLayer::PaintingTransparencyClipBox, RenderLayer::RootOfTransparencyClipBox, paintingInfo.subPixelAccumulation, paintingInfo.paintBehavior); | 
| - m_renderLayer.enclosingPaginationLayer()->collectFragments(enclosingPaginationFragments, paintingInfo.rootLayer, paintingInfo.paintDirtyRect, | 
| + m_renderLayer.enclosingPaginationLayer()->collectFragments(enclosingPaginationFragments, 0, paintingInfo.rootLayer, paintingInfo.paintDirtyRect, | 
| (paintFlags & PaintLayerUncachedClipRects) ? UncachedClipRects : PaintingClipRects, IgnoreOverlayScrollbarSize, | 
| shouldRespectOverflowClip(paintFlags, m_renderLayer.renderer()), &offsetOfPaginationLayerFromRoot, paintingInfo.subPixelAccumulation, &transformedExtent); |