Overhaul memory model to new Arbutils memory.
Some checks failed
continuous-integration/drone/push Build is failing
Some checks failed
continuous-integration/drone/push Build is failing
Signed-off-by: Deukhoofd <Deukhoofd@gmail.com>
This commit is contained in:
@@ -15,9 +15,9 @@ namespace CreatureLib::Battling {
|
||||
return 1;
|
||||
}
|
||||
|
||||
static ArbUt::List<ArbUt::BorrowedPtr<Creature>> ResolveTargets(const CreatureIndex& index,
|
||||
CreatureLib::Library::AttackTarget target,
|
||||
const ArbUt::BorrowedPtr<Battle>& battle) {
|
||||
static ArbUt::List<ArbUt::OptionalBorrowedPtr<Creature>>
|
||||
ResolveTargets(const CreatureIndex& index, CreatureLib::Library::AttackTarget target,
|
||||
const ArbUt::BorrowedPtr<Battle>& battle) {
|
||||
switch (target) {
|
||||
case CreatureLib::Library::AttackTarget::Adjacent: {
|
||||
return {battle->GetCreature(index)};
|
||||
@@ -32,14 +32,15 @@ namespace CreatureLib::Battling {
|
||||
return {battle->GetCreature(index)};
|
||||
};
|
||||
case CreatureLib::Library::AttackTarget::All: {
|
||||
ArbUt::BorrowedPtr<Creature> arr[battle->GetCreaturesPerSide() * battle->GetSides().Count()];
|
||||
ArbUt::OptionalBorrowedPtr<Creature>
|
||||
arr[battle->GetCreaturesPerSide() * battle->GetSides().Count()];
|
||||
size_t i = 0;
|
||||
for (auto side : battle->GetSides()) {
|
||||
for (auto mon : side->GetCreatures()) {
|
||||
arr[i++] = mon;
|
||||
}
|
||||
}
|
||||
return ArbUt::List<ArbUt::BorrowedPtr<Creature>>(arr, arr + i);
|
||||
return ArbUt::List<ArbUt::OptionalBorrowedPtr<Creature>>(arr, arr + i);
|
||||
}
|
||||
case CreatureLib::Library::AttackTarget::AllAdjacent: {
|
||||
auto left = index.GetCreatureIndex() - 1;
|
||||
@@ -77,20 +78,20 @@ namespace CreatureLib::Battling {
|
||||
}
|
||||
}
|
||||
case CreatureLib::Library::AttackTarget::AllAlly: {
|
||||
ArbUt::BorrowedPtr<Creature> arr[battle->GetCreaturesPerSide()];
|
||||
ArbUt::OptionalBorrowedPtr<Creature> arr[battle->GetCreaturesPerSide()];
|
||||
size_t i = 0;
|
||||
for (auto mon : battle->GetSides()[index.GetSideIndex()]->GetCreatures()) {
|
||||
arr[i++] = mon;
|
||||
}
|
||||
return ArbUt::List<ArbUt::BorrowedPtr<Creature>>(arr, arr + i);
|
||||
return ArbUt::List<ArbUt::OptionalBorrowedPtr<Creature>>(arr, arr + i);
|
||||
};
|
||||
case CreatureLib::Library::AttackTarget::AllOpponent: {
|
||||
ArbUt::BorrowedPtr<Creature> arr[battle->GetCreaturesPerSide()];
|
||||
ArbUt::OptionalBorrowedPtr<Creature> arr[battle->GetCreaturesPerSide()];
|
||||
size_t i = 0;
|
||||
for (auto mon : battle->GetSides()[index.GetSideIndex()]->GetCreatures()) {
|
||||
arr[i++] = mon;
|
||||
}
|
||||
return ArbUt::List<ArbUt::BorrowedPtr<Creature>>(arr, arr + i);
|
||||
return ArbUt::List<ArbUt::OptionalBorrowedPtr<Creature>>(arr, arr + i);
|
||||
};
|
||||
case CreatureLib::Library::AttackTarget::Any: {
|
||||
return {battle->GetCreature(index)};
|
||||
|
||||
Reference in New Issue
Block a user