From e5a4e8e83b962aa3797ce839394efbdc227ca551 Mon Sep 17 00:00:00 2001 From: Roman Timushev Date: Thu, 1 Aug 2024 10:43:08 +0200 Subject: [PATCH] Fix fetching when no branch is specified (#148) While the configuration with `revision` and without a `branch` is not recommended, and fetching all branches is not very efficient, there are such `protofetch.toml` files in the wild, so we need to maintain the compatibility with them. --- src/git/repository.rs | 9 +++------ 1 file changed, 3 insertions(+), 6 deletions(-) diff --git a/src/git/repository.rs b/src/git/repository.rs index b5bda8d..57fda71 100644 --- a/src/git/repository.rs +++ b/src/git/repository.rs @@ -61,12 +61,9 @@ impl<'a> ProtoGitRepository<'a> { let mut refspecs = Vec::with_capacity(3); if let Revision::Pinned { revision } = &specification.revision { refspecs.push(format!("+refs/tags/{}:refs/tags/{}", revision, revision)); - // Some protofetch.toml files specify branch in the revision field, so we - // need to fetch branches as well to maintain compatibility. - refspecs.push(format!( - "+refs/heads/{}:refs/remotes/origin/{}", - revision, revision - )); + // Some protofetch.toml files specify branch in the revision field, + // or do not specify the branch at all, so we need to fetch all branches. + refspecs.push("+refs/heads/*:refs/remotes/origin/*".to_owned()); } if let Some(branch) = &specification.branch { refspecs.push(format!(