summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xbin/snapshot46
1 files changed, 32 insertions, 14 deletions
diff --git a/bin/snapshot b/bin/snapshot
index 8aaac84..e2b3b55 100755
--- a/bin/snapshot
+++ b/bin/snapshot
@@ -38,6 +38,7 @@ fi
#
# Command options
cmd="all"
+test_opt=""
errcode=0
echo '$#=' $# '$*="' $* '"'
while [ $# -gt 0 ] ; do
@@ -53,6 +54,10 @@ while [ $# -gt 0 ] ; do
cmdtest="test"
cmd=""
;;
+ srcdir)
+ #use srcdir option for test
+ srcdir="yes"
+ ;;
release)
cmdrel="release"
cmd=""
@@ -93,12 +98,15 @@ done
if [ "$cmd" = help ]; then
set -
- echo "Usage: $0 [all] [checkout] [test] [release] [help] [hdf4 <hdf4lib_path>] [archive <arch_path> ]"
+ echo "Usage: $0 [all] [checkout] [test] [srcdir] [release] [help] [hdf4 <hdf4lib_path>] [archive <arch_path> ]"
echo " all: Run all commands (checkout, test & release)"
echo " [Default is all]"
echo " checkout: Run cvs checkout"
echo " test: Run test"
echo " release: Run release"
+ echo " srcdir: Use srcdir option (does not imply other commands)"
+ echo ' "snapshot srcdir" is equivalent to "snapshot srcdir all"'
+ echo ' "snapshot srcdir checkout" is equivalent to "snapshot checkout"'
echo " help: Print this message"
echo " hdf4 <hdf4lib_path>:"
echo " Use <hdf4lib_path> as the HDF4LIB locations"
@@ -118,6 +126,8 @@ CONFIGURE="./configure $HDF4LIB"
snapshot=yes
COMPARE=${HOME}/hdf5-snapshots
+CURRENT=${COMPARE}/current
+PREVIOUS=${COMPARE}/previous
#=============================
# Run CVS checkout
@@ -129,7 +139,7 @@ if [ "$cmd" = "all" -o -n "$cmdcheckout" ]; then
test -d ${COMPARE} || mkdir -p ${COMPARE} || exit 1
# Check out the current version from CVS
- cvs -Q co -d ${COMPARE}/current hdf5 || exit 1
+ cvs -Q co -d ${CURRENT} hdf5 || exit 1
fi # Do CVS checkout
@@ -137,9 +147,17 @@ fi # Do CVS checkout
# Run Test the HDF5 library
#=============================
if [ "$cmd" = "all" -o -n "$cmdtest" ]; then
+ # setup if srcdir is used.
+ if [ -z "$srcdir" ]; then
+ TESTDIR=${CURRENT}
+ else
+ #create TESTDIR if not exist yet
+ TESTDIR=${COMPARE}/TestDir/`hostname`
+ test -d ${TESTDIR} || mkdir ${TESTDIR}
+ fi
# Make sure current version exists and is clean
- if [ -d ${COMPARE}/current ]; then
- (cd ${COMPARE}/current && ${MAKE} distclean)
+ if [ -d ${TESTDIR} ]; then
+ (cd ${TESTDIR} && ${MAKE} distclean)
else
errcode=$?
snapshot=no
@@ -148,13 +166,13 @@ if [ "$cmd" = "all" -o -n "$cmdtest" ]; then
# Compare it with the previous version. Compare only files listed in
# the MANIFEST plus the MANIFEST itself.
- if [ -d ${COMPARE}/previous ]; then
- if (diff -c ${COMPARE}/previous/MANIFEST ${COMPARE}/current/MANIFEST); then
+ if [ -d ${PREVIOUS} ]; then
+ if (diff -c ${PREVIOUS}/MANIFEST ${CURRENT}/MANIFEST); then
snapshot=no
- for src in `grep '^\.' ${COMPARE}/current/MANIFEST|expand|cut -f1 -d' '`; do
+ for src in `grep '^\.' ${CURRENT}/MANIFEST|expand|cut -f1 -d' '`; do
diff -I H5_VERS_RELEASE -I " released on " \
-I " currently under development" \
- ${COMPARE}/previous/$src ${COMPARE}/current/$src || \
+ ${PREVIOUS}/$src ${CURRENT}/$src || \
snapshot=yes
# Don't break because we want to see all the diffs.
done
@@ -163,8 +181,8 @@ if [ "$cmd" = "all" -o -n "$cmdtest" ]; then
# Make sure all the serial tests work.
if [ "$snapshot" = "yes" ]; then
- if (cd ${COMPARE}/current; \
- ${CONFIGURE}; \
+ if (cd ${TESTDIR}; \
+ ${srcdir:+${CURRENT}/}${CONFIGURE}; \
${MAKE} check); then
:
else
@@ -181,12 +199,12 @@ fi # Test the HDF5 library
#=============================
if [ "$cmd" = "all" -o -n "$cmdrel" ]; then
if [ "$snapshot" = "yes" ]; then
- (cd ${COMPARE}/current; ${MAKE} distclean)
+ (cd ${CURRENT}; ${MAKE} distclean)
(
# Turn on exit on error in the sub-shell so that it does not
# cvs commit if errors encounter here.
set -e
- cd ${COMPARE}/current
+ cd ${CURRENT}
bin/release -d $ARCHIVES $METHODS
RELEASE_VERSION="`perl bin/h5vers -v`"
perl bin/h5vers -i
@@ -196,8 +214,8 @@ if [ "$cmd" = "all" -o -n "$cmdrel" ]; then
fi
# Replace the previous version with the current version.
- rm -rf ${COMPARE}/previous
- mv ${COMPARE}/current ${COMPARE}/previous
+ rm -rf ${PREVIOUS}
+ mv ${CURRENT} ${PREVIOUS}
fi #Release snapshot
exit $errcode