| 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 // Histogram is an object that aggregates statistics, and can summarize them in | 5 // Histogram is an object that aggregates statistics, and can summarize them in |
| 6 // various forms, including ASCII graphical, HTML, and numerically (as a | 6 // various forms, including ASCII graphical, HTML, and numerically (as a |
| 7 // vector of numbers corresponding to each of the aggregating buckets). | 7 // vector of numbers corresponding to each of the aggregating buckets). |
| 8 // See header file for details and examples. | 8 // See header file for details and examples. |
| 9 | 9 |
| 10 #include "base/metrics/histogram.h" | 10 #include "base/metrics/histogram.h" |
| (...skipping 351 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 362 if (!ValidateRangeChecksum(*histogram, range_checksum)) { | 362 if (!ValidateRangeChecksum(*histogram, range_checksum)) { |
| 363 // The serialized histogram might be corrupted. | 363 // The serialized histogram might be corrupted. |
| 364 return NULL; | 364 return NULL; |
| 365 } | 365 } |
| 366 return histogram; | 366 return histogram; |
| 367 } | 367 } |
| 368 | 368 |
| 369 scoped_ptr<SampleVector> Histogram::SnapshotSampleVector() const { | 369 scoped_ptr<SampleVector> Histogram::SnapshotSampleVector() const { |
| 370 scoped_ptr<SampleVector> samples(new SampleVector(bucket_ranges())); | 370 scoped_ptr<SampleVector> samples(new SampleVector(bucket_ranges())); |
| 371 samples->Add(*samples_); | 371 samples->Add(*samples_); |
| 372 return samples; | 372 return samples.Pass(); |
| 373 } | 373 } |
| 374 | 374 |
| 375 void Histogram::WriteAsciiImpl(bool graph_it, | 375 void Histogram::WriteAsciiImpl(bool graph_it, |
| 376 const string& newline, | 376 const string& newline, |
| 377 string* output) const { | 377 string* output) const { |
| 378 // Get local (stack) copies of all effectively volatile class data so that we | 378 // Get local (stack) copies of all effectively volatile class data so that we |
| 379 // are consistent across our output activities. | 379 // are consistent across our output activities. |
| 380 scoped_ptr<SampleVector> snapshot = SnapshotSampleVector(); | 380 scoped_ptr<SampleVector> snapshot = SnapshotSampleVector(); |
| 381 Count sample_count = snapshot->TotalCount(); | 381 Count sample_count = snapshot->TotalCount(); |
| 382 | 382 |
| (...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 488 } | 488 } |
| 489 | 489 |
| 490 void Histogram::GetCountAndBucketData(Count* count, | 490 void Histogram::GetCountAndBucketData(Count* count, |
| 491 int64* sum, | 491 int64* sum, |
| 492 ListValue* buckets) const { | 492 ListValue* buckets) const { |
| 493 scoped_ptr<SampleVector> snapshot = SnapshotSampleVector(); | 493 scoped_ptr<SampleVector> snapshot = SnapshotSampleVector(); |
| 494 *count = snapshot->TotalCount(); | 494 *count = snapshot->TotalCount(); |
| 495 *sum = snapshot->sum(); | 495 *sum = snapshot->sum(); |
| 496 size_t index = 0; | 496 size_t index = 0; |
| 497 for (size_t i = 0; i < bucket_count(); ++i) { | 497 for (size_t i = 0; i < bucket_count(); ++i) { |
| 498 Sample count = snapshot->GetCountAtIndex(i); | 498 Sample count_at_index = snapshot->GetCountAtIndex(i); |
| 499 if (count > 0) { | 499 if (count_at_index > 0) { |
| 500 scoped_ptr<DictionaryValue> bucket_value(new DictionaryValue()); | 500 scoped_ptr<DictionaryValue> bucket_value(new DictionaryValue()); |
| 501 bucket_value->SetInteger("low", ranges(i)); | 501 bucket_value->SetInteger("low", ranges(i)); |
| 502 if (i != bucket_count() - 1) | 502 if (i != bucket_count() - 1) |
| 503 bucket_value->SetInteger("high", ranges(i + 1)); | 503 bucket_value->SetInteger("high", ranges(i + 1)); |
| 504 bucket_value->SetInteger("count", count); | 504 bucket_value->SetInteger("count", count_at_index); |
| 505 buckets->Set(index, bucket_value.release()); | 505 buckets->Set(index, bucket_value.release()); |
| 506 ++index; | 506 ++index; |
| 507 } | 507 } |
| 508 } | 508 } |
| 509 } | 509 } |
| 510 | 510 |
| 511 //------------------------------------------------------------------------------ | 511 //------------------------------------------------------------------------------ |
| 512 // LinearHistogram: This histogram uses a traditional set of evenly spaced | 512 // LinearHistogram: This histogram uses a traditional set of evenly spaced |
| 513 // buckets. | 513 // buckets. |
| 514 //------------------------------------------------------------------------------ | 514 //------------------------------------------------------------------------------ |
| (...skipping 322 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 837 | 837 |
| 838 BucketRanges* bucket_ranges = new BucketRanges(ranges.size()); | 838 BucketRanges* bucket_ranges = new BucketRanges(ranges.size()); |
| 839 for (size_t i = 0; i < ranges.size(); i++) { | 839 for (size_t i = 0; i < ranges.size(); i++) { |
| 840 bucket_ranges->set_range(i, ranges[i]); | 840 bucket_ranges->set_range(i, ranges[i]); |
| 841 } | 841 } |
| 842 bucket_ranges->ResetChecksum(); | 842 bucket_ranges->ResetChecksum(); |
| 843 return bucket_ranges; | 843 return bucket_ranges; |
| 844 } | 844 } |
| 845 | 845 |
| 846 } // namespace base | 846 } // namespace base |
| OLD | NEW |