Use smart pointers for basic libraries.
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:
@@ -1,40 +1,17 @@
|
||||
#include "DataLibrary.hpp"
|
||||
|
||||
CreatureLib::Library::DataLibrary::DataLibrary(LibrarySettings* settings, CreatureLib::Library::SpeciesLibrary* species,
|
||||
CreatureLib::Library::AttackLibrary* attacks,
|
||||
CreatureLib::Library::ItemLibrary* items,
|
||||
CreatureLib::Library::GrowthRateLibrary* growthRates,
|
||||
TypeLibrary* typeLibrary)
|
||||
: _settings(settings), _species(species), _attacks(attacks), _items(items), _growthRates(growthRates),
|
||||
_typeLibrary(typeLibrary) {
|
||||
CreatureLib::Library::DataLibrary::DataLibrary(std::unique_ptr<const LibrarySettings> settings,
|
||||
std::unique_ptr<const SpeciesLibrary> species,
|
||||
std::unique_ptr<const AttackLibrary> attacks,
|
||||
std::unique_ptr<const ItemLibrary> items,
|
||||
std::unique_ptr<const GrowthRateLibrary> growthRates,
|
||||
std::unique_ptr<const TypeLibrary> typeLibrary)
|
||||
: _settings(std::move(settings)), _species(std::move(species)), _attacks(std::move(attacks)),
|
||||
_items(std::move(items)), _growthRates(std::move(growthRates)), _typeLibrary(std::move(typeLibrary)) {
|
||||
AssertNotNull(_settings)
|
||||
AssertNotNull(_species)
|
||||
AssertNotNull(_attacks)
|
||||
AssertNotNull(_items)
|
||||
AssertNotNull(_growthRates)
|
||||
AssertNotNull(_typeLibrary)
|
||||
}
|
||||
|
||||
const CreatureLib::Library::LibrarySettings* CreatureLib::Library::DataLibrary::GetSettings() const noexcept {
|
||||
return _settings;
|
||||
}
|
||||
|
||||
const CreatureLib::Library::SpeciesLibrary* CreatureLib::Library::DataLibrary::GetSpeciesLibrary() const noexcept {
|
||||
return _species;
|
||||
}
|
||||
|
||||
const CreatureLib::Library::AttackLibrary* CreatureLib::Library::DataLibrary::GetAttackLibrary() const noexcept {
|
||||
return _attacks;
|
||||
}
|
||||
|
||||
const CreatureLib::Library::ItemLibrary* CreatureLib::Library::DataLibrary::GetItemLibrary() const noexcept {
|
||||
return _items;
|
||||
}
|
||||
|
||||
const CreatureLib::Library::GrowthRateLibrary* CreatureLib::Library::DataLibrary::GetGrowthRates() const noexcept {
|
||||
return _growthRates;
|
||||
}
|
||||
|
||||
const CreatureLib::Library::TypeLibrary* CreatureLib::Library::DataLibrary::GetTypeLibrary() const noexcept {
|
||||
return _typeLibrary;
|
||||
}
|
||||
}
|
||||
@@ -1,6 +1,7 @@
|
||||
#ifndef CREATURELIB_DATALIBRARY_HPP
|
||||
#define CREATURELIB_DATALIBRARY_HPP
|
||||
|
||||
#include <memory>
|
||||
#include "AttackLibrary.hpp"
|
||||
#include "GrowthRates/GrowthRateLibrary.hpp"
|
||||
#include "ItemLibrary.hpp"
|
||||
@@ -14,32 +15,31 @@ namespace CreatureLib::Library {
|
||||
*/
|
||||
class DataLibrary {
|
||||
private:
|
||||
const LibrarySettings* _settings;
|
||||
const SpeciesLibrary* _species;
|
||||
const AttackLibrary* _attacks;
|
||||
const ItemLibrary* _items;
|
||||
const GrowthRateLibrary* _growthRates;
|
||||
const TypeLibrary* _typeLibrary;
|
||||
const std::unique_ptr<const LibrarySettings> _settings;
|
||||
const std::unique_ptr<const SpeciesLibrary> _species;
|
||||
const std::unique_ptr<const AttackLibrary> _attacks;
|
||||
const std::unique_ptr<const ItemLibrary> _items;
|
||||
const std::unique_ptr<const GrowthRateLibrary> _growthRates;
|
||||
const std::unique_ptr<const TypeLibrary> _typeLibrary;
|
||||
|
||||
public:
|
||||
DataLibrary(LibrarySettings* settings, CreatureLib::Library::SpeciesLibrary* species,
|
||||
CreatureLib::Library::AttackLibrary* attacks, CreatureLib::Library::ItemLibrary* items,
|
||||
CreatureLib::Library::GrowthRateLibrary* growthRates, TypeLibrary* typeLibrary);
|
||||
DataLibrary(std::unique_ptr<const LibrarySettings> settings, std::unique_ptr<const SpeciesLibrary> species,
|
||||
std::unique_ptr<const AttackLibrary> attacks, std::unique_ptr<const ItemLibrary> items,
|
||||
std::unique_ptr<const GrowthRateLibrary> growthRates,
|
||||
std::unique_ptr<const TypeLibrary> typeLibrary);
|
||||
|
||||
virtual ~DataLibrary() {
|
||||
delete _species;
|
||||
delete _attacks;
|
||||
delete _items;
|
||||
delete _growthRates;
|
||||
delete _typeLibrary;
|
||||
virtual ~DataLibrary() {}
|
||||
|
||||
[[nodiscard]] const std::unique_ptr<const LibrarySettings>& GetSettings() const noexcept { return _settings; }
|
||||
[[nodiscard]] const std::unique_ptr<const SpeciesLibrary>& GetSpeciesLibrary() const noexcept {
|
||||
return _species;
|
||||
}
|
||||
|
||||
[[nodiscard]] const LibrarySettings* GetSettings() const noexcept;
|
||||
[[nodiscard]] const SpeciesLibrary* GetSpeciesLibrary() const noexcept;
|
||||
[[nodiscard]] const AttackLibrary* GetAttackLibrary() const noexcept;
|
||||
[[nodiscard]] const ItemLibrary* GetItemLibrary() const noexcept;
|
||||
[[nodiscard]] const GrowthRateLibrary* GetGrowthRates() const noexcept;
|
||||
[[nodiscard]] const TypeLibrary* GetTypeLibrary() const noexcept;
|
||||
[[nodiscard]] const std::unique_ptr<const AttackLibrary>& GetAttackLibrary() const noexcept { return _attacks; }
|
||||
[[nodiscard]] const std::unique_ptr<const ItemLibrary>& GetItemLibrary() const noexcept { return _items; }
|
||||
[[nodiscard]] const std::unique_ptr<const GrowthRateLibrary>& GetGrowthRates() const noexcept {
|
||||
return _growthRates;
|
||||
}
|
||||
[[nodiscard]] const std::unique_ptr<const TypeLibrary>& GetTypeLibrary() const noexcept { return _typeLibrary; }
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user