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

Side by Side Diff: chrome/browser/translate/translate_browser_metrics.cc

Issue 15987004: Translate: Filter and record languages whose names Chrome doesn't show (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Made Translate.ServerReportedUnsupportedLanguage deprecated Created 7 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
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/translate/translate_manager_metrics.h" 5 #include "chrome/browser/translate/translate_browser_metrics.h"
6 6
7 #include <string> 7 #include <string>
8 8
9 #include "base/basictypes.h" 9 #include "base/basictypes.h"
10 #include "base/metrics/histogram.h" 10 #include "base/metrics/histogram.h"
11 #include "base/metrics/sparse_histogram.h" 11 #include "base/metrics/sparse_histogram.h"
12 #include "chrome/browser/language_usage_metrics.h" 12 #include "chrome/browser/language_usage_metrics.h"
13 13
14 namespace { 14 namespace {
15 15
16 // Constant string values to indicate UMA names. All entries should have 16 // Constant string values to indicate UMA names. All entries should have
17 // a corresponding index in MetricsNameIndex and an entry in |kMetricsEntries|. 17 // a corresponding index in MetricsNameIndex and an entry in |kMetricsEntries|.
18 const char kTranslateInitiationStatus[] = 18 const char kTranslateInitiationStatus[] =
19 "Translate.InitiationStatus"; 19 "Translate.InitiationStatus";
20 const char kTranslateReportLanguageDetectionError[] = 20 const char kTranslateReportLanguageDetectionError[] =
21 "Translate.ReportLanguageDetectionError"; 21 "Translate.ReportLanguageDetectionError";
22 const char kTranslateServerReportedUnsupportedLanguage[] =
23 "Translate.ServerReportedUnsupportedLanguage";
24 const char kTranslateUnsupportedLanguageAtInitiation[] = 22 const char kTranslateUnsupportedLanguageAtInitiation[] =
25 "Translate.UnsupportedLanguageAtInitiation"; 23 "Translate.UnsupportedLanguageAtInitiation";
24 const char kTranslateUndisplayableLanguage[] =
25 "Translate.UndisplayableLanguage";
Ilya Sherman 2013/06/01 00:59:47 nit: Alphabetize?
hajimehoshi 2013/06/05 04:44:05 Done.
26 26
27 struct MetricsEntry { 27 struct MetricsEntry {
28 TranslateManagerMetrics::MetricsNameIndex index; 28 TranslateBrowserMetrics::MetricsNameIndex index;
29 const char* const name; 29 const char* const name;
30 }; 30 };
31 31
32 // This entry table should be updated when new UMA items are added. 32 // This entry table should be updated when new UMA items are added.
33 const MetricsEntry kMetricsEntries[] = { 33 const MetricsEntry kMetricsEntries[] = {
34 { TranslateManagerMetrics::UMA_INITIATION_STATUS, 34 { TranslateBrowserMetrics::UMA_INITIATION_STATUS,
35 kTranslateInitiationStatus }, 35 kTranslateInitiationStatus },
36 { TranslateManagerMetrics::UMA_LANGUAGE_DETECTION_ERROR, 36 { TranslateBrowserMetrics::UMA_LANGUAGE_DETECTION_ERROR,
37 kTranslateReportLanguageDetectionError }, 37 kTranslateReportLanguageDetectionError },
38 { TranslateManagerMetrics::UMA_SERVER_REPORTED_UNSUPPORTED_LANGUAGE, 38 { TranslateBrowserMetrics::UMA_UNSUPPORTED_LANGUAGE_AT_INITIATION,
39 kTranslateServerReportedUnsupportedLanguage },
40 { TranslateManagerMetrics::UMA_UNSUPPORTED_LANGUAGE_AT_INITIATION,
41 kTranslateUnsupportedLanguageAtInitiation }, 39 kTranslateUnsupportedLanguageAtInitiation },
40 { TranslateBrowserMetrics::UMA_UNDISPLAYABLE_LANGUAGE,
41 kTranslateUndisplayableLanguage },
42 }; 42 };
43 43
44 COMPILE_ASSERT(arraysize(kMetricsEntries) == TranslateManagerMetrics::UMA_MAX, 44 COMPILE_ASSERT(arraysize(kMetricsEntries) == TranslateBrowserMetrics::UMA_MAX,
45 arraysize_of_kMetricsEntries_should_be_UMA_MAX); 45 arraysize_of_kMetricsEntries_should_be_UMA_MAX);
46 46
47 } // namespace 47 } // namespace
48 48
49 namespace TranslateManagerMetrics { 49 namespace TranslateBrowserMetrics {
50 50
51 void ReportInitiationStatus(InitiationStatusType type) { 51 void ReportInitiationStatus(InitiationStatusType type) {
52 UMA_HISTOGRAM_ENUMERATION(kTranslateInitiationStatus, 52 UMA_HISTOGRAM_ENUMERATION(kTranslateInitiationStatus,
53 type, 53 type,
54 INITIATION_STATUS_MAX); 54 INITIATION_STATUS_MAX);
55 } 55 }
56 56
57 void ReportLanguageDetectionError() { 57 void ReportLanguageDetectionError() {
58 UMA_HISTOGRAM_COUNTS(kTranslateReportLanguageDetectionError, 1); 58 UMA_HISTOGRAM_COUNTS(kTranslateReportLanguageDetectionError, 1);
59 } 59 }
60 60
61 void ReportUnsupportedLanguage() {
62 UMA_HISTOGRAM_COUNTS(kTranslateServerReportedUnsupportedLanguage, 1);
63 }
64
65 void ReportUnsupportedLanguageAtInitiation(const std::string& language) { 61 void ReportUnsupportedLanguageAtInitiation(const std::string& language) {
66 int language_code = LanguageUsageMetrics::ToLanguageCode(language); 62 int language_code = LanguageUsageMetrics::ToLanguageCode(language);
67 UMA_HISTOGRAM_SPARSE_SLOWLY(kTranslateUnsupportedLanguageAtInitiation, 63 UMA_HISTOGRAM_SPARSE_SLOWLY(kTranslateUnsupportedLanguageAtInitiation,
68 language_code); 64 language_code);
69 } 65 }
70 66
67 void ReportUndisplayableLanguage(const std::string& language) {
68 int language_code = LanguageUsageMetrics::ToLanguageCode(language);
69 UMA_HISTOGRAM_SPARSE_SLOWLY(kTranslateUndisplayableLanguage,
70 language_code);
71 }
72
71 const char* GetMetricsName(MetricsNameIndex index) { 73 const char* GetMetricsName(MetricsNameIndex index) {
72 for (size_t i = 0; i < arraysize(kMetricsEntries); ++i) { 74 for (size_t i = 0; i < arraysize(kMetricsEntries); ++i) {
73 if (kMetricsEntries[i].index == index) 75 if (kMetricsEntries[i].index == index)
74 return kMetricsEntries[i].name; 76 return kMetricsEntries[i].name;
75 } 77 }
76 NOTREACHED(); 78 NOTREACHED();
77 return NULL; 79 return NULL;
78 } 80 }
79 81
80 } // namespace TranslateManagerMetrics 82 } // namespace TranslateBrowserMetrics
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698