#!/bin/sh
+LC_COLLATE="C"
progname="${0##*/}"
warn ()
usage ()
{
cat <<EOF
-Usage: $progname lustretag
- where lustretag is a tag of the lustre-core module
+Usage: $progname <lustretag>
+ where <lustretag> is a tag of the lustre-core module
EOF
}
-# portalstag="HEAD"
+if [ -z "$LUSTRECVS_UPDATED" ] ; then
+ echo "$progname: updating lustrecvs"
+ cvs up -l || fatal 1 "Error updating lustrecvs"
+ export LUSTRECVS_UPDATED=yes
+ exec "$0" "$@"
+fi
+
+[ "$1" = "-r" ] && shift
+
buildtag="HEAD"
-portalstag="HEAD"
lustretag="$1"
-libsysiotag="head_0607"
+shift
+
+if [ "$*" ] ; then
+ usage >&2
+ exit 1
+fi
+
case "$lustretag" in
'')
exit 0
;;
- # this is the branch table
- # keep this list sorted alphabetically!
+ b1_4_newconfig*|b_newconfig_rdmarouting*|b1_4_mountconf*)
+ buildtag="b_lnet"
+ ;;
- b1_4_bgl)
- portalstag="b1_4_bgl"
- ;;
+ v*) buildtag=$lustretag ;;
- b_newsysio | b_sec)
- libsysiotag="head_0809"
- ;;
+ # this is the branch table
+ # keep this list sorted alphabetically!
- b_port_step)
- portalstag="b_port_step"
+ *)
+ buildtag="HEAD"
;;
esac
+error_modules=
cvs_cmd ()
{
- local dir="$1"
- local module="$2"
- local tag="$3"
- local cvstag=""
+ dir="$1"
+ module="$2"
+ tag="$3"
+ cotag=""
+ update=""
- if [ "$tag" != "HEAD" ] ; then
- cvstag="-r $tag"
+ if [ "$tag" = "HEAD" ] ; then
+ cotag=""
+ uptag="-A"
+ elif [ "$tag" ] ; then
+ cotag="-r $tag"
+ uptag="-r $tag"
+ else
+ # silently skip if no tag was specified
+ return
fi
if [ -d "$dir" ] ; then
echo "$progname: Updating $dir to $tag"
- ( cd "$dir" && cvs up $cvstag )
+ ( cd "$dir" && cvs up -dP $uptag )
else
echo "$progname: Checking out $dir from $tag"
- cvs co $cvstag -d "$dir" "$module"
+ cvs co -P $cotag -d "$dir" "$module"
+ fi
+ if [ $? != 0 ] ; then
+ error_modules="$dir $error_modules"
fi
}
cvs_cmd build lustre-build "$buildtag"
-cvs_cmd libsysio libsysio "$libsysiotag"
-cvs_cmd portals portals "$portalstag"
-cvs_cmd lustre lustre-core "$lustretag"
+
+if [ -f build/buildcvs ] ; then
+ . build/buildcvs
+else
+ fatal 1 "build/buildcvs does not exist; not updating other modules."
+fi
+
+if [ "$error_modules" ] ; then
+ fatal 1 "There were errors checking out the following directories: $error_modules"
+fi