123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150 |
- package repo
- import (
- "container/list"
- "path"
- "github.com/go-martini/martini"
- "github.com/gogits/gogs/models"
- "github.com/gogits/gogs/modules/base"
- "github.com/gogits/gogs/modules/middleware"
- )
- func Commits(ctx *middleware.Context, params martini.Params) {
- userName := params["username"]
- repoName := params["reponame"]
- branchName := params["branchname"]
- brs, err := models.GetBranches(userName, repoName)
- if err != nil {
- ctx.Handle(500, "repo.Commits", err)
- return
- } else if len(brs) == 0 {
- ctx.Handle(404, "repo.Commits", nil)
- return
- }
- repoPath := models.RepoPath(userName, repoName)
- commitsCount, err := models.GetCommitsCount(repoPath, branchName)
- if err != nil {
- ctx.Handle(500, "repo.Commits(GetCommitsCount)", err)
- return
- }
-
- page, _ := base.StrTo(ctx.Query("p")).Int()
- if page < 1 {
- page = 1
- }
- lastPage := page - 1
- if lastPage < 0 {
- lastPage = 0
- }
- nextPage := page + 1
- if nextPage*50 > commitsCount {
- nextPage = 0
- }
-
- commits, err := models.GetCommitsByRange(repoPath, branchName, page)
- if err != nil {
- ctx.Handle(500, "repo.Commits(get commits)", err)
- return
- }
- ctx.Data["Username"] = userName
- ctx.Data["Reponame"] = repoName
- ctx.Data["CommitCount"] = commitsCount
- ctx.Data["Commits"] = commits
- ctx.Data["LastPageNum"] = lastPage
- ctx.Data["NextPageNum"] = nextPage
- ctx.Data["IsRepoToolbarCommits"] = true
- ctx.HTML(200, "repo/commits")
- }
- func Diff(ctx *middleware.Context, params martini.Params) {
- userName := ctx.Repo.Owner.Name
- repoName := ctx.Repo.Repository.Name
- branchName := ctx.Repo.BranchName
- commitId := ctx.Repo.CommitId
- commit := ctx.Repo.Commit
- diff, err := models.GetDiff(models.RepoPath(userName, repoName), commitId)
- if err != nil {
- ctx.Handle(404, "repo.Diff", err)
- return
- }
- isImageFile := func(name string) bool {
- repoFile, err := models.GetTargetFile(userName, repoName,
- branchName, commitId, name)
- if err != nil {
- return false
- }
- blob, err := repoFile.LookupBlob()
- if err != nil {
- return false
- }
- data := blob.Contents()
- _, isImage := base.IsImageFile(data)
- return isImage
- }
- ctx.Data["IsImageFile"] = isImageFile
- ctx.Data["Title"] = commit.Message() + " · " + base.ShortSha(commitId)
- ctx.Data["Commit"] = commit
- ctx.Data["Diff"] = diff
- ctx.Data["DiffNotAvailable"] = diff.NumFiles() == 0
- ctx.Data["IsRepoToolbarCommits"] = true
- ctx.Data["SourcePath"] = "/" + path.Join(userName, repoName, "src", commitId)
- ctx.Data["RawPath"] = "/" + path.Join(userName, repoName, "raw", commitId)
- ctx.HTML(200, "repo/diff")
- }
- func SearchCommits(ctx *middleware.Context, params martini.Params) {
- keyword := ctx.Query("q")
- if len(keyword) == 0 {
- ctx.Redirect(ctx.Repo.RepoLink + "/commits/" + ctx.Repo.BranchName)
- return
- }
- userName := params["username"]
- repoName := params["reponame"]
- branchName := params["branchname"]
- brs, err := models.GetBranches(userName, repoName)
- if err != nil {
- ctx.Handle(500, "repo.SearchCommits(GetBranches)", err)
- return
- } else if len(brs) == 0 {
- ctx.Handle(404, "repo.SearchCommits(GetBranches)", nil)
- return
- }
- var commits *list.List
- if !models.IsBranchExist(userName, repoName, branchName) {
- ctx.Handle(404, "repo.SearchCommits(IsBranchExist)", err)
- return
- } else if commits, err = models.SearchCommits(models.RepoPath(userName, repoName), branchName, keyword); err != nil {
- ctx.Handle(500, "repo.SearchCommits(SearchCommits)", err)
- return
- }
- ctx.Data["Keyword"] = keyword
- ctx.Data["Username"] = userName
- ctx.Data["Reponame"] = repoName
- ctx.Data["CommitCount"] = commits.Len()
- ctx.Data["Commits"] = commits
- ctx.Data["IsSearchPage"] = true
- ctx.Data["IsRepoToolbarCommits"] = true
- ctx.HTML(200, "repo/commits")
- }
|