diff options
| author | Simon Hausmann <simon.hausmann@nokia.com> | 2012-05-11 09:43:24 +0200 | 
|---|---|---|
| committer | Simon Hausmann <simon.hausmann@nokia.com> | 2012-05-11 09:43:24 +0200 | 
| commit | 1b914638db989aaa98631a1c1e02c7b2d44805d8 (patch) | |
| tree | 87f4fd2c7b38db320079a5de8877890d2ca3c485 /Source/WebKit/chromium/src/FrameLoaderClientImpl.cpp | |
| parent | 2cf6c8816a73e0132bd8fa3b509d62d7c51b6e47 (diff) | |
| download | qtwebkit-1b914638db989aaa98631a1c1e02c7b2d44805d8.tar.gz | |
Imported WebKit commit 9a52e27980f47e8b0d8f8b7cc0fd7b5741bceb92 (http://svn.webkit.org/repository/webkit/trunk@116736)
New snapshot to include QDeclarative* -> QQml* build fixes
Diffstat (limited to 'Source/WebKit/chromium/src/FrameLoaderClientImpl.cpp')
| -rw-r--r-- | Source/WebKit/chromium/src/FrameLoaderClientImpl.cpp | 35 | 
1 files changed, 32 insertions, 3 deletions
| diff --git a/Source/WebKit/chromium/src/FrameLoaderClientImpl.cpp b/Source/WebKit/chromium/src/FrameLoaderClientImpl.cpp index abe1e98b4..d0602a9a0 100644 --- a/Source/WebKit/chromium/src/FrameLoaderClientImpl.cpp +++ b/Source/WebKit/chromium/src/FrameLoaderClientImpl.cpp @@ -68,6 +68,7 @@  #include "WebFrameClient.h"  #include "WebFrameImpl.h"  #include "WebIntentRequest.h" +#include "WebIntentServiceInfo.h"  #include "WebKit.h"  #include "WebNode.h"  #include "WebPermissionClient.h" @@ -634,8 +635,14 @@ void FrameLoaderClientImpl::dispatchDidNavigateWithinPage()      // didStopLoading only when loader is completed so that we don't fire      // them for fragment redirection that happens in window.onload handler.      // See https://bugs.webkit.org/show_bug.cgi?id=31838 -    bool loaderCompleted = -        !webView->page()->mainFrame()->loader()->activeDocumentLoader()->isLoadingInAPISense(); +    // +    // FIXME: Although FrameLoader::loadInSameDocument which invokes this +    // method does not have a provisional document loader, we're seeing crashes +    // where the FrameLoader is in provisional state, and thus +    // activeDocumentLoader returns 0. Lacking any understanding of how this +    // can happen, we do this check here to avoid crashing. +    FrameLoader* loader = webView->page()->mainFrame()->loader(); +    bool loaderCompleted = !(loader->activeDocumentLoader() && loader->activeDocumentLoader()->isLoadingInAPISense());      // Generate didStartLoading if loader is completed.      if (webView->client() && loaderCompleted) @@ -1376,6 +1383,10 @@ void FrameLoaderClientImpl::setTitle(const StringWithDirection& title, const KUR  String FrameLoaderClientImpl::userAgent(const KURL& url)  { +    WebString override; +    if (m_webFrame->client()->userAgent(WebURL(url), &override)) +        return override; +      return WebKit::Platform::current()->userAgent(url);  } @@ -1591,10 +1602,28 @@ bool FrameLoaderClientImpl::willCheckAndDispatchMessageEvent(      if (!m_webFrame->client())          return false; +    WebFrame* source = 0; +    if (event && event->source() && event->source()->document()) +        source = WebFrameImpl::fromFrame(event->source()->document()->frame());      return m_webFrame->client()->willCheckAndDispatchMessageEvent( -        m_webFrame, WebSecurityOrigin(target), WebDOMMessageEvent(event)); +        source, WebSecurityOrigin(target), WebDOMMessageEvent(event));  } +#if ENABLE(WEB_INTENTS_TAG) +void FrameLoaderClientImpl::registerIntentService( +        const String& action, +        const String& type, +        const KURL& href, +        const String& title, +        const String& disposition) { +    if (!m_webFrame->client()) +        return; + +    WebIntentServiceInfo service(action, type, href, title, disposition); +    m_webFrame->client()->registerIntentService(m_webFrame, service); +} +#endif +  #if ENABLE(WEB_INTENTS)  void FrameLoaderClientImpl::dispatchIntent(PassRefPtr<WebCore::IntentRequest> intentRequest)  { | 
