Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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 #import "ios/chrome/browser/tabs/tab_helper_util.h" | 5 #import "ios/chrome/browser/tabs/tab_helper_util.h" |
| 6 | 6 |
| 7 #if !defined(__has_feature) || !__has_feature(objc_arc) | 7 #if !defined(__has_feature) || !__has_feature(objc_arc) |
| 8 #error "This file requires ARC support." | 8 #error "This file requires ARC support." |
| 9 #endif | 9 #endif |
| 10 | 10 |
| (...skipping 17 matching lines...) Expand all Loading... | |
| 28 #import "ios/chrome/browser/store_kit/store_kit_tab_helper.h" | 28 #import "ios/chrome/browser/store_kit/store_kit_tab_helper.h" |
| 29 #import "ios/chrome/browser/sync/ios_chrome_synced_tab_delegate.h" | 29 #import "ios/chrome/browser/sync/ios_chrome_synced_tab_delegate.h" |
| 30 #import "ios/chrome/browser/tabs/legacy_tab_helper.h" | 30 #import "ios/chrome/browser/tabs/legacy_tab_helper.h" |
| 31 #import "ios/chrome/browser/tabs/tab.h" | 31 #import "ios/chrome/browser/tabs/tab.h" |
| 32 #import "ios/chrome/browser/tabs/tab_private.h" | 32 #import "ios/chrome/browser/tabs/tab_private.h" |
| 33 #import "ios/chrome/browser/translate/chrome_ios_translate_client.h" | 33 #import "ios/chrome/browser/translate/chrome_ios_translate_client.h" |
| 34 #import "ios/chrome/browser/web/blocked_popup_tab_helper.h" | 34 #import "ios/chrome/browser/web/blocked_popup_tab_helper.h" |
| 35 #import "ios/chrome/browser/web/network_activity_indicator_tab_helper.h" | 35 #import "ios/chrome/browser/web/network_activity_indicator_tab_helper.h" |
| 36 #import "ios/chrome/browser/web/repost_form_tab_helper.h" | 36 #import "ios/chrome/browser/web/repost_form_tab_helper.h" |
| 37 #import "ios/chrome/browser/web/sad_tab_tab_helper.h" | 37 #import "ios/chrome/browser/web/sad_tab_tab_helper.h" |
| 38 #import "ios/chrome/browser/web/tab_id_tab_helper.h" | |
| 38 #import "ios/public/provider/chrome/browser/chrome_browser_provider.h" | 39 #import "ios/public/provider/chrome/browser/chrome_browser_provider.h" |
| 39 #import "ios/web/public/web_state/web_state.h" | 40 #import "ios/web/public/web_state/web_state.h" |
| 40 | 41 |
| 41 void AttachTabHelpers(web::WebState* web_state) { | 42 void AttachTabHelpers(web::WebState* web_state) { |
| 43 // TabIDTabHelper provides the TabID, which is necessary in other helpers. | |
|
Eugene But (OOO till 7-30)
2017/06/23 22:44:56
nit: Does this comment add anything?
edchin
2017/06/26 16:20:57
Updated to be more specific.
| |
| 44 TabIDTabHelper::CreateForWebState(web_state); | |
| 42 LegacyTabHelper::CreateForWebState(web_state); | 45 LegacyTabHelper::CreateForWebState(web_state); |
| 43 Tab* tab = LegacyTabHelper::GetTabForWebState(web_state); | 46 Tab* tab = LegacyTabHelper::GetTabForWebState(web_state); |
| 44 DCHECK(tab); | 47 DCHECK(tab); |
| 45 | 48 |
| 46 ios::ChromeBrowserState* browser_state = | 49 ios::ChromeBrowserState* browser_state = |
| 47 ios::ChromeBrowserState::FromBrowserState(web_state->GetBrowserState()); | 50 ios::ChromeBrowserState::FromBrowserState(web_state->GetBrowserState()); |
| 48 | 51 |
| 49 // IOSChromeSessionTabHelper comes first because it sets up the tab ID, | 52 // IOSChromeSessionTabHelper comes first because it sets up the session ID, |
| 50 // and other helpers may rely on that. | 53 // and other helpers may rely on that. |
| 51 IOSChromeSessionTabHelper::CreateForWebState(web_state); | 54 IOSChromeSessionTabHelper::CreateForWebState(web_state); |
| 52 | 55 |
| 53 NetworkActivityIndicatorTabHelper::CreateForWebState(web_state, tab.tabId); | 56 NetworkActivityIndicatorTabHelper::CreateForWebState(web_state, tab.tabId); |
| 54 IOSChromeSyncedTabDelegate::CreateForWebState(web_state); | 57 IOSChromeSyncedTabDelegate::CreateForWebState(web_state); |
| 55 InfoBarManagerImpl::CreateForWebState(web_state); | 58 InfoBarManagerImpl::CreateForWebState(web_state); |
| 56 IOSSecurityStateTabHelper::CreateForWebState(web_state); | 59 IOSSecurityStateTabHelper::CreateForWebState(web_state); |
| 57 RepostFormTabHelper::CreateForWebState(web_state); | 60 RepostFormTabHelper::CreateForWebState(web_state); |
| 58 BlockedPopupTabHelper::CreateForWebState(web_state); | 61 BlockedPopupTabHelper::CreateForWebState(web_state); |
| 59 FindTabHelper::CreateForWebState(web_state, tab.findInPageControllerDelegate); | 62 FindTabHelper::CreateForWebState(web_state, tab.findInPageControllerDelegate); |
| (...skipping 24 matching lines...) Expand all Loading... | |
| 84 web_state, | 87 web_state, |
| 85 ios::TopSitesFactory::GetForBrowserState(original_browser_state).get()); | 88 ios::TopSitesFactory::GetForBrowserState(original_browser_state).get()); |
| 86 | 89 |
| 87 // Allow the embedder to attach tab helpers. | 90 // Allow the embedder to attach tab helpers. |
| 88 ios::GetChromeBrowserProvider()->AttachTabHelpers(web_state, tab); | 91 ios::GetChromeBrowserProvider()->AttachTabHelpers(web_state, tab); |
| 89 | 92 |
| 90 // Allow the Tab to attach tab helper like objects (all those objects should | 93 // Allow the Tab to attach tab helper like objects (all those objects should |
| 91 // really be tab helpers and created above). | 94 // really be tab helpers and created above). |
| 92 [tab attachTabHelpers]; | 95 [tab attachTabHelpers]; |
| 93 } | 96 } |
| OLD | NEW |