| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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_helpers.h" | 5 #include "chrome/common/metrics_helpers.h" |
| 6 | 6 |
| 7 #if defined(USE_SYSTEM_LIBBZ2) | 7 #if defined(USE_SYSTEM_LIBBZ2) |
| 8 #include <bzlib.h> | 8 #include <bzlib.h> |
| 9 #else | 9 #else |
| 10 #include "third_party/bzip2/bzlib.h" | 10 #include "third_party/bzip2/bzlib.h" |
| (...skipping 159 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 170 return std::string(reinterpret_cast<char*>(xml_wrapper_->buffer()->content)); | 170 return std::string(reinterpret_cast<char*>(xml_wrapper_->buffer()->content)); |
| 171 } | 171 } |
| 172 | 172 |
| 173 int MetricsLogBase::GetElapsedSeconds() { | 173 int MetricsLogBase::GetElapsedSeconds() { |
| 174 return static_cast<int>((Time::Now() - start_time_).InSeconds()); | 174 return static_cast<int>((Time::Now() - start_time_).InSeconds()); |
| 175 } | 175 } |
| 176 | 176 |
| 177 std::string MetricsLogBase::CreateHash(const std::string& value) { | 177 std::string MetricsLogBase::CreateHash(const std::string& value) { |
| 178 base::MD5Context ctx; | 178 base::MD5Context ctx; |
| 179 base::MD5Init(&ctx); | 179 base::MD5Init(&ctx); |
| 180 base::MD5Update(&ctx, value.data(), value.length()); | 180 base::MD5Update(&ctx, value); |
| 181 | 181 |
| 182 base::MD5Digest digest; | 182 base::MD5Digest digest; |
| 183 base::MD5Final(&digest, &ctx); | 183 base::MD5Final(&digest, &ctx); |
| 184 | 184 |
| 185 uint64 reverse_uint64; | 185 uint64 reverse_uint64; |
| 186 // UMA only uses first 8 chars of hash. We use the above uint64 instead | 186 // UMA only uses first 8 chars of hash. We use the above uint64 instead |
| 187 // of a unsigned char[8] so that we don't run into strict aliasing issues | 187 // of a unsigned char[8] so that we don't run into strict aliasing issues |
| 188 // in the LOG statement below when trying to interpret reverse as a uint64. | 188 // in the LOG statement below when trying to interpret reverse as a uint64. |
| 189 unsigned char* reverse = reinterpret_cast<unsigned char *>(&reverse_uint64); | 189 unsigned char* reverse = reinterpret_cast<unsigned char *>(&reverse_uint64); |
| 190 DCHECK(arraysize(digest.a) >= sizeof(reverse_uint64)); | 190 DCHECK(arraysize(digest.a) >= sizeof(reverse_uint64)); |
| (...skipping 394 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 585 snapshot.Subtract(*already_logged); | 585 snapshot.Subtract(*already_logged); |
| 586 } | 586 } |
| 587 | 587 |
| 588 // Snapshot now contains only a delta to what we've already_logged. | 588 // Snapshot now contains only a delta to what we've already_logged. |
| 589 if (snapshot.redundant_count() > 0) { | 589 if (snapshot.redundant_count() > 0) { |
| 590 TransmitHistogramDelta(histogram, snapshot); | 590 TransmitHistogramDelta(histogram, snapshot); |
| 591 // Add new data into our running total. | 591 // Add new data into our running total. |
| 592 already_logged->Add(snapshot); | 592 already_logged->Add(snapshot); |
| 593 } | 593 } |
| 594 } | 594 } |
| OLD | NEW |