Only mark Nodes dirty if an actual node is removed.
Summary: Currently, when we try to remove a child from a node, that node is mark dirty //regardless of whether or not anything was actually removed//. This fixes it. Reviewed By: gkassabli Differential Revision: D4125453 fbshipit-source-id: 745cfc55269415fea106a80c72401eb3074f2d31
This commit is contained in:
committed by
Facebook Github Bot
parent
b938017ccf
commit
e00e30ca15
@@ -263,10 +263,11 @@ void CSSNodeInsertChild(const CSSNodeRef node, const CSSNodeRef child, const uin
|
||||
}
|
||||
|
||||
void CSSNodeRemoveChild(const CSSNodeRef node, const CSSNodeRef child) {
|
||||
CSSNodeListDelete(node->children, child);
|
||||
if (CSSNodeListDelete(node->children, child) != NULL) {
|
||||
child->parent = NULL;
|
||||
_CSSNodeMarkDirty(node);
|
||||
}
|
||||
}
|
||||
|
||||
CSSNodeRef CSSNodeGetChild(const CSSNodeRef node, const uint32_t index) {
|
||||
return CSSNodeListGet(node->children, index);
|
||||
|
@@ -69,3 +69,25 @@ TEST(CSSLayoutTest, dirty_propagation_only_if_prop_changed) {
|
||||
|
||||
CSSNodeFreeRecursive(root);
|
||||
}
|
||||
|
||||
TEST(CSSLayoutTest, dirty_node_only_if_children_are_actually_removed) {
|
||||
const CSSNodeRef root = CSSNodeNew();
|
||||
CSSNodeStyleSetAlignItems(root, CSSAlignFlexStart);
|
||||
CSSNodeStyleSetWidth(root, 50);
|
||||
CSSNodeStyleSetHeight(root, 50);
|
||||
|
||||
const CSSNodeRef child0 = CSSNodeNew();
|
||||
CSSNodeStyleSetWidth(child0, 50);
|
||||
CSSNodeStyleSetHeight(child0, 25);
|
||||
CSSNodeInsertChild(root, child0, 0);
|
||||
|
||||
CSSNodeCalculateLayout(root, CSSUndefined, CSSUndefined, CSSDirectionLTR);
|
||||
|
||||
CSSNodeRemoveChild(root, CSSNodeNew());
|
||||
EXPECT_FALSE(CSSNodeIsDirty(root));
|
||||
|
||||
CSSNodeRemoveChild(root, child0);
|
||||
EXPECT_TRUE(CSSNodeIsDirty(root));
|
||||
|
||||
CSSNodeFreeRecursive(root);
|
||||
}
|
||||
|
Reference in New Issue
Block a user