39 lines
1.9 KiB
C++
39 lines
1.9 KiB
C++
#include "../../src/Library/Species/PokemonSpecies.hpp"
|
|
#include "../Core.hpp"
|
|
using namespace PkmnLib::Library;
|
|
|
|
export uint8_t PkmnLib_PokemonSpecies_Construct(const PokemonSpecies*& out, uint16_t id, const char* name,
|
|
const PokemonForme* defaultForme, float genderRatio,
|
|
const char* growthRate, uint8_t captureRate, uint8_t baseHappiness,
|
|
const char* const* eggGroupsRaw, size_t eggGroupsLength) {
|
|
|
|
Try(
|
|
ArbUt::List<ArbUt::StringView> eggGroups(eggGroupsLength);
|
|
for (size_t i = 0; i < eggGroupsLength; i++) { eggGroups.Append(ArbUt::StringView(eggGroupsRaw[i])); }
|
|
auto cName = ArbUt::StringView(name);
|
|
auto cGrowthRate = ArbUt::StringView(growthRate);
|
|
out = new PokemonSpecies(id, cName, defaultForme, genderRatio, cGrowthRate, captureRate, baseHappiness,
|
|
eggGroups);)
|
|
}
|
|
|
|
export void PkmnLib_PokemonSpecies_Destruct(const PokemonSpecies* p) { delete p; }
|
|
|
|
SIMPLE_GET_FUNC(PokemonSpecies, GetBaseHappiness, uint8_t);
|
|
export void PkmnLib_PokemonSpecies_AddEvolution(PokemonSpecies* p, EvolutionData* evo) { p->AddEvolution(evo); }
|
|
|
|
export size_t PkmnLib_PokemonSpecies_GetEvolutionCount(const PokemonSpecies* p) { return p->GetEvolutions().Count(); }
|
|
|
|
export uint8_t PkmnLib_PokemonSpecies_GetEvolution(const PokemonSpecies* p, size_t index, const EvolutionData*& out) {
|
|
Try(out = p->GetEvolutions().At(index).GetRaw());
|
|
}
|
|
|
|
export uint8_t PkmnLib_PokemonSpecies_GetEvolutions(const PokemonSpecies* p, const EvolutionData* const*& out) {
|
|
Try(out = p->GetEvolutions().RawData());
|
|
}
|
|
|
|
export size_t PkmnLib_PokemonSpecies_GetEggGroupCount(const PokemonSpecies* p) {
|
|
return p->GetEggGroups().Count();
|
|
}
|
|
export const char* PkmnLib_PokemonSpecies_GetEggGroup(const PokemonSpecies* p, size_t index){
|
|
return p->GetEggGroups()[index].c_str();
|
|
} |