]> git.localhorst.tv Git - l2e.git/blobdiff - src/common/Hero.cpp
feed victory messages from upgrade
[l2e.git] / src / common / Hero.cpp
index ab73a6be70d3ee91fbc003d4918342ebba28638c..4e7b5b91068f08e8db5137fb8f97656afae79bd8 100644 (file)
@@ -1,10 +1,3 @@
-/*
- * Hero.cpp
- *
- *  Created on: Oct 7, 2012
- *      Author: holy
- */
-
 #include "Hero.h"
 
 #include "Item.h"
 #include "../loader/TypeDescription.h"
 #include "../map/Entity.h"
 
+#include <cstring>
+
 using graphics::Animation;
 using graphics::Sprite;
 using loader::FieldDescription;
 using loader::Interpreter;
 using loader::TypeDescription;
 using map::Entity;
+using std::memset;
+using std::vector;
+
 
 namespace common {
 
@@ -40,18 +38,11 @@ Hero::Hero()
 
 , useMask(0)
 
-, weapon(0)
-, armor(0)
-, shield(0)
-, helmet(0)
-, ring(0)
-, jewel(0)
-
 , battleSprite(0)
 , meleeAnimation(0)
 , attackAnimation(0)
 , spellAnimation(0) {
-
+       memset(equipment, 0, sizeof(equipment));
 }
 
 
@@ -79,6 +70,29 @@ int Hero::NextLevel() const {
        }
 }
 
+void Hero::AddExperience(int exp, vector<UpgradeInfo> &info) {
+       if (level > numLevels) {
+               // don't award any experience if at highest level
+               return;
+       }
+       int remain = exp;
+       while (remain >= NextLevel()) {
+               int added = NextLevel();
+               experience += added;
+               remain -= added;
+               ++level;
+
+               info.push_back(UpgradeInfo(UPGRADE_LVL, level));
+
+               // TODO: upgrade attributes and push info
+
+               if (level > numLevels) {
+                       return;
+               }
+       }
+       experience += remain;
+}
+
 
 bool Hero::CanEquip(const Item &item) const {
        return useMask & item.HeroMask();
@@ -107,7 +121,7 @@ void Hero::CreateTypeDescription() {
        td.AddField("stats", FieldDescription(((char *)&h.stats) - ((char *)&h), Stats::TYPE_ID));
 
        td.AddField("level", FieldDescription(((char *)&h.level) - ((char *)&h), Interpreter::NUMBER_ID));
-       td.AddField("ladder", FieldDescription(((char *)&h.levelLadder) - ((char *)&h), Interpreter::NUMBER_ID).SetReferenced().SetAggregate());
+       td.AddField("ladder", FieldDescription(((char *)&h.levelLadder) - ((char *)&h), Interpreter::NUMBER_ID).SetAggregate());
 
        td.AddField("useMask", FieldDescription(((char *)&h.useMask) - ((char *)&h), Interpreter::NUMBER_ID));