| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 #ifndef BASE_METRICS_HISTOGRAM_MACROS_H_ | 5 #ifndef BASE_METRICS_HISTOGRAM_MACROS_H_ |
| 6 #define BASE_METRICS_HISTOGRAM_MACROS_H_ | 6 #define BASE_METRICS_HISTOGRAM_MACROS_H_ |
| 7 | 7 |
| 8 #include "base/atomicops.h" | 8 #include "base/atomicops.h" |
| 9 #include "base/basictypes.h" | |
| 10 #include "base/logging.h" | 9 #include "base/logging.h" |
| 11 #include "base/metrics/histogram.h" | 10 #include "base/metrics/histogram.h" |
| 12 #include "base/time/time.h" | 11 #include "base/time/time.h" |
| 13 | 12 |
| 14 //------------------------------------------------------------------------------ | 13 //------------------------------------------------------------------------------ |
| 15 // Histograms are often put in areas where they are called many many times, and | 14 // Histograms are often put in areas where they are called many many times, and |
| 16 // performance is critical. As a result, they are designed to have a very low | 15 // performance is critical. As a result, they are designed to have a very low |
| 17 // recurring cost of executing (adding additional samples). Toward that end, | 16 // recurring cost of executing (adding additional samples). Toward that end, |
| 18 // the macros declare a static pointer to the histogram in question, and only | 17 // the macros declare a static pointer to the histogram in question, and only |
| 19 // take a "slow path" to construct (or find) the histogram on the first run | 18 // take a "slow path" to construct (or find) the histogram on the first run |
| (...skipping 241 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 261 UMA_HISTOGRAM_LONG_TIMES_100(name, elapsed); \ | 260 UMA_HISTOGRAM_LONG_TIMES_100(name, elapsed); \ |
| 262 } else { \ | 261 } else { \ |
| 263 UMA_HISTOGRAM_TIMES(name, elapsed); \ | 262 UMA_HISTOGRAM_TIMES(name, elapsed); \ |
| 264 } \ | 263 } \ |
| 265 } \ | 264 } \ |
| 266 private: \ | 265 private: \ |
| 267 base::TimeTicks constructed_; \ | 266 base::TimeTicks constructed_; \ |
| 268 } scoped_histogram_timer_##key | 267 } scoped_histogram_timer_##key |
| 269 | 268 |
| 270 #endif // BASE_METRICS_HISTOGRAM_MACROS_H_ | 269 #endif // BASE_METRICS_HISTOGRAM_MACROS_H_ |
| OLD | NEW |