add function to lib94 to remove all warriors; fix crash on removing last warrior in bench

This commit is contained in:
Benji Dial 2023-11-26 20:28:29 -05:00
parent 920bedec8c
commit 8723fe0781
3 changed files with 17 additions and 1 deletions

View file

@ -320,7 +320,17 @@ void bench_window::on_click_remove_warrior() {
break;
}
on_click_new_round();
if (warriors.size())
on_click_new_round();
else {
lib94::remove_all_warriors();
lib94::clear_address_sets();
core.mut.lock();
core.clear_all();
core.mut.unlock();
update_ui();
}
delete w;

View file

@ -108,6 +108,8 @@ namespace lib94 {
//with the current time, before the first time you call this.
bool init_round(const warrior *const *warriors, size_t count, const number_t *offsets, bool shuffle);
void remove_all_warriors();
//returns the number of warriors who have at least one process
size_t alive_warrior_count();

View file

@ -114,6 +114,10 @@ namespace lib94 {
return true;
}
void remove_all_warriors() {
alive_warriors.clear();
}
size_t alive_warrior_count() {
return alive_warriors.size();
}