[WTF] Add makeUnique<T>, which ensures T is fast-allocated, makeUnique / makeUniqueWi...
[WebKit-https.git] / Source / WebCore / platform / text / LocaleICU.cpp
index 9903bb4..2c8cce7 100644 (file)
 #include <unicode/udatpg.h>
 #include <unicode/uloc.h>
 #include <wtf/DateMath.h>
-#include <wtf/PassOwnPtr.h>
 #include <wtf/text/StringBuilder.h>
 
-using namespace icu;
-using namespace std;
 
 namespace WebCore {
+using namespace icu;
 
-PassOwnPtr<Locale> Locale::create(const AtomicString& locale)
+std::unique_ptr<Locale> Locale::create(const AtomString& locale)
 {
-    return LocaleICU::create(locale.string().utf8().data());
+    return makeUnique<LocaleICU>(locale.string().utf8().data());
 }
 
 LocaleICU::LocaleICU(const char* locale)
     : m_locale(locale)
-    , m_numberFormat(0)
-    , m_shortDateFormat(0)
-    , m_didCreateDecimalFormat(false)
-    , m_didCreateShortDateFormat(false)
-#if ENABLE(CALENDAR_PICKER)
-    , m_firstDayOfWeek(0)
-#endif
-#if ENABLE(DATE_AND_TIME_INPUT_TYPES)
-    , m_mediumTimeFormat(0)
-    , m_shortTimeFormat(0)
-    , m_didCreateTimeFormat(false)
-#endif
 {
 }
 
 LocaleICU::~LocaleICU()
 {
+#if !UCONFIG_NO_FORMATTING
     unum_close(m_numberFormat);
-    udat_close(m_shortDateFormat);
+#endif
 #if ENABLE(DATE_AND_TIME_INPUT_TYPES)
+    udat_close(m_shortDateFormat);
     udat_close(m_mediumTimeFormat);
     udat_close(m_shortTimeFormat);
 #endif
 }
 
-PassOwnPtr<LocaleICU> LocaleICU::create(const char* localeString)
-{
-    return adoptPtr(new LocaleICU(localeString));
-}
-
+#if !UCONFIG_NO_FORMATTING
 String LocaleICU::decimalSymbol(UNumberFormatSymbol symbol)
 {
     UErrorCode status = U_ZERO_ERROR;
@@ -93,7 +77,7 @@ String LocaleICU::decimalSymbol(UNumberFormatSymbol symbol)
     unum_getSymbol(m_numberFormat, symbol, buffer.data(), bufferLength, &status);
     if (U_FAILURE(status))
         return String();
-    return String::adopt(buffer);
+    return String::adopt(WTFMove(buffer));
 }
 
 String LocaleICU::decimalTextAttribute(UNumberFormatTextAttribute tag)
@@ -109,11 +93,13 @@ String LocaleICU::decimalTextAttribute(UNumberFormatTextAttribute tag)
     ASSERT(U_SUCCESS(status));
     if (U_FAILURE(status))
         return String();
-    return String::adopt(buffer);
+    return String::adopt(WTFMove(buffer));
 }
+#endif
 
 void LocaleICU::initializeLocaleData()
 {
+#if !UCONFIG_NO_FORMATTING
     if (m_didCreateDecimalFormat)
         return;
     m_didCreateDecimalFormat = true;
@@ -137,8 +123,10 @@ void LocaleICU::initializeLocaleData()
     symbols.append(decimalSymbol(UNUM_GROUPING_SEPARATOR_SYMBOL));
     ASSERT(symbols.size() == DecimalSymbolsSize);
     setLocaleData(symbols, decimalTextAttribute(UNUM_POSITIVE_PREFIX), decimalTextAttribute(UNUM_POSITIVE_SUFFIX), decimalTextAttribute(UNUM_NEGATIVE_PREFIX), decimalTextAttribute(UNUM_NEGATIVE_SUFFIX));
+#endif
 }
 
