1 /* 2 * Copyright (C) 2012 Google Inc. All rights reserved. 3 * 4 * Redistribution and use in source and binary forms, with or without 5 * modification, are permitted provided that the following conditions 6 * are met: 7 * 1. Redistributions of source code must retain the above copyright 8 * notice, this list of conditions and the following disclaimer. 9 * 2. Redistributions in binary form must reproduce the above copyright 10 * notice, this list of conditions and the following disclaimer in the 11 * documentation and/or other materials provided with the distribution. 12 * 13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' AND 14 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 16 * ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE 17 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 18 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 19 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 20 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 21 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 22 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH 23 * DAMAGE. 24 */ 25 26 #ifndef PlatformLocale_h 27 #define PlatformLocale_h 28 29 #include "platform/DateComponents.h" 30 #include "platform/Language.h" 31 #include "public/platform/WebLocalizedString.h" 32 #include "wtf/PassOwnPtr.h" 33 #include "wtf/text/WTFString.h" 34 35 namespace blink { 36 37 class PLATFORM_EXPORT Locale { 38 WTF_MAKE_NONCOPYABLE(Locale); 39 public: 40 static PassOwnPtr<Locale> create(const String& localeIdentifier); 41 static Locale& defaultLocale(); 42 43 String queryString(blink::WebLocalizedString::Name); 44 String queryString(blink::WebLocalizedString::Name, const String& parameter); 45 String queryString(blink::WebLocalizedString::Name, const String& parameter1, const String& parameter2); 46 String validationMessageTooLongText(unsigned valueLength, int maxLength); 47 48 // Converts the specified number string to another number string localized 49 // for this Locale locale. The input string must conform to HTML 50 // floating-point numbers, and is not empty. 51 String convertToLocalizedNumber(const String&); 52 53 // Converts the specified localized number string to a number string in the 54 // HTML floating-point number format. The input string is provided by a end 55 // user, and might not be a number string. It's ok that the function returns 56 // a string which is not conforms to the HTML floating-point number format, 57 // callers of this function are responsible to check the format of the 58 // resultant string. 59 String convertFromLocalizedNumber(const String&); 60 61 #if ENABLE(INPUT_MULTIPLE_FIELDS_UI) 62 // Returns localized decimal separator, e.g. "." for English, "," for French. 63 String localizedDecimalSeparator(); 64 #endif 65 66 // Returns date format in Unicode TR35 LDML[1] containing day of month, 67 // month, and year, e.g. "dd/mm/yyyy" 68 // [1] LDML http://unicode.org/reports/tr35/#Date_Format_Patterns 69 virtual String dateFormat() = 0; 70 71 // Returns a year-month format in Unicode TR35 LDML. 72 virtual String monthFormat() = 0; 73 74 // Returns a year-month format using short month lanel in Unicode TR35 LDML. 75 virtual String shortMonthFormat() = 0; 76 77 // Returns time format in Unicode TR35 LDML[1] containing hour, minute, and 78 // second with optional period(AM/PM), e.g. "h:mm:ss a" 79 // [1] LDML http://unicode.org/reports/tr35/#Date_Format_Patterns 80 virtual String timeFormat() = 0; 81 82 // Returns time format in Unicode TR35 LDML containing hour, and minute 83 // with optional period(AM/PM), e.g. "h:mm a" 84 // Note: Some platforms return same value as timeFormat(). 85 virtual String shortTimeFormat() = 0; 86 87 // Returns a date-time format in Unicode TR35 LDML. It should have a seconds 88 // field. 89 virtual String dateTimeFormatWithSeconds() = 0; 90 91 // Returns a date-time format in Unicode TR35 LDML. It should have no seconds 92 // field. 93 virtual String dateTimeFormatWithoutSeconds() = 0; 94 95 // weekFormatInLDML() returns week and year format in LDML, Unicode 96 // technical standard 35, Locale Data Markup Language, e.g. "'Week' ww, yyyy" 97 String weekFormatInLDML(); 98 99 // Returns a vector of string of which size is 12. The first item is a 100 // localized string of Jan and the last item is a localized string of 101 // Dec. These strings should be short. 102 virtual const Vector<String>& shortMonthLabels() = 0; 103 104 // Returns a vector of string of which size is 12. The first item is a 105 // stand-alone localized string of January and the last item is a 106 // stand-alone localized string of December. These strings should not be 107 // abbreviations. 108 virtual const Vector<String>& standAloneMonthLabels() = 0; 109 110 // Stand-alone month version of shortMonthLabels. 111 virtual const Vector<String>& shortStandAloneMonthLabels() = 0; 112 113 // Returns localized period field(AM/PM) strings. 114 virtual const Vector<String>& timeAMPMLabels() = 0; 115 116 // Returns a vector of string of which size is 12. The first item is a 117 // localized string of January, and the last item is a localized string of 118 // December. These strings should not be abbreviations. 119 virtual const Vector<String>& monthLabels() = 0; 120 121 // Returns a vector of string of which size is 7. The first item is a 122 // localized short string of Monday, and the last item is a localized 123 // short string of Saturday. These strings should be short. 124 virtual const Vector<String>& weekDayShortLabels() = 0; 125 126 // The first day of a week. 0 is Sunday, and 6 is Saturday. 127 virtual unsigned firstDayOfWeek() = 0; 128 129 // Returns true if people use right-to-left writing in the locale for this 130 // object. 131 virtual bool isRTL() = 0; 132 133 enum FormatType { FormatTypeUnspecified, FormatTypeShort, FormatTypeMedium }; 134 135 // Serializes the specified date into a formatted date string to 136 // display to the user. If an implementation doesn't support 137 // localized dates the function should return an empty string. 138 // FormatType can be used to specify if you want the short format. 139 String formatDateTime(const DateComponents&, FormatType = FormatTypeUnspecified); 140 141 virtual ~Locale(); 142 143 protected: 144 enum { 145 // 0-9 for digits. 146 DecimalSeparatorIndex = 10, 147 GroupSeparatorIndex = 11, 148 DecimalSymbolsSize 149 }; 150 Locale()151 Locale() : m_hasLocaleData(false) { } 152 virtual void initializeLocaleData() = 0; 153 void setLocaleData(const Vector<String, DecimalSymbolsSize>&, const String& positivePrefix, const String& positiveSuffix, const String& negativePrefix, const String& negativeSuffix); 154 155 private: 156 bool detectSignAndGetDigitRange(const String& input, bool& isNegative, unsigned& startIndex, unsigned& endIndex); 157 unsigned matchedDecimalSymbolIndex(const String& input, unsigned& position); 158 159 String m_decimalSymbols[DecimalSymbolsSize]; 160 String m_positivePrefix; 161 String m_positiveSuffix; 162 String m_negativePrefix; 163 String m_negativeSuffix; 164 bool m_hasLocaleData; 165 }; 166 167 } 168 #endif 169