XL non-recursive fix (#1450)

This commit is contained in:
karthic rao 2016-05-02 11:46:44 +05:30 committed by Harshavardhana
parent d006129fb5
commit 2393a3a0be

View File

@ -296,35 +296,33 @@ func (xl xlObjects) ListObjects(bucket, prefix, marker, delimiter string, maxKey
for _, fileInfo := range fileInfos { for _, fileInfo := range fileInfos {
// FIXME: use fileInfo.Mode.IsDir() instead after fixing the bug in // FIXME: use fileInfo.Mode.IsDir() instead after fixing the bug in
// XL listing which is not reseting the Mode to 0 for leaf dirs. // XL listing which is not reseting the Mode to 0 for leaf dirs.
if strings.HasSuffix(fileInfo.Name, slashSeparator) { if strings.HasSuffix(fileInfo.Name, slashSeparator) && isLeafDirectory(xl.storage, bucket, fileInfo.Name) {
if isLeafDirectory(xl.storage, bucket, fileInfo.Name) {
fileInfo.Name = strings.TrimSuffix(fileInfo.Name, slashSeparator)
// Set the Mode to a "regular" file. // Set the Mode to a "regular" file.
fileInfo.Mode = 0
var info MultipartObjectInfo var info MultipartObjectInfo
info, err = xl.getMultipartObjectInfo(bucket, fileInfo.Name) info, err = xl.getMultipartObjectInfo(bucket, fileInfo.Name)
if err != nil { if err == nil {
return ListObjectsInfo{}, toObjectErr(err, bucket) fileInfo.Mode = 0
}
fileInfo.Name = strings.TrimSuffix(fileInfo.Name, slashSeparator)
fileInfo.Size = info.GetSize() fileInfo.Size = info.GetSize()
} else if err != errFileNotFound {
return ListObjectsInfo{}, toObjectErr(err, bucket, fileInfo.Name)
}
allFileInfos = append(allFileInfos, fileInfo) allFileInfos = append(allFileInfos, fileInfo)
maxKeys-- maxKeys--
continue continue
} } else if strings.HasSuffix(fileInfo.Name, multipartMetaFile) {
}
if strings.HasSuffix(fileInfo.Name, multipartMetaFile) {
fileInfo.Name = path.Dir(fileInfo.Name) fileInfo.Name = path.Dir(fileInfo.Name)
var info MultipartObjectInfo var info MultipartObjectInfo
info, err = xl.getMultipartObjectInfo(bucket, fileInfo.Name) info, err = xl.getMultipartObjectInfo(bucket, fileInfo.Name)
if err != nil { if err != nil {
return ListObjectsInfo{}, toObjectErr(err, bucket) return ListObjectsInfo{}, toObjectErr(err, bucket, fileInfo.Name)
} }
fileInfo.Size = info.GetSize() fileInfo.Size = info.GetSize()
allFileInfos = append(allFileInfos, fileInfo) allFileInfos = append(allFileInfos, fileInfo)
maxKeys-- maxKeys--
continue continue
} } else if strings.HasSuffix(fileInfo.Name, multipartSuffix) {
if strings.HasSuffix(fileInfo.Name, multipartSuffix) {
continue continue
} }
allFileInfos = append(allFileInfos, fileInfo) allFileInfos = append(allFileInfos, fileInfo)