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 //------------------------------------------------------------------------------ | 5 //------------------------------------------------------------------------------ |
6 // Description of the life cycle of a instance of MetricsService. | 6 // Description of the life cycle of a instance of MetricsService. |
7 // | 7 // |
8 // OVERVIEW | 8 // OVERVIEW |
9 // | 9 // |
10 // A MetricsService instance is typically created at application startup. It is | 10 // A MetricsService instance is typically created at application startup. It is |
(...skipping 330 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
341 local_state_->SetInt64(prefs::kInstallDate, base::Time::Now().ToTimeT()); | 341 local_state_->SetInt64(prefs::kInstallDate, base::Time::Now().ToTimeT()); |
342 } | 342 } |
343 | 343 |
344 MetricsService::~MetricsService() { | 344 MetricsService::~MetricsService() { |
345 DisableRecording(); | 345 DisableRecording(); |
346 } | 346 } |
347 | 347 |
348 void MetricsService::InitializeMetricsRecordingState() { | 348 void MetricsService::InitializeMetricsRecordingState() { |
349 InitializeMetricsState(); | 349 InitializeMetricsState(); |
350 | 350 |
351 base::Closure callback = base::Bind(&MetricsService::StartScheduledUpload, | 351 base::Closure upload_callback = |
352 self_ptr_factory_.GetWeakPtr()); | 352 base::Bind(&MetricsService::StartScheduledUpload, |
353 scheduler_.reset(new MetricsReportingScheduler(callback)); | 353 self_ptr_factory_.GetWeakPtr()); |
| 354 scheduler_.reset( |
| 355 new MetricsReportingScheduler(upload_callback, is_cellular_callback_)); |
354 } | 356 } |
355 | 357 |
356 void MetricsService::Start() { | 358 void MetricsService::Start() { |
357 HandleIdleSinceLastTransmission(false); | 359 HandleIdleSinceLastTransmission(false); |
358 EnableRecording(); | 360 EnableRecording(); |
359 EnableReporting(); | 361 EnableReporting(); |
360 } | 362 } |
361 | 363 |
362 bool MetricsService::StartIfMetricsReportingEnabled() { | 364 bool MetricsService::StartIfMetricsReportingEnabled() { |
363 const bool enabled = state_manager_->IsMetricsReportingEnabled(); | 365 const bool enabled = state_manager_->IsMetricsReportingEnabled(); |
(...skipping 892 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1256 DCHECK(IsSingleThreaded()); | 1258 DCHECK(IsSingleThreaded()); |
1257 local_state_->SetBoolean(path, value); | 1259 local_state_->SetBoolean(path, value); |
1258 RecordCurrentState(local_state_); | 1260 RecordCurrentState(local_state_); |
1259 } | 1261 } |
1260 | 1262 |
1261 void MetricsService::RecordCurrentState(PrefService* pref) { | 1263 void MetricsService::RecordCurrentState(PrefService* pref) { |
1262 pref->SetInt64(prefs::kStabilityLastTimestampSec, | 1264 pref->SetInt64(prefs::kStabilityLastTimestampSec, |
1263 base::Time::Now().ToTimeT()); | 1265 base::Time::Now().ToTimeT()); |
1264 } | 1266 } |
1265 | 1267 |
| 1268 void MetricsService::SetConnectionTypeCallback( |
| 1269 base::Callback<void(bool*)> is_cellular_callback) { |
| 1270 DCHECK(!scheduler_); |
| 1271 is_cellular_callback_ = is_cellular_callback; |
| 1272 } |
| 1273 |
1266 } // namespace metrics | 1274 } // namespace metrics |
OLD | NEW |