| 1 | #!/bin/sh | 
|---|
| 2 |  | 
|---|
| 3 | # Run this from /tmp. | 
|---|
| 4 | CVSROOT=${CVSROOT:-/cvs/gcc} | 
|---|
| 5 | export CVSROOT | 
|---|
| 6 | /bin/rm -rf /tmp/$$ | 
|---|
| 7 | /bin/mkdir /tmp/$$ | 
|---|
| 8 | cd /tmp/$$ | 
|---|
| 9 |  | 
|---|
| 10 | # The path to cvs. | 
|---|
| 11 | CVS=${CVS:-/usr/local/bin/cvs} | 
|---|
| 12 |  | 
|---|
| 13 | # Compute the branches which we should update. | 
|---|
| 14 | $CVS co gcc/ChangeLog | 
|---|
| 15 | BRANCHES=`$CVS status -v gcc/ChangeLog \ | 
|---|
| 16 | | awk '{print $1;}' \ | 
|---|
| 17 | | egrep 'gcc-[0-9]+_[0-9]+-branch$'` | 
|---|
| 18 | # Always update the mainline. | 
|---|
| 19 | BRANCHES="${BRANCHES} HEAD" | 
|---|
| 20 |  | 
|---|
| 21 | # ARGS is passed to 'cvs co' | 
|---|
| 22 | CURR_DATE=`/bin/date +"%Y%m%d"` | 
|---|
| 23 |  | 
|---|
| 24 | # version is contained within a char* | 
|---|
| 25 | textstring_FILES="gcc/gcc/version.c gcc/gcc/ada/gnatvsn.ads gcc/gcc/f/version.c gcc/libf2c/libF77/Version.c gcc/libf2c/libI77/Version.c gcc/libf2c/libU77/Version.c" | 
|---|
| 26 |  | 
|---|
| 27 | # version is contained within a #define | 
|---|
| 28 | cppdefine_FILES="gcc/libstdc++-v3/include/bits/c++config" | 
|---|
| 29 |  | 
|---|
| 30 | # Assume all will go well. | 
|---|
| 31 | RESULT=0 | 
|---|
| 32 |  | 
|---|
| 33 | for BRANCH in $BRANCHES; do | 
|---|
| 34 | # Check out the files on the branch.  HEAD is a special case; if | 
|---|
| 35 | # you check out files with -r HEAD, CVS will not let you check | 
|---|
| 36 | # in changes. | 
|---|
| 37 | if test "$BRANCH" = HEAD; then | 
|---|
| 38 | ${CVS} co $textstring_FILES $cppdefine_FILES | 
|---|
| 39 | else | 
|---|
| 40 | ${CVS} co -r $BRANCH $textstring_FILES $cppdefine_FILES | 
|---|
| 41 | fi | 
|---|
| 42 |  | 
|---|
| 43 | # There are no files to commit yet. | 
|---|
| 44 | COMMIT_FILES="" | 
|---|
| 45 |  | 
|---|
| 46 | for file in $textstring_FILES; do | 
|---|
| 47 | if test -f $file; then | 
|---|
| 48 | /bin/sed  <$file >$file.new -e \ | 
|---|
| 49 | "s/\(.*\"[^ ]*\) [0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]/\1 ${CURR_DATE}/" | 
|---|
| 50 |  | 
|---|
| 51 | if /usr/bin/cmp -s $file $file.new; then | 
|---|
| 52 | rm -f $file.new | 
|---|
| 53 | else | 
|---|
| 54 | mv -f $file.new $file | 
|---|
| 55 | COMMIT_FILES="$COMMIT_FILES $file" | 
|---|
| 56 | fi | 
|---|
| 57 | fi | 
|---|
| 58 | done | 
|---|
| 59 |  | 
|---|
| 60 | for file in $cppdefine_FILES; do | 
|---|
| 61 | if test -f $file; then | 
|---|
| 62 | /bin/sed <$file >$file.new -e \ | 
|---|
| 63 | "s/\(#.*\) [0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]/\1 ${CURR_DATE}/" | 
|---|
| 64 |  | 
|---|
| 65 | if /usr/bin/cmp -s $file $file.new; then | 
|---|
| 66 | rm -f $file.new | 
|---|
| 67 | else | 
|---|
| 68 | mv -f $file.new $file | 
|---|
| 69 | COMMIT_FILES="$COMMIT_FILES $file" | 
|---|
| 70 | fi | 
|---|
| 71 | fi | 
|---|
| 72 | done | 
|---|
| 73 |  | 
|---|
| 74 | if test -n "$COMMIT_FILES" \ | 
|---|
| 75 | && ! ${CVS} commit -m "Daily bump." $COMMIT_FILES; then | 
|---|
| 76 | # If we could not commit the files, indicate failure. | 
|---|
| 77 | RESULT=1 | 
|---|
| 78 | fi | 
|---|
| 79 |  | 
|---|
| 80 | # Remove the files. | 
|---|
| 81 | rm -rf gcc | 
|---|
| 82 | done | 
|---|
| 83 |  | 
|---|
| 84 | /bin/rm -rf /tmp/$$ | 
|---|
| 85 | exit $RESULT | 
|---|
| 86 |  | 
|---|