From 5e0813ca04027cb2cd40e2d6a81369d016b499fe Mon Sep 17 00:00:00 2001 From: Alexander Neumann Date: Sun, 8 May 2016 22:20:57 +0200 Subject: [PATCH] fuse: Use correct file size in case it's zero --- src/restic/fuse/file.go | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/src/restic/fuse/file.go b/src/restic/fuse/file.go index 2f5c4b05c..2f0db5738 100644 --- a/src/restic/fuse/file.go +++ b/src/restic/fuse/file.go @@ -49,6 +49,7 @@ var blobPool = sync.Pool{ func newFile(repo BlobLoader, node *restic.Node, ownerIsRoot bool) (*file, error) { debug.Log("newFile", "create new file for %v with %d blobs", node.Name, len(node.Content)) + var bytes uint64 sizes := make([]uint, len(node.Content)) for i, id := range node.Content { size, err := repo.LookupBlobSize(id) @@ -57,6 +58,12 @@ func newFile(repo BlobLoader, node *restic.Node, ownerIsRoot bool) (*file, error } sizes[i] = size + bytes += uint64(size) + } + + if bytes != node.Size { + debug.Log("newFile", "sizes do not match: node.Size %v != size %v, using real size", node.Size, bytes) + node.Size = bytes } return &file{