Fix the race condition when user cancel the network loading will not trigger the completion block.
Now we do not relay on URLSession delegate timing, directly callback when cancelled.
This commit is contained in:
parent
7a17674f7e
commit
9a010de0e8
|
@ -233,8 +233,6 @@ typedef NSMutableDictionary<NSString *, id> SDCallbacksDictionary;
|
|||
if (self.isFinished) return;
|
||||
[super cancel];
|
||||
|
||||
if (self.dataTask) {
|
||||
[self.dataTask cancel];
|
||||
__block typeof(self) strongSelf = self;
|
||||
dispatch_async(dispatch_get_main_queue(), ^{
|
||||
[[NSNotificationCenter defaultCenter] postNotificationName:SDWebImageDownloadStopNotification object:strongSelf];
|
||||
|
@ -244,6 +242,13 @@ typedef NSMutableDictionary<NSString *, id> SDCallbacksDictionary;
|
|||
// maintain the isFinished and isExecuting flags.
|
||||
if (self.isExecuting) self.executing = NO;
|
||||
if (!self.isFinished) self.finished = YES;
|
||||
|
||||
if (self.dataTask) {
|
||||
[self.dataTask cancel];
|
||||
self.dataTask = nil;
|
||||
// Provide the same userInfo as URLSession if network is cancelled
|
||||
// Don't relay on `URLSession:task:didCompleteWithError:` delegate callback because it may delay
|
||||
[self callCompletionBlocksWithError:[NSError errorWithDomain:NSURLErrorDomain code:NSURLErrorCancelled userInfo:@{NSLocalizedDescriptionKey: @"cancelled", NSURLErrorFailingURLErrorKey: self.request.URL, NSURLErrorFailingURLStringErrorKey: self.request.URL.absoluteString}]];
|
||||
} else {
|
||||
// Operation cancelled by user during sending the request
|
||||
[self callCompletionBlocksWithError:[NSError errorWithDomain:SDWebImageErrorDomain code:SDWebImageErrorCancelled userInfo:@{NSLocalizedDescriptionKey : @"Operation cancelled by user during sending the request"}]];
|
||||
|
|
Loading…
Reference in New Issue