]> source.dussan.org Git - gitea.git/commitdiff
bug fixed
authorLunny Xiao <xiaolunwen@gmail.com>
Mon, 17 Mar 2014 12:16:58 +0000 (20:16 +0800)
committerLunny Xiao <xiaolunwen@gmail.com>
Mon, 17 Mar 2014 12:16:58 +0000 (20:16 +0800)
models/repo2.go

index 3c170a06f4f5811ab498342a2ac3b7f36b2b81cf..91c057808b1e1693da9f1cbc139fc0a1ecebaa18 100644 (file)
@@ -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)