|
@ -3,7 +3,6 @@ package filer |
|
|
import ( |
|
|
import ( |
|
|
"bytes" |
|
|
"bytes" |
|
|
"fmt" |
|
|
"fmt" |
|
|
"github.com/chrislusf/seaweedfs/weed/wdclient" |
|
|
|
|
|
"io" |
|
|
"io" |
|
|
"math" |
|
|
"math" |
|
|
"net/url" |
|
|
"net/url" |
|
@ -11,6 +10,8 @@ import ( |
|
|
"sync" |
|
|
"sync" |
|
|
"time" |
|
|
"time" |
|
|
|
|
|
|
|
|
|
|
|
"github.com/chrislusf/seaweedfs/weed/wdclient" |
|
|
|
|
|
|
|
|
"github.com/golang/protobuf/proto" |
|
|
"github.com/golang/protobuf/proto" |
|
|
|
|
|
|
|
|
"github.com/chrislusf/seaweedfs/weed/glog" |
|
|
"github.com/chrislusf/seaweedfs/weed/glog" |
|
@ -63,14 +64,14 @@ func ResolveChunkManifest(lookupFileIdFn wdclient.LookupFileIdFunctionType, chun |
|
|
|
|
|
|
|
|
resolvedChunks, err := ResolveOneChunkManifest(lookupFileIdFn, chunk) |
|
|
resolvedChunks, err := ResolveOneChunkManifest(lookupFileIdFn, chunk) |
|
|
if err != nil { |
|
|
if err != nil { |
|
|
return chunks, nil, err |
|
|
|
|
|
|
|
|
return dataChunks, nil, err |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
manifestChunks = append(manifestChunks, chunk) |
|
|
manifestChunks = append(manifestChunks, chunk) |
|
|
// recursive
|
|
|
// recursive
|
|
|
subDataChunks, subManifestChunks, subErr := ResolveChunkManifest(lookupFileIdFn, resolvedChunks, startOffset, stopOffset) |
|
|
subDataChunks, subManifestChunks, subErr := ResolveChunkManifest(lookupFileIdFn, resolvedChunks, startOffset, stopOffset) |
|
|
if subErr != nil { |
|
|
if subErr != nil { |
|
|
return chunks, nil, subErr |
|
|
|
|
|
|
|
|
return dataChunks, nil, subErr |
|
|
} |
|
|
} |
|
|
dataChunks = append(dataChunks, subDataChunks...) |
|
|
dataChunks = append(dataChunks, subDataChunks...) |
|
|
manifestChunks = append(manifestChunks, subManifestChunks...) |
|
|
manifestChunks = append(manifestChunks, subManifestChunks...) |
|
|