+#if ENABLE(DATE_AND_TIME_INPUT_TYPES)
 bool LocaleICU::initializeShortDateFormat()
 {
     if (m_didCreateShortDateFormat)
@@ -155,7 +143,6 @@ UDateFormat* LocaleICU::openDateFormat(UDateFormatStyle timeStyle, UDateFormatSt
     return udat_open(timeStyle, dateStyle, m_locale.data(), gmtTimezone, WTF_ARRAY_LENGTH(gmtTimezone), 0, -1, &status);
 }
 
-#if ENABLE(DATE_AND_TIME_INPUT_TYPES)
 static String getDateFormatPattern(const UDateFormat* dateFormat)
 {
     if (!dateFormat)
@@ -170,75 +157,40 @@ static String getDateFormatPattern(const UDateFormat* dateFormat)
     udat_toPattern(dateFormat, TRUE, buffer.data(), length, &status);
     if (U_FAILURE(status))
         return emptyString();
-    return String::adopt(buffer);
+    return String::adopt(WTFMove(buffer));
 }
 
-PassOwnPtr<Vector<String> > LocaleICU::createLabelVector(const UDateFormat* dateFormat, UDateFormatSymbolType type, int32_t startIndex, int32_t size)
+std::unique_ptr<Vector<String>> LocaleICU::createLabelVector(const UDateFormat* dateFormat, UDateFormatSymbolType type, int32_t startIndex, int32_t size)
 {
     if (!dateFormat)
-        return PassOwnPtr<Vector<String> >();
+        return makeUnique<Vector<String>>();
     if (udat_countSymbols(dateFormat, type) != startIndex + size)
-        return PassOwnPtr<Vector<String> >();
+        return makeUnique<Vector<String>>();
 
-    OwnPtr<Vector<String> > labels = adoptPtr(new Vector<String>());
+    auto labels = makeUnique<Vector<String>>();
     labels->reserveCapacity(size);
     for (int32_t i = 0; i < size; ++i) {
         UErrorCode status = U_ZERO_ERROR;
         int32_t length = udat_getSymbols(dateFormat, type, startIndex + i, 0, 0, &status);
         if (status != U_BUFFER_OVERFLOW_ERROR)
-            return PassOwnPtr<Vector<String> >();
+            return makeUnique<Vector<String>>();
         Vector<UChar> buffer(length);
         status = U_ZERO_ERROR;
         udat_getSymbols(dateFormat, type, startIndex + i, buffer.data(), length, &status);
         if (U_FAILURE(status))
-            return PassOwnPtr<Vector<String> >();
-        labels->append(String::adopt(buffer));
+            return makeUnique<Vector<String>>();
+        labels->append(String::adopt(WTFMove(buffer)));
     }
-    return labels.release();
+    return WTFMove(labels);
 }
-#endif
 
-#if ENABLE(CALENDAR_PICKER)
-static PassOwnPtr<Vector<String> > createFallbackWeekDayShortLabels()
+static std::unique_ptr<Vector<String>> createFallbackMonthLabels()
 {
-    OwnPtr<Vector<String> > labels = adoptPtr(new Vector<String>());
-    labels->reserveCapacity(7);
-    labels->append("Sun");
-    labels->append("Mon");
-    labels->append("Tue");
-    labels->append("Wed");
-    labels->append("Thu");
-    labels->append("Fri");
-    labels->append("Sat");
-    return labels.release();
-}
-
-void LocaleICU::initializeCalendar()
-{
-    if (m_weekDayShortLabels)
-        return;
-
-    if (!initializeShortDateFormat()) {
-        m_firstDayOfWeek = 0;
-        m_weekDayShortLabels = createFallbackWeekDayShortLabels();
-        return;
-    }
-    m_firstDayOfWeek = ucal_getAttribute(udat_getCalendar(m_shortDateFormat), UCAL_FIRST_DAY_OF_WEEK) - UCAL_SUNDAY;
-
-    m_weekDayShortLabels = createLabelVector(m_shortDateFormat, UDAT_SHORT_WEEKDAYS, UCAL_SUNDAY, 7);
-    if (!m_weekDayShortLabels)
-        m_weekDayShortLabels = createFallbackWeekDayShortLabels();
-}
-#endif
-
-#if ENABLE(DATE_AND_TIME_INPUT_TYPES)
-static PassOwnPtr<Vector<String> > createFallbackMonthLabels()
-{
-    OwnPtr<Vector<String> > labels = adoptPtr(new Vector<String>());
+    auto labels = makeUnique<Vector<String>>();
     labels->reserveCapacity(WTF_ARRAY_LENGTH(WTF::monthFullName));
     for (unsigned i = 0; i < WTF_ARRAY_LENGTH(WTF::monthFullName); ++i)
         labels->append(WTF::monthFullName[i]);
-    return labels.release();
+    return WTFMove(labels);
 }
 
 const Vector<String>& LocaleICU::monthLabels()
@@ -253,36 +205,14 @@ const Vector<String>& LocaleICU::monthLabels()
     m_monthLabels = createFallbackMonthLabels();
     return *m_monthLabels;
 }
