summaryrefslogtreecommitdiffstats
path: root/subcmds/sync.py
diff options
context:
space:
mode:
authorDaniel Andersson <daniel.r.andersson@volvocars.com>2022-04-01 12:55:38 +0200
committerMike Frysinger <vapier@google.com>2022-04-08 21:06:37 +0000
commitd52ca421d52c75837d1614ec54549569f354b7ec (patch)
treec8f18a193433680c03572d55b46d9c322c70427b /subcmds/sync.py
parenta2ff20dd209fe3eb091cdf1bddd4672f86b76bd8 (diff)
downloadgit-repo-d52ca421d52c75837d1614ec54549569f354b7ec.tar.gz
sync: respect `sync-c` manifest option
The documentation states that a `sync-c` attribute in the manifest file can set a default for whether only the current branch should be fetched or all branches. This seems to have been broken for some time. Commit 7356114 introduced the `--no-current-branch` CLI option and relied on getting `None` via `optparse` if neither `--current-branch` nor `--no-current-branch` was set to distinguish it from a boolean value. If `None` was received, it would read the value from the manifest option `sync-c`. The parsing went through the utility function `_GetCurrentBranchOnly` which returned `True` if `--current-branch` had been given on the command-line, or fell back on the "superproject" setting, which would either return `True` or `None`. This would incorrectly make `repo` fall back to the manifest setting even if the user had given `--no-current-branch` if no superproject was requested -- the manifest became "too powerful": Command-line Using superproject → `current_branch_only` ------------ ------------------ ----------------------- No From manifest Yes True --current-branch No True --current-branch Yes True --no-current-branch No From manifest ← wrong --no-current-branch Yes True In commit 0cb6e92 the superproject configuration value reading changed from something that could return `None` to something that always returned a boolean. If it returned `False`, this would then incorrectly make `repo` ignore the manifest option even if neither `--current-branch` nor `--no-current-branch` had been given. The manifest default became useless: Command-line Using superproject → `current_branch_only` ------------ ------------------ ----------------------- No False ← wrong Yes True --current-branch No True --current-branch Yes True --no-current-branch No False --no-current-branch Yes True By swapping the order in which the command-line option target and the superproject setting is evaluated, things should work as documented: Command-line Using superproject → `current_branch_only` ------------ ------------------ ----------------------- No From manifest Yes True --current-branch No True --current-branch Yes True --no-current-branch No False --no-current-branch Yes True Change-Id: I933c232d2fbecc6b9bdc364ebac181798bce9175 Tested-by: Daniel Andersson <daniel.r.andersson@volvocars.com> Reviewed-on: https://gerrit-review.googlesource.com/c/git-repo/+/334270 Reviewed-by: Mike Frysinger <vapier@google.com>
Diffstat (limited to 'subcmds/sync.py')
-rw-r--r--subcmds/sync.py9
1 files changed, 7 insertions, 2 deletions
diff --git a/subcmds/sync.py b/subcmds/sync.py
index baee6b23..9e783205 100644
--- a/subcmds/sync.py
+++ b/subcmds/sync.py
@@ -280,8 +280,13 @@ later is required to fix a server side protocol bug.
280 return branch 280 return branch
281 281
282 def _GetCurrentBranchOnly(self, opt): 282 def _GetCurrentBranchOnly(self, opt):
283 """Returns True if current-branch or use-superproject options are enabled.""" 283 """Returns whether current-branch or use-superproject options are enabled.
284 return opt.current_branch_only or git_superproject.UseSuperproject(opt, self.manifest) 284
285 Returns:
286 True if a superproject is requested, otherwise the value of the
287 current_branch option (True, False or None).
288 """
289 return git_superproject.UseSuperproject(opt, self.manifest) or opt.current_branch_only
285 290
286 def _UpdateProjectsRevisionId(self, opt, args, load_local_manifests, superproject_logging_data): 291 def _UpdateProjectsRevisionId(self, opt, args, load_local_manifests, superproject_logging_data):
287 """Update revisionId of every project with the SHA from superproject. 292 """Update revisionId of every project with the SHA from superproject.