X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fcommon%2FHero.cpp;h=4e7b5b91068f08e8db5137fb8f97656afae79bd8;hb=8f4cb4e8ad954ba73fb78a030c969c933a7ed60c;hp=7150af0a35b8c0528058d5c845794875c4483c18;hpb=1338442a6db3a706d09622188aad1cdfe183a70b;p=l2e.git diff --git a/src/common/Hero.cpp b/src/common/Hero.cpp index 7150af0..4e7b5b9 100644 --- a/src/common/Hero.cpp +++ b/src/common/Hero.cpp @@ -1,10 +1,3 @@ -/* - * Hero.cpp - * - * Created on: Oct 7, 2012 - * Author: holy - */ - #include "Hero.h" #include "Item.h" @@ -24,6 +17,7 @@ using loader::Interpreter; using loader::TypeDescription; using map::Entity; using std::memset; +using std::vector; namespace common { @@ -76,6 +70,29 @@ int Hero::NextLevel() const { } } +void Hero::AddExperience(int exp, vector &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(); @@ -104,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));