Move the line of infinity loop checking in AnimationStateMachine
(cherry picked from commit b8d555c74b
)
This commit is contained in:
parent
caf55eb072
commit
3c779d37bf
|
@ -905,15 +905,16 @@ bool AnimationNodeStateMachinePlayback::_transition_to_next_recursive(AnimationT
|
|||
transition_path.push_back(current);
|
||||
while (true) {
|
||||
next = _find_next(p_tree, p_state_machine);
|
||||
if (transition_path.has(next.node)) {
|
||||
WARN_PRINT_ONCE_ED("AnimationNodeStateMachinePlayback: " + base_path + "playback aborts the transition by detecting one or more looped transitions in the same frame to prevent to infinity loop. You may need to check the transition settings.");
|
||||
break; // Maybe infinity loop, do nothing more.
|
||||
}
|
||||
|
||||
if (!_can_transition_to_next(p_tree, p_state_machine, next, p_test_only)) {
|
||||
break; // Finish transition.
|
||||
}
|
||||
|
||||
if (transition_path.has(next.node)) {
|
||||
WARN_PRINT_ONCE_ED("AnimationNodeStateMachinePlayback: " + base_path + "playback aborts the transition by detecting one or more looped transitions in the same frame to prevent to infinity loop. You may need to check the transition settings.");
|
||||
break; // Maybe infinity loop, do nothing more.
|
||||
}
|
||||
|
||||
transition_path.push_back(next.node);
|
||||
is_state_changed = true;
|
||||
|
||||
|
|
Loading…
Reference in New Issue