]> git.localhorst.tv Git - l2e.git/blobdiff - src/common/Ikari.cpp
converted pseudo-fields into real ones
[l2e.git] / src / common / Ikari.cpp
index fb3767e8a43be63a0a19321e95b3533a2186df38..e91f12fa943e948d12c2ade80f1722f1c25845c9 100644 (file)
@@ -7,12 +7,36 @@
 
 #include "Ikari.h"
 
+#include "../loader/TypeDescription.h"
+
+using loader::FieldDescription;
+using loader::TypeDescription;
+
 namespace common {
 
 Ikari::Ikari()
 : name("")
-, cost(0) {
+, cost(0)
+, isPhysical(false) {
+
+}
+
+
+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.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, true));
 }
 
 }