Better adherence to coding conventions
This commit is contained in:
@@ -80,9 +80,10 @@
|
|||||||
* @return array
|
* @return array
|
||||||
*/
|
*/
|
||||||
$.uls.data.getAutonyms = function () {
|
$.uls.data.getAutonyms = function () {
|
||||||
var autonymsByCode = {};
|
var language,
|
||||||
|
autonymsByCode = {};
|
||||||
|
|
||||||
for ( var language in $.uls.data.languages ) {
|
for ( language in $.uls.data.languages ) {
|
||||||
if ( $.uls.data.isRedirect( language ) ) {
|
if ( $.uls.data.isRedirect( language ) ) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@@ -98,9 +99,10 @@
|
|||||||
* @return array
|
* @return array
|
||||||
*/
|
*/
|
||||||
$.uls.data.getAllRegions = function () {
|
$.uls.data.getAllRegions = function () {
|
||||||
var allRegions = [];
|
var region,
|
||||||
|
allRegions = [];
|
||||||
|
|
||||||
for ( var region in $.uls.data.regiongroups ) {
|
for ( region in $.uls.data.regiongroups ) {
|
||||||
allRegions.push( region );
|
allRegions.push( region );
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -123,14 +125,15 @@
|
|||||||
* @return array of strings (languages codes)
|
* @return array of strings (languages codes)
|
||||||
*/
|
*/
|
||||||
$.uls.data.getLanguagesInScripts = function ( scripts ) {
|
$.uls.data.getLanguagesInScripts = function ( scripts ) {
|
||||||
var languagesInScripts = [];
|
var language, i,
|
||||||
|
languagesInScripts = [];
|
||||||
|
|
||||||
for ( var language in $.uls.data.languages ) {
|
for ( language in $.uls.data.languages ) {
|
||||||
if ( $.uls.data.isRedirect( language ) ) {
|
if ( $.uls.data.isRedirect( language ) ) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
for ( var i = 0; i < scripts.length; i++ ) {
|
for ( i = 0; i < scripts.length; i++ ) {
|
||||||
if ( scripts[i] === $.uls.data.getScript( language ) ) {
|
if ( scripts[i] === $.uls.data.getScript( language ) ) {
|
||||||
languagesInScripts.push( language );
|
languagesInScripts.push( language );
|
||||||
break;
|
break;
|
||||||
@@ -156,14 +159,15 @@
|
|||||||
* @return array of strings (languages codes)
|
* @return array of strings (languages codes)
|
||||||
*/
|
*/
|
||||||
$.uls.data.getLanguagesInRegions = function ( regions ) {
|
$.uls.data.getLanguagesInRegions = function ( regions ) {
|
||||||
var languagesInRegions = [];
|
var language, i,
|
||||||
|
languagesInRegions = [];
|
||||||
|
|
||||||
for ( var language in $.uls.data.languages ) {
|
for ( language in $.uls.data.languages ) {
|
||||||
if ( $.uls.data.isRedirect( language ) ) {
|
if ( $.uls.data.isRedirect( language ) ) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
for ( var i = 0; i < regions.length; i++ ) {
|
for ( i = 0; i < regions.length; i++ ) {
|
||||||
if ( $.inArray( regions[i], $.uls.data.getRegions( language ) ) !== -1 ) {
|
if ( $.inArray( regions[i], $.uls.data.getRegions( language ) ) !== -1 ) {
|
||||||
languagesInRegions.push( language );
|
languagesInRegions.push( language );
|
||||||
break;
|
break;
|
||||||
@@ -190,15 +194,16 @@
|
|||||||
* @return associative array
|
* @return associative array
|
||||||
*/
|
*/
|
||||||
$.uls.data.getLanguagesByScriptInRegion = function ( region ) {
|
$.uls.data.getLanguagesByScriptInRegion = function ( region ) {
|
||||||
var languagesByScriptInRegion = {};
|
var language, script,
|
||||||
|
languagesByScriptInRegion = {};
|
||||||
|
|
||||||
for ( var language in $.uls.data.languages ) {
|
for ( language in $.uls.data.languages ) {
|
||||||
if ( $.uls.data.isRedirect( language ) ) {
|
if ( $.uls.data.isRedirect( language ) ) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( $.inArray( region, $.uls.data.getRegions( language ) ) !== -1 ) {
|
if ( $.inArray( region, $.uls.data.getRegions( language ) ) !== -1 ) {
|
||||||
var script = $.uls.data.getScript( language );
|
script = $.uls.data.getScript( language );
|
||||||
|
|
||||||
if ( languagesByScriptInRegion[script] === undefined ) {
|
if ( languagesByScriptInRegion[script] === undefined ) {
|
||||||
languagesByScriptInRegion[script] = [];
|
languagesByScriptInRegion[script] = [];
|
||||||
@@ -263,16 +268,17 @@
|
|||||||
* @return associative array
|
* @return associative array
|
||||||
*/
|
*/
|
||||||
$.uls.data.getLanguagesByScriptGroupInRegions = function ( regions ) {
|
$.uls.data.getLanguagesByScriptGroupInRegions = function ( regions ) {
|
||||||
var languagesByScriptGroupInRegions = {};
|
var language, i, scriptGroup,
|
||||||
|
languagesByScriptGroupInRegions = {};
|
||||||
|
|
||||||
for ( var language in $.uls.data.languages ) {
|
for ( language in $.uls.data.languages ) {
|
||||||
if ( $.uls.data.isRedirect( language ) ) {
|
if ( $.uls.data.isRedirect( language ) ) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
for ( var i = 0; i < regions.length; i++ ) {
|
for ( i = 0; i < regions.length; i++ ) {
|
||||||
if ( $.inArray( regions[i], $.uls.data.getRegions( language ) ) !== -1 ) {
|
if ( $.inArray( regions[i], $.uls.data.getRegions( language ) ) !== -1 ) {
|
||||||
var scriptGroup = $.uls.data.getScriptGroupOfLanguage( language );
|
scriptGroup = $.uls.data.getScriptGroupOfLanguage( language );
|
||||||
|
|
||||||
if ( languagesByScriptGroupInRegions[scriptGroup] === undefined ) {
|
if ( languagesByScriptGroupInRegions[scriptGroup] === undefined ) {
|
||||||
languagesByScriptGroupInRegions[scriptGroup] = [];
|
languagesByScriptGroupInRegions[scriptGroup] = [];
|
||||||
@@ -293,9 +299,9 @@
|
|||||||
* @return associative array
|
* @return associative array
|
||||||
*/
|
*/
|
||||||
$.uls.data.getAllLanguagesByRegionAndScript = function () {
|
$.uls.data.getAllLanguagesByRegionAndScript = function () {
|
||||||
var allLanguagesByRegionAndScript = {},
|
var region, regionGroup, language,
|
||||||
region,
|
script, scriptGroup, regions, regionNum,
|
||||||
regionGroup;
|
allLanguagesByRegionAndScript = {};
|
||||||
|
|
||||||
for ( region in $.uls.data.regiongroups ) {
|
for ( region in $.uls.data.regiongroups ) {
|
||||||
regionGroup = $.uls.data.regiongroups[region];
|
regionGroup = $.uls.data.regiongroups[region];
|
||||||
@@ -307,16 +313,16 @@
|
|||||||
allLanguagesByRegionAndScript[regionGroup][region] = {};
|
allLanguagesByRegionAndScript[regionGroup][region] = {};
|
||||||
}
|
}
|
||||||
|
|
||||||
for ( var language in $.uls.data.languages ) {
|
for ( language in $.uls.data.languages ) {
|
||||||
if ( $.uls.data.isRedirect( language ) ) {
|
if ( $.uls.data.isRedirect( language ) ) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
var script = $.uls.data.getScript( language );
|
script = $.uls.data.getScript( language );
|
||||||
var scriptGroup = $.uls.data.getGroupOfScript( script );
|
scriptGroup = $.uls.data.getGroupOfScript( script );
|
||||||
var regions = $.uls.data.getRegions( language );
|
regions = $.uls.data.getRegions( language );
|
||||||
|
|
||||||
for ( var regionNum = 0; regionNum < regions.length; regionNum++ ) {
|
for ( regionNum = 0; regionNum < regions.length; regionNum++ ) {
|
||||||
region = regions[regionNum];
|
region = regions[regionNum];
|
||||||
regionGroup = $.uls.data.regiongroups[region];
|
regionGroup = $.uls.data.regiongroups[region];
|
||||||
|
|
||||||
@@ -341,9 +347,10 @@
|
|||||||
* @return array of strings
|
* @return array of strings
|
||||||
*/
|
*/
|
||||||
$.uls.data.getRegionsInGroup = function ( groupNum ) {
|
$.uls.data.getRegionsInGroup = function ( groupNum ) {
|
||||||
var regionsInGroup = [];
|
var region,
|
||||||
|
regionsInGroup = [];
|
||||||
|
|
||||||
for ( var region in $.uls.data.regiongroups ) {
|
for ( region in $.uls.data.regiongroups ) {
|
||||||
if ( $.uls.data.regiongroups[region] === groupNum ) {
|
if ( $.uls.data.regiongroups[region] === groupNum ) {
|
||||||
regionsInGroup.push( region );
|
regionsInGroup.push( region );
|
||||||
}
|
}
|
||||||
@@ -360,9 +367,11 @@
|
|||||||
* @return string script group name
|
* @return string script group name
|
||||||
*/
|
*/
|
||||||
$.uls.data.getGroupOfScript = function ( script ) {
|
$.uls.data.getGroupOfScript = function ( script ) {
|
||||||
for ( var group in $.uls.data.scriptgroups ) {
|
var scriptGroup;
|
||||||
if ( $.inArray( script, $.uls.data.scriptgroups[group] ) !== -1 ) {
|
|
||||||
return group;
|
for ( scriptGroup in $.uls.data.scriptgroups ) {
|
||||||
|
if ( $.inArray( script, $.uls.data.scriptgroups[scriptGroup] ) !== -1 ) {
|
||||||
|
return scriptGroup;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -12,6 +12,7 @@
|
|||||||
* header is left intact. See files GPL-LICENSE and MIT-LICENSE for details.
|
* header is left intact. See files GPL-LICENSE and MIT-LICENSE for details.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
( function ( $ ) {
|
( function ( $ ) {
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
@@ -22,10 +23,12 @@
|
|||||||
* they belong to the 'Other' group.
|
* they belong to the 'Other' group.
|
||||||
*/
|
*/
|
||||||
var orphanScripts = function () {
|
var orphanScripts = function () {
|
||||||
var result = [];
|
var language, script,
|
||||||
|
result = [];
|
||||||
|
|
||||||
|
for ( language in $.uls.data.languages ) {
|
||||||
|
script = $.uls.data.getScript( language );
|
||||||
|
|
||||||
for ( var language in $.uls.data.languages ) {
|
|
||||||
var script = $.uls.data.getScript( language );
|
|
||||||
if ( $.uls.data.getGroupOfScript( script ) === 'Other' ) {
|
if ( $.uls.data.getGroupOfScript( script ) === 'Other' ) {
|
||||||
result.push( script );
|
result.push( script );
|
||||||
}
|
}
|
||||||
@@ -38,10 +41,11 @@
|
|||||||
* Runs over all languages and checks that all redirects have a valid target.
|
* Runs over all languages and checks that all redirects have a valid target.
|
||||||
*/
|
*/
|
||||||
var badRedirects = function () {
|
var badRedirects = function () {
|
||||||
var result = [];
|
var language, target,
|
||||||
|
result = [];
|
||||||
|
|
||||||
for ( var language in $.uls.data.languages ) {
|
for ( language in $.uls.data.languages ) {
|
||||||
var target = $.uls.data.isRedirect( language );
|
target = $.uls.data.isRedirect( language );
|
||||||
|
|
||||||
if ( target && !$.uls.data.languages[target] ) {
|
if ( target && !$.uls.data.languages[target] ) {
|
||||||
result.push( language );
|
result.push( language );
|
||||||
@@ -56,10 +60,11 @@
|
|||||||
* There's no reason to have double redirects.
|
* There's no reason to have double redirects.
|
||||||
*/
|
*/
|
||||||
var doubleRedirects = function () {
|
var doubleRedirects = function () {
|
||||||
var result = [];
|
var language, target,
|
||||||
|
result = [];
|
||||||
|
|
||||||
for ( var language in $.uls.data.languages ) {
|
for ( language in $.uls.data.languages ) {
|
||||||
var target = $.uls.data.isRedirect( language );
|
target = $.uls.data.isRedirect( language );
|
||||||
|
|
||||||
if ( target && $.uls.data.isRedirect( target ) ) {
|
if ( target && $.uls.data.isRedirect( target ) ) {
|
||||||
result.push( language );
|
result.push( language );
|
||||||
@@ -74,9 +79,10 @@
|
|||||||
* they have something that looks like an autonym.
|
* they have something that looks like an autonym.
|
||||||
*/
|
*/
|
||||||
var languagesWithoutAutonym = function () {
|
var languagesWithoutAutonym = function () {
|
||||||
var result = [];
|
var language,
|
||||||
|
result = [];
|
||||||
|
|
||||||
for ( var language in $.uls.data.languages ) {
|
for ( language in $.uls.data.languages ) {
|
||||||
if ( typeof $.uls.data.getAutonym( language ) !== 'string' ) {
|
if ( typeof $.uls.data.getAutonym( language ) !== 'string' ) {
|
||||||
result.push( language );
|
result.push( language );
|
||||||
}
|
}
|
||||||
@@ -85,11 +91,19 @@
|
|||||||
return result;
|
return result;
|
||||||
};
|
};
|
||||||
|
|
||||||
test( "-- Initial check", 1, function ( assert ) {
|
test( '-- Initial check', 1, function ( assert ) {
|
||||||
assert.ok( $.fn.uls, "$.fn.uls is defined" );
|
assert.ok( $.fn.uls, '$.fn.uls is defined' );
|
||||||
} );
|
} );
|
||||||
|
|
||||||
test( "-- $.uls.data testing", 46, function ( assert ) {
|
test( '-- $.uls.data testing', 46, function ( assert ) {
|
||||||
|
var autonyms,
|
||||||
|
allLanguagesByRegionAndScript,
|
||||||
|
languagesInEU,
|
||||||
|
languagesByScriptInAM, languagesByScriptInEU,
|
||||||
|
languagesToGroup, groupedLanguages,
|
||||||
|
languagesByScriptGroupInEMEA,
|
||||||
|
allLanguagesByScriptGroup;
|
||||||
|
|
||||||
// Add a language in run time.
|
// Add a language in run time.
|
||||||
// This is done early to make sure that it doesn't break other functions.
|
// This is done early to make sure that it doesn't break other functions.
|
||||||
$.uls.data.addLanguage( 'qqq', {
|
$.uls.data.addLanguage( 'qqq', {
|
||||||
@@ -100,11 +114,11 @@
|
|||||||
|
|
||||||
assert.ok( $.uls.data.getAutonym( 'qqq' ), 'Language documentation', 'Language qqq was added with the correct autonym' );
|
assert.ok( $.uls.data.getAutonym( 'qqq' ), 'Language documentation', 'Language qqq was added with the correct autonym' );
|
||||||
|
|
||||||
assert.strictEqual( $.uls.data.isRedirect( 'sr-ec' ), 'sr-cyrl', "'sr-ec' is a redirect to 'sr-cyrl'" );
|
assert.strictEqual( $.uls.data.isRedirect( 'sr-ec' ), 'sr-cyrl', '"sr-ec" is a redirect to "sr-cyrl"' );
|
||||||
var autonyms = $.uls.data.getAutonyms();
|
autonyms = $.uls.data.getAutonyms();
|
||||||
assert.strictEqual( autonyms['zu'], 'isiZulu', 'Correct autonym is returned for Zulu using getAutonyms().' );
|
assert.strictEqual( autonyms['zu'], 'isiZulu', 'Correct autonym is returned for Zulu using getAutonyms().' );
|
||||||
assert.strictEqual( autonyms['pa'], undefined, "Language 'pa' is not listed in autonyms, because it's a redirect" );
|
assert.strictEqual( autonyms['pa'], undefined, 'Language "pa" is not listed in autonyms, because it is a redirect' );
|
||||||
assert.strictEqual( autonyms['pa-guru'], 'ਪੰਜਾਬੀ', "Language 'pa-guru' has the correct autonym" );
|
assert.strictEqual( autonyms['pa-guru'], 'ਪੰਜਾਬੀ', 'Language "pa-guru" has the correct autonym' );
|
||||||
|
|
||||||
// This test assumes that we don't want any scripts to be in the 'Other'
|
// This test assumes that we don't want any scripts to be in the 'Other'
|
||||||
// group. Actually, this may become wrong some day.
|
// group. Actually, this may become wrong some day.
|
||||||
@@ -129,9 +143,9 @@
|
|||||||
assert.deepEqual( $.uls.data.getRegions( 'lzz' ), [
|
assert.deepEqual( $.uls.data.getRegions( 'lzz' ), [
|
||||||
'EU', 'ME'
|
'EU', 'ME'
|
||||||
], 'Correct regions of the Laz language were selected' );
|
], 'Correct regions of the Laz language were selected' );
|
||||||
assert.strictEqual( $.uls.data.getRegions( 'no-such-language' ), 'UNKNOWN', "The region of an invalid language is 'UNKNOWN'" );
|
assert.strictEqual( $.uls.data.getRegions( 'no-such-language' ), 'UNKNOWN', 'The region of an invalid language is "UNKNOWN"' );
|
||||||
|
|
||||||
var allLanguagesByRegionAndScript = $.uls.data.getAllLanguagesByRegionAndScript();
|
allLanguagesByRegionAndScript = $.uls.data.getAllLanguagesByRegionAndScript();
|
||||||
assert.deepEqual( allLanguagesByRegionAndScript['4']['AS']['SouthEastAsian']['Bugi'], [
|
assert.deepEqual( allLanguagesByRegionAndScript['4']['AS']['SouthEastAsian']['Bugi'], [
|
||||||
'bug'
|
'bug'
|
||||||
], 'All languages in the Buginese script in Asia were selected' );
|
], 'All languages in the Buginese script in Asia were selected' );
|
||||||
@@ -139,39 +153,39 @@
|
|||||||
'pa-guru'
|
'pa-guru'
|
||||||
], 'Only language pa-guru appears as a language in script Guru in SouthAsian languages in Asia' );
|
], 'Only language pa-guru appears as a language in script Guru in SouthAsian languages in Asia' );
|
||||||
|
|
||||||
var languagesInEU = $.uls.data.getLanguagesInRegion( 'EU' );
|
languagesInEU = $.uls.data.getLanguagesInRegion( 'EU' );
|
||||||
assert.strictEqual( $.inArray( 'sr-ec', languagesInEU ), -1, "Language 'sr-ec' doesn't appear in languages of region EU, because it's a redirect" );
|
assert.strictEqual( $.inArray( 'sr-ec', languagesInEU ), -1, 'Language "sr-ec" does not appear in languages of region EU, because it is a redirect' );
|
||||||
assert.ok( $.inArray( 'sr-cyrl', languagesInEU ) > -1, "Language 'sr-cyrl' appears in languages of region EU, because it's not a redirect" );
|
assert.ok( $.inArray( 'sr-cyrl', languagesInEU ) > -1, 'Language "sr-cyrl" appears in languages of region EU, because it is not a redirect' );
|
||||||
|
|
||||||
assert.deepEqual( $.uls.data.getLanguagesInRegion( "PA" ),
|
assert.deepEqual( $.uls.data.getLanguagesInRegion( 'PA' ),
|
||||||
[
|
[
|
||||||
"ace", "bi", "ch", "en-gb", "en", "fj", "haw", "hif", "ho", "jv", "jv-java",
|
'ace', 'bi', 'ch', 'en-gb', 'en', 'fj', 'haw', 'hif', 'ho', 'jv', 'jv-java',
|
||||||
"mh", "mi", "na", "niu", "pih", "pis", "pt", "rtm", "sm", "tet",
|
'mh', 'mi', 'na', 'niu', 'pih', 'pis', 'pt', 'rtm', 'sm', 'tet',
|
||||||
"to", "tpi", "ty", "wls"
|
'to', 'tpi', 'ty', 'wls'
|
||||||
],
|
],
|
||||||
"languages of region PA are selected correctly" );
|
'languages of region PA are selected correctly' );
|
||||||
assert.deepEqual( $.uls.data.getLanguagesInRegions( ["AM", "WW"] ),
|
assert.deepEqual( $.uls.data.getLanguagesInRegions( ['AM', 'WW'] ),
|
||||||
[
|
[
|
||||||
"akz", "arn", "aro", "ase", "avk", "ay", "cho", "chr", "chy", "cr", "cr-latn",
|
'akz', 'arn', 'aro', 'ase', 'avk', 'ay', 'cho', 'chr', 'chy', 'cr', 'cr-latn',
|
||||||
"en-ca", "en", "eo", "es-419", "es-formal", "es", "esu", "fr", "frc", "gcf", "gn",
|
'en-ca', 'en', 'eo', 'es-419', 'es-formal', 'es', 'esu', 'fr', 'frc', 'gcf', 'gn',
|
||||||
"guc", "haw", "ht", "ia", "ie", "ik", "ike-cans", "ike-latn", "io", "iu", "jam",
|
'guc', 'haw', 'ht', 'ia', 'ie', 'ik', 'ike-cans', 'ike-latn', 'io', 'iu', 'jam',
|
||||||
"jbo", "kgp", "kl", "lad-latn", "lad-hebr", "lfn", "mfe", "mic", "mus", "nah", "nl-informal", "nl",
|
'jbo', 'kgp', 'kl', 'lad-latn', 'lad-hebr', 'lfn', 'mfe', 'mic', 'mus', 'nah', 'nl-informal', 'nl',
|
||||||
"nov", "nv", "pap", "pdc", "pdt", "ppl", "pt-br", "pt", "qu", "qug", "rap", "sei",
|
'nov', 'nv', 'pap', 'pdc', 'pdt', 'ppl', 'pt-br', 'pt', 'qu', 'qug', 'rap', 'sei',
|
||||||
"simple", "srn", "tokipona", "vo", "yi", "yrl", "yua"
|
'simple', 'srn', 'tokipona', 'vo', 'yi', 'yrl', 'yua'
|
||||||
],
|
],
|
||||||
"languages of regions AM and WW are selected correctly"
|
'languages of regions AM and WW are selected correctly'
|
||||||
);
|
);
|
||||||
|
|
||||||
assert.deepEqual( $.uls.data.getLanguagesInScript( 'Knda' ), [
|
assert.deepEqual( $.uls.data.getLanguagesInScript( 'Knda' ), [
|
||||||
"kn", "tcy"
|
'kn', 'tcy'
|
||||||
], "languages in script Knda are selected correctly" );
|
], 'languages in script Knda are selected correctly' );
|
||||||
assert.deepEqual( $.uls.data.getLanguagesInScript( 'Guru' ),
|
assert.deepEqual( $.uls.data.getLanguagesInScript( 'Guru' ),
|
||||||
["pa-guru"],
|
['pa-guru'],
|
||||||
"'pa-guru' is written in script Guru, and 'pa' is skipped as a redirect"
|
'"pa-guru" is written in script Guru, and "pa" is skipped as a redirect'
|
||||||
);
|
);
|
||||||
assert.deepEqual( $.uls.data.getLanguagesInScripts( ['Geor', 'Armn'] ),
|
assert.deepEqual( $.uls.data.getLanguagesInScripts( ['Geor', 'Armn'] ),
|
||||||
["hy", "ka", "xmf"],
|
['hy', 'ka', 'xmf'],
|
||||||
"languages in scripts Geor and Armn are selected correctly"
|
'languages in scripts Geor and Armn are selected correctly'
|
||||||
);
|
);
|
||||||
|
|
||||||
assert.deepEqual( $.uls.data.getRegionsInGroup( 3 ), [
|
assert.deepEqual( $.uls.data.getRegionsInGroup( 3 ), [
|
||||||
@@ -184,48 +198,48 @@
|
|||||||
'WW', 'SP'
|
'WW', 'SP'
|
||||||
], 'regions in group 1 are selected correctly' );
|
], 'regions in group 1 are selected correctly' );
|
||||||
|
|
||||||
var languagesByScriptInAM = $.uls.data.getLanguagesByScriptInRegion( "AM" );
|
languagesByScriptInAM = $.uls.data.getLanguagesByScriptInRegion( 'AM' );
|
||||||
assert.deepEqual( languagesByScriptInAM['Cans'], [
|
assert.deepEqual( languagesByScriptInAM['Cans'], [
|
||||||
"cr", "ike-cans", "iu"
|
'cr', 'ike-cans', 'iu'
|
||||||
], "correct languages in Cans in AM selected" );
|
], 'correct languages in Cans in AM selected' );
|
||||||
|
|
||||||
var languagesByScriptInEU = $.uls.data.getLanguagesByScriptInRegion( "EU" );
|
languagesByScriptInEU = $.uls.data.getLanguagesByScriptInRegion( 'EU' );
|
||||||
assert.strictEqual( $.inArray( 'sr-el', languagesByScriptInEU['Latn'] ), -1,
|
assert.strictEqual( $.inArray( 'sr-el', languagesByScriptInEU['Latn'] ), -1,
|
||||||
"Language 'sr-el' doesn't appear as a Latin-script language in EU, because it's a redirect" );
|
'Language "sr-el" does not appear as a Latin-script language in EU, because it is a redirect' );
|
||||||
assert.ok( $.inArray( 'sr-latn', languagesByScriptInEU['Latn'] ) > -1,
|
assert.ok( $.inArray( 'sr-latn', languagesByScriptInEU['Latn'] ) > -1,
|
||||||
"Language 'sr-latn' appears as a Latin-script language in EU, because it's not a redirect" );
|
'Language "sr-latn" appears as a Latin-script language in EU, because it is not a redirect' );
|
||||||
|
|
||||||
assert.strictEqual( $.uls.data.getAutonym( 'pa' ), 'ਪੰਜਾਬੀ', 'Correct autonym of the Punjabi language was selected using code pa.' );
|
assert.strictEqual( $.uls.data.getAutonym( 'pa' ), 'ਪੰਜਾਬੀ', 'Correct autonym of the Punjabi language was selected using code pa.' );
|
||||||
assert.strictEqual( $.uls.data.getAutonym( 'pa-guru' ), 'ਪੰਜਾਬੀ', 'Correct autonym of the Punjabi language was selected using code pa-guru.' );
|
assert.strictEqual( $.uls.data.getAutonym( 'pa-guru' ), 'ਪੰਜਾਬੀ', 'Correct autonym of the Punjabi language was selected using code pa-guru.' );
|
||||||
|
|
||||||
var languagesToGroup = {
|
languagesToGroup = {
|
||||||
'en': 'English',
|
'en': 'English',
|
||||||
'fiu-vro': 'Võro', // Alias before target
|
'fiu-vro': 'Võro', // Alias before target
|
||||||
'ru': 'русский',
|
'ru': 'русский',
|
||||||
'sr': 'српски', // Alias before target
|
'sr': 'српски', // Alias before target
|
||||||
'sr-cyrl': 'српски', // Target before alias
|
'sr-cyrl': 'српски', // Target before alias
|
||||||
'sr-latn': 'srpski', // Target before alias
|
'sr-latn': 'srpski', // Target before alias
|
||||||
'sr-el': 'srpski', // Alias after target
|
'sr-el': 'srpski', // Alias after target
|
||||||
'vro': 'Võro' // Target after alias
|
'vro': 'Võro' // Target after alias
|
||||||
},
|
};
|
||||||
groupedLanguages = {
|
groupedLanguages = {
|
||||||
Latin: [ 'en', 'vro', 'sr-latn' ],
|
Latin: [ 'en', 'vro', 'sr-latn' ],
|
||||||
Cyrillic: [ 'ru', 'sr-cyrl' ]
|
Cyrillic: [ 'ru', 'sr-cyrl' ]
|
||||||
};
|
};
|
||||||
|
|
||||||
assert.deepEqual( $.uls.data.getLanguagesByScriptGroup( languagesToGroup ), groupedLanguages,
|
assert.deepEqual( $.uls.data.getLanguagesByScriptGroup( languagesToGroup ), groupedLanguages,
|
||||||
'A custom list of languages is grouped correctly using getLanguagesByScriptGroup.' );
|
'A custom list of languages is grouped correctly using getLanguagesByScriptGroup.' );
|
||||||
|
|
||||||
var languagesByScriptGroupInEMEA = $.uls.data.getLanguagesByScriptGroupInRegions( $.uls.data.getRegionsInGroup( 3 ) );
|
languagesByScriptGroupInEMEA = $.uls.data.getLanguagesByScriptGroupInRegions( $.uls.data.getRegionsInGroup( 3 ) );
|
||||||
assert.deepEqual( languagesByScriptGroupInEMEA['WestCaucasian'], [
|
assert.deepEqual( languagesByScriptGroupInEMEA['WestCaucasian'], [
|
||||||
'hy', 'ka', 'xmf'
|
'hy', 'ka', 'xmf'
|
||||||
], 'Correct languages in WestCaucasian script group in EMEA selected' );
|
], 'Correct languages in WestCaucasian script group in EMEA selected' );
|
||||||
assert.strictEqual( $.inArray( 'sr-ec', languagesByScriptGroupInEMEA['Cyrillic'] ), -1,
|
assert.strictEqual( $.inArray( 'sr-ec', languagesByScriptGroupInEMEA['Cyrillic'] ), -1,
|
||||||
"Language 'sr-ec' doesn't appear as a Cyrillic-scriptgroup language in EMEA, because it's a redirect" );
|
'Language "sr-ec" does not appear as a Cyrillic-scriptgroup language in EMEA, because it is a redirect' );
|
||||||
assert.ok( $.inArray( 'sr-cyrl', languagesByScriptGroupInEMEA['Cyrillic'] ) > -1,
|
assert.ok( $.inArray( 'sr-cyrl', languagesByScriptGroupInEMEA['Cyrillic'] ) > -1,
|
||||||
"Language 'sr-cyrl' appears as a Cyrillic-scriptgroup language in EMEA, because it's not a redirect" );
|
'Language "sr-cyrl" appears as a Cyrillic-scriptgroup language in EMEA, because it is not a redirect' );
|
||||||
|
|
||||||
var allLanguagesByScriptGroup = $.uls.data.getAllLanguagesByScriptGroup();
|
allLanguagesByScriptGroup = $.uls.data.getAllLanguagesByScriptGroup();
|
||||||
assert.deepEqual( allLanguagesByScriptGroup['Greek'], [
|
assert.deepEqual( allLanguagesByScriptGroup['Greek'], [
|
||||||
'el', 'grc', 'pnt', 'ruq-grek', 'tsd'
|
'el', 'grc', 'pnt', 'ruq-grek', 'tsd'
|
||||||
], 'All languages in the Greek script found' );
|
], 'All languages in the Greek script found' );
|
||||||
@@ -239,13 +253,15 @@
|
|||||||
'gn', 'de', 'hu', 'fi'
|
'gn', 'de', 'hu', 'fi'
|
||||||
], 'Languages are correctly sorted by autonym' );
|
], 'Languages are correctly sorted by autonym' );
|
||||||
|
|
||||||
assert.strictEqual( $.uls.data.isRtl( "te" ), false, "Telugu language is not RTL" );
|
assert.strictEqual( $.uls.data.isRtl( 'te' ), false, 'Telugu language is not RTL' );
|
||||||
assert.strictEqual( $.uls.data.isRtl( "dv" ), true, "Divehi language is RTL" );
|
assert.strictEqual( $.uls.data.isRtl( 'dv' ), true, 'Divehi language is RTL' );
|
||||||
assert.strictEqual( $.uls.data.getDir( "mzn" ), "rtl", "Mazandarani language is RTL" );
|
assert.strictEqual( $.uls.data.getDir( 'mzn' ), 'rtl', 'Mazandarani language is RTL' );
|
||||||
assert.strictEqual( $.uls.data.getDir( "uk" ), "ltr", "Ukrainian language is LTR" );
|
assert.strictEqual( $.uls.data.getDir( 'uk' ), 'ltr', 'Ukrainian language is LTR' );
|
||||||
|
|
||||||
assert.ok( $.inArray( "sah", $.uls.data.getLanguagesInTerritory( "RU" ) )
|
assert.ok(
|
||||||
> -1, "Sakha language is spoken in Russia" );
|
$.inArray( 'sah', $.uls.data.getLanguagesInTerritory( 'RU' ) ) > -1,
|
||||||
|
'Sakha language is spoken in Russia'
|
||||||
|
);
|
||||||
|
|
||||||
assert.ok( $.uls.data.deleteLanguage( 'qqq' ), 'Deleting language qqq, which was added earlier, returns true.' );
|
assert.ok( $.uls.data.deleteLanguage( 'qqq' ), 'Deleting language qqq, which was added earlier, returns true.' );
|
||||||
assert.strictEqual( $.uls.data.languages['qqq'], undefined, 'Data about qqq is undefined after being deleted.' );
|
assert.strictEqual( $.uls.data.languages['qqq'], undefined, 'Data about qqq is undefined after being deleted.' );
|
||||||
|
|||||||
Reference in New Issue
Block a user