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 #ifndef CHROME_BROWSER_TRANSLATE_TRANSLATE_BROWSER_METRICS_H_ | 5 #ifndef CHROME_BROWSER_TRANSLATE_TRANSLATE_BROWSER_METRICS_H_ |
6 #define CHROME_BROWSER_TRANSLATE_TRANSLATE_BROWSER_METRICS_H_ | 6 #define CHROME_BROWSER_TRANSLATE_TRANSLATE_BROWSER_METRICS_H_ |
7 | 7 |
8 #include <string> | 8 #include <string> |
9 | 9 |
10 namespace TranslateBrowserMetrics { | 10 namespace TranslateBrowserMetrics { |
11 | 11 |
12 // An indexing type to query each UMA entry name via GetMetricsName() function. | 12 // An indexing type to query each UMA entry name via GetMetricsName() function. |
13 // Note: |kMetricsEntries| should be updated when a new entry is added here. | 13 // Note: |kMetricsEntries| should be updated when a new entry is added here. |
14 enum MetricsNameIndex { | 14 enum MetricsNameIndex { |
15 UMA_INITIATION_STATUS, | 15 UMA_INITIATION_STATUS, |
16 UMA_LANGUAGE_DETECTION_ERROR, | 16 UMA_LANGUAGE_DETECTION_ERROR, |
17 UMA_LOCALES_ON_DISABLED_BY_PREFS, | 17 UMA_LOCALES_ON_DISABLED_BY_PREFS, |
18 UMA_UNDISPLAYABLE_LANGUAGE, | 18 UMA_UNDISPLAYABLE_LANGUAGE, |
19 UMA_UNSUPPORTED_LANGUAGE_AT_INITIATION, | 19 UMA_UNSUPPORTED_LANGUAGE_AT_INITIATION, |
20 UMA_MAX, | 20 UMA_MAX, |
21 }; | 21 }; |
22 | 22 |
23 // When Chrome Translate is ready to translate a page, one of following reason | 23 // When Chrome Translate is ready to translate a page, one of following reason |
24 // decide the next browser action. | 24 // decide the next browser action. |
25 // Note: Don't insert any item. It will change reporting UMA value, and break | |
26 // the UMA dashboard page. Insteads, append it at the end of enum as suggested | |
27 // below. | |
Ilya Sherman
2013/11/05 00:04:59
It looks like this change will break the histogram
Takashi Toyoshima
2013/11/05 00:18:27
Actually, it was already broken, and this change i
Ilya Sherman
2013/11/05 00:20:58
If it was already broken, then you already have po
| |
25 enum InitiationStatusType { | 28 enum InitiationStatusType { |
26 INITIATION_STATUS_DISABLED_BY_PREFS, | 29 INITIATION_STATUS_DISABLED_BY_PREFS, |
27 INITIATION_STATUS_DISABLED_BY_SWITCH, | 30 INITIATION_STATUS_DISABLED_BY_SWITCH, |
28 INITIATION_STATUS_DISABLED_BY_CONFIG, | 31 INITIATION_STATUS_DISABLED_BY_CONFIG, |
29 INITIATION_STATUS_LANGUAGE_IS_NOT_SUPPORTED, | 32 INITIATION_STATUS_LANGUAGE_IS_NOT_SUPPORTED, |
30 INITIATION_STATUS_MIME_TYPE_IS_NOT_SUPPORTED, | |
31 INITIATION_STATUS_URL_IS_NOT_SUPPORTED, | 33 INITIATION_STATUS_URL_IS_NOT_SUPPORTED, |
32 INITIATION_STATUS_SIMILAR_LANGUAGES, | 34 INITIATION_STATUS_SIMILAR_LANGUAGES, |
33 INITIATION_STATUS_ACCEPT_LANGUAGES, | 35 INITIATION_STATUS_ACCEPT_LANGUAGES, |
34 | |
35 INITIATION_STATUS_AUTO_BY_CONFIG, | 36 INITIATION_STATUS_AUTO_BY_CONFIG, |
36 INITIATION_STATUS_AUTO_BY_LINK, | 37 INITIATION_STATUS_AUTO_BY_LINK, |
37 INITIATION_STATUS_SHOW_INFOBAR, | 38 INITIATION_STATUS_SHOW_INFOBAR, |
38 | 39 INITIATION_STATUS_MIME_TYPE_IS_NOT_SUPPORTED, |
40 // Insert new item here. | |
Ilya Sherman
2013/11/05 00:04:59
nit: "new item" -> "new items"
Takashi Toyoshima
2013/11/05 01:31:04
Done.
| |
39 INITIATION_STATUS_MAX, | 41 INITIATION_STATUS_MAX, |
40 }; | 42 }; |
41 | 43 |
42 // Called when Chrome Translate is initiated to report a reason of the next | 44 // Called when Chrome Translate is initiated to report a reason of the next |
43 // browser action. | 45 // browser action. |
44 void ReportInitiationStatus(InitiationStatusType type); | 46 void ReportInitiationStatus(InitiationStatusType type); |
45 | 47 |
46 // Called when Chrome opens the URL so that the user sends an error feedback. | 48 // Called when Chrome opens the URL so that the user sends an error feedback. |
47 void ReportLanguageDetectionError(); | 49 void ReportLanguageDetectionError(); |
48 | 50 |
49 void ReportLocalesOnDisabledByPrefs(const std::string& locale); | 51 void ReportLocalesOnDisabledByPrefs(const std::string& locale); |
50 | 52 |
51 // Called when Chrome Translate server sends the language list which includes | 53 // Called when Chrome Translate server sends the language list which includes |
52 // a undisplayable language in the user's locale. | 54 // a undisplayable language in the user's locale. |
53 void ReportUndisplayableLanguage(const std::string& language); | 55 void ReportUndisplayableLanguage(const std::string& language); |
54 | 56 |
55 void ReportUnsupportedLanguageAtInitiation(const std::string& language); | 57 void ReportUnsupportedLanguageAtInitiation(const std::string& language); |
56 | 58 |
57 // Provides UMA entry names for unit tests. | 59 // Provides UMA entry names for unit tests. |
58 const char* GetMetricsName(MetricsNameIndex index); | 60 const char* GetMetricsName(MetricsNameIndex index); |
59 | 61 |
60 } // namespace TranslateBrowserMetrics | 62 } // namespace TranslateBrowserMetrics |
61 | 63 |
62 #endif // CHROME_BROWSER_TRANSLATE_TRANSLATE_BROWSER_METRICS_H_ | 64 #endif // CHROME_BROWSER_TRANSLATE_TRANSLATE_BROWSER_METRICS_H_ |
OLD | NEW |