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 #include "chrome/common/metrics/metrics_log_manager.h" | 5 #include "components/metrics/metrics_log_manager.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 | 8 |
9 #include "base/metrics/histogram.h" | 9 #include "base/metrics/histogram.h" |
10 #include "base/sha1.h" | 10 #include "base/sha1.h" |
11 #include "base/strings/string_util.h" | 11 #include "base/strings/string_util.h" |
12 #include "base/timer/elapsed_timer.h" | 12 #include "base/timer/elapsed_timer.h" |
13 #include "chrome/common/metrics/metrics_log_base.h" | 13 #include "components/metrics/metrics_log_base.h" |
| 14 |
| 15 namespace metrics { |
14 | 16 |
15 MetricsLogManager::SerializedLog::SerializedLog() {} | 17 MetricsLogManager::SerializedLog::SerializedLog() {} |
16 MetricsLogManager::SerializedLog::~SerializedLog() {} | 18 MetricsLogManager::SerializedLog::~SerializedLog() {} |
17 | 19 |
18 bool MetricsLogManager::SerializedLog::IsEmpty() const { | 20 bool MetricsLogManager::SerializedLog::IsEmpty() const { |
19 return log_text_.empty(); | 21 return log_text_.empty(); |
20 } | 22 } |
21 | 23 |
22 void MetricsLogManager::SerializedLog::SwapLogText(std::string* log_text) { | 24 void MetricsLogManager::SerializedLog::SwapLogText(std::string* log_text) { |
23 log_text_.swap(*log_text); | 25 log_text_.swap(*log_text); |
(...skipping 112 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
136 if (store_type == PROVISIONAL_STORE) { | 138 if (store_type == PROVISIONAL_STORE) { |
137 last_provisional_store_index_ = destination_list->size() - 1; | 139 last_provisional_store_index_ = destination_list->size() - 1; |
138 last_provisional_store_type_ = log_type; | 140 last_provisional_store_type_ = log_type; |
139 } | 141 } |
140 } | 142 } |
141 | 143 |
142 void MetricsLogManager::DiscardLastProvisionalStore() { | 144 void MetricsLogManager::DiscardLastProvisionalStore() { |
143 if (last_provisional_store_index_ == -1) | 145 if (last_provisional_store_index_ == -1) |
144 return; | 146 return; |
145 std::vector<SerializedLog>* source_list = | 147 std::vector<SerializedLog>* source_list = |
146 (last_provisional_store_type_ == MetricsLogBase::ONGOING_LOG) ? | 148 (last_provisional_store_type_ == MetricsLogBase::ONGOING_LOG) |
147 &unsent_ongoing_logs_ : &unsent_initial_logs_; | 149 ? &unsent_ongoing_logs_ |
| 150 : &unsent_initial_logs_; |
148 DCHECK_LT(static_cast<unsigned int>(last_provisional_store_index_), | 151 DCHECK_LT(static_cast<unsigned int>(last_provisional_store_index_), |
149 source_list->size()); | 152 source_list->size()); |
150 source_list->erase(source_list->begin() + last_provisional_store_index_); | 153 source_list->erase(source_list->begin() + last_provisional_store_index_); |
151 last_provisional_store_index_ = -1; | 154 last_provisional_store_index_ = -1; |
152 } | 155 } |
153 | 156 |
154 void MetricsLogManager::PersistUnsentLogs() { | 157 void MetricsLogManager::PersistUnsentLogs() { |
155 DCHECK(log_serializer_.get()); | 158 DCHECK(log_serializer_.get()); |
156 if (!log_serializer_.get()) | 159 if (!log_serializer_.get()) |
157 return; | 160 return; |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
194 UMA_HISTOGRAM_TIMES("UMA.LoadLogsTime", timer.Elapsed()); | 197 UMA_HISTOGRAM_TIMES("UMA.LoadLogsTime", timer.Elapsed()); |
195 | 198 |
196 unsent_logs_loaded_ = true; | 199 unsent_logs_loaded_ = true; |
197 } | 200 } |
198 | 201 |
199 void MetricsLogManager::CompressCurrentLog(SerializedLog* compressed_log) { | 202 void MetricsLogManager::CompressCurrentLog(SerializedLog* compressed_log) { |
200 std::string log_text; | 203 std::string log_text; |
201 current_log_->GetEncodedLog(&log_text); | 204 current_log_->GetEncodedLog(&log_text); |
202 compressed_log->SwapLogText(&log_text); | 205 compressed_log->SwapLogText(&log_text); |
203 } | 206 } |
| 207 |
| 208 } // namespace metrics |
OLD | NEW |