OLD | NEW |
---|---|
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/android/data_usage/data_use_tab_helper.h" | 5 #include "chrome/browser/android/data_usage/data_use_tab_helper.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "chrome/browser/android/data_usage/data_use_ui_tab_model.h" | 8 #include "chrome/browser/android/data_usage/data_use_ui_tab_model.h" |
9 #include "chrome/browser/android/data_usage/data_use_ui_tab_model_factory.h" | 9 #include "chrome/browser/android/data_usage/data_use_ui_tab_model_factory.h" |
10 #include "chrome/browser/profiles/profile.h" | 10 #include "chrome/browser/profiles/profile.h" |
11 #include "chrome/browser/sessions/session_tab_helper.h" | 11 #include "chrome/browser/sessions/session_tab_helper.h" |
12 #include "content/public/browser/browser_thread.h" | 12 #include "content/public/browser/browser_thread.h" |
13 #include "content/public/browser/navigation_handle.h" | 13 #include "content/public/browser/navigation_handle.h" |
14 #include "content/public/browser/render_frame_host.h" | |
14 #include "ui/base/page_transition_types.h" | 15 #include "ui/base/page_transition_types.h" |
15 | 16 |
16 namespace content { | |
17 class RenderFrameHost; | |
18 } | |
19 | |
20 DEFINE_WEB_CONTENTS_USER_DATA_KEY(DataUseTabHelper); | 17 DEFINE_WEB_CONTENTS_USER_DATA_KEY(DataUseTabHelper); |
21 | 18 |
22 DataUseTabHelper::~DataUseTabHelper() {} | 19 DataUseTabHelper::~DataUseTabHelper() {} |
23 | 20 |
24 DataUseTabHelper::DataUseTabHelper(content::WebContents* web_contents) | 21 DataUseTabHelper::DataUseTabHelper(content::WebContents* web_contents) |
25 : content::WebContentsObserver(web_contents) { | 22 : content::WebContentsObserver(web_contents) { |
26 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); | 23 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); |
27 } | 24 } |
28 | 25 |
29 void DataUseTabHelper::ReadyToCommitNavigation( | 26 void DataUseTabHelper::DidFinishNavigation( |
30 content::NavigationHandle* navigation_handle) { | 27 content::NavigationHandle* navigation_handle) { |
31 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); | 28 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); |
29 if (!navigation_handle->IsInMainFrame()) | |
bengr
2015/11/23 18:26:25
I suppose this makes sense. Add a TODO to consider
tbansal1
2015/11/23 19:58:08
Done.
| |
30 return; | |
32 | 31 |
33 // Notify the DataUseUITabModel. | 32 // Notify the DataUseUITabModel. |
34 chrome::android::DataUseUITabModel* data_use_ui_tab_model = | 33 chrome::android::DataUseUITabModel* data_use_ui_tab_model = |
35 chrome::android::DataUseUITabModelFactory::GetForBrowserContext( | 34 chrome::android::DataUseUITabModelFactory::GetForBrowserContext( |
36 Profile::FromBrowserContext(web_contents()->GetBrowserContext())); | 35 Profile::FromBrowserContext(web_contents()->GetBrowserContext())); |
37 if (data_use_ui_tab_model) { | 36 int32_t tab_id = SessionTabHelper::IdForTab(web_contents()); |
bengr
2015/11/23 18:26:25
Why not make tab_id a SessionID::id_type and inclu
tbansal1
2015/11/23 19:58:08
Done.
| |
37 if (data_use_ui_tab_model && tab_id >= 0) { | |
38 data_use_ui_tab_model->ReportBrowserNavigation( | 38 data_use_ui_tab_model->ReportBrowserNavigation( |
39 navigation_handle->GetURL(), | 39 navigation_handle->GetURL(), |
40 ui::PageTransitionFromInt(navigation_handle->GetPageTransition()), | 40 ui::PageTransitionFromInt(navigation_handle->GetPageTransition()), |
41 SessionTabHelper::IdForTab(web_contents())); | 41 tab_id); |
42 } | 42 } |
43 } | 43 } |
44 | 44 |
45 void DataUseTabHelper::FrameDeleted( | 45 void DataUseTabHelper::RenderFrameDeleted( |
46 content::RenderFrameHost* render_frame_host) { | 46 content::RenderFrameHost* render_frame_host) { |
47 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); | 47 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); |
48 | 48 |
49 // Check if it is a main frame. | |
50 if (render_frame_host->GetParent() != nullptr || | |
51 render_frame_host->IsRenderFrameLive()) { | |
bengr
2015/11/23 18:26:25
Why do you only proceed if the render frame is not
tbansal1
2015/11/23 19:58:08
Done.
| |
52 return; | |
53 } | |
54 | |
49 // Notify the DataUseUITabModel. | 55 // Notify the DataUseUITabModel. |
50 chrome::android::DataUseUITabModel* data_use_ui_tab_model = | 56 chrome::android::DataUseUITabModel* data_use_ui_tab_model = |
51 chrome::android::DataUseUITabModelFactory::GetForBrowserContext( | 57 chrome::android::DataUseUITabModelFactory::GetForBrowserContext( |
52 Profile::FromBrowserContext(web_contents()->GetBrowserContext())); | 58 Profile::FromBrowserContext(web_contents()->GetBrowserContext())); |
53 if (data_use_ui_tab_model) { | 59 int32_t tab_id = SessionTabHelper::IdForTab(web_contents()); |
bengr
2015/11/23 18:26:25
SessionID::id_type?
tbansal1
2015/11/23 19:58:08
Done.
| |
54 data_use_ui_tab_model->ReportTabClosure( | 60 if (data_use_ui_tab_model && tab_id >= 0) |
55 SessionTabHelper::IdForTab(web_contents())); | 61 data_use_ui_tab_model->ReportTabClosure(tab_id); |
56 } | |
57 } | 62 } |
OLD | NEW |