diff options
author | Lukas Tönne <lukas.toenne@gmail.com> | 2013-12-28 17:51:53 +0400 |
---|---|---|
committer | Lukas Tönne <lukas.toenne@gmail.com> | 2013-12-28 17:54:53 +0400 |
commit | fa9b5d544993a619347e555ee708078913b7ec97 (patch) | |
tree | f18f5398a3337514c2888e9dba4cb924cded3934 /source | |
parent | 33b87dc1ad63284ee1191ca2bfc569b108719f71 (diff) |
Fix T37939, concern raised in rBd9e0a94: Avoid access to linked node
tree ID data when freeing bNodeTree data blocks, while also making sure
localized node group copies get freed properly.
Diffstat (limited to 'source')
-rw-r--r-- | source/blender/blenkernel/intern/node.c | 22 |
1 files changed, 12 insertions, 10 deletions
diff --git a/source/blender/blenkernel/intern/node.c b/source/blender/blenkernel/intern/node.c index 977aa016d2e..583739c00ec 100644 --- a/source/blender/blenkernel/intern/node.c +++ b/source/blender/blenkernel/intern/node.c @@ -1676,14 +1676,19 @@ static void free_localized_node_groups(bNodeTree *ntree) { bNode *node; + /* Only localized node trees store a copy for each node group tree. + * Each node group tree in a localized node tree can be freed, + * since it is a localized copy itself (no risk of accessing free'd + * data in main, see [#37939]). + */ + if (!(ntree->flag & NTREE_IS_LOCALIZED)) + return; + for (node = ntree->nodes.first; node; node = node->next) { if (node->type == NODE_GROUP && node->id) { bNodeTree *ngroup = (bNodeTree *)node->id; - if (ngroup->flag & NTREE_IS_LOCALIZED) { - /* ntree is a localized copy: free it */ - ntreeFreeTree_ex(ngroup, false); - MEM_freeN(ngroup); - } + ntreeFreeTree_ex(ngroup, false); + MEM_freeN(ngroup); } } } @@ -1714,11 +1719,8 @@ void ntreeFreeTree_ex(bNodeTree *ntree, const short do_id_user) } } - /* when freeing main, this would check other ntree's which may have been freed, see [#37939] */ - if (do_id_user) { - /* XXX not nice, but needed to free localized node groups properly */ - free_localized_node_groups(ntree); - } + /* XXX not nice, but needed to free localized node groups properly */ + free_localized_node_groups(ntree); /* unregister associated RNA types */ ntreeInterfaceTypeFree(ntree); |