Browse Source

revert sort.Search

pull/2841/head
Konstantin Lebedev 3 years ago
parent
commit
993283bb1d
  1. 19
      weed/s3api/filer_multipart.go

19
weed/s3api/filer_multipart.go

@ -175,16 +175,21 @@ func findByPartNumber(fileName string, parts []CompletedPart) (etag string, foun
if formatErr != nil { if formatErr != nil {
return return
} }
foundParts := []int{}
for i, part := range parts {
if part.PartNumber == partNumber {
foundParts = append(foundParts, i)
x := sort.Search(len(parts), func(i int) bool {
return parts[i].PartNumber >= partNumber
})
if parts[x].PartNumber != partNumber {
return
} }
y := 0
for i, part := range parts[x:] {
if part.PartNumber == partNumber {
y = i
} else {
break
} }
if len(foundParts) == 0 {
return
} }
return parts[foundParts[len(foundParts)-1]].ETag, true
return parts[x+y].ETag, true
} }
func (s3a *S3ApiServer) abortMultipartUpload(input *s3.AbortMultipartUploadInput) (output *s3.AbortMultipartUploadOutput, code s3err.ErrorCode) { func (s3a *S3ApiServer) abortMultipartUpload(input *s3.AbortMultipartUploadInput) (output *s3.AbortMultipartUploadOutput, code s3err.ErrorCode) {

Loading…
Cancel
Save