summaryrefslogtreecommitdiff
path: root/libgo/merge.sh
diff options
context:
space:
mode:
authorIan Lance Taylor <ian@gcc.gnu.org>2011-12-02 19:27:25 +0000
committerIan Lance Taylor <ian@gcc.gnu.org>2011-12-02 19:27:25 +0000
commitbfa9b58039ceacb1bae803fbbfb049b93540f2a7 (patch)
treea7d9295b44f2312e0262b6f8f72055204cc6de2a /libgo/merge.sh
parentb3c85d792d9ab861fb5c44c4569729204ef64470 (diff)
downloadgcc-bfa9b58039ceacb1bae803fbbfb049b93540f2a7.tar.gz
merge.sh: Add files, add revision option, handle middle dot.
From-SVN: r181937
Diffstat (limited to 'libgo/merge.sh')
-rwxr-xr-xlibgo/merge.sh44
1 files changed, 35 insertions, 9 deletions
diff --git a/libgo/merge.sh b/libgo/merge.sh
index 660a5f90063..638182b7c9a 100755
--- a/libgo/merge.sh
+++ b/libgo/merge.sh
@@ -25,10 +25,15 @@ if ! test -f MERGE; then
exit 1
fi
-if test $# -ne 1; then
- echo 1>&2 "merge.sh: Usage: merge.sh mercurial-repository"
+rev=weekly
+case $# in
+1) ;;
+2) rev=$2 ;;
+*)
+ echo 1>&2 "merge.sh: Usage: merge.sh mercurial-repository [revision]"
exit 1
-fi
+ ;;
+esac
repository=$1
@@ -38,9 +43,9 @@ rm -rf ${OLDDIR}
hg clone -r ${old_rev} ${repository} ${OLDDIR}
rm -rf ${NEWDIR}
-hg clone -u weekly ${repository} ${NEWDIR}
+hg clone -u ${rev} ${repository} ${NEWDIR}
-new_rev=`cd ${NEWDIR} && hg log -r weekly | sed 1q | sed -e 's/.*://'`
+new_rev=`cd ${NEWDIR} && hg log -r ${rev} | sed 1q | sed -e 's/.*://'`
merge() {
name=$1
@@ -146,12 +151,33 @@ done
done
done
-runtime="goc2c.c mcache.c mcentral.c mfinal.c mfixalloc.c mgc0.c mheap.c msize.c malloc.h malloc.goc mprof.goc"
+runtime="chan.c cpuprof.c goc2c.c lock_futex.c lock_sema.c mcache.c mcentral.c mfinal.c mfixalloc.c mgc0.c mheap.c msize.c proc.c runtime.c runtime.h malloc.h malloc.goc mprof.goc runtime1.goc sema.goc sigqueue.goc string.goc"
for f in $runtime; do
oldfile=${OLDDIR}/src/pkg/runtime/$f
- newfile=${NEWDIR}/src/pkg/runtime/$f
- libgofile=runtime/$f
- merge $f ${oldfile} ${newfile} ${libgofile}
+ if test -f ${oldfile}; then
+ sed -e 's/·/_/g' < ${oldfile} > ${oldfile}.tmp
+ oldfile=${oldfile}.tmp
+ newfile=${NEWDIR}/src/pkg/runtime/$f
+ sed -e 's/·/_/g' < ${newfile} > ${newfile}.tmp
+ newfile=${newfile}.tmp
+ libgofile=runtime/$f
+ merge $f ${oldfile} ${newfile} ${libgofile}
+ fi
+done
+
+runtime2="linux/thread.c thread-linux.c linux/mem.c mem.c"
+echo $runtime2 | while read from; do
+ read to
+ oldfile=${OLDDIR}/src/pkg/runtime/$from
+ if test -f ${oldfile}; then
+ sed -e 's/·/_/g' < ${oldfile} > ${oldfile}.tmp
+ oldfile=${oldfile}.tmp
+ newfile=${NEWDIR}/src/pkg/runtime/$from
+ sed -e 's/·/_/g' < ${newfile} > ${newfile}.tmp
+ newfile=${newfile}.tmp
+ libgofile=runtime/$to
+ merge $f ${oldfile} ${newfile} ${libgofile}
+ fi
done
(cd ${OLDDIR}/src/pkg && find . -name '*.go' -print) | while read f; do