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/i18n/i18n_constants.h"
12 #include "base/strings/string16.h"
16 // Defines the error handling modes of UTF16ToCodepage, CodepageToUTF16,
17 // WideToCodepage and CodepageToWide.
18 class OnStringConversionError
{
21 // The function will return failure. The output buffer will be empty.
24 // The offending characters are skipped and the conversion will proceed as
25 // if they did not exist.
28 // When converting to Unicode, the offending byte sequences are substituted
29 // by Unicode replacement character (U+FFFD). When converting from Unicode,
30 // this is the same as SKIP.
35 OnStringConversionError();
38 // Converts between UTF-16 strings and the encoding specified. If the
39 // encoding doesn't exist or the encoding fails (when on_error is FAIL),
41 BASE_I18N_EXPORT
bool UTF16ToCodepage(const string16
& utf16
,
42 const char* codepage_name
,
43 OnStringConversionError::Type on_error
,
44 std::string
* encoded
);
45 BASE_I18N_EXPORT
bool CodepageToUTF16(const std::string
& encoded
,
46 const char* codepage_name
,
47 OnStringConversionError::Type on_error
,
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),
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
,
62 // Converts from any codepage to UTF-8 and ensures the resulting UTF-8 is
64 BASE_I18N_EXPORT
bool ConvertToUtf8AndNormalize(const std::string
& text
,
65 const std::string
& charset
,
70 #endif // BASE_I18N_ICU_STRING_CONVERSIONS_H_