aboutsummaryrefslogtreecommitdiff
path: root/src/load-locale-messages.sh.in
diff options
context:
space:
mode:
authorEuAndreh <eu@euandre.org>2021-09-14 22:07:29 -0300
committerEuAndreh <eu@euandre.org>2021-09-14 22:07:29 -0300
commite22fa5d3d78008f53227014afb6b1a6622d5c1d4 (patch)
tree2ac167c91a0f7c90f48046e51b68f54290869b9f /src/load-locale-messages.sh.in
parentTODOs.md: Add #task-e9b72107-7dad-0844-d993-503259c729b5 (diff)
downloadgit-permalink-e22fa5d3d78008f53227014afb6b1a6622d5c1d4.tar.gz
git-permalink-e22fa5d3d78008f53227014afb6b1a6622d5c1d4.tar.xz
Rework how translation is done
Instead of variables on the code itself, each language gets its own file.
Diffstat (limited to 'src/load-locale-messages.sh.in')
-rw-r--r--src/load-locale-messages.sh.in33
1 files changed, 33 insertions, 0 deletions
diff --git a/src/load-locale-messages.sh.in b/src/load-locale-messages.sh.in
new file mode 100644
index 0000000..4840e0f
--- /dev/null
+++ b/src/load-locale-messages.sh.in
@@ -0,0 +1,33 @@
+#!/bin/sh
+set -eu
+
+get_lang() {
+ # LC_MESSAGES="ll_CC.CODESET@modifier" -> ll_CC, where quotes are
+ # optional
+ locale 2>/dev/null |
+ grep ^LC_MESSAGES |
+ cut -d. -f1 |
+ cut -d\" -f2 |
+ cut -d= -f2
+}
+
+locpath() {
+ lang="$1"
+ printf '@LOCALEDIR@/%s/LC_MESSAGES/@NAME@.sh' "$lang"
+}
+
+ll_CC="$(get_lang)"
+ll="$(echo "$ll_CC" | cut -d_ -f1)"
+
+if [ -r "$(locpath "$ll")" ]; then
+ . "$(locpath "$ll")"
+fi
+
+if [ -r "$(locpath "$ll_CC")" ]; then
+ . "$(locpath "$ll_CC")"
+fi
+
+# locale hierarchy:
+# 1. the language+country specific message
+# 2. the language specific message
+# 3. the default fallback value