diff options
author | Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE> | 2010-09-13 14:44:21 +0000 |
---|---|---|
committer | Rainer Orth <ro@gcc.gnu.org> | 2010-09-13 14:44:21 +0000 |
commit | 97075d3bf181c4b83ae157dac44062b565d7fb68 (patch) | |
tree | 084b74a80a55b4efa949af3fa55c7f987e2babdb /contrib | |
parent | 2f434b97f176acb60b345d2d135a0e15fcb5c5b7 (diff) | |
download | gcc-97075d3bf181c4b83ae157dac44062b565d7fb68.tar.gz |
* gcc_update: Handle hg, too.
From-SVN: r164246
Diffstat (limited to 'contrib')
-rw-r--r-- | contrib/ChangeLog | 4 | ||||
-rwxr-xr-x | contrib/gcc_update | 160 |
2 files changed, 107 insertions, 57 deletions
diff --git a/contrib/ChangeLog b/contrib/ChangeLog index 5175d512d52..26c446c3be7 100644 --- a/contrib/ChangeLog +++ b/contrib/ChangeLog @@ -1,3 +1,7 @@ +2010-09-13 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE> + + * gcc_update: Handle hg, too. + 2010-07-08 Eric Botcazou <ebotcazou@adacore.com> * make_sunver.pl: Remove extra whitespace in regexp. diff --git a/contrib/gcc_update b/contrib/gcc_update index cfae86a50c6..8192d811102 100755 --- a/contrib/gcc_update +++ b/contrib/gcc_update @@ -1,10 +1,11 @@ #! /bin/sh # -# Update a local Subversion tree from the GCC repository, with an emphasis -# on treating generated files correctly, so that autoconf, gperf et -# al are not required for the ``end'' user. +# Update a local Subversion, Git or Mercurial tree from the GCC +# repository, with an emphasis on treating generated files correctly, so +# that autoconf, gperf et al are not required for the ``end'' user. # -# (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation +# (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2009, 2010 +# Free Software Foundation # Originally by Gerald Pfeifer <pfeifer@dbai.tuwien.ac.at>, August 1998. # # This script is Free Software, and it can be copied, distributed and @@ -12,8 +13,8 @@ # its license can be downloaded from http://www.gnu.org/copyleft/gpl.html # # -# By default all command-line options are passed to `svn update` in -# addition to $UPDATE_OPTIONS (defined below). If the first parameter +# By default all command-line options are passed to `svn update` or `hg/git +# pull` in addition to $UPDATE_OPTIONS (defined below). If the first parameter # reads --nostdflags, $UPDATE_OPTIONS as well as this parameter itself # are omitted. # @@ -38,9 +39,7 @@ # contrib/gcc_update --list -# SVN command -GCC_SVN=${GCC_SVN-${SVN-svn}} -# Default options used when updating via SVN (none). +# Default options used when updating (none). UPDATE_OPTIONS="" # Set the locale to C to make this script work for users with foreign @@ -245,14 +244,18 @@ p esac -is_git=0 -# Check whether this indeed looks like a local SVN tree. +# Check for known version control systems. if [ -d .git ]; then GCC_GIT=${GCC_GIT-${GIT-git}} - GCC_SVN="true -" - is_git=1 -elif [ ! -d .svn ]; then - echo "This does not seem to be a GCC SVN tree!" + vcs_type="git" +elif [ -d .hg ]; then + GCC_HG=${GCC_HG-${HG-hg}} + vcs_type="hg" +elif [ -d .svn ]; then + GCC_SVN=${GCC_SVN-${SVN-svn}} + vcs_type="svn" +else + echo "This does not seem to be a GCC GIT/HG/SVN tree!" exit fi @@ -263,53 +266,96 @@ else set -- $UPDATE_OPTIONS ${1+"$@"} fi -if [ $is_git -eq 0 ]; then -chat "Updating SVN tree" +case $vcs_type in + git) + chat "Updating GIT tree" -$GCC_SVN ${silent+-q} --non-interactive update ${1+"$@"} -if [ $? -ne 0 ]; then - (touch_files_reexec) - echo "SVN update of full tree failed." >&2 - exit 1 -fi + $GCC_GIT diff --quiet --exit-code HEAD + if [ $? -ne 0 ]; then + echo "Attempting to update a dirty git tree!" >&2 + echo "Commit or stash your changes first and retry." >&2 + exit 1 + fi -rm -f LAST_UPDATED gcc/REVISION + $GCC_GIT pull ${silent+-q} --rebase ${1+"$@"} + if [ $? -ne 0 ]; then + (touch_files_reexec) + echo "git pull of full tree failed." >&2 + exit 1 + fi -revision=`svn info | awk '/Revision:/ { print $2 }'` -branch=`svn info | sed -ne "/URL:/ { -s,.*/trunk,trunk, -s,.*/branches/,, -s,.*/tags/,, -p -}"` + revision=`$GCC_GIT log -n1 --pretty=%p:%t:%H` + branch=`$GCC_GIT name-rev --name-only HEAD || :` + ;; + + hg) + chat "Updating HG tree" + + # Add -q so untracked files aren't listed. + if [ `$GCC_HG status -q | wc -l` -gt 0 ]; then + echo "Attempting to update a dirty hg tree!" >&2 + echo "Commit or revert your changes first and retry." >&2 + exit 1 + fi + + # Check for mq extension. mq patches must be popped so tip has + # been converted from the SVN tree. + if [ -d .hg/patches ] && [ `$GCC_HG qapplied | wc -l` -gt 0 ]; then + # FIXME: Perhaps pop queue instead? We could do that since we + # know the tree is clean. + echo "Attempting to update hg tree with mq patches applied!" >&2 + echo "Pop your patches first and retry." >&2 + exit 1 + fi + + # Update tree, but make sure to only pull the default branch. + # Otherwise all branches in the upstream repo are added, even if + # only a single one has been cloned. + $GCC_HG pull -u ${silent+-q} -r`$GCC_HG branch` ${1+"$@"} + if [ $? -ne 0 ]; then + (touch_files_reexec) + echo "hg pull of full tree failed." >&2 + exit 1 + fi + + # Extract SVN revision corresponding to tip, as stored by hg convert. + # Before hg 1.4.3, there's no template keyword corresponding to the + # extra: tag, so need to use hg log --debug to extract the info. + revision=`$GCC_HG log --debug -l1 | \ + sed -ne "/^extra:.*convert_revision=svn:/ { + s%^.*@%% + p + }"` + branch=`$GCC_HG branch` + # trunk in SVN parlance shows up as default branch in hg. + [ x$branch = x"default" ] && branch="trunk" + ;; + + svn) + chat "Updating SVN tree" + + $GCC_SVN ${silent+-q} --non-interactive update ${1+"$@"} + if [ $? -ne 0 ]; then + (touch_files_reexec) + echo "SVN update of full tree failed." >&2 + exit 1 + fi + + revision=`svn info | awk '/Revision:/ { print $2 }'` + branch=`svn info | sed -ne "/URL:/ { + s,.*/trunk,trunk, + s,.*/branches/,, + s,.*/tags/,, + p + }"` + ;; +esac + +rm -f LAST_UPDATED gcc/REVISION { - date - echo "`TZ=UTC date` (revision $revision)" + date + echo "`TZ=UTC date` (revision $revision)" } > LAST_UPDATED - echo "[$branch revision $revision]" > gcc/REVISION -else - chat "Updating GIT tree" - $GCC_GIT diff --quiet --exit-code HEAD - if [ $? -ne 0 ]; then - echo "Attempting to update a dirty git tree!" >&2 - echo "Commit or stash your changes first and retry." >&2 - exit 1 - fi - $GCC_GIT pull ${silent+-q} --rebase ${1+"$@"} - if [ $? -ne 0 ]; then - (touch_files_reexec) - echo "git pull of full tree failed." >&2 - exit 1 - fi - rm -f LAST_UPDATED gcc/REVISION - revision=`$GCC_GIT log -n1 --pretty=%p:%t:%H` - branch=`$GCC_GIT name-rev --name-only HEAD || :` - { - date - echo "`TZ=UTC date` (revision $revision)" - } > LAST_UPDATED - echo "[$branch revision $revision]" > gcc/REVISION -fi touch_files_reexec |