You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

commit.go 8.2 kB

11 years ago
11 years ago
Compare branches, commits and tags with each other (#6991) * Supports tags when comparing commits or branches Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Hide headline when only comparing and don't load unused data Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Merges compare logics to allow comparing branches, commits and tags with eachother Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Display branch or tag instead of commit when used for comparing Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Show pull request form after click on button Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Transfers relevant pull.go changes from master to compare.go Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Fixes error when comparing forks against a commit or tag Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Removes console.log from JavaScript file Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Show icon next to commit reference when comparing branch or tag Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Updates css file Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Fixes import order * Renames template variable * Update routers/repo/compare.go Co-Authored-By: zeripath <art27@cantab.net> * Update from master Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Allow short-shas in compare * Renames prInfo to compareInfo Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Check PR permissions only if compare is pull request Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Adjusts comment Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Use compareInfo instead of prInfo
6 years ago
10 years ago
10 years ago
10 years ago
Better logging (#6038) (#6095) * Panic don't fatal on create new logger Fixes #5854 Signed-off-by: Andrew Thornton <art27@cantab.net> * partial broken * Update the logging infrastrcture Signed-off-by: Andrew Thornton <art27@cantab.net> * Reset the skip levels for Fatal and Error Signed-off-by: Andrew Thornton <art27@cantab.net> * broken ncsa * More log.Error fixes Signed-off-by: Andrew Thornton <art27@cantab.net> * Remove nal * set log-levels to lowercase * Make console_test test all levels * switch to lowercased levels * OK now working * Fix vetting issues * Fix lint * Fix tests * change default logging to match current gitea * Improve log testing Signed-off-by: Andrew Thornton <art27@cantab.net> * reset error skip levels to 0 * Update documentation and access logger configuration * Redirect the router log back to gitea if redirect macaron log but also allow setting the log level - i.e. TRACE * Fix broken level caching * Refactor the router log * Add Router logger * Add colorizing options * Adjust router colors * Only create logger if they will be used * update app.ini.sample * rename Attribute ColorAttribute * Change from white to green for function * Set fatal/error levels * Restore initial trace logger * Fix Trace arguments in modules/auth/auth.go * Properly handle XORMLogger * Improve admin/config page * fix fmt * Add auto-compression of old logs * Update error log levels * Remove the unnecessary skip argument from Error, Fatal and Critical * Add stacktrace support * Fix tests * Remove x/sync from vendors? * Add stderr option to console logger * Use filepath.ToSlash to protect against Windows in tests * Remove prefixed underscores from names in colors.go * Remove not implemented database logger This was removed from Gogs on 4 Mar 2016 but left in the configuration since then. * Ensure that log paths are relative to ROOT_PATH * use path.Join * rename jsonConfig to logConfig * Rename "config" to "jsonConfig" to make it clearer * Requested changes * Requested changes: XormLogger * Try to color the windows terminal If successful default to colorizing the console logs * fixup * Colorize initially too * update vendor * Colorize logs on default and remove if this is not a colorizing logger * Fix documentation * fix test * Use go-isatty to detect if on windows we are on msys or cygwin * Fix spelling mistake * Add missing vendors * More changes * Rationalise the ANSI writer protection * Adjust colors on advice from @0x5c * Make Flags a comma separated list * Move to use the windows constant for ENABLE_VIRTUAL_TERMINAL_PROCESSING * Ensure matching is done on the non-colored message - to simpify EXPRESSION
6 years ago
Adds side-by-side diff for images (#6784) * Adds side-by-side diff for images Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Explain blank imports Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Use complete word for width and height labels on image compare Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Update index.css from master Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Moves ImageInfo to git commit file Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Assign ImageInfo function for template and sets correct target for BeforeSourcePath Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Adds missing comment Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Return error if ImageInfo failed Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Avoid template panic when ImageInfo failed for some reason Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Show file size on image diff Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Removes unused helper function Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Reverts copyright year change Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Close file reader Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Update commit.go Sets correct data key * Moves reader.Close() up a few lines * Updates index.css * Updates CSS file Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Transfers adjustments for image compare to compare.go file Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Adjusts variable name Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Apply lesshint recommendations Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Do not show old image on image compare if it is not in index of base commit Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Change file size text Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com>
6 years ago
Adds side-by-side diff for images (#6784) * Adds side-by-side diff for images Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Explain blank imports Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Use complete word for width and height labels on image compare Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Update index.css from master Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Moves ImageInfo to git commit file Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Assign ImageInfo function for template and sets correct target for BeforeSourcePath Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Adds missing comment Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Return error if ImageInfo failed Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Avoid template panic when ImageInfo failed for some reason Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Show file size on image diff Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Removes unused helper function Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Reverts copyright year change Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Close file reader Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Update commit.go Sets correct data key * Moves reader.Close() up a few lines * Updates index.css * Updates CSS file Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Transfers adjustments for image compare to compare.go file Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Adjusts variable name Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Apply lesshint recommendations Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Do not show old image on image compare if it is not in index of base commit Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Change file size text Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com>
6 years ago
10 years ago
Improve listing performance by using go-git (#6478) * Use go-git for tree reading and commit info lookup. Signed-off-by: Filip Navara <navara@emclient.com> * Use TreeEntry.IsRegular() instead of ObjectType that was removed. Signed-off-by: Filip Navara <navara@emclient.com> * Use the treePath to optimize commit info search. Signed-off-by: Filip Navara <navara@emclient.com> * Extract the latest commit at treePath along with the other commits. Signed-off-by: Filip Navara <navara@emclient.com> * Fix listing commit info for a directory that was created in one commit and never modified after. Signed-off-by: Filip Navara <navara@emclient.com> * Avoid nearly all external 'git' invocations when doing directory listing (.editorconfig code path is still hit). Signed-off-by: Filip Navara <navara@emclient.com> * Use go-git for reading blobs. Signed-off-by: Filip Navara <navara@emclient.com> * Make SHA1 type alias for plumbing.Hash in go-git. Signed-off-by: Filip Navara <navara@emclient.com> * Make Signature type alias for object.Signature in go-git. Signed-off-by: Filip Navara <navara@emclient.com> * Fix GetCommitsInfo for repository with only one commit. Signed-off-by: Filip Navara <navara@emclient.com> * Fix PGP signature verification. Signed-off-by: Filip Navara <navara@emclient.com> * Fix issues with walking commit graph across merges. Signed-off-by: Filip Navara <navara@emclient.com> * Fix typo in condition. Signed-off-by: Filip Navara <navara@emclient.com> * Speed up loading branch list by keeping the repository reference (and thus all the loaded packfile indexes). Signed-off-by: Filip Navara <navara@emclient.com> * Fix lising submodules. Signed-off-by: Filip Navara <navara@emclient.com> * Fix build Signed-off-by: Filip Navara <navara@emclient.com> * Add back commit cache because of name-rev Signed-off-by: Filip Navara <navara@emclient.com> * Fix tests Signed-off-by: Filip Navara <navara@emclient.com> * Fix code style * Fix spelling * Address PR feedback Signed-off-by: Filip Navara <navara@emclient.com> * Update vendor module list Signed-off-by: Filip Navara <navara@emclient.com> * Fix getting trees by commit id Signed-off-by: Filip Navara <navara@emclient.com> * Fix remaining unit test failures * Fix GetTreeBySHA * Avoid running `git name-rev` if not necessary Signed-off-by: Filip Navara <navara@emclient.com> * Move Branch code to git module * Clean up GPG signature verification and fix it for tagged commits * Address PR feedback (import formatting, copyright headers) * Make blob lookup by SHA working * Update tests to use public API * Allow getting content from any type of object through the blob interface * Change test to actually expect the object content that is in the GIT repository * Change one more test to actually expect the object content that is in the GIT repository * Add comments
6 years ago
Compare branches, commits and tags with each other (#6991) * Supports tags when comparing commits or branches Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Hide headline when only comparing and don't load unused data Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Merges compare logics to allow comparing branches, commits and tags with eachother Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Display branch or tag instead of commit when used for comparing Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Show pull request form after click on button Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Transfers relevant pull.go changes from master to compare.go Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Fixes error when comparing forks against a commit or tag Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Removes console.log from JavaScript file Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Show icon next to commit reference when comparing branch or tag Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Updates css file Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Fixes import order * Renames template variable * Update routers/repo/compare.go Co-Authored-By: zeripath <art27@cantab.net> * Update from master Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Allow short-shas in compare * Renames prInfo to compareInfo Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Check PR permissions only if compare is pull request Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Adjusts comment Signed-off-by: Mario Lubenka <mario.lubenka@googlemail.com> * Use compareInfo instead of prInfo
6 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298
  1. // Copyright 2014 The Gogs Authors. All rights reserved.
  2. // Copyright 2019 The Gitea Authors. All rights reserved.
  3. // Use of this source code is governed by a MIT-style
  4. // license that can be found in the LICENSE file.
  5. package repo
  6. import (
  7. "path"
  8. "strings"
  9. "code.gitea.io/gitea/models"
  10. "code.gitea.io/gitea/modules/base"
  11. "code.gitea.io/gitea/modules/charset"
  12. "code.gitea.io/gitea/modules/context"
  13. "code.gitea.io/gitea/modules/git"
  14. "code.gitea.io/gitea/modules/gitgraph"
  15. "code.gitea.io/gitea/modules/log"
  16. "code.gitea.io/gitea/modules/setting"
  17. "code.gitea.io/gitea/services/gitdiff"
  18. )
  19. const (
  20. tplCommits base.TplName = "repo/commits"
  21. tplGraph base.TplName = "repo/graph"
  22. tplCommitPage base.TplName = "repo/commit_page"
  23. )
  24. // RefCommits render commits page
  25. func RefCommits(ctx *context.Context) {
  26. switch {
  27. case len(ctx.Repo.TreePath) == 0:
  28. Commits(ctx)
  29. case ctx.Repo.TreePath == "search":
  30. SearchCommits(ctx)
  31. default:
  32. FileHistory(ctx)
  33. }
  34. }
  35. // Commits render branch's commits
  36. func Commits(ctx *context.Context) {
  37. ctx.Data["PageIsCommits"] = true
  38. if ctx.Repo.Commit == nil {
  39. ctx.NotFound("Commit not found", nil)
  40. return
  41. }
  42. ctx.Data["PageIsViewCode"] = true
  43. commitsCount, err := ctx.Repo.GetCommitsCount()
  44. if err != nil {
  45. ctx.ServerError("GetCommitsCount", err)
  46. return
  47. }
  48. page := ctx.QueryInt("page")
  49. if page <= 1 {
  50. page = 1
  51. }
  52. // Both `git log branchName` and `git log commitId` work.
  53. commits, err := ctx.Repo.Commit.CommitsByRange(page)
  54. if err != nil {
  55. ctx.ServerError("CommitsByRange", err)
  56. return
  57. }
  58. commits = models.ValidateCommitsWithEmails(commits)
  59. commits = models.ParseCommitsWithSignature(commits)
  60. commits = models.ParseCommitsWithStatus(commits, ctx.Repo.Repository)
  61. ctx.Data["Commits"] = commits
  62. ctx.Data["Username"] = ctx.Repo.Owner.Name
  63. ctx.Data["Reponame"] = ctx.Repo.Repository.Name
  64. ctx.Data["CommitCount"] = commitsCount
  65. ctx.Data["Branch"] = ctx.Repo.BranchName
  66. pager := context.NewPagination(int(commitsCount), git.CommitsRangeSize, page, 5)
  67. pager.SetDefaultParams(ctx)
  68. ctx.Data["Page"] = pager
  69. ctx.HTML(200, tplCommits)
  70. }
  71. // Graph render commit graph - show commits from all branches.
  72. func Graph(ctx *context.Context) {
  73. ctx.Data["PageIsCommits"] = true
  74. ctx.Data["PageIsViewCode"] = true
  75. commitsCount, err := ctx.Repo.GetCommitsCount()
  76. if err != nil {
  77. ctx.ServerError("GetCommitsCount", err)
  78. return
  79. }
  80. allCommitsCount, err := ctx.Repo.GitRepo.GetAllCommitsCount()
  81. if err != nil {
  82. ctx.ServerError("GetAllCommitsCount", err)
  83. return
  84. }
  85. page := ctx.QueryInt("page")
  86. graph, err := gitgraph.GetCommitGraph(ctx.Repo.GitRepo, page)
  87. if err != nil {
  88. ctx.ServerError("GetCommitGraph", err)
  89. return
  90. }
  91. ctx.Data["Graph"] = graph
  92. ctx.Data["Username"] = ctx.Repo.Owner.Name
  93. ctx.Data["Reponame"] = ctx.Repo.Repository.Name
  94. ctx.Data["CommitCount"] = commitsCount
  95. ctx.Data["Branch"] = ctx.Repo.BranchName
  96. ctx.Data["RequireGitGraph"] = true
  97. ctx.Data["Page"] = context.NewPagination(int(allCommitsCount), setting.UI.GraphMaxCommitNum, page, 5)
  98. ctx.HTML(200, tplGraph)
  99. }
  100. // SearchCommits render commits filtered by keyword
  101. func SearchCommits(ctx *context.Context) {
  102. ctx.Data["PageIsCommits"] = true
  103. ctx.Data["PageIsViewCode"] = true
  104. query := strings.Trim(ctx.Query("q"), " ")
  105. if len(query) == 0 {
  106. ctx.Redirect(ctx.Repo.RepoLink + "/commits/" + ctx.Repo.BranchNameSubURL())
  107. return
  108. }
  109. all := ctx.QueryBool("all")
  110. opts := git.NewSearchCommitsOptions(query, all)
  111. commits, err := ctx.Repo.Commit.SearchCommits(opts)
  112. if err != nil {
  113. ctx.ServerError("SearchCommits", err)
  114. return
  115. }
  116. commits = models.ValidateCommitsWithEmails(commits)
  117. commits = models.ParseCommitsWithSignature(commits)
  118. commits = models.ParseCommitsWithStatus(commits, ctx.Repo.Repository)
  119. ctx.Data["Commits"] = commits
  120. ctx.Data["Keyword"] = query
  121. if all {
  122. ctx.Data["All"] = "checked"
  123. }
  124. ctx.Data["Username"] = ctx.Repo.Owner.Name
  125. ctx.Data["Reponame"] = ctx.Repo.Repository.Name
  126. ctx.Data["CommitCount"] = commits.Len()
  127. ctx.Data["Branch"] = ctx.Repo.BranchName
  128. ctx.HTML(200, tplCommits)
  129. }
  130. // FileHistory show a file's reversions
  131. func FileHistory(ctx *context.Context) {
  132. ctx.Data["IsRepoToolbarCommits"] = true
  133. fileName := ctx.Repo.TreePath
  134. if len(fileName) == 0 {
  135. Commits(ctx)
  136. return
  137. }
  138. branchName := ctx.Repo.BranchName
  139. commitsCount, err := ctx.Repo.GitRepo.FileCommitsCount(branchName, fileName)
  140. if err != nil {
  141. ctx.ServerError("FileCommitsCount", err)
  142. return
  143. } else if commitsCount == 0 {
  144. ctx.NotFound("FileCommitsCount", nil)
  145. return
  146. }
  147. page := ctx.QueryInt("page")
  148. if page <= 1 {
  149. page = 1
  150. }
  151. commits, err := ctx.Repo.GitRepo.CommitsByFileAndRange(branchName, fileName, page)
  152. if err != nil {
  153. ctx.ServerError("CommitsByFileAndRange", err)
  154. return
  155. }
  156. commits = models.ValidateCommitsWithEmails(commits)
  157. commits = models.ParseCommitsWithSignature(commits)
  158. commits = models.ParseCommitsWithStatus(commits, ctx.Repo.Repository)
  159. ctx.Data["Commits"] = commits
  160. ctx.Data["Username"] = ctx.Repo.Owner.Name
  161. ctx.Data["Reponame"] = ctx.Repo.Repository.Name
  162. ctx.Data["FileName"] = fileName
  163. ctx.Data["CommitCount"] = commitsCount
  164. ctx.Data["Branch"] = branchName
  165. pager := context.NewPagination(int(commitsCount), git.CommitsRangeSize, page, 5)
  166. pager.SetDefaultParams(ctx)
  167. ctx.Data["Page"] = pager
  168. ctx.HTML(200, tplCommits)
  169. }
  170. // Diff show different from current commit to previous commit
  171. func Diff(ctx *context.Context) {
  172. ctx.Data["PageIsDiff"] = true
  173. ctx.Data["RequireHighlightJS"] = true
  174. userName := ctx.Repo.Owner.Name
  175. repoName := ctx.Repo.Repository.Name
  176. commitID := ctx.Params(":sha")
  177. commit, err := ctx.Repo.GitRepo.GetCommit(commitID)
  178. if err != nil {
  179. if git.IsErrNotExist(err) {
  180. ctx.NotFound("Repo.GitRepo.GetCommit", err)
  181. } else {
  182. ctx.ServerError("Repo.GitRepo.GetCommit", err)
  183. }
  184. return
  185. }
  186. if len(commitID) != 40 {
  187. commitID = commit.ID.String()
  188. }
  189. statuses, err := models.GetLatestCommitStatus(ctx.Repo.Repository, commitID, 0)
  190. if err != nil {
  191. log.Error("GetLatestCommitStatus: %v", err)
  192. }
  193. ctx.Data["CommitStatus"] = models.CalcCommitStatus(statuses)
  194. diff, err := gitdiff.GetDiffCommit(models.RepoPath(userName, repoName),
  195. commitID, setting.Git.MaxGitDiffLines,
  196. setting.Git.MaxGitDiffLineCharacters, setting.Git.MaxGitDiffFiles)
  197. if err != nil {
  198. ctx.NotFound("GetDiffCommit", err)
  199. return
  200. }
  201. parents := make([]string, commit.ParentCount())
  202. for i := 0; i < commit.ParentCount(); i++ {
  203. sha, err := commit.ParentID(i)
  204. parents[i] = sha.String()
  205. if err != nil {
  206. ctx.NotFound("repo.Diff", err)
  207. return
  208. }
  209. }
  210. ctx.Data["CommitID"] = commitID
  211. ctx.Data["AfterCommitID"] = commitID
  212. ctx.Data["Username"] = userName
  213. ctx.Data["Reponame"] = repoName
  214. var parentCommit *git.Commit
  215. if commit.ParentCount() > 0 {
  216. parentCommit, err = ctx.Repo.GitRepo.GetCommit(parents[0])
  217. if err != nil {
  218. ctx.NotFound("GetParentCommit", err)
  219. return
  220. }
  221. }
  222. setImageCompareContext(ctx, parentCommit, commit)
  223. headTarget := path.Join(userName, repoName)
  224. setPathsCompareContext(ctx, parentCommit, commit, headTarget)
  225. ctx.Data["Title"] = commit.Summary() + " · " + base.ShortSha(commitID)
  226. ctx.Data["Commit"] = commit
  227. ctx.Data["Verification"] = models.ParseCommitWithSignature(commit)
  228. ctx.Data["Author"] = models.ValidateCommitWithEmail(commit)
  229. ctx.Data["Diff"] = diff
  230. ctx.Data["Parents"] = parents
  231. ctx.Data["DiffNotAvailable"] = diff.NumFiles() == 0
  232. note := &git.Note{}
  233. err = git.GetNote(ctx.Repo.GitRepo, commitID, note)
  234. if err == nil {
  235. ctx.Data["Note"] = string(charset.ToUTF8WithFallback(note.Message))
  236. ctx.Data["NoteCommit"] = note.Commit
  237. ctx.Data["NoteAuthor"] = models.ValidateCommitWithEmail(note.Commit)
  238. }
  239. ctx.Data["BranchName"], err = commit.GetBranchName()
  240. if err != nil {
  241. ctx.ServerError("commit.GetBranchName", err)
  242. }
  243. ctx.HTML(200, tplCommitPage)
  244. }
  245. // RawDiff dumps diff results of repository in given commit ID to io.Writer
  246. func RawDiff(ctx *context.Context) {
  247. if err := gitdiff.GetRawDiff(
  248. models.RepoPath(ctx.Repo.Owner.Name, ctx.Repo.Repository.Name),
  249. ctx.Params(":sha"),
  250. gitdiff.RawDiffType(ctx.Params(":ext")),
  251. ctx.Resp,
  252. ); err != nil {
  253. ctx.ServerError("GetRawDiff", err)
  254. return
  255. }
  256. }