X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fmap%2FEntity.h;h=13ecacac627eb021ee9f35ede96db8b739e6ea8f;hb=0ad5ca97b5df217329bc319d62564a9f46ba11d7;hp=3ddc9ccef49f5340680882be332ae216cbb1c259;hpb=3f9f41338d8100a719e161a3a1cdda9dd227e2b4;p=l2e.git diff --git a/src/map/Entity.h b/src/map/Entity.h index 3ddc9cc..13ecaca 100644 --- a/src/map/Entity.h +++ b/src/map/Entity.h @@ -8,6 +8,8 @@ #ifndef MAP_ENTITY_H_ #define MAP_ENTITY_H_ +#include "../battle/fwd.h" +#include "../battle/Monster.h" #include "../geometry/Vector.h" #include "../graphics/fwd.h" #include "../graphics/Animation.h" @@ -56,10 +58,14 @@ public: void SetFlags(int f) { flags = f; } bool Blocking() const { return !(flags & FLAG_NONBLOCKING); } - bool Hostile() const { - // NOTE: this is a stub for testing! - return Blocking(); - } + bool Hostile() const { return partyLayout && numMonsters > 0; } + + void SetPartyLayout(battle::PartyLayout *l) { partyLayout = l; } + battle::PartyLayout *PartyLayout() { return partyLayout; } + + void SetMonsters(battle::Monster *m, int num) { monsters = m; numMonsters = num; } + battle::Monster *MonstersBegin() { return monsters; } + battle::Monster *MonstersEnd() { return monsters + numMonsters; } Entity *Follower() { return follower; } const Entity *Follower() const { return follower; } @@ -82,6 +88,9 @@ private: private: Entity *follower; const graphics::Animation *animation; + battle::PartyLayout *partyLayout; + battle::Monster *monsters; + int numMonsters; graphics::AnimationRunner runner; geometry::Vector spriteOffset; geometry::Vector position;