X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fcommon%2FIkari.cpp;h=8ed8698af9112a3e0c0d1ae37c60e4cb14091fcb;hb=616330670a0c3d9d4554c145e997129747d05979;hp=6f7da0cd6ce77460771395783b18b31b9b966053;hpb=41983a2cd8dbbfe6adc02cdfccbf5c2887306e51;p=l2e.git diff --git a/src/common/Ikari.cpp b/src/common/Ikari.cpp index 6f7da0c..8ed8698 100644 --- a/src/common/Ikari.cpp +++ b/src/common/Ikari.cpp @@ -7,6 +7,11 @@ #include "Ikari.h" +#include "../loader/TypeDescription.h" + +using loader::FieldDescription; +using loader::TypeDescription; + namespace common { Ikari::Ikari() @@ -16,4 +21,27 @@ Ikari::Ikari() } + +void Ikari::CreateTypeDescription() { + Ikari i; + + int boolId(TypeDescription::GetTypeId("Boolean")); + int numberId(TypeDescription::GetTypeId("Number")); // FIXME: need small number type + int stringId(TypeDescription::GetTypeId("String")); + int targetsId(TypeDescription::GetTypeId("TargetingMode")); + + TypeDescription &td(TypeDescription::CreateOrGet("Ikari")); + td.SetConstructor(&Construct); + td.SetSize(sizeof(Ikari)); + + td.AddField("name", FieldDescription(((char *)&i.name) - ((char *)&i), stringId, true)); + td.AddField("cost", FieldDescription(((char *)&i.cost) - ((char *)&i), numberId, false)); + td.AddField("targets", FieldDescription(((char *)&i.targetingMode) - ((char *)&i), targetsId, false)); + td.AddField("type", FieldDescription(((char *)&i.isPhysical) - ((char *)&i), boolId, false)); +} + +void Ikari::Construct(void *data) { + new (data) Ikari; +} + }