|
@ -10,7 +10,7 @@ import ( |
|
|
"github.com/chrislusf/seaweedfs/weed/util" |
|
|
"github.com/chrislusf/seaweedfs/weed/util" |
|
|
) |
|
|
) |
|
|
|
|
|
|
|
|
func EnsureVisited(mc *MetaCache, client filer_pb.FilerClient, dirPath util.FullPath, entryChan chan *filer.Entry) error { |
|
|
|
|
|
|
|
|
func EnsureVisited(mc *MetaCache, client filer_pb.FilerClient, dirPath util.FullPath) error { |
|
|
|
|
|
|
|
|
currentPath := dirPath |
|
|
currentPath := dirPath |
|
|
|
|
|
|
|
@ -22,15 +22,9 @@ func EnsureVisited(mc *MetaCache, client filer_pb.FilerClient, dirPath util.Full |
|
|
return nil |
|
|
return nil |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if entryChan != nil && dirPath == currentPath { |
|
|
|
|
|
if err := doEnsureVisited(mc, client, currentPath, entryChan); err != nil { |
|
|
|
|
|
|
|
|
if err := doEnsureVisited(mc, client, currentPath); err != nil { |
|
|
return err |
|
|
return err |
|
|
} |
|
|
} |
|
|
} else { |
|
|
|
|
|
if err := doEnsureVisited(mc, client, currentPath, nil); err != nil { |
|
|
|
|
|
return err |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// continue to parent directory
|
|
|
// continue to parent directory
|
|
|
if currentPath != mc.root { |
|
|
if currentPath != mc.root { |
|
@ -45,7 +39,7 @@ func EnsureVisited(mc *MetaCache, client filer_pb.FilerClient, dirPath util.Full |
|
|
|
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func doEnsureVisited(mc *MetaCache, client filer_pb.FilerClient, path util.FullPath, entryChan chan *filer.Entry) error { |
|
|
|
|
|
|
|
|
func doEnsureVisited(mc *MetaCache, client filer_pb.FilerClient, path util.FullPath) error { |
|
|
|
|
|
|
|
|
glog.V(4).Infof("ReadDirAllEntries %s ...", path) |
|
|
glog.V(4).Infof("ReadDirAllEntries %s ...", path) |
|
|
|
|
|
|
|
@ -59,9 +53,6 @@ func doEnsureVisited(mc *MetaCache, client filer_pb.FilerClient, path util.FullP |
|
|
glog.V(0).Infof("read %s: %v", entry.FullPath, err) |
|
|
glog.V(0).Infof("read %s: %v", entry.FullPath, err) |
|
|
return err |
|
|
return err |
|
|
} |
|
|
} |
|
|
if entryChan != nil { |
|
|
|
|
|
entryChan <- entry |
|
|
|
|
|
} |
|
|
|
|
|
return nil |
|
|
return nil |
|
|
}) |
|
|
}) |
|
|
}) |
|
|
}) |
|
|