Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(335)

Side by Side Diff: chrome/browser/custom_handlers/register_protocol_handler_infobar_delegate.cc

Issue 228293004: InfoBarService inherits from InfoBarManager (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: whitespace Created 6 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/custom_handlers/register_protocol_handler_infobar_deleg ate.h" 5 #include "chrome/browser/custom_handlers/register_protocol_handler_infobar_deleg ate.h"
6 6
7 #include "base/strings/utf_string_conversions.h" 7 #include "base/strings/utf_string_conversions.h"
8 #include "chrome/browser/custom_handlers/protocol_handler_registry.h" 8 #include "chrome/browser/custom_handlers/protocol_handler_registry.h"
9 #include "chrome/browser/infobars/infobar.h" 9 #include "chrome/browser/infobars/infobar.h"
10 #include "chrome/browser/infobars/infobar_manager.h"
11 #include "chrome/browser/infobars/infobar_service.h" 10 #include "chrome/browser/infobars/infobar_service.h"
12 #include "chrome/common/url_constants.h" 11 #include "chrome/common/url_constants.h"
13 #include "content/public/browser/user_metrics.h" 12 #include "content/public/browser/user_metrics.h"
14 #include "content/public/browser/web_contents.h" 13 #include "content/public/browser/web_contents.h"
15 #include "grit/generated_resources.h" 14 #include "grit/generated_resources.h"
16 #include "ui/base/l10n/l10n_util.h" 15 #include "ui/base/l10n/l10n_util.h"
17 16
18 // static 17 // static
19 void RegisterProtocolHandlerInfoBarDelegate::Create( 18 void RegisterProtocolHandlerInfoBarDelegate::Create(
20 InfoBarService* infobar_service, 19 InfoBarService* infobar_service,
21 ProtocolHandlerRegistry* registry, 20 ProtocolHandlerRegistry* registry,
22 const ProtocolHandler& handler) { 21 const ProtocolHandler& handler) {
23 content::RecordAction( 22 content::RecordAction(
24 base::UserMetricsAction("RegisterProtocolHandler.InfoBar_Shown")); 23 base::UserMetricsAction("RegisterProtocolHandler.InfoBar_Shown"));
25 24
26 scoped_ptr<InfoBar> infobar(ConfirmInfoBarDelegate::CreateInfoBar( 25 scoped_ptr<InfoBar> infobar(ConfirmInfoBarDelegate::CreateInfoBar(
27 scoped_ptr<ConfirmInfoBarDelegate>( 26 scoped_ptr<ConfirmInfoBarDelegate>(
28 new RegisterProtocolHandlerInfoBarDelegate(registry, handler)))); 27 new RegisterProtocolHandlerInfoBarDelegate(registry, handler))));
29 28
30 InfoBarManager* infobar_manager = infobar_service->infobar_manager(); 29 for (size_t i = 0; i < infobar_service->infobar_count(); ++i) {
31 for (size_t i = 0; i < infobar_manager->infobar_count(); ++i) { 30 InfoBar* existing_infobar = infobar_service->infobar_at(i);
32 InfoBar* existing_infobar = infobar_manager->infobar_at(i);
33 RegisterProtocolHandlerInfoBarDelegate* existing_delegate = 31 RegisterProtocolHandlerInfoBarDelegate* existing_delegate =
34 existing_infobar->delegate()-> 32 existing_infobar->delegate()->
35 AsRegisterProtocolHandlerInfoBarDelegate(); 33 AsRegisterProtocolHandlerInfoBarDelegate();
36 if ((existing_delegate != NULL) && 34 if ((existing_delegate != NULL) &&
37 existing_delegate->handler_.IsEquivalent(handler)) { 35 existing_delegate->handler_.IsEquivalent(handler)) {
38 infobar_service->ReplaceInfoBar(existing_infobar, infobar.Pass()); 36 infobar_service->ReplaceInfoBar(existing_infobar, infobar.Pass());
39 return; 37 return;
40 } 38 }
41 } 39 }
42 40
(...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after
125 } 123 }
126 124
127 base::string16 RegisterProtocolHandlerInfoBarDelegate::GetProtocolName( 125 base::string16 RegisterProtocolHandlerInfoBarDelegate::GetProtocolName(
128 const ProtocolHandler& handler) const { 126 const ProtocolHandler& handler) const {
129 if (handler.protocol() == "mailto") 127 if (handler.protocol() == "mailto")
130 return l10n_util::GetStringUTF16(IDS_REGISTER_PROTOCOL_HANDLER_MAILTO_NAME); 128 return l10n_util::GetStringUTF16(IDS_REGISTER_PROTOCOL_HANDLER_MAILTO_NAME);
131 if (handler.protocol() == "webcal") 129 if (handler.protocol() == "webcal")
132 return l10n_util::GetStringUTF16(IDS_REGISTER_PROTOCOL_HANDLER_WEBCAL_NAME); 130 return l10n_util::GetStringUTF16(IDS_REGISTER_PROTOCOL_HANDLER_WEBCAL_NAME);
133 return base::UTF8ToUTF16(handler.protocol()); 131 return base::UTF8ToUTF16(handler.protocol());
134 } 132 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698