aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorGravatar lancebord 2026-03-03 12:04:57 -0500
committerGravatar lancebord 2026-03-03 12:04:57 -0500
commit8d5a95c42f540769aeed0575f2bbc4f0742eb897 (patch)
treef06b5877125fbdd4a5afbca83f2cb7956d76201e /src
parentdeatch head for tagged (diff)
update pull to tag to not user merge logic
Diffstat (limited to 'src')
-rw-r--r--src/util.rs26
1 files changed, 8 insertions, 18 deletions
diff --git a/src/util.rs b/src/util.rs
index 9a75111..7950d2a 100644
--- a/src/util.rs
+++ b/src/util.rs
@@ -133,12 +133,6 @@ pub fn print_collected_packages(packages: &PackageList, message: &str) {
pub fn pull_latest_tag(path: &Path) -> Result<(), git2::Error> {
let repo = Repository::open(path)?;
- let head = repo.head()?;
- let branch = head
- .shorthand()
- .ok_or_else(|| git2::Error::from_str("Could not determine current branch"))?
- .to_string();
-
let mut callbacks = RemoteCallbacks::new();
callbacks.credentials(|_url, username_from_url, _allowed| {
Cred::ssh_key_from_agent(username_from_url.unwrap())
@@ -151,15 +145,14 @@ pub fn pull_latest_tag(path: &Path) -> Result<(), git2::Error> {
remote.fetch(&["refs/tags/*:refs/tags/*"], Some(&mut fetch_options), None)?;
let tag_names = repo.tag_names(None)?;
-
let mut latest_commit = None;
let mut latest_time = 0;
for name in tag_names.iter().flatten() {
let obj = repo.revparse_single(&format!("refs/tags/{}", name))?;
let commit = obj.peel_to_commit()?;
-
let time = commit.time().seconds();
+
if time > latest_time {
latest_time = time;
latest_commit = Some(commit);
@@ -168,21 +161,18 @@ pub fn pull_latest_tag(path: &Path) -> Result<(), git2::Error> {
let latest_commit = latest_commit.ok_or_else(|| git2::Error::from_str("No tags found"))?;
- let annotated = repo.find_annotated_commit(latest_commit.id())?;
- let (analysis, _) = repo.merge_analysis(&[&annotated])?;
+ let current_commit = repo.head()?.peel_to_commit()?;
- if analysis.is_fast_forward() {
- let refname = format!("refs/heads/{}", branch);
- let mut reference = repo.find_reference(&refname)?;
- reference.set_target(latest_commit.id(), "set to latest tag")?;
- repo.set_head_detached(latest_commit.id())?;
- repo.checkout_head(Some(CheckoutBuilder::default().force()))?;
- } else if !analysis.is_up_to_date() {
- println!("Cannot fast-forward to latest tag.");
+ if current_commit.id() == latest_commit.id() {
+ return Ok(());
}
+ repo.set_head_detached(latest_commit.id())?;
+ repo.checkout_head(Some(CheckoutBuilder::default().force()))?;
+
Ok(())
}
+
pub fn pull_repo(path: &Path) -> Result<(), git2::Error> {
let repo = Repository::open(path)?;