|
@@ -11,6 +11,7 @@ import (
|
|
|
"regexp"
|
|
|
"strings"
|
|
|
"time"
|
|
|
+ "unicode"
|
|
|
|
|
|
"github.com/gogits/git"
|
|
|
|
|
@@ -93,12 +94,15 @@ func (a Action) GetContent() string {
|
|
|
return a.Content
|
|
|
}
|
|
|
|
|
|
-func updateIssuesCommit(repoUserName, repoName string, commits []*base.PushCommit) error {
|
|
|
+func updateIssuesCommit(userId, repoId int64, repoUserName, repoName string, commits []*base.PushCommit) error {
|
|
|
for _, c := range commits {
|
|
|
refs := IssueKeywordsPat.FindAllString(c.Message, -1)
|
|
|
|
|
|
for _, ref := range refs {
|
|
|
ref := ref[strings.IndexByte(ref, byte(' '))+1:]
|
|
|
+ ref = strings.TrimRightFunc(ref, func(c rune) bool {
|
|
|
+ return !unicode.IsDigit(c)
|
|
|
+ })
|
|
|
|
|
|
if len(ref) == 0 {
|
|
|
continue
|
|
@@ -120,24 +124,44 @@ func updateIssuesCommit(repoUserName, repoName string, commits []*base.PushCommi
|
|
|
return err
|
|
|
}
|
|
|
|
|
|
- if issue.IsClosed {
|
|
|
- continue
|
|
|
- }
|
|
|
-
|
|
|
- issue.IsClosed = true
|
|
|
+ url := fmt.Sprintf("/%s/%s/commit/%s", repoUserName, repoName, c.Sha1)
|
|
|
+ message := fmt.Sprintf(`<a href="%s">%s</a>`, url, c.Message)
|
|
|
|
|
|
- if err = UpdateIssue(issue); err != nil {
|
|
|
+ if err = CreateComment(userId, issue.RepoId, issue.Id, 0, 0, COMMIT, message); err != nil {
|
|
|
return err
|
|
|
}
|
|
|
|
|
|
- issue.Repo.NumClosedIssues++
|
|
|
+ if issue.RepoId == repoId {
|
|
|
+ if issue.IsClosed {
|
|
|
+ continue
|
|
|
+ }
|
|
|
|
|
|
- if err = UpdateRepository(issue.Repo); err != nil {
|
|
|
- return err
|
|
|
- }
|
|
|
+ issue.IsClosed = true
|
|
|
|
|
|
- if err = ChangeMilestoneIssueStats(issue); err != nil {
|
|
|
- return err
|
|
|
+ if err = UpdateIssue(issue); err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+
|
|
|
+ issue.Repo, err = GetRepositoryById(issue.RepoId)
|
|
|
+
|
|
|
+ if err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+
|
|
|
+ issue.Repo.NumClosedIssues++
|
|
|
+
|
|
|
+ if err = UpdateRepository(issue.Repo); err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+
|
|
|
+ if err = ChangeMilestoneIssueStats(issue); err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+
|
|
|
+ // If commit happened in the referenced repository, it means the issue can be closed.
|
|
|
+ if err = CreateComment(userId, repoId, issue.Id, 0, 0, CLOSE, ""); err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
}
|
|
@@ -174,7 +198,7 @@ func CommitRepoAction(userId, repoUserId int64, userName, actEmail string,
|
|
|
return errors.New("action.CommitRepoAction(UpdateRepository): " + err.Error())
|
|
|
}
|
|
|
|
|
|
- err = updateIssuesCommit(repoUserName, repoName, commit.Commits)
|
|
|
+ err = updateIssuesCommit(userId, repoId, repoUserName, repoName, commit.Commits)
|
|
|
|
|
|
if err != nil {
|
|
|
log.Debug("action.CommitRepoAction(updateIssuesCommit): ", err)
|