linux standalone: When LOCPATH is already set, use it instead of the bundled locales.

It can be set to an empty string to use the system locales too. Of course
whether that will work depends on the amount of divergence.

This commit was supported by the NSF-funded DataLad project.
This commit is contained in:
Joey Hess 2018-08-20 12:20:54 -04:00
parent 48fb6f9886
commit fa44bca8b3
No known key found for this signature in database
GPG key ID: DB12DB0FF05F8F38
2 changed files with 50 additions and 44 deletions

View file

@ -11,6 +11,9 @@ git-annex (6.20180808) UNRELEASED; urgency=medium
pipe. This also avoids git buffering the whole file content in memory. pipe. This also avoids git buffering the whole file content in memory.
* v6: After updating the worktree for an add/drop, update git's index, * v6: After updating the worktree for an add/drop, update git's index,
so git status will not show the files as modified. so git status will not show the files as modified.
* linux standalone: When LOCPATH is already set, use it instead of the
bundled locales. It can be set to an empty string to use the system
locales too.
-- Joey Hess <id@joeyh.name> Wed, 08 Aug 2018 11:24:08 -0400 -- Joey Hess <id@joeyh.name> Wed, 08 Aug 2018 11:24:08 -0400

View file

@ -123,56 +123,59 @@ export MANPATH
unset LD_PRELOAD unset LD_PRELOAD
# Avoid using system locales, which may interact badly with bundled libc. # Avoid using system locales, which may interact badly with bundled libc.
# (But if LOCPATH is set, don't override it.)
ORIG_LOCPATH="$LOCPATH" ORIG_LOCPATH="$LOCPATH"
export ORIG_LOCPATH export ORIG_LOCPATH
LOCPATH="$HOME/.cache/git-annex/locales/$(echo "$base" | tr / _ )" if [ -z "${LOCPATH+set}" ]; then
export LOCPATH LOCPATH="$HOME/.cache/git-annex/locales/$(echo "$base" | tr / _ )"
export LOCPATH
# Clean up locale caches when their standalone bundle no longer exists.
for localecache in $HOME/.cache/git-annex/locales/*; do # Clean up locale caches when their standalone bundle no longer exists.
cachebase=$(cat "$localecache/base" 2>/dev/null || true) for localecache in $HOME/.cache/git-annex/locales/*; do
if [ ! -d "$cachebase" ] || ! cmp "$localecache/buildid" "$cachebase/buildid" >/dev/null ; then cachebase=$(cat "$localecache/base" 2>/dev/null || true)
rm -rf "$localecache" 2>&1 || true if [ ! -d "$cachebase" ] || ! cmp "$localecache/buildid" "$cachebase/buildid" >/dev/null ; then
rm -rf "$localecache" 2>&1 || true
fi
done
# If the locale cache for this bundle is out of date, refresh it.
if [ -e "$LOCPATH/buildid" ] && ! cmp "$LOCPATH/buildid" "$base/buildid" >/dev/null ; then
rm -rf "$LOCPATH"
fi fi
done if ! mkdir -p "$LOCPATH"; then
echo "Unable to write to $LOCPATH; can't continue!" >&2
exit 1
fi
echo "$base" > "$LOCPATH/base"
cp "$base/buildid" "$LOCPATH/buildid"
# If the locale cache for this bundle is out of date, refresh it. # Generate locale definition files for the locales in use,
if [ -e "$LOCPATH/buildid" ] && ! cmp "$LOCPATH/buildid" "$base/buildid" >/dev/null ; then # using the localedef and locale files from the bundle.
rm -rf "$LOCPATH" # Currently only utf-8 locales are handled.
fi lastlocaleenv=""
if ! mkdir -p "$LOCPATH"; then for localeenv in "$LANG" "$LANGUAGE" "$LC_CTYPE" "$LC_NUMERIC" "$LC_TIME" \
echo "Unable to write to $LOCPATH; can't continue!" >&2 "$LC_COLLATE" "$LC_MONETARY" "$LC_MESSAGES" "$LC_PAPER" \
exit 1 "$LC_NAME" "$LC_ADDRESS" "$LC_TELEPHONE" "$LC_MEASUREMENT" \
fi "$LC_IDENTIFICATION" "$LC_ALL"; do
echo "$base" > "$LOCPATH/base" if [ "$localeenv" != "$lastlocaleenv" ]; then
cp "$base/buildid" "$LOCPATH/buildid" lastlocaleenv="$localeenv"
if [ ! -d "$LOCPATH/$localeenv" ]; then
# Generate locale definition files for the locales in use, if [ "${localeenv##[!.]*.}" = "utf8" ] || [ "${localeenv##[!.]*.}" = "UTF-8" ]; then
# using the localedef and locale files from the bundle. (
# Currently only utf-8 locales are handled. rm -rf "$LOCPATH/$localeenv.new.$$" &&
lastlocaleenv="" mkdir -p "$LOCPATH/$localeenv.new.$$" &&
for localeenv in "$LANG" "$LANGUAGE" "$LC_CTYPE" "$LC_NUMERIC" "$LC_TIME" \ # cd to $base since localedef reads files from pwd
"$LC_COLLATE" "$LC_MONETARY" "$LC_MESSAGES" "$LC_PAPER" \ cd "$base" &&
"$LC_NAME" "$LC_ADDRESS" "$LC_TELEPHONE" "$LC_MEASUREMENT" \ # Run localedef using the bundled i18n files;
"$LC_IDENTIFICATION" "$LC_ALL"; do # use LANG=C to avoid it reading the system locale archive.
if [ "$localeenv" != "$lastlocaleenv" ]; then I18NPATH="$base/i18n" LANG=C localedef -i "${localeenv%%.*}" -c -f UTF-8 "$LOCPATH/$localeenv.new.$$" &&
lastlocaleenv="$localeenv" mv "$LOCPATH/$localeenv.new.$$" "$LOCPATH/$localeenv"
if [ ! -d "$LOCPATH/$localeenv" ]; then ) >/dev/null 2>/dev/null || true
if [ "${localeenv##[!.]*.}" = "utf8" ] || [ "${localeenv##[!.]*.}" = "UTF-8" ]; then fi
(
rm -rf "$LOCPATH/$localeenv.new.$$" &&
mkdir -p "$LOCPATH/$localeenv.new.$$" &&
# cd to $base since localedef reads files from pwd
cd "$base" &&
# Run localedef using the bundled i18n files;
# use LANG=C to avoid it reading the system locale archive.
I18NPATH="$base/i18n" LANG=C localedef -i "${localeenv%%.*}" -c -f UTF-8 "$LOCPATH/$localeenv.new.$$" &&
mv "$LOCPATH/$localeenv.new.$$" "$LOCPATH/$localeenv"
) >/dev/null 2>/dev/null || true
fi fi
fi fi
fi done
done fi
useproot="" useproot=""
case "$os" in case "$os" in