diff options
author | 2013-07-25 23:09:37 -0700 | |
---|---|---|
committer | 2013-07-25 23:09:37 -0700 | |
commit | c559c8834773c4d6d78cb0cccc968d2a3477f67a (patch) | |
tree | aa5daeec68ac98f5cee85333ee3fa9baa3d6e2cd /src/objc/imap/MCOIMAPMessageRenderingOperation.mm | |
parent | b27f76a56eebe7e297e9f7c2f00bf3b0eb61d662 (diff) |
Fixed memory leak on cancellation in ObjC API
Diffstat (limited to 'src/objc/imap/MCOIMAPMessageRenderingOperation.mm')
-rw-r--r-- | src/objc/imap/MCOIMAPMessageRenderingOperation.mm | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/src/objc/imap/MCOIMAPMessageRenderingOperation.mm b/src/objc/imap/MCOIMAPMessageRenderingOperation.mm index 983b6cac..4fb49bdb 100644 --- a/src/objc/imap/MCOIMAPMessageRenderingOperation.mm +++ b/src/objc/imap/MCOIMAPMessageRenderingOperation.mm @@ -39,12 +39,21 @@ typedef void (^CompletionType)(NSString * htmlString, NSError * error); [super dealloc]; } -- (void)start:(void (^)(NSString * htmlString, NSError * error))completionBlock { +- (void) start:(void (^)(NSString * htmlString, NSError * error))completionBlock +{ _completionBlock = [completionBlock copy]; [self start]; } -- (void)operationCompleted { +- (void) cancel +{ + [_completionBlock release]; + _completionBlock = nil; + [super cancel]; +} + +- (void) operationCompleted +{ if (_completionBlock == NULL) return; |