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

Side by Side Diff: content/browser/histogram_controller.cc

Issue 10454086: Histograms - Support histograms for Plugins, GPU (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Created 8 years, 6 months 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 | Annotate | Revision Log
Property Changes:
Added: svn:eol-style
## -0,0 +1 ##
+LF
OLDNEW
(Empty)
1 // Copyright (c) 2012 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 #include "content/browser/histogram_controller.h"
6
7 #include "base/bind.h"
8 #include "base/metrics/histogram.h"
9 #include "content/browser/histogram_subscriber.h"
10 #include "content/common/child_process_messages.h"
11 #include "content/public/browser/browser_child_process_host_iterator.h"
12 #include "content/public/browser/browser_thread.h"
13 #include "content/public/browser/child_process_data.h"
14 #include "content/public/browser/render_process_host.h"
15
16 using content::BrowserChildProcessHostIterator;
jam 2012/06/07 03:34:33 you don't need using statements since this class i
ramant (doing other things) 2012/06/07 23:39:25 Done.
17 using content::BrowserThread;
18
19 namespace content {
20
21 HistogramController* HistogramController::GetInstance() {
22 return Singleton<HistogramController>::get();
23 }
24
25 HistogramController::HistogramController() : subscriber_(NULL) {
26 }
27
28 HistogramController::~HistogramController() {
29 }
30
31 void HistogramController::OnPendingProcesses(int sequence_number,
32 int pending_processes,
33 bool end) {
34 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
35 if (subscriber_)
36 subscriber_->OnPendingProcesses(sequence_number, pending_processes, end);
37 }
38
39 void HistogramController::OnHistogramDataCollected(
40 int sequence_number,
41 const std::vector<std::string>& pickled_histograms) {
42 if (!BrowserThread::CurrentlyOn(BrowserThread::UI)) {
43 BrowserThread::PostTask(
44 BrowserThread::UI, FROM_HERE,
45 base::Bind(&HistogramController::OnHistogramDataCollected,
46 base::Unretained(this),
47 sequence_number,
48 pickled_histograms));
49 return;
50 }
51
52 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
53 if (subscriber_) {
54 subscriber_->OnHistogramDataCollected(sequence_number,
55 pickled_histograms);
56 }
57 }
58
59 void HistogramController::Register(HistogramSubscriber* subscriber) {
60 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
61 DCHECK(!subscriber_);
62 subscriber_ = subscriber;
63 }
64
65 void HistogramController::Unregister(
66 const HistogramSubscriber* subscriber) {
67 DCHECK_EQ(subscriber_, subscriber);
68 subscriber_ = NULL;
69 }
70
71 void HistogramController::GetHistogramDataFromChildProcesses(
72 int sequence_number) {
73 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
74
75 int pending_processes = 0;
76 for (BrowserChildProcessHostIterator iter; !iter.Done(); ++iter) {
77 ++pending_processes;
78 if (!iter.Send(new ChildProcessMsg_GetChildHistogramData(sequence_number)))
79 --pending_processes;
80 }
81
82 BrowserThread::PostTask(
83 BrowserThread::UI,
84 FROM_HERE,
85 base::Bind(
86 &HistogramController::OnPendingProcesses,
87 base::Unretained(this),
88 sequence_number,
89 pending_processes,
90 true));
91 }
92
93 void HistogramController::GetHistogramData(int sequence_number) {
94 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
95
96 int pending_processes = 0;
97 for (RenderProcessHost::iterator it(RenderProcessHost::AllHostsIterator());
98 !it.IsAtEnd(); it.Advance()) {
99 ++pending_processes;
100 if (!it.GetCurrentValue()->Send(
101 new ChildProcessMsg_GetChildHistogramData(sequence_number))) {
102 --pending_processes;
103 }
104 }
105 OnPendingProcesses(sequence_number, pending_processes, false);
106
107 BrowserThread::PostTask(
108 BrowserThread::IO,
109 FROM_HERE,
110 base::Bind(&HistogramController::GetHistogramDataFromChildProcesses,
111 base::Unretained(this),
112 sequence_number));
113 }
114
115 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698