OSDN Git Service

default permmision memo
[pukiwiki/pukiwiki_devel.git] / release.sh
index db9ec4c..0575e2b 100755 (executable)
@@ -1,11 +1,11 @@
 #!/bin/sh
-# $Id: release.sh,v 1.16 2005/03/21 11:43:49 henoheno Exp $
+# $Id: release.sh,v 1.31 2011/01/13 15:43:22 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 --------------------------------------------
@@ -16,6 +16,9 @@ usage(){
   warn  "Usage: $_name [options] VERSION_TAG (1.4.3_rc1 like)"
   warn  "  Options:"
   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  "    -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"
@@ -36,6 +39,32 @@ trace(){
   _msg="$1" ; test $# -gt 0 && shift ; warn "  $_msg   : ` quote "$@" `"
 }
 
+check_versiontag(){
+  case "$1" in
+    [1-9].[0-9]              | [1-9].[0-9]                   ) tag="r$1" ;;
+    [1-9].[0-9]_rc[1-9]      | [1-9].[0-9]_rc[1-9]           ) tag="r$1" ;;
+    [1-9].[0-9].[0-9]        | [1-9].[0-9].[0-9][0-9]        ) tag="r$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" ;;
+    '' ) usage ; return 1 ;;
+     * ) warn "Error: Invalid string: $1" ; usage ; return 1 ;;
+  esac
+  echo "$tag" | tr '.' '_'
+}
+
+chmod_pkg(){
+  ( cd "$1"
+    # ALL: Read only
+    find . -type d | while read line; do chmod 755 "$line"; done
+    find . -type f | while read line; do chmod 644 "$line"; done
+    # Add write permission for PukiWiki
+    chmod 777 attach backup cache counter diff trackback wiki* 2>/dev/null
+    chmod 666 wiki*/*.txt cache/*.dat cache/*.ref cache/*.rel  2>/dev/null
+  )
+}
+
 # Default variables -----------------------------------------
 
 mod=pukiwiki
@@ -50,11 +79,14 @@ getopt(){ _arg=noarg
   case "$1" in
   ''  )  echo 1 ;;
   -[hH]|--help ) echo _help _exit ;;
-  --debug      ) echo _debug      ;;
-  --nopkg      ) echo _nopkg      ;;
-  -z|--zip     ) echo _zip        ;;
-  --copy-dist  ) echo _copy_dist  ;;
-  --move-dist  ) echo _move_dist  ;;
+  --debug      ) echo _debug 1    ;;
+  --nopkg      ) echo _nopkg 1    ;;
+  --norm|--noremove ) echo _nopkg _noremove 1 ;;
+  --co|--checkout   ) echo _nopkg _noremove _checkout 1 ;;
+  -z|--zip     ) echo _zip 1      ;;
+  --ut|--utf|--utf8|--utf-8 ) echo _utf8 1  ;;
+  --copy-dist  ) echo _copy_dist 1 ;;
+  --move-dist  ) echo _move_dist 1 ;;
   -d  ) echo _CVSROOT 2 ; _arg="$2" ;;
   -*  ) warn "Error: Unknown option \"$1\"" ; return 1 ;;
    *  ) echo OTHER ;;
@@ -83,7 +115,7 @@ while [ $# -gt 0 ] ; do
 
      _CVSROOT) CVSROOT="$2" ;;
 
-     _*      ) shift ; eval "_$ch"=on ;;
+     _*      ) eval "_$ch"=on ;;
       *      ) break 2   ;;
     esac
   done
@@ -92,7 +124,41 @@ done
 # No argument
 if [ $# -eq 0 ] ; then usage ; exit ; fi
 
-# Archiver check --------------------------------------------
+# Utility check ---------------------------------------------
+
+if [ "$__utf8" ] ; then
+
+  # nkf
+  which nkf || err "nkf version 2.0 or later (UTF-8 enabled) not found"
+  nkf_version="` nkf -v 2>&1 | sed -e '/^Network Kanji Filter/!d' -e 's/.* Version \([1-9]\).*/\1/' `"
+  if [ "$nkf_version" = '1' -o "$nkf_version" = '0' ] ; then
+    err "nkf found but not seems 2.x (UTF-8 enabled) or later"
+  fi
+
+  # encls.php
+  encls="./encls.php"
+  if [ ! -f "$encls" ]
+  then err "encls not found"
+  else
+    php="` which php `"        || err "php-cli not found"
+    test -f /usr/local/bin/php || err "/usr/local/bin/php not found (but $php found)"
+    encls="`pwd`/$encls"
+  fi
+
+  convert(){
+    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"
+    done
+  }
+  convert_EUCJP2UTF8(){
+    for list in "$@" ; do
+      # Very rough conversion!
+      #sed 's/EUC-JP/UTF-8/g' "$list" > "$list.$$.tmp" && mv "$list.$$.tmp" "$list"
+      sed 's#^//UTF-8:##' "$list" > "$list.$$.tmp" && mv "$list.$$.tmp" "$list"
+    done
+  }
+fi > /dev/null
 
 if [ -z "$__zip" ]
 then
@@ -105,49 +171,67 @@ fi > /dev/null
 # Argument check --------------------------------------------
 
 rel="$1"
+tag="` check_versiontag "$rel" `" || exit 1
 pkg_dir="${mod}-${rel}"
-case "$rel" in
-  [1-9].[0-9]              | [1-9].[0-9]                   ) tag="r$rel" ;;
-  [1-9].[0-9]_rc[1-9]      | [1-9].[0-9]_rc[1-9]           ) tag="r$rel" ;;
-  [1-9].[0-9].[0-9]        | [1-9].[0-9].[0-9][0-9]        ) tag="r$rel" ;;
-  [1-9].[0-9].[0-9]_[a-z]* | [1-9].[0-9].[0-9][0-9]_[a-z]* ) tag="r$rel" ;;
-  [1-9].[0-9].[0-9]_[1-9]  | [1-9].[0-9].[0-9][0-9]_[1-9]  ) tag="r$rel" ;;
-  HEAD | r1_3_3_branch ) tag="$rel" ;;
-  * ) usage ; exit ;;
-esac
-tag="` echo "$tag" | tr '.' '_' `"
+
+if [ "$__utf8" ] ; then
+  pkg_dir="${pkg_dir}_utf8"
+fi
 
 # Export the module -----------------------------------------
 
 test ! -d "$pkg_dir" || err "There's already a directory: $pkg_dir"
 
