]> git.localhorst.tv Git - l2e.git/blobdiff - src/common/Spell.cpp
added forwarding headers
[l2e.git] / src / common / Spell.cpp
index f347774317cfae7e70050df334b2c3a369a9f87d..4fce398bdaf16e534c702736b1d12d101f0362f9 100644 (file)
@@ -7,11 +7,40 @@
 
 #include "Spell.h"
 
+#include "../loader/TypeDescription.h"
+
+using loader::FieldDescription;
+using loader::TypeDescription;
+
 namespace common {
 
 Spell::Spell()
-: name(""), value(0), cost(0), usability(0) {
+: name(""), value(0), cost(0), status(false), battle(false) {
+
+}
+
+
+void Spell::CreateTypeDescription() {
+       Spell s;
+
+       int boolId(TypeDescription::GetTypeId("Boolean"));
+       int numberId(TypeDescription::GetTypeId("Number"));
+       int stringId(TypeDescription::GetTypeId("String"));
+       int targetsId(TypeDescription::GetTypeId("TargetingMode"));
+
+       TypeDescription &td(TypeDescription::CreateOrGet("Spell"));
+       td.SetConstructor(&Construct);
+       td.SetSize(sizeof(Spell));
+
+       td.AddField("name", FieldDescription(((char *)&s.name) - ((char *)&s), stringId, true));
+       td.AddField("cost", FieldDescription(((char *)&s.cost) - ((char *)&s), numberId, false));
+       td.AddField("targets", FieldDescription(((char *)&s.targetingMode) - ((char *)&s), targetsId, false));
+       td.AddField("status", FieldDescription(((char *)&s.status) - ((char *)&s), boolId, false));
+       td.AddField("battle", FieldDescription(((char *)&s.battle) - ((char *)&s), boolId, false));
+}
 
+void Spell::Construct(void *data) {
+       new (data) Spell;
 }
 
 }