diff options
author | Aki <please@ignore.pl> | 2022-11-13 00:20:42 +0100 |
---|---|---|
committer | Aki <please@ignore.pl> | 2022-11-13 00:20:42 +0100 |
commit | 1b39b8aaf6be5be56530979044fb893a5b51b489 (patch) | |
tree | 6c9499db7a07be5dbbfa69d3641c6a489ff13f8f /battles/src/TeamManager.cpp | |
parent | c6d17ef545978bec555c8af8ef5eaef82c44e5f1 (diff) | |
download | kurator-1b39b8aaf6be5be56530979044fb893a5b51b489.zip kurator-1b39b8aaf6be5be56530979044fb893a5b51b489.tar.gz kurator-1b39b8aaf6be5be56530979044fb893a5b51b489.tar.bz2 |
Implemented dumb keep-at-range behaviour
Diffstat (limited to 'battles/src/TeamManager.cpp')
-rw-r--r-- | battles/src/TeamManager.cpp | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/battles/src/TeamManager.cpp b/battles/src/TeamManager.cpp new file mode 100644 index 0000000..e4afeb3 --- /dev/null +++ b/battles/src/TeamManager.cpp @@ -0,0 +1,60 @@ +#include "TeamManager.h" + +#include <algorithm> +#include <random> +#include <utility> +#include <vector> + +#include <entt/entity/registry.hpp> + + +namespace kurator +{ +namespace battles +{ + + +TeamManager::TeamManager() : + teams {}, + generator {std::random_device{}()} +{ +} + + +void +TeamManager::add(int team, entt::entity entity) +{ + for (int i = teams.size(); i < team + 1; ++i) + teams.emplace_back(); + teams.at(team).push_back(std::move(entity)); +} + + +TeamManager::Team +TeamManager::get(int team) const +{ + return teams.at(team); +} + + +entt::entity +TeamManager::random(int team) +{ + auto& members = teams.at(team); + std::uniform_int_distribution<Team::size_type> uniform{0, members.size() - 1}; + return members.at(uniform(generator)); +} + + +void +TeamManager::clear(entt::registry& registry) +{ + for (auto& members : teams) { + auto is_valid = [®istry](entt::entity entity){ return !registry.valid(entity); }; + members.erase(std::remove_if(members.begin(), members.end(), is_valid), members.end()); + } +} + + +} // namespace battles +} // namespace kurator |