include buildid in LOCPATH
This avoids the possibility that the bundle could be updated in place, leading to LOCPATH existing but containing locales for the old version, which needed to be tested for with code that was not race-free. LOCPATH/buildid is still written and checked when cleaning up stale caches. That is not actually necessary, except old versions of the standalone bundle expect to see it, and this prevents them cleaning up the locale cache of a new version. And still checking it prevents the new version cleaning up the locale cache of the old version while the old version is still in use. Added explicit tests before creating LOCPATH and the base and buildid files. The buildid file no longer needs to be updated every time, because it's stable for the given LOCPATH directory. And the base file actually did not need to be updated every time, because the LOCPATH is derived from base, so if the bundle is moved elsewhere, a different LOCPATH will be used. Transitioning to this will mean that two git-annex builds that otherwise have the same buildid -- the same git-annex md5sum -- will use different LOCPATH values, but that's handled fine by the cache cleanup code, so at most it will mean one extra generation of the locale files.
This commit is contained in:
parent
cb487e7417
commit
f0ec725234
2 changed files with 52 additions and 17 deletions
|
@ -133,7 +133,7 @@ unset LD_PRELOAD
|
|||
ORIG_LOCPATH="$LOCPATH"
|
||||
export ORIG_LOCPATH
|
||||
if [ -z "${LOCPATH+set}" ] && [ -z "$GIT_ANNEX_PACKAGE_INSTALL" ]; then
|
||||
LOCPATH="$HOME/.cache/git-annex/locales/$(echo "$base" | tr / _ )"
|
||||
LOCPATH="$HOME/.cache/git-annex/locales/$(cat "$base/buildid")_$(echo "$base" | tr / _ )"
|
||||
# try to generate a short version, if md5sum is available
|
||||
locpathmd5=$( (echo "$LOCPATH" | md5sum | cut -d ' ' -f 1 2>/dev/null) || true)
|
||||
if [ -n "$locpathmd5" ]; then
|
||||
|
@ -149,24 +149,22 @@ if [ -z "${LOCPATH+set}" ] && [ -z "$GIT_ANNEX_PACKAGE_INSTALL" ]; then
|
|||
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 2>&1 ; then
|
||||
rm -rf "$LOCPATH"
|
||||
if [ ! -d "$LOCPATH" ]; then
|
||||
if ! mkdir -p "$LOCPATH"; then
|
||||
echo "Unable to write to $LOCPATH; can't continue!" >&2
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
if ! mkdir -p "$LOCPATH"; then
|
||||
echo "Unable to write to $LOCPATH; can't continue!" >&2
|
||||
exit 1
|
||||
if [ ! -e "$LOCPATH/base" ]; then
|
||||
echo "$base" > "$LOCPATH/base.$$"
|
||||
mv -f "$LOCPATH/base.$$" "$LOCPATH/base"
|
||||
fi
|
||||
# Not using cp to avoid using the one bundled with git-annex
|
||||
# before the environment is set up to run it.
|
||||
if [ ! -e "$LOCPATH/buildid" ]; then
|
||||
cat < "$base/buildid" > "$LOCPATH/buildid.$$"
|
||||
mv -f "$LOCPATH/buildid.$$" "$LOCPATH/buildid"
|
||||
fi
|
||||
# This is updated each time, because the bundle could be moved to a
|
||||
# different directory.
|
||||
echo "$base" > "$LOCPATH/base.$$"
|
||||
mv -f "$LOCPATH/base.$$" "$LOCPATH/base"
|
||||
# This is updated each time, because the bundle could be updated
|
||||
# in place to a new version.
|
||||
# Not using cp to avoid using the one bundled with git-annex before
|
||||
# the environment is set up to run it.
|
||||
cat < "$base/buildid" > "$LOCPATH/buildid.$$"
|
||||
mv -f "$LOCPATH/buildid.$$" "$LOCPATH/buildid"
|
||||
|
||||
# Generate locale definition files for the locales in use,
|
||||
# using the localedef and locale files from the bundle.
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue