mirror of https://github.com/tc39/test262.git
87 lines
2.9 KiB
JavaScript
87 lines
2.9 KiB
JavaScript
|
// Copyright (C) 2017 André Bargull. All rights reserved.
|
||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||
|
|
||
|
/*---
|
||
|
esid: sec-intl.getcanonicallocales
|
||
|
description: >
|
||
|
Call Intl.getCanonicalLocales function with grandfathered language tags.
|
||
|
info: |
|
||
|
8.2.1 Intl.getCanonicalLocales (locales)
|
||
|
1. Let ll be ? CanonicalizeLocaleList(locales).
|
||
|
2. Return CreateArrayFromList(ll).
|
||
|
|
||
|
9.2.1 CanonicalizeLocaleList (locales)
|
||
|
...
|
||
|
7. Repeat, while k < len
|
||
|
...
|
||
|
c. If kPresent is true, then
|
||
|
...
|
||
|
v. Let canonicalizedTag be CanonicalizeLanguageTag(tag).
|
||
|
...
|
||
|
|
||
|
6.2.3 CanonicalizeLanguageTag ( locale )
|
||
|
The CanonicalizeLanguageTag abstract operation returns the canonical and case-regularized
|
||
|
form of the locale argument (which must be a String value that is a structurally valid
|
||
|
BCP 47 language tag as verified by the IsStructurallyValidLanguageTag abstract operation).
|
||
|
A conforming implementation shall take the steps specified in RFC 5646 section 4.5, or
|
||
|
successor, to bring the language tag into canonical form, and to regularize the case of
|
||
|
the subtags. Furthermore, a conforming implementation shall not take the steps to bring
|
||
|
a language tag into "extlang form", nor shall it reorder variant subtags.
|
||
|
|
||
|
The specifications for extensions to BCP 47 language tags, such as RFC 6067, may include
|
||
|
canonicalization rules for the extension subtag sequences they define that go beyond the
|
||
|
canonicalization rules of RFC 5646 section 4.5. Implementations are allowed, but not
|
||
|
required, to apply these additional rules.
|
||
|
|
||
|
includes: [testIntl.js]
|
||
|
---*/
|
||
|
|
||
|
// Generated from http://www.iana.org/assignments/language-subtag-registry/language-subtag-registry
|
||
|
// File-Date: 2017-08-15
|
||
|
var canonicalizedTags = {
|
||
|
// Irregular tags.
|
||
|
"en-gb-oed": "en-GB-oxendict",
|
||
|
"i-ami": "ami",
|
||
|
"i-bnn": "bnn",
|
||
|
"i-default": "i-default",
|
||
|
"i-enochian": "i-enochian",
|
||
|
"i-hak": "hak",
|
||
|
"i-klingon": "tlh",
|
||
|
"i-lux": "lb",
|
||
|
"i-mingo": "i-mingo",
|
||
|
"i-navajo": "nv",
|
||
|
"i-pwn": "pwn",
|
||
|
"i-tao": "tao",
|
||
|
"i-tay": "tay",
|
||
|
"i-tsu": "tsu",
|
||
|
"sgn-be-fr": "sfb",
|
||
|
"sgn-be-nl": "vgt",
|
||
|
"sgn-ch-de": "sgg",
|
||
|
|
||
|
// Regular tags.
|
||
|
"art-lojban": "jbo",
|
||
|
"cel-gaulish": "cel-gaulish",
|
||
|
"no-bok": "nb",
|
||
|
"no-nyn": "nn",
|
||
|
"zh-guoyu": "cmn",
|
||
|
"zh-hakka": "hak",
|
||
|
"zh-min": "zh-min",
|
||
|
"zh-min-nan": "nan",
|
||
|
"zh-xiang": "hsn",
|
||
|
};
|
||
|
|
||
|
// make sure the data above is correct
|
||
|
Object.getOwnPropertyNames(canonicalizedTags).forEach(function (tag) {
|
||
|
var canonicalizedTag = canonicalizedTags[tag];
|
||
|
assert(
|
||
|
isCanonicalizedStructurallyValidLanguageTag(canonicalizedTag),
|
||
|
"Test data \"" + canonicalizedTag + "\" is not canonicalized and structurally valid language tag."
|
||
|
);
|
||
|
});
|
||
|
|
||
|
Object.getOwnPropertyNames(canonicalizedTags).forEach(function (tag) {
|
||
|
var canonicalLocales = Intl.getCanonicalLocales(tag);
|
||
|
assert.sameValue(canonicalLocales.length, 1);
|
||
|
assert.sameValue(canonicalLocales[0], canonicalizedTags[tag]);
|
||
|
});
|