-#endif
-
-#if ENABLE(CALENDAR_PICKER)
-const Vector<String>& LocaleICU::weekDayShortLabels()
-{
-    initializeCalendar();
-    return *m_weekDayShortLabels;
-}
-
-unsigned LocaleICU::firstDayOfWeek()
-{
-    initializeCalendar();
-    return m_firstDayOfWeek;
-}
 
-bool LocaleICU::isRTL()
+static std::unique_ptr<Vector<String>> createFallbackAMPMLabels()
 {
-    UErrorCode status = U_ZERO_ERROR;
-    return uloc_getCharacterOrientation(m_locale.data(), &status) == ULOC_LAYOUT_RTL;
-}
-#endif
-
-#if ENABLE(DATE_AND_TIME_INPUT_TYPES)
-static PassOwnPtr<Vector<String> > createFallbackAMPMLabels()
-{
-    OwnPtr<Vector<String> > labels = adoptPtr(new Vector<String>());
+    auto labels = makeUnique<Vector<String>>();
     labels->reserveCapacity(2);
     labels->append("AM");
     labels->append("PM");
-    return labels.release();
+    return WTFMove(labels);
 }
 
 void LocaleICU::initializeDateTimeFormat()
@@ -307,7 +237,7 @@ void LocaleICU::initializeDateTimeFormat()
     m_dateTimeFormatWithoutSeconds = getDateFormatPattern(dateTimeFormatWithoutSeconds);
     udat_close(dateTimeFormatWithoutSeconds);
 
-    OwnPtr<Vector<String> > timeAMPMLabels = createLabelVector(m_mediumTimeFormat, UDAT_AM_PMS, UCAL_AM, 2);
+    auto timeAMPMLabels = createLabelVector(m_mediumTimeFormat, UDAT_AM_PMS, UCAL_AM, 2);
     if (!timeAMPMLabels)
         timeAMPMLabels = createFallbackAMPMLabels();
     m_timeAMPMLabels = *timeAMPMLabels;
@@ -320,26 +250,26 @@ String LocaleICU::dateFormat()
     if (!m_dateFormat.isNull())
         return m_dateFormat;
     if (!initializeShortDateFormat())
-        return ASCIILiteral("yyyy-MM-dd");
+        return "yyyy-MM-dd"_s;
     m_dateFormat = getDateFormatPattern(m_shortDateFormat);
     return m_dateFormat;
 }
 
