From c7bcdce232aa701135c1b7272b132961b846c38c Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Mon, 09 Jan 2012 22:21:32 -0500 Subject: [PATCH] Updated to Groovy 1.8.5 --- groovy/sendmail.groovy | 42 +++++++++++++++++++++++++++--------------- 1 files changed, 27 insertions(+), 15 deletions(-) diff --git a/groovy/sendmail.groovy b/groovy/sendmail.groovy index 1020241..0b60dfa 100644 --- a/groovy/sendmail.groovy +++ b/groovy/sendmail.groovy @@ -19,6 +19,7 @@ import com.gitblit.models.TeamModel import com.gitblit.models.UserModel import com.gitblit.utils.JGitUtils +import java.text.SimpleDateFormat import org.eclipse.jgit.lib.Repository import org.eclipse.jgit.lib.Config import org.eclipse.jgit.revwalk.RevCommit @@ -113,9 +114,12 @@ } // construct a simple text summary of the changes contained in the push +def branchBreak = '>---------------------------------------------------------------\n' +def commitBreak = '\n\n ----\n' def commitCount = 0 def changes = '' -def table = { it.authorIdent.name.padRight(25, ' ') + it.shortMessage + "\n$commitUrl" + it.id.name } +SimpleDateFormat df = new SimpleDateFormat(gitblit.getString(Keys.web.datetimestampLongFormat, 'EEEE, MMMM d, yyyy h:mm a z')) +def table = { "\n ${JGitUtils.getDisplayName(it.authorIdent)}\n ${df.format(JGitUtils.getCommitDate(it))}\n\n $it.shortMessage\n\n $commitUrl$it.id.name" } for (command in commands) { def ref = command.refName if (ref.startsWith('refs/heads/')) { @@ -126,32 +130,40 @@ switch (command.type) { case ReceiveCommand.Type.CREATE: - def commits = JGitUtils.getRevLog(r, command.oldId.name, command.newId.name) + def commits = JGitUtils.getRevLog(r, command.oldId.name, command.newId.name).reverse() commitCount += commits.size() - // new branch commits table - changes += "$ref created ($commits.size commits)\n\n" - changes += commits.collect(table).join('\n\n') - changes += '\n' + if (commits.size() > 0) { + // new branch + changes += "\n$branchBreak new branch $ref created ($commits.size commits)\n$branchBreak" + changes += commits.collect(table).join(commitBreak) + changes += '\n' + } else if (ref.command.refName.startsWith('refs/tags/')) { + // new tag + changes += "\n$branchBreak new tag $ref created\n$branchBreak" + } else if (ref.command.refName.startsWith('refs/heads/')) { + // new branch + changes += "\n$branchBreak new $ref branch created\n$branchBreak" + } break case ReceiveCommand.Type.UPDATE: - def commits = JGitUtils.getRevLog(r, command.oldId.name, command.newId.name) + def commits = JGitUtils.getRevLog(r, command.oldId.name, command.newId.name).reverse() commitCount += commits.size() // fast-forward branch commits table - changes += "$ref updated ($commits.size commits)\n\n" - changes += commits.collect(table).join('\n\n') + changes += "\n$branchBreak $ref branch updated ($commits.size commits)\n$branchBreak" + changes += commits.collect(table).join(commitBreak) changes += '\n' break case ReceiveCommand.Type.UPDATE_NONFASTFORWARD: - def commits = JGitUtils.getRevLog(r, command.oldId.name, command.newId.name) + def commits = JGitUtils.getRevLog(r, command.oldId.name, command.newId.name).reverse() commitCount += commits.size() // non-fast-forward branch commits table - changes += "$ref updated [NON fast-forward] ($commits.size commits)\n\n" - changes += commits.collect(table).join('\n\n') + changes += "\n$branchBreak $ref branch updated [NON fast-forward] ($commits.size commits)\n$branchBreak" + changes += commits.collect(table).join(commitBreak) changes += '\n' break case ReceiveCommand.Type.DELETE: - // deleted branch - changes += "$ref deleted\n\n" + // deleted branch/tag + changes += "\n$branchBreak $ref deleted\n$branchBreak" break default: break @@ -161,4 +173,4 @@ r.close() // tell Gitblit to send the message (Gitblit filters duplicate addresses) -gitblit.sendMail("$emailprefix $user.username pushed $commitCount commits => $repository.name", "$summaryUrl\n\n$changes", toAddresses) \ No newline at end of file +gitblit.sendMail("$emailprefix $user.username pushed $commitCount commits => $repository.name", "$summaryUrl\n$changes", toAddresses) \ No newline at end of file -- Gitblit v1.9.1