Index: third_party/WebKit/Source/core/frame/FrameView.cpp |
diff --git a/third_party/WebKit/Source/core/frame/FrameView.cpp b/third_party/WebKit/Source/core/frame/FrameView.cpp |
index 9d93a5fb2b42126d2194a639970391c26ef15663..cfbc6ee8b4a9e440a2f7f794606a2b3e59dbec91 100644 |
--- a/third_party/WebKit/Source/core/frame/FrameView.cpp |
+++ b/third_party/WebKit/Source/core/frame/FrameView.cpp |
@@ -3367,6 +3367,23 @@ IntSize FrameView::contentsSize() const |
return m_contentsSize; |
} |
+IntRect FrameView::visibleContentRectForPainting() const |
+{ |
+ if (m_visibleContentRectForPainting) |
+ return *m_visibleContentRectForPainting; |
+ return visibleContentRect(); |
+} |
+ |
+void FrameView::setVisibleContentRectForPainting(const IntRect& rect) |
+{ |
+ m_visibleContentRectForPainting = IntRect(rect); |
+} |
+ |
+void FrameView::resetVisibleContentRectForPainting() |
+{ |
+ m_visibleContentRectForPainting = WTF::nullopt; |
+} |
+ |
IntPoint FrameView::minimumScrollPosition() const |
{ |
return IntPoint(-scrollOrigin().x(), -scrollOrigin().y()); |
@@ -3445,7 +3462,7 @@ void FrameView::setScrollOffset(const DoublePoint& offset, ScrollType scrollType |
cache->handleScrollPositionChanged(this); |
frame().loader().saveScrollState(); |
- frame().loader().client()->didChangeScrollOffset(); |
+ didChangeScrollOffset(); |
if (scrollType == CompositorScroll && m_frame->isMainFrame()) { |
if (DocumentLoader* documentLoader = m_frame->loader().documentLoader()) |
@@ -3456,6 +3473,13 @@ void FrameView::setScrollOffset(const DoublePoint& offset, ScrollType scrollType |
clearScrollAnchor(); |
} |
+void FrameView::didChangeScrollOffset() |
+{ |
+ frame().loader().client()->didChangeScrollOffset(); |
+ if (frame().isMainFrame()) |
+ frame().host()->chromeClient().mainFrameScrollOffsetChanged(); |
+} |
+ |
void FrameView::clearScrollAnchor() |
{ |
if (!RuntimeEnabledFeatures::scrollAnchoringEnabled()) |