limboai/bt/tasks/composites/bt_dynamic_selector.cpp

35 lines
1015 B
C++
Raw Normal View History

/**
* bt_dynamic_selector.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.
* =============================================================================
*/
#include "bt_dynamic_selector.h"
void BTDynamicSelector::_enter() {
last_running_idx = 0;
}
BT::Status BTDynamicSelector::_tick(double p_delta) {
Status status = SUCCESS;
int i;
for (i = 0; i < get_child_count(); i++) {
status = get_child(i)->execute(p_delta);
if (status != FAILURE) {
break;
}
}
// If the last node ticked is earlier in the tree than the previous runner,
// cancel previous runner.
if (last_running_idx > i && get_child(last_running_idx)->get_status() == RUNNING) {
get_child(last_running_idx)->abort();
}
last_running_idx = i;
return status;
2024-03-21 20:38:57 +00:00
}