Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2009)

Side by Side Diff: components/rappor/rappor_recorder.h

Issue 49753002: RAPPOR implementation (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 7 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 // RapporRecorder holds all Rappors collected in the system, and methods for
6 // retrieving the recorded data.
7
8 #ifndef COMPONENTS_RAPPOR_RAPPOR_RECORDER_H_
9 #define COMPONENTS_RAPPOR_RAPPOR_RECORDER_H_
10
11 #include <map>
12 #include <string>
13 #include <vector>
14
15 #include "base/basictypes.h"
16 #include "base/gtest_prod_util.h"
17 #include "base/lazy_instance.h"
18 #include "base/synchronization/lock.h"
19 #include "components/rappor/rappor.h"
20
21 #define RAPPOR_SAMPLES(parameters, samples) \
22 rappor::g_rappor_recorder.Get().RecordSamples(parameters, samples);
Alexei Svitkine (slow) 2013/12/19 19:47:02 I don't think we should have a global recorder or
Steven Holte 2013/12/20 03:03:55 Collapsed this class into RapporService
23
24 namespace rappor {
25
26 class RapporRecorder {
27 public:
28 typedef std::vector<Rappor*> Rappors;
Alexei Svitkine (slow) 2013/12/19 19:47:02 This should use a ScopedVector<Rappor>.
Steven Holte 2013/12/20 03:03:55 N/A, since RapporService just directly iterates ov
29
30 // Removes all of the collected rappor metrics from the RapporRecorder, and
31 // stores them in the output list. The caller is responsible for deleting
32 // Rappor objects.
33 void CollectRappors(Rappors* output);
34
35 // Deletes all of the rappors in a list.
36 static void DeleteRappors(Rappors* rappors);
37
38 // Find a rappor by name, and create it if it doesn't already exist, and adds
39 // samples to it. This method is thread safe.
40 void RecordSamples(const RapporParameters* parameters,
41 const std::vector<std::string>& samples);
42
43 // The constructor just initializes static members. Usually client code should
44 // use Initialize to do this. But in test code, you can friend this class and
45 // call destructor/constructor to get a clean RapporRecorder.
46 RapporRecorder();
Alexei Svitkine (slow) 2013/12/19 19:47:02 These should be before any other methods.
Steven Holte 2013/12/20 03:03:55 N/A
47 ~RapporRecorder();
48
49 private:
50 // Find a rappor by name, and create it if it doesn't already exist.
51 Rappor* GetRappor(const RapporParameters* parameters);
52
53 // We keep all registered histograms in a map, from name to histogram.
54 typedef std::map<std::string, Rappor*> RapporMap;
55
56 RapporMap rappors_;
57
58 // Lock protects access to above map.
59 base::Lock lock_;
60 };
61
62 extern base::LazyInstance<RapporRecorder>::Leaky g_rappor_recorder;
63
64 } // namespace rappor
65
66 #endif // COMPONENTS_RAPPOR_RAPPOR_RECORDER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698