diff options
author | Kevin Deldycke <kevin@deldycke.com> | 2017-04-07 16:09:14 +0200 |
---|---|---|
committer | Kevin Deldycke <kevin@deldycke.com> | 2017-05-17 18:00:10 +0200 |
commit | d97de31509f3394e72a8dfc066cf77aabe2e1122 (patch) | |
tree | ef739144270ee46a869bf979dce6e68962820f66 /scripts | |
parent | 23adb4fac4d8f5a84ecd13cb2cb10727da9e8cf3 (diff) | |
download | babel-d97de31509f3394e72a8dfc066cf77aabe2e1122.tar.gz |
Add currency utilities and helpers.
Diffstat (limited to 'scripts')
-rwxr-xr-x | scripts/import_cldr.py | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/scripts/import_cldr.py b/scripts/import_cldr.py index b804119..7b9e773 100755 --- a/scripts/import_cldr.py +++ b/scripts/import_cldr.py @@ -12,6 +12,7 @@ # individuals. For the exact contribution history, see the revision # history and logs, available at http://babel.edgewall.org/log/. +import collections from optparse import OptionParser import os import re @@ -218,6 +219,7 @@ def parse_global(srcdir, sup): likely_subtags = global_data.setdefault('likely_subtags', {}) territory_currencies = global_data.setdefault('territory_currencies', {}) parent_exceptions = global_data.setdefault('parent_exceptions', {}) + all_currencies = collections.defaultdict(set) currency_fractions = global_data.setdefault('currency_fractions', {}) territory_languages = global_data.setdefault('territory_languages', {}) bcp47_timezone = parse(os.path.join(srcdir, 'bcp47', 'timezone.xml')) @@ -286,14 +288,18 @@ def parse_global(srcdir, sup): region_code = region.attrib['iso3166'] region_currencies = [] for currency in region.findall('./currency'): + cur_code = currency.attrib['iso4217'] cur_start = _parse_currency_date(currency.attrib.get('from')) cur_end = _parse_currency_date(currency.attrib.get('to')) - region_currencies.append((currency.attrib['iso4217'], - cur_start, cur_end, - currency.attrib.get( - 'tender', 'true') == 'true')) + cur_tender = currency.attrib.get('tender', 'true') == 'true' + # Tie region to currency. + region_currencies.append((cur_code, cur_start, cur_end, cur_tender)) + # Keep a reverse index of currencies to territorie. + all_currencies[cur_code].add(region_code) region_currencies.sort(key=_currency_sort_key) territory_currencies[region_code] = region_currencies + global_data['all_currencies'] = dict([ + (currency, tuple(sorted(regions))) for currency, regions in all_currencies.items()]) # Explicit parent locales for paternity in sup.findall('.//parentLocales/parentLocale'): |