 Chromium Code Reviews
 Chromium Code Reviews Issue 2582993002:
  [intl] Add new semantics + compat fallback to Intl constructor  (Closed)
    
  
    Issue 2582993002:
  [intl] Add new semantics + compat fallback to Intl constructor  (Closed) 
  | OLD | NEW | 
|---|---|
| 1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 the V8 project 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 // ECMAScript 402 API implementation. | 5 // ECMAScript 402 API implementation. | 
| 6 | 6 | 
| 7 /** | 7 /** | 
| 8 * Intl object is a single object that has some named properties, | 8 * Intl object is a single object that has some named properties, | 
| 9 * all of which are constructors. | 9 * all of which are constructors. | 
| 10 */ | 10 */ | 
| 11 (function(global, utils) { | 11 (function(global, utils) { | 
| 12 | 12 | 
| 13 "use strict"; | 13 "use strict"; | 
| 14 | 14 | 
| 15 %CheckIsBootstrapping(); | 15 %CheckIsBootstrapping(); | 
| 16 | 16 | 
| 17 // ------------------------------------------------------------------- | 17 // ------------------------------------------------------------------- | 
| 18 // Imports | 18 // Imports | 
| 19 | 19 | 
| 20 var ArrayJoin; | 20 var ArrayJoin; | 
| 21 var ArrayPush; | 21 var ArrayPush; | 
| 22 var GlobalDate = global.Date; | 22 var GlobalDate = global.Date; | 
| 23 var GlobalNumber = global.Number; | 23 var GlobalNumber = global.Number; | 
| 24 var GlobalRegExp = global.RegExp; | 24 var GlobalRegExp = global.RegExp; | 
| 25 var GlobalString = global.String; | 25 var GlobalString = global.String; | 
| 26 var IntlFallbackSymbol = utils.ImportNow("intl_fallback_symbol"); | |
| 26 var InstallFunctions = utils.InstallFunctions; | 27 var InstallFunctions = utils.InstallFunctions; | 
| 27 var InstallGetter = utils.InstallGetter; | 28 var InstallGetter = utils.InstallGetter; | 
| 28 var InternalArray = utils.InternalArray; | 29 var InternalArray = utils.InternalArray; | 
| 29 var ObjectHasOwnProperty = utils.ImportNow("ObjectHasOwnProperty"); | 30 var ObjectHasOwnProperty = utils.ImportNow("ObjectHasOwnProperty"); | 
| 30 var OverrideFunction = utils.OverrideFunction; | 31 var OverrideFunction = utils.OverrideFunction; | 
| 31 var patternSymbol = utils.ImportNow("intl_pattern_symbol"); | 32 var patternSymbol = utils.ImportNow("intl_pattern_symbol"); | 
| 32 var resolvedSymbol = utils.ImportNow("intl_resolved_symbol"); | 33 var resolvedSymbol = utils.ImportNow("intl_resolved_symbol"); | 
| 33 var SetFunctionName = utils.SetFunctionName; | 34 var SetFunctionName = utils.SetFunctionName; | 
| 34 var StringSubstr = GlobalString.prototype.substr; | 35 var StringSubstr = GlobalString.prototype.substr; | 
| 35 var StringSubstring = GlobalString.prototype.substring; | 36 var StringSubstring = GlobalString.prototype.substring; | 
| (...skipping 14 matching lines...) Expand all Loading... | |
| 50 %CheckIsBootstrapping(); | 51 %CheckIsBootstrapping(); | 
| 51 SetFunctionName(func, name); | 52 SetFunctionName(func, name); | 
| 52 %AddNamedProperty(object, name, func, DONT_ENUM); | 53 %AddNamedProperty(object, name, func, DONT_ENUM); | 
| 53 %SetNativeFlag(func); | 54 %SetNativeFlag(func); | 
| 54 %ToFastProperties(object); | 55 %ToFastProperties(object); | 
| 55 } | 56 } | 
| 56 | 57 | 
| 57 /** | 58 /** | 
| 58 * Adds bound method to the prototype of the given object. | 59 * Adds bound method to the prototype of the given object. | 
| 59 */ | 60 */ | 
| 60 function AddBoundMethod(obj, methodName, implementation, length, type) { | 61 function AddBoundMethod(obj, methodName, implementation, length, typename, compa t) { | 
| 
Yang
2016/12/23 09:05:46
80 char limit
 
Dan Ehrenberg
2016/12/23 14:01:53
Done.
 | |
| 61 %CheckIsBootstrapping(); | 62 %CheckIsBootstrapping(); | 
| 62 var internalName = %CreatePrivateSymbol(methodName); | 63 var internalName = %CreatePrivateSymbol(methodName); | 
| 63 // Making getter an anonymous function will cause | 64 // Making getter an anonymous function will cause | 
| 64 // %DefineGetterPropertyUnchecked to properly set the "name" | 65 // %DefineGetterPropertyUnchecked to properly set the "name" | 
| 65 // property on each JSFunction instance created here, rather | 66 // property on each JSFunction instance created here, rather | 
| 66 // than (as utils.InstallGetter would) on the SharedFunctionInfo | 67 // than (as utils.InstallGetter would) on the SharedFunctionInfo | 
| 67 // associated with all functions returned from AddBoundMethod. | 68 // associated with all functions returned from AddBoundMethod. | 
| 68 var getter = ANONYMOUS_FUNCTION(function() { | 69 var getter = ANONYMOUS_FUNCTION(function() { | 
| 69 if (!%IsInitializedIntlObjectOfType(this, type)) { | 70 var receiver = Unwrap(this, typename, obj, methodName, compat); | 
| 70 throw %make_type_error(kMethodCalledOnWrongObject, methodName); | 71 if (IS_UNDEFINED(receiver[internalName])) { | 
| 71 } | |
| 72 if (IS_UNDEFINED(this[internalName])) { | |
| 73 var boundMethod; | 72 var boundMethod; | 
| 74 if (IS_UNDEFINED(length) || length === 2) { | 73 if (IS_UNDEFINED(length) || length === 2) { | 
| 75 boundMethod = | 74 boundMethod = | 
| 76 ANONYMOUS_FUNCTION((fst, snd) => implementation(this, fst, snd)); | 75 ANONYMOUS_FUNCTION((fst, snd) => implementation(receiver, fst, snd)); | 
| 77 } else if (length === 1) { | 76 } else if (length === 1) { | 
| 78 boundMethod = ANONYMOUS_FUNCTION(fst => implementation(this, fst)); | 77 boundMethod = ANONYMOUS_FUNCTION(fst => implementation(receiver, fst)); | 
| 79 } else { | 78 } else { | 
| 80 boundMethod = ANONYMOUS_FUNCTION((...args) => { | 79 boundMethod = ANONYMOUS_FUNCTION((...args) => { | 
| 81 // DateTimeFormat.format needs to be 0 arg method, but can still | 80 // DateTimeFormat.format needs to be 0 arg method, but can still | 
| 82 // receive an optional dateValue param. If one was provided, pass it | 81 // receive an optional dateValue param. If one was provided, pass it | 
| 83 // along. | 82 // along. | 
| 84 if (args.length > 0) { | 83 if (args.length > 0) { | 
| 85 return implementation(this, args[0]); | 84 return implementation(receiver, args[0]); | 
| 86 } else { | 85 } else { | 
| 87 return implementation(this); | 86 return implementation(receiver); | 
| 88 } | 87 } | 
| 89 }); | 88 }); | 
| 90 } | 89 } | 
| 91 %SetNativeFlag(boundMethod); | 90 %SetNativeFlag(boundMethod); | 
| 92 this[internalName] = boundMethod; | 91 receiver[internalName] = boundMethod; | 
| 93 } | 92 } | 
| 94 return this[internalName]; | 93 return receiver[internalName]; | 
| 95 }); | 94 }); | 
| 96 | 95 | 
| 97 %FunctionRemovePrototype(getter); | 96 %FunctionRemovePrototype(getter); | 
| 98 %DefineGetterPropertyUnchecked(obj.prototype, methodName, getter, DONT_ENUM); | 97 %DefineGetterPropertyUnchecked(obj.prototype, methodName, getter, DONT_ENUM); | 
| 99 %SetNativeFlag(getter); | 98 %SetNativeFlag(getter); | 
| 100 } | 99 } | 
| 101 | 100 | 
| 101 function IntlConstruct(receiver, constructor, initializer, newTarget, args, | |
| 102 compat) { | |
| 103 var locales = args[0]; | |
| 104 var options = args[1]; | |
| 105 | |
| 106 if (IS_UNDEFINED(newTarget)) { | |
| 107 if (compat && receiver instanceof constructor) { | |
| 108 let success = %object_define_property(receiver, IntlFallbackSymbol, | |
| 109 { value: new constructor(locales, options) }); | |
| 110 if (!success) { | |
| 111 throw %make_type_error(kReinitializeIntl, constructor); | |
| 112 } | |
| 113 return receiver; | |
| 114 } | |
| 115 | |
| 116 return new constructor(locales, options); | |
| 117 } | |
| 118 | |
| 119 return initializer(receiver, locales, options); | |
| 120 } | |
| 121 | |
| 122 | |
| 123 | |
| 124 function Unwrap(receiver, typename, constructor, method, compat) { | |
| 125 if (!%IsInitializedIntlObjectOfType(receiver, typename)) { | |
| 126 if (compat && receiver instanceof constructor) { | |
| 127 let fallback = receiver[IntlFallbackSymbol]; | |
| 128 if (%IsInitializedIntlObjectOfType(fallback, typename)) { | |
| 129 return fallback; | |
| 130 } | |
| 131 } | |
| 132 throw %make_type_error(kIncompatibleMethodReceiver, method, receiver); | |
| 133 } | |
| 134 return receiver; | |
| 135 } | |
| 136 | |
| 137 | |
| 102 // ------------------------------------------------------------------- | 138 // ------------------------------------------------------------------- | 
| 103 | 139 | 
| 104 var Intl = {}; | 140 var Intl = {}; | 
| 105 | 141 | 
| 106 %AddNamedProperty(global, "Intl", Intl, DONT_ENUM); | 142 %AddNamedProperty(global, "Intl", Intl, DONT_ENUM); | 
| 107 | 143 | 
| 108 /** | 144 /** | 
| 109 * Caches available locales for each service. | 145 * Caches available locales for each service. | 
| 110 */ | 146 */ | 
| 111 var AVAILABLE_LOCALES = { | 147 var AVAILABLE_LOCALES = { | 
| (...skipping 910 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1022 return collator; | 1058 return collator; | 
| 1023 } | 1059 } | 
| 1024 | 1060 | 
| 1025 | 1061 | 
| 1026 /** | 1062 /** | 
| 1027 * Constructs Intl.Collator object given optional locales and options | 1063 * Constructs Intl.Collator object given optional locales and options | 
| 1028 * parameters. | 1064 * parameters. | 
| 1029 * | 1065 * | 
| 1030 * @constructor | 1066 * @constructor | 
| 1031 */ | 1067 */ | 
| 1032 InstallConstructor(Intl, 'Collator', function() { | 1068 function Collator() { | 
| 1033 var locales = arguments[0]; | 1069 return IntlConstruct(this, Collator, initializeCollator, new.target, | 
| 1034 var options = arguments[1]; | 1070 arguments); | 
| 1035 | 1071 } | 
| 1036 if (!this || this === Intl) { | 1072 InstallConstructor(Intl, 'Collator', Collator); | 
| 1037 // Constructor is called as a function. | |
| 1038 return new Intl.Collator(locales, options); | |
| 1039 } | |
| 1040 | |
| 1041 return initializeCollator(TO_OBJECT(this), locales, options); | |
| 1042 } | |
| 1043 ); | |
| 1044 | 1073 | 
| 1045 | 1074 | 
| 1046 /** | 1075 /** | 
| 1047 * Collator resolvedOptions method. | 1076 * Collator resolvedOptions method. | 
| 1048 */ | 1077 */ | 
| 1049 InstallFunction(Intl.Collator.prototype, 'resolvedOptions', function() { | 1078 InstallFunction(Intl.Collator.prototype, 'resolvedOptions', function() { | 
| 1050 if (!%IsInitializedIntlObjectOfType(this, 'collator')) { | 1079 var coll = Unwrap(this, 'collator', Collator, 'resolvedOptions', false); | 
| 1051 throw %make_type_error(kResolvedOptionsCalledOnNonObject, "Collator"); | |
| 1052 } | |
| 1053 | |
| 1054 var coll = this; | |
| 1055 var locale = getOptimalLanguageTag(coll[resolvedSymbol].requestedLocale, | 1080 var locale = getOptimalLanguageTag(coll[resolvedSymbol].requestedLocale, | 
| 1056 coll[resolvedSymbol].locale); | 1081 coll[resolvedSymbol].locale); | 
| 1057 | 1082 | 
| 1058 return { | 1083 return { | 
| 1059 locale: locale, | 1084 locale: locale, | 
| 1060 usage: coll[resolvedSymbol].usage, | 1085 usage: coll[resolvedSymbol].usage, | 
| 1061 sensitivity: coll[resolvedSymbol].sensitivity, | 1086 sensitivity: coll[resolvedSymbol].sensitivity, | 
| 1062 ignorePunctuation: coll[resolvedSymbol].ignorePunctuation, | 1087 ignorePunctuation: coll[resolvedSymbol].ignorePunctuation, | 
| 1063 numeric: coll[resolvedSymbol].numeric, | 1088 numeric: coll[resolvedSymbol].numeric, | 
| 1064 caseFirst: coll[resolvedSymbol].caseFirst, | 1089 caseFirst: coll[resolvedSymbol].caseFirst, | 
| (...skipping 24 matching lines...) Expand all Loading... | |
| 1089 * of this Collator object, and will be negative, zero, or positive, depending | 1114 * of this Collator object, and will be negative, zero, or positive, depending | 
| 1090 * on whether x comes before y in the sort order, the Strings are equal under | 1115 * on whether x comes before y in the sort order, the Strings are equal under | 
| 1091 * the sort order, or x comes after y in the sort order, respectively. | 1116 * the sort order, or x comes after y in the sort order, respectively. | 
| 1092 */ | 1117 */ | 
| 1093 function compare(collator, x, y) { | 1118 function compare(collator, x, y) { | 
| 1094 return %InternalCompare(%GetImplFromInitializedIntlObject(collator), | 1119 return %InternalCompare(%GetImplFromInitializedIntlObject(collator), | 
| 1095 TO_STRING(x), TO_STRING(y)); | 1120 TO_STRING(x), TO_STRING(y)); | 
| 1096 }; | 1121 }; | 
| 1097 | 1122 | 
| 1098 | 1123 | 
| 1099 AddBoundMethod(Intl.Collator, 'compare', compare, 2, 'collator'); | 1124 AddBoundMethod(Intl.Collator, 'compare', compare, 2, 'collator', false); | 
| 1100 | 1125 | 
| 1101 /** | 1126 /** | 
| 1102 * Verifies that the input is a well-formed ISO 4217 currency code. | 1127 * Verifies that the input is a well-formed ISO 4217 currency code. | 
| 1103 * Don't uppercase to test. It could convert invalid code into a valid one. | 1128 * Don't uppercase to test. It could convert invalid code into a valid one. | 
| 1104 * For example \u00DFP (Eszett+P) becomes SSP. | 1129 * For example \u00DFP (Eszett+P) becomes SSP. | 
| 1105 */ | 1130 */ | 
| 1106 function isWellFormedCurrencyCode(currency) { | 1131 function isWellFormedCurrencyCode(currency) { | 
| 1107 return typeof currency == "string" && currency.length == 3 && | 1132 return typeof currency == "string" && currency.length == 3 && | 
| 1108 IS_NULL(%regexp_internal_match(/[^A-Za-z]/, currency)); | 1133 IS_NULL(%regexp_internal_match(/[^A-Za-z]/, currency)); | 
| 1109 } | 1134 } | 
| (...skipping 145 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1255 return numberFormat; | 1280 return numberFormat; | 
| 1256 } | 1281 } | 
| 1257 | 1282 | 
| 1258 | 1283 | 
| 1259 /** | 1284 /** | 
| 1260 * Constructs Intl.NumberFormat object given optional locales and options | 1285 * Constructs Intl.NumberFormat object given optional locales and options | 
| 1261 * parameters. | 1286 * parameters. | 
| 1262 * | 1287 * | 
| 1263 * @constructor | 1288 * @constructor | 
| 1264 */ | 1289 */ | 
| 1265 InstallConstructor(Intl, 'NumberFormat', function() { | 1290 function NumberFormat() { | 
| 1266 var locales = arguments[0]; | 1291 return IntlConstruct(this, NumberFormat, initializeNumberFormat, new.target, | 
| 1267 var options = arguments[1]; | 1292 arguments, true); | 
| 1268 | 1293 } | 
| 1269 if (!this || this === Intl) { | 1294 InstallConstructor(Intl, 'NumberFormat', NumberFormat); | 
| 1270 // Constructor is called as a function. | |
| 1271 return new Intl.NumberFormat(locales, options); | |
| 1272 } | |
| 1273 | |
| 1274 return initializeNumberFormat(TO_OBJECT(this), locales, options); | |
| 1275 } | |
| 1276 ); | |
| 1277 | 1295 | 
| 1278 | 1296 | 
| 1279 /** | 1297 /** | 
| 1280 * NumberFormat resolvedOptions method. | 1298 * NumberFormat resolvedOptions method. | 
| 1281 */ | 1299 */ | 
| 1282 InstallFunction(Intl.NumberFormat.prototype, 'resolvedOptions', function() { | 1300 InstallFunction(Intl.NumberFormat.prototype, 'resolvedOptions', function() { | 
| 1283 if (!%IsInitializedIntlObjectOfType(this, 'numberformat')) { | 1301 var format = Unwrap(this, 'numberformat', NumberFormat, | 
| 1284 throw %make_type_error(kResolvedOptionsCalledOnNonObject, "NumberFormat"); | 1302 'resolvedOptions', true); | 
| 1285 } | |
| 1286 | |
| 1287 var format = this; | |
| 1288 var locale = getOptimalLanguageTag(format[resolvedSymbol].requestedLocale, | 1303 var locale = getOptimalLanguageTag(format[resolvedSymbol].requestedLocale, | 
| 1289 format[resolvedSymbol].locale); | 1304 format[resolvedSymbol].locale); | 
| 1290 | 1305 | 
| 1291 var result = { | 1306 var result = { | 
| 1292 locale: locale, | 1307 locale: locale, | 
| 1293 numberingSystem: format[resolvedSymbol].numberingSystem, | 1308 numberingSystem: format[resolvedSymbol].numberingSystem, | 
| 1294 style: format[resolvedSymbol].style, | 1309 style: format[resolvedSymbol].style, | 
| 1295 useGrouping: format[resolvedSymbol].useGrouping, | 1310 useGrouping: format[resolvedSymbol].useGrouping, | 
| 1296 minimumIntegerDigits: format[resolvedSymbol].minimumIntegerDigits, | 1311 minimumIntegerDigits: format[resolvedSymbol].minimumIntegerDigits, | 
| 1297 minimumFractionDigits: format[resolvedSymbol].minimumFractionDigits, | 1312 minimumFractionDigits: format[resolvedSymbol].minimumFractionDigits, | 
| (...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1338 */ | 1353 */ | 
| 1339 function formatNumber(formatter, value) { | 1354 function formatNumber(formatter, value) { | 
| 1340 // Spec treats -0 and +0 as 0. | 1355 // Spec treats -0 and +0 as 0. | 
| 1341 var number = TO_NUMBER(value) + 0; | 1356 var number = TO_NUMBER(value) + 0; | 
| 1342 | 1357 | 
| 1343 return %InternalNumberFormat(%GetImplFromInitializedIntlObject(formatter), | 1358 return %InternalNumberFormat(%GetImplFromInitializedIntlObject(formatter), | 
| 1344 number); | 1359 number); | 
| 1345 } | 1360 } | 
| 1346 | 1361 | 
| 1347 | 1362 | 
| 1348 AddBoundMethod(Intl.NumberFormat, 'format', formatNumber, 1, 'numberformat'); | 1363 AddBoundMethod(Intl.NumberFormat, 'format', formatNumber, 1, 'numberformat', tru e); | 
| 1349 | 1364 | 
| 1350 /** | 1365 /** | 
| 1351 * Returns a string that matches LDML representation of the options object. | 1366 * Returns a string that matches LDML representation of the options object. | 
| 1352 */ | 1367 */ | 
| 1353 function toLDMLString(options) { | 1368 function toLDMLString(options) { | 
| 1354 var getOption = getGetOption(options, 'dateformat'); | 1369 var getOption = getGetOption(options, 'dateformat'); | 
| 1355 | 1370 | 
| 1356 var ldmlString = ''; | 1371 var ldmlString = ''; | 
| 1357 | 1372 | 
| 1358 var option = getOption('weekday', 'string', ['narrow', 'short', 'long']); | 1373 var option = getOption('weekday', 'string', ['narrow', 'short', 'long']); | 
| (...skipping 272 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1631 return dateFormat; | 1646 return dateFormat; | 
| 1632 } | 1647 } | 
| 1633 | 1648 | 
| 1634 | 1649 | 
| 1635 /** | 1650 /** | 
| 1636 * Constructs Intl.DateTimeFormat object given optional locales and options | 1651 * Constructs Intl.DateTimeFormat object given optional locales and options | 
| 1637 * parameters. | 1652 * parameters. | 
| 1638 * | 1653 * | 
| 1639 * @constructor | 1654 * @constructor | 
| 1640 */ | 1655 */ | 
| 1641 InstallConstructor(Intl, 'DateTimeFormat', function() { | 1656 function DateTimeFormat() { | 
| 1642 var locales = arguments[0]; | 1657 return IntlConstruct(this, DateTimeFormat, initializeDateTimeFormat, | 
| 1643 var options = arguments[1]; | 1658 new.target, arguments, true); | 
| 1644 | 1659 } | 
| 1645 if (!this || this === Intl) { | 1660 InstallConstructor(Intl, 'DateTimeFormat', DateTimeFormat); | 
| 1646 // Constructor is called as a function. | |
| 1647 return new Intl.DateTimeFormat(locales, options); | |
| 1648 } | |
| 1649 | |
| 1650 return initializeDateTimeFormat(TO_OBJECT(this), locales, options); | |
| 1651 } | |
| 1652 ); | |
| 1653 | 1661 | 
| 1654 | 1662 | 
| 1655 /** | 1663 /** | 
| 1656 * DateTimeFormat resolvedOptions method. | 1664 * DateTimeFormat resolvedOptions method. | 
| 1657 */ | 1665 */ | 
| 1658 InstallFunction(Intl.DateTimeFormat.prototype, 'resolvedOptions', function() { | 1666 InstallFunction(Intl.DateTimeFormat.prototype, 'resolvedOptions', function() { | 
| 1659 if (!%IsInitializedIntlObjectOfType(this, 'dateformat')) { | 1667 var format = Unwrap(this, 'dateformat', DateTimeFormat, | 
| 1660 throw %make_type_error(kResolvedOptionsCalledOnNonObject, "DateTimeFormat" ); | 1668 'resolvedOptions', true); | 
| 1661 } | |
| 1662 | 1669 | 
| 1663 /** | 1670 /** | 
| 1664 * Maps ICU calendar names to LDML/BCP47 types for key 'ca'. | 1671 * Maps ICU calendar names to LDML/BCP47 types for key 'ca'. | 
| 1665 * See typeMap section in third_party/icu/source/data/misc/keyTypeData.txt | 1672 * See typeMap section in third_party/icu/source/data/misc/keyTypeData.txt | 
| 1666 * and | 1673 * and | 
| 1667 * http://www.unicode.org/repos/cldr/tags/latest/common/bcp47/calendar.xml | 1674 * http://www.unicode.org/repos/cldr/tags/latest/common/bcp47/calendar.xml | 
| 1668 */ | 1675 */ | 
| 1669 var ICU_CALENDAR_MAP = { | 1676 var ICU_CALENDAR_MAP = { | 
| 1670 'gregorian': 'gregory', | 1677 'gregorian': 'gregory', | 
| 1671 'ethiopic-amete-alem': 'ethioaa' | 1678 'ethiopic-amete-alem': 'ethioaa' | 
| 1672 }; | 1679 }; | 
| 1673 | 1680 | 
| 1674 var format = this; | |
| 1675 var fromPattern = fromLDMLString(format[resolvedSymbol][patternSymbol]); | 1681 var fromPattern = fromLDMLString(format[resolvedSymbol][patternSymbol]); | 
| 1676 var userCalendar = ICU_CALENDAR_MAP[format[resolvedSymbol].calendar]; | 1682 var userCalendar = ICU_CALENDAR_MAP[format[resolvedSymbol].calendar]; | 
| 1677 if (IS_UNDEFINED(userCalendar)) { | 1683 if (IS_UNDEFINED(userCalendar)) { | 
| 1678 // No match means that ICU's legacy name is identical to LDML/BCP type. | 1684 // No match means that ICU's legacy name is identical to LDML/BCP type. | 
| 1679 userCalendar = format[resolvedSymbol].calendar; | 1685 userCalendar = format[resolvedSymbol].calendar; | 
| 1680 } | 1686 } | 
| 1681 | 1687 | 
| 1682 var locale = getOptimalLanguageTag(format[resolvedSymbol].requestedLocale, | 1688 var locale = getOptimalLanguageTag(format[resolvedSymbol].requestedLocale, | 
| 1683 format[resolvedSymbol].locale); | 1689 format[resolvedSymbol].locale); | 
| 1684 | 1690 | 
| (...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1751 if (!NUMBER_IS_FINITE(dateMs)) throw %make_range_error(kDateRange); | 1757 if (!NUMBER_IS_FINITE(dateMs)) throw %make_range_error(kDateRange); | 
| 1752 | 1758 | 
| 1753 return %InternalDateFormatToParts( | 1759 return %InternalDateFormatToParts( | 
| 1754 %GetImplFromInitializedIntlObject(this), new GlobalDate(dateMs)); | 1760 %GetImplFromInitializedIntlObject(this), new GlobalDate(dateMs)); | 
| 1755 } | 1761 } | 
| 1756 | 1762 | 
| 1757 %FunctionSetLength(FormatDateToParts, 0); | 1763 %FunctionSetLength(FormatDateToParts, 0); | 
| 1758 | 1764 | 
| 1759 | 1765 | 
| 1760 // 0 because date is optional argument. | 1766 // 0 because date is optional argument. | 
| 1761 AddBoundMethod(Intl.DateTimeFormat, 'format', formatDate, 0, 'dateformat'); | 1767 AddBoundMethod(Intl.DateTimeFormat, 'format', formatDate, 0, 'dateformat', true) ; | 
| 1762 | 1768 | 
| 1763 | 1769 | 
| 1764 /** | 1770 /** | 
| 1765 * Returns canonical Area/Location(/Location) name, or throws an exception | 1771 * Returns canonical Area/Location(/Location) name, or throws an exception | 
| 1766 * if the zone name is invalid IANA name. | 1772 * if the zone name is invalid IANA name. | 
| 1767 */ | 1773 */ | 
| 1768 function canonicalizeTimeZoneID(tzID) { | 1774 function canonicalizeTimeZoneID(tzID) { | 
| 1769 // Skip undefined zones. | 1775 // Skip undefined zones. | 
| 1770 if (IS_UNDEFINED(tzID)) { | 1776 if (IS_UNDEFINED(tzID)) { | 
| 1771 return tzID; | 1777 return tzID; | 
| (...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1840 return iterator; | 1846 return iterator; | 
| 1841 } | 1847 } | 
| 1842 | 1848 | 
| 1843 | 1849 | 
| 1844 /** | 1850 /** | 
| 1845 * Constructs Intl.v8BreakIterator object given optional locales and options | 1851 * Constructs Intl.v8BreakIterator object given optional locales and options | 
| 1846 * parameters. | 1852 * parameters. | 
| 1847 * | 1853 * | 
| 1848 * @constructor | 1854 * @constructor | 
| 1849 */ | 1855 */ | 
| 1850 InstallConstructor(Intl, 'v8BreakIterator', function() { | 1856 function v8BreakIterator() { | 
| 1851 var locales = arguments[0]; | 1857 return IntlConstruct(this, v8BreakIterator, initializeBreakIterator, | 
| 1852 var options = arguments[1]; | 1858 new.target, arguments); | 
| 1853 | 1859 } | 
| 1854 if (!this || this === Intl) { | 1860 InstallConstructor(Intl, 'v8BreakIterator', v8BreakIterator); | 
| 1855 // Constructor is called as a function. | |
| 1856 return new Intl.v8BreakIterator(locales, options); | |
| 1857 } | |
| 1858 | |
| 1859 return initializeBreakIterator(TO_OBJECT(this), locales, options); | |
| 1860 } | |
| 1861 ); | |
| 1862 | 1861 | 
| 1863 | 1862 | 
| 1864 /** | 1863 /** | 
| 1865 * BreakIterator resolvedOptions method. | 1864 * BreakIterator resolvedOptions method. | 
| 1866 */ | 1865 */ | 
| 1867 InstallFunction(Intl.v8BreakIterator.prototype, 'resolvedOptions', | 1866 InstallFunction(Intl.v8BreakIterator.prototype, 'resolvedOptions', | 
| 1868 function() { | 1867 function() { | 
| 1869 if (!IS_UNDEFINED(new.target)) { | 1868 if (!IS_UNDEFINED(new.target)) { | 
| 1870 throw %make_type_error(kOrdinaryFunctionCalledAsConstructor); | 1869 throw %make_type_error(kOrdinaryFunctionCalledAsConstructor); | 
| 1871 } | 1870 } | 
| 1872 | 1871 | 
| 1873 if (!%IsInitializedIntlObjectOfType(this, 'breakiterator')) { | 1872 var segmenter = Unwrap(this, 'breakiterator', v8BreakIterator, | 
| 1874 throw %make_type_error(kResolvedOptionsCalledOnNonObject, "v8BreakIterator "); | 1873 'resolvedOptions', false); | 
| 1875 } | |
| 1876 | 1874 | 
| 1877 var segmenter = this; | |
| 1878 var locale = | 1875 var locale = | 
| 1879 getOptimalLanguageTag(segmenter[resolvedSymbol].requestedLocale, | 1876 getOptimalLanguageTag(segmenter[resolvedSymbol].requestedLocale, | 
| 1880 segmenter[resolvedSymbol].locale); | 1877 segmenter[resolvedSymbol].locale); | 
| 1881 | 1878 | 
| 1882 return { | 1879 return { | 
| 1883 locale: locale, | 1880 locale: locale, | 
| 1884 type: segmenter[resolvedSymbol].type | 1881 type: segmenter[resolvedSymbol].type | 
| 1885 }; | 1882 }; | 
| 1886 } | 1883 } | 
| 1887 ); | 1884 ); | 
| (...skipping 310 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2198 } | 2195 } | 
| 2199 ); | 2196 ); | 
| 2200 | 2197 | 
| 2201 %FunctionRemovePrototype(FormatDateToParts); | 2198 %FunctionRemovePrototype(FormatDateToParts); | 
| 2202 | 2199 | 
| 2203 utils.Export(function(to) { | 2200 utils.Export(function(to) { | 
| 2204 to.FormatDateToParts = FormatDateToParts; | 2201 to.FormatDateToParts = FormatDateToParts; | 
| 2205 }); | 2202 }); | 
| 2206 | 2203 | 
| 2207 }) | 2204 }) | 
| OLD | NEW |