OLD | NEW |
---|---|
(Empty) | |
1 /* | |
2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. | |
3 * | |
4 * Use of this source code is governed by a BSD-style license | |
5 * that can be found in the LICENSE file in the root of the source | |
6 * tree. An additional intellectual property rights grant can be found | |
7 * in the file PATENTS. All contributing project authors may | |
8 * be found in the AUTHORS file in the root of the source tree. | |
9 */ | |
10 | |
11 #ifndef WEBRTC_SYSTEM_WRAPPERS_INCLUDE_METRICS_DEFAULT_H_ | |
12 #define WEBRTC_SYSTEM_WRAPPERS_INCLUDE_METRICS_DEFAULT_H_ | |
13 | |
14 #include <map> | |
15 #include <memory> | |
16 #include <string> | |
17 | |
18 namespace webrtc { | |
19 namespace metrics { | |
20 | |
21 struct SampleInfo { | |
22 SampleInfo(const std::string& name, int min, int max, int bucket_count); | |
pbos-webrtc
2016/05/06 19:58:39
size_t bucket_count
åsapersson
2016/05/09 14:47:41
Done.
| |
23 ~SampleInfo(); | |
24 | |
25 const std::string name; | |
26 const int min; | |
27 const int max; | |
28 const int bucket_count; | |
pbos-webrtc
2016/05/06 19:58:40
size_t
åsapersson
2016/05/09 14:47:40
Done.
| |
29 std::map<int, int> samples; // <value, # of events> | |
pbos-webrtc
2016/05/06 19:58:39
Shouldn't this be a std::vector of ints that's ini
åsapersson
2016/05/09 14:47:40
Since most metrics are an aggregate over the call
| |
30 }; | |
31 | |
32 // Enables collection of samples. | |
33 // This method should be called before any other call into webrtc. | |
34 void Enable(); | |
35 | |
36 // Gets histograms and clears all samples. | |
37 void GetAndReset( | |
38 std::map<std::string, std::unique_ptr<SampleInfo>>* histograms); | |
39 | |
40 // Functions below are mainly for testing. | |
41 | |
42 // Clears all samples. | |
43 void Reset(); | |
44 | |
45 // Returns the number of times the |sample| has been added to the histogram. | |
46 int NumEvents(const std::string& name, int sample); | |
pbos-webrtc
2016/05/06 19:58:39
If we do go with respecting buckets, I think we sh
| |
47 | |
48 // Returns the total number of added samples to the histogram. | |
49 int NumSamples(const std::string& name); | |
50 | |
51 // Returns the minimum sample value (or -1 if the histogram has no samples). | |
52 int MinSample(const std::string& name); | |
53 | |
54 } // namespace metrics | |
55 } // namespace webrtc | |
56 | |
57 #endif // WEBRTC_SYSTEM_WRAPPERS_INCLUDE_METRICS_DEFAULT_H_ | |
OLD | NEW |