| 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 | 
|---|