Fix removal of virtual nodes in FabricReconciler

Reviewed By: mdvacca

Differential Revision: D7338949

fbshipit-source-id: 31263c138689f9b3f59deb26851132df04b8a823
This commit is contained in:
Andrew Chen (Eng) 2018-03-21 14:21:37 -07:00 committed by Facebook Github Bot
parent cf036dbc7a
commit c0d27de37e
2 changed files with 19 additions and 11 deletions

View File

@ -89,12 +89,11 @@ public class FabricReconciler {
// If a View is not re-ordered, then the ReactTag is deleted (ReactShadowNode and native View
// are released from memory)
List<Integer> tagsToDelete = new LinkedList<>();
int[] indicesToRemove = new int[prevList.size() - firstRemovedOrAddedViewIndex];
int indicesToRemoveIndex = 0;
for (int j = firstRemovedOrAddedViewIndex; j < prevList.size(); j++) {
List<Integer> indicesToRemove = new LinkedList<>();
for (int j = prevList.size() - 1; j >= firstRemovedOrAddedViewIndex; j--) {
ReactShadowNode nodeToRemove = prevList.get(j);
if (nodeToRemove.isVirtual()) continue;
indicesToRemove[indicesToRemoveIndex++] = j;
indicesToRemove.add(0, j);
if (!addedTags.contains(nodeToRemove.getReactTag())) {
tagsToDelete.add(nodeToRemove.getReactTag());
// TODO: T26729293 since we are not cloning ReactShadowNode's we need to "manually" remove
@ -103,21 +102,21 @@ public class FabricReconciler {
}
}
int[] tagsToDeleteArray = ArrayUtils.copyListToArray(tagsToDelete);
ViewAtIndex[] viewsToAddArray = viewsToAdd.toArray(new ViewAtIndex[viewsToAdd.size()]);
// TODO (t27180994): Mutate views synchronously on main thread
if (indicesToRemove.length > 0 || viewsToAddArray.length > 0 || tagsToDeleteArray.length > 0) {
if (!(indicesToRemove.isEmpty() && viewsToAdd.isEmpty() && tagsToDelete.isEmpty())) {
int[] indicesToRemoveArray = ArrayUtils.copyListToArray(indicesToRemove);
ViewAtIndex[] viewsToAddArray = viewsToAdd.toArray(new ViewAtIndex[viewsToAdd.size()]);
int[] tagsToDeleteArray = ArrayUtils.copyListToArray(tagsToDelete);
if (DEBUG) {
Log.d(
TAG,
"manageChildren.enqueueManageChildren parent: " + parent.getReactTag() +
"\n\tIndices2Remove: " + Arrays.toString(indicesToRemove) +
"\n\tIndices2Remove: " + Arrays.toString(indicesToRemoveArray) +
"\n\tViews2Add: " + Arrays.toString(viewsToAddArray) +
"\n\tTags2Delete: " + Arrays.toString(tagsToDeleteArray));
}
uiViewOperationQueue.enqueueManageChildren(
parent.getReactTag(), indicesToRemove, viewsToAddArray, tagsToDeleteArray);
parent.getReactTag(), indicesToRemoveArray, viewsToAddArray, tagsToDeleteArray);
}
}

View File

@ -29,8 +29,17 @@ public class ViewAtIndex {
mIndex = index;
}
@Override
public boolean equals(Object obj) {
if (obj == null || obj.getClass() != getClass()) {
return false;
}
ViewAtIndex other = (ViewAtIndex) obj;
return mIndex == other.mIndex && mTag == other.mTag;
}
@Override
public String toString() {
return "[" + mIndex + ", " + mTag + "]";
return "[" + mTag + ", " + mIndex + "]";
}
}