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 #ifndef CHROME_BROWSER_RLZ_RLZ_H_ | 5 #ifndef CHROME_BROWSER_RLZ_RLZ_H_ |
6 #define CHROME_BROWSER_RLZ_RLZ_H_ | 6 #define CHROME_BROWSER_RLZ_RLZ_H_ |
7 #pragma once | 7 #pragma once |
8 | 8 |
9 #include "build/build_config.h" | 9 #include "build/build_config.h" |
10 | 10 |
11 #if defined(OS_WIN) | 11 #if defined(OS_WIN) || defined(OS_MACOSX) |
12 | 12 |
13 #include <map> | 13 #include <map> |
14 #include <string> | 14 #include <string> |
15 | 15 |
16 #include "base/basictypes.h" | 16 #include "base/basictypes.h" |
17 #include "base/memory/singleton.h" | 17 #include "base/memory/singleton.h" |
18 #include "base/string16.h" | 18 #include "base/string16.h" |
| 19 #include "base/threading/sequenced_worker_pool.h" |
19 #include "content/public/browser/notification_observer.h" | 20 #include "content/public/browser/notification_observer.h" |
20 #include "content/public/browser/notification_registrar.h" | 21 #include "content/public/browser/notification_registrar.h" |
21 #include "rlz/lib/rlz_lib.h" | 22 #include "rlz/lib/rlz_lib.h" |
22 | 23 |
23 // RLZ is a library which is used to measure distribution scenarios. | 24 // RLZ is a library which is used to measure distribution scenarios. |
24 // Its job is to record certain lifetime events in the registry and to send | 25 // Its job is to record certain lifetime events in the registry and to send |
25 // them encoded as a compact string at most twice. The sent data does | 26 // them encoded as a compact string at most twice. The sent data does |
26 // not contain information that can be used to identify a user or to infer | 27 // not contain information that can be used to identify a user or to infer |
27 // browsing habits. The API in this file is a wrapper around the open source | 28 // browsing habits. The API in this file is a wrapper around the open source |
28 // RLZ library which can be found at http://code.google.com/p/rlz. | 29 // RLZ library which can be found at http://code.google.com/p/rlz. |
(...skipping 90 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
119 // Tracker used for testing purposes only. If this value is non-NULL, it | 120 // Tracker used for testing purposes only. If this value is non-NULL, it |
120 // will be returned from GetInstance() instead of the regular singleton. | 121 // will be returned from GetInstance() instead of the regular singleton. |
121 static RLZTracker* tracker_; | 122 static RLZTracker* tracker_; |
122 | 123 |
123 // Configuation data for RLZ tracker. Set by call to Init(). | 124 // Configuation data for RLZ tracker. Set by call to Init(). |
124 bool first_run_; | 125 bool first_run_; |
125 bool send_ping_immediately_; | 126 bool send_ping_immediately_; |
126 bool google_default_search_; | 127 bool google_default_search_; |
127 bool google_default_homepage_; | 128 bool google_default_homepage_; |
128 | 129 |
| 130 // Unique sequence token so that tasks posted by RLZTracker are executed |
| 131 // sequentially in the blocking pool. |
| 132 base::SequencedWorkerPool::SequenceToken worker_pool_token_; |
| 133 |
129 // Keeps track if the RLZ tracker has already performed its delayed | 134 // Keeps track if the RLZ tracker has already performed its delayed |
130 // initialization. | 135 // initialization. |
131 bool already_ran_; | 136 bool already_ran_; |
132 | 137 |
133 // Keeps a cache of RLZ access point strings, since they rarely change. | 138 // Keeps a cache of RLZ access point strings, since they rarely change. |
134 // The cache must be protected by a lock since it may be accessed from | 139 // The cache must be protected by a lock since it may be accessed from |
135 // the UI thread for reading and the IO thread for reading and/or writing. | 140 // the UI thread for reading and the IO thread for reading and/or writing. |
136 base::Lock cache_lock_; | 141 base::Lock cache_lock_; |
137 std::map<rlz_lib::AccessPoint, string16> rlz_cache_; | 142 std::map<rlz_lib::AccessPoint, string16> rlz_cache_; |
138 | 143 |
139 // Keeps track of whether the omnibox or host page have been used. | 144 // Keeps track of whether the omnibox or host page have been used. |
140 bool omnibox_used_; | 145 bool omnibox_used_; |
141 bool homepage_used_; | 146 bool homepage_used_; |
142 | 147 |
143 content::NotificationRegistrar registrar_; | 148 content::NotificationRegistrar registrar_; |
144 | 149 |
145 DISALLOW_COPY_AND_ASSIGN(RLZTracker); | 150 DISALLOW_COPY_AND_ASSIGN(RLZTracker); |
146 }; | 151 }; |
147 | 152 |
148 #endif // defined(OS_WIN) | 153 #endif // defined(OS_WIN) || defined(OS_MACOSX) |
149 | 154 |
150 #endif // CHROME_BROWSER_RLZ_RLZ_H_ | 155 #endif // CHROME_BROWSER_RLZ_RLZ_H_ |
OLD | NEW |