2022-08-28 21:36:21 +00:00
|
|
|
/* bt_dynamic_sequence.cpp */
|
|
|
|
|
|
|
|
#include "bt_dynamic_sequence.h"
|
|
|
|
|
|
|
|
void BTDynamicSequence::_enter() {
|
|
|
|
last_running_idx = 0;
|
|
|
|
}
|
|
|
|
|
2023-04-10 08:08:11 +00:00
|
|
|
int BTDynamicSequence::_tick(double p_delta) {
|
2022-08-28 21:36:21 +00:00
|
|
|
int status = SUCCESS;
|
|
|
|
int i;
|
|
|
|
for (i = 0; i < get_child_count(); i++) {
|
|
|
|
status = get_child(i)->execute(p_delta);
|
|
|
|
if (status != SUCCESS) {
|
|
|
|
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)->cancel();
|
|
|
|
}
|
|
|
|
last_running_idx = i;
|
|
|
|
return status;
|
|
|
|
}
|