summaryrefslogtreecommitdiffstats
path: root/Source/WebCore/page/Frame.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'Source/WebCore/page/Frame.cpp')
-rw-r--r--Source/WebCore/page/Frame.cpp15
1 files changed, 12 insertions, 3 deletions
diff --git a/Source/WebCore/page/Frame.cpp b/Source/WebCore/page/Frame.cpp
index 9a562a1..3652c9a 100644
--- a/Source/WebCore/page/Frame.cpp
+++ b/Source/WebCore/page/Frame.cpp
@@ -690,8 +690,10 @@ void Frame::pageDestroyed()
if (Frame* parent = tree()->parent())
parent->loader()->checkLoadComplete();
- if (m_domWindow)
+ if (m_domWindow) {
+ m_domWindow->resetGeolocation();
m_domWindow->pageDestroyed();
+ }
// FIXME: It's unclear as to why this is called more than once, but it is,
// so page() could be NULL.
@@ -736,6 +738,13 @@ void Frame::transferChildFrameToNewDocument()
m_page->decrementFrameCount();
}
+ // FIXME: We should ideally allow existing Geolocation activities to continue
+ // when the Geolocation's iframe is reparented.
+ // See https://bugs.webkit.org/show_bug.cgi?id=55577
+ // and https://bugs.webkit.org/show_bug.cgi?id=52877
+ if (m_domWindow)
+ m_domWindow->resetGeolocation();
+
m_page = newPage;
if (newPage)
@@ -901,7 +910,7 @@ Color Frame::tiledBackingStoreBackgroundColor() const
}
#endif
-String Frame::layerTreeAsText() const
+String Frame::layerTreeAsText(bool showDebugInfo) const
{
#if USE(ACCELERATED_COMPOSITING)
document()->updateLayout();
@@ -909,7 +918,7 @@ String Frame::layerTreeAsText() const
if (!contentRenderer())
return String();
- return contentRenderer()->compositor()->layerTreeAsText();
+ return contentRenderer()->compositor()->layerTreeAsText(showDebugInfo);
#else
return String();
#endif