Chromium Code Reviews| OLD | NEW |
|---|---|
| 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_manager_metrics.h" |
| 6 | 6 |
| 7 #include "base/basictypes.h" | |
| 7 #include "base/metrics/histogram.h" | 8 #include "base/metrics/histogram.h" |
| 8 | 9 |
| 9 namespace { | 10 namespace { |
| 10 | 11 |
| 11 const char kTranslateInitiationStatus[] = "Translate.InitiationStatus"; | 12 // Constant string values to indicate UMA names. All entry should have |
|
MAD
2013/05/15 01:32:48
All entry -> All entries
Takashi Toyoshima
2013/05/15 07:35:04
Oops. This is a mistake belonging to "All your bas
| |
| 13 // a corresponding index in MetricsNameIndex and an entry in |kMetricsEntries|. | |
| 14 const char kTranslateInitiationStatus[] = | |
| 15 "Translate.InitiationStatus"; | |
| 16 const char kTranslateReportLanguageDetectionError[] = | |
| 17 "Translate.ReportLanguageDetectionError"; | |
| 18 const char kTranslateServerReportedUnsupportedLanguage[] = | |
| 19 "Translate.ServerReportedUnsupportedLanguage"; | |
| 20 | |
| 21 struct MetricsEntry { | |
| 22 TranslateManagerMetrics::MetricsNameIndex index; | |
| 23 const char* const name; | |
| 24 }; | |
| 25 | |
| 26 // This entry table should be updated when new UMA item is added. | |
|
MAD
2013/05/15 01:32:48
item is -> items are
Takashi Toyoshima
2013/05/15 07:35:04
Done.
| |
| 27 const MetricsEntry kMetricsEntries[] = { | |
| 28 { TranslateManagerMetrics::UMA_INITIATION_STATUS, | |
| 29 kTranslateInitiationStatus }, | |
| 30 { TranslateManagerMetrics::UMA_LANGUAGE_DETECTION_ERROR, | |
| 31 kTranslateReportLanguageDetectionError }, | |
| 32 { TranslateManagerMetrics::UMA_SERVER_REPORTED_UNSUPPORTED_LANGUAGE, | |
| 33 kTranslateServerReportedUnsupportedLanguage }, | |
| 34 }; | |
| 35 | |
| 36 COMPILE_ASSERT(arraysize(kMetricsEntries) == TranslateManagerMetrics::UMA_MAX, | |
| 37 arraysize_of_kMetricsEntries_should_be_UMA_MAX); | |
| 12 | 38 |
| 13 } // namespace | 39 } // namespace |
| 14 | 40 |
| 15 namespace TranslateManagerMetrics { | 41 namespace TranslateManagerMetrics { |
| 16 | 42 |
| 17 void ReportInitiationStatus(InitiationStatusType type) { | 43 void ReportInitiationStatus(InitiationStatusType type) { |
| 18 UMA_HISTOGRAM_ENUMERATION(kTranslateInitiationStatus, | 44 UMA_HISTOGRAM_ENUMERATION(kTranslateInitiationStatus, |
| 19 type, | 45 type, |
| 20 INITIATION_STATUS_MAX); | 46 INITIATION_STATUS_MAX); |
| 21 } | 47 } |
| 22 | 48 |
| 23 const char* GetMetricsName(MetricsNameIndex index) { | 49 void ReportLanguageDetectionError() { |
| 24 const char* names[] = { | 50 UMA_HISTOGRAM_COUNTS(kTranslateReportLanguageDetectionError, 1); |
| 25 kTranslateInitiationStatus, | |
| 26 }; | |
| 27 CHECK(index < UMA_MAX); | |
| 28 return names[index]; | |
| 29 } | 51 } |
| 30 | 52 |
| 31 // TODO(toyoshim): Move UMA related code in TranslateManager to | 53 void ReportUnsupportedLanguage() { |
| 32 // TranslateManagerMetrics. | 54 UMA_HISTOGRAM_COUNTS("Translate.ServerReportedUnsupportedLanguage", 1); |
|
MAD
2013/05/15 01:32:48
Oupss... Please use the variable...
Takashi Toyoshima
2013/05/15 07:35:04
Sorry for poor copy and paste...
| |
| 55 } | |
| 56 | |
| 57 const char* GetMetricsName(MetricsNameIndex index) { | |
| 58 for (size_t i = 0; i < arraysize(kMetricsEntries); ++i) { | |
| 59 if (kMetricsEntries[i].index == index) | |
| 60 return kMetricsEntries[i].name; | |
| 61 } | |
| 62 NOTREACHED(); | |
| 63 return NULL; | |
| 64 } | |
| 33 | 65 |
| 34 } // namespace TranslateManagerMetrics | 66 } // namespace TranslateManagerMetrics |
| OLD | NEW |