Register Species Library for AngelScript.
continuous-integration/drone/push Build is passing
Details
continuous-integration/drone/push Build is passing
Details
This commit is contained in:
parent
dbc8aa2675
commit
c1d865d366
|
@ -4,7 +4,7 @@
|
||||||
#include "TypeRegistry/Library/RegisterGrowthRateTypes.hpp"
|
#include "TypeRegistry/Library/RegisterGrowthRateTypes.hpp"
|
||||||
#include "TypeRegistry/Library/RegisterItemTypes.hpp"
|
#include "TypeRegistry/Library/RegisterItemTypes.hpp"
|
||||||
#include "TypeRegistry/Library/RegisterMoveTypes.hpp"
|
#include "TypeRegistry/Library/RegisterMoveTypes.hpp"
|
||||||
#include "TypeRegistry/Library/RegisterPokemonTypes.hpp"
|
#include "TypeRegistry/Library/RegisterSpeciesTypes.hpp"
|
||||||
|
|
||||||
CreatureLib::Battling::ScriptResolver* PkmnLib::Battling::BattleLibrary::CreateScriptResolver() {
|
CreatureLib::Battling::ScriptResolver* PkmnLib::Battling::BattleLibrary::CreateScriptResolver() {
|
||||||
return new AngelScripResolver();
|
return new AngelScripResolver();
|
||||||
|
@ -29,7 +29,7 @@ void AngelScripResolver::Initialize(CreatureLib::Battling::BattleLibrary* librar
|
||||||
|
|
||||||
RegisterExceptionRoutines(_engine);
|
RegisterExceptionRoutines(_engine);
|
||||||
|
|
||||||
RegisterPokemonTypes::Register(_engine);
|
RegisterSpeciesTypes::Register(_engine);
|
||||||
RegisterItemTypes::Register(_engine);
|
RegisterItemTypes::Register(_engine);
|
||||||
RegisterMoveTypes::Register(_engine);
|
RegisterMoveTypes::Register(_engine);
|
||||||
RegisterGrowthRateTypes::Register(_engine);
|
RegisterGrowthRateTypes::Register(_engine);
|
||||||
|
|
|
@ -73,7 +73,7 @@ void RegisterMoveTypes::RegisterMoveType(asIScriptEngine* engine) {
|
||||||
void RegisterMoveTypes::RegisterMoveLibrary(asIScriptEngine* engine) {
|
void RegisterMoveTypes::RegisterMoveLibrary(asIScriptEngine* engine) {
|
||||||
[[maybe_unused]] int r = engine->RegisterObjectType("MoveLibrary", 0, asOBJ_REF | asOBJ_NOCOUNT);
|
[[maybe_unused]] int r = engine->RegisterObjectType("MoveLibrary", 0, asOBJ_REF | asOBJ_NOCOUNT);
|
||||||
assert(r >= 0);
|
assert(r >= 0);
|
||||||
r = engine->RegisterObjectMethod("MoveLibrary", "const MoveData@ GetMove(const string &in flag) const",
|
r = engine->RegisterObjectMethod("MoveLibrary", "const MoveData@ GetMove(const string &in name) const",
|
||||||
asMETHOD(PkmnLib::Library::MoveLibrary, GetMove), asCALL_THISCALL);
|
asMETHOD(PkmnLib::Library::MoveLibrary, GetMove), asCALL_THISCALL);
|
||||||
assert(r >= 0);
|
assert(r >= 0);
|
||||||
|
|
||||||
|
|
|
@ -1,16 +1,18 @@
|
||||||
#include "RegisterPokemonTypes.hpp"
|
#include "RegisterSpeciesTypes.hpp"
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
#include "../../../Library/Species/PokemonSpecies.hpp"
|
#include "../../../Library/Species/PokemonSpecies.hpp"
|
||||||
|
#include "../../../Library/Species/SpeciesLibrary.hpp"
|
||||||
#include "../../../Library/Statistic.hpp"
|
#include "../../../Library/Statistic.hpp"
|
||||||
|
|
||||||
void RegisterPokemonTypes::Register(asIScriptEngine* engine) {
|
void RegisterSpeciesTypes::Register(asIScriptEngine* engine) {
|
||||||
RegisterGenderEnum(engine);
|
RegisterGenderEnum(engine);
|
||||||
RegisterStatisticEnum(engine);
|
RegisterStatisticEnum(engine);
|
||||||
RegisterFormeType(engine);
|
RegisterFormeType(engine);
|
||||||
RegisterSpeciesType(engine);
|
RegisterSpeciesType(engine);
|
||||||
|
RegisterSpeciesLibrary(engine);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RegisterPokemonTypes::RegisterGenderEnum(asIScriptEngine* engine) {
|
void RegisterSpeciesTypes::RegisterGenderEnum(asIScriptEngine* engine) {
|
||||||
[[maybe_unused]] int r = engine->RegisterEnum("Gender");
|
[[maybe_unused]] int r = engine->RegisterEnum("Gender");
|
||||||
assert(r >= 0);
|
assert(r >= 0);
|
||||||
r = engine->RegisterEnumValue("Gender", "Male", (int)CreatureLib::Library::Gender::Male);
|
r = engine->RegisterEnumValue("Gender", "Male", (int)CreatureLib::Library::Gender::Male);
|
||||||
|
@ -21,7 +23,7 @@ void RegisterPokemonTypes::RegisterGenderEnum(asIScriptEngine* engine) {
|
||||||
assert(r >= 0);
|
assert(r >= 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RegisterPokemonTypes::RegisterStatisticEnum(asIScriptEngine* engine) {
|
void RegisterSpeciesTypes::RegisterStatisticEnum(asIScriptEngine* engine) {
|
||||||
[[maybe_unused]] int r = engine->RegisterEnum("Statistic");
|
[[maybe_unused]] int r = engine->RegisterEnum("Statistic");
|
||||||
assert(r >= 0);
|
assert(r >= 0);
|
||||||
r = engine->RegisterEnumValue("Statistic", "HP", PkmnLib::Library::Statistic::HealthPoints);
|
r = engine->RegisterEnumValue("Statistic", "HP", PkmnLib::Library::Statistic::HealthPoints);
|
||||||
|
@ -38,7 +40,7 @@ void RegisterPokemonTypes::RegisterStatisticEnum(asIScriptEngine* engine) {
|
||||||
assert(r >= 0);
|
assert(r >= 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RegisterPokemonTypes::RegisterSpeciesType(asIScriptEngine* engine) {
|
void RegisterSpeciesTypes::RegisterSpeciesType(asIScriptEngine* engine) {
|
||||||
[[maybe_unused]] int r = engine->RegisterObjectType("Species", 0, asOBJ_REF | asOBJ_NOCOUNT);
|
[[maybe_unused]] int r = engine->RegisterObjectType("Species", 0, asOBJ_REF | asOBJ_NOCOUNT);
|
||||||
assert(r >= 0);
|
assert(r >= 0);
|
||||||
r = engine->RegisterObjectMethod("Species", "const string& get_Name() const property",
|
r = engine->RegisterObjectMethod("Species", "const string& get_Name() const property",
|
||||||
|
@ -65,7 +67,7 @@ void RegisterPokemonTypes::RegisterSpeciesType(asIScriptEngine* engine) {
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
void RegisterPokemonTypes::RegisterFormeType(asIScriptEngine* engine) {
|
void RegisterSpeciesTypes::RegisterFormeType(asIScriptEngine* engine) {
|
||||||
[[maybe_unused]] int r = engine->RegisterObjectType("Forme", 0, asOBJ_REF | asOBJ_NOCOUNT);
|
[[maybe_unused]] int r = engine->RegisterObjectType("Forme", 0, asOBJ_REF | asOBJ_NOCOUNT);
|
||||||
assert(r >= 0);
|
assert(r >= 0);
|
||||||
r = engine->RegisterObjectMethod("Forme", "const string& get_Name() const property",
|
r = engine->RegisterObjectMethod("Forme", "const string& get_Name() const property",
|
||||||
|
@ -94,3 +96,10 @@ void RegisterPokemonTypes::RegisterFormeType(asIScriptEngine* engine) {
|
||||||
assert(r >= 0);
|
assert(r >= 0);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
void RegisterSpeciesTypes::RegisterSpeciesLibrary(asIScriptEngine* engine) {
|
||||||
|
[[maybe_unused]] int r = engine->RegisterObjectType("SpeciesLibrary", 0, asOBJ_REF | asOBJ_NOCOUNT);
|
||||||
|
assert(r >= 0);
|
||||||
|
r = engine->RegisterObjectMethod("SpeciesLibrary", "const Species@ GetSpecies(const string &in name) const",
|
||||||
|
asMETHOD(PkmnLib::Library::SpeciesLibrary, GetPkmnSpecies), asCALL_THISCALL);
|
||||||
|
assert(r >= 0);
|
||||||
|
}
|
|
@ -1,8 +1,8 @@
|
||||||
#ifndef PKMNLIB_REGISTERPOKEMONTYPES_HPP
|
#ifndef PKMNLIB_REGISTERSPECIESTYPES_HPP
|
||||||
#define PKMNLIB_REGISTERPOKEMONTYPES_HPP
|
#define PKMNLIB_REGISTERSPECIESTYPES_HPP
|
||||||
#include <angelscript.h>
|
#include <angelscript.h>
|
||||||
|
|
||||||
class RegisterPokemonTypes {
|
class RegisterSpeciesTypes {
|
||||||
public:
|
public:
|
||||||
static void Register(asIScriptEngine* engine);
|
static void Register(asIScriptEngine* engine);
|
||||||
|
|
||||||
|
@ -11,6 +11,7 @@ private:
|
||||||
static void RegisterStatisticEnum(asIScriptEngine* engine);
|
static void RegisterStatisticEnum(asIScriptEngine* engine);
|
||||||
static void RegisterSpeciesType(asIScriptEngine* engine);
|
static void RegisterSpeciesType(asIScriptEngine* engine);
|
||||||
static void RegisterFormeType(asIScriptEngine* engine);
|
static void RegisterFormeType(asIScriptEngine* engine);
|
||||||
|
static void RegisterSpeciesLibrary(asIScriptEngine* engine);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // PKMNLIB_REGISTERPOKEMONTYPES_HPP
|
#endif // PKMNLIB_REGISTERSPECIESTYPES_HPP
|
Loading…
Reference in New Issue