0

Is the following creating a strong reference cycle? I have a feeling it is because I'm referencing self within callback.

- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info {
    [picker dismissViewControllerAnimated:YES completion:^{
        UIImage *image = [self cropImageWithInfo:info];
        if (currentScreen == CurrentScreenApartment) {
            [self.profileViewModel.apartmentPhotos addObject:[RuntimePhoto runtimePhotoWithImage:image]];
        }
        else {
            [self.profileViewModel.userPhotos addObject:[RuntimePhoto runtimePhotoWithImage:image]];
        }
        dispatch_async(dispatch_get_main_queue(), ^{
            [self reloadPhotosCell];
        });
    }];
}
AnonProgrammer
  • 239
  • 1
  • 11

1 Answers1

0

You can use a weak variable of self:

- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info {

    typeof(self) __weak weakSelf = self;

    [picker dismissViewControllerAnimated:YES completion:^{
        UIImage *image = [weakSelf cropImageWithInfo:info];
        if (currentScreen == CurrentScreenApartment) {
            [weakSelf.profileViewModel.apartmentPhotos addObject:[RuntimePhoto runtimePhotoWithImage:image]];
        }
        else {
            [weakSelf.profileViewModel.userPhotos addObject:[RuntimePhoto runtimePhotoWithImage:image]];
        }
        dispatch_async(dispatch_get_main_queue(), ^{
            [weakSelf reloadPhotosCell];
        });
    }];
}
koen
  • 5,383
  • 7
  • 50
  • 89