mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 16:40:24 +08:00 
			
		
		
		
	Huge updates!!!!! Be careful to merge!!!!
This commit is contained in:
		@@ -4,224 +4,221 @@
 | 
			
		||||
 | 
			
		||||
package repo
 | 
			
		||||
 | 
			
		||||
// import (
 | 
			
		||||
// 	"path"
 | 
			
		||||
import (
 | 
			
		||||
	"path"
 | 
			
		||||
 | 
			
		||||
// 	"github.com/Unknwon/com"
 | 
			
		||||
// 	"github.com/go-martini/martini"
 | 
			
		||||
	"github.com/Unknwon/com"
 | 
			
		||||
 | 
			
		||||
// 	"github.com/gogits/gogs/models"
 | 
			
		||||
// 	"github.com/gogits/gogs/modules/base"
 | 
			
		||||
// 	"github.com/gogits/gogs/modules/middleware"
 | 
			
		||||
// )
 | 
			
		||||
	"github.com/gogits/gogs/models"
 | 
			
		||||
	"github.com/gogits/gogs/modules/base"
 | 
			
		||||
	"github.com/gogits/gogs/modules/middleware"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// const (
 | 
			
		||||
// 	COMMITS base.TplName = "repo/commits"
 | 
			
		||||
// 	DIFF    base.TplName = "repo/diff"
 | 
			
		||||
// )
 | 
			
		||||
const (
 | 
			
		||||
	COMMITS base.TplName = "repo/commits"
 | 
			
		||||
	DIFF    base.TplName = "repo/diff"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// func Commits(ctx *middleware.Context, params martini.Params) {
 | 
			
		||||
// 	ctx.Data["IsRepoToolbarCommits"] = true
 | 
			
		||||
func Commits(ctx *middleware.Context) {
 | 
			
		||||
	ctx.Data["IsRepoToolbarCommits"] = true
 | 
			
		||||
 | 
			
		||||
// 	userName := ctx.Repo.Owner.Name
 | 
			
		||||
// 	repoName := ctx.Repo.Repository.Name
 | 
			
		||||
	userName := ctx.Repo.Owner.Name
 | 
			
		||||
	repoName := ctx.Repo.Repository.Name
 | 
			
		||||
 | 
			
		||||
// 	brs, err := ctx.Repo.GitRepo.GetBranches()
 | 
			
		||||
// 	if err != nil {
 | 
			
		||||
// 		ctx.Handle(500, "repo.Commits(GetBranches)", err)
 | 
			
		||||
// 		return
 | 
			
		||||
// 	} else if len(brs) == 0 {
 | 
			
		||||
// 		ctx.Handle(404, "repo.Commits(GetBranches)", nil)
 | 
			
		||||
// 		return
 | 
			
		||||
// 	}
 | 
			
		||||
	brs, err := ctx.Repo.GitRepo.GetBranches()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "GetBranches", err)
 | 
			
		||||
		return
 | 
			
		||||
	} else if len(brs) == 0 {
 | 
			
		||||
		ctx.Handle(404, "GetBranches", nil)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
// 	commitsCount, err := ctx.Repo.Commit.CommitsCount()
 | 
			
		||||
// 	if err != nil {
 | 
			
		||||
// 		ctx.Handle(500, "repo.Commits(GetCommitsCount)", err)
 | 
			
		||||
// 		return
 | 
			
		||||
// 	}
 | 
			
		||||
	commitsCount, err := ctx.Repo.Commit.CommitsCount()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "GetCommitsCount", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
// 	// Calculate and validate page number.
 | 
			
		||||
// 	page, _ := com.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
 | 
			
		||||
// 	}
 | 
			
		||||
	// Calculate and validate page number.
 | 
			
		||||
	page, _ := com.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
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
// 	// Both `git log branchName` and `git log commitId` work.
 | 
			
		||||
// 	// ctx.Data["Commits"], err = ctx.Repo.Commit.CommitsByRange(page)
 | 
			
		||||
// 	// if err != nil {
 | 
			
		||||
// 	// 	ctx.Handle(500, "repo.Commits(CommitsByRange)", err)
 | 
			
		||||
// 	// 	return
 | 
			
		||||
// 	// }
 | 
			
		||||
	// Both `git log branchName` and `git log commitId` work.
 | 
			
		||||
	ctx.Data["Commits"], err = ctx.Repo.Commit.CommitsByRange(page)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "CommitsByRange", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
// 	ctx.Data["Username"] = userName
 | 
			
		||||
// 	ctx.Data["Reponame"] = repoName
 | 
			
		||||
// 	ctx.Data["CommitCount"] = commitsCount
 | 
			
		||||
// 	ctx.Data["LastPageNum"] = lastPage
 | 
			
		||||
// 	ctx.Data["NextPageNum"] = nextPage
 | 
			
		||||
// 	ctx.HTML(200, COMMITS)
 | 
			
		||||
// }
 | 
			
		||||
	ctx.Data["Username"] = userName
 | 
			
		||||
	ctx.Data["Reponame"] = repoName
 | 
			
		||||
	ctx.Data["CommitCount"] = commitsCount
 | 
			
		||||
	ctx.Data["LastPageNum"] = lastPage
 | 
			
		||||
	ctx.Data["NextPageNum"] = nextPage
 | 
			
		||||
	ctx.HTML(200, COMMITS)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// func SearchCommits(ctx *middleware.Context, params martini.Params) {
 | 
			
		||||
// 	ctx.Data["IsSearchPage"] = true
 | 
			
		||||
// 	ctx.Data["IsRepoToolbarCommits"] = true
 | 
			
		||||
func SearchCommits(ctx *middleware.Context) {
 | 
			
		||||
	ctx.Data["IsSearchPage"] = true
 | 
			
		||||
	ctx.Data["IsRepoToolbarCommits"] = true
 | 
			
		||||
 | 
			
		||||
// 	keyword := ctx.Query("q")
 | 
			
		||||
// 	if len(keyword) == 0 {
 | 
			
		||||
// 		ctx.Redirect(ctx.Repo.RepoLink + "/commits/" + ctx.Repo.BranchName)
 | 
			
		||||
// 		return
 | 
			
		||||
// 	}
 | 
			
		||||
	keyword := ctx.Query("q")
 | 
			
		||||
	if len(keyword) == 0 {
 | 
			
		||||
		ctx.Redirect(ctx.Repo.RepoLink + "/commits/" + ctx.Repo.BranchName)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
// 	userName := params["username"]
 | 
			
		||||
// 	repoName := params["reponame"]
 | 
			
		||||
	userName := ctx.Params(":username")
 | 
			
		||||
	repoName := ctx.Params(":reponame")
 | 
			
		||||
 | 
			
		||||
// 	brs, err := ctx.Repo.GitRepo.GetBranches()
 | 
			
		||||
// 	if err != nil {
 | 
			
		||||
// 		ctx.Handle(500, "repo.SearchCommits(GetBranches)", err)
 | 
			
		||||
// 		return
 | 
			
		||||
// 	} else if len(brs) == 0 {
 | 
			
		||||
// 		ctx.Handle(404, "repo.SearchCommits(GetBranches)", nil)
 | 
			
		||||
// 		return
 | 
			
		||||
// 	}
 | 
			
		||||
	brs, err := ctx.Repo.GitRepo.GetBranches()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "GetBranches", err)
 | 
			
		||||
		return
 | 
			
		||||
	} else if len(brs) == 0 {
 | 
			
		||||
		ctx.Handle(404, "GetBranches", nil)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
// 	// commits, err := ctx.Repo.Commit.SearchCommits(keyword)
 | 
			
		||||
// 	// if err != nil {
 | 
			
		||||
// 	// 	ctx.Handle(500, "repo.SearchCommits(SearchCommits)", err)
 | 
			
		||||
// 	// 	return
 | 
			
		||||
// 	// }
 | 
			
		||||
	commits, err := ctx.Repo.Commit.SearchCommits(keyword)
 | 
			
		||||
	if 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.HTML(200, COMMITS)
 | 
			
		||||
// }
 | 
			
		||||
	ctx.Data["Keyword"] = keyword
 | 
			
		||||
	ctx.Data["Username"] = userName
 | 
			
		||||
	ctx.Data["Reponame"] = repoName
 | 
			
		||||
	ctx.Data["CommitCount"] = commits.Len()
 | 
			
		||||
	ctx.Data["Commits"] = commits
 | 
			
		||||
	ctx.HTML(200, COMMITS)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// func Diff(ctx *middleware.Context, params martini.Params) {
 | 
			
		||||
// 	ctx.Data["IsRepoToolbarCommits"] = true
 | 
			
		||||
func Diff(ctx *middleware.Context) {
 | 
			
		||||
	ctx.Data["IsRepoToolbarCommits"] = true
 | 
			
		||||
 | 
			
		||||
// 	userName := ctx.Repo.Owner.Name
 | 
			
		||||
// 	repoName := ctx.Repo.Repository.Name
 | 
			
		||||
// 	commitId := ctx.Repo.CommitId
 | 
			
		||||
	userName := ctx.Repo.Owner.Name
 | 
			
		||||
	repoName := ctx.Repo.Repository.Name
 | 
			
		||||
	commitId := ctx.Repo.CommitId
 | 
			
		||||
 | 
			
		||||
// 	commit := ctx.Repo.Commit
 | 
			
		||||
	commit := ctx.Repo.Commit
 | 
			
		||||
 | 
			
		||||
// 	diff, err := models.GetDiff(models.RepoPath(userName, repoName), commitId)
 | 
			
		||||
// 	if err != nil {
 | 
			
		||||
// 		ctx.Handle(404, "repo.Diff(GetDiff)", err)
 | 
			
		||||
// 		return
 | 
			
		||||
// 	}
 | 
			
		||||
	diff, err := models.GetDiff(models.RepoPath(userName, repoName), commitId)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(404, "GetDiff", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
// 	isImageFile := func(name string) bool {
 | 
			
		||||
// 		// blob, err := ctx.Repo.Commit.GetBlobByPath(name)
 | 
			
		||||
// 		// if err != nil {
 | 
			
		||||
// 		// 	return false
 | 
			
		||||
// 		// }
 | 
			
		||||
	isImageFile := func(name string) bool {
 | 
			
		||||
		blob, err := ctx.Repo.Commit.GetBlobByPath(name)
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			return false
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
// 		// dataRc, err := blob.Data()
 | 
			
		||||
// 		// if err != nil {
 | 
			
		||||
// 		// 	return false
 | 
			
		||||
// 		// }
 | 
			
		||||
// 		// buf := make([]byte, 1024)
 | 
			
		||||
// 		// n, _ := dataRc.Read(buf)
 | 
			
		||||
// 		// if n > 0 {
 | 
			
		||||
// 		// 	buf = buf[:n]
 | 
			
		||||
// 		// }
 | 
			
		||||
// 		// dataRc.Close()
 | 
			
		||||
// 		// _, isImage := base.IsImageFile(buf)
 | 
			
		||||
// 		// return isImage
 | 
			
		||||
// 		return false
 | 
			
		||||
// 	}
 | 
			
		||||
		dataRc, err := blob.Data()
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			return false
 | 
			
		||||
		}
 | 
			
		||||
		buf := make([]byte, 1024)
 | 
			
		||||
		n, _ := dataRc.Read(buf)
 | 
			
		||||
		if n > 0 {
 | 
			
		||||
			buf = buf[:n]
 | 
			
		||||
		}
 | 
			
		||||
		_, isImage := base.IsImageFile(buf)
 | 
			
		||||
		return isImage
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
// 	parents := make([]string, commit.ParentCount())
 | 
			
		||||
// 	for i := 0; i < commit.ParentCount(); i++ {
 | 
			
		||||
// 		sha, err := commit.ParentId(i)
 | 
			
		||||
// 		parents[i] = sha.String()
 | 
			
		||||
// 		if err != nil {
 | 
			
		||||
// 			ctx.Handle(404, "repo.Diff", err)
 | 
			
		||||
// 			return
 | 
			
		||||
// 		}
 | 
			
		||||
// 	}
 | 
			
		||||
	parents := make([]string, commit.ParentCount())
 | 
			
		||||
	for i := 0; i < commit.ParentCount(); i++ {
 | 
			
		||||
		sha, err := commit.ParentId(i)
 | 
			
		||||
		parents[i] = sha.String()
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			ctx.Handle(404, "repo.Diff", err)
 | 
			
		||||
			return
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
// 	ctx.Data["Username"] = userName
 | 
			
		||||
// 	ctx.Data["Reponame"] = repoName
 | 
			
		||||
// 	ctx.Data["IsImageFile"] = isImageFile
 | 
			
		||||
// 	ctx.Data["Title"] = commit.Summary() + " · " + base.ShortSha(commitId)
 | 
			
		||||
// 	ctx.Data["Commit"] = commit
 | 
			
		||||
// 	ctx.Data["Diff"] = diff
 | 
			
		||||
// 	ctx.Data["Parents"] = parents
 | 
			
		||||
// 	ctx.Data["DiffNotAvailable"] = diff.NumFiles() == 0
 | 
			
		||||
// 	ctx.Data["SourcePath"] = "/" + path.Join(userName, repoName, "src", commitId)
 | 
			
		||||
// 	ctx.Data["RawPath"] = "/" + path.Join(userName, repoName, "raw", commitId)
 | 
			
		||||
// 	ctx.HTML(200, DIFF)
 | 
			
		||||
// }
 | 
			
		||||
	ctx.Data["Username"] = userName
 | 
			
		||||
	ctx.Data["Reponame"] = repoName
 | 
			
		||||
	ctx.Data["IsImageFile"] = isImageFile
 | 
			
		||||
	ctx.Data["Title"] = commit.Summary() + " · " + base.ShortSha(commitId)
 | 
			
		||||
	ctx.Data["Commit"] = commit
 | 
			
		||||
	ctx.Data["Diff"] = diff
 | 
			
		||||
	ctx.Data["Parents"] = parents
 | 
			
		||||
	ctx.Data["DiffNotAvailable"] = diff.NumFiles() == 0
 | 
			
		||||
	ctx.Data["SourcePath"] = "/" + path.Join(userName, repoName, "src", commitId)
 | 
			
		||||
	ctx.Data["RawPath"] = "/" + path.Join(userName, repoName, "raw", commitId)
 | 
			
		||||
	ctx.HTML(200, DIFF)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// func FileHistory(ctx *middleware.Context, params martini.Params) {
 | 
			
		||||
// 	ctx.Data["IsRepoToolbarCommits"] = true
 | 
			
		||||
func FileHistory(ctx *middleware.Context) {
 | 
			
		||||
	ctx.Data["IsRepoToolbarCommits"] = true
 | 
			
		||||
 | 
			
		||||
// 	fileName := params["_1"]
 | 
			
		||||
// 	if len(fileName) == 0 {
 | 
			
		||||
// 		Commits(ctx, params)
 | 
			
		||||
// 		return
 | 
			
		||||
// 	}
 | 
			
		||||
	fileName := ctx.Params("*")
 | 
			
		||||
	if len(fileName) == 0 {
 | 
			
		||||
		Commits(ctx)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
// 	userName := ctx.Repo.Owner.Name
 | 
			
		||||
// 	repoName := ctx.Repo.Repository.Name
 | 
			
		||||
// 	branchName := params["branchname"]
 | 
			
		||||
	userName := ctx.Repo.Owner.Name
 | 
			
		||||
	repoName := ctx.Repo.Repository.Name
 | 
			
		||||
	branchName := ctx.Params(":branchname")
 | 
			
		||||
 | 
			
		||||
// 	brs, err := ctx.Repo.GitRepo.GetBranches()
 | 
			
		||||
// 	if err != nil {
 | 
			
		||||
// 		ctx.Handle(500, "repo.FileHistory", err)
 | 
			
		||||
// 		return
 | 
			
		||||
// 	} else if len(brs) == 0 {
 | 
			
		||||
// 		ctx.Handle(404, "repo.FileHistory", nil)
 | 
			
		||||
// 		return
 | 
			
		||||
// 	}
 | 
			
		||||
	brs, err := ctx.Repo.GitRepo.GetBranches()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "GetBranches", err)
 | 
			
		||||
		return
 | 
			
		||||
	} else if len(brs) == 0 {
 | 
			
		||||
		ctx.Handle(404, "GetBranches", nil)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
// 	// commitsCount, err := ctx.Repo.GitRepo.FileCommitsCount(branchName, fileName)
 | 
			
		||||
// 	// if err != nil {
 | 
			
		||||
// 	// 	ctx.Handle(500, "repo.FileHistory(GetCommitsCount)", err)
 | 
			
		||||
// 	// 	return
 | 
			
		||||
// 	// } else if commitsCount == 0 {
 | 
			
		||||
// 	// 	ctx.Handle(404, "repo.FileHistory", nil)
 | 
			
		||||
// 	// 	return
 | 
			
		||||
// 	// }
 | 
			
		||||
	commitsCount, err := ctx.Repo.GitRepo.FileCommitsCount(branchName, fileName)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "repo.FileHistory(GetCommitsCount)", err)
 | 
			
		||||
		return
 | 
			
		||||
	} else if commitsCount == 0 {
 | 
			
		||||
		ctx.Handle(404, "repo.FileHistory", nil)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
// 	// Calculate and validate page number.
 | 
			
		||||
// 	// 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
 | 
			
		||||
// 	// }
 | 
			
		||||
	// Calculate and validate page number.
 | 
			
		||||
	page := com.StrTo(ctx.Query("p")).MustInt()
 | 
			
		||||
	if page < 1 {
 | 
			
		||||
		page = 1
 | 
			
		||||
	}
 | 
			
		||||
	lastPage := page - 1
 | 
			
		||||
	if lastPage < 0 {
 | 
			
		||||
		lastPage = 0
 | 
			
		||||
	}
 | 
			
		||||
	nextPage := page + 1
 | 
			
		||||
	if nextPage*50 > commitsCount {
 | 
			
		||||
		nextPage = 0
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
// 	// ctx.Data["Commits"], err = ctx.Repo.GitRepo.CommitsByFileAndRange(
 | 
			
		||||
// 	// 	branchName, fileName, page)
 | 
			
		||||
// 	// if err != nil {
 | 
			
		||||
// 	// 	ctx.Handle(500, "repo.FileHistory(CommitsByRange)", err)
 | 
			
		||||
// 	// 	return
 | 
			
		||||
// 	// }
 | 
			
		||||
	ctx.Data["Commits"], err = ctx.Repo.GitRepo.CommitsByFileAndRange(
 | 
			
		||||
		branchName, fileName, page)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		ctx.Handle(500, "repo.FileHistory(CommitsByRange)", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
// 	ctx.Data["Username"] = userName
 | 
			
		||||
// 	ctx.Data["Reponame"] = repoName
 | 
			
		||||
// 	ctx.Data["FileName"] = fileName
 | 
			
		||||
// 	// ctx.Data["CommitCount"] = commitsCount
 | 
			
		||||
// 	// ctx.Data["LastPageNum"] = lastPage
 | 
			
		||||
// 	// ctx.Data["NextPageNum"] = nextPage
 | 
			
		||||
// 	ctx.HTML(200, COMMITS)
 | 
			
		||||
// }
 | 
			
		||||
	ctx.Data["Username"] = userName
 | 
			
		||||
	ctx.Data["Reponame"] = repoName
 | 
			
		||||
	ctx.Data["FileName"] = fileName
 | 
			
		||||
	ctx.Data["CommitCount"] = commitsCount
 | 
			
		||||
	ctx.Data["LastPageNum"] = lastPage
 | 
			
		||||
	ctx.Data["NextPageNum"] = nextPage
 | 
			
		||||
	ctx.HTML(200, COMMITS)
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user