diff options
| author | Nicolas Roard <nicolasroard@google.com> | 2011-08-05 18:04:35 -0700 | 
|---|---|---|
| committer | Nicolas Roard <nicolasroard@google.com> | 2011-08-05 18:04:35 -0700 | 
| commit | db9378c1fab20d230f03456aa467c178cc2fbf7f (patch) | |
| tree | b62c7b3fed318d28a2272ef753761414ceb3a646 /Source/WebCore/rendering | |
| parent | 6b9d05281a529f9cd3e527fb8d657b338bb4fd7a (diff) | |
| download | external_webkit-db9378c1fab20d230f03456aa467c178cc2fbf7f.zip external_webkit-db9378c1fab20d230f03456aa467c178cc2fbf7f.tar.gz external_webkit-db9378c1fab20d230f03456aa467c178cc2fbf7f.tar.bz2 | |
Fix crashes on plus.google.com and reduce the number of necessary layers
bug:5121768
Change-Id: I616af5cdc3f8b0a790fd50434c919b2c95b0e486
Diffstat (limited to 'Source/WebCore/rendering')
| -rw-r--r-- | Source/WebCore/rendering/RenderLayerCompositor.cpp | 24 | 
1 files changed, 20 insertions, 4 deletions
| diff --git a/Source/WebCore/rendering/RenderLayerCompositor.cpp b/Source/WebCore/rendering/RenderLayerCompositor.cpp index 8d066e9..2f344b9 100644 --- a/Source/WebCore/rendering/RenderLayerCompositor.cpp +++ b/Source/WebCore/rendering/RenderLayerCompositor.cpp @@ -79,6 +79,7 @@ struct CompositingState {          , m_subtreeIsCompositing(false)  #if ENABLE(COMPOSITED_FIXED_ELEMENTS)          , m_fixedSibling(false) +        , m_hasFixedElement(false)  #endif  #if ENABLE(ANDROID_OVERFLOW_SCROLL)          , m_hasScrollableElement(false) @@ -93,6 +94,7 @@ struct CompositingState {      bool m_subtreeIsCompositing;  #if ENABLE(COMPOSITED_FIXED_ELEMENTS)      bool m_fixedSibling; +    bool m_hasFixedElement;  #endif  #if ENABLE(ANDROID_OVERFLOW_SCROLL)      bool m_hasScrollableElement; @@ -625,9 +627,15 @@ bool RenderLayerCompositor::checkForFixedLayers(Vector<RenderLayer*>* list, bool              haveFixedLayer = j;              fixedSibling = true;          } +        IntRect currentLayerBounds = currentLayer->renderer()->localToAbsoluteQuad( +            FloatRect(currentLayer->localBoundingBox())).enclosingBoundingBox(); +        if ((currentLayerBounds.width() <= 1 +            || currentLayerBounds.height() <= 1) +            && haveFixedLayer == j) { +            haveFixedLayer = -1; +            fixedSibling = false; +        }          if (haveFixedLayer != -1 && haveFixedLayer != j) { -            IntRect currentLayerBounds = currentLayer->renderer()->localToAbsoluteQuad( -                FloatRect(currentLayer->localBoundingBox())).enclosingBoundingBox();              bool needComposite = true;              int stop = 0;              if (stopAtFixedLayer) @@ -709,12 +717,16 @@ void RenderLayerCompositor::computeCompositingRequirements(RenderLayer* layer, O      if (layer->hasOverflowScroll())          compositingState.m_hasScrollableElement = true;  #endif +#if ENABLE(COMPOSITED_FIXED_ELEMENTS) +    if (layer->isFixed()) +        compositingState.m_hasFixedElement = true; +#endif  #if ENABLE(ANDROID_OVERFLOW_SCROLL)      // we don't want to signal that the subtree is compositing if the reason      // is because the layer is an overflow layer -- doing so would trigger      // all the above layers to be composited unnecessarily -    if (willBeComposited && !layer->hasOverflowScroll()) { +    if (willBeComposited && !layer->hasOverflowScroll() && !layer->isFixed()) {  #else      if (willBeComposited) {  #endif @@ -816,6 +828,10 @@ void RenderLayerCompositor::computeCompositingRequirements(RenderLayer* layer, O      if (childState.m_subtreeIsCompositing)          compositingState.m_subtreeIsCompositing = true; +#if ENABLE(COMPOSITED_FIXED_ELEMENTS) +    if (childState.m_hasFixedElement) +        compositingState.m_hasFixedElement = true; +#endif  #if ENABLE(ANDROID_OVERFLOW_SCROLL)      if (childState.m_hasScrollableElement)          compositingState.m_hasScrollableElement = true; @@ -837,7 +853,7 @@ void RenderLayerCompositor::computeCompositingRequirements(RenderLayer* layer, O  #if ENABLE(ANDROID_OVERFLOW_SCROLL)      // We also need to check that we don't have a scrollable layer, as this      // would not have set the m_subtreeIsCompositing flag -    if (layer->isRootLayer() && !childState.m_subtreeIsCompositing && !childState.m_hasScrollableElement && !requiresCompositingLayer(layer) && !m_forceCompositingMode) { +    if (layer->isRootLayer() && !childState.m_subtreeIsCompositing && !childState.m_hasScrollableElement && !childState.m_hasFixedElement && !requiresCompositingLayer(layer) && !m_forceCompositingMode) {  #else      if (layer->isRootLayer() && !childState.m_subtreeIsCompositing && !requiresCompositingLayer(layer) && !m_forceCompositingMode) {  #endif | 
