limboai/bt/tasks/composites/bt_random_sequence.cpp

36 lines
980 B
C++
Raw Normal View History

/**
* bt_random_sequence.cpp
* =============================================================================
* Copyright (c) 2023-present Serhii Snitsaruk and the LimboAI contributors.
*
* Use of this source code is governed by an MIT-style
* license that can be found in the LICENSE file or at
* https://opensource.org/licenses/MIT.
* =============================================================================
*/
2022-08-29 09:41:42 +00:00
#include "bt_random_sequence.h"
void BTRandomSequence::_enter() {
last_running_idx = 0;
if (indicies.size() != get_child_count()) {
indicies.resize(get_child_count());
2022-08-29 09:41:42 +00:00
for (int i = 0; i < get_child_count(); i++) {
indicies[i] = i;
2022-08-29 09:41:42 +00:00
}
}
indicies.shuffle();
2022-08-29 09:41:42 +00:00
}
BT::Status BTRandomSequence::_tick(double p_delta) {
Status status = SUCCESS;
for (int i = last_running_idx; i < get_child_count(); i++) {
status = get_child(indicies[i])->execute(p_delta);
2022-08-29 09:41:42 +00:00
if (status != SUCCESS) {
last_running_idx = i;
break;
}
}
return status;
2024-01-13 16:10:42 +00:00
}