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,9 +263,10 @@ void CSSNodeInsertChild(const CSSNodeRef node, const CSSNodeRef child, const uin
|
|||||||
}
|
}
|
||||||
|
|
||||||
void CSSNodeRemoveChild(const CSSNodeRef node, const CSSNodeRef child) {
|
void CSSNodeRemoveChild(const CSSNodeRef node, const CSSNodeRef child) {
|
||||||
CSSNodeListDelete(node->children, child);
|
if (CSSNodeListDelete(node->children, child) != NULL) {
|
||||||
child->parent = NULL;
|
child->parent = NULL;
|
||||||
_CSSNodeMarkDirty(node);
|
_CSSNodeMarkDirty(node);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CSSNodeRef CSSNodeGetChild(const CSSNodeRef node, const uint32_t index) {
|
CSSNodeRef CSSNodeGetChild(const CSSNodeRef node, const uint32_t index) {
|
||||||
|
@@ -69,3 +69,25 @@ TEST(CSSLayoutTest, dirty_propagation_only_if_prop_changed) {
|
|||||||
|
|
||||||
CSSNodeFreeRecursive(root);
|
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