1
// Copyright 2015 The Gogs Authors. All rights reserved.
2
// Copyright 2019 The Gitea Authors. All rights reserved.
3
// SPDX-License-Identifier: MIT
12
"github.com/go-git/go-git/v5/plumbing"
13
"github.com/go-git/go-git/v5/plumbing/object"
16
// Tree represents a flat directory listing.
22
gogitTree *object.Tree
28
func (t *Tree) loadTreeObject() error {
29
gogitTree, err := t.repo.gogitRepo.TreeObject(plumbing.Hash(t.ID.RawValue()))
34
t.gogitTree = gogitTree
38
// ListEntries returns all entries of current tree.
39
func (t *Tree) ListEntries() (Entries, error) {
40
if t.gogitTree == nil {
41
err := t.loadTreeObject()
47
entries := make([]*TreeEntry, len(t.gogitTree.Entries))
48
for i, entry := range t.gogitTree.Entries {
49
entries[i] = &TreeEntry{
50
ID: ParseGogitHash(entry.Hash),
51
gogitTreeEntry: &t.gogitTree.Entries[i],
59
// ListEntriesRecursiveWithSize returns all entries of current tree recursively including all subtrees
60
func (t *Tree) ListEntriesRecursiveWithSize() (Entries, error) {
61
if t.gogitTree == nil {
62
err := t.loadTreeObject()
68
var entries []*TreeEntry
69
seen := map[plumbing.Hash]bool{}
70
walker := object.NewTreeWalker(t.gogitTree, true, seen)
72
fullName, entry, err := walker.Next()
83
convertedEntry := &TreeEntry{
84
ID: ParseGogitHash(entry.Hash),
85
gogitTreeEntry: &entry,
89
entries = append(entries, convertedEntry)
95
// ListEntriesRecursiveFast is the alias of ListEntriesRecursiveWithSize for the gogit version
96
func (t *Tree) ListEntriesRecursiveFast() (Entries, error) {
97
return t.ListEntriesRecursiveWithSize()