Make BaseLibraries use shared_ptr.
continuous-integration/drone/push Build is passing
Details
continuous-integration/drone/push Build is passing
Details
This commit is contained in:
parent
b17c0648ff
commit
d82792e27a
|
@ -11,7 +11,9 @@ export uint8_t CreatureLib_Creature_Construct(Creature*& out, const BattleLibrar
|
||||||
const char* nickname, bool secretTalent, uint8_t talent,
|
const char* nickname, bool secretTalent, uint8_t talent,
|
||||||
LearnedAttack* attacks[], size_t attacksNum, bool allowedExperienceGain) {
|
LearnedAttack* attacks[], size_t attacksNum, bool allowedExperienceGain) {
|
||||||
Try(auto attacksVec = List<LearnedAttack*>(attacks, attacks + attacksNum);
|
Try(auto attacksVec = List<LearnedAttack*>(attacks, attacks + attacksNum);
|
||||||
out = new Creature(library, species, variant, level, experience, uid, gender, coloring, heldItem, nickname,
|
out = new Creature(library, std::shared_ptr<const CreatureLib::Library::CreatureSpecies>(species), variant,
|
||||||
|
level, experience, uid, gender, coloring,
|
||||||
|
std::shared_ptr<const CreatureLib::Library::Item>(heldItem), nickname,
|
||||||
CreatureLib::Library::TalentIndex(secretTalent, talent), attacksVec, allowedExperienceGain);)
|
CreatureLib::Library::TalentIndex(secretTalent, talent), attacksVec, allowedExperienceGain);)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -19,8 +21,10 @@ export void CreatureLib_Creature_Destruct(const Creature* p) { delete p; }
|
||||||
|
|
||||||
#define SIMPLE_GET_FUNC(type, name, returnType) \
|
#define SIMPLE_GET_FUNC(type, name, returnType) \
|
||||||
export returnType CreatureLib_##type##_##name(const type* p) { return p->name(); }
|
export returnType CreatureLib_##type##_##name(const type* p) { return p->name(); }
|
||||||
|
#define SIMPLE_GET_FUNC_SMART_PTR(type, name, returnType) \
|
||||||
|
export returnType CreatureLib_##type##_##name(const type* p) { return p->name().operator->(); }
|
||||||
|
|
||||||
SIMPLE_GET_FUNC(Creature, GetSpecies, const CreatureLib::Library::CreatureSpecies*);
|
SIMPLE_GET_FUNC_SMART_PTR(Creature, GetSpecies, const CreatureLib::Library::CreatureSpecies*);
|
||||||
SIMPLE_GET_FUNC(Creature, GetVariant, const CreatureLib::Library::SpeciesVariant*);
|
SIMPLE_GET_FUNC(Creature, GetVariant, const CreatureLib::Library::SpeciesVariant*);
|
||||||
SIMPLE_GET_FUNC(Creature, GetLevel, uint8_t);
|
SIMPLE_GET_FUNC(Creature, GetLevel, uint8_t);
|
||||||
SIMPLE_GET_FUNC(Creature, GetExperience, uint32_t);
|
SIMPLE_GET_FUNC(Creature, GetExperience, uint32_t);
|
||||||
|
@ -31,13 +35,13 @@ export bool CreatureLib_Creature_HasHeldItem(const Creature* p, const char* name
|
||||||
return p->HasHeldItem(ConstString(name));
|
return p->HasHeldItem(ConstString(name));
|
||||||
}
|
}
|
||||||
export bool CreatureLib_Creature_HasHeldItemWithHash(const Creature* p, uint32_t hash) { return p->HasHeldItem(hash); }
|
export bool CreatureLib_Creature_HasHeldItemWithHash(const Creature* p, uint32_t hash) { return p->HasHeldItem(hash); }
|
||||||
SIMPLE_GET_FUNC(Creature, GetHeldItem, const CreatureLib::Library::Item*);
|
SIMPLE_GET_FUNC_SMART_PTR(Creature, GetHeldItem, const CreatureLib::Library::Item*);
|
||||||
export uint8_t CreatureLib_Creature_SetHeldItem(Creature* p, const char* name) {
|
export uint8_t CreatureLib_Creature_SetHeldItem(Creature* p, const char* name) {
|
||||||
Try(p->SetHeldItem(ConstString(name));)
|
Try(p->SetHeldItem(ConstString(name));)
|
||||||
}
|
}
|
||||||
export uint8_t CreatureLib_Creature_SetHeldItemWithHash(Creature* p, uint32_t hash) { Try(p->SetHeldItem(hash);) }
|
export uint8_t CreatureLib_Creature_SetHeldItemWithHash(Creature* p, uint32_t hash) { Try(p->SetHeldItem(hash);) }
|
||||||
export void CreatureLib_Creature_SetHeldItemFromItem(Creature* p, const CreatureLib::Library::Item* item) {
|
export void CreatureLib_Creature_SetHeldItemFromItem(Creature* p, const CreatureLib::Library::Item* item) {
|
||||||
return p->SetHeldItem(item);
|
return p->SetHeldItem(std::shared_ptr<const CreatureLib::Library::Item>(item));
|
||||||
}
|
}
|
||||||
SIMPLE_GET_FUNC(Creature, GetCurrentHealth, uint32_t);
|
SIMPLE_GET_FUNC(Creature, GetCurrentHealth, uint32_t);
|
||||||
SIMPLE_GET_FUNC(Creature, GetBattle, Battle*);
|
SIMPLE_GET_FUNC(Creature, GetBattle, Battle*);
|
||||||
|
@ -79,10 +83,10 @@ export bool CreatureLib_Creature_HasVolatileScript(Creature* p, const char* scri
|
||||||
}
|
}
|
||||||
export size_t CreatureLib_Creature_GetAttacksCount(Creature* p) { return p->GetAttacks().Count(); }
|
export size_t CreatureLib_Creature_GetAttacksCount(Creature* p) { return p->GetAttacks().Count(); }
|
||||||
export LearnedAttack* const* CreatureLib_Creature_GetAttacks(Creature* p) { return p->GetAttacks().RawData(); }
|
export LearnedAttack* const* CreatureLib_Creature_GetAttacks(Creature* p) { return p->GetAttacks().RawData(); }
|
||||||
SIMPLE_GET_FUNC(Creature, GetDisplaySpecies, const CreatureLib::Library::CreatureSpecies*);
|
SIMPLE_GET_FUNC_SMART_PTR(Creature, GetDisplaySpecies, const CreatureLib::Library::CreatureSpecies*);
|
||||||
SIMPLE_GET_FUNC(Creature, GetDisplayVariant, const CreatureLib::Library::SpeciesVariant*);
|
SIMPLE_GET_FUNC(Creature, GetDisplayVariant, const CreatureLib::Library::SpeciesVariant*);
|
||||||
export void CreatureLib_Creature_SetDisplaySpecies(Creature* p, const CreatureLib::Library::CreatureSpecies* species) {
|
export void CreatureLib_Creature_SetDisplaySpecies(Creature* p, const CreatureLib::Library::CreatureSpecies* species) {
|
||||||
return p->SetDisplaySpecies(species);
|
return p->SetDisplaySpecies(std::shared_ptr<const CreatureLib::Library::CreatureSpecies>(species));
|
||||||
}
|
}
|
||||||
export void CreatureLib_Creature_SetDisplayVariant(Creature* p, const CreatureLib::Library::SpeciesVariant* variant) {
|
export void CreatureLib_Creature_SetDisplayVariant(Creature* p, const CreatureLib::Library::SpeciesVariant* variant) {
|
||||||
return p->SetDisplayVariant(variant);
|
return p->SetDisplayVariant(variant);
|
||||||
|
@ -103,4 +107,5 @@ export int8_t CreatureLib_Creature_GetStatBoost(Creature* p, CreatureLib::Librar
|
||||||
return p->GetStatBoost(stat);
|
return p->GetStatBoost(stat);
|
||||||
}
|
}
|
||||||
|
|
||||||
#undef SIMPLE_GET_FUNC
|
#undef SIMPLE_GET_FUNC
|
||||||
|
#undef SIMPLE_GET_FUNC_SMART_PTR
|
|
@ -2,16 +2,19 @@
|
||||||
#include "../Core.hpp"
|
#include "../Core.hpp"
|
||||||
using namespace CreatureLib::Battling;
|
using namespace CreatureLib::Battling;
|
||||||
|
|
||||||
export uint8_t CreatureLib_LearnedAttack_Construct(LearnedAttack*& out, CreatureLib::Library::AttackData* attack,
|
export uint8_t CreatureLib_LearnedAttack_Construct(LearnedAttack*& out, const CreatureLib::Library::AttackData* attack,
|
||||||
uint8_t maxUses, AttackLearnMethod learnMethod) {
|
uint8_t maxUses, AttackLearnMethod learnMethod) {
|
||||||
Try(out = new LearnedAttack(attack, maxUses, learnMethod);)
|
Try(out = new LearnedAttack(std::shared_ptr<const CreatureLib::Library::AttackData>(attack), maxUses, learnMethod);)
|
||||||
}
|
}
|
||||||
export void CreatureLib_LearnedAttack_Destruct(LearnedAttack* p) { delete p; }
|
export void CreatureLib_LearnedAttack_Destruct(LearnedAttack* p) { delete p; }
|
||||||
|
|
||||||
#define SIMPLE_GET_FUNC(type, name, returnType) \
|
#define SIMPLE_GET_FUNC(type, name, returnType) \
|
||||||
export returnType CreatureLib_##type##_##name(const type* p) { return p->name(); }
|
export returnType CreatureLib_##type##_##name(const type* p) { return p->name(); }
|
||||||
|
|
||||||
SIMPLE_GET_FUNC(LearnedAttack, GetAttack, const CreatureLib::Library::AttackData*);
|
#define SIMPLE_GET_FUNC_SMART_PTR(type, name, returnType) \
|
||||||
|
export returnType CreatureLib_##type##_##name(const type* p) { return p->name().operator->(); }
|
||||||
|
|
||||||
|
SIMPLE_GET_FUNC_SMART_PTR(LearnedAttack, GetAttack, const CreatureLib::Library::AttackData*);
|
||||||
SIMPLE_GET_FUNC(LearnedAttack, GetMaxUses, uint8_t);
|
SIMPLE_GET_FUNC(LearnedAttack, GetMaxUses, uint8_t);
|
||||||
SIMPLE_GET_FUNC(LearnedAttack, GetRemainingUses, uint8_t);
|
SIMPLE_GET_FUNC(LearnedAttack, GetRemainingUses, uint8_t);
|
||||||
SIMPLE_GET_FUNC(LearnedAttack, GetLearnMethod, AttackLearnMethod);
|
SIMPLE_GET_FUNC(LearnedAttack, GetLearnMethod, AttackLearnMethod);
|
||||||
|
@ -20,3 +23,6 @@ export bool CreatureLib_LearnedAttack_TryUse(LearnedAttack* p, uint8_t uses) { r
|
||||||
export void CreatureLib_LearnedAttack_DecreaseUses(LearnedAttack* p, uint8_t uses) { p->DecreaseUses(uses); }
|
export void CreatureLib_LearnedAttack_DecreaseUses(LearnedAttack* p, uint8_t uses) { p->DecreaseUses(uses); }
|
||||||
export void CreatureLib_LearnedAttack_RestoreUses(LearnedAttack* p, uint8_t uses) { p->RestoreUses(uses); }
|
export void CreatureLib_LearnedAttack_RestoreUses(LearnedAttack* p, uint8_t uses) { p->RestoreUses(uses); }
|
||||||
export void CreatureLib_LearnedAttack_RestoreAllUses(LearnedAttack* p) { p->RestoreAllUses(); }
|
export void CreatureLib_LearnedAttack_RestoreAllUses(LearnedAttack* p) { p->RestoreAllUses(); }
|
||||||
|
|
||||||
|
#undef SIMPLE_GET_FUNC
|
||||||
|
#undef SIMPLE_GET_FUNC_SMART_PTR
|
||||||
|
|
|
@ -16,19 +16,25 @@
|
||||||
export uint8_t simpleName##_DeleteWithHash(fullname* p, uint32_t hashedKey) { Try(p->Delete(hashedKey);) } \
|
export uint8_t simpleName##_DeleteWithHash(fullname* p, uint32_t hashedKey) { Try(p->Delete(hashedKey);) } \
|
||||||
\
|
\
|
||||||
export bool simpleName##_TryGet(fullname* p, const char* name, const returnType*& out) { \
|
export bool simpleName##_TryGet(fullname* p, const char* name, const returnType*& out) { \
|
||||||
return p->TryGet(Arbutils::CaseInsensitiveConstString::GetHash(name), out); \
|
std::shared_ptr<const returnType> o; \
|
||||||
|
auto v = p->TryGet(Arbutils::CaseInsensitiveConstString::GetHash(name), o); \
|
||||||
|
out = o.operator->(); \
|
||||||
|
return v; \
|
||||||
} \
|
} \
|
||||||
\
|
\
|
||||||
export bool simpleName##_TryGetWithHash(fullname* p, uint32_t hashedKey, const returnType*& out) { \
|
export bool simpleName##_TryGetWithHash(fullname* p, uint32_t hashedKey, const returnType*& out) { \
|
||||||
return p->TryGet(hashedKey, out); \
|
std::shared_ptr<const returnType> o; \
|
||||||
|
auto v = p->TryGet(hashedKey, o); \
|
||||||
|
out = o.operator->(); \
|
||||||
|
return v; \
|
||||||
} \
|
} \
|
||||||
\
|
\
|
||||||
export uint8_t simpleName##_Get(fullname* p, const char* name, const returnType*& out) { \
|
export uint8_t simpleName##_Get(fullname* p, const char* name, const returnType*& out) { \
|
||||||
Try(out = p->Get(Arbutils::CaseInsensitiveConstString::GetHash(name));) \
|
Try(out = p->Get(Arbutils::CaseInsensitiveConstString::GetHash(name)).operator->();) \
|
||||||
} \
|
} \
|
||||||
\
|
\
|
||||||
export uint8_t simpleName##_GetWithHash(fullname* p, uint32_t hashedKey, const returnType*& out) { \
|
export uint8_t simpleName##_GetWithHash(fullname* p, uint32_t hashedKey, const returnType*& out) { \
|
||||||
Try(out = p->Get(hashedKey);) \
|
Try(out = p->Get(hashedKey).operator->();) \
|
||||||
} \
|
} \
|
||||||
\
|
\
|
||||||
export size_t simpleName##_GetCount(fullname* p) { return p->GetCount(); }
|
export size_t simpleName##_GetCount(fullname* p) { return p->GetCount(); }
|
||||||
|
|
|
@ -11,13 +11,14 @@ bool CreatureLib::Battling::MiscLibrary::IsCritical(CreatureLib::Battling::Execu
|
||||||
}
|
}
|
||||||
|
|
||||||
static CreatureLib::Battling::LearnedAttack* _replacementAttack = nullptr;
|
static CreatureLib::Battling::LearnedAttack* _replacementAttack = nullptr;
|
||||||
static CreatureLib::Library::AttackData* _replacementAttackData = nullptr;
|
static std::shared_ptr<const CreatureLib::Library::AttackData> _replacementAttackData = nullptr;
|
||||||
|
|
||||||
static CreatureLib::Library::AttackData* GetReplacementAttackData() {
|
static const std::shared_ptr<const CreatureLib::Library::AttackData>& GetReplacementAttackData() {
|
||||||
if (_replacementAttackData == nullptr) {
|
if (_replacementAttackData == nullptr) {
|
||||||
_replacementAttackData = new CreatureLib::Library::AttackData(
|
_replacementAttackData =
|
||||||
"replacement"_cnc, 0, CreatureLib::Library::AttackCategory::Physical, 30, 255, 255,
|
std::shared_ptr<const CreatureLib::Library::AttackData>(new CreatureLib::Library::AttackData(
|
||||||
CreatureLib::Library::AttackTarget::Any, 0, new CreatureLib::Library::SecondaryEffect(), {});
|
"replacement"_cnc, 0, CreatureLib::Library::AttackCategory::Physical, 30, 255, 255,
|
||||||
|
CreatureLib::Library::AttackTarget::Any, 0, new CreatureLib::Library::SecondaryEffect(), {}));
|
||||||
}
|
}
|
||||||
return _replacementAttackData;
|
return _replacementAttackData;
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,7 +32,7 @@ CreateCreature CreateCreature::WithAttack(const Arbutils::CaseInsensitiveConstSt
|
||||||
|
|
||||||
Creature* CreateCreature::Create() {
|
Creature* CreateCreature::Create() {
|
||||||
auto rand = Arbutils::Random();
|
auto rand = Arbutils::Random();
|
||||||
auto species = this->_library->GetSpeciesLibrary()->Get(this->_species);
|
auto& species = this->_library->GetSpeciesLibrary()->Get(this->_species);
|
||||||
auto variant = species->GetVariant(this->_variant);
|
auto variant = species->GetVariant(this->_variant);
|
||||||
Library::TalentIndex talent;
|
Library::TalentIndex talent;
|
||||||
if (this->_talent.Empty()) {
|
if (this->_talent.Empty()) {
|
||||||
|
@ -48,9 +48,9 @@ Creature* CreateCreature::Create() {
|
||||||
if (gender == static_cast<Library::Gender>(-1)) {
|
if (gender == static_cast<Library::Gender>(-1)) {
|
||||||
gender = species->GetRandomGender(rand);
|
gender = species->GetRandomGender(rand);
|
||||||
}
|
}
|
||||||
const Library::Item* heldItem = nullptr;
|
std::shared_ptr<const Library::Item> heldItem = nullptr;
|
||||||
if (!this->_heldItem.Empty()) {
|
if (!this->_heldItem.Empty()) {
|
||||||
if (!_library->GetItemLibrary()->TryGet(this->_heldItem, heldItem)) {
|
if (!_library->GetItemLibrary()->TryGet(this->_heldItem.GetHash(), heldItem)) {
|
||||||
throw CreatureException("Invalid held item.");
|
throw CreatureException("Invalid held item.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,7 +21,7 @@ namespace CreatureLib::Battling {
|
||||||
uint8_t _coloring = 0;
|
uint8_t _coloring = 0;
|
||||||
Arbutils::CaseInsensitiveConstString _heldItem = ""_cnc;
|
Arbutils::CaseInsensitiveConstString _heldItem = ""_cnc;
|
||||||
uint32_t _identifier = 0;
|
uint32_t _identifier = 0;
|
||||||
List<std::tuple<const Library::AttackData*, AttackLearnMethod>> _attacks;
|
List<std::tuple<std::shared_ptr<const Library::AttackData>, AttackLearnMethod>> _attacks;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CreateCreature(const BattleLibrary* library, const Arbutils::CaseInsensitiveConstString& species, uint8_t level)
|
CreateCreature(const BattleLibrary* library, const Arbutils::CaseInsensitiveConstString& species, uint8_t level)
|
||||||
|
|
|
@ -6,11 +6,13 @@
|
||||||
|
|
||||||
using namespace CreatureLib;
|
using namespace CreatureLib;
|
||||||
|
|
||||||
Battling::Creature::Creature(const BattleLibrary* library, const Library::CreatureSpecies* species,
|
Battling::Creature::Creature(const BattleLibrary* library,
|
||||||
|
const std::shared_ptr<const Library::CreatureSpecies>& species,
|
||||||
const Library::SpeciesVariant* variant, uint8_t level, uint32_t experience, uint32_t uid,
|
const Library::SpeciesVariant* variant, uint8_t level, uint32_t experience, uint32_t uid,
|
||||||
Library::Gender gender, uint8_t coloring, const Library::Item* heldItem,
|
Library::Gender gender, uint8_t coloring,
|
||||||
std::string nickname, const Library::TalentIndex& talent,
|
const std::shared_ptr<const Library::Item> heldItem, std::string nickname,
|
||||||
const List<LearnedAttack*>& attacks, bool allowedExperienceGain)
|
const Library::TalentIndex& talent, const List<LearnedAttack*>& attacks,
|
||||||
|
bool allowedExperienceGain)
|
||||||
: _library(library), _species(species), _variant(variant), _level(level), _experience(experience),
|
: _library(library), _species(species), _variant(variant), _level(level), _experience(experience),
|
||||||
_uniqueIdentifier(uid), _gender(gender), _coloring(coloring), _heldItem(heldItem), _nickname(std::move(nickname)),
|
_uniqueIdentifier(uid), _gender(gender), _coloring(coloring), _heldItem(heldItem), _nickname(std::move(nickname)),
|
||||||
_talentIndex(talent), _hasOverridenTalent(false), _attacks(attacks),
|
_talentIndex(talent), _hasOverridenTalent(false), _attacks(attacks),
|
||||||
|
@ -185,7 +187,7 @@ void Battling::Creature::AddExperience(uint32_t amount) {
|
||||||
_experience = exp;
|
_experience = exp;
|
||||||
_level = level;
|
_level = level;
|
||||||
}
|
}
|
||||||
const Library::CreatureSpecies* Battling::Creature::GetDisplaySpecies() const noexcept {
|
std::shared_ptr<const Library::CreatureSpecies> Battling::Creature::GetDisplaySpecies() const noexcept {
|
||||||
auto species = _displaySpecies;
|
auto species = _displaySpecies;
|
||||||
if (species == nullptr)
|
if (species == nullptr)
|
||||||
species = _species;
|
species = _species;
|
||||||
|
@ -198,14 +200,14 @@ const Library::SpeciesVariant* Battling::Creature::GetDisplayVariant() const noe
|
||||||
return variant;
|
return variant;
|
||||||
}
|
}
|
||||||
void Battling::Creature::SetHeldItem(const ConstString& itemName) {
|
void Battling::Creature::SetHeldItem(const ConstString& itemName) {
|
||||||
const Library::Item* item;
|
std::shared_ptr<const Library::Item> item;
|
||||||
if (!_library->GetItemLibrary()->TryGet(itemName, item)) {
|
if (!_library->GetItemLibrary()->TryGet(itemName.GetHash(), item)) {
|
||||||
throw CreatureException("Item not found.");
|
throw CreatureException("Item not found.");
|
||||||
}
|
}
|
||||||
_heldItem = item;
|
_heldItem = item;
|
||||||
}
|
}
|
||||||
void Battling::Creature::SetHeldItem(uint32_t itemNameHash) {
|
void Battling::Creature::SetHeldItem(uint32_t itemNameHash) {
|
||||||
const Library::Item* item;
|
std::shared_ptr<const Library::Item> item;
|
||||||
if (!_library->GetItemLibrary()->TryGet(itemNameHash, item)) {
|
if (!_library->GetItemLibrary()->TryGet(itemNameHash, item)) {
|
||||||
throw CreatureException("Item not found.");
|
throw CreatureException("Item not found.");
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,10 +23,10 @@ namespace CreatureLib::Battling {
|
||||||
protected:
|
protected:
|
||||||
const BattleLibrary* _library;
|
const BattleLibrary* _library;
|
||||||
|
|
||||||
const Library::CreatureSpecies* _species;
|
std::shared_ptr<const Library::CreatureSpecies> _species;
|
||||||
const Library::SpeciesVariant* _variant;
|
const Library::SpeciesVariant* _variant;
|
||||||
|
|
||||||
const Library::CreatureSpecies* _displaySpecies = nullptr;
|
std::shared_ptr<const Library::CreatureSpecies> _displaySpecies = nullptr;
|
||||||
const Library::SpeciesVariant* _displayVariant = nullptr;
|
const Library::SpeciesVariant* _displayVariant = nullptr;
|
||||||
|
|
||||||
uint8_t _level;
|
uint8_t _level;
|
||||||
|
@ -34,7 +34,7 @@ namespace CreatureLib::Battling {
|
||||||
uint32_t _uniqueIdentifier;
|
uint32_t _uniqueIdentifier;
|
||||||
Library::Gender _gender;
|
Library::Gender _gender;
|
||||||
uint8_t _coloring;
|
uint8_t _coloring;
|
||||||
const Library::Item* _heldItem;
|
std::shared_ptr<const Library::Item> _heldItem;
|
||||||
uint32_t _currentHealth;
|
uint32_t _currentHealth;
|
||||||
|
|
||||||
Library::ClampedStatisticSet<int8_t, -6, 6> _statBoost;
|
Library::ClampedStatisticSet<int8_t, -6, 6> _statBoost;
|
||||||
|
@ -63,10 +63,10 @@ namespace CreatureLib::Battling {
|
||||||
void OnFaint();
|
void OnFaint();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Creature(const BattleLibrary* library, const Library::CreatureSpecies* species,
|
Creature(const BattleLibrary* library, const std::shared_ptr<const Library::CreatureSpecies>& species,
|
||||||
const Library::SpeciesVariant* variant, uint8_t level, uint32_t experience, uint32_t uid,
|
const Library::SpeciesVariant* variant, uint8_t level, uint32_t experience, uint32_t uid,
|
||||||
Library::Gender gender, uint8_t coloring, const Library::Item* heldItem, std::string nickname,
|
Library::Gender gender, uint8_t coloring, const std::shared_ptr<const Library::Item> heldItem,
|
||||||
const Library::TalentIndex& talent, const List<LearnedAttack*>& attacks,
|
std::string nickname, const Library::TalentIndex& talent, const List<LearnedAttack*>& attacks,
|
||||||
bool allowedExperienceGain = true);
|
bool allowedExperienceGain = true);
|
||||||
|
|
||||||
virtual ~Creature() {
|
virtual ~Creature() {
|
||||||
|
@ -82,7 +82,7 @@ namespace CreatureLib::Battling {
|
||||||
_currentHealth = GetBoostedStat(Library::Statistic::Health);
|
_currentHealth = GetBoostedStat(Library::Statistic::Health);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline const Library::CreatureSpecies* GetSpecies() const noexcept { return _species; }
|
inline const std::shared_ptr<const Library::CreatureSpecies>& GetSpecies() const noexcept { return _species; }
|
||||||
inline const Library::SpeciesVariant* GetVariant() const noexcept { return _variant; }
|
inline const Library::SpeciesVariant* GetVariant() const noexcept { return _variant; }
|
||||||
inline uint8_t GetLevel() const noexcept { return _level; }
|
inline uint8_t GetLevel() const noexcept { return _level; }
|
||||||
inline uint32_t GetExperience() const noexcept { return _experience; }
|
inline uint32_t GetExperience() const noexcept { return _experience; }
|
||||||
|
@ -94,10 +94,10 @@ namespace CreatureLib::Battling {
|
||||||
inline bool HasHeldItem(uint32_t nameHash) const noexcept {
|
inline bool HasHeldItem(uint32_t nameHash) const noexcept {
|
||||||
return _heldItem != nullptr && _heldItem->GetName() == nameHash;
|
return _heldItem != nullptr && _heldItem->GetName() == nameHash;
|
||||||
}
|
}
|
||||||
inline const Library::Item* GetHeldItem() const noexcept { return _heldItem; }
|
inline const std::shared_ptr<const Library::Item>& GetHeldItem() const noexcept { return _heldItem; }
|
||||||
void SetHeldItem(const ConstString& itemName);
|
void SetHeldItem(const ConstString& itemName);
|
||||||
void SetHeldItem(uint32_t itemNameHash);
|
void SetHeldItem(uint32_t itemNameHash);
|
||||||
inline void SetHeldItem(const Library::Item* item) noexcept { _heldItem = item; };
|
inline void SetHeldItem(const std::shared_ptr<const Library::Item>& item) noexcept { _heldItem = item; };
|
||||||
|
|
||||||
inline uint32_t GetCurrentHealth() const noexcept { return _currentHealth; }
|
inline uint32_t GetCurrentHealth() const noexcept { return _currentHealth; }
|
||||||
|
|
||||||
|
@ -135,10 +135,12 @@ namespace CreatureLib::Battling {
|
||||||
|
|
||||||
const List<LearnedAttack*>& GetAttacks() noexcept { return _attacks; }
|
const List<LearnedAttack*>& GetAttacks() noexcept { return _attacks; }
|
||||||
|
|
||||||
const Library::CreatureSpecies* GetDisplaySpecies() const noexcept;
|
std::shared_ptr<const Library::CreatureSpecies> GetDisplaySpecies() const noexcept;
|
||||||
const Library::SpeciesVariant* GetDisplayVariant() const noexcept;
|
const Library::SpeciesVariant* GetDisplayVariant() const noexcept;
|
||||||
|
|
||||||
void SetDisplaySpecies(const Library::CreatureSpecies* species) noexcept { _displaySpecies = species; }
|
void SetDisplaySpecies(const std::shared_ptr<const Library::CreatureSpecies>& species) noexcept {
|
||||||
|
_displaySpecies = species;
|
||||||
|
}
|
||||||
void SetDisplayVariant(const Library::SpeciesVariant* variant) noexcept { _displayVariant = variant; };
|
void SetDisplayVariant(const Library::SpeciesVariant* variant) noexcept { _displayVariant = variant; };
|
||||||
|
|
||||||
inline bool AllowedExperienceGain() const noexcept { return _allowedExperienceGain; }
|
inline bool AllowedExperienceGain() const noexcept { return _allowedExperienceGain; }
|
||||||
|
|
|
@ -1,18 +1,20 @@
|
||||||
#include "LearnedAttack.hpp"
|
#include "LearnedAttack.hpp"
|
||||||
#include <Arbutils/Assert.hpp>
|
#include <Arbutils/Assert.hpp>
|
||||||
CreatureLib::Battling::LearnedAttack::LearnedAttack(const CreatureLib::Library::AttackData* attack, uint8_t maxUses,
|
CreatureLib::Battling::LearnedAttack::LearnedAttack(
|
||||||
AttackLearnMethod learnMethod)
|
const std::shared_ptr<const CreatureLib::Library::AttackData>& attack, uint8_t maxUses,
|
||||||
|
AttackLearnMethod learnMethod)
|
||||||
: _attack(attack), _maxUses(maxUses), _remainingUses(maxUses), _learnMethod(learnMethod) {
|
: _attack(attack), _maxUses(maxUses), _remainingUses(maxUses), _learnMethod(learnMethod) {
|
||||||
AssertNotNull(_attack)
|
AssertNotNull(_attack)
|
||||||
}
|
}
|
||||||
|
|
||||||
CreatureLib::Battling::LearnedAttack::LearnedAttack(const CreatureLib::Library::AttackData* attack,
|
CreatureLib::Battling::LearnedAttack::LearnedAttack(
|
||||||
AttackLearnMethod learnMethod)
|
const std::shared_ptr<const CreatureLib::Library::AttackData>& attack, AttackLearnMethod learnMethod)
|
||||||
: _attack(attack), _maxUses(attack->GetBaseUsages()), _remainingUses(_maxUses), _learnMethod(learnMethod) {
|
: _attack(attack), _maxUses(attack->GetBaseUsages()), _remainingUses(_maxUses), _learnMethod(learnMethod) {
|
||||||
AssertNotNull(_attack)
|
AssertNotNull(_attack)
|
||||||
}
|
}
|
||||||
|
|
||||||
const CreatureLib::Library::AttackData* CreatureLib::Battling::LearnedAttack::GetAttack() const noexcept {
|
const std::shared_ptr<const CreatureLib::Library::AttackData>&
|
||||||
|
CreatureLib::Battling::LearnedAttack::GetAttack() const noexcept {
|
||||||
return _attack;
|
return _attack;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,23 +1,26 @@
|
||||||
#ifndef CREATURELIB_LEARNEDATTACK_HPP
|
#ifndef CREATURELIB_LEARNEDATTACK_HPP
|
||||||
#define CREATURELIB_LEARNEDATTACK_HPP
|
#define CREATURELIB_LEARNEDATTACK_HPP
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
#include "../../Library/Attacks/AttackData.hpp"
|
#include "../../Library/Attacks/AttackData.hpp"
|
||||||
#include "AttackLearnMethod.hpp"
|
#include "AttackLearnMethod.hpp"
|
||||||
|
|
||||||
namespace CreatureLib::Battling {
|
namespace CreatureLib::Battling {
|
||||||
class LearnedAttack {
|
class LearnedAttack {
|
||||||
const Library::AttackData* _attack;
|
std::shared_ptr<const Library::AttackData> _attack;
|
||||||
uint8_t _maxUses;
|
uint8_t _maxUses;
|
||||||
uint8_t _remainingUses;
|
uint8_t _remainingUses;
|
||||||
AttackLearnMethod _learnMethod;
|
AttackLearnMethod _learnMethod;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
LearnedAttack(const Library::AttackData* attack, uint8_t maxUses, AttackLearnMethod learnMethod);
|
LearnedAttack(const std::shared_ptr<const CreatureLib::Library::AttackData>& attack, uint8_t maxUses,
|
||||||
LearnedAttack(const Library::AttackData* attack, AttackLearnMethod learnMethod);
|
AttackLearnMethod learnMethod);
|
||||||
|
LearnedAttack(const std::shared_ptr<const CreatureLib::Library::AttackData>& attack,
|
||||||
|
AttackLearnMethod learnMethod);
|
||||||
|
|
||||||
virtual ~LearnedAttack() = default;
|
virtual ~LearnedAttack() = default;
|
||||||
|
|
||||||
const Library::AttackData* GetAttack() const noexcept;
|
const std::shared_ptr<const Library::AttackData>& GetAttack() const noexcept;
|
||||||
uint8_t GetMaxUses() const noexcept;
|
uint8_t GetMaxUses() const noexcept;
|
||||||
uint8_t GetRemainingUses() const noexcept;
|
uint8_t GetRemainingUses() const noexcept;
|
||||||
AttackLearnMethod GetLearnMethod() const noexcept;
|
AttackLearnMethod GetLearnMethod() const noexcept;
|
||||||
|
|
|
@ -7,23 +7,19 @@
|
||||||
#include <Arbutils/ConstString.hpp>
|
#include <Arbutils/ConstString.hpp>
|
||||||
#include <Arbutils/Random.hpp>
|
#include <Arbutils/Random.hpp>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
#include <memory>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
namespace CreatureLib::Library {
|
namespace CreatureLib::Library {
|
||||||
template <class T> class BaseLibrary {
|
template <class T> class BaseLibrary {
|
||||||
Arbutils::Collections::Dictionary<uint32_t, const T*> _values;
|
Arbutils::Collections::Dictionary<uint32_t, std::shared_ptr<const T>> _values;
|
||||||
Arbutils::Collections::List<uint32_t> _listValues;
|
Arbutils::Collections::List<uint32_t> _listValues;
|
||||||
size_t _index;
|
size_t _index;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
BaseLibrary(size_t initialCapacity = 32) : _values(initialCapacity), _listValues(initialCapacity) {}
|
BaseLibrary(size_t initialCapacity = 32) : _values(initialCapacity), _listValues(initialCapacity) {}
|
||||||
|
|
||||||
virtual ~BaseLibrary() {
|
virtual ~BaseLibrary() { _values.Clear(); }
|
||||||
for (const auto& v : _values) {
|
|
||||||
delete v.second;
|
|
||||||
}
|
|
||||||
_values.Clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void Insert(const Arbutils::CaseInsensitiveConstString& key, const T* value) {
|
inline void Insert(const Arbutils::CaseInsensitiveConstString& key, const T* value) {
|
||||||
AssertNotNull(value)
|
AssertNotNull(value)
|
||||||
|
@ -32,7 +28,7 @@ namespace CreatureLib::Library {
|
||||||
}
|
}
|
||||||
inline void Insert(uint32_t hashedKey, const T* value) {
|
inline void Insert(uint32_t hashedKey, const T* value) {
|
||||||
AssertNotNull(value)
|
AssertNotNull(value)
|
||||||
_values.Insert(hashedKey, value);
|
_values.Insert(hashedKey, std::shared_ptr<const T>(value));
|
||||||
_listValues.Append(hashedKey);
|
_listValues.Append(hashedKey);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,31 +43,38 @@ namespace CreatureLib::Library {
|
||||||
_listValues.Remove(k);
|
_listValues.Remove(k);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool TryGet(const Arbutils::CaseInsensitiveConstString& name, const T*& out) const {
|
bool TryGet(const Arbutils::CaseInsensitiveConstString& name, const std::shared_ptr<const T>& out) const {
|
||||||
return TryGet(name.GetHash(), out);
|
return TryGet(name.GetHash(), out);
|
||||||
}
|
}
|
||||||
bool TryGet(uint32_t hashedKey, const T*& out) const { return _values.TryGet(hashedKey, out); }
|
bool TryGet(uint32_t hashedKey, std::shared_ptr<const T>& out) const { return _values.TryGet(hashedKey, out); }
|
||||||
|
|
||||||
[[nodiscard]] inline const T* Get(const Arbutils::CaseInsensitiveConstString& name) const {
|
[[nodiscard]] inline const std::shared_ptr<const T>&
|
||||||
|
Get(const Arbutils::CaseInsensitiveConstString& name) const {
|
||||||
return _values.Get(name.GetHash());
|
return _values.Get(name.GetHash());
|
||||||
}
|
}
|
||||||
[[nodiscard]] inline const T* Get(uint32_t hashedKey) const { return _values.Get(hashedKey); }
|
[[nodiscard]] inline const std::shared_ptr<const T>& Get(uint32_t hashedKey) const {
|
||||||
|
return _values.Get(hashedKey);
|
||||||
|
}
|
||||||
|
|
||||||
[[nodiscard]] inline const T* operator[](const Arbutils::CaseInsensitiveConstString& name) const {
|
[[nodiscard]] inline const std::shared_ptr<const T>&
|
||||||
|
operator[](const Arbutils::CaseInsensitiveConstString& name) const {
|
||||||
return Get(name);
|
return Get(name);
|
||||||
}
|
}
|
||||||
[[nodiscard]] inline const T* operator[](uint32_t hashedKey) const { return Get(hashedKey); }
|
[[nodiscard]] inline const std::shared_ptr<const T>& operator[](uint32_t hashedKey) const {
|
||||||
[[nodiscard]] inline const Arbutils::Collections::Dictionary<uint32_t, const T*>& GetIterator() const {
|
return Get(hashedKey);
|
||||||
|
}
|
||||||
|
[[nodiscard]] inline const Arbutils::Collections::Dictionary<uint32_t, const std::shared_ptr<const T>>&
|
||||||
|
GetIterator() const {
|
||||||
return _values;
|
return _values;
|
||||||
}
|
}
|
||||||
|
|
||||||
[[nodiscard]] size_t GetCount() const { return _values.Count(); }
|
[[nodiscard]] size_t GetCount() const { return _values.Count(); }
|
||||||
|
|
||||||
inline const T* GetRandomValue(Arbutils::Random rand = Arbutils::Random()) const {
|
inline const std::shared_ptr<const T>& GetRandomValue(Arbutils::Random rand = Arbutils::Random()) const {
|
||||||
auto i = rand.Get(_listValues.Count());
|
auto i = rand.Get(_listValues.Count());
|
||||||
return _values[_listValues[i]];
|
return _values[_listValues[i]];
|
||||||
}
|
}
|
||||||
inline const T* GetRandomValue(Arbutils::Random* rand) const {
|
inline const std::shared_ptr<const T>& GetRandomValue(Arbutils::Random* rand) const {
|
||||||
auto i = rand->Get(_listValues.Count());
|
auto i = rand->Get(_listValues.Count());
|
||||||
return _values[_listValues[i]];
|
return _values[_listValues[i]];
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue