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
3 // found in the LICENSE file.
5 #ifndef BASE_I18N_ICU_STRING_CONVERSIONS_H_
6 #define BASE_I18N_ICU_STRING_CONVERSIONS_H_
10 #include "base/i18n/base_i18n_export.h"
11 #include "base/string16.h"
15 // Defines the error handling modes of UTF16ToCodepage, CodepageToUTF16,
16 // WideToCodepage and CodepageToWide.
17 class OnStringConversionError
{
20 // The function will return failure. The output buffer will be empty.
23 // The offending characters are skipped and the conversion will proceed as
24 // if they did not exist.
27 // When converting to Unicode, the offending byte sequences are substituted
28 // by Unicode replacement character (U+FFFD). When converting from Unicode,
29 // this is the same as SKIP.
34 OnStringConversionError();
37 // Names of codepages (charsets) understood by icu.
38 BASE_I18N_EXPORT
extern const char kCodepageLatin1
[]; // a.k.a. ISO 8859-1
39 BASE_I18N_EXPORT
extern const char kCodepageUTF8
[];
40 BASE_I18N_EXPORT
extern const char kCodepageUTF16BE
[];
41 BASE_I18N_EXPORT
extern const char kCodepageUTF16LE
[];
43 // Converts between UTF-16 strings and the encoding specified. If the
44 // encoding doesn't exist or the encoding fails (when on_error is FAIL),
46 BASE_I18N_EXPORT
bool UTF16ToCodepage(const string16
& utf16
,
47 const char* codepage_name
,
48 OnStringConversionError::Type on_error
,
49 std::string
* encoded
);
50 BASE_I18N_EXPORT
bool CodepageToUTF16(const std::string
& encoded
,
51 const char* codepage_name
,
52 OnStringConversionError::Type on_error
,
55 // Converts between wide strings and the encoding specified. If the
56 // encoding doesn't exist or the encoding fails (when on_error is FAIL),
58 BASE_I18N_EXPORT
bool WideToCodepage(const std::wstring
& wide
,
59 const char* codepage_name
,
60 OnStringConversionError::Type on_error
,
61 std::string
* encoded
);
62 BASE_I18N_EXPORT
bool CodepageToWide(const std::string
& encoded
,
63 const char* codepage_name
,
64 OnStringConversionError::Type on_error
,
67 // Converts from any codepage to UTF-8 and ensures the resulting UTF-8 is
69 BASE_I18N_EXPORT
bool ConvertToUtf8AndNormalize(const std::string
& text
,
70 const std::string
& charset
,
75 #endif // BASE_I18N_ICU_STRING_CONVERSIONS_H_