From 403b64edf468204597559cf61b346b93af9af232 Mon Sep 17 00:00:00 2001 From: David Pursehouse Date: Mon, 27 Apr 2015 10:41:33 +0900 Subject: [PATCH] Don't append branch to fetch spec when syncing to a mirror Appending the branch to the fetch spec causes sync of a mirror to fail for projects that don't have an explicit revision specified, and don't have a branch of the same name as the default revision. For example, a manifest defining a default revision: having a project without an explicit revision: and not having a branch named "master", will cause repo sync to fail for that project with the error: Couldn't find remote ref refs/heads/master Modify the logic to not append the branch onto the fetch spec when syncing to a mirror. Change-Id: I5c4457bd125519abf27abe682dea62ad708978c9 --- project.py | 25 +++++++++++++------------ 1 file changed, 13 insertions(+), 12 deletions(-) diff --git a/project.py b/project.py index e76d6394..6217aec8 100644 --- a/project.py +++ b/project.py @@ -1853,18 +1853,19 @@ class Project(object): spec.append('tag') spec.append(tag_name) - branch = self.revisionExpr - if is_sha1 and depth: - # Shallow checkout of a specific commit, fetch from that commit and not - # the heads only as the commit might be deeper in the history. - spec.append(branch) - else: - if is_sha1: - branch = self.upstream - if branch is not None and branch.strip(): - if not branch.startswith('refs/'): - branch = R_HEADS + branch - spec.append(str((u'+%s:' % branch) + remote.ToLocal(branch))) + if not self.manifest.IsMirror: + branch = self.revisionExpr + if is_sha1 and depth: + # Shallow checkout of a specific commit, fetch from that commit and not + # the heads only as the commit might be deeper in the history. + spec.append(branch) + else: + if is_sha1: + branch = self.upstream + if branch is not None and branch.strip(): + if not branch.startswith('refs/'): + branch = R_HEADS + branch + spec.append(str((u'+%s:' % branch) + remote.ToLocal(branch))) cmd.extend(spec) shallowfetch = self.config.GetString('repo.shallowfetch')