Index: chrome/browser/android/hung_renderer_infobar_delegate.cc |
diff --git a/chrome/browser/android/hung_renderer_infobar_delegate.cc b/chrome/browser/android/hung_renderer_infobar_delegate.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..ac61570a6041755e51e02f1efb27bcaee14a7650 |
--- /dev/null |
+++ b/chrome/browser/android/hung_renderer_infobar_delegate.cc |
@@ -0,0 +1,43 @@ |
+// Copyright 2015 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "chrome/browser/android/hung_renderer_infobar_delegate.h" |
+ |
+#include "base/callback.h" |
+#include "chrome/grit/generated_resources.h" |
+#include "components/infobars/core/infobar.h" |
+#include "content/public/browser/render_process_host.h" |
+#include "content/public/browser/web_contents.h" |
+#include "content/public/common/result_codes.h" |
+#include "grit/theme_resources.h" |
+#include "ui/base/l10n/l10n_util.h" |
+ |
+HungRendererInfoBarDelegate::HungRendererInfoBarDelegate( |
+ content::WebContents* web_contents) |
+ : web_contents_(web_contents) { |
jdduke (slow)
2015/08/18 17:39:29
There's not much code here, I thought of just embe
gone
2015/08/18 18:21:36
Eh, the less things we shove into TabAndroid the b
|
+ DCHECK(web_contents); |
+} |
+ |
+HungRendererInfoBarDelegate::~HungRendererInfoBarDelegate() {} |
+ |
+int HungRendererInfoBarDelegate::GetIconID() const { |
+ return IDR_FROZEN_TAB_ICON; |
+} |
+ |
+base::string16 HungRendererInfoBarDelegate::GetMessageText() const { |
+ return l10n_util::GetPluralStringFUTF16(IDS_BROWSER_HANGMONITOR_RENDERER, 1); |
+} |
+ |
+base::string16 HungRendererInfoBarDelegate::GetButtonLabel( |
+ InfoBarButton button) const { |
+ return l10n_util::GetStringUTF16((button == BUTTON_OK) |
+ ? IDS_BROWSER_HANGMONITOR_RENDERER_END |
+ : IDS_BROWSER_HANGMONITOR_RENDERER_WAIT); |
+} |
+ |
+bool HungRendererInfoBarDelegate::Accept() { |
+ content::RenderProcessHost* process = web_contents_->GetRenderProcessHost(); |
+ process->Shutdown(content::RESULT_CODE_HUNG, false); |
+ return true; |
+} |