Index: chrome/browser/tab_contents/tab_contents.cc |
diff --git a/chrome/browser/tab_contents/tab_contents.cc b/chrome/browser/tab_contents/tab_contents.cc |
index 2f946be16bb945a3a29a5caff2461bab3e7b1847..34d5adfab950d0053758e08c3dcecf0b08436728 100644 |
--- a/chrome/browser/tab_contents/tab_contents.cc |
+++ b/chrome/browser/tab_contents/tab_contents.cc |
@@ -22,6 +22,8 @@ |
#include "chrome/browser/child_process_security_policy.h" |
#include "chrome/browser/content_settings/content_settings_details.h" |
#include "chrome/browser/content_settings/host_content_settings_map.h" |
+#include "chrome/browser/custom_handlers/protocol_handler_registry.h" |
+#include "chrome/browser/custom_handlers/register_protocol_handler_infobar_delegate.h" |
#include "chrome/browser/debugger/devtools_manager.h" |
#include "chrome/browser/defaults.h" |
#include "chrome/browser/desktop_notification_handler.h" |
@@ -2620,6 +2622,23 @@ void TabContents::ProcessExternalHostMessage(const std::string& message, |
delegate()->ForwardMessageToExternalHost(message, origin, target); |
} |
+void TabContents::RegisterProtocolHandler(const std::string& protocol, |
+ const GURL& url, |
+ const string16& title) { |
+ ProtocolHandler* handler = ProtocolHandler::CreateProtocolHandler(protocol, url, title); |
+ |
+ if (handler == NULL) { |
+ return; |
+ } |
+ |
+ if (profile()->GetProtocolHandlerRegistry()->IsAlreadyRegistered(handler)) { |
+ return; |
tony
2011/02/14 23:40:07
Nit: 2 space indent. I would probably add a TODO(
koz (OOO until 15th September)
2011/02/15 03:37:27
Actually I've implemented the logic for showing a
|
+ } |
+ |
+ AddInfoBar(new RegisterProtocolHandlerInfoBarDelegate( |
+ this, profile()->GetProtocolHandlerRegistry(), handler)); |
+} |
+ |
void TabContents::RunJavaScriptMessage( |
const std::wstring& message, |
const std::wstring& default_prompt, |