Put the check for slots filled behind the check whether all choices are set.

This because this check can be more expensive, and should run as little times
as possible. In this case it should only run when all choices are set,
which should be in most cases once a turn.
This commit is contained in:
2019-12-07 12:49:18 +01:00
parent 57f16bc420
commit 8897f2282f

View File

@@ -26,13 +26,16 @@ bool Battle::TrySetChoice(BaseTurnChoice* choice) {
void Battle::CheckChoicesSetAndRun() { void Battle::CheckChoicesSetAndRun() {
for (auto side : _sides) { for (auto side : _sides) {
if (!side->AllPossibleSlotsFilled()) {
return;
}
if (!side->AllChoicesSet()) { if (!side->AllChoicesSet()) {
return; return;
} }
} }
for (auto side : _sides) {
if (!side->AllPossibleSlotsFilled()) {
return;
}
}
auto choices = std::vector<BaseTurnChoice*>(_numberOfSides * _creaturesPerSide); auto choices = std::vector<BaseTurnChoice*>(_numberOfSides * _creaturesPerSide);
auto i = 0; auto i = 0;
for (auto side : _sides) { for (auto side : _sides) {