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 |