aboutsummaryrefslogtreecommitdiffstats
path: root/routers/repo
diff options
context:
space:
mode:
authorEthan Koenig <ethantkoenig@gmail.com>2017-11-25 05:47:19 -0800
committerLunny Xiao <xiaolunwen@gmail.com>2017-11-25 21:47:19 +0800
commit40c545ddbccc65aa607a2153d38b56cc3bb99be9 (patch)
tree9cf9bdef087d4776f7b0d8facab3df7537d8caa2 /routers/repo
parent183da4c2c1611d845f0198a3ddeeddd85c745243 (diff)
downloadgitea-40c545ddbccc65aa607a2153d38b56cc3bb99be9.tar.gz
gitea-40c545ddbccc65aa607a2153d38b56cc3bb99be9.zip
Fix files/commits of merged PRs (#2937)
Diffstat (limited to 'routers/repo')
-rw-r--r--routers/repo/pull.go38
1 files changed, 30 insertions, 8 deletions
diff --git a/routers/repo/pull.go b/routers/repo/pull.go
index ac0d36c278..14b0928734 100644
--- a/routers/repo/pull.go
+++ b/routers/repo/pull.go
@@ -257,12 +257,24 @@ func PrepareMergedViewPullInfo(ctx *context.Context, issue *models.Issue) {
setMergeTarget(ctx, pull)
ctx.Data["HasMerged"] = true
- ctx.Data["NumCommits"], err = ctx.Repo.GitRepo.CommitsCountBetween(pull.MergeBase, pull.MergedCommitID)
+ mergedCommit, err := ctx.Repo.GitRepo.GetCommit(pull.MergedCommitID)
+ if err != nil {
+ ctx.Handle(500, "GetCommit", err)
+ return
+ }
+ // the ID of the last commit in the PR (not including the merge commit)
+ endCommitID, err := mergedCommit.ParentID(mergedCommit.ParentCount() - 1)
+ if err != nil {
+ ctx.Handle(500, "ParentID", err)
+ return
+ }
+
+ ctx.Data["NumCommits"], err = ctx.Repo.GitRepo.CommitsCountBetween(pull.MergeBase, endCommitID.String())
if err != nil {
ctx.Handle(500, "Repo.GitRepo.CommitsCountBetween", err)
return
}
- ctx.Data["NumFiles"], err = ctx.Repo.GitRepo.FilesCountBetween(pull.MergeBase, pull.MergedCommitID)
+ ctx.Data["NumFiles"], err = ctx.Repo.GitRepo.FilesCountBetween(pull.MergeBase, endCommitID.String())
if err != nil {
ctx.Handle(500, "Repo.GitRepo.FilesCountBetween", err)
return
@@ -338,19 +350,19 @@ func ViewPullCommits(ctx *context.Context) {
ctx.Data["Username"] = ctx.Repo.Owner.Name
ctx.Data["Reponame"] = ctx.Repo.Repository.Name
- startCommit, err := ctx.Repo.GitRepo.GetCommit(pull.MergeBase)
+ mergedCommit, err := ctx.Repo.GitRepo.GetCommit(pull.MergedCommitID)
if err != nil {
ctx.Handle(500, "Repo.GitRepo.GetCommit", err)
return
}
- endCommit, err := ctx.Repo.GitRepo.GetCommit(pull.MergedCommitID)
+ endCommitID, err := mergedCommit.ParentID(mergedCommit.ParentCount() - 1)
if err != nil {
- ctx.Handle(500, "Repo.GitRepo.GetCommit", err)
+ ctx.Handle(500, "ParentID", err)
return
}
- commits, err = ctx.Repo.GitRepo.CommitsBetween(endCommit, startCommit)
+ commits, err = ctx.Repo.GitRepo.CommitsBetweenIDs(endCommitID.String(), pull.MergeBase)
if err != nil {
- ctx.Handle(500, "Repo.GitRepo.CommitsBetween", err)
+ ctx.Handle(500, "Repo.GitRepo.CommitsBetweenIDs", err)
return
}
} else {
@@ -402,7 +414,17 @@ func ViewPullFiles(ctx *context.Context) {
diffRepoPath = ctx.Repo.GitRepo.Path
startCommitID = pull.MergeBase
- endCommitID = pull.MergedCommitID
+ mergedCommit, err := ctx.Repo.GitRepo.GetCommit(pull.MergedCommitID)
+ if err != nil {
+ ctx.Handle(500, "GetCommit", err)
+ return
+ }
+ endCommitSha, err := mergedCommit.ParentID(mergedCommit.ParentCount() - 1)
+ if err != nil {
+ ctx.Handle(500, "ParentID", err)
+ return
+ }
+ endCommitID = endCommitSha.String()
gitRepo = ctx.Repo.GitRepo
headTarget = path.Join(ctx.Repo.Owner.Name, ctx.Repo.Repository.Name)