Index: chrome/browser/engagement/site_engagement_metrics.cc |
diff --git a/chrome/browser/engagement/site_engagement_metrics.cc b/chrome/browser/engagement/site_engagement_metrics.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..21f2d777b46418d1f6af00c336c6819ad83af274 |
--- /dev/null |
+++ b/chrome/browser/engagement/site_engagement_metrics.cc |
@@ -0,0 +1,71 @@ |
+// 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 "chrome/browser/engagement/site_engagement_metrics.h" |
+ |
+#include "base/metrics/histogram_macros.h" |
+#include "base/metrics/sparse_histogram.h" |
+ |
+const char SiteEngagementMetrics::kTotalEngagementHistogram[] = |
+ "SiteEngagementService.TotalEngagement"; |
+ |
+const char SiteEngagementMetrics::kTotalOriginsHistogram[] = |
+ "SiteEngagementService.OriginsEngaged"; |
+ |
+const char SiteEngagementMetrics::kEngagementScoreHistogram[] = |
+ "SiteEngagementService.EngagementScore"; |
+ |
+const char SiteEngagementMetrics::kOriginsWithMaxEngagementHistogram[] = |
+ "SiteEngagementService.OriginsWithMaxEngagement"; |
+ |
+const char SiteEngagementMetrics::kOriginsWithMaxDailyEngagementHistogram[] = |
+ "SiteEngagementService.OriginsWithMaxDailyEngagement"; |
+ |
+const char SiteEngagementMetrics::kEngagementTypeHistogram[] = |
+ "SiteEngagementService.EngagementType"; |
+ |
+void SiteEngagementMetrics::RecordTotalSiteEngagement( |
+ double total_engagement) { |
+ UMA_HISTOGRAM_COUNTS_10000(kTotalEngagementHistogram, total_engagement); |
+} |
+ |
+void SiteEngagementMetrics::RecordTotalOriginsEngaged(int num_origins) { |
+ UMA_HISTOGRAM_COUNTS_10000(kTotalOriginsHistogram, num_origins); |
+} |
+ |
+void SiteEngagementMetrics::RecordEngagementScore( |
+ std::map<GURL, double> score_map) { |
+ for (const auto& value: score_map) { |
+ UMA_HISTOGRAM_COUNTS_100(kEngagementScoreHistogram, value.second); |
+ } |
+} |
+ |
+void SiteEngagementMetrics::RecordOriginsWithMaxEngagement(int total_origins) { |
+ UMA_HISTOGRAM_COUNTS_100(kOriginsWithMaxEngagementHistogram, total_origins); |
+} |
+ |
+void SiteEngagementMetrics::RecordOriginsWithMaxDailyEngagement( |
+ int total_origins) { |
+ UMA_HISTOGRAM_COUNTS_100(kOriginsWithMaxDailyEngagementHistogram, |
+ total_origins); |
+} |
+ |
+void SiteEngagementMetrics::RecordEngagement(EngagementType type) { |
+ switch (type) { |
+ case ENGAGEMENT_NAVIGATION: |
+ UMA_HISTOGRAM_SPARSE_SLOWLY(kEngagementTypeHistogram, |
benwells
2015/09/30 00:10:54
Reading https://groups.google.com/a/chromium.org/f
Ilya Sherman
2015/10/01 07:08:17
It's fine either way, but yeah, UMA_HISTOGRAM_ENUM
dominickn
2015/10/01 08:19:44
Done.
|
+ ENGAGEMENT_NAVIGATION); |
+ break; |
+ case ENGAGEMENT_KEYPRESS: |
+ UMA_HISTOGRAM_SPARSE_SLOWLY(kEngagementTypeHistogram, |
+ ENGAGEMENT_KEYPRESS); |
+ break; |
+ case ENGAGEMENT_MOUSE: |
+ UMA_HISTOGRAM_SPARSE_SLOWLY(kEngagementTypeHistogram, ENGAGEMENT_MOUSE); |
Ilya Sherman
2015/10/01 07:08:17
nit: Please move the UMA_HISTOGRAM_ macro out of t
dominickn
2015/10/01 08:19:44
Done.
|
+ break; |
+ default: |
Ilya Sherman
2015/10/01 07:08:17
nit: Please remove the default case: the compiler
dominickn
2015/10/01 08:19:44
Done.
|
+ NOTREACHED() << "Invalid type passed to RecordUserInput()."; |
+ break; |
+ } |
+} |