From 271a68b3b0ce6707130c77b5b009b3457d6b9d3b Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Mon, 22 Jul 2013 15:57:36 -0400 Subject: [PATCH] Update Gitblit reflog on branch delete from UI if Gitblit has an existing reflog --- src/main/java/com/gitblit/wicket/panels/BranchesPanel.java | 23 +++++++++++++++++++---- 1 files changed, 19 insertions(+), 4 deletions(-) diff --git a/src/main/java/com/gitblit/wicket/panels/BranchesPanel.java b/src/main/java/com/gitblit/wicket/panels/BranchesPanel.java index 1262077..7aa185b 100644 --- a/src/main/java/com/gitblit/wicket/panels/BranchesPanel.java +++ b/src/main/java/com/gitblit/wicket/panels/BranchesPanel.java @@ -37,7 +37,9 @@ import com.gitblit.models.RefModel; import com.gitblit.models.RepositoryModel; import com.gitblit.models.UserModel; +import com.gitblit.utils.CommitCache; import com.gitblit.utils.JGitUtils; +import com.gitblit.utils.RefLogUtils; import com.gitblit.utils.StringUtils; import com.gitblit.wicket.GitBlitWebSession; import com.gitblit.wicket.WicketUtils; @@ -191,15 +193,28 @@ } return; } - boolean success = JGitUtils.deleteBranchRef(r, entry.getName()); - r.close(); + final String branch = entry.getName(); + boolean success = JGitUtils.deleteBranchRef(r, branch); if (success) { - info(MessageFormat.format("Branch \"{0}\" deleted", entry.displayName)); + // clear commit cache + CommitCache.instance().clear(repositoryModel.name, branch); + + // optionally update reflog + if (RefLogUtils.hasRefLogBranch(r)) { + UserModel user = GitBlitWebSession.get().getUser(); + success = RefLogUtils.deleteRef(user, r, branch); + } + } + + r.close(); + + if (success) { + info(MessageFormat.format("Branch \"{0}\" deleted", branch)); // redirect to the owning page setResponsePage(getPage().getClass(), WicketUtils.newRepositoryParameter(repositoryModel.name)); } else { - error(MessageFormat.format("Failed to delete branch \"{0}\"", entry.displayName)); + error(MessageFormat.format("Failed to delete branch \"{0}\"", branch)); } } }; -- Gitblit v1.9.1