Chromium Code Reviews| Index: base/metrics/sparse_histogram.cc |
| =================================================================== |
| --- base/metrics/sparse_histogram.cc (revision 0) |
| +++ base/metrics/sparse_histogram.cc (revision 0) |
| @@ -0,0 +1,45 @@ |
| +// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "base/metrics/sparse_histogram.h" |
| + |
| +#include "base/metrics/statistics_recorder.h" |
| +#include "base/synchronization/lock.h" |
| + |
| +using std::string; |
|
Ilya Sherman
2012/08/04 01:18:35
nit: This sort of using statement is not permitted
kaiwang
2012/08/08 03:59:33
are you sure about this?
This is allowed in google
Ilya Sherman
2012/08/08 05:00:29
Sorry, you're right, this sort of using statement
|
| + |
| +namespace base { |
| + |
| +// static |
| +HistogramBase* SparseHistogram::FactoryGet(const string& name, |
| + Flags flags) { |
|
Ilya Sherman
2012/08/04 01:18:35
nit: Should this be |int32 flags|, as it is everyw
kaiwang
2012/08/08 03:59:33
Done. Good catch
|
| + HistogramBase* histogram = new SparseHistogram(name); |
|
Ilya Sherman
2012/08/04 01:18:35
nit: I believe this is an intentional leak, right?
|
| + histogram->SetFlags(flags); |
| + return histogram; |
| +} |
|
Ilya Sherman
2012/08/04 01:18:35
Is this method eventually going to look up the his
kaiwang
2012/08/08 03:59:33
You are right. FactoryGet will eventually register
|
| + |
| +SparseHistogram::~SparseHistogram() {} |
| + |
| +void SparseHistogram::Add(Sample value) { |
| + base::AutoLock auto_lock(*lock_); |
| + sample_[value]++; |
| +} |
| + |
| +void SparseHistogram::SnapshotSample( |
| + SparseHistogram::SampleCounts* sample) const { |
| + base::AutoLock auto_lock(*lock_); |
| + *sample = sample_; |
| +} |
| + |
| +void SparseHistogram::WriteHTMLGraph(string* output) const { |
|
Ilya Sherman
2012/08/04 01:18:35
nit: Please add a TODO, linked to a crbug, to impl
kaiwang
2012/08/08 03:59:33
Added todo.
Most code is in histogram.cc. Seems no
|
| +} |
| + |
| +void SparseHistogram::WriteAscii(string* output) const { |
| +} |
| + |
| +SparseHistogram::SparseHistogram(const string& name) |
| + : HistogramBase(name), |
| + lock_(new base::Lock()) {} |
| + |
| +} // namespace base |
| Property changes on: base/metrics/sparse_histogram.cc |
| ___________________________________________________________________ |
| Added: svn:eol-style |
| + LF |