Code

Adds MD5SUM file, creates multiple branch snapshots and doesn't
authorTon Voon <tonvoon@users.sourceforge.net>
Sat, 8 Mar 2003 00:55:50 +0000 (00:55 +0000)
committerTon Voon <tonvoon@users.sourceforge.net>
Sat, 8 Mar 2003 00:55:50 +0000 (00:55 +0000)
rerun configure/automake/autoconf unnecessarily

git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@378 f882894a-f735-0410-b71e-b25c423dba1c

tools/sfsnapshot

index 47421af4668b30f29df1b1402759a8fbe6e27724..5cbdfb4352cbbcee860773080119933297ef1cbe 100755 (executable)
@@ -2,55 +2,79 @@
 
 # Butchered version of snapshot
 # Can only run on the shell compile farm server
+# Will always create a snapshot of HEAD
+# If want multiple snapshots, just run with "sfsnapshot {branch} [branch2 ...]"
 # Assumes:
 #  ssh setup to send to shell.sf.net and $CF without password prompt
 #  autconf and automake installed on shell cf at v 2.57 & 1.72 and in PATH
 
 function die { echo $1; exit 1; }
 
+# This makes the distribution. Expects $1 as CVS tag, otherwise uses HEAD
+function make_dist {
+       if [[ -n $1 ]] ; then
+               cvs_rel=$1
+               v="$1-"
+       else
+               cvs_rel="HEAD"
+               v=""
+       fi
+       
+       # Get compile server to do the work
+       # Variables will be expanded locally before being run on $CF
+       ssh $CF <<-EOF
+       set -x
+       PATH=$PATH
+       [[ ! -d $IN/$cvs_rel ]] && mkdir -p $IN/$cvs_rel
+       cd $IN/$cvs_rel
+       if [[ -d $PROJECT ]] ; then
+               cd $PROJECT 
+               cvs update -r $cvs_rel
+       else
+               cvs -z3 -d:pserver:anonymous@cvs.sourceforge.net:/cvsroot/nagiosplug co -r $cvs_rel nagiosplug
+               cd $PROJECT
+               aclocal
+               autoheader
+               autoconf
+               automake
+               autoreconf
+               ./configure
+       fi
+
+       # Make the Nagiosplug dist tarball
+       VER=$v$DS VERSION=$v$DS REL=snapshot make -e dist
+
+       # End ssh
+       EOF
+}
+
 # Set working variables
 PROJECT=nagiosplug
 IN=${HOME}/tmp_snapshot
 OUT_SERVER="shell.sf.net"
-OUT="/home/groups/n/na/nagiosplug/htdocs/snapshot"
+#OUT="/home/groups/n/na/nagiosplug/htdocs/snapshot"
+OUT="~/test"
 CF="usf-cf-x86-linux-2"
 DS=`date -u +%Y%m%d%H%M`
 
-# Get compile server to do the work
-# Variables will be expanded locally before being run on $CF
-ssh $CF <<EOF
-PATH=$PATH
-[[ ! -d $IN ]] && mkdir -p $IN
-cd ${IN}
-if [[ -d $PROJECT ]] ; then
-       cd $PROJECT 
-       rm -f configure.in
-       cvs update
-else
-       cvs -z3 -d:pserver:anonymous@cvs.sourceforge.net:/cvsroot/nagiosplug co nagiosplug
-       cd $PROJECT
-fi
-
-sed 's/^VER=.*/VER=${DS}/;s/^REL=.*/REL=snapshot/' configure.in > configure.tmp
-mv configure.tmp configure.in
-aclocal
-autoheader
-autoconf
-automake
-autoreconf
-
-# Make the Nagiosplug dist tarball
-./configure
-make dist
-
-# End ssh
-EOF
+# Make dists for HEAD and any others in command parameters
+make_dist
+for i in $* ; do
+       make_dist $i
+done
 
 # Check for *.gz files locally (expect NFS between cf shell server and $CF)
 set -x
-cd $IN/$PROJECT
-ls *.gz > /dev/null 2>&1 || die "No file created"
+files=$(ls $IN/*/$PROJECT/*.gz 2>/dev/null)
+[[ -z $files ]] && die "No files created"
 ssh $OUT_SERVER "rm -f $OUT/*.gz"
-scp *.gz $OUT_SERVER:$OUT
-rm -f *.gz
+scp $files $OUT_SERVER:$OUT
+
+# Create MD5 sum
+ssh $OUT_SERVER << EOF
+cd $OUT
+md5sum *.gz > MD5SUM
+EOF
+
+rm -f $files