diff options
author | Mario <mario@mariovavti.com> | 2020-06-15 07:02:18 +0000 |
---|---|---|
committer | Mario <mario@mariovavti.com> | 2020-06-15 07:02:18 +0000 |
commit | 49dee6312f64be7b76bdf3902f971080d5c68cd6 (patch) | |
tree | ba7e4fa48735463b71b7a527007ba2ad48239f62 /vendor/commerceguys/intl/scripts | |
parent | 63a6b4a162041d8381c9e58c641b44ec5120011a (diff) | |
download | volse-hubzilla-49dee6312f64be7b76bdf3902f971080d5c68cd6.tar.gz volse-hubzilla-49dee6312f64be7b76bdf3902f971080d5c68cd6.tar.bz2 volse-hubzilla-49dee6312f64be7b76bdf3902f971080d5c68cd6.zip |
new file
Diffstat (limited to 'vendor/commerceguys/intl/scripts')
-rw-r--r-- | vendor/commerceguys/intl/scripts/generate_base.php | 91 |
1 files changed, 91 insertions, 0 deletions
diff --git a/vendor/commerceguys/intl/scripts/generate_base.php b/vendor/commerceguys/intl/scripts/generate_base.php new file mode 100644 index 000000000..d5e18f2b6 --- /dev/null +++ b/vendor/commerceguys/intl/scripts/generate_base.php @@ -0,0 +1,91 @@ +<?php + +require __DIR__ . '/../vendor/autoload.php'; + +// Downloaded from http://www.currency-iso.org/en/home/tables/table-a1.html +$isoCurrencies = __DIR__ . '/assets/c2.xml'; +// Downloaded from https://github.com/unicode-cldr/cldr-core.git +$currencyData = __DIR__ . '/assets/cldr-core/supplemental/currencyData.json'; +// Downloaded from https://github.com/unicode-cldr/cldr-localenames-full.git +$localeDirectory = __DIR__ . '/assets/cldr-localenames-full/main/'; +// Downloaded from https://github.com/unicode-cldr/cldr-numbers-full.git +$numbersDirectory = __DIR__ . '/assets/cldr-numbers-full/main/'; + +// Preflight checks. +if (!file_exists($currencyData)) { + die("The $currencyData file was not found"); +} +if (!file_exists($isoCurrencies)) { + die("The $isoCurrencies file was not found"); +} +if (!is_dir($localeDirectory)) { + die("The $localeDirectory directory was not found"); +} +if (!is_dir($numbersDirectory)) { + die("The $numbersDirectory directory was not found"); +} +if (!function_exists('collator_create')) { + // Reimplementing intl's collator would be a huge undertaking, so we + // use it instead to presort the generated locale specific data. + die('The intl extension was not found.'); +} + +// Locales listed without a "-" match all variants. +// Locales listed with a "-" match only those exact ones. +$ignoredLocales = [ + // Esperanto, Interlingua, Volapuk are made up languages. + 'eo', 'ia', 'vo', + // Church Slavic, Manx, Prussian are historical languages. + 'cu', 'gv', 'prg', + // Valencian differs from its parent only by a single character (è/é). + 'ca-ES-VALENCIA', + // Africa secondary languages. + 'agq', 'ak', 'am', 'asa', 'bas', 'bem', 'bez', 'bm', 'cgg', 'dav', + 'dje', 'dua', 'dyo', 'ebu', 'ee', 'ewo', 'ff', 'ff-Latn', 'guz', + 'ha', 'ig', 'jgo', 'jmc', 'kab', 'kam', 'kea', 'kde', 'ki', 'kkj', + 'kln', 'khq', 'ksb', 'ksf', 'lag', 'luo', 'luy', 'lu', 'lg', 'ln', + 'mas', 'mer', 'mua', 'mgo', 'mgh', 'mfe', 'naq', 'nd', 'nmg', 'nnh', + 'nus', 'nyn', 'om', 'pcm', 'rof', 'rwk', 'saq', 'seh', 'ses', 'sbp', + 'sg', 'shi', 'sn', 'teo', 'ti', 'tzm', 'twq', 'vai', 'vai-Latn', 'vun', + 'wo', 'xog', 'xh', 'zgh', 'yav', 'yo', 'zu', + // Europe secondary languages. + 'br', 'dsb', 'fo', 'fur', 'fy', 'hsb', 'ksh', 'kw', 'nds', 'or', 'rm', + 'se', 'smn', 'wae', + // Other infrequently used locales. + 'ceb', 'ccp', 'chr', 'ckb', 'haw', 'ii', 'jv', 'kl', 'kn', 'lkt', + 'lrc', 'mi', 'mzn', 'os', 'qu', 'row', 'sah', 'su', 'tt', 'ug', 'yi', + // Special "grouping" locales. + 'root', 'en-US-POSIX', +]; + +/** + * Converts the provided data into json and writes it to the disk. + */ +function file_put_json($filename, $data) +{ + $data = json_encode($data, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE); + // Indenting with tabs instead of 4 spaces gives us 20% smaller files. + $data = str_replace(' ', "\t", $data); + file_put_contents($filename, $data); +} + +/** + * Creates a list of available locales. + */ +function discover_locales() +{ + global $localeDirectory, $ignoredLocales; + + // Gather available locales. + $locales = []; + foreach (scandir($localeDirectory) as $entry) { + if (substr($entry, 0, 1) != '.') { + $entryParts = explode('-', $entry); + if (!in_array($entry, $ignoredLocales) && !in_array($entryParts[0], $ignoredLocales)) { + $locales[] = $entry; + } + } + } + + return $locales; +} |