Index: chrome/browser/android/data_usage/data_use_tab_model.h |
diff --git a/chrome/browser/android/data_usage/data_use_tab_model.h b/chrome/browser/android/data_usage/data_use_tab_model.h |
index 43a07bdb110c5a8ac329cb20af38617e10afe9e3..8789d41bbf8df177c91afeeabd9f023b52d64433 100644 |
--- a/chrome/browser/android/data_usage/data_use_tab_model.h |
+++ b/chrome/browser/android/data_usage/data_use_tab_model.h |
@@ -14,7 +14,7 @@ |
#include "base/macros.h" |
#include "base/memory/ref_counted.h" |
#include "base/memory/weak_ptr.h" |
-#include "base/observer_list_threadsafe.h" |
+#include "base/observer_list.h" |
#include "base/threading/thread_checker.h" |
#include "chrome/browser/android/data_usage/tab_data_use_entry.h" |
#include "components/data_usage/core/data_use.h" |
@@ -83,12 +83,10 @@ class DataUseTabModel { |
// Notifies the DataUseTabModel of navigation events. |tab_id| is the source |
// tab of the generated event, |transition| indicates the type of the UI |
- // event/transition, |url| is the URL in the source tab, |package| indicates |
- // the android package name of external application that initiated the event. |
+ // event/transition, |url| is the URL in the source tab. |
void OnNavigationEvent(int32_t tab_id, |
TransitionType transition, |
- const GURL& url, |
- const std::string& package); |
+ const GURL& url); |
// Notifies the DataUseTabModel that tab with |tab_id| is closed. Any active |
// tracking sessions for the tab are terminated, and the tab is marked as |
@@ -102,11 +100,20 @@ class DataUseTabModel { |
bool GetLabelForDataUse(const data_usage::DataUse& data_use, |
std::string* output_label) const; |
- // Adds or removes observers from the observer list. These functions are |
- // thread-safe and can be called from any thread. |
+ // Adds or removes observers from the observer list. Must be called only on |
+ // IO thread. |
void AddObserver(TabDataUseObserver* observer); |
void RemoveObserver(TabDataUseObserver* observer); |
+ protected: |
+ // Notifies the observers that a data usage tracking session started for |
+ // |tab_id|. Protected for testing. |
+ void NotifyObserversOfTrackingStarting(int32_t tab_id); |
+ |
+ // Notifies the observers that an active data usage tracking session ended for |
+ // |tab_id|. Protected for testing. |
+ void NotifyObserversOfTrackingEnding(int32_t tab_id); |
+ |
private: |
friend class DataUseTabModelTest; |
friend class MockTabDataUseEntryTest; |
@@ -127,14 +134,6 @@ class DataUseTabModel { |
// about. |
static size_t GetMaxTabEntriesForTests(); |
- // Notifies the observers that a data usage tracking session started for |
- // |tab_id|. |
- void NotifyObserversOfTrackingStarting(int32_t tab_id); |
- |
- // Notifies the observers that an active data usage tracking session ended for |
- // |tab_id|. |
- void NotifyObserversOfTrackingEnding(int32_t tab_id); |
- |
// Initiates a new tracking session with the |label| for tab with id |tab_id|. |
void StartTrackingDataUse(int32_t tab_id, const std::string& label); |
@@ -152,16 +151,13 @@ class DataUseTabModel { |
const ExternalDataUseObserver* data_use_observer_; |
// List of observers waiting for tracking session start and end notifications. |
- const scoped_refptr<base::ObserverListThreadSafe<TabDataUseObserver>> |
- observer_list_; |
+ base::ObserverList<TabDataUseObserver> observer_list_; |
// Maintains the tracking sessions of multiple tabs. |
TabEntryMap active_tabs_; |
base::ThreadChecker thread_checker_; |
- // |weak_factory_| is used for generating weak pointers to be passed to |
- // DataUseTabUIManager on the UI thread. |
base::WeakPtrFactory<DataUseTabModel> weak_factory_; |
DISALLOW_COPY_AND_ASSIGN(DataUseTabModel); |