aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/commerceguys/intl/scripts/generate_base.php
diff options
context:
space:
mode:
authorMario <mario@mariovavti.com>2020-06-15 07:02:18 +0000
committerMario <mario@mariovavti.com>2020-06-15 07:02:18 +0000
commit49dee6312f64be7b76bdf3902f971080d5c68cd6 (patch)
treeba7e4fa48735463b71b7a527007ba2ad48239f62 /vendor/commerceguys/intl/scripts/generate_base.php
parent63a6b4a162041d8381c9e58c641b44ec5120011a (diff)
downloadvolse-hubzilla-49dee6312f64be7b76bdf3902f971080d5c68cd6.tar.gz
volse-hubzilla-49dee6312f64be7b76bdf3902f971080d5c68cd6.tar.bz2
volse-hubzilla-49dee6312f64be7b76bdf3902f971080d5c68cd6.zip
new file
Diffstat (limited to 'vendor/commerceguys/intl/scripts/generate_base.php')
-rw-r--r--vendor/commerceguys/intl/scripts/generate_base.php91
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;
+}