cldr
Version:
Library for extracting data from CLDR (the Unicode Common Locale Data Repository)
922 lines (740 loc) • 25.3 kB
Markdown
# cldr
A module that allows you to extract a bunch of locale-specific
information from the <a href="http://cldr.unicode.org/">Unicode
CLDR</a> (Common Localization Data Repository), including:
- Date, time, and date-time formats
- Date interval formats
- Number formats, symbols, and digits for all number systems
- Exemplar and ellipsis characters
- Day names, month names, quarter names, era names, and cyclic names
- Patterns for rendering lists of items (see the [this-and-that](https://github.com/papandreou/this-and-that) module for an easy-to-consume version)
- Display names for languages, time zones, territories, scripts and currencies
- Plural rule functions (converted to JavaScript functions)
- Rule-based number formatting functions (converted to JavaScript functions)
The extraction code was originally written for the <a
href="https://github.com/papandreou/inter">inter i18n library</a>, but can be
used on its own.
To understand the data itself, you might need to dive into the <a
href="https://www.unicode.org/reports/tr35/tr35-61/tr35.html">LDML
specification</a>, which describes the schema of the CLDR XML files.
Comes bundled with the CLDR 45 release and isn't attempting to be backwards
compatible with earlier versions.
# Releases
See the [changelog](CHANGELOG.md).
# Usage
Make sure you have <a href="http://nodejs.org/">node.js</a> and <a
href="http://npmjs.org/">npm</a> installed, then run:
```
$ npm install cldr
```
Now you're ready to create a node-cldr instance and take it for a
spin:
```javascript
var cldr = require('cldr');
console.log(cldr.extractTerritoryDisplayNames('fr'));
```
Output:
```
{ '142': 'Asie',
'143': 'Asie centrale',
'145': 'Asie occidentale',
'150': 'Europe',
[...]
YT: 'Mayotte',
ZA: 'Afrique du Sud',
ZM: 'Zambie',
ZW: 'Zimbabwe',
ZZ: 'région indéterminée' }
```
Advanced users can also provide the path to another CLDR installation
like this:
```javascript
var cldr = require('cldr').load('/path/to/cldr');
```
# Properties
### cldr.localeIds
An array of locale ids for which data is available (656 in CLDR
release 22.1). The locale ids are "normalized" to be all lower case
with underscores separating the fragments. However, all methods that
take a locale id as a parameter will accept any casing and both `-`
and `_` as separators.
### cldr.calendarIds
An array of calendar ids for which data is available. In CLDR release
22.1:
```javascript
[
'buddhist',
'chinese',
'coptic',
'dangi',
'ethioaa',
'ethiopic',
'gregorian',
'hebrew',
'indian',
'islamic',
'islamicc',
'iso8601',
'japanese',
'persian',
'roc',
];
```
### cldr.numberSystemIds
An array of number system ids for which data is available. In CLDR
release 22.1:
```javascript
[
'arab',
'arabext',
'armn',
'armnlow',
'bali',
'beng',
'brah',
'cakm',
'cham',
'deva',
'ethi',
'finance',
'fullwide',
'geor',
'grek',
'greklow',
'gujr',
'guru',
'hanidec',
'hans',
'hansfin',
'hant',
'hantfin',
'hebr',
'java',
'jpan',
'jpanfin',
'kali',
'khmr',
'knda',
'lana',
'lanatham',
'laoo',
'latn',
'lepc',
'limb',
'mlym',
'mong',
'mtei',
'mymr',
'mymrshan',
'native',
'nkoo',
'olck',
'orya',
'osma',
'roman',
'romanlow',
'saur',
'shrd',
'sora',
'sund',
'takr',
'talu',
'taml',
'tamldec',
'telu',
'thai',
'tibt',
'traditio',
'vaii',
];
```
# Methods
All the data extraction methods are synchronous, which means that XML
documents that haven't already been loaded will be loaded using
`fs.readFileSync`. The reasoning behind this is that the API would be
awkward if all the extraction methods had to take callbacks. Also,
`node-cldr` is unlikely to be used in a setting where performance is
critical. However, if for some reason you want to avoid the
synchronous loads, you can use `cldr.load(<arrayOfLocaleIds>, cb)` to
load all the needed data in parallel before starting the extraction
itself. Then all the needed documents will be loaded and ready.
### cldr.extractLocaleDisplayPattern(localeId='root')
Extract a locale display pattern hash for a locale:
```javascript
cldr.extractLocaleDisplayPattern('en_GB');
{ localePattern: '{0} ({1})',
localeSeparator: '{0}, {1}',
localeKeyTypePattern: '{0}: {1}' }
```
### cldr.extractLanguageDisplayNames(localeId='root')
Extract a locale ID => display name hash for a locale:
```javascript
cldr.extractLanguageDisplayNames('it').en;
('inglese');
```
### cldr.extractSubdivisionAliases()
Subdivision aliases contain deprecated or alternative subdivision codes. Note that the returned code may be either a territory code, (such as 'cn71' => 'TW'), or a subdivision code.
```javascript
cldr.extractSubdivisionAliases().czol;
({ replacement: 'cz71', reason: 'deprecated' });
```
### cldr.extractSubdivisionDisplayNames(localeId)
Extract a subnational territory ID => display name hash for a locale.
Codes follow the BCP47 standard, e.g. `usca` for California, USA.
Note that these codes are similar but not identical to ISO 3166-2 codes. Unlike ISO 3166-2, CLDR never reuses a code.
For global regions and countries, see [extractTerritoryDisplayNames](#cldrextractterritorydisplaynameslocaleidroot)
```javascript
cldr.extractSubdivisionDisplayNames('en').dk85;
('Zealand');
```
### cldr.extractTimeZoneDisplayNames(localeId='root')
Extract a time zone ID (Olson) => display name hash for a locale:
```javascript
cldr.extractTimeZoneDisplayNames('it')['Europe/Gibraltar'];
('Gibilterra');
```
### cldr.extractTimeZoneFormats(localeId='root')
Extract a hash with ICU formats for displaying information about a
time zone in a locale:
```javascript
cldr.extractTimeZoneFormats('da');
{ hour: [ '+HH.mm', '-HH.mm' ],
gmt: 'GMT{0}',
gmtZero: 'GMT',
region: 'Tidszone for {0}',
fallback: '{1} ({0})',
regions: { daylight: '{0} (+1)', standard: '{0} (+0)' } }
```
### cldr.extractTerritoryAliases()
Territory aliases contain deprecated or alternative territory codes.
```javascript
cldr.extractTerritoryAliases().BU;
({ replacement: 'MM', reason: 'deprecated' });
```
### cldr.extractTerritoryDisplayNames(localeId)
Extract a territory ID => display name hash for a locale.
This method will return global regions and countries. For subnational
divisions, see [extractSubdivisionDisplayNames](#cldrextractsubdivisiondisplaynameslocaleidroot).
```javascript
cldr.extractTerritoryDisplayNames('fr').US;
('États-Unis');
```
### extractTerritoryContainmentGroups()
Get a flattened tree structure with information about which territories are
contained in other territories. The territories are given by their id, so the
result is locale-independent. Consult `extractTerritoryDisplayNames` for the
translated display names.
```javascript
cldr.extractTerritoryContainmentGroups()
{ '142':
{ type: '142',
contains: [ '145', '143', '030', '034', '035' ],
parent: '001' },
'143':
{ type: '143',
contains: [ 'TM', 'TJ', 'KG', 'KZ', 'UZ' ],
parent: '142' },
[...]
'009':
{ type: '009',
contains: [ '053', '054', '057', '061', 'QO' ],
parent: '001' },
QO:
{ type: 'QO',
contains: [ 'AQ', 'AC', 'CP', 'DG', 'TA' ],
parent: '009' } }
```
### cldr.extractCurrencyInfoById(localeId='root')
Extract hash with currency ID keys mapping to currency info objects
for a locale:
```javascript
cldr.extractCurrencyInfoById('es').YUN;
{ displayName: 'dinar convertible yugoslavo',
symbol: undefined,
one: 'dinar convertible yugoslavo',
other: 'dinares convertibles yugoslavos' },
```
### cldr.extractScriptDisplayNames(localeId='root')
Extract a script ID => display name hash for a locale:
```javascript
cldr.extractScriptDisplayNames('en_US').Arab;
('Arabic');
```
### cldr.extractVariantDisplayNames(localeId='root')
Extract a variant ID => display name hash for a locale:
```javascript
cldr.extractVariantDisplayNames('fr').VALENCIA;
('valencien');
```
### cldr.extractKeyTypes(localeId='root')
Extract keys and their associated types for a locale.
```javascript
cldr.extractKeyTypes('en').calendar;
{ displayName: 'Calendar',
types:
{ buddhist: 'Buddhist Calendar',
chinese: 'Chinese Calendar',
coptic: 'Coptic Calendar',
dangi: 'Dangi Calendar',
ethiopic: 'Ethiopic Calendar',
ethiopicAmeteAlem: 'Ethiopic Amete Alem Calendar',
gregorian: 'Gregorian Calendar',
hebrew: 'Hebrew Calendar',
indian: 'Indian National Calendar',
islamic: 'Islamic Calendar',
islamicCivil: 'Islamic Calendar (tabular, civil epoch)',
islamicRgsa: 'Islamic Calendar (Saudi Arabia, sighting)',
islamicTbla: 'Islamic Calendar (tabular, astronomical epoch)',
islamicUmalqura: 'Islamic Calendar (Umm al-Qura)',
iso8601: 'ISO-8601 Calendar',
japanese: 'Japanese Calendar',
persian: 'Persian Calendar',
roc: 'Minguo Calendar' } }
```
```javascript
cldr.extractKeyTypes('en').x;
{
displayName: 'Private-Use';
}
```
### cldr.extractTransformNames(localeId='root')
Extract a hash of transform names for a locale.
```javascript
cldr.extractTransformNames('en');
{ BGN: 'BGN',
Numeric: 'Numeric',
Tone: 'Tone',
UNGEGN: 'UNGEGN',
'x-Accents': 'Accents',
'x-Fullwidth': 'Fullwidth',
'x-Halfwidth': 'Halfwidth',
'x-Jamo': 'Jamo',
'x-Pinyin': 'Pinyin',
'x-Publishing': 'Publishing' }
```
### cldr.extractMeasurementSystemNames(localeId='root')
Extract a hash of measurement system names for a locale.
```javascript
cldr.extractMeasurementSystemNames('en');
{ metric: 'Metric', UK: 'UK', US: 'US' }
```
### cldr.extractCodePatterns(localeId='root')
Extract a hash of code patterns for a locale.
```javascript
> cldr.extractCodePatterns('en');
{ language: 'Language: {0}',
script: 'Script: {0}',
territory: 'Region: {0}' }
```
### cldr.extractEraNames(localeId='root', calendarId='gregorian')
Extract a nested hash with era names in `wide` and `abbreviated`
formats for a calendar and locale:
```javascript
cldr.extractEraNames('es', 'gregorian');
{ wide:
{ '0': 'antes de Cristo',
'1': 'anno Dómini' },
abbreviated:
{ '0': 'a.C.',
'1': 'd.C.' } }
```
### cldr.extractQuarterNames(localeId='root', calendarId='gregorian')
Extract a nested hash with quarter names in various formats for a calendar and locale:
```javascript
cldr.extractQuarterNames('es', 'gregorian');
{ format:
{ abbreviated: { '0': 'T1', '1': 'T2', '2': 'T3', '3': 'T4' },
narrow: { '0': '1T', '1': '2T', '2': '3T', '3': '4T' },
wide: { '0': '1er trimestre', '1': '2º trimestre', '2': '3er trimestre', '3': '4º trimestre' } },
standAlone:
{ abbreviated: { '0': 'Q1', '1': 'Q2', '2': 'Q3', '3': 'Q4' },
narrow: { '0': '1T', '1': '2T', '2': '3T', '3': '4T' },
wide: { '0': '1.er trimestre', '1': '2.º trimestre', '2': '3.er trimestre', '3': '4.º trimestre' } } }
```
### cldr.extractDayPeriods(localeId='root', calendarId='gregorian')
Extract a nested hash with day periods in various formats for a
calendar and locale:
```javascript
cldr.extractDayPeriods('en_GB', 'gregorian');
{ format:
{ abbreviated: { am: 'AM', pm: 'PM' },
narrow: { am: 'a', noon: 'n', pm: 'p' },
wide: { am: 'am', pm: 'pm', noon: 'noon' } },
standAlone:
{ abbreviated: { am: 'AM', pm: 'PM' },
narrow: { am: 'AM', pm: 'PM' },
wide: { am: 'AM', pm: 'PM' } } }
```
### cldr.extractCyclicNames(localeId='root', calendarId='gregorian')
Extract a nested hash with cyclic names for a calendar and locale
(only the `chinese` calendar contains these):
```javascript
cldr.extractCyclicNames('en_US', 'chinese').zodiacs.format.abbreviated;
{ '1': 'Rat', '2': 'Ox', '3': 'Tiger', '4': 'Rabbit', '5': 'Dragon', '6': 'Snake', '7': 'Horse', '8': 'Goat', '9': 'Monkey', '10': 'Rooster', '11': 'Dog', '12': 'Pig' }
```
### cldr.extractMonthNames(localeId='root', calendarId='gregorian')
Extract a nested hash with month names (in various contexts) for a
calendar and locale:
```javascript
cldr.extractMonthNames('nl', 'gregorian').format.wide;
{ '0': 'januari', '1': 'februari', '2': 'maart', '3': 'april', '4': 'mei', '5': 'juni', '6': 'juli',
'7': 'augustus', '8': 'september', '9': 'oktober', '10': 'november', '11': 'december' }
```
### cldr.extractMonthPatterns(localeId='root', calendarId='gregorian')
Extract a nested hash with month patterns (in various contexts) for a
calendar and locale:
```javascript
cldr.extractMonthPatterns('nl', 'chinese');
{ format:
{ abbreviated: { leap: '{0}bis' },
narrow: { leap: '{0}b' },
wide: { leap: '{0}bis' } },
numeric: { all: { leap: '{0}bis' } },
standAlone:
{ abbreviated: { leap: '{0}bis' },
narrow: { leap: '{0}b' },
wide: { leap: '{0}bis' } } }
```
### cldr.extractDayNames(localeId='root', calendarId='gregorian')
Extract a nested hash with day names (in various contexts) for a
calendar and locale:
```javascript
cldr.extractDayNames('en', 'gregorian').format.abbreviated;
{ '0': 'Sun',
'1': 'Mon',
'2': 'Tue',
'3': 'Wed',
'4': 'Thu',
'5': 'Fri',
'6': 'Sat' }
```
### cldr.extractFields(localeId='root')
Extract a nested hash with display names (including relative) for
various fields for a locale:
```javascript
cldr.extractFields('en').month;
{ displayName: 'Month',
relative:
{ '0': 'this month',
'1': 'next month',
'-1': 'last month' },
relativeTime:
{ future:
{ one: 'in {0} month',
other: 'in {0} months' },
past:
{ one: '{0} month ago',
other: '{0} months ago' } } }
```
### cldr.extractDateTimePatterns(localeId='root', calendarId='gregorian')
Extract a hash with ICU patterns that show how to build a date-time
pattern out of a date pattern and a time pattern in various contexts
for a calendar and locale:
```javascript
cldr.extractDateTimePatterns('en', 'gregorian');
{ full: '{1} \'at\' {0}',
long: '{1} \'at\' {0}',
medium: '{1}, {0}',
short: '{1}, {0}' }
```
### cldr.extractDateFormats(localeId='root', calendarId='gregorian')
Extract a hash of basic date formats (ICU) for a calendar and locale:
```javascript
cldr.extractDateFormats('en_GB', 'gregorian');
{ full: 'EEEE, d MMMM y',
long: 'd MMMM y',
medium: 'd MMM y',
short: 'dd/MM/yyyy' }
```
### cldr.extractTimeFormats(localeId='root', calendarId='gregorian')
Extract a hash of basic time formats (ICU) for a given calendar and
locale:
```javascript
cldr.extractTimeFormats('en_GB', 'gregorian');
{ full: 'HH:mm:ss zzzz',
long: 'HH:mm:ss z',
medium: 'HH:mm:ss',
short: 'HH:mm' }
```
### cldr.extractDateFormatItems(localeId='root', calendarId='gregorian')
Extract a hash of <a
href="http://www.unicode.org/reports/tr35/tr35-29.html#Date_Format_Patterns">ICU
date formats</a> for displaying dates and times at various detail
levels for a calendar and locale:
```javascript
cldr.extractDateFormatItems('en_GB', 'gregorian');
{ d: 'd',
Ed: 'E d',
Ehm: 'E h:mm a',
EHm: 'E HH:mm',
[...]
yQQQ: 'QQQ y',
yyMMM: 'MMM yy',
yyyyMM: 'MM/yyyy',
yyyyMMMM: 'MMMM y' }
```
### cldr.extractDateIntervalFormats(localeId='root', calendarId='gregorian')
Extract a nested hash with date interval display formats (ICU), keyed
by the detail level and the 'greatest difference' field for a calendar
and a locale (tip: Look for "greatest difference" in the <a
href="http://www.unicode.org/reports/tr35/tr35-29.html">LDML
spec</a>):
```javascript
cldr.extractDateIntervalFormats('en_GB', 'gregorian');
{ d: { d: 'd–d' },
h: { a: 'h a – h a', h: 'h–h a' },
H: { H: 'HH–HH' },
hm: { a: 'h:mm a – h:mm a', h: 'h:mm–h:mm a', m: 'h:mm–h:mm a' },
[...]
yMMMEd:
{ d: 'E, d – E, d MMM y',
M: 'E, d MMM – E, d MMM y',
y: 'E, d MMM y – E, d MMM y' },
yMMMM: { M: 'MMMM–MMMM y', y: 'MMMM y – MMMM y' } }
```
### cldr.extractDateIntervalFallbackFormat(localeId='root', calendarId='gregorian')
Extract the date interval fallback format (ICU) for a given calendar
and locale (to be used when the date interval formats don't offer a
specific format):
```javascript
cldr.extractDateIntervalFallbackFormat('en_GB', 'gregorian');
('{0} – {1}');
```
### cldr.extractNumberSymbols(localeId='root', numberSystemId='latn')
Extract the number symbols for a given number system and locale:
```javascript
cldr.extractNumberSymbols('en_GB', 'latn');
{ decimal: '.',
group: ',',
list: ';',
percentSign: '%',
plusSign: '+',
minusSign: '-',
exponential: 'E',
perMille: '‰',
infinity: '∞',
nan: 'NaN' }
```
### cldr.extractNumberFormats(localeId='root', numberSystemId='latn')
Extract the number formats (<a
href="http://www.unicode.org/reports/tr35/tr35-29.html#Number_Format_Patterns">ICU
DecimalFormat</a>) for a given number system and locale:
```javascript
cldr.extractNumberFormats('en_GB', 'latn');
{ scientific: { default: '#E0' },
decimal:
{ long:
{ '1000': { one: '0 thousand', other: '0 thousand' },
'10000': { one: '00 thousand', other: '00 thousand' },
[...]
'100000000000000': { one: '000 trillion', other: '000 trillion' } },
short:
{ '1000': { one: '0k', other: '0K' },
'10000': { one: '00k', other: '00K' },
[...]
'100000000000000': { one: '000tn', other: '000T' } },
default: '#,##0.###' },
currency: { default: '¤#,##0.00', one: '{0} {1}', other: '{0} {1}' },
percent: { default: '#,##0%' } }
```
### cldr.extractDefaultNumberSystemId(localeId='root')
Extract the id of the default number system for a locale:
```javascript
cldr.extractDefaultNumberSystemId('en_GB');
('latn');
cldr.extractDefaultNumberSystemId('ar');
('arab');
```
### cldr.extractUnitPatterns(localeId='root')
Extract the unit patterns (ICU) for a locale (to be used with a plural rule function):
```javascript
cldr.extractUnitPatterns('en_GB').long.unit.massKilogram
{ one: '{0} kilogram',
other: '{0} kilograms' }
```
### cldr.extractDelimiters(localeId='root')
Extract the delimiters for a locale:
```javascript
cldr.extractDelimiters('en_GB');
{ quotationStart: '“',
quotationEnd: '”',
alternateQuotationStart: '‘',
alternateQuotationEnd: '’' }
```
### cldr.extractListPatterns(localeId='root')
Extract the list patterns (ICU) for a locale:
```javascript
Object.keys(cldr.extractListPatterns('en_GB'));
[ 'default',
'unit',
'unitNarrow',
'unitShort' ]
cldr.extractListPatterns('en_GB').default;
{ '2': '{0} and {1}',
end: '{0} and {1}',
middle: '{0}, {1}',
start: '{0}, {1}' }
```
### cldr.extractLayout(localeId='root')
Extract information about the writing direction for a locale:
```javascript
cldr.extractLayout('ar');
{ orientation:
{ characterOrder: 'right-to-left',
lineOrder: 'top-to-bottom' } }
```
### cldr.extractCharacters(localeId='root')
Extract information about various character classes, ellipsis patterns etc. for a locale:
```javascript
cldr.extractCharacters('en_GB');
{ exemplar:
{ default: [ 'a', 'b', 'c', 'd', 'e', [...], 'x', 'y', 'z' ],
auxiliary: [ 'á', 'à', 'ă', 'â', 'å', [...], 'ü', 'ū', 'ÿ' ],
index: [ 'A', 'B', 'C', 'D', 'E', [...], 'X', 'Y', 'Z' ],
punctuation: [ '\\-', '‐', '–', '—', ',', [...], '‡', '′', '″' ] },
ellipsis: { final: '{0}…', initial: '…{0}', medial: '{0}… {1}' },
moreInformation: '?' }
```
### cldr.extractPluralClasses(localeId='root', 'cardinal'|'ordinal')
Extract a list of available plural classes for a locale (See <a
href="http://www.unicode.org/reports/tr35/tr35-29.html#Language_Plural_Rules">the
LDML spec</a> for an explanation):
```javascript
cldr.extractPluralClasses('en_GB', 'cardinal')[('one', 'other')];
cldr.extractPluralRuleFunction('ar', 'cardinal')[
('zero', 'one', 'two', 'few', 'many', 'other')
];
cldr.extractPluralRuleFunction('ar', 'ordinal')['other'];
```
### cldr.extractPluralRuleFunction(localeId='root', 'cardinal'|'ordinal')
Extract a plural rule function for a locale (See <a
href="http://www.unicode.org/reports/tr35/tr35-29.html#Language_Plural_Rules">the
LDML spec</a> for an explanation):
```javascript
cldr.extractPluralRuleFunction('en_GB', 'cardinal').toString();
function (n) {
if (typeof n === "string") n = parseInt(n, 10);
if (n === 1) return "one";
return "other";
}
cldr.extractPluralRuleFunction('en_GB', 'ordinal').toString();
function (n) {
if (typeof n === "string") n = parseInt(n, 10);
if (n % 10 === 1 && !(n % 100 === 11)) return "one";
if (n % 10 === 2 && !(n % 100 === 12)) return "two";
if (n % 10 === 3 && !(n % 100 === 13)) return "few";
return "other";
}
cldr.extractPluralRuleFunction('ar').toString();
function (n) {
if (typeof n === "string") n = parseInt(n, 10);
if (n === 0) return "zero";
if (n === 1) return "one";
if (n === 2) return "two";
if (n % 100 >= 3 && n % 100 <= 10) return "few";
if (n % 100 >= 11 && n % 100 <= 99) return "many";
return "other";
}
```
### cldr.extractRbnfFunctionByType(localeId='root'[, types])
Extracts RBNF (<a
href="http://www.unicode.org/reports/tr35/tr35-29.html#Rule-Based_Number_Formatting">rule-based
number formatting</a>) functions for a locale. The 'types' parameter
specifies the names of the functions you want (defaults to all
available), and the returned hash will contain the ones that were
found plus their dependencies.
The original function names have been converted to camelCase and
prefixed with `render`, and you need to use that naming convention
when specifying the `types` array as well.
```javascript
cldr.extractRbnfFunctionByType('en_GB').renderRomanUpper(2012);
('MMXII');
cldr.extractRbnfFunctionByType('de').renderSpelloutOrdinal(2323);
('zwei tausend drei hundert drei und zwanzigste');
```
Note that some of the generated functions expect to be able to call
`this.renderNumber(<number>, <icuNumberFormat>);`. If there's demand
for it, that can be made customizable, just file an issue.
### cldr.extractNumberingSystem(numberingSystemId)
Extract information about a numbering system. The supported numbering systems
can be retrieved as `cldr.numberingSystemIds`.
Most of the numbering systems will have a type of `numeric` and provide an array
of digits that correspond to 0 through 9:
```javascript
cldr.extractNumberingSystem('bali');
{ type: 'numeric',
digits: [ '᭐', '᭑', '᭒', '᭓', '᭔', '᭕', '᭖', '᭗', '᭘', '᭙' ] }
```
For other more complicated numbering systems, the `type` will be `algorithmic`
and there will be a `rules` property that is a string starting with `render`. In
that case, use the RBNF function (see above) of that name for producing a
number. These RBNF functions are the same in every locale, so you can just pass
`root`:
```javascript
cldr.extractNumberingSystem('cyrl')
{ type: 'algorithmic', rules: 'renderCyrillicLower' }
const rbnfs = cldr.extractRbnfFunctionByType('root', 'renderCyrillicLower')
rbnfs.renderCyrillicLower(1234)
'҂асл҃д'
```
Some of the `algorithmic` numbering systems will additionally refer to a
specific locale:
```javascript
cldr.extractNumberingSystem('jpan');
{ type: 'algorithmic',
rules: 'renderSpelloutCardinal',
locale: 'ja' }
```
In that case you should extract the RBNF rule from that specific locale to
render the numbers:
```javascript
const rbnfs = cldr.extractRbnfFunctionByType('ja', 'renderSpelloutCardinal');
const rbnfs.renderSpelloutCardinal(1234);
'千二百三十四'
```
### cldr.extractDigitsByNumberSystemId()
**Deprecated**: Please use `extractNumberingSystem()` instead.
Extract a hash of number system id => digits array. For some exotic
number systems, 'digits' is a string starting with `render`. In that
case, use the RBNF function (see above) of that name for producing a
number.
```javascript
cldr.extractDigitsByNumberSystemId();
{ arab: [ '٠', '١', '٢', '٣', '٤', '٥', '٦', '٧', '٨', '٩' ],
arabext: [ '۰', '۱', '۲', '۳', '۴', '۵', '۶', '۷', '۸', '۹' ],
armn: 'renderArmenianUpper',
armnlow: 'renderArmenianLower',
[...]
latn: [ '0', '1', '2', '3', '4', '5', '6', '7', '8', '9' ],
orya: [ '୦', '୧', '୨', '୩', '୪', '୫', '୬', '୭', '୮', '୯' ],
[...] }
```
### cldr.extractLanguageSupplementalData()
Extract supplemental data for languages. These data contain a list of
territories where the language is spoken, and scripts that are used
with the language. Both territories and scripts can be either primary
or secondary for the language.
```javascript
{ ar:
{ scripts: [ 'Arab' ], territories: [ 'AE', 'BH', [...] ],
secondary: {
scripts: [ 'Syrc' ], territories: [ 'IR', 'SS' ] }
},
[...] }
```
### cldr.extractWeekData()
Extract supplemental week data, including what day should be considered the first day of the week. The data is grouped by territories and/or locales.
```javascript
{ firstDay:
[
{ day='mon', territories=[ '001', 'AD', [...] ] },
{ day='fri', territories=[ 'MV'] },
{ day='sat', territories=[ 'AE', 'AF', [...] ] },
{ day='sun', territories=[ 'AG', 'AR', [...] ] },
{ day='sun', variant=true, territories=[ 'GB' ] },
],
[...] }
```
## License
node-cldr is licensed under a standard 3-clause BSD license -- see the
`LICENSE`-file for details.