First LS version

This commit is contained in:
Quentin 2021-04-23 16:44:42 +02:00
parent c09c5406e9
commit dff728baea
Signed by: quentin
GPG key ID: A98E9B769E4FF428
4 changed files with 41 additions and 18 deletions

View file

@ -4,7 +4,7 @@ import(
"log" "log"
) )
func cmdHead(config configCollect) { func cmdHead(config *configCollect) {
rc := NewRepoCommits(config) rc := NewRepoCommits(config)
rc.CollectDescs() rc.CollectDescs()
@ -28,5 +28,16 @@ func cmdHead(config configCollect) {
func cmdLs(config *configCollect) { func cmdLs(config *configCollect) {
rf := NewRepoFs(config) rf := NewRepoFs(config)
log.Println(rf.EntryNode.String()) rf.EntryNode.Walk(ExpandOnlyDirectory, -1)
stackFolders := []*DirNode{rf.EntryNode}
for len(stackFolders) > 0 {
fold := stackFolders[0]
stackFolders = append(stackFolders[1:], fold.Folders...)
log.Println(fold.String())
for _, file := range fold.Files {
log.Println(file.String())
}
}
} }

View file

@ -13,7 +13,7 @@ type Empty struct{}
var empty Empty var empty Empty
type RepoCommits struct { type RepoCommits struct {
Config configCollect Config *configCollect
CommitDesc map[string]string CommitDesc map[string]string
CommitContent map[string]*CommitNode CommitContent map[string]*CommitNode
Root map[*CommitNode]Empty Root map[*CommitNode]Empty
@ -64,7 +64,7 @@ RepoDesc: %v
`, nilable(c.RootId), nilable(c.CreatorName), nilable(c.Creator), nilable(c.Description), time.Unix(c.Ctime, 0), nilable(c.RepoName), nilable(c.RepoDesc)) `, nilable(c.RootId), nilable(c.CreatorName), nilable(c.Creator), nilable(c.Description), time.Unix(c.Ctime, 0), nilable(c.RepoName), nilable(c.RepoDesc))
} }
func NewRepoCommits (config configCollect) *RepoCommits { func NewRepoCommits (config *configCollect) *RepoCommits {
rc := new(RepoCommits) rc := new(RepoCommits)
rc.Config = config rc.Config = config
rc.CommitDesc = make(map[string]string) rc.CommitDesc = make(map[string]string)

32
fs.go
View file

@ -53,6 +53,7 @@ type FileNode struct {
Config *configCollect Config *configCollect
Ent *DirEnt Ent *DirEnt
Elem FileElem Elem FileElem
AbsolutePath string
} }
type RepoFs struct { type RepoFs struct {
@ -70,6 +71,7 @@ func NewRepoFs(config *configCollect) *RepoFs {
rf.EntryNode.AbsolutePath = "/" rf.EntryNode.AbsolutePath = "/"
rf.EntryNode.Files = make([]*FileNode,0) rf.EntryNode.Files = make([]*FileNode,0)
rf.EntryNode.Folders = make([]*DirNode,0) rf.EntryNode.Folders = make([]*DirNode,0)
rf.EntryNode.Config = config
return rf return rf
} }
@ -90,10 +92,15 @@ func (dn* DirNode) String() string {
return fmt.Sprintf("%v %v", dn.Ent.Id[:6], dn.AbsolutePath) return fmt.Sprintf("%v %v", dn.Ent.Id[:6], dn.AbsolutePath)
} }
func (fn* FileNode) String() string {
return fmt.Sprintf("%v %v", fn.Ent.Id[:6], fn.AbsolutePath)
}
func NewFileNode(parent *DirNode, ent *DirEnt) *FileNode { func NewFileNode(parent *DirNode, ent *DirEnt) *FileNode {
fn := new (FileNode) fn := new (FileNode)
fn.Ent = ent fn.Ent = ent
fn.Config = parent.Config fn.Config = parent.Config
fn.AbsolutePath = parent.AbsolutePath + ent.Name
return fn return fn
} }
@ -144,20 +151,25 @@ const (
ExpandAll ExpandAll
) )
func (dn* DirNode) Expand(strat ExpandStrat) { func (dn* DirNode) Walk(strat ExpandStrat, depth int) {
for _, cdn := range dn.Folders { qNode := []*DirNode{dn}
cdn.Parse() for len(qNode) > 0 && depth != 0{
if depth > 0 { depth = depth - 1 }
cursor := qNode[0]
qNode = qNode[1:]
cursor.Parse()
for _, ndn := range dn.Folders {
qNode = append(qNode, ndn)
} }
if strat == ExpandAll { if ExpandAll == strat {
for _, cfn := range dn.Files { for _, nfn := range dn.Files {
cfn.Parse() nfn.Parse()
}
} }
} }
}
func (dn* DirNode) Walk(strat ExpandStrat) {
} }
/*func (rf* RepoFs) Walk() { /*func (rf* RepoFs) Walk() {

View file

@ -19,10 +19,10 @@ Options:
-h --help Show this screen -h --help Show this screen
--storage=<sto> Set Seafile storage path [default: ./storage]` --storage=<sto> Set Seafile storage path [default: ./storage]`
var config configCollect config := new(configCollect)
opts, err := docopt.ParseDoc(usage) opts, err := docopt.ParseDoc(usage)
if err != nil { log.Fatal(err) } if err != nil { log.Fatal(err) }
opts.Bind(&config) opts.Bind(config)
checkRootFolder(config.Storage) checkRootFolder(config.Storage)
rexists := repoExistsIn(config.Storage, config.RepoId) rexists := repoExistsIn(config.Storage, config.RepoId)
@ -32,7 +32,7 @@ Options:
cmdHead(config) cmdHead(config)
} else if config.Ls { } else if config.Ls {
if !rexists["fs"] { log.Fatal("No fs folder found for repo ",config.RepoId) } if !rexists["fs"] { log.Fatal("No fs folder found for repo ",config.RepoId) }
cmdLs(&config) cmdLs(config)
} else if config.Dump { } else if config.Dump {
if !rexists["fs"] { log.Fatal("No fs folder found for repo ",config.RepoId) } if !rexists["fs"] { log.Fatal("No fs folder found for repo ",config.RepoId) }
if !rexists["blocks"] { log.Fatal("No blocks folder found for repo ",config.RepoId) } if !rexists["blocks"] { log.Fatal("No blocks folder found for repo ",config.RepoId) }