Index: Source/core/rendering/RenderBox.cpp |
diff --git a/Source/core/rendering/RenderBox.cpp b/Source/core/rendering/RenderBox.cpp |
index 8e4e9c49be0340d5f50717d2bec7330dd036e73c..bac05864c92591a5c7b058a932e902e9867982ba 100644 |
--- a/Source/core/rendering/RenderBox.cpp |
+++ b/Source/core/rendering/RenderBox.cpp |
@@ -143,8 +143,8 @@ void RenderBox::styleWillChange(StyleDifference diff, const RenderStyle& newStyl |
if (oldStyle) { |
// The background of the root element or the body element could propagate up to |
// the canvas. Just dirty the entire canvas when our style changes substantially. |
- if (diff >= StyleDifferenceRepaint && node() && |
- (isHTMLHtmlElement(*node()) || isHTMLBodyElement(*node()))) { |
+ if ((diff.needsRepaint() || diff.needsLayout()) && node() |
+ && (isHTMLHtmlElement(*node()) || isHTMLBodyElement(*node()))) { |
view()->repaint(); |
if (oldStyle->hasEntirelyFixedBackground() != newStyle.hasEntirelyFixedBackground()) |
@@ -153,7 +153,7 @@ void RenderBox::styleWillChange(StyleDifference diff, const RenderStyle& newStyl |
// When a layout hint happens and an object's position style changes, we have to do a layout |
// to dirty the render tree using the old position value now. |
- if (diff == StyleDifferenceLayout && parent() && oldStyle->position() != newStyle.position()) { |
+ if (diff.needsFullLayout() && parent() && oldStyle->position() != newStyle.position()) { |
markContainingBlocksForLayout(); |
if (oldStyle->position() == StaticPosition) |
repaint(); |
@@ -209,7 +209,7 @@ void RenderBox::styleDidChange(StyleDifference diff, const RenderStyle* oldStyle |
} |
// Our opaqueness might have changed without triggering layout. |
- if (diff == StyleDifferenceRepaint || diff == StyleDifferenceRepaintLayer) { |
+ if (diff.needsRepaint()) { |
RenderObject* parentToInvalidate = parent(); |
for (unsigned i = 0; i < backgroundObscurationTestMaxDepth && parentToInvalidate; ++i) { |
parentToInvalidate->invalidateBackgroundObscurationStatus(); |