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

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

Issue 211273007: Split InfoBarService core code into InfoBarManager (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase + comments 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"
10 #include "chrome/browser/infobars/infobar_service.h" 11 #include "chrome/browser/infobars/infobar_service.h"
11 #include "chrome/common/url_constants.h" 12 #include "chrome/common/url_constants.h"
12 #include "content/public/browser/user_metrics.h" 13 #include "content/public/browser/user_metrics.h"
13 #include "content/public/browser/web_contents.h" 14 #include "content/public/browser/web_contents.h"
14 #include "grit/generated_resources.h" 15 #include "grit/generated_resources.h"
15 #include "ui/base/l10n/l10n_util.h" 16 #include "ui/base/l10n/l10n_util.h"
16 17
17 // static 18 // static
18 void RegisterProtocolHandlerInfoBarDelegate::Create( 19 void RegisterProtocolHandlerInfoBarDelegate::Create(
19 InfoBarService* infobar_service, 20 InfoBarService* infobar_service,
20 ProtocolHandlerRegistry* registry, 21 ProtocolHandlerRegistry* registry,
21 const ProtocolHandler& handler) { 22 const ProtocolHandler& handler) {
22 content::RecordAction( 23 content::RecordAction(
23 base::UserMetricsAction("RegisterProtocolHandler.InfoBar_Shown")); 24 base::UserMetricsAction("RegisterProtocolHandler.InfoBar_Shown"));
24 25
25 scoped_ptr<InfoBar> infobar(ConfirmInfoBarDelegate::CreateInfoBar( 26 scoped_ptr<InfoBar> infobar(ConfirmInfoBarDelegate::CreateInfoBar(
26 scoped_ptr<ConfirmInfoBarDelegate>( 27 scoped_ptr<ConfirmInfoBarDelegate>(
27 new RegisterProtocolHandlerInfoBarDelegate(registry, handler)))); 28 new RegisterProtocolHandlerInfoBarDelegate(registry, handler))));
28 29
29 for (size_t i = 0; i < infobar_service->infobar_count(); ++i) { 30 InfoBarManager* infobar_manager = infobar_service->infobar_manager();
30 InfoBar* existing_infobar = infobar_service->infobar_at(i); 31 for (size_t i = 0; i < infobar_manager->infobar_count(); ++i) {
32 InfoBar* existing_infobar = infobar_manager->infobar_at(i);
31 RegisterProtocolHandlerInfoBarDelegate* existing_delegate = 33 RegisterProtocolHandlerInfoBarDelegate* existing_delegate =
32 existing_infobar->delegate()-> 34 existing_infobar->delegate()->
33 AsRegisterProtocolHandlerInfoBarDelegate(); 35 AsRegisterProtocolHandlerInfoBarDelegate();
34 if ((existing_delegate != NULL) && 36 if ((existing_delegate != NULL) &&
35 existing_delegate->handler_.IsEquivalent(handler)) { 37 existing_delegate->handler_.IsEquivalent(handler)) {
36 infobar_service->ReplaceInfoBar(existing_infobar, infobar.Pass()); 38 infobar_service->ReplaceInfoBar(existing_infobar, infobar.Pass());
37 return; 39 return;
38 } 40 }
39 } 41 }
40 42
(...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after
123 } 125 }
124 126
125 base::string16 RegisterProtocolHandlerInfoBarDelegate::GetProtocolName( 127 base::string16 RegisterProtocolHandlerInfoBarDelegate::GetProtocolName(
126 const ProtocolHandler& handler) const { 128 const ProtocolHandler& handler) const {
127 if (handler.protocol() == "mailto") 129 if (handler.protocol() == "mailto")
128 return l10n_util::GetStringUTF16(IDS_REGISTER_PROTOCOL_HANDLER_MAILTO_NAME); 130 return l10n_util::GetStringUTF16(IDS_REGISTER_PROTOCOL_HANDLER_MAILTO_NAME);
129 if (handler.protocol() == "webcal") 131 if (handler.protocol() == "webcal")
130 return l10n_util::GetStringUTF16(IDS_REGISTER_PROTOCOL_HANDLER_WEBCAL_NAME); 132 return l10n_util::GetStringUTF16(IDS_REGISTER_PROTOCOL_HANDLER_WEBCAL_NAME);
131 return base::UTF8ToUTF16(handler.protocol()); 133 return base::UTF8ToUTF16(handler.protocol());
132 } 134 }
OLDNEW
« no previous file with comments | « chrome/browser/content_settings/permission_queue_controller.cc ('k') | chrome/browser/download/download_browsertest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698