summaryrefslogtreecommitdiffstats
path: root/routers
diff options
context:
space:
mode:
authorUnknwon <u@gogs.io>2015-12-13 22:58:12 -0500
committerUnknwon <u@gogs.io>2015-12-13 22:58:12 -0500
commit7509fa2c33b6eeff20091a4c6883c006d99b3425 (patch)
tree91f436036cb421eed20e7e6caca5bd96150866f7 /routers
parentacdb4d8bdd31ee910c6c5fa6db65379703bdfbca (diff)
downloadgitea-7509fa2c33b6eeff20091a4c6883c006d99b3425.tar.gz
gitea-7509fa2c33b6eeff20091a4c6883c006d99b3425.zip
improve get commits performance
Diffstat (limited to 'routers')
-rw-r--r--routers/repo/view.go36
1 files changed, 5 insertions, 31 deletions
diff --git a/routers/repo/view.go b/routers/repo/view.go
index f019256d3e..e4815bf0c5 100644
--- a/routers/repo/view.go
+++ b/routers/repo/view.go
@@ -8,12 +8,11 @@ import (
"bytes"
"io/ioutil"
"path"
- "path/filepath"
"strings"
"github.com/Unknwon/paginater"
- "github.com/gogits/git-shell"
+ git "github.com/gogits/git-shell"
"github.com/gogits/gogs/models"
"github.com/gogits/gogs/modules/base"
@@ -134,38 +133,13 @@ func Home(ctx *middleware.Context) {
}
entries.Sort()
- files := make([][]interface{}, 0, len(entries))
- for _, te := range entries {
- if te.Type != git.OBJECT_COMMIT {
- c, err := ctx.Repo.Commit.GetCommitByPath(filepath.Join(treePath, te.Name()))
- if err != nil {
- ctx.Handle(500, "GetCommitByPath", err)
- return
- }
- files = append(files, []interface{}{te, c})
- } else {
- sm, err := ctx.Repo.Commit.GetSubModule(path.Join(treename, te.Name()))
- if err != nil {
- ctx.Handle(500, "GetSubModule", err)
- return
- }
- smUrl := ""
- if sm != nil {
- smUrl = sm.Url
- }
-
- c, err := ctx.Repo.Commit.GetCommitByPath(filepath.Join(treePath, te.Name()))
- if err != nil {
- ctx.Handle(500, "GetCommitByPath", err)
- return
- }
- files = append(files, []interface{}{te, git.NewSubModuleFile(c, smUrl, te.ID.String())})
- }
+ ctx.Data["Files"], err = entries.GetCommitsInfo(ctx.Repo.Commit, treePath)
+ if err != nil {
+ ctx.Handle(500, "GetCommitsInfo", err)
+ return
}
- ctx.Data["Files"] = files
var readmeFile *git.Blob
-
for _, f := range entries {
if f.IsDir() || !base.IsReadmeFile(f.Name()) {
continue