forked from TrueCloudLab/rclone
swift: Make sure we read the size for 0 length files - Fixes #237
This was causing a problem with sync for chunked files. The directory listing would read their size back as 0 and see that the size had changed and immediately resync it.
This commit is contained in:
parent
2aa3c0a2af
commit
8369b5209f
1 changed files with 8 additions and 3 deletions
|
@ -210,6 +210,12 @@ func (f *Fs) newFsObjectWithInfo(remote string, info *swift.Object) fs.Object {
|
||||||
fs: f,
|
fs: f,
|
||||||
remote: remote,
|
remote: remote,
|
||||||
}
|
}
|
||||||
|
// Note that due to a quirk of swift, manifest files are
|
||||||
|
// returned as 0 bytes in the listing. Correct this here by
|
||||||
|
// making sure we read the full metadata for all 0 byte files.
|
||||||
|
if info != nil && info.Bytes == 0 {
|
||||||
|
info = nil
|
||||||
|
}
|
||||||
if info != nil {
|
if info != nil {
|
||||||
// Set info but not headers
|
// Set info but not headers
|
||||||
o.info = *info
|
o.info = *info
|
||||||
|
@ -537,9 +543,8 @@ func (o *Object) SetModTime(modTime time.Time) {
|
||||||
|
|
||||||
// Storable returns if this object is storable
|
// Storable returns if this object is storable
|
||||||
//
|
//
|
||||||
// It reads the metadata for <= directoryMarkerMaxSize byte objects then compares the
|
// It compares the Content-Type to directoryMarkerContentType - that
|
||||||
// Content-Type to directoryMarkerContentType - that makes it a
|
// makes it a directory marker which is not storable.
|
||||||
// directory marker which is not storable.
|
|
||||||
func (o *Object) Storable() bool {
|
func (o *Object) Storable() bool {
|
||||||
return o.info.ContentType != directoryMarkerContentType
|
return o.info.ContentType != directoryMarkerContentType
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue