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_base.h" | 5 #include "chrome/common/metrics/metrics_log_base.h" |
6 | 6 |
7 #include "base/base64.h" | 7 #include "base/base64.h" |
8 #include "base/basictypes.h" | 8 #include "base/basictypes.h" |
9 #include "base/md5.h" | 9 #include "base/md5.h" |
10 #include "base/perftimer.h" | 10 #include "base/perftimer.h" |
(...skipping 434 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
445 | 445 |
446 // TODO(JAR): A The following should really be part of the histogram class. | 446 // TODO(JAR): A The following should really be part of the histogram class. |
447 // Internal state is being needlessly exposed, and it would be hard to reuse | 447 // Internal state is being needlessly exposed, and it would be hard to reuse |
448 // this code. If we moved this into the Histogram class, then we could use | 448 // this code. If we moved this into the Histogram class, then we could use |
449 // the same infrastructure for logging StatsCounters, RatesCounters, etc. | 449 // the same infrastructure for logging StatsCounters, RatesCounters, etc. |
450 void MetricsLogBase::RecordHistogramDelta( | 450 void MetricsLogBase::RecordHistogramDelta( |
451 const Histogram& histogram, | 451 const Histogram& histogram, |
452 const Histogram::SampleSet& snapshot) { | 452 const Histogram::SampleSet& snapshot) { |
453 DCHECK(!locked_); | 453 DCHECK(!locked_); |
454 DCHECK_NE(0, snapshot.TotalCount()); | 454 DCHECK_NE(0, snapshot.TotalCount()); |
455 snapshot.CheckSize(histogram); | 455 DCHECK_EQ(histogram.bucket_count(), snapshot.size()); |
456 | 456 |
457 // We will ignore the MAX_INT/infinite value in the last element of range[]. | 457 // We will ignore the MAX_INT/infinite value in the last element of range[]. |
458 | 458 |
459 OPEN_ELEMENT_FOR_SCOPE("histogram"); | 459 OPEN_ELEMENT_FOR_SCOPE("histogram"); |
460 | 460 |
461 std::string base64_name_hash; | 461 std::string base64_name_hash; |
462 uint64 numeric_name_hash; | 462 uint64 numeric_name_hash; |
463 CreateHashes(histogram.histogram_name(), | 463 CreateHashes(histogram.histogram_name(), |
464 &base64_name_hash, | 464 &base64_name_hash, |
465 &numeric_name_hash); | 465 &numeric_name_hash); |
(...skipping 22 matching lines...) Expand all Loading... |
488 for (size_t i = 0; i < histogram.bucket_count(); ++i) { | 488 for (size_t i = 0; i < histogram.bucket_count(); ++i) { |
489 if (snapshot.counts(i)) { | 489 if (snapshot.counts(i)) { |
490 HistogramEventProto::Bucket* bucket = histogram_proto->add_bucket(); | 490 HistogramEventProto::Bucket* bucket = histogram_proto->add_bucket(); |
491 bucket->set_min(histogram.ranges(i)); | 491 bucket->set_min(histogram.ranges(i)); |
492 bucket->set_max(histogram.ranges(i + 1)); | 492 bucket->set_max(histogram.ranges(i + 1)); |
493 bucket->set_bucket_index(i); | 493 bucket->set_bucket_index(i); |
494 bucket->set_count(snapshot.counts(i)); | 494 bucket->set_count(snapshot.counts(i)); |
495 } | 495 } |
496 } | 496 } |
497 } | 497 } |
OLD | NEW |