|
|
|
@ -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)
|
|
|
|
|