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/metrics_services_manager.h" | 5 #include "chrome/browser/metrics/metrics_services_manager.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/prefs/pref_service.h" | 8 #include "base/prefs/pref_service.h" |
9 #include "chrome/browser/metrics/chrome_metrics_service_client.h" | 9 #include "chrome/browser/metrics/chrome_metrics_service_client.h" |
10 #include "chrome/browser/metrics/extensions_metrics_provider.h" | |
11 #include "chrome/browser/metrics/metrics_service.h" | 10 #include "chrome/browser/metrics/metrics_service.h" |
12 #include "chrome/browser/metrics/metrics_state_manager.h" | 11 #include "chrome/browser/metrics/metrics_state_manager.h" |
13 #include "chrome/browser/metrics/variations/variations_service.h" | 12 #include "chrome/browser/metrics/variations/variations_service.h" |
14 #include "chrome/common/chrome_switches.h" | 13 #include "chrome/common/chrome_switches.h" |
15 #include "chrome/common/pref_names.h" | 14 #include "chrome/common/pref_names.h" |
16 #include "components/rappor/rappor_service.h" | 15 #include "components/rappor/rappor_service.h" |
17 | 16 |
18 #if defined(OS_CHROMEOS) | 17 #if defined(OS_CHROMEOS) |
19 #include "chrome/browser/chromeos/settings/cros_settings.h" | 18 #include "chrome/browser/chromeos/settings/cros_settings.h" |
20 #endif | 19 #endif |
21 | 20 |
22 MetricsServicesManager::MetricsServicesManager(PrefService* local_state) | 21 MetricsServicesManager::MetricsServicesManager(PrefService* local_state) |
23 : local_state_(local_state) { | 22 : local_state_(local_state) { |
24 DCHECK(local_state); | 23 DCHECK(local_state); |
25 } | 24 } |
26 | 25 |
27 MetricsServicesManager::~MetricsServicesManager() { | 26 MetricsServicesManager::~MetricsServicesManager() { |
28 } | 27 } |
29 | 28 |
30 MetricsService* MetricsServicesManager::GetMetricsService() { | 29 MetricsService* MetricsServicesManager::GetMetricsService() { |
31 DCHECK(thread_checker_.CalledOnValidThread()); | 30 DCHECK(thread_checker_.CalledOnValidThread()); |
32 if (!metrics_service_client_) { | 31 if (!metrics_service_client_) { |
33 metrics_service_client_ = | 32 metrics_service_client_ = |
34 ChromeMetricsServiceClient::Create(GetMetricsStateManager()).Pass(); | 33 ChromeMetricsServiceClient::Create(GetMetricsStateManager()).Pass(); |
35 metrics_service_->RegisterMetricsProvider( | |
36 scoped_ptr<metrics::MetricsProvider>( | |
37 new ExtensionsMetricsProvider(GetMetricsStateManager()))); | |
38 } | 34 } |
39 return metrics_service_client_->metrics_service(); | 35 return metrics_service_client_->metrics_service(); |
40 } | 36 } |
41 | 37 |
42 rappor::RapporService* MetricsServicesManager::GetRapporService() { | 38 rappor::RapporService* MetricsServicesManager::GetRapporService() { |
43 DCHECK(thread_checker_.CalledOnValidThread()); | 39 DCHECK(thread_checker_.CalledOnValidThread()); |
44 if (!rappor_service_) | 40 if (!rappor_service_) |
45 rappor_service_.reset(new rappor::RapporService); | 41 rappor_service_.reset(new rappor::RapporService); |
46 return rappor_service_.get(); | 42 return rappor_service_.get(); |
47 } | 43 } |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
81 #if defined(GOOGLE_CHROME_BUILD) | 77 #if defined(GOOGLE_CHROME_BUILD) |
82 #if defined(OS_CHROMEOS) | 78 #if defined(OS_CHROMEOS) |
83 chromeos::CrosSettings::Get()->GetBoolean(chromeos::kStatsReportingPref, | 79 chromeos::CrosSettings::Get()->GetBoolean(chromeos::kStatsReportingPref, |
84 &enabled); | 80 &enabled); |
85 #else | 81 #else |
86 enabled = local_state_->GetBoolean(prefs::kMetricsReportingEnabled); | 82 enabled = local_state_->GetBoolean(prefs::kMetricsReportingEnabled); |
87 #endif // #if defined(OS_CHROMEOS) | 83 #endif // #if defined(OS_CHROMEOS) |
88 #endif // defined(GOOGLE_CHROME_BUILD) | 84 #endif // defined(GOOGLE_CHROME_BUILD) |
89 return enabled; | 85 return enabled; |
90 } | 86 } |
OLD | NEW |