svn commit: r310199 - head/tools/tools/locale/tools
Baptiste Daroussin
bapt at FreeBSD.org
Sun Dec 18 04:11:14 UTC 2016
Author: bapt
Date: Sun Dec 18 04:11:13 2016
New Revision: 310199
URL: https://svnweb.freebsd.org/changeset/base/310199
Log:
Better handle posix names for locales
Modified:
head/tools/tools/locale/tools/finalize
Modified: head/tools/tools/locale/tools/finalize
==============================================================================
--- head/tools/tools/locale/tools/finalize Sun Dec 18 02:02:33 2016 (r310198)
+++ head/tools/tools/locale/tools/finalize Sun Dec 18 04:11:13 2016 (r310199)
@@ -41,20 +41,29 @@ AWKCMD="/## PLACEHOLDER/ { \
# Rename the sources with 3 components name into the POSIX version of the name using @modifier
cd $old
+pwd
for i in *_*_*.*.src; do
+ if [ "$i" = "*_*_*.*.src" ]; then
+ break
+ fi
oldname=${i%.*}
nname=`echo $oldname | awk '{ split($0, a, "_"); print a[1]"_"a[3]"@"a[2];} '`
- mv -i ${oldname}.src ${nname}.src
+ mv -f ${oldname}.src ${nname}.src
+ sed -i '' -e "s/${oldname}/${nname}/g" Makefile
+ COLLATIONS_SPECIAL=$(echo ${COLLATIONS_SPECIAL} | sed -e "s/${oldname}/${nname}/g")
done
- sed -i '' -Ee "s/([a-zA-Z]{2})_([a-zA-Z]+)_([a-zA-Z]{2}).([a-zA-Z0-9-]+)/\1_\3.\4@\2/g" ${old}/Makefile
# For variable without @modifier ambiguity do not keep the @modifier
for i in *@*.src; do
+ if [ "$i" = "*@*.src" ]; then
+ break
+ fi
oldname=${i%.*}
shortname=${oldname%@*}
- if [ $(ls ${shortname}@* | wc -l) -eq 1 -a ! -f ${shortname}.src ] ; then
- mv -i $i ${shortname}.src
- sed -i '' -e "s/${oldname}/${shortname}/g" ${old}/Makefile
+ if [ $(ls ${shortname}@* | wc -l) -eq 1 ] ; then
+ mv -f $i ${shortname}.src
+ sed -i '' -e "s/${oldname}/${shortname}/g" Makefile
+ COLLATIONS_SPECIAL=$(echo ${COLLATIONS_SPECIAL} | sed -e "s/${oldname}/${shortname}/g")
fi
done
@@ -63,16 +72,19 @@ for i in *@Latn.src; do
if [ "$i" = "*@Latn.src" ]; then
break
fi
- mv ${i} ${i%@*}@latin.src
+ mv -f ${i} ${i%@*}@latin.src
+ sed -i '' -e "s/${i%.*}/${i%@*}@latin/g" Makefile
+ COLLATIONS_SPECIAL=$(echo ${COLLATIONS_SPECIAL} | sed -e "s/${i%.*}/${i%@*}@latin/g")
done
- sed -i '' -e "s/@Latn/@latin/g" ${old}/Makefile
+
for i in *@Cyrl.src; do
if [ "$i" = "*@Cyrl.src" ]; then
break
fi
- mv ${i} ${i%@*}@cyrillic.src
+ mv -f ${i} ${i%@*}@cyrillic.src
+ sed -i '' -e "s/${i%.*}/${i%@*}@cyrillic/g" Makefile
+ COLLATIONS_SPECIAL=$(echo ${COLLATIONS_SPECIAL} | sed -e "s/${i%.*}/${i%@*}@cyrillic/g")
done
- sed -i '' -e "s/@Cyrl/@cyrillic/g" ${old}/Makefile
# On locales with multiple modifiers rename the "default" version without the @modifier
default_locales="sr_RS at cyrillic"
@@ -83,8 +95,8 @@ for i in ${default_locales}; do
if [ "$l" = "${localename}.*@${mod}.src" ]; then
break
fi
- mv ${l} ${l%@*}.src
- sed -i '' -e "s/${l%.*}/${l%@*}/g" ${old}/Makefile
+ mv -f ${l} ${l%@*}.src
+ sed -i '' -e "s/${l%.*}/${l%@*}/g" Makefile
done
done
cd -
@@ -146,13 +158,12 @@ then
done
echo "" >> ${TEMP4}
for enc in ${COLLATIONS_SPECIAL}; do
- nname=`echo $enc | sed -e 's/_Hans//g'`
- sed -i '' "/^.*${nname}$/d" ${TEMP4}
- echo "LOCALES+= ${nname}" >> ${TEMP4}
+ sed -i '' "/^.*${enc}$/d" ${TEMP4}
+ echo "LOCALES+= ${enc}" >> ${TEMP4}
done
keep=$(cat ${TEMP} | awk '{ print $2 }')
- for original in ${keep}
+ for original in ${keep} ${COLLATIONS_SPECIAL}
do
cp ${old}/${original}.src ${new}/
done
More information about the svn-src-all
mailing list