X-Git-Url: https://git.whamcloud.com/?p=fs%2Flustre-release.git;a=blobdiff_plain;f=lustrecvs;h=46168d6f69a71e1788a02142687d30b7939685f2;hp=f6f62eff2c547a315dade714e28aa8a5614a00f7;hb=7f8bac9b653d3b7b83429c0162061b0e9ab9edc6;hpb=23c0df84d5018abb8666107bd41acdb2e0423332 diff --git a/lustrecvs b/lustrecvs index f6f62ef..46168d6 100755 --- a/lustrecvs +++ b/lustrecvs @@ -1,4 +1,4 @@ -#!/bin/sh +#!/bin/bash LC_COLLATE="C" progname="${0##*/}" @@ -19,14 +19,22 @@ fatal () usage () { cat < +Usage: $progname where is a tag of the lustre-core module + and is an optional quoted timestamp suitable for cvs -D EOF } if [ -z "$LUSTRECVS_UPDATED" ] ; then echo "$progname: updating lustrecvs" - cvs up -l || fatal 1 "Error updating lustrecvs" + + # If checking out a specific tag, make sure all of the files here are also + # checked out with the same tag to avoid later changes breaking things. + case "$1" in + v*|b_release_*) TAG="-r $1" ;; + esac + + cvs update -l $TAG export LUSTRECVS_UPDATED=yes exec "$0" "$@" fi @@ -36,13 +44,14 @@ fi buildtag="HEAD" lustretag="$1" shift +pindate=$1 +shift if [ "$*" ] ; then usage >&2 exit 1 fi - case "$lustretag" in '') warn "a lustretag is required." @@ -54,10 +63,26 @@ case "$lustretag" in exit 0 ;; - b1_4_newconfig*) - buildtag="b_lnet" - ;; + # this is the branch table + # keep this list sorted alphabetically! + + # These use special build directories + + b1_4*) buildtag="b1_4" ;; + + b_release_1_4_6-patchless) buildtag="b1_4" ;; + b_release_1_4_7-test) buildtag="b_release_1_4_7" ;; + b_release*) buildtag=$lustretag ;; + + b_uoss) buildtag=$lustretag ;; + + # These releases did not get build tagged for them because they + # this build system didn't exist when they were tagged + v1_2_8|v1_4_0) + buildtag="b1_4" + ;; + v*) buildtag=$lustretag ;; # this is the branch table @@ -66,7 +91,6 @@ case "$lustretag" in *) buildtag="HEAD" ;; - esac error_modules= @@ -79,25 +103,85 @@ cvs_cmd () update="" if [ "$tag" = "HEAD" ] ; then - cotag="" - uptag="-A" + cotag="" + uptag="-A" elif [ "$tag" ] ; then - cotag="-r $tag" - uptag="-r $tag" + cotag="-r $tag" + uptag="-r $tag" else - # silently skip if no tag was specified - return + # silently skip if no tag was specified + return + fi + + # create a cvs date format that will survive shell expansion + if [ -n "$pindate" ]; then + datecmd=$(date -u +%s -d "$pindate") + datecmd="-D @$datecmd" + else + datecmd="" fi if [ -d "$dir" ] ; then - echo "$progname: Updating $dir to $tag" - ( cd "$dir" && cvs up -dP $uptag ) + echo "$progname: Updating $dir to $tag" + ( cd "$dir" && cvs up $datecmd -dAP $uptag ) + else + echo "$progname: Checking out $dir from $tag" + cvs co $datecmd -P $cotag -d "$dir" "$module" + fi + if [ $? != 0 ] ; then + error_modules="$dir $error_modules" + fi +} + +hg_cmd () +{ + dir="$1" + base_url="$2" + repository="$3" + + if [ ! "$repository" ]; then + return + fi + + if ! which hg &> /dev/null; then + cat <