warn " --nopkg Suppress creating archive (Extract and chmod only)"
warn " --norm --nopkg, and remove nothing (.cvsignore etc)"
warn " --co --norm, and use 'checkout' command instead of 'export'"
- warn " --utf8 Create UTF-8 converted archive (EXPERIMENTAL)"
+ warn " --utf8 Create UTF-8 converted archive"
+ warn " --eucjp Create EUC_JP converted archive"
+ warn " --fromeucjp Indicate source charset is EUC_JP"
warn " -z|--zip Create *.zip archive"
warn " --move-dist Move *.ini.php => *.ini-dist.php"
warn " --copy-dist Move, and Copy *.ini.php <= *.ini-dist.php"
--co|--checkout ) echo _nopkg _noremove _checkout 1 ;;
-z|--zip ) echo _zip 1 ;;
--ut|--utf|--utf8|--utf-8 ) echo _utf8 1 ;;
+ --eucjp ) echo _eucjp 1 ;;
+ --fromeucjp ) echo _fromeucjp 1 ;;
--copy-dist ) echo _copy_dist 1 ;;
--move-dist ) echo _move_dist 1 ;;
-d ) echo _CVSROOT 2 ; _arg="$2" ;;
# Utility check ---------------------------------------------
-if [ "$__utf8" ] ; then
+# Convert UTF-8 -> EUC_JP or EUC_JP -> UTF-8
+if [ \( "$__eucjp" -a ! "$__fromeucjp" \) -o \( "$__utf8" -a "$__fromeucjp" \) ] ; then
+ __charconv=1
+fi
+
+if [ "$__charconv" ] ; then
# nkf
which nkf || err "nkf version 2.0 or later (UTF-8 enabled) not found"
fi
convert(){
+ __nkfopt="--ic=eucJP-ms -w"
+ if [ "$__eucjp" ] ; then
+ __nkfopt="--ic=UTF8 --oc=eucJP-ms"
+ fi
for list in "$@" ; do
# NOTE: Specify '-E'(From EUC-JP) otherwise skin file will be collapsed
- nkf -Ew "$list" > "$list.$$.tmp" && mv "$list.$$.tmp" "$list" && echo " $list"
+ nkf $__nkfopt "$list" > "$list.$$.tmp" && mv "$list.$$.tmp" "$list" && echo " $list"
done
}
convert_EUCJP2UTF8(){
sed 's#^//UTF-8:##' "$list" > "$list.$$.tmp" && mv "$list.$$.tmp" "$list"
done
}
+ convert_UTF82EUCJP(){
+ for list in "$@" ; do
+ # Very rough conversion!
+ #sed 's/UTF-8/EUC-JP/g' "$list" > "$list.$$.tmp" && mv "$list.$$.tmp" "$list"
+ # This is very specific logic for PukiWiki 1.5.x source code
+ sed -i 's#^define('\''PKWK_UTF8_ENABLE'\'', *1);#//UTF-8:\0#' "$list"
+ sed -i 's#^case \+'\''ko'\'': *define('\''MB_LANGUAGE'\'', *'\''Korean'\''#//UTF-8:\0#' "$list"
+ sed -i 's#^[^a-zA-Z]*// *See *BugTrack2/13 *for *all#//UTF-8:\0#' "$list"
+ sed -i 's#^[^a-zA-Z]*// *and *give *us *your *report#//UTF-8:\0#' "$list"
+
+ done
+ }
fi > /dev/null
if [ -z "$__zip" ]
fi
if [ "$__git" ] ; then
- echo git clone --depth 10 --branch "$tag" "$gitrepo" "$pkg_dir"
- git clone --depth 10 --branch "$tag" "$gitrepo" "$pkg_dir"
+ echo git clone "$gitrepo" "$pkg_dir"
+ git clone "$gitrepo" "$pkg_dir"
+ echo cd $pkg_dir
+ cd $pkg_dir
+ echo git reset --hard "$tag"
+ git reset --hard "$tag"
+
+ # Set file timestamp
+ for FILE in $(git ls-files); do
+ TIME=$(git log --pretty=format:%ci -n1 $FILE)
+ echo $TIME'\t'$FILE
+ STAMP=$(date -d "$TIME" +"%y%m%d%H%M.%S")
+ touch -t $STAMP $FILE
+ done
+
+ cd ..
else
exit
echo cvs -z3 -d "$CVSROOT" -q "$cmd" -r "$tag" -d "$pkg_dir" "$mod"
find "$pkg_dir" -type f -name '.cvsignore' | xargs rm -f
}
+# Get back original files ----------------------------------
+mv $pkg_dir/wiki/_526563656E744368616E676573.txt $pkg_dir/wiki/526563656E744368616E676573.txt
+mv $pkg_dir/cache/_recent.dat $pkg_dir/cache/recent.dat
+
+
# Conversion ------------------------------------------------
-if [ "$__utf8" ] ; then
- echo "Converting EUC-JP => UTF-8 ..."
+if [ "$__charconv" ] ; then
+ if [ "$__utf8" ] ; then
+ echo "Converting EUC-JP => UTF-8 ..."
+ else
+ echo "Converting UTF-8 => EUC-JP ..."
+ fi
find "$pkg_dir" -type f \( -name "*.txt" -or -name "*.php" -or -name "*.lng" -or -name "*.dat" -or -name "*.ref" \) |
while read line; do
case "$line" in
esac
done
- # Replace 'EUC-JP' => 'UTF-8'
- ( cd "$pkg_dir" &&
- convert_EUCJP2UTF8 lib/init.php skin/pukiwiki.skin*.php
- )
+ if [ "$__utf8" ] ; then
+ # Replace 'EUC-JP' => 'UTF-8'
+ ( cd "$pkg_dir" &&
+ convert_EUCJP2UTF8 lib/init.php skin/pukiwiki.skin*.php
+ )
+ else
+ # Replace 'UTF-8' => 'EUC-JP'
+ ( cd "$pkg_dir" &&
+ convert_UTF82EUCJP lib/init.php skin/pukiwiki.skin*.php
+ )
+ fi
# Filename encoded 'encoded-EUC-JP' to 'encoded-UTF-8'
echo "Renaming encoded-EUC-JP => encoded-UTF-8 ..."