blob: e4b790bc16f1896b797de344ea99723d3a5a005d [file] [log] [blame]
asapersson01d70a32016-05-20 06:29:46 -07001/*
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
18namespace webrtc {
19namespace metrics {
20
21struct SampleInfo {
22 SampleInfo(const std::string& name, int min, int max, size_t bucket_count);
23 ~SampleInfo();
24
25 const std::string name;
26 const int min;
27 const int max;
28 const size_t bucket_count;
29 std::map<int, int> samples; // <value, # of events>
30};
31
32// Enables collection of samples.
33// This method should be called before any other call into webrtc.
34void Enable();
35
36// Gets histograms and clears all samples.
37void GetAndReset(
38 std::map<std::string, std::unique_ptr<SampleInfo>>* histograms);
39
40// Functions below are mainly for testing.
41
42// Clears all samples.
43void Reset();
44
45// Returns the number of times the |sample| has been added to the histogram.
46int NumEvents(const std::string& name, int sample);
47
48// Returns the total number of added samples to the histogram.
49int NumSamples(const std::string& name);
50
51// Returns the minimum sample value (or -1 if the histogram has no samples).
52int MinSample(const std::string& name);
53
54} // namespace metrics
55} // namespace webrtc
56
57#endif // WEBRTC_SYSTEM_WRAPPERS_INCLUDE_METRICS_DEFAULT_H_