OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/metrics/signin_status_metrics_provider.h" | 5 #include "chrome/browser/metrics/signin_status_metrics_provider.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "base/bind.h" | 10 #include "base/bind.h" |
11 #include "base/message_loop/message_loop.h" | 11 #include "base/location.h" |
12 #include "base/metrics/histogram.h" | 12 #include "base/metrics/histogram.h" |
| 13 #include "base/single_thread_task_runner.h" |
| 14 #include "base/thread_task_runner_handle.h" |
13 #include "chrome/browser/browser_process.h" | 15 #include "chrome/browser/browser_process.h" |
14 #include "chrome/browser/profiles/profile.h" | 16 #include "chrome/browser/profiles/profile.h" |
15 #include "chrome/browser/profiles/profile_info_cache.h" | 17 #include "chrome/browser/profiles/profile_info_cache.h" |
16 #include "chrome/browser/profiles/profile_manager.h" | 18 #include "chrome/browser/profiles/profile_manager.h" |
17 #include "chrome/browser/ui/browser.h" | 19 #include "chrome/browser/ui/browser.h" |
18 #include "chrome/browser/ui/browser_list.h" | 20 #include "chrome/browser/ui/browser_list.h" |
19 #include "components/signin/core/browser/signin_manager.h" | 21 #include "components/signin/core/browser/signin_manager.h" |
20 | 22 |
21 #if !defined(OS_ANDROID) | 23 #if !defined(OS_ANDROID) |
22 #include "chrome/browser/ui/browser_finder.h" | 24 #include "chrome/browser/ui/browser_finder.h" |
(...skipping 21 matching lines...) Expand all Loading... |
44 } // namespace | 46 } // namespace |
45 | 47 |
46 SigninStatusMetricsProvider::SigninStatusMetricsProvider(bool is_test) | 48 SigninStatusMetricsProvider::SigninStatusMetricsProvider(bool is_test) |
47 : scoped_observer_(this), | 49 : scoped_observer_(this), |
48 is_test_(is_test), | 50 is_test_(is_test), |
49 weak_ptr_factory_(this) { | 51 weak_ptr_factory_(this) { |
50 if (is_test_) | 52 if (is_test_) |
51 return; | 53 return; |
52 | 54 |
53 // Postpone the initialization until all threads are created. | 55 // Postpone the initialization until all threads are created. |
54 base::MessageLoop::current()->PostTask( | 56 base::ThreadTaskRunnerHandle::Get()->PostTask( |
55 FROM_HERE, | 57 FROM_HERE, base::Bind(&SigninStatusMetricsProvider::Initialize, |
56 base::Bind(&SigninStatusMetricsProvider::Initialize, | 58 weak_ptr_factory_.GetWeakPtr())); |
57 weak_ptr_factory_.GetWeakPtr())); | |
58 } | 59 } |
59 | 60 |
60 SigninStatusMetricsProvider::~SigninStatusMetricsProvider() { | 61 SigninStatusMetricsProvider::~SigninStatusMetricsProvider() { |
61 if (is_test_) | 62 if (is_test_) |
62 return; | 63 return; |
63 | 64 |
64 #if !defined(OS_ANDROID) | 65 #if !defined(OS_ANDROID) |
65 BrowserList::RemoveObserver(this); | 66 BrowserList::RemoveObserver(this); |
66 #endif | 67 #endif |
67 | 68 |
(...skipping 179 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
247 SetSigninStatus(UNKNOWN_SIGNIN_STATUS); | 248 SetSigninStatus(UNKNOWN_SIGNIN_STATUS); |
248 } else { | 249 } else { |
249 UpdateInitialSigninStatus(opened_profiles_count, signed_in_profiles_count); | 250 UpdateInitialSigninStatus(opened_profiles_count, signed_in_profiles_count); |
250 } | 251 } |
251 } | 252 } |
252 | 253 |
253 SigninStatusMetricsProvider::SigninStatus | 254 SigninStatusMetricsProvider::SigninStatus |
254 SigninStatusMetricsProvider::GetSigninStatusForTesting() { | 255 SigninStatusMetricsProvider::GetSigninStatusForTesting() { |
255 return signin_status(); | 256 return signin_status(); |
256 } | 257 } |
OLD | NEW |