2023-07-21 09:50:06 +00:00
|
|
|
/**
|
|
|
|
* bt_random_selector.cpp
|
|
|
|
* =============================================================================
|
2025-01-21 01:18:59 +00:00
|
|
|
* Copyright (c) 2023-present Serhii Snitsaruk and the LimboAI contributors.
|
2023-07-21 09:50:06 +00:00
|
|
|
*
|
|
|
|
* 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_selector.h"
|
|
|
|
|
|
|
|
void BTRandomSelector::_enter() {
|
|
|
|
last_running_idx = 0;
|
2022-12-17 10:47:10 +00:00
|
|
|
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++) {
|
2024-01-06 23:47:46 +00:00
|
|
|
indicies[i] = i;
|
2022-08-29 09:41:42 +00:00
|
|
|
}
|
|
|
|
}
|
2022-12-17 10:47:10 +00:00
|
|
|
indicies.shuffle();
|
2022-08-29 09:41:42 +00:00
|
|
|
}
|
|
|
|
|
2023-09-19 11:43:26 +00:00
|
|
|
BT::Status BTRandomSelector::_tick(double p_delta) {
|
|
|
|
Status status = FAILURE;
|
2022-09-05 13:08:35 +00:00
|
|
|
for (int i = last_running_idx; i < get_child_count(); i++) {
|
2022-12-17 10:47:10 +00:00
|
|
|
status = get_child(indicies[i])->execute(p_delta);
|
2022-08-29 09:41:42 +00:00
|
|
|
if (status != FAILURE) {
|
|
|
|
last_running_idx = i;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return status;
|
2024-01-13 16:10:42 +00:00
|
|
|
}
|