[Bf-blender-cvs] [d9e0a94] master: Fix T37939: Crash on exit (reading from freed node trees)
Campbell Barton
noreply at git.blender.org
Wed Dec 25 22:58:20 CET 2013
Commit: d9e0a9467503dc6cd004c67a118d315f2238f3b0
Author: Campbell Barton
Date: Thu Dec 26 08:57:44 2013 +1100
https://developer.blender.org/rBd9e0a9467503dc6cd004c67a118d315f2238f3b0
Fix T37939: Crash on exit (reading from freed node trees)
===================================================================
M source/blender/blenkernel/intern/library.c
M source/blender/blenkernel/intern/node.c
===================================================================
diff --git a/source/blender/blenkernel/intern/library.c b/source/blender/blenkernel/intern/library.c
index 95f1cce..910ab0f 100644
--- a/source/blender/blenkernel/intern/library.c
+++ b/source/blender/blenkernel/intern/library.c
@@ -950,7 +950,7 @@ void BKE_libblock_free_ex(ListBase *lb, void *idv, bool do_id_user)
BKE_action_free((bAction *)id);
break;
case ID_NT:
- ntreeFreeTree((bNodeTree *)id);
+ ntreeFreeTree_ex((bNodeTree *)id, do_id_user);
break;
case ID_BR:
BKE_brush_free((Brush *)id);
diff --git a/source/blender/blenkernel/intern/node.c b/source/blender/blenkernel/intern/node.c
index d0ce563..977aa01 100644
--- a/source/blender/blenkernel/intern/node.c
+++ b/source/blender/blenkernel/intern/node.c
@@ -1714,8 +1714,11 @@ void ntreeFreeTree_ex(bNodeTree *ntree, const short do_id_user)
}
}
- /* XXX not nice, but needed to free localized node groups properly */
- free_localized_node_groups(ntree);
+ /* 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);
+ }
/* unregister associated RNA types */
ntreeInterfaceTypeFree(ntree);
More information about the Bf-blender-cvs
mailing list