| 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 "net/disk_cache/stats_histogram.h" | 5 #include "net/disk_cache/stats_histogram.h" |
| 6 | 6 |
| 7 #include "base/debug/leak_annotations.h" |
| 7 #include "base/logging.h" | 8 #include "base/logging.h" |
| 8 #include "net/disk_cache/stats.h" | 9 #include "net/disk_cache/stats.h" |
| 9 | 10 |
| 10 namespace disk_cache { | 11 namespace disk_cache { |
| 11 | 12 |
| 12 using base::Histogram; | 13 using base::Histogram; |
| 13 using base::StatisticsRecorder; | 14 using base::StatisticsRecorder; |
| 14 | 15 |
| 15 // Static. | 16 // Static. |
| 16 const Stats* StatsHistogram::stats_ = NULL; | 17 const Stats* StatsHistogram::stats_ = NULL; |
| 17 | 18 |
| 18 StatsHistogram::~StatsHistogram() { | 19 StatsHistogram::~StatsHistogram() { |
| 19 // Only cleanup what we set. | 20 // Only cleanup what we set. |
| 20 if (init_) | 21 if (init_) |
| 21 stats_ = NULL; | 22 stats_ = NULL; |
| 22 } | 23 } |
| 23 | 24 |
| 24 StatsHistogram* StatsHistogram::StatsHistogramFactoryGet( | 25 StatsHistogram* StatsHistogram::FactoryGet(const std::string& name) { |
| 25 const std::string& name) { | |
| 26 Histogram* histogram(NULL); | 26 Histogram* histogram(NULL); |
| 27 | 27 |
| 28 Sample minimum = 1; | 28 Sample minimum = 1; |
| 29 Sample maximum = disk_cache::Stats::kDataSizesLength - 1; | 29 Sample maximum = disk_cache::Stats::kDataSizesLength - 1; |
| 30 size_t bucket_count = disk_cache::Stats::kDataSizesLength; | 30 size_t bucket_count = disk_cache::Stats::kDataSizesLength; |
| 31 | 31 |
| 32 if (StatisticsRecorder::FindHistogram(name, &histogram)) { | 32 if (StatisticsRecorder::FindHistogram(name, &histogram)) { |
| 33 DCHECK(histogram != NULL); | 33 DCHECK(histogram != NULL); |
| 34 } else { | 34 } else { |
| 35 // To avoid racy destruction at shutdown, the following will be leaked. | 35 // To avoid racy destruction at shutdown, the following will be leaked. |
| 36 StatsHistogram* stats_histogram = | 36 StatsHistogram* stats_histogram = |
| 37 new StatsHistogram(name, minimum, maximum, bucket_count); | 37 new StatsHistogram(name, minimum, maximum, bucket_count); |
| 38 stats_histogram->InitializeBucketRange(); | 38 stats_histogram->InitializeBucketRange(); |
| 39 stats_histogram->SetFlags(kUmaTargetedHistogramFlag); | 39 stats_histogram->SetFlags(kUmaTargetedHistogramFlag); |
| 40 histogram = StatisticsRecorder::RegisterOrDeleteDuplicate(stats_histogram); | 40 histogram = StatisticsRecorder::RegisterOrDeleteDuplicate(stats_histogram); |
| 41 } | 41 } |
| 42 | 42 |
| 43 DCHECK(HISTOGRAM == histogram->histogram_type()); | 43 DCHECK(HISTOGRAM == histogram->histogram_type()); |
| 44 DCHECK(histogram->HasConstructorArguments(minimum, maximum, bucket_count)); | 44 DCHECK(histogram->HasConstructorArguments(minimum, maximum, bucket_count)); |
| 45 | 45 |
| 46 // We're preparing for an otherwise unsafe upcast by ensuring we have the | 46 // We're preparing for an otherwise unsafe upcast by ensuring we have the |
| 47 // proper class type. | 47 // proper class type. |
| 48 StatsHistogram* return_histogram = static_cast<StatsHistogram*>(histogram); | 48 StatsHistogram* return_histogram = static_cast<StatsHistogram*>(histogram); |
| 49 // Validate upcast by seeing that we're probably providing the checksum. | 49 // Validate upcast by seeing that we're probably providing the checksum. |
| 50 CHECK_EQ(return_histogram->StatsHistogram::CalculateRangeChecksum(), | 50 CHECK_EQ(return_histogram->StatsHistogram::CalculateRangeChecksum(), |
| 51 return_histogram->CalculateRangeChecksum()); | 51 return_histogram->CalculateRangeChecksum()); |
| 52 ANNOTATE_LEAKING_OBJECT_PTR(return_histogram); // see crbug.com/79322 |
| 52 return return_histogram; | 53 return return_histogram; |
| 53 } | 54 } |
| 54 | 55 |
| 55 bool StatsHistogram::Init(const Stats* stats) { | 56 bool StatsHistogram::Init(const Stats* stats) { |
| 56 DCHECK(stats); | 57 DCHECK(stats); |
| 57 if (stats_) | 58 if (stats_) |
| 58 return false; | 59 return false; |
| 59 | 60 |
| 60 // We support statistics report for only one cache. | 61 // We support statistics report for only one cache. |
| 61 init_ = true; | 62 init_ = true; |
| (...skipping 27 matching lines...) Expand all Loading... |
| 89 return NO_INCONSISTENCIES; // This class won't monitor inconsistencies. | 90 return NO_INCONSISTENCIES; // This class won't monitor inconsistencies. |
| 90 } | 91 } |
| 91 | 92 |
| 92 uint32 StatsHistogram::CalculateRangeChecksum() const { | 93 uint32 StatsHistogram::CalculateRangeChecksum() const { |
| 93 // We don't calculate checksums, so at least establish a unique constant. | 94 // We don't calculate checksums, so at least establish a unique constant. |
| 94 const uint32 kStatsHistogramChecksum = 0x0cecce; | 95 const uint32 kStatsHistogramChecksum = 0x0cecce; |
| 95 return kStatsHistogramChecksum; | 96 return kStatsHistogramChecksum; |
| 96 } | 97 } |
| 97 | 98 |
| 98 } // namespace disk_cache | 99 } // namespace disk_cache |
| OLD | NEW |