Chromium Code Reviews| OLD | NEW |
|---|---|
| 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/ui/tab_contents/tab_contents.h" | 5 #include "chrome/browser/ui/tab_contents/tab_contents.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/lazy_instance.h" | 8 #include "base/lazy_instance.h" |
| 9 #include "chrome/browser/autofill/autofill_external_delegate.h" | 9 #include "chrome/browser/autofill/autofill_external_delegate.h" |
| 10 #include "chrome/browser/autofill/autofill_manager.h" | 10 #include "chrome/browser/autofill/autofill_manager.h" |
| 11 #include "chrome/browser/automation/automation_tab_helper.h" | 11 #include "chrome/browser/automation/automation_tab_helper.h" |
| 12 #include "chrome/browser/content_settings/tab_specific_content_settings.h" | 12 #include "chrome/browser/content_settings/tab_specific_content_settings.h" |
| 13 #include "chrome/browser/extensions/api/web_navigation/web_navigation_api.h" | 13 #include "chrome/browser/extensions/api/web_navigation/web_navigation_api.h" |
| 14 #include "chrome/browser/extensions/tab_helper.h" | 14 #include "chrome/browser/extensions/tab_helper.h" |
| 15 #include "chrome/browser/external_protocol/external_protocol_observer.h" | 15 #include "chrome/browser/external_protocol/external_protocol_observer.h" |
| 16 #include "chrome/browser/favicon/favicon_download_helper.h" | |
| 16 #include "chrome/browser/favicon/favicon_tab_helper.h" | 17 #include "chrome/browser/favicon/favicon_tab_helper.h" |
| 17 #include "chrome/browser/history/history_tab_helper.h" | 18 #include "chrome/browser/history/history_tab_helper.h" |
| 18 #include "chrome/browser/infobars/infobar_tab_helper.h" | 19 #include "chrome/browser/infobars/infobar_tab_helper.h" |
| 19 #include "chrome/browser/net/load_time_stats.h" | 20 #include "chrome/browser/net/load_time_stats.h" |
| 20 #include "chrome/browser/omnibox_search_hint.h" | 21 #include "chrome/browser/omnibox_search_hint.h" |
| 21 #include "chrome/browser/password_manager/password_manager.h" | 22 #include "chrome/browser/password_manager/password_manager.h" |
| 22 #include "chrome/browser/password_manager/password_manager_delegate_impl.h" | 23 #include "chrome/browser/password_manager/password_manager_delegate_impl.h" |
| 23 #include "chrome/browser/pepper_broker_observer.h" | 24 #include "chrome/browser/pepper_broker_observer.h" |
| 24 #include "chrome/browser/plugins/plugin_observer.h" | 25 #include "chrome/browser/plugins/plugin_observer.h" |
| 25 #include "chrome/browser/prerender/prerender_tab_helper.h" | 26 #include "chrome/browser/prerender/prerender_tab_helper.h" |
| (...skipping 98 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 124 } | 125 } |
| 125 BlockedContentTabHelper::CreateForWebContents(contents); | 126 BlockedContentTabHelper::CreateForWebContents(contents); |
| 126 BookmarkTabHelper::CreateForWebContents(contents); | 127 BookmarkTabHelper::CreateForWebContents(contents); |
| 127 chrome_browser_net::LoadTimeStatsTabHelper::CreateForWebContents(contents); | 128 chrome_browser_net::LoadTimeStatsTabHelper::CreateForWebContents(contents); |
| 128 ConstrainedWindowTabHelper::CreateForWebContents(contents); | 129 ConstrainedWindowTabHelper::CreateForWebContents(contents); |
| 129 CoreTabHelper::CreateForWebContents(contents); | 130 CoreTabHelper::CreateForWebContents(contents); |
| 130 extensions::TabHelper::CreateForWebContents(contents); | 131 extensions::TabHelper::CreateForWebContents(contents); |
| 131 extensions::WebNavigationTabObserver::CreateForWebContents(contents); | 132 extensions::WebNavigationTabObserver::CreateForWebContents(contents); |
| 132 ExternalProtocolObserver::CreateForWebContents(contents); | 133 ExternalProtocolObserver::CreateForWebContents(contents); |
| 133 FaviconTabHelper::CreateForWebContents(contents); | 134 FaviconTabHelper::CreateForWebContents(contents); |
| 135 FaviconDownloadHelper::CreateForWebContentsAndDelegate(contents, | |
| 136 FaviconTabHelper::FromWebContents(contents)); | |
|
sky
2012/10/24 16:38:10
Doesn't doing this lead to the possibility of Favi
Cait (Slow)
2012/10/24 17:31:20
That is a possibility. The FaviconDownloadHelper o
| |
| 134 FindTabHelper::CreateForWebContents(contents); | 137 FindTabHelper::CreateForWebContents(contents); |
| 135 HistoryTabHelper::CreateForWebContents(contents); | 138 HistoryTabHelper::CreateForWebContents(contents); |
| 136 HungPluginTabHelper::CreateForWebContents(contents); | 139 HungPluginTabHelper::CreateForWebContents(contents); |
| 137 InfoBarTabHelper::CreateForWebContents(contents); | 140 InfoBarTabHelper::CreateForWebContents(contents); |
| 138 MetroPinTabHelper::CreateForWebContents(contents); | 141 MetroPinTabHelper::CreateForWebContents(contents); |
| 139 NavigationMetricsRecorder::CreateForWebContents(contents); | 142 NavigationMetricsRecorder::CreateForWebContents(contents); |
| 140 PasswordManagerDelegateImpl::CreateForWebContents(contents); | 143 PasswordManagerDelegateImpl::CreateForWebContents(contents); |
| 141 PasswordManager::CreateForWebContentsAndDelegate( | 144 PasswordManager::CreateForWebContentsAndDelegate( |
| 142 contents, PasswordManagerDelegateImpl::FromWebContents(contents)); | 145 contents, PasswordManagerDelegateImpl::FromWebContents(contents)); |
| 143 PepperBrokerObserver::CreateForWebContents(contents); | 146 PepperBrokerObserver::CreateForWebContents(contents); |
| (...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 222 | 225 |
| 223 //////////////////////////////////////////////////////////////////////////////// | 226 //////////////////////////////////////////////////////////////////////////////// |
| 224 // WebContentsObserver overrides | 227 // WebContentsObserver overrides |
| 225 | 228 |
| 226 void TabContents::WebContentsDestroyed(WebContents* tab) { | 229 void TabContents::WebContentsDestroyed(WebContents* tab) { |
| 227 // Destruction of the WebContents should only be done by us from our | 230 // Destruction of the WebContents should only be done by us from our |
| 228 // destructor. Otherwise it's very likely we (or one of the helpers we own) | 231 // destructor. Otherwise it's very likely we (or one of the helpers we own) |
| 229 // will attempt to access the WebContents and we'll crash. | 232 // will attempt to access the WebContents and we'll crash. |
| 230 DCHECK(in_destructor_); | 233 DCHECK(in_destructor_); |
| 231 } | 234 } |
| OLD | NEW |