#!/bin/sh
-# $Id: release.sh,v 1.29 2009/03/22 14:15:01 henoheno Exp $
+# $Id: release.sh,v 1.35 2011/06/05 14:22:51 henoheno Exp $
# $CVSKNIT_Id: release.sh,v 1.11 2004/05/28 14:26:24 henoheno Exp $
# Release automation script for PukiWiki
# ==========================================================
- Copyright='(C) 2002-2004 minix-up project, All Rights Reserved'
+ Copyright='(C) 2002-2004,2011 minix-up project, All Rights Reserved'
Homepage='http://cvsknit.sourceforge.net/'
- License='BSD Licnese, NO WARRANTY'
+ License='(also revised)BSD Licnese, NO WARRANTY'
#
# Name and Usage --------------------------------------------
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"
+ warn " --git Use git repository"
+ warn " --repo <repository> Git repository_url"
+ warn " --name <distname> package_name"
return 1
}
[1-9].[0-9].[0-9]_[a-z]* | [1-9].[0-9].[0-9][0-9]_[a-z]* ) tag="r$1" ;;
[1-9].[0-9].[0-9]_[1-9] | [1-9].[0-9].[0-9][0-9]_[1-9] ) tag="r$1" ;;
[1-9].[0-9].[0-9]_[1-9]_[a-z]* | [1-9].[0-9].[0-9][0-9]_[1-9]_[a-z]* ) tag="r$1" ;;
- HEAD | r1_3_3_branch ) tag="$rel" ;;
+ HEAD | r1_3_3_branch | branch_r* ) tag="$rel" ;;
'' ) usage ; return 1 ;;
* ) warn "Error: Invalid string: $1" ; usage ; return 1 ;;
esac
--copy-dist ) echo _copy_dist 1 ;;
--move-dist ) echo _move_dist 1 ;;
-d ) echo _CVSROOT 2 ; _arg="$2" ;;
+ --git ) echo _git 1 ;;
+ --repo ) echo _gitrepo 2 ; _arg="$2" ;;
+ --name ) echo _pkg_name 2 ; _arg="$2" ;;
-* ) warn "Error: Unknown option \"$1\"" ; return 1 ;;
* ) echo OTHER ;;
esac
_help ) usage ;;
_CVSROOT) CVSROOT="$2" ;;
+ _gitrepo) gitrepo="$2" ;;
+ _pkg_name) pkg_name="$2" ;;
_* ) eval "_$ch"=on ;;
* ) break 2 ;;
if [ ! -f "$encls" ]
then err "encls not found"
else
- which php || err "php-cli not found"
- encls="`pwd`/$encls"
+ php="` which php `" || err "php-cli not found"
+ encls="$php `pwd`/$encls"
fi
convert(){
# Argument check --------------------------------------------
rel="$1"
-tag="` check_versiontag "$rel" `" || exit 1
-pkg_dir="${mod}-${rel}"
-if [ "$__utf8" ] ; then
- pkg_dir="${pkg_dir}_utf8"
+if [ "$pkg_name" ] ; then
+ pkg_dir="$pkg_name"
+ tag="$rel"
+else
+ tag="` check_versiontag "$rel" `" || exit 1
+ pkg_dir="${mod}-${rel}"
+ if [ "$__utf8" ] ; then
+ pkg_dir="${pkg_dir}_utf8"
+ fi
fi
# Export the module -----------------------------------------
-
test ! -d "$pkg_dir" || err "There's already a directory: $pkg_dir"
if [ -z "$__checkout" ]
else cmd="checkout"
fi
-echo cvs -z3 -d "$CVSROOT" -q "$cmd" -r "$tag" -d "$pkg_dir" "$mod"
- cvs -z3 -d "$CVSROOT" -q "$cmd" -r "$tag" -d "$pkg_dir" "$mod"
+if [ "$__git" ] ; then
+ 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"
+ cvs -z3 -d "$CVSROOT" -q "$cmd" -r "$tag" -d "$pkg_dir" "$mod"
+fi
test -d "$pkg_dir" || err "There isn't a directory: $pkg_dir"
# Remove '.cvsignore' if exists -----------------------------
test -z "$__noremove" && {
+ if [ "$__git" ] ; then
+ echo rm -rf "$pkg_dir/.git"
+ rm -rf "$pkg_dir/.git"
+ fi
echo find "$pkg_dir" -type f -name '.cvsignore' "| xargs rm -f"
find "$pkg_dir" -type f -name '.cvsignore' | xargs rm -f
}
+
# Conversion ------------------------------------------------
if [ "$__utf8" ] ; then
echo "Converting EUC-JP => UTF-8 ..."
find "$pkg_dir" -type f \( -name "*.txt" -or -name "*.php" -or -name "*.lng" -or -name "*.dat" -or -name "*.ref" \) |
while read line; do
- convert "$line"
+ case "$line" in
+ "$pkg_dir"/zh-CN.lng.php ) ;; # UTF-8 already, Do nothing
+ * ) convert "$line" ;;
+ esac
done
# Replace 'EUC-JP' => 'UTF-8'