| Index: third_party/WebKit/Source/core/dom/Element.cpp
|
| diff --git a/third_party/WebKit/Source/core/dom/Element.cpp b/third_party/WebKit/Source/core/dom/Element.cpp
|
| index e785c06dfc53d2423487e8af18cf389fe9095aa8..b59d331fb942ba28d352a9bbbaa911b6d3c9b93b 100644
|
| --- a/third_party/WebKit/Source/core/dom/Element.cpp
|
| +++ b/third_party/WebKit/Source/core/dom/Element.cpp
|
| @@ -973,18 +973,35 @@ void Element::scrollFrameTo(const ScrollToOptions& scrollToOptions)
|
| viewport->setScrollPosition(DoublePoint(scaledLeft, scaledTop), ProgrammaticScroll, scrollBehavior);
|
| }
|
|
|
| -void Element::incrementProxyCount()
|
| +bool Element::hasCompositorProxy() const
|
| {
|
| - if (ensureElementRareData().incrementProxyCount() == 1)
|
| + return hasRareData() && elementRareData()->proxiedPropertyCounts();
|
| +}
|
| +
|
| +void Element::incrementProxiedPropertyCounts(uint32_t mutableProperties)
|
| +{
|
| + const bool hadProxy = hasCompositorProxy();
|
| + ensureElementRareData().incrementProxiedPropertyCounts(mutableProperties);
|
| + if (!hadProxy && hasCompositorProxy())
|
| setNeedsStyleRecalc(LocalStyleChange, StyleChangeReasonForTracing::create(StyleChangeReason::CompositorProxy));
|
| }
|
|
|
| -void Element::decrementProxyCount()
|
| +void Element::decrementProxiedPropertyCounts(uint32_t mutableProperties)
|
| {
|
| - if (ensureElementRareData().decrementProxyCount() == 0)
|
| + ASSERT(hasRareData());
|
| + const bool hadProxy = hasCompositorProxy();
|
| + elementRareData()->decrementProxiedPropertyCounts(mutableProperties);
|
| + if (hadProxy && !hasCompositorProxy())
|
| setNeedsStyleRecalc(LocalStyleChange, StyleChangeReasonForTracing::create(StyleChangeReason::CompositorProxy));
|
| }
|
|
|
| +uint32_t Element::compositorMutableProperties() const
|
| +{
|
| + if (!hasCompositorProxy())
|
| + return WebCompositorMutablePropertyNone;
|
| + return elementRareData()->proxiedPropertyCounts()->proxiedProperties();
|
| +}
|
| +
|
| bool Element::hasNonEmptyLayoutSize() const
|
| {
|
| document().updateLayoutIgnorePendingStylesheets();
|
| @@ -1686,9 +1703,6 @@ PassRefPtr<ComputedStyle> Element::styleForLayoutObject()
|
| style->setHasInlineTransform(inlineStyle->hasProperty(CSSPropertyTransform));
|
| }
|
|
|
| - if (hasRareData() && elementRareData()->proxyCount() > 0)
|
| - style->setHasCompositorProxy(true);
|
| -
|
| document().didRecalculateStyleForElement();
|
| return style.release();
|
| }
|
|
|