aboutsummaryrefslogtreecommitdiff
path: root/weed/filesys/dir.go
diff options
context:
space:
mode:
authorChris Lu <chris.lu@gmail.com>2018-05-14 02:02:17 -0700
committerChris Lu <chris.lu@gmail.com>2018-05-14 02:02:17 -0700
commit58954bf46f5098c1181920bd04ac9e45f6b97913 (patch)
tree383aa901b80d84992df019dbb6a5c0e7ceaa6b9e /weed/filesys/dir.go
parent67401f190851f645e54687c502f9af6ad0e6651d (diff)
downloadseaweedfs-58954bf46f5098c1181920bd04ac9e45f6b97913.tar.xz
seaweedfs-58954bf46f5098c1181920bd04ac9e45f6b97913.zip
pass file attributes from filer to mount
Diffstat (limited to 'weed/filesys/dir.go')
-rw-r--r--weed/filesys/dir.go4
1 files changed, 3 insertions, 1 deletions
diff --git a/weed/filesys/dir.go b/weed/filesys/dir.go
index c1c6afe9c..d408dc1ac 100644
--- a/weed/filesys/dir.go
+++ b/weed/filesys/dir.go
@@ -12,6 +12,7 @@ import (
"github.com/chrislusf/seaweedfs/weed/filer"
"github.com/chrislusf/seaweedfs/weed/glog"
"github.com/chrislusf/seaweedfs/weed/pb/filer_pb"
+ "time"
)
type Dir struct {
@@ -74,7 +75,7 @@ func (dir *Dir) Lookup(ctx context.Context, name string) (node fs.Node, err erro
if entry.IsDirectory {
node = &Dir{Path: path.Join(dir.Path, name), wfs: dir.wfs}
} else {
- node = &File{FileId: filer.FileId(entry.FileId), Name: name, wfs: dir.wfs}
+ node = &File{FileId: filer.FileId(entry.FileId), Name: name, dir: dir, wfs: dir.wfs}
}
dir.NodeMap[name] = node
return node, nil
@@ -104,6 +105,7 @@ func (dir *Dir) ReadDirAll(ctx context.Context) (ret []fuse.Dirent, err error) {
} else {
dirent := fuse.Dirent{Name: entry.Name, Type: fuse.DT_File}
ret = append(ret, dirent)
+ dir.wfs.listDirectoryEntriesCache.Set(dir.Path+"/"+entry.Name, entry.Attributes, 3*time.Second)
}
}