X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;ds=sidebyside;f=src%2Floader%2FInterpreter.h;h=b12efaedebb35fe3fac09057ffb13600aa3348ff;hb=02db07fbdd774a0a3b10806aa77d782059ba62cc;hp=c2fc25f84b6a1b6cb09edf1492e046f1e13c50d2;hpb=107b78b720db69ad402c09c0b1d9beb3b88a1952;p=l2e.git diff --git a/src/loader/Interpreter.h b/src/loader/Interpreter.h index c2fc25f..b12efae 100644 --- a/src/loader/Interpreter.h +++ b/src/loader/Interpreter.h @@ -8,20 +8,50 @@ #ifndef LOADER_INTERPRETER_H_ #define LOADER_INTERPRETER_H_ +#include "ParsedSource.h" +#include "TypeDescription.h" +#include "../geometry/Vector.h" +#include "../graphics/Color.h" +#include "../graphics/ComplexAnimation.h" + #include +#include #include #include #include +#include namespace battle { + class Hero; class Monster; + class PartyLayout; + struct Resources; + class Stats; +} + +namespace common { + class Ikari; + class Item; + class Spell; + class TargetingMode; +} + +namespace graphics { + class Animation; + class Font; + class Frame; + class Gauge; + struct MenuProperties; + class SimpleAnimation; + class Sprite; } namespace loader { class Definition; -class ParsedSource; +class Literal; class PropertyList; +class Value; class Interpreter { @@ -33,23 +63,61 @@ public: public: Interpreter(const ParsedSource &source) : source(source) { } - ~Interpreter() { } + ~Interpreter(); private: Interpreter(const Interpreter &); Interpreter &operator =(const Interpreter &); public: void ReadSource(); + void *GetObject(int typeId, const std::string &name); + + static void CreateTypeDescriptions(); + struct ParsedDefinition { + ParsedDefinition(const Definition *dfn, int type, int id) + : dfn(dfn), type(type), id(id) { } + const Definition *dfn; + int type; + int id; + }; + struct PostponedDefinition { + PostponedDefinition(int type, int id, std::ptrdiff_t offset, const char *identifier, int linkedType, bool inlined) + : type(type), id(id), offset(offset), identifier(identifier), linkedType(linkedType), inlined(inlined) { } + int type; + int id; + std::ptrdiff_t offset; + const char *identifier; + int linkedType; + bool inlined; + }; + + const std::set &ExportedIdentifiers() const { return source.Exports(); } + const ParsedDefinition &GetDefinition(const std::string &identifier) const { return parsedDefinitions.at(identifier); } + const std::map &Images() const { return imageCache; } + const std::vector &PostponedDefinitions() const { return postponedDefinitions; } + const std::map > &Values() const { return values; } private: + void ReadDefinition(const Definition &); void ReadLiteral(const Definition &); void ReadObject(const Definition &); - void ReadMonster(battle::Monster &, const PropertyList &); + void ReadLiteral(int typeId, int id, char *dest, const Literal &); + void *GetObject(int typeId, const Value &value); + void ReadObject(int typeId, int id, char *dest, const PropertyList &); + + SDL_Surface *GetImage(const std::string &); + + bool CanLink(const Value &) const; + void Postpone(int type, int id, std::ptrdiff_t offset, const std::string &identifier, int linkedType, bool inlined); private: const ParsedSource &source; - std::vector monsters; + + std::map parsedDefinitions; + std::vector postponedDefinitions; + std::map imageCache; + std::map > values; };