-echo cvs -z3 -d "$CVSROOT" -q export -r "$tag" -d "$pkg_dir" "$mod"
-     cvs -z3 -d "$CVSROOT" -q export -r "$tag" -d "$pkg_dir" "$mod"
+if [ -z "$__checkout" ]
+then cmd="export"
+else cmd="checkout"
+fi
 
-#echo cvs -z3 -d "$CVSROOT" -q co -r "$tag" -d "$pkg_dir" "$mod"
-#     cvs -z3 -d "$CVSROOT" -q co -r "$tag" -d "$pkg_dir" "$mod"
+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"
 
-test   -d "$pkg_dir" || err "There is'nt a directory: $pkg_dir"
+test   -d "$pkg_dir" || err "There isn't a directory: $pkg_dir"
 
 # Remove '.cvsignore' if exists -----------------------------
-echo find "$pkg_dir" -type f -name '.cvsignore' -delete
-     find "$pkg_dir" -type f -name '.cvsignore' -delete
+test -z "$__noremove" && {
+  echo find "$pkg_dir" -type f -name '.cvsignore' "| xargs rm -f"
+       find "$pkg_dir" -type f -name '.cvsignore' | xargs rm -f
+}
 
-# chmod -----------------------------------------------------
-( cd "$pkg_dir"
+# Conversion ------------------------------------------------
 
-  # ALL: Read only
-  find . -type d | while read line; do
-      chmod 755 "$line"
-    done
-  find . -type f | while read line; do
-      chmod 644 "$line"
+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"
+  done
+
+  # Replace 'EUC-JP' => 'UTF-8'
+  ( cd "$pkg_dir" &&
+    convert_EUCJP2UTF8 lib/init.php skin/pukiwiki.skin*.php
+  )
+
+  # Filename encoded 'encoded-EUC-JP' to 'encoded-UTF-8'
+  echo "Renaming encoded-EUC-JP => encoded-UTF-8 ..."
+  ( cd "$pkg_dir" &&
+    for dir in wiki wiki.en cache; do
+      ( cd "$dir" &&
+        ls *.txt *.ref *.rel 2>/dev/null | while read line; do
+         target="`$encls "$line" 2>/dev/null`" || exit 1
+         if [ "x$line" != "x$target" ] ; then
+            echo " " mv "$dir/$line" "$dir/$target"
+                     mv "$line" "$target" || exit 1
+         fi
+        done
+      ) || exit 1
     done
+  ) || err "stop."
+fi
 
-  # Add write permission for PukiWiki
-  chmod 777 attach backup cache counter diff trackback wiki*
-  chmod 666 wiki*/*.txt cache/*.dat cache/*.ref cache/*.rel
-)
+# chmod -----------------------------------------------------
+
+chmod_pkg "$pkg_dir"
 
 # Create a package ------------------------------------------