Skip to content

Commit

Permalink
[ASCollectionElement] Add checks for nil element, prior to other PRs …
Browse files Browse the repository at this point in the history
…landing. (#421)
  • Loading branch information
appleguy authored and Adlai Holler committed Jul 5, 2017
1 parent 928bc9f commit 812210a
Showing 1 changed file with 29 additions and 6 deletions.
35 changes: 29 additions & 6 deletions Source/ASCollectionView.mm
Original file line number Diff line number Diff line change
Expand Up @@ -1074,7 +1074,13 @@ - (void)collectionView:(UICollectionView *)collectionView willDisplayCell:(UICol
auto cell = (_ASCollectionViewCell *)rawCell;

ASCollectionElement *element = cell.element;
[_visibleElements addObject:element];
if (element) {
[_visibleElements addObject:element];
} else {
ASDisplayNodeAssert(NO, @"Unexpected nil element for willDisplayCell: %@, %@, %@", rawCell, self, indexPath);
return;
}

ASCellNode *cellNode = element.node;
cellNode.scrollView = collectionView;

Expand Down Expand Up @@ -1126,8 +1132,13 @@ - (void)collectionView:(UICollectionView *)collectionView didEndDisplayingCell:(
auto cell = (_ASCollectionViewCell *)rawCell;

ASCollectionElement *element = cell.element;
[_visibleElements removeObject:element];
ASDisplayNodeAssertNotNil(element, @"Expected element associated with removed cell not to be nil.");
if (element) {
[_visibleElements removeObject:element];
} else {
ASDisplayNodeAssert(NO, @"Unexpected nil element for didEndDisplayingCell: %@, %@, %@", rawCell, self, indexPath);
return;
}

ASCellNode *cellNode = element.node;

if (_asyncDelegateFlags.collectionNodeDidEndDisplayingItem) {
Expand Down Expand Up @@ -1155,8 +1166,14 @@ - (void)collectionView:(UICollectionView *)collectionView willDisplaySupplementa
return;
}
auto view = (_ASCollectionReusableView *)rawView;

[_visibleElements addObject:view.element];

if (view.element) {
[_visibleElements addObject:view.element];
} else {
ASDisplayNodeAssert(NO, @"Unexpected nil element for willDisplaySupplementaryView: %@, %@, %@", rawView, self, indexPath);
return;
}

// This is a safeguard similar to the behavior for cells in -[ASCollectionView collectionView:willDisplayCell:forItemAtIndexPath:]
// It ensures _ASCollectionReusableView receives layoutAttributes and calls applyLayoutAttributes.
if (view.layoutAttributes == nil) {
Expand All @@ -1178,7 +1195,13 @@ - (void)collectionView:(UICollectionView *)collectionView didEndDisplayingSupple
}
auto view = (_ASCollectionReusableView *)rawView;

[_visibleElements removeObject:view.element];
if (view.element) {
[_visibleElements removeObject:view.element];
} else {
ASDisplayNodeAssert(NO, @"Unexpected nil element for didEndDisplayingSupplementaryView: %@, %@, %@", rawView, self, indexPath);
return;
}

if (_asyncDelegateFlags.collectionNodeDidEndDisplayingSupplementaryElement) {
GET_COLLECTIONNODE_OR_RETURN(collectionNode, (void)0);
ASCellNode *node = [self supplementaryNodeForElementKind:elementKind atIndexPath:indexPath];
Expand Down

0 comments on commit 812210a

Please sign in to comment.