|  | // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | #ifndef BASE_I18N_CASE_CONVERSION_H_ | 
|  | #define BASE_I18N_CASE_CONVERSION_H_ | 
|  |  | 
|  | #include "base/i18n/base_i18n_export.h" | 
|  | #include "base/strings/string16.h" | 
|  | #include "base/strings/string_piece.h" | 
|  |  | 
|  | namespace base { | 
|  | namespace i18n { | 
|  |  | 
|  | // UNICODE CASE-HANDLING ADVICE | 
|  | // | 
|  | // In English it's always safe to convert to upper-case or lower-case text | 
|  | // and get a good answer. But some languages have rules specific to those | 
|  | // locales. One example is the Turkish I: | 
|  | //   http://www.i18nguy.com/unicode/turkish-i18n.html | 
|  | // | 
|  | // ToLower/ToUpper use the current ICU locale which will take into account | 
|  | // the user language preference. Use this when dealing with user typing. | 
|  | // | 
|  | // FoldCase canonicalizes to a standardized form independent of the current | 
|  | // locale. Use this when comparing general Unicode strings that don't | 
|  | // necessarily belong in the user's current locale (like commands, protocol | 
|  | // names, other strings from the web) for case-insensitive equality. | 
|  | // | 
|  | // Note that case conversions will change the length of the string in some | 
|  | // not-uncommon cases. Never assume that the output is the same length as | 
|  | // the input. | 
|  |  | 
|  | // Returns the lower case equivalent of string. Uses ICU's current locale. | 
|  | BASE_I18N_EXPORT string16 ToLower(StringPiece16 string); | 
|  |  | 
|  | // Returns the upper case equivalent of string. Uses ICU's current locale. | 
|  | BASE_I18N_EXPORT string16 ToUpper(StringPiece16 string); | 
|  |  | 
|  | // Convert the given string to a canonical case, independent of the current | 
|  | // locale. For ASCII the canonical form is lower case. | 
|  | // See http://unicode.org/faq/casemap_charprop.html#2 | 
|  | BASE_I18N_EXPORT string16 FoldCase(StringPiece16 string); | 
|  |  | 
|  | }  // namespace i18n | 
|  | }  // namespace base | 
|  |  | 
|  | #endif  // BASE_I18N_CASE_CONVERSION_H_ |