X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fcommon%2FHero.cpp;h=beeab8305844b8a9b2cccb95a98a66d73c8153ee;hb=3d69f521b593457304b282e5f23e36ab165288b6;hp=cca9d43f812eba77b89c039fc10990889c97645c;hpb=dc275497c592669dda75645604a9b35d32f63e90;p=l2e.git diff --git a/src/common/Hero.cpp b/src/common/Hero.cpp index cca9d43..beeab83 100644 --- a/src/common/Hero.cpp +++ b/src/common/Hero.cpp @@ -2,6 +2,7 @@ #include "Item.h" #include "Spell.h" +#include "Upgrade.h" #include "../graphics/Animation.h" #include "../graphics/Sprite.h" #include "../loader/Interpreter.h" @@ -17,6 +18,7 @@ using loader::Interpreter; using loader::TypeDescription; using map::Entity; using std::memset; +using std::vector; namespace common { @@ -69,6 +71,35 @@ int Hero::NextLevel() const { } } +void Hero::AddExperience(int exp, vector &info) { + if (level > numLevels) { + // don't award any experience if at highest level + info.push_back(Upgrade( + name, Upgrade::LEVEL_NEXT, NextLevel())); + return; + } + int remain = exp; + while (remain >= NextLevel()) { + int added = NextLevel(); + experience += added; + remain -= added; + ++level; + + info.push_back(Upgrade(name, Upgrade::LEVEL_UP, level)); + + // TODO: upgrade attributes and push info + + if (level > numLevels) { + info.push_back(Upgrade( + name, Upgrade::LEVEL_NEXT, NextLevel())); + return; + } + } + experience += remain; + info.push_back(Upgrade( + name, Upgrade::LEVEL_NEXT, NextLevel())); +} + bool Hero::CanEquip(const Item &item) const { return useMask & item.HeroMask();