vaadin-framework/scripts/merge-all.sh
Johannes Dahlström f315689eff Bugfix: concatenate merge commands properly
svn changeset:22804/svn branch:6.8
2012-01-27 16:26:09 +00:00

65 lines
1.2 KiB
Bash
Executable File

#!/bin/bash
FROM=$1
AUTOMERGE=$2
if [ "$FROM" = "" ]
then
echo "Usage: $0 <from version> [automerge]"
exit 3
fi
if [ "$AUTOMERGE" = "automerge" ]
then
AUTOCOMMIT="autocommit"
fi
svn up
localchanges=`svn stat|wc -l`
if [ "$localchanges" != "0" ] && [ "$IGNOREDIRTY" != "ignoredirty" ]
then
echo "You must have a clean working space copy"
exit 4
fi
currentrepowithoutversion=`svn info|grep URL|sed "s/URL: //"|sed "s/\/[^\/]*$//"`
sourceurl="$currentrepowithoutversion/$FROM"
unmerged=`svn mergeinfo --show-revs eligible $sourceurl|sed "s/r//g"`
if [ "$unmerged" = "" ]
then
echo "No changes to merge"
exit 0
fi
echo "Unmerged changes"
echo "================"
for revision in $unmerged
do
echo -n "[$revision] "
svn log $sourceurl -r $revision --xml|grep "<msg>"|sed "s/<msg>//"|sed "s/<\/msg>//"
done
cmd=""
for revision in $unmerged
do
thiscmd=`dirname $0`"/merge.sh $FROM $revision $AUTOCOMMIT $IGNOREDIRTY"
cmd="$cmd $thiscmd && "
if [ "$AUTOMERGE" = "automerge" ]
then
echo "Merging [$revision]..."
$thiscmd
if [ "$?" != "0" ]
then
echo "Merge of [$revision] failed, aborting..."
exit 1
fi
fi
done
cmd="$cmd true"
if [ "$AUTOMERGE" != "automerge" ]
then
echo
echo "Merge command:"
echo
echo $cmd
fi
exit 0