summaryrefslogtreecommitdiff
path: root/testing/glibc/locale-gen
diff options
context:
space:
mode:
authorroot <root@rshg054.dnsready.net>2011-08-15 23:14:29 +0000
committerroot <root@rshg054.dnsready.net>2011-08-15 23:14:29 +0000
commitea595018ba8ae00d7030ff296ec4f50e122d2ea9 (patch)
treeea62e7b37f59699ecfd7183fa33f0f3a81d39cc0 /testing/glibc/locale-gen
parent4784cc8068c68b6fc23c2bd0ee8158b2a924f5f4 (diff)
Mon Aug 15 23:14:29 UTC 2011
Diffstat (limited to 'testing/glibc/locale-gen')
-rwxr-xr-xtesting/glibc/locale-gen42
1 files changed, 42 insertions, 0 deletions
diff --git a/testing/glibc/locale-gen b/testing/glibc/locale-gen
new file mode 100755
index 000000000..5aff344c4
--- /dev/null
+++ b/testing/glibc/locale-gen
@@ -0,0 +1,42 @@
+#!/bin/sh
+
+set -e
+
+LOCALEGEN=/etc/locale.gen
+LOCALES=/usr/share/i18n/locales
+if [ -n "$POSIXLY_CORRECT" ]; then
+ unset POSIXLY_CORRECT
+fi
+
+
+[ -f $LOCALEGEN -a -s $LOCALEGEN ] || exit 0;
+
+# Remove all old locale dir and locale-archive before generating new
+# locale data.
+rm -rf /usr/lib/locale/* || true
+
+umask 022
+
+is_entry_ok() {
+ if [ -n "$locale" -a -n "$charset" ] ; then
+ true
+ else
+ echo "error: Bad entry '$locale $charset'"
+ false
+ fi
+}
+
+echo "Generating locales..."
+while read locale charset; do \
+ case $locale in \#*) continue;; "") continue;; esac; \
+ is_entry_ok || continue
+ echo -n " `echo $locale | sed 's/\([^.\@]*\).*/\1/'`"; \
+ echo -n ".$charset"; \
+ echo -n `echo $locale | sed 's/\([^\@]*\)\(\@.*\)*/\2/'`; \
+ echo -n '...'; \
+ if [ -f $LOCALES/$locale ]; then input=$locale; else \
+ input=`echo $locale | sed 's/\([^.]*\)[^@]*\(.*\)/\1\2/'`; fi; \
+ localedef -i $input -c -f $charset -A /usr/share/locale/locale.alias $locale; \
+ echo ' done'; \
+done < $LOCALEGEN
+echo "Generation complete."