Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCampbell Barton <ideasman42@gmail.com>2013-09-10 07:18:43 +0400
committerCampbell Barton <ideasman42@gmail.com>2013-09-10 07:18:43 +0400
commitc7f0344aaeedfbcfc683d352fe13435d4f7294f2 (patch)
tree3565329416822b78c2188e990e4de6d0fbb8af89 /source/blender/nodes/texture/nodes/node_texture_common.c
parent48c0c6ac02857c9f402871dc27ad6d1ecfead3b4 (diff)
fix/workaround [#36694] Texture node groups tend to crash Blender a lot.
Diffstat (limited to 'source/blender/nodes/texture/nodes/node_texture_common.c')
-rw-r--r--source/blender/nodes/texture/nodes/node_texture_common.c18
1 files changed, 12 insertions, 6 deletions
diff --git a/source/blender/nodes/texture/nodes/node_texture_common.c b/source/blender/nodes/texture/nodes/node_texture_common.c
index 6ab8d27f6e6..fec6abbf062 100644
--- a/source/blender/nodes/texture/nodes/node_texture_common.c
+++ b/source/blender/nodes/texture/nodes/node_texture_common.c
@@ -93,9 +93,12 @@ static void group_copy_inputs(bNode *gnode, bNodeStack **in, bNodeStack *gstack)
for (node = ngroup->nodes.first; node; node = node->next) {
if (node->type == NODE_GROUP_INPUT) {
for (sock = node->outputs.first, a = 0; sock; sock = sock->next, ++a) {
- ns = node_get_socket_stack(gstack, sock);
- if (ns)
- copy_stack(ns, in[a]);
+ if (in[a]) { /* shouldn't need to check this [#36694] */
+ ns = node_get_socket_stack(gstack, sock);
+ if (ns) {
+ copy_stack(ns, in[a]);
+ }
+ }
}
}
}
@@ -114,9 +117,12 @@ static void group_copy_outputs(bNode *gnode, bNodeStack **out, bNodeStack *gstac
for (node = ngroup->nodes.first; node; node = node->next) {
if (node->type == NODE_GROUP_OUTPUT && (node->flag & NODE_DO_OUTPUT)) {
for (sock = node->inputs.first, a = 0; sock; sock = sock->next, ++a) {
- ns = node_get_socket_stack(gstack, sock);
- if (ns)
- copy_stack(out[a], ns);
+ if (out[a]) { /* shouldn't need to check this [#36694] */
+ ns = node_get_socket_stack(gstack, sock);
+ if (ns) {
+ copy_stack(out[a], ns);
+ }
+ }
}
break; /* only one active output node */
}