Chromium Code Reviews| 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; |
| +} |