mirror of
https://gerrit.googlesource.com/git-repo
synced 2025-01-02 16:14:25 +00:00
Ensure HEAD is correct when skipping remote fetch
A recent optimization (2fb6466f79
) skips
performing a remote fetch if we already know we have the sha1 we want.
However, that optimization skipped initialization steps that ensure HEAD
points to the correct sha1. This change makes sure not to skip those
steps.
Here is an example of how to test this change:
"""""""""
url=<manifest url>
branch1=<branch name>
branch2=<branch name>
project=<project with revision set to different sha1 in each branch>
repo init -u $url -b $branch1 --mirror
repo sync $project
first=$(cd $project.git; git rev-parse HEAD)
repo init -b $branch2
repo sync $project
second=$(cd platform/build.git; git rev-parse HEAD)
if [[ $first == $second ]]
then
echo 'problem!'
else
echo 'no problem!'
fi
"""""""""
This commit is contained in:
parent
f2af756425
commit
666d534636
17
project.py
17
project.py
@ -1103,17 +1103,12 @@ class Project(object):
|
|||||||
elif self.manifest.default.sync_c:
|
elif self.manifest.default.sync_c:
|
||||||
current_branch_only = True
|
current_branch_only = True
|
||||||
|
|
||||||
is_sha1 = False
|
has_sha1 = ID_RE.match(self.revisionExpr) and self._CheckForSha1()
|
||||||
if ID_RE.match(self.revisionExpr) is not None:
|
if (not has_sha1 #Need to fetch since we don't already have this revision
|
||||||
is_sha1 = True
|
and not self._RemoteFetch(initial=is_new, quiet=quiet, alt_dir=alt_dir,
|
||||||
if is_sha1 and self._CheckForSha1():
|
current_branch_only=current_branch_only,
|
||||||
# Don't need to fetch since we already have this revision
|
no_tags=no_tags)):
|
||||||
return True
|
return False
|
||||||
|
|
||||||
if not self._RemoteFetch(initial=is_new, quiet=quiet, alt_dir=alt_dir,
|
|
||||||
current_branch_only=current_branch_only,
|
|
||||||
no_tags=no_tags):
|
|
||||||
return False
|
|
||||||
|
|
||||||
if self.worktree:
|
if self.worktree:
|
||||||
self._InitMRef()
|
self._InitMRef()
|
||||||
|
Loading…
Reference in New Issue
Block a user