Index: ash/metrics/task_switch_metrics_recorder.cc |
diff --git a/ash/metrics/task_switch_metrics_recorder.cc b/ash/metrics/task_switch_metrics_recorder.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..991d7cfc70145835a8e5afe300546d457a6432a1 |
--- /dev/null |
+++ b/ash/metrics/task_switch_metrics_recorder.cc |
@@ -0,0 +1,64 @@ |
+// Copyright 2015 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 "ash/metrics/task_switch_metrics_recorder.h" |
+ |
+#include "ash/metrics/task_switch_time_tracker.h" |
+ |
+namespace ash { |
+ |
+namespace { |
+ |
+const char kShelf_histogram[] = "Ash.Shelf.TimeBetweenNavigateToTaskSwitches"; |
Alexei Svitkine (slow)
2015/05/14 14:51:54
Nit: kShelfHistogram
bruthig
2015/05/14 15:35:20
Done.
|
+ |
+// Returns the histogram name for the given |task_switch_source|. |
+const char* GetHistogramName( |
+ TaskSwitchMetricsRecorder::TaskSwitchSource task_switch_source) { |
+ switch (task_switch_source) { |
+ case TaskSwitchMetricsRecorder::kShelf: |
+ return kShelf_histogram; |
+ } |
+ NOTREACHED(); |
+ return nullptr; |
+} |
+ |
+} // namespace |
+ |
+TaskSwitchMetricsRecorder::TaskSwitchMetricsRecorder() { |
+} |
+ |
+TaskSwitchMetricsRecorder::~TaskSwitchMetricsRecorder() { |
+} |
+ |
+void TaskSwitchMetricsRecorder::OnTaskSwitch( |
+ TaskSwitchSource task_switch_source) { |
+ TaskSwitchTimeTracker* task_switch_time_tracker = |
+ FindTaskSwitchTimeTracker(task_switch_source); |
+ if (!task_switch_time_tracker) |
+ AddTaskSwitchTimeTracker(task_switch_source); |
+ |
+ task_switch_time_tracker = FindTaskSwitchTimeTracker(task_switch_source); |
+ CHECK(task_switch_time_tracker); |
+ |
+ task_switch_time_tracker->OnTaskSwitch(); |
+} |
+ |
+TaskSwitchTimeTracker* TaskSwitchMetricsRecorder::FindTaskSwitchTimeTracker( |
+ TaskSwitchSource task_switch_source) { |
+ return histogram_map_.get(task_switch_source); |
+} |
+ |
+void TaskSwitchMetricsRecorder::AddTaskSwitchTimeTracker( |
+ TaskSwitchSource task_switch_source) { |
+ CHECK(histogram_map_.find(task_switch_source) == histogram_map_.end()); |
+ |
+ const char* histogram_name = GetHistogramName(task_switch_source); |
+ DCHECK(histogram_name); |
+ |
+ histogram_map_.add(task_switch_source, |
+ scoped_ptr<TaskSwitchTimeTracker>( |
Alexei Svitkine (slow)
2015/05/14 14:51:54
make_scoped_ptr?
bruthig
2015/05/14 15:35:20
Done.
|
+ new TaskSwitchTimeTracker(histogram_name))); |
+} |
+ |
+} // namespace ash |