OLD | NEW |
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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 #include "base/strings/utf_string_conversions.h" | 5 #include "base/strings/utf_string_conversions.h" |
6 | 6 |
7 #include "base/strings/string_piece.h" | 7 #include "base/strings/string_piece.h" |
8 #include "base/strings/string_util.h" | 8 #include "base/strings/string_util.h" |
9 #include "base/strings/utf_string_conversion_utils.h" | 9 #include "base/strings/utf_string_conversion_utils.h" |
10 | 10 |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
66 bool UTF8ToWide(const char* src, size_t src_len, std::wstring* output) { | 66 bool UTF8ToWide(const char* src, size_t src_len, std::wstring* output) { |
67 if (IsStringASCII(StringPiece(src, src_len))) { | 67 if (IsStringASCII(StringPiece(src, src_len))) { |
68 output->assign(src, src + src_len); | 68 output->assign(src, src + src_len); |
69 return true; | 69 return true; |
70 } else { | 70 } else { |
71 PrepareForUTF16Or32Output(src, src_len, output); | 71 PrepareForUTF16Or32Output(src, src_len, output); |
72 return ConvertUnicode(src, src_len, output); | 72 return ConvertUnicode(src, src_len, output); |
73 } | 73 } |
74 } | 74 } |
75 | 75 |
76 std::wstring UTF8ToWide(const StringPiece& utf8) { | 76 std::wstring UTF8ToWide(StringPiece utf8) { |
77 if (IsStringASCII(utf8)) { | 77 if (IsStringASCII(utf8)) { |
78 return std::wstring(utf8.begin(), utf8.end()); | 78 return std::wstring(utf8.begin(), utf8.end()); |
79 } | 79 } |
80 | 80 |
81 std::wstring ret; | 81 std::wstring ret; |
82 PrepareForUTF16Or32Output(utf8.data(), utf8.length(), &ret); | 82 PrepareForUTF16Or32Output(utf8.data(), utf8.length(), &ret); |
83 ConvertUnicode(utf8.data(), utf8.length(), &ret); | 83 ConvertUnicode(utf8.data(), utf8.length(), &ret); |
84 return ret; | 84 return ret; |
85 } | 85 } |
86 | 86 |
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
146 bool UTF8ToUTF16(const char* src, size_t src_len, string16* output) { | 146 bool UTF8ToUTF16(const char* src, size_t src_len, string16* output) { |
147 if (IsStringASCII(StringPiece(src, src_len))) { | 147 if (IsStringASCII(StringPiece(src, src_len))) { |
148 output->assign(src, src + src_len); | 148 output->assign(src, src + src_len); |
149 return true; | 149 return true; |
150 } else { | 150 } else { |
151 PrepareForUTF16Or32Output(src, src_len, output); | 151 PrepareForUTF16Or32Output(src, src_len, output); |
152 return ConvertUnicode(src, src_len, output); | 152 return ConvertUnicode(src, src_len, output); |
153 } | 153 } |
154 } | 154 } |
155 | 155 |
156 string16 UTF8ToUTF16(const StringPiece& utf8) { | 156 string16 UTF8ToUTF16(StringPiece utf8) { |
157 if (IsStringASCII(utf8)) { | 157 if (IsStringASCII(utf8)) { |
158 return string16(utf8.begin(), utf8.end()); | 158 return string16(utf8.begin(), utf8.end()); |
159 } | 159 } |
160 | 160 |
161 string16 ret; | 161 string16 ret; |
162 PrepareForUTF16Or32Output(utf8.data(), utf8.length(), &ret); | 162 PrepareForUTF16Or32Output(utf8.data(), utf8.length(), &ret); |
163 // Ignore the success flag of this call, it will do the best it can for | 163 // Ignore the success flag of this call, it will do the best it can for |
164 // invalid input, which is what we want here. | 164 // invalid input, which is what we want here. |
165 ConvertUnicode(utf8.data(), utf8.length(), &ret); | 165 ConvertUnicode(utf8.data(), utf8.length(), &ret); |
166 return ret; | 166 return ret; |
167 } | 167 } |
168 | 168 |
169 bool UTF16ToUTF8(const char16* src, size_t src_len, std::string* output) { | 169 bool UTF16ToUTF8(const char16* src, size_t src_len, std::string* output) { |
170 if (IsStringASCII(StringPiece16(src, src_len))) { | 170 if (IsStringASCII(StringPiece16(src, src_len))) { |
171 output->assign(src, src + src_len); | 171 output->assign(src, src + src_len); |
172 return true; | 172 return true; |
173 } else { | 173 } else { |
174 PrepareForUTF8Output(src, src_len, output); | 174 PrepareForUTF8Output(src, src_len, output); |
175 return ConvertUnicode(src, src_len, output); | 175 return ConvertUnicode(src, src_len, output); |
176 } | 176 } |
177 } | 177 } |
178 | 178 |
179 std::string UTF16ToUTF8(const string16& utf16) { | 179 std::string UTF16ToUTF8(StringPiece16 utf16) { |
180 if (IsStringASCII(utf16)) { | 180 if (IsStringASCII(utf16)) { |
181 return std::string(utf16.begin(), utf16.end()); | 181 return std::string(utf16.begin(), utf16.end()); |
182 } | 182 } |
183 | 183 |
184 std::string ret; | 184 std::string ret; |
185 // Ignore the success flag of this call, it will do the best it can for | 185 // Ignore the success flag of this call, it will do the best it can for |
186 // invalid input, which is what we want here. | 186 // invalid input, which is what we want here. |
187 UTF16ToUTF8(utf16.data(), utf16.length(), &ret); | 187 UTF16ToUTF8(utf16.data(), utf16.length(), &ret); |
188 return ret; | 188 return ret; |
189 } | 189 } |
190 | 190 |
191 #elif defined(WCHAR_T_IS_UTF16) | 191 #elif defined(WCHAR_T_IS_UTF16) |
192 // Easy case since we can use the "wide" versions we already wrote above. | 192 // Easy case since we can use the "wide" versions we already wrote above. |
193 | 193 |
194 bool UTF8ToUTF16(const char* src, size_t src_len, string16* output) { | 194 bool UTF8ToUTF16(const char* src, size_t src_len, string16* output) { |
195 return UTF8ToWide(src, src_len, output); | 195 return UTF8ToWide(src, src_len, output); |
196 } | 196 } |
197 | 197 |
198 string16 UTF8ToUTF16(const StringPiece& utf8) { | 198 string16 UTF8ToUTF16(StringPiece utf8) { |
199 return UTF8ToWide(utf8); | 199 return UTF8ToWide(utf8); |
200 } | 200 } |
201 | 201 |
202 bool UTF16ToUTF8(const char16* src, size_t src_len, std::string* output) { | 202 bool UTF16ToUTF8(const char16* src, size_t src_len, std::string* output) { |
203 return WideToUTF8(src, src_len, output); | 203 return WideToUTF8(src, src_len, output); |
204 } | 204 } |
205 | 205 |
206 std::string UTF16ToUTF8(const string16& utf16) { | 206 std::string UTF16ToUTF8(StringPiece16 utf16) { |
207 return WideToUTF8(utf16); | 207 if (IsStringASCII(utf16)) |
| 208 return std::string(utf16.data(), utf16.data() + utf16.length()); |
| 209 |
| 210 std::string ret; |
| 211 PrepareForUTF8Output(utf16.data(), utf16.length(), &ret); |
| 212 ConvertUnicode(utf16.data(), utf16.length(), &ret); |
| 213 return ret; |
208 } | 214 } |
209 | 215 |
210 #endif | 216 #endif |
211 | 217 |
212 string16 ASCIIToUTF16(const StringPiece& ascii) { | 218 string16 ASCIIToUTF16(StringPiece ascii) { |
213 DCHECK(IsStringASCII(ascii)) << ascii; | 219 DCHECK(IsStringASCII(ascii)) << ascii; |
214 return string16(ascii.begin(), ascii.end()); | 220 return string16(ascii.begin(), ascii.end()); |
215 } | 221 } |
216 | 222 |
217 std::string UTF16ToASCII(const string16& utf16) { | 223 std::string UTF16ToASCII(StringPiece16 utf16) { |
218 DCHECK(IsStringASCII(utf16)) << UTF16ToUTF8(utf16); | 224 DCHECK(IsStringASCII(utf16)) << UTF16ToUTF8(utf16); |
219 return std::string(utf16.begin(), utf16.end()); | 225 return std::string(utf16.begin(), utf16.end()); |
220 } | 226 } |
221 | 227 |
222 } // namespace base | 228 } // namespace base |
OLD | NEW |