Index: src/extensions/experimental/i18n-extension.cc |
=================================================================== |
--- src/extensions/experimental/i18n-extension.cc (revision 7591) |
+++ src/extensions/experimental/i18n-extension.cc (working copy) |
@@ -27,13 +27,9 @@ |
#include "i18n-extension.h" |
-#include <algorithm> |
-#include <string> |
- |
#include "break-iterator.h" |
+#include "i18n-locale.h" |
#include "natives.h" |
-#include "unicode/locid.h" |
-#include "unicode/uloc.h" |
namespace v8 { |
namespace internal { |
@@ -57,21 +53,21 @@ |
v8::Handle<v8::FunctionTemplate> I18NExtension::GetNativeFunction( |
v8::Handle<v8::String> name) { |
if (name->Equals(v8::String::New("NativeJSLocale"))) { |
- return v8::FunctionTemplate::New(JSLocale); |
+ return v8::FunctionTemplate::New(I18NLocale::JSLocale); |
} else if (name->Equals(v8::String::New("NativeJSAvailableLocales"))) { |
- return v8::FunctionTemplate::New(JSAvailableLocales); |
+ return v8::FunctionTemplate::New(I18NLocale::JSAvailableLocales); |
} else if (name->Equals(v8::String::New("NativeJSMaximizedLocale"))) { |
- return v8::FunctionTemplate::New(JSMaximizedLocale); |
+ return v8::FunctionTemplate::New(I18NLocale::JSMaximizedLocale); |
} else if (name->Equals(v8::String::New("NativeJSMinimizedLocale"))) { |
- return v8::FunctionTemplate::New(JSMinimizedLocale); |
+ return v8::FunctionTemplate::New(I18NLocale::JSMinimizedLocale); |
} else if (name->Equals(v8::String::New("NativeJSDisplayLanguage"))) { |
- return v8::FunctionTemplate::New(JSDisplayLanguage); |
+ return v8::FunctionTemplate::New(I18NLocale::JSDisplayLanguage); |
} else if (name->Equals(v8::String::New("NativeJSDisplayScript"))) { |
- return v8::FunctionTemplate::New(JSDisplayScript); |
+ return v8::FunctionTemplate::New(I18NLocale::JSDisplayScript); |
} else if (name->Equals(v8::String::New("NativeJSDisplayRegion"))) { |
- return v8::FunctionTemplate::New(JSDisplayRegion); |
+ return v8::FunctionTemplate::New(I18NLocale::JSDisplayRegion); |
} else if (name->Equals(v8::String::New("NativeJSDisplayName"))) { |
- return v8::FunctionTemplate::New(JSDisplayName); |
+ return v8::FunctionTemplate::New(I18NLocale::JSDisplayName); |
} else if (name->Equals(v8::String::New("NativeJSBreakIterator"))) { |
return v8::FunctionTemplate::New(BreakIterator::JSBreakIterator); |
} |
@@ -79,144 +75,6 @@ |
return v8::Handle<v8::FunctionTemplate>(); |
} |
-v8::Handle<v8::Value> I18NExtension::JSLocale(const v8::Arguments& args) { |
- // TODO(cira): Fetch browser locale. Accept en-US as good default for now. |
- // We could possibly pass browser locale as a parameter in the constructor. |
- std::string locale_name("en-US"); |
- if (args.Length() == 1 && args[0]->IsString()) { |
- locale_name = *v8::String::Utf8Value(args[0]->ToString()); |
- } |
- |
- v8::Local<v8::Object> locale = v8::Object::New(); |
- locale->Set(v8::String::New("locale"), v8::String::New(locale_name.c_str())); |
- |
- icu::Locale icu_locale(locale_name.c_str()); |
- |
- const char* language = icu_locale.getLanguage(); |
- locale->Set(v8::String::New("language"), v8::String::New(language)); |
- |
- const char* script = icu_locale.getScript(); |
- if (strlen(script)) { |
- locale->Set(v8::String::New("script"), v8::String::New(script)); |
- } |
- |
- const char* region = icu_locale.getCountry(); |
- if (strlen(region)) { |
- locale->Set(v8::String::New("region"), v8::String::New(region)); |
- } |
- |
- return locale; |
-} |
- |
-// TODO(cira): Filter out locales that Chrome doesn't support. |
-v8::Handle<v8::Value> I18NExtension::JSAvailableLocales( |
- const v8::Arguments& args) { |
- v8::Local<v8::Array> all_locales = v8::Array::New(); |
- |
- int count = 0; |
- const icu::Locale* icu_locales = icu::Locale::getAvailableLocales(count); |
- for (int i = 0; i < count; ++i) { |
- all_locales->Set(i, v8::String::New(icu_locales[i].getName())); |
- } |
- |
- return all_locales; |
-} |
- |
-// Use - as tag separator, not _ that ICU uses. |
-static std::string NormalizeLocale(const std::string& locale) { |
- std::string result(locale); |
- // TODO(cira): remove STL dependency. |
- std::replace(result.begin(), result.end(), '_', '-'); |
- return result; |
-} |
- |
-v8::Handle<v8::Value> I18NExtension::JSMaximizedLocale( |
- const v8::Arguments& args) { |
- if (!args.Length() || !args[0]->IsString()) { |
- return v8::Undefined(); |
- } |
- |
- UErrorCode status = U_ZERO_ERROR; |
- std::string locale_name = *v8::String::Utf8Value(args[0]->ToString()); |
- char max_locale[ULOC_FULLNAME_CAPACITY]; |
- uloc_addLikelySubtags(locale_name.c_str(), max_locale, |
- sizeof(max_locale), &status); |
- if (U_FAILURE(status)) { |
- return v8::Undefined(); |
- } |
- |
- return v8::String::New(NormalizeLocale(max_locale).c_str()); |
-} |
- |
-v8::Handle<v8::Value> I18NExtension::JSMinimizedLocale( |
- const v8::Arguments& args) { |
- if (!args.Length() || !args[0]->IsString()) { |
- return v8::Undefined(); |
- } |
- |
- UErrorCode status = U_ZERO_ERROR; |
- std::string locale_name = *v8::String::Utf8Value(args[0]->ToString()); |
- char min_locale[ULOC_FULLNAME_CAPACITY]; |
- uloc_minimizeSubtags(locale_name.c_str(), min_locale, |
- sizeof(min_locale), &status); |
- if (U_FAILURE(status)) { |
- return v8::Undefined(); |
- } |
- |
- return v8::String::New(NormalizeLocale(min_locale).c_str()); |
-} |
- |
-// Common code for JSDisplayXXX methods. |
-static v8::Handle<v8::Value> GetDisplayItem(const v8::Arguments& args, |
- const std::string& item) { |
- if (args.Length() != 2 || !args[0]->IsString() || !args[1]->IsString()) { |
- return v8::Undefined(); |
- } |
- |
- std::string base_locale = *v8::String::Utf8Value(args[0]->ToString()); |
- icu::Locale icu_locale(base_locale.c_str()); |
- icu::Locale display_locale = |
- icu::Locale(*v8::String::Utf8Value(args[1]->ToString())); |
- icu::UnicodeString result; |
- if (item == "language") { |
- icu_locale.getDisplayLanguage(display_locale, result); |
- } else if (item == "script") { |
- icu_locale.getDisplayScript(display_locale, result); |
- } else if (item == "region") { |
- icu_locale.getDisplayCountry(display_locale, result); |
- } else if (item == "name") { |
- icu_locale.getDisplayName(display_locale, result); |
- } else { |
- return v8::Undefined(); |
- } |
- |
- if (result.length()) { |
- return v8::String::New( |
- reinterpret_cast<const uint16_t*>(result.getBuffer()), result.length()); |
- } |
- |
- return v8::Undefined(); |
-} |
- |
-v8::Handle<v8::Value> I18NExtension::JSDisplayLanguage( |
- const v8::Arguments& args) { |
- return GetDisplayItem(args, "language"); |
-} |
- |
-v8::Handle<v8::Value> I18NExtension::JSDisplayScript( |
- const v8::Arguments& args) { |
- return GetDisplayItem(args, "script"); |
-} |
- |
-v8::Handle<v8::Value> I18NExtension::JSDisplayRegion( |
- const v8::Arguments& args) { |
- return GetDisplayItem(args, "region"); |
-} |
- |
-v8::Handle<v8::Value> I18NExtension::JSDisplayName(const v8::Arguments& args) { |
- return GetDisplayItem(args, "name"); |
-} |
- |
I18NExtension* I18NExtension::get() { |
if (!extension_) { |
extension_ = new I18NExtension(); |