-static String getFormatForSkeleton(const char* locale, const String& skeleton)
+static String getFormatForSkeleton(const char* locale, const UChar* skeleton, int32_t skeletonLength)
 {
-    String format = ASCIILiteral("yyyy-MM");
+    String format = "yyyy-MM"_s;
     UErrorCode status = U_ZERO_ERROR;
     UDateTimePatternGenerator* patternGenerator = udatpg_open(locale, &status);
     if (!patternGenerator)
         return format;
     status = U_ZERO_ERROR;
-    int32_t length = udatpg_getBestPattern(patternGenerator, skeleton.characters(), skeleton.length(), 0, 0, &status);
+    int32_t length = udatpg_getBestPattern(patternGenerator, skeleton, skeletonLength, 0, 0, &status);
     if (status == U_BUFFER_OVERFLOW_ERROR && length) {
         Vector<UChar> buffer(length);
         status = U_ZERO_ERROR;
-        udatpg_getBestPattern(patternGenerator, skeleton.characters(), skeleton.length(), buffer.data(), length, &status);
+        udatpg_getBestPattern(patternGenerator, skeleton, skeletonLength, buffer.data(), length, &status);
         if (U_SUCCESS(status))
-            format = String::adopt(buffer);
+            format = String::adopt(WTFMove(buffer));
     }
     udatpg_close(patternGenerator);
     return format;
@@ -351,10 +281,20 @@ String LocaleICU::monthFormat()
         return m_monthFormat;
     // Gets a format for "MMMM" because Windows API always provides formats for
     // "MMMM" in some locales.
-    m_monthFormat = getFormatForSkeleton(m_locale.data(), ASCIILiteral("yyyyMMMM"));
+    const UChar skeleton[] = { 'y', 'y', 'y', 'y', 'M', 'M', 'M', 'M' };
+    m_monthFormat = getFormatForSkeleton(m_locale.data(), skeleton, WTF_ARRAY_LENGTH(skeleton));
     return m_monthFormat;
 }
 
+String LocaleICU::shortMonthFormat()
+{
+    if (!m_shortMonthFormat.isNull())
+        return m_shortMonthFormat;
+    const UChar skeleton[] = { 'y', 'y', 'y', 'y', 'M', 'M', 'M' };
+    m_shortMonthFormat = getFormatForSkeleton(m_locale.data(), skeleton, WTF_ARRAY_LENGTH(skeleton));
+    return m_shortMonthFormat;
+}
+
 String LocaleICU::timeFormat()
 {
     initializeDateTimeFormat();
@@ -384,7 +324,7 @@ const Vector<String>& LocaleICU::shortMonthLabels()
     if (!m_shortMonthLabels.isEmpty())
         return m_shortMonthLabels;
     if (initializeShortDateFormat()) {
-        if (OwnPtr<Vector<String> > labels = createLabelVector(m_shortDateFormat, UDAT_SHORT_MONTHS, UCAL_JANUARY, 12)) {
+        if (auto labels = createLabelVector(m_shortDateFormat, UDAT_SHORT_MONTHS, UCAL_JANUARY, 12)) {
             m_shortMonthLabels = *labels;
             return m_shortMonthLabels;
         }
@@ -400,7 +340,7 @@ const Vector<String>& LocaleICU::standAloneMonthLabels()
     if (!m_standAloneMonthLabels.isEmpty())
         return m_standAloneMonthLabels;
     if (initializeShortDateFormat()) {
-        if (OwnPtr<Vector<String> > labels = createLabelVector(m_shortDateFormat, UDAT_STANDALONE_MONTHS, UCAL_JANUARY, 12)) {
+        if (auto labels = createLabelVector(m_shortDateFormat, UDAT_STANDALONE_MONTHS, UCAL_JANUARY, 12)) {
             m_standAloneMonthLabels = *labels;
             return m_standAloneMonthLabels;
         }
@@ -414,7 +354,7 @@ const Vector<String>& LocaleICU::shortStandAloneMonthLabels()
     if (!m_shortStandAloneMonthLabels.isEmpty())
         return m_shortStandAloneMonthLabels;
     if (initializeShortDateFormat()) {
-        if (OwnPtr<Vector<String> > labels = createLabelVector(m_shortDateFormat, UDAT_STANDALONE_SHORT_MONTHS, UCAL_JANUARY, 12)) {
+        if (auto labels = createLabelVector(m_shortDateFormat, UDAT_STANDALONE_SHORT_MONTHS, UCAL_JANUARY, 12)) {
             m_shortStandAloneMonthLabels = *labels;
             return m_shortStandAloneMonthLabels;
         }