Isolate depot_tools update into a separate script.
Also, modify git-cl to also update depot_tools. Otherwise, the git-cl script never gets updated for folks that only use git-cl but not gclient. This fixes a bug ChromiumOS developers are currently seeing where there git-cl checkout is still pointing to src.chromium.org and not git.chromium.org. BUG=none TEST=Verified that git-cl help and gclient help work. Review URL: http://codereview.chromium.org/3817011 git-svn-id: svn://svn.chromium.org/chrome/trunk/tools/depot_tools@62948 0039d316-1c4b-4281-b951-d872f2087c98experimental/szager/collated-output
parent
37801da395
commit
2a94904744
@ -0,0 +1,68 @@
|
||||
#!/bin/bash
|
||||
# Copyright (c) 2010 The Chromium Authors. All rights reserved.
|
||||
# Use of this source code is governed by a BSD-style license that can be
|
||||
# found in the LICENSE file.
|
||||
|
||||
# This script will try to sync the bootstrap directories and then defer control.
|
||||
|
||||
base_dir=$(dirname "$0")
|
||||
|
||||
# Test git and git --version.
|
||||
function test_git {
|
||||
local GITV="$(git --version)" || {
|
||||
echo "git isn't installed, please install it"
|
||||
exit 1
|
||||
}
|
||||
|
||||
GITV="${GITV##* }" # Only examine last word (i.e. version number)
|
||||
local GITD=( ${GITV//./ } ) # Split version number into decimals
|
||||
if ((GITD[0] < 1 || (GITD[0] == 1 && GITD[1] < 6) )); then
|
||||
echo "git version is ${GITV}, please update to a version later than 1.6"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
# Test git svn and git svn --version.
|
||||
function test_git_svn {
|
||||
local GITV="$(git svn --version)" || {
|
||||
echo "git-svn isn't installed, please install it"
|
||||
exit 1
|
||||
}
|
||||
|
||||
GITV="${GITV#* version }" # git svn --version has extra output to remove.
|
||||
GITV="${GITV% (svn*}"
|
||||
local GITD=( ${GITV//./ } ) # Split version number into decimals
|
||||
if ((GITD[0] < 1 || (GITD[0] == 1 && GITD[1] < 6) )); then
|
||||
echo "git version is ${GITV}, please update to a version later than 1.6"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
|
||||
# Update git checkouts prior the cygwin check, we don't want to use msysgit.
|
||||
if [ "X$DEPOT_TOOLS_UPDATE" != "X0" -a -e "$base_dir/.git" ]
|
||||
then
|
||||
cd $base_dir
|
||||
test_git_svn
|
||||
# work around a git-svn --quiet bug
|
||||
OUTPUT=`git svn rebase -q -q`
|
||||
if [[ ! "$OUTPUT" =~ Current.branch ]]; then
|
||||
echo $OUTPUT
|
||||
fi
|
||||
cd - > /dev/null
|
||||
fi
|
||||
|
||||
# Use the batch file as an entry point if on cygwin.
|
||||
if [ "${OSTYPE}" = "cygwin" -a "${TERM}" != "xterm" ]; then
|
||||
${base_dir}/gclient.bat "$@"
|
||||
exit
|
||||
fi
|
||||
|
||||
|
||||
# We're on POSIX (not cygwin). We can now safely look for svn checkout.
|
||||
if [ "X$DEPOT_TOOLS_UPDATE" != "X0" -a -e "$base_dir/.svn" ]
|
||||
then
|
||||
# Update the bootstrap directory to stay up-to-date with the latest
|
||||
# depot_tools.
|
||||
svn -q up "$base_dir"
|
||||
fi
|
Loading…
Reference in New Issue