[Bf-blender-cvs] [42ae2e4c6c2] temp-gpu-image-engine: Fix T93920: Wrong field inferencing state with unavailable socket

Hans Goudey noreply at git.blender.org
Wed Dec 15 14:37:50 CET 2021


Commit: 42ae2e4c6c288f83aadd45e5b319b7beb2001154
Author: Hans Goudey
Date:   Tue Dec 14 08:30:45 2021 -0600
Branches: temp-gpu-image-engine
https://developer.blender.org/rB42ae2e4c6c288f83aadd45e5b319b7beb2001154

Fix T93920: Wrong field inferencing state with unavailable socket

This commit ignores unavailable sockets in one more place, to fix the
case in T93920.

Differential Revision: https://developer.blender.org/D13562

===================================================================

M	source/blender/blenkernel/intern/node.cc

===================================================================

diff --git a/source/blender/blenkernel/intern/node.cc b/source/blender/blenkernel/intern/node.cc
index a78917ab0a3..a4de6730f8f 100644
--- a/source/blender/blenkernel/intern/node.cc
+++ b/source/blender/blenkernel/intern/node.cc
@@ -4748,7 +4748,9 @@ static void propagate_data_requirements_from_right_to_left(
       /* The output is required to be a single value when it is connected to any input that does
        * not support fields. */
       for (const InputSocketRef *target_socket : output_socket->directly_linked_sockets()) {
-        state.requires_single |= field_state_by_socket_id[target_socket->id()].requires_single;
+        if (target_socket->is_available()) {
+          state.requires_single |= field_state_by_socket_id[target_socket->id()].requires_single;
+        }
       }
 
       if (state.requires_single) {



More information about the Bf-blender-cvs mailing list