summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSteve Block <steveblock@google.com>2010-03-09 21:24:23 +0000
committerSteve Block <steveblock@google.com>2010-03-09 21:24:23 +0000
commitb9362877ccf9e5f8027f12898166d56518bbedb6 (patch)
tree3f4182f1613ef2f135f86efbd4877d2d97b68305
parent7d67a82337a9bcfb3e00791b15af51ff6c720f04 (diff)
downloadexternal_webkit-b9362877ccf9e5f8027f12898166d56518bbedb6.zip
external_webkit-b9362877ccf9e5f8027f12898166d56518bbedb6.tar.gz
external_webkit-b9362877ccf9e5f8027f12898166d56518bbedb6.tar.bz2
When starting the Geolocation service, we need to make sure that we have a valid FrameView before querying the Java side to determine whether the WebView is paused.
Bug: 2501254 Change-Id: Ideb86ce4c35efb7bc7595c4205dc1e8d5c1cf106
-rw-r--r--WebCore/page/Geolocation.cpp7
1 files changed, 6 insertions, 1 deletions
diff --git a/WebCore/page/Geolocation.cpp b/WebCore/page/Geolocation.cpp
index faa8f86..d021f7b 100644
--- a/WebCore/page/Geolocation.cpp
+++ b/WebCore/page/Geolocation.cpp
@@ -650,7 +650,12 @@ bool Geolocation::startUpdating(GeoNotifier* notifier)
// TODO: Upstream to webkit.org. See https://bugs.webkit.org/show_bug.cgi?id=34082
// Note that the correct fix is to use a 'paused' flag in WebCore, rather
// than calling into PlatformBridge.
- return m_service->startUpdating(notifier->m_options.get(), PlatformBridge::isWebViewPaused(m_frame->view()));
+ if (!m_frame)
+ return false;
+ FrameView* view = m_frame->view();
+ if (!view)
+ return false;
+ return m_service->startUpdating(notifier->m_options.get(), PlatformBridge::isWebViewPaused(view));
#else
return m_service->startUpdating(notifier->m_options.get());
#endif