gitea源码

editor_cherry_pick.go 2.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. // Copyright 2021 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package repo
  4. import (
  5. "bytes"
  6. "net/http"
  7. "strings"
  8. "code.gitea.io/gitea/modules/git"
  9. "code.gitea.io/gitea/modules/util"
  10. "code.gitea.io/gitea/services/context"
  11. "code.gitea.io/gitea/services/forms"
  12. "code.gitea.io/gitea/services/repository/files"
  13. )
  14. func CherryPick(ctx *context.Context) {
  15. prepareEditorCommitFormOptions(ctx, "_cherrypick")
  16. if ctx.Written() {
  17. return
  18. }
  19. fromCommitID := ctx.PathParam("sha")
  20. ctx.Data["FromCommitID"] = fromCommitID
  21. cherryPickCommit, err := ctx.Repo.GitRepo.GetCommit(fromCommitID)
  22. if err != nil {
  23. HandleGitError(ctx, "GetCommit", err)
  24. return
  25. }
  26. if ctx.FormString("cherry-pick-type") == "revert" {
  27. ctx.Data["CherryPickType"] = "revert"
  28. ctx.Data["commit_summary"] = "revert " + ctx.PathParam("sha")
  29. ctx.Data["commit_message"] = "revert " + cherryPickCommit.Message()
  30. } else {
  31. ctx.Data["CherryPickType"] = "cherry-pick"
  32. splits := strings.SplitN(cherryPickCommit.Message(), "\n", 2)
  33. ctx.Data["commit_summary"] = splits[0]
  34. ctx.Data["commit_message"] = splits[1]
  35. }
  36. ctx.HTML(http.StatusOK, tplCherryPick)
  37. }
  38. func CherryPickPost(ctx *context.Context) {
  39. fromCommitID := ctx.PathParam("sha")
  40. parsed := prepareEditorCommitSubmittedForm[*forms.CherryPickForm](ctx)
  41. if ctx.Written() {
  42. return
  43. }
  44. defaultCommitMessage := util.Iif(parsed.form.Revert, ctx.Locale.TrString("repo.commit.revert-header", fromCommitID), ctx.Locale.TrString("repo.commit.cherry-pick-header", fromCommitID))
  45. opts := &files.ApplyDiffPatchOptions{
  46. LastCommitID: parsed.form.LastCommit,
  47. OldBranch: parsed.OldBranchName,
  48. NewBranch: parsed.NewBranchName,
  49. Message: parsed.GetCommitMessage(defaultCommitMessage),
  50. Author: parsed.GitCommitter,
  51. Committer: parsed.GitCommitter,
  52. }
  53. // First try the simple plain read-tree -m approach
  54. opts.Content = fromCommitID
  55. if _, err := files.CherryPick(ctx, ctx.Repo.Repository, ctx.Doer, parsed.form.Revert, opts); err != nil {
  56. // Drop through to the "apply" method
  57. buf := &bytes.Buffer{}
  58. if parsed.form.Revert {
  59. err = git.GetReverseRawDiff(ctx, ctx.Repo.Repository.RepoPath(), fromCommitID, buf)
  60. } else {
  61. err = git.GetRawDiff(ctx.Repo.GitRepo, fromCommitID, "patch", buf)
  62. }
  63. if err == nil {
  64. opts.Content = buf.String()
  65. _, err = files.ApplyDiffPatch(ctx, ctx.Repo.Repository, ctx.Doer, opts)
  66. if err != nil {
  67. err = util.ErrorWrapLocale(err, "repo.editor.fail_to_apply_patch")
  68. }
  69. }
  70. if err != nil {
  71. editorHandleFileOperationError(ctx, parsed.NewBranchName, err)
  72. return
  73. }
  74. }
  75. redirectForCommitChoice(ctx, parsed, parsed.form.TreePath)
  76. }