Adds functionality for held items
All checks were successful
continuous-integration/drone/push Build is passing
All checks were successful
continuous-integration/drone/push Build is passing
This commit is contained in:
@@ -8,26 +8,32 @@ namespace CreatureLib::Library {
|
||||
int32_t _price;
|
||||
|
||||
ArbUt::OptionalUniquePtr<const SecondaryEffect> _effect = nullptr;
|
||||
ArbUt::OptionalUniquePtr<const SecondaryEffect> _battleTriggerEffect = nullptr;
|
||||
std::unordered_set<uint32_t> _flags;
|
||||
|
||||
public:
|
||||
inline impl(const ArbUt::StringView& name, ItemCategory category, BattleItemCategory battleCategory,
|
||||
int32_t price, const SecondaryEffect* effect, const std::unordered_set<uint32_t>& flags) noexcept
|
||||
int32_t price, const SecondaryEffect* effect, const SecondaryEffect* battleTriggerEffect,
|
||||
const std::unordered_set<uint32_t>& flags) noexcept
|
||||
: _name(name), _category(category), _battleCategory(battleCategory), _price(price), _effect(effect),
|
||||
_flags(flags) {}
|
||||
_battleTriggerEffect(battleTriggerEffect), _flags(flags) {}
|
||||
|
||||
inline const ArbUt::StringView& GetName() const noexcept { return _name; }
|
||||
inline ItemCategory GetCategory() const noexcept { return _category; }
|
||||
inline BattleItemCategory GetBattleCategory() const noexcept { return _battleCategory; }
|
||||
inline int32_t GetPrice() const noexcept { return _price; }
|
||||
inline const ArbUt::OptionalUniquePtr<const SecondaryEffect>& GetEffect() const noexcept { return _effect; }
|
||||
inline const ArbUt::OptionalUniquePtr<const SecondaryEffect>& GetBattleTriggerEffect() const noexcept {
|
||||
return _battleTriggerEffect;
|
||||
}
|
||||
|
||||
inline bool HasFlag(const ArbUt::BasicStringView& flag) const noexcept { return this->_flags.contains(flag); }
|
||||
inline bool HasFlag(uint32_t flag) const noexcept { return this->_flags.contains(flag); }
|
||||
};
|
||||
Item::Item(const ArbUt::StringView& name, ItemCategory category, BattleItemCategory battleCategory, int32_t price,
|
||||
const SecondaryEffect* effect, const std::unordered_set<uint32_t>& flags) noexcept
|
||||
: _impl(new impl(name, category, battleCategory, price, effect, flags)) {}
|
||||
const SecondaryEffect* effect, const SecondaryEffect* battleTriggerEffect,
|
||||
const std::unordered_set<uint32_t>& flags) noexcept
|
||||
: _impl(new impl(name, category, battleCategory, price, effect, battleTriggerEffect, flags)) {}
|
||||
|
||||
Item::~Item() = default;
|
||||
const ArbUt::StringView& Item::GetName() const noexcept { return _impl->GetName(); }
|
||||
@@ -37,6 +43,9 @@ namespace CreatureLib::Library {
|
||||
const ArbUt::OptionalUniquePtr<const SecondaryEffect>& Item::GetEffect() const noexcept {
|
||||
return _impl->GetEffect();
|
||||
}
|
||||
const ArbUt::OptionalUniquePtr<const SecondaryEffect>& Item::GetBattleTriggerEffect() const noexcept {
|
||||
return _impl->GetBattleTriggerEffect();
|
||||
}
|
||||
|
||||
bool Item::HasFlag(const ArbUt::BasicStringView& flag) const noexcept { return _impl->HasFlag(flag); }
|
||||
bool Item::HasFlag(uint32_t flag) const noexcept { return _impl->HasFlag(flag); }
|
||||
|
||||
@@ -16,7 +16,8 @@ namespace CreatureLib::Library {
|
||||
|
||||
public:
|
||||
Item(const ArbUt::StringView& name, ItemCategory category, BattleItemCategory battleCategory, int32_t price,
|
||||
const SecondaryEffect* effect, const std::unordered_set<uint32_t>& flags) noexcept;
|
||||
const SecondaryEffect* effect, const SecondaryEffect* battleTriggerEffect,
|
||||
const std::unordered_set<uint32_t>& flags) noexcept;
|
||||
NO_COPY_OR_MOVE(Item)
|
||||
|
||||
virtual ~Item();
|
||||
@@ -27,6 +28,7 @@ namespace CreatureLib::Library {
|
||||
int32_t GetPrice() const noexcept;
|
||||
|
||||
const ArbUt::OptionalUniquePtr<const SecondaryEffect>& GetEffect() const noexcept;
|
||||
const ArbUt::OptionalUniquePtr<const SecondaryEffect>& GetBattleTriggerEffect() const noexcept;
|
||||
bool HasFlag(const ArbUt::BasicStringView& flag) const noexcept;
|
||||
bool HasFlag(uint32_t flag) const noexcept;
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user