icu_string_conversions.h revision 90dce4d38c5ff5333bea97d859d4e484e27edf0c
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.
4
5#ifndef BASE_I18N_ICU_STRING_CONVERSIONS_H_
6#define BASE_I18N_ICU_STRING_CONVERSIONS_H_
7
8#include <string>
9
10#include "base/i18n/base_i18n_export.h"
11#include "base/i18n/i18n_constants.h"
12#include "base/string16.h"
13
14namespace base {
15
16// Defines the error handling modes of UTF16ToCodepage, CodepageToUTF16,
17// WideToCodepage and CodepageToWide.
18class OnStringConversionError {
19 public:
20  enum Type {
21    // The function will return failure. The output buffer will be empty.
22    FAIL,
23
24    // The offending characters are skipped and the conversion will proceed as
25    // if they did not exist.
26    SKIP,
27
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.
31    SUBSTITUTE,
32  };
33
34 private:
35  OnStringConversionError();
36};
37
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),
40// returns false.
41BASE_I18N_EXPORT bool UTF16ToCodepage(const string16& utf16,
42                                      const char* codepage_name,
43                                      OnStringConversionError::Type on_error,
44                                      std::string* encoded);
45BASE_I18N_EXPORT bool CodepageToUTF16(const std::string& encoded,
46                                      const char* codepage_name,
47                                      OnStringConversionError::Type on_error,
48                                      string16* utf16);
49
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.
53BASE_I18N_EXPORT bool WideToCodepage(const std::wstring& wide,
54                                     const char* codepage_name,
55                                     OnStringConversionError::Type on_error,
56                                     std::string* encoded);
57BASE_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
63// normalized.
64BASE_I18N_EXPORT bool ConvertToUtf8AndNormalize(const std::string& text,
65                                                const std::string& charset,
66                                                std::string* result);
67
68}  // namespace base
69
70#endif  // BASE_I18N_ICU_STRING_CONVERSIONS_H_
71