Chromium Code Reviews| Index: chrome/browser/net/net_error_tab_helper.cc |
| diff --git a/chrome/browser/net/net_error_tab_helper.cc b/chrome/browser/net/net_error_tab_helper.cc |
| index 8e325f9be01b1103ffc5f6c8a10b0606006b6049..59fe3dee90a5f4ace32dd5c96bc79474d6ca5695 100644 |
| --- a/chrome/browser/net/net_error_tab_helper.cc |
| +++ b/chrome/browser/net/net_error_tab_helper.cc |
| @@ -22,6 +22,10 @@ |
| #include "net/base/net_errors.h" |
| #include "url/gurl.h" |
| +#if defined(OS_ANDROID) |
| +#include "chrome/browser/android/tab_android.h" |
| +#endif |
| + |
| using content::BrowserContext; |
| using content::BrowserThread; |
| using content::WebContents; |
| @@ -118,6 +122,16 @@ void NetErrorTabHelper::DidStartProvisionalLoadForFrame( |
| return; |
| is_error_page_ = is_error_page; |
| + |
| +#if defined(OS_ANDROID) |
|
mmenke
2015/11/09 19:31:44
Should we use a different label for this, or add a
jianli
2015/11/09 21:59:52
Moved this part into a helper function that is pla
|
| + TabAndroid* tab = |
| + web_contents() ? TabAndroid::FromWebContents(web_contents()) : nullptr; |
| + bool has_offline_pages = (tab && tab->HasOfflinePages()); |
| + render_frame_host->Send( |
| + new ChromeViewMsg_SetHasOfflinePages( |
| + render_frame_host->GetRoutingID(), |
| + has_offline_pages)); |
| +#endif |
| } |
| void NetErrorTabHelper::DidCommitProvisionalLoadForFrame( |
| @@ -167,6 +181,7 @@ bool NetErrorTabHelper::OnMessageReceived( |
| IPC_BEGIN_MESSAGE_MAP(NetErrorTabHelper, message) |
| IPC_MESSAGE_HANDLER(ChromeViewHostMsg_RunNetworkDiagnostics, |
| RunNetworkDiagnostics) |
| + IPC_MESSAGE_HANDLER(ChromeViewHostMsg_ShowOfflinePages, ShowOfflinePages) |
| IPC_MESSAGE_UNHANDLED(handled = false) |
| IPC_END_MESSAGE_MAP() |
| @@ -274,4 +289,13 @@ void NetErrorTabHelper::RunNetworkDiagnosticsHelper( |
| ShowNetworkDiagnosticsDialog(web_contents(), sanitized_url); |
| } |
| +void NetErrorTabHelper::ShowOfflinePages() { |
| +#if defined(OS_ANDROID) |
| + TabAndroid* tab = |
| + web_contents() ? TabAndroid::FromWebContents(web_contents()) : nullptr; |
| + if (tab) |
| + tab->ShowOfflinePages(); |
| +#endif |
| +} |
| + |
| } // namespace chrome_browser_net |