X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Floader%2FInterpreter.h;h=044a3c0848c0dd51bb0df8a3124fb48e1c0457f2;hb=22be995eefbf6e27f76606226422aaf3fbaa5b80;hp=7755a1beb01e767684f5db5561143b48661b4cca;hpb=09e8cfd4d7b2d187fed0870ebdb2e9e3f77fe4b9;p=l2e.git diff --git a/src/loader/Interpreter.h b/src/loader/Interpreter.h index 7755a1b..044a3c0 100644 --- a/src/loader/Interpreter.h +++ b/src/loader/Interpreter.h @@ -9,6 +9,7 @@ #define LOADER_INTERPRETER_H_ #include "../geometry/Vector.h" +#include "../graphics/Color.h" #include "../graphics/ComplexAnimation.h" #include @@ -21,6 +22,7 @@ namespace battle { class Hero; class Monster; class PartyLayout; + struct Resources; class Stats; } @@ -36,6 +38,7 @@ namespace graphics { class Font; class Frame; class Gauge; + struct MenuProperties; class SimpleAnimation; class Sprite; } @@ -67,13 +70,16 @@ public: public: graphics::Animation *GetAnimation(const std::string &name); + battle::Resources *GetBattleResources(const std::string &name); bool GetBoolean(const std::string &name) const; + const graphics::Color &GetColor(const std::string &name) const; graphics::Font *GetFont(const std::string &name); graphics::Frame *GetFrame(const std::string &name); graphics::Gauge *GetGauge(const std::string &name); battle::Hero *GetHero(const std::string &name); common::Ikari *GetIkari(const std::string &name); common::Item *GetItem(const std::string &name); + graphics::MenuProperties *GetMenuProperties(const std::string &name); battle::Monster *GetMonster(const std::string &name); int GetNumber(const std::string &name) const; battle::PartyLayout *GetPartyLayout(const std::string &name); @@ -85,7 +91,9 @@ public: geometry::Vector GetVector(const std::string &name) const; public: + const std::vector &BattleResources() const { return battleResources; } const std::vector &Booleans() const { return booleans; } + const std::vector &Colors() const { return colors; } const std::vector &ComplexAnimations() const { return complexAnimations; } const std::vector &Fonts() const { return fonts; } const std::vector &Frames() const { return frames; } @@ -94,6 +102,7 @@ public: const std::vector &Ikaris() const { return ikaris; } const std::vector &Images() const { return images; } const std::vector &Items() const { return items; } + const std::vector &MenuProperties() const { return menuProperties; } const std::vector &Monsters() const { return monsters; } const std::vector &Numbers() const { return numbers; } const std::vector &PartyLayouts() const { return partyLayouts; } @@ -110,6 +119,8 @@ private: void ReadObject(const Definition &); graphics::Animation *GetAnimation(const Value &); + battle::Resources *GetBattleResources(const Value &); + graphics::Color GetColor(const Value &); bool GetBoolean(const Value &); graphics::Font *GetFont(const Value &); graphics::Frame *GetFrame(const Value &); @@ -118,6 +129,8 @@ private: common::Ikari *GetIkari(const Value &); SDL_Surface *GetImage(const Value &); common::Item *GetItem(const Value &); + graphics::MenuProperties *GetMenuProperties(const Value &); + battle::Monster *GetMonster(const Value &); int GetNumber(const Value &); battle::PartyLayout *GetPartyLayout(const Value &); const PropertyList *GetPropertyList(const Value &); @@ -130,6 +143,7 @@ private: const std::vector &GetValueArray(const Value &); geometry::Vector GetVector(const Value &); + void ReadBattleResources(battle::Resources &, const PropertyList &); void ReadComplexAnimation(graphics::ComplexAnimation &, const PropertyList &); void ReadComplexAnimationFrame(graphics::ComplexAnimation::FrameProp &, const PropertyList &); void ReadFont(graphics::Font &, const PropertyList &); @@ -138,6 +152,7 @@ private: void ReadHero(battle::Hero &, const PropertyList &); void ReadIkari(common::Ikari &, const PropertyList &); void ReadItem(common::Item &, const PropertyList &); + void ReadMenuProperties(graphics::MenuProperties &, const PropertyList &); void ReadMonster(battle::Monster &, const PropertyList &); void ReadPartyLayout(battle::PartyLayout &, const PropertyList &); void ReadSimpleAnimation(graphics::SimpleAnimation &, const PropertyList &); @@ -149,7 +164,9 @@ private: private: const ParsedSource &source; enum Type { + BATTLE_RESOURCES, BOOLEAN, + COLOR, COMPLEX_ANIMATION, FONT, FRAME, @@ -158,6 +175,7 @@ private: IKARI, IMAGE, ITEM, + MENU_PROPERTIES, MONSTER, NUMBER, PARTY_LAYOUT, @@ -182,7 +200,9 @@ private: std::map imageCache; + std::vector battleResources; std::vector booleans; + std::vector colors; std::vector complexAnimations; std::vector fonts; std::vector frames; @@ -191,6 +211,7 @@ private: std::vector ikaris; std::vector images; std::vector items; + std::vector menuProperties; std::vector monsters; std::vector numbers; std::vector partyLayouts;