OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 BASE_I18N_ICU_STRING_CONVERSIONS_H_ | 5 #ifndef BASE_I18N_ICU_STRING_CONVERSIONS_H_ |
6 #define BASE_I18N_ICU_STRING_CONVERSIONS_H_ | 6 #define BASE_I18N_ICU_STRING_CONVERSIONS_H_ |
7 | 7 |
8 #include <string> | 8 #include <string> |
9 | 9 |
10 #include "base/i18n/base_i18n_export.h" | 10 #include "base/i18n/base_i18n_export.h" |
11 #include "base/i18n/i18n_constants.h" | 11 #include "base/i18n/i18n_constants.h" |
12 #include "base/strings/string16.h" | 12 #include "base/strings/string16.h" |
13 | 13 |
14 namespace base { | 14 namespace base { |
15 | 15 |
16 // Defines the error handling modes of UTF16ToCodepage, CodepageToUTF16, | 16 // Defines the error handling modes of UTF16ToCodepage and CodepageToUTF16. |
17 // WideToCodepage and CodepageToWide. | |
18 class OnStringConversionError { | 17 class OnStringConversionError { |
19 public: | 18 public: |
20 enum Type { | 19 enum Type { |
21 // The function will return failure. The output buffer will be empty. | 20 // The function will return failure. The output buffer will be empty. |
22 FAIL, | 21 FAIL, |
23 | 22 |
24 // The offending characters are skipped and the conversion will proceed as | 23 // The offending characters are skipped and the conversion will proceed as |
25 // if they did not exist. | 24 // if they did not exist. |
26 SKIP, | 25 SKIP, |
27 | 26 |
(...skipping 12 matching lines...) Expand all Loading... |
40 // returns false. | 39 // returns false. |
41 BASE_I18N_EXPORT bool UTF16ToCodepage(const string16& utf16, | 40 BASE_I18N_EXPORT bool UTF16ToCodepage(const string16& utf16, |
42 const char* codepage_name, | 41 const char* codepage_name, |
43 OnStringConversionError::Type on_error, | 42 OnStringConversionError::Type on_error, |
44 std::string* encoded); | 43 std::string* encoded); |
45 BASE_I18N_EXPORT bool CodepageToUTF16(const std::string& encoded, | 44 BASE_I18N_EXPORT bool CodepageToUTF16(const std::string& encoded, |
46 const char* codepage_name, | 45 const char* codepage_name, |
47 OnStringConversionError::Type on_error, | 46 OnStringConversionError::Type on_error, |
48 string16* utf16); | 47 string16* utf16); |
49 | 48 |
50 // Converts between wide strings and the encoding specified. If the | |
51 // encoding doesn't exist or the encoding fails (when on_error is FAIL), | |
52 // returns false. | |
53 BASE_I18N_EXPORT bool WideToCodepage(const std::wstring& wide, | |
54 const char* codepage_name, | |
55 OnStringConversionError::Type on_error, | |
56 std::string* encoded); | |
57 BASE_I18N_EXPORT bool CodepageToWide(const std::string& encoded, | |
58 const char* codepage_name, | |
59 OnStringConversionError::Type on_error, | |
60 std::wstring* wide); | |
61 | |
62 // Converts from any codepage to UTF-8 and ensures the resulting UTF-8 is | 49 // Converts from any codepage to UTF-8 and ensures the resulting UTF-8 is |
63 // normalized. | 50 // normalized. |
64 BASE_I18N_EXPORT bool ConvertToUtf8AndNormalize(const std::string& text, | 51 BASE_I18N_EXPORT bool ConvertToUtf8AndNormalize(const std::string& text, |
65 const std::string& charset, | 52 const std::string& charset, |
66 std::string* result); | 53 std::string* result); |
67 | 54 |
68 } // namespace base | 55 } // namespace base |
69 | 56 |
70 #endif // BASE_I18N_ICU_STRING_CONVERSIONS_H_ | 57 #endif // BASE_I18N_ICU_STRING_CONVERSIONS_H_ |
OLD | NEW |