find: Move functions to struct

This commit is contained in:
Alexander Neumann 2017-06-04 11:38:46 +02:00
parent 3b7ca4ac35
commit 7b5efaf7b0

View file

@ -12,7 +12,6 @@ import (
"restic" "restic"
"restic/debug" "restic/debug"
"restic/errors" "restic/errors"
"restic/repository"
) )
var cmdFind = &cobra.Command{ var cmdFind = &cobra.Command{
@ -172,10 +171,17 @@ func (s *statefulOutput) Finish() {
} }
} }
func findInTree(repo *repository.Repository, pat *findPattern, id restic.ID, prefix string, state *statefulOutput) error { // Finder bundles information needed to find a file or directory.
debug.Log("%v checking tree %v\n", prefix, id) type Finder struct {
repo restic.Repository
pat findPattern
out statefulOutput
}
tree, err := repo.LoadTree(id) func (f *Finder) findInTree(treeID restic.ID, prefix string) error {
debug.Log("%v checking tree %v\n", prefix, treeID.Str())
tree, err := f.repo.LoadTree(treeID)
if err != nil { if err != nil {
return err return err
} }
@ -184,34 +190,32 @@ func findInTree(repo *repository.Repository, pat *findPattern, id restic.ID, pre
debug.Log(" testing entry %q\n", node.Name) debug.Log(" testing entry %q\n", node.Name)
name := node.Name name := node.Name
if pat.ignoreCase { if f.pat.ignoreCase {
name = strings.ToLower(name) name = strings.ToLower(name)
} }
m, err := filepath.Match(pat.pattern, name) m, err := filepath.Match(f.pat.pattern, name)
if err != nil { if err != nil {
return err return err
} }
if m { if m {
debug.Log(" pattern matches\n") if !f.pat.oldest.IsZero() && node.ModTime.Before(f.pat.oldest) {
if !pat.oldest.IsZero() && node.ModTime.Before(pat.oldest) { debug.Log(" ModTime is older than %s\n", f.pat.oldest)
debug.Log(" ModTime is older than %s\n", pat.oldest)
continue continue
} }
if !pat.newest.IsZero() && node.ModTime.After(pat.newest) { if !f.pat.newest.IsZero() && node.ModTime.After(f.pat.newest) {
debug.Log(" ModTime is newer than %s\n", pat.newest) debug.Log(" ModTime is newer than %s\n", f.pat.newest)
continue continue
} }
state.Print(prefix, node) debug.Log(" found match\n")
} else { f.out.Print(prefix, node)
debug.Log(" pattern does not match\n")
} }
if node.Type == "dir" { if node.Type == "dir" {
if err := findInTree(repo, pat, *node.Subtree, filepath.Join(prefix, node.Name), state); err != nil { if err := f.findInTree(*node.Subtree, filepath.Join(prefix, node.Name)); err != nil {
return err return err
} }
} }
@ -220,11 +224,11 @@ func findInTree(repo *repository.Repository, pat *findPattern, id restic.ID, pre
return nil return nil
} }
func findInSnapshot(repo *repository.Repository, sn *restic.Snapshot, pat findPattern, state *statefulOutput) error { func (f *Finder) findInSnapshot(sn *restic.Snapshot) error {
debug.Log("searching in snapshot %s\n for entries within [%s %s]", sn.ID(), pat.oldest, pat.newest) debug.Log("searching in snapshot %s\n for entries within [%s %s]", sn.ID(), f.pat.oldest, f.pat.newest)
state.newsn = sn f.out.newsn = sn
if err := findInTree(repo, &pat, *sn.Tree, string(filepath.Separator), state); err != nil { if err := f.findInTree(*sn.Tree, string(filepath.Separator)); err != nil {
return err return err
} }
return nil return nil
@ -273,13 +277,18 @@ func runFind(opts FindOptions, gopts GlobalOptions, args []string) error {
ctx, cancel := context.WithCancel(gopts.ctx) ctx, cancel := context.WithCancel(gopts.ctx)
defer cancel() defer cancel()
state := statefulOutput{ListLong: opts.ListLong, JSON: globalOptions.JSON}
f := &Finder{
repo: repo,
pat: pat,
out: statefulOutput{ListLong: opts.ListLong, JSON: globalOptions.JSON},
}
for sn := range FindFilteredSnapshots(ctx, repo, opts.Host, opts.Tags, opts.Paths, opts.Snapshots) { for sn := range FindFilteredSnapshots(ctx, repo, opts.Host, opts.Tags, opts.Paths, opts.Snapshots) {
if err = findInSnapshot(repo, sn, pat, &state); err != nil { if err = f.findInSnapshot(sn); err != nil {
return err return err
} }
} }
state.Finish() f.out.Finish()
return nil return nil
} }