summaryrefslogtreecommitdiffstats
path: root/models
diff options
context:
space:
mode:
authorLunny Xiao <xiaolunwen@gmail.com>2014-03-17 20:16:58 +0800
committerLunny Xiao <xiaolunwen@gmail.com>2014-03-17 20:16:58 +0800
commitbe8baea7ad269eb633a6b5a569b904982021723d (patch)
treed616b64938ce64cb5bb01c5b91fe20723595cbef /models
parentf2b0dc18b5cc7e9f42bfc2e45f37ffb45d478fd2 (diff)
downloadgitea-be8baea7ad269eb633a6b5a569b904982021723d.tar.gz
gitea-be8baea7ad269eb633a6b5a569b904982021723d.zip
bug fixed
Diffstat (limited to 'models')
-rw-r--r--models/repo2.go26
1 files changed, 2 insertions, 24 deletions
diff --git a/models/repo2.go b/models/repo2.go
index 3c170a06f4..91c057808b 100644
--- a/models/repo2.go
+++ b/models/repo2.go
@@ -37,28 +37,6 @@ type RepoFile struct {
LastCommit string
}
-func findTree(repo *git.Repository, tree *git.Tree, rpath string) *git.Tree {
- if rpath == "" {
- return tree
- }
- paths := strings.Split(rpath, "/")
- var g = tree
- for _, p := range paths {
- s := g.EntryByName(p)
- if s == nil {
- return nil
- }
- g, err := repo.LookupTree(s.Id)
- if err != nil {
- return nil
- }
- if g == nil {
- return nil
- }
- }
- return g
-}
-
func (file *RepoFile) LookupBlob() (*git.Blob, error) {
if file.Repo == nil {
return nil, ErrRepoFileNotLoaded
@@ -116,7 +94,7 @@ func GetReposFiles(userName, reposName, branchName, rpath string) ([]*RepoFile,
if cm.ParentCount() == 0 {
break
} else if cm.ParentCount() == 1 {
- pt := findTree(repo, cm.Parent(0).Tree, dirname)
+ pt, _ := repo.SubTree(cm.Parent(0).Tree, dirname)
if pt == nil {
break
}
@@ -131,7 +109,7 @@ func GetReposFiles(userName, reposName, branchName, rpath string) ([]*RepoFile,
var sameIdcnt = 0
for i := 0; i < cm.ParentCount(); i++ {
p := cm.Parent(i)
- pt := findTree(repo, p.Tree, dirname)
+ pt, _ := repo.SubTree(p.Tree, dirname)
var pEntry *git.TreeEntry
if pt != nil {
pEntry = pt.EntryByName(entry.Name)