OLD | NEW |
1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2006-2008 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/histogram.h" | 10 #include "base/histogram.h" |
11 | 11 |
12 #include <math.h> | 12 #include <math.h> |
13 #include <string> | 13 #include <string> |
14 | 14 |
15 #include "base/logging.h" | 15 #include "base/logging.h" |
16 #include "base/scoped_ptr.h" | 16 #include "base/scoped_ptr.h" |
17 #include "base/string_util.h" | 17 #include "base/string_util.h" |
18 | 18 |
19 using base::TimeDelta; | 19 using base::TimeDelta; |
20 | 20 |
21 typedef Histogram::Count Count; | 21 typedef Histogram::Count Count; |
22 | 22 |
23 // static | 23 // static |
24 const int Histogram::kHexRangePrintingFlag = 0x8000; | 24 const int Histogram::kHexRangePrintingFlag = 0x8000; |
25 | 25 |
26 Histogram::Histogram(const wchar_t* name, Sample minimum, | 26 Histogram::Histogram(const wchar_t* name, Sample minimum, |
27 Sample maximum, size_t bucket_count) | 27 Sample maximum, size_t bucket_count) |
28 : StatsRate(name), | 28 : StatsRate(WideToASCII(name).c_str()), |
29 histogram_name_(WideToASCII(name)), | 29 histogram_name_(WideToASCII(name)), |
30 declared_min_(minimum), | 30 declared_min_(minimum), |
31 declared_max_(maximum), | 31 declared_max_(maximum), |
32 bucket_count_(bucket_count), | 32 bucket_count_(bucket_count), |
33 flags_(0), | 33 flags_(0), |
34 ranges_(bucket_count + 1, 0), | 34 ranges_(bucket_count + 1, 0), |
35 sample_(), | 35 sample_(), |
36 registered_(false) { | 36 registered_(false) { |
37 Initialize(); | 37 Initialize(); |
38 } | 38 } |
39 | 39 |
40 Histogram::Histogram(const wchar_t* name, TimeDelta minimum, | 40 Histogram::Histogram(const wchar_t* name, TimeDelta minimum, |
41 TimeDelta maximum, size_t bucket_count) | 41 TimeDelta maximum, size_t bucket_count) |
42 : StatsRate(name), | 42 : StatsRate(WideToASCII(name).c_str()), |
43 histogram_name_(WideToASCII(name)), | 43 histogram_name_(WideToASCII(name)), |
44 declared_min_(static_cast<int> (minimum.InMilliseconds())), | 44 declared_min_(static_cast<int> (minimum.InMilliseconds())), |
45 declared_max_(static_cast<int> (maximum.InMilliseconds())), | 45 declared_max_(static_cast<int> (maximum.InMilliseconds())), |
46 bucket_count_(bucket_count), | 46 bucket_count_(bucket_count), |
47 flags_(0), | 47 flags_(0), |
48 ranges_(bucket_count + 1, 0), | 48 ranges_(bucket_count + 1, 0), |
49 sample_(), | 49 sample_(), |
50 registered_(false) { | 50 registered_(false) { |
51 Initialize(); | 51 Initialize(); |
52 } | 52 } |
(...skipping 587 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
640 } | 640 } |
641 } | 641 } |
642 | 642 |
643 // static | 643 // static |
644 StatisticsRecorder::HistogramMap* StatisticsRecorder::histograms_ = NULL; | 644 StatisticsRecorder::HistogramMap* StatisticsRecorder::histograms_ = NULL; |
645 // static | 645 // static |
646 Lock* StatisticsRecorder::lock_ = NULL; | 646 Lock* StatisticsRecorder::lock_ = NULL; |
647 // static | 647 // static |
648 bool StatisticsRecorder::dump_on_exit_ = false; | 648 bool StatisticsRecorder::dump_on_exit_ = false; |
649 | 649 |
OLD | NEW |