|
|
|
@ -6,12 +6,12 @@ package repo
|
|
|
|
|
|
|
|
|
|
import ( |
|
|
|
|
"container/list" |
|
|
|
|
"fmt" |
|
|
|
|
"path" |
|
|
|
|
|
|
|
|
|
"github.com/codegangsta/martini" |
|
|
|
|
|
|
|
|
|
"github.com/gogits/gogs/models" |
|
|
|
|
"github.com/gogits/gogs/modules/base" |
|
|
|
|
"github.com/gogits/gogs/modules/middleware" |
|
|
|
|
) |
|
|
|
|
|
|
|
|
@ -50,25 +50,49 @@ func Commits(ctx *middleware.Context, params martini.Params) {
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
func Diff(ctx *middleware.Context, params martini.Params) { |
|
|
|
|
fmt.Println(params["branchname"]) |
|
|
|
|
commit, err := models.GetCommit(params["username"], params["reponame"], params["branchname"], params["commitid"]) |
|
|
|
|
userName := params["username"] |
|
|
|
|
repoName := params["reponame"] |
|
|
|
|
branchName := params["branchname"] |
|
|
|
|
commitId := params["commitid"] |
|
|
|
|
|
|
|
|
|
commit, err := models.GetCommit(userName, repoName, branchName, commitId) |
|
|
|
|
if err != nil { |
|
|
|
|
ctx.Handle(404, "repo.Diff", err) |
|
|
|
|
return |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
diff, err := models.GetDiff(models.RepoPath(params["username"], params["reponame"]), params["commitid"]) |
|
|
|
|
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 |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
shortSha := params["commitid"][:10] |
|
|
|
|
ctx.Data["IsImageFile"] = isImageFile |
|
|
|
|
ctx.Data["Title"] = commit.Message() + " · " + shortSha |
|
|
|
|
ctx.Data["Commit"] = commit |
|
|
|
|
ctx.Data["ShortSha"] = shortSha |
|
|
|
|
ctx.Data["Diff"] = diff |
|
|
|
|
ctx.Data["IsRepoToolbarCommits"] = true |
|
|
|
|
ctx.Data["SourcePath"] = "/" + path.Join(params["username"], params["reponame"], "src", params["commitid"]) |
|
|
|
|
ctx.Data["SourcePath"] = "/" + path.Join(userName, repoName, "src", commitId) |
|
|
|
|
ctx.Data["RawPath"] = "/" + path.Join(userName, repoName, "raw", commitId) |
|
|
|
|
ctx.HTML(200, "repo/diff") |
|
|
|
|
} |
|
|
|
|