CCallback.h 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311
  1. #ifndef __CCALLBACK_H__
  2. #define __CCALLBACK_H__
  3. #include "global.h"
  4. #ifdef _WIN32
  5. #include "tchar.h"
  6. #else
  7. #include "tchar_amigaos4.h" //XXX this is mingw header are we need this for something? for 'true'
  8. //support of unicode we should use ICU or some boost wraper areound it
  9. //(boost using this lib during compilation i dont know what for exactly)
  10. #endif
  11. #include "lib/CGameState.h"
  12. /*
  13. * CCallback.h, part of VCMI engine
  14. *
  15. * Authors: listed in file AUTHORS in main folder
  16. *
  17. * License: GNU General Public License v2.0 or later
  18. * Full text of license available in license.txt file, in main folder
  19. *
  20. */
  21. class CGHeroInstance;
  22. class CGameState;
  23. struct CPath;
  24. class CGObjectInstance;
  25. class CArmedInstance;
  26. class SComponent;
  27. class IChosen;
  28. class CSelectableComponent;
  29. struct BattleAction;
  30. class CGTownInstance;
  31. struct StartInfo;
  32. class CStack;
  33. struct lua_State;
  34. class CClient;
  35. struct TerrainTile;
  36. class CHeroClass;
  37. class IShipyard;
  38. struct CPackForServer;
  39. class CMapHeader;
  40. struct CGPathNode;
  41. struct CGPath;
  42. struct InfoAboutTown
  43. {
  44. struct Details
  45. {
  46. int hallLevel, goldIncome;
  47. bool customRes;
  48. bool garrisonedHero;
  49. } *details;
  50. const CArmedInstance * obj;
  51. char fortLevel; //0 - none
  52. char owner;
  53. std::string name;
  54. CTown *tType;
  55. bool built;
  56. CCreatureSet army; //numbers of creatures are valid only if details
  57. InfoAboutTown();
  58. ~InfoAboutTown();
  59. void initFromTown(const CGTownInstance *t, bool detailed);
  60. };
  61. class ICallback
  62. {
  63. public:
  64. bool waitTillRealize; //if true, request functions will return after they are realized by server
  65. //hero
  66. virtual bool moveHero(const CGHeroInstance *h, int3 dst) =0; //dst must be free, neighbouring tile (this function can move hero only by one tile)
  67. virtual bool dismissHero(const CGHeroInstance * hero)=0; //dismisses given hero; true - successfuly, false - not successfuly
  68. //town
  69. virtual void recruitHero(const CGTownInstance *town, const CGHeroInstance *hero)=0;
  70. virtual bool buildBuilding(const CGTownInstance *town, si32 buildingID)=0;
  71. virtual void recruitCreatures(const CGObjectInstance *obj, ui32 ID, ui32 amount)=0;
  72. virtual bool upgradeCreature(const CArmedInstance *obj, int stackPos, int newID=-1)=0; //if newID==-1 then best possible upgrade will be made
  73. virtual void swapGarrisonHero(const CGTownInstance *town)=0;
  74. virtual void trade(int mode, int id1, int id2, int val1)=0; //mode==0: sell val1 units of id1 resource for id2 resiurce
  75. virtual void selectionMade(int selection, int asker) =0;
  76. virtual int swapCreatures(const CArmedInstance *s1, const CArmedInstance *s2, int p1, int p2)=0;//swaps creatures between two posiibly different garrisons // TODO: AI-unsafe code - fix it!
  77. virtual int mergeStacks(const CArmedInstance *s1, const CArmedInstance *s2, int p1, int p2)=0;//joins first stack tothe second (creatures must be same type)
  78. virtual int splitStack(const CArmedInstance *s1, const CArmedInstance *s2, int p1, int p2, int val)=0;//split creatures from the first stack
  79. virtual bool swapArtifacts(const CGHeroInstance * hero1, ui16 pos1, const CGHeroInstance * hero2, ui16 pos2)=0; //swaps artifacts between two given heroes
  80. virtual bool assembleArtifacts(const CGHeroInstance * hero, ui16 artifactSlot, bool assemble, ui32 assembleTo)=0;
  81. virtual bool dismissCreature(const CArmedInstance *obj, int stackPos)=0;
  82. virtual void endTurn()=0;
  83. virtual void buyArtifact(const CGHeroInstance *hero, int aid)=0; //used to buy artifacts in towns (including spell book in the guild and war machines in blacksmith)
  84. virtual void setFormation(const CGHeroInstance * hero, bool tight)=0;
  85. virtual void setSelection(const CArmedInstance * obj)=0;
  86. virtual void save(const std::string &fname) = 0;
  87. virtual void sendMessage(const std::string &mess) = 0;
  88. virtual void buildBoat(const IShipyard *obj) = 0;
  89. //get info
  90. virtual bool verifyPath(CPath * path, bool blockSea)const =0;
  91. virtual int getDate(int mode=0)const =0; //mode=0 - total days in game, mode=1 - day of week, mode=2 - current week, mode=3 - current month
  92. virtual std::vector< std::vector< std::vector<unsigned char> > > & getVisibilityMap()const =0; //returns visibility map (TODO: make it const)
  93. virtual int getResourceAmount(int type)const =0;
  94. virtual bool isVisible(int3 pos)const =0;
  95. virtual int getMyColor()const =0;
  96. virtual int getMySerial()const =0;
  97. virtual int getHeroSerial(const CGHeroInstance * hero)const =0;
  98. virtual const StartInfo * getStartInfo()const =0;
  99. virtual const CMapHeader * getMapHeader()const =0;
  100. virtual int getSpellCost(const CSpell * sp, const CGHeroInstance * caster) const =0; //when called during battle, takes into account creatures' spell cost reduction
  101. virtual int estimateSpellDamage(const CSpell * sp) const =0; //estimates damage of given spell; returns 0 if spell causes no dmg
  102. virtual void getThievesGuildInfo(SThievesGuildInfo & thi, const CGObjectInstance * obj)=0; //get thieves' guild info obtainable while visiting given object
  103. virtual int3 getGrailPos(float &outKnownRatio)=0;
  104. //hero
  105. virtual int howManyHeroes(bool includeGarrisoned = true)const =0;
  106. virtual const CGHeroInstance * getHeroInfo(int val, int mode=2)const =0; //mode = 0 -> val = serial; mode = 1 -> val = ID
  107. virtual std::vector < const CGHeroInstance *> getHeroesInfo(bool onlyOur=true)const =0;
  108. virtual bool getHeroInfo(const CGObjectInstance *hero, InfoAboutHero &dest) const = 0;
  109. virtual bool getPath(int3 src, int3 dest, const CGHeroInstance * hero, CPath &ret)=0;
  110. virtual const CGPathNode *getPathInfo(int3 tile)=0; //uses main, client pathfinder info
  111. virtual bool getPath2(int3 dest, CGPath &ret)=0; //uses main, client pathfinder info
  112. virtual void calculatePaths(const CGHeroInstance *hero, CPathsInfo &out, int3 src = int3(-1,-1,-1), int movement = -1) =0;
  113. virtual void recalculatePaths()=0; //updates main, client pathfinder info (should be called when moving hero is over)
  114. virtual void dig(const CGObjectInstance *hero)=0;
  115. //map
  116. virtual std::vector < const CGObjectInstance * > getBlockingObjs(int3 pos)const =0;
  117. virtual std::vector < const CGObjectInstance * > getVisitableObjs(int3 pos)const =0;
  118. virtual std::vector < const CGObjectInstance * > getFlaggableObjects(int3 pos) const =0;
  119. virtual std::vector < std::string > getObjDescriptions(int3 pos)const =0; //returns descriptions of objects at pos in order from the lowest to the highest
  120. //town
  121. virtual int howManyTowns()const =0;
  122. virtual const CGTownInstance * getTownInfo(int val, bool mode)const =0; //mode = 0 -> val = serial; mode = 1 -> val = ID
  123. virtual std::vector < const CGTownInstance *> getTownsInfo(bool onlyOur=true) const=0;
  124. virtual std::vector<const CGHeroInstance *> getAvailableHeroes(const CGTownInstance * town) const =0; //heroes that can be recruited
  125. virtual int canBuildStructure(const CGTownInstance *t, int ID) =0;//// 0 - no more than one capitol, 1 - lack of water, 2 - forbidden, 3 - Add another level to Mage Guild, 4 - already built, 5 - cannot build, 6 - cannot afford, 7 - build, 8 - lack of requirements
  126. virtual std::set<int> getBuildingRequiments(const CGTownInstance *t, int ID) =0;
  127. virtual void getMarketOffer(int t1, int t2, int &give, int &rec, int mode=0)const =0; //t1 - type of given resource, t2 - type of received resource; give is the amount of resource t1 that can be traded for amount rec of resource t2 (one of them is 1)
  128. virtual bool getTownInfo(const CGObjectInstance *town, InfoAboutTown &dest) const = 0;
  129. virtual UpgradeInfo getUpgradeInfo(const CArmedInstance *obj, int stackPos)const =0;
  130. virtual const CCreatureSet* getGarrison(const CGObjectInstance *obj)const =0;
  131. virtual int3 getMapSize() const =0; //returns size of map - z is 1 for one - level map and 2 for two level map
  132. virtual const TerrainTile * getTileInfo(int3 tile) const = 0;
  133. //battle
  134. virtual int battleGetBattlefieldType()=0; // 1. sand/shore 2. sand/mesas 3. dirt/birches 4. dirt/hills 5. dirt/pines 6. grass/hills 7. grass/pines 8. lava 9. magic plains 10. snow/mountains 11. snow/trees 12. subterranean 13. swamp/trees 14. fiery fields 15. rock lands 16. magic clouds 17. lucid pools 18. holy ground 19. clover field 20. evil fog 21. "favourable winds" text on magic plains background 22. cursed ground 23. rough 24. ship to ship 25. ship
  135. virtual int battleGetObstaclesAtTile(int tile)=0; //returns bitfield
  136. virtual std::vector<CObstacleInstance> battleGetAllObstacles()=0; //returns all obstacles on the battlefield
  137. virtual int battleGetStack(int pos, bool onlyAlive)=0; //returns ID of stack on the tile
  138. virtual const CStack * battleGetStackByID(int ID, bool onlyAlive = true)=0; //returns stack info by given ID
  139. virtual const CStack * battleGetStackByPos(int pos, bool onlyAlive = true)=0; //returns stack info by given pos
  140. virtual int battleGetPos(int stack)=0; //returns position (tile ID) of stack
  141. virtual int battleMakeAction(BattleAction* action)=0;//for casting spells by hero - DO NOT use it for moving active stack
  142. virtual std::map<int, CStack> battleGetStacks()=0; //returns stacks on battlefield
  143. virtual void getStackQueue( std::vector<const CStack *> &out, int howMany )=0; //returns vector of stack in order of their move sequence
  144. virtual CCreature battleGetCreature(int number)=0; //returns type of creature by given number of stack
  145. //virtual bool battleMoveCreature(int ID, int dest)=0; //moves creature with id ID to dest if possible
  146. virtual std::vector<int> battleGetAvailableHexes(int ID, bool addOccupiable)=0; //reutrns numbers of hexes reachable by creature with id ID
  147. virtual bool battleIsStackMine(int ID)=0; //returns true if stack with id ID belongs to caller
  148. virtual bool battleCanShoot(int ID, int dest)=0; //returns true if unit with id ID can shoot to dest
  149. virtual bool battleCanCastSpell()=0; //returns true, if caller can cast a spell
  150. virtual bool battleCanFlee()=0; //returns true if caller can flee from the battle
  151. virtual const CGTownInstance * battleGetDefendedTown()=0; //returns defended town if current battle is a siege, NULL instead
  152. virtual ui8 battleGetWallState(int partOfWall)=0; //for determining state of a part of the wall; format: parameter [0] - keep, [1] - bottom tower, [2] - bottom wall, [3] - below gate, [4] - over gate, [5] - upper wall, [6] - uppert tower, [7] - gate; returned value: 1 - intact, 2 - damaged, 3 - destroyed; 0 - no battle
  153. virtual int battleGetWallUnderHex(int hex)=0; //returns part of destructible wall / gate / keep under given hex or -1 if not found
  154. virtual std::pair<ui32, ui32> battleEstimateDamage(int attackerID, int defenderID)=0; //estimates damage dealt by attacker to defender; it may be not precise especially when stack has randomly working bonuses; returns pair <min dmg, max dmg>
  155. virtual ui8 battleGetSiegeLevel()=0; //returns 0 when there is no siege, 1 if fort, 2 is citadel, 3 is castle
  156. virtual const CGHeroInstance * battleGetFightingHero(ui8 side) const =0; //returns hero corresponding ot given side (0 - attacker, 1 - defender)
  157. virtual si8 battleGetStackMorale(int stackID) =0; //returns morale of given stack
  158. virtual si8 battleGetStackLuck(int stackID) =0; //returns luck of given stack
  159. };
  160. struct HeroMoveDetails
  161. {
  162. HeroMoveDetails(){};
  163. HeroMoveDetails(int3 Src, int3 Dst, CGHeroInstance*Ho);
  164. int3 src, dst; //source and destination points
  165. CGHeroInstance * ho; //object instance of this hero
  166. int owner, style; //style: 0 - normal move, 1 - teleport, 2 - instant jump
  167. bool successful;
  168. };
  169. class CCallback : public ICallback
  170. {
  171. private:
  172. CCallback(CGameState * GS, int Player, CClient *C);;
  173. CGameState * gs;
  174. CClient *cl;
  175. bool isVisible(int3 pos, int Player) const;
  176. bool isVisible(const CGObjectInstance *obj, int Player) const;
  177. template <typename T> void sendRequest(const T*request);
  178. protected:
  179. int player;
  180. public:
  181. //commands
  182. bool moveHero(const CGHeroInstance *h, int3 dst); //dst must be free, neighbouring tile (this function can move hero only by one tile)
  183. void selectionMade(int selection, int asker);
  184. int swapCreatures(const CArmedInstance *s1, const CArmedInstance *s2, int p1, int p2);
  185. int mergeStacks(const CArmedInstance *s1, const CArmedInstance *s2, int p1, int p2); //first goes to the second
  186. int splitStack(const CArmedInstance *s1, const CArmedInstance *s2, int p1, int p2, int val);
  187. bool dismissHero(const CGHeroInstance * hero);
  188. bool swapArtifacts(const CGHeroInstance * hero1, ui16 pos1, const CGHeroInstance * hero2, ui16 pos2);
  189. bool assembleArtifacts(const CGHeroInstance * hero, ui16 artifactSlot, bool assemble, ui32 assembleTo);
  190. bool buildBuilding(const CGTownInstance *town, si32 buildingID);
  191. void recruitCreatures(const CGObjectInstance *obj, ui32 ID, ui32 amount);
  192. bool dismissCreature(const CArmedInstance *obj, int stackPos);
  193. bool upgradeCreature(const CArmedInstance *obj, int stackPos, int newID=-1);
  194. void endTurn();
  195. void swapGarrisonHero(const CGTownInstance *town);
  196. void buyArtifact(const CGHeroInstance *hero, int aid);
  197. void trade(int mode, int id1, int id2, int val1);
  198. void setFormation(const CGHeroInstance * hero, bool tight);
  199. void setSelection(const CArmedInstance * obj);
  200. void recruitHero(const CGTownInstance *town, const CGHeroInstance *hero);
  201. void save(const std::string &fname);
  202. void sendMessage(const std::string &mess);
  203. void buildBoat(const IShipyard *obj);
  204. void dig(const CGObjectInstance *hero);
  205. //get info
  206. bool verifyPath(CPath * path, bool blockSea) const;
  207. int getDate(int mode=0) const; //mode=0 - total days in game, mode=1 - day of week, mode=2 - current week, mode=3 - current month
  208. std::vector< std::vector< std::vector<unsigned char> > > & getVisibilityMap() const; //returns visibility map (TODO: make it const)
  209. const CGHeroInstance * getHeroInfo(int val, int mode=2) const; //mode = 0 -> val = serial; mode = 1 -> val = hero type id (subID); mode = 2 -> val = global object serial id (id)
  210. const CGObjectInstance * getObjectInfo(int ID) const; //global object serial id (ID)
  211. int getResourceAmount(int type) const;
  212. std::vector<si32> getResourceAmount() const;
  213. int howManyHeroes(bool includeGarrisoned = true) const;
  214. const CGTownInstance * getTownInfo(int val, bool mode) const; //mode = 0 -> val = serial; mode = 1 -> val = ID
  215. std::vector < const CGTownInstance *> getTownsInfo(bool onlyOur=true) const;
  216. int howManyTowns()const;
  217. std::vector < std::string > getObjDescriptions(int3 pos) const; //returns descriptions of objects at pos in order from the lowest to the highest
  218. std::vector < const CGHeroInstance *> getHeroesInfo(bool onlyOur=true) const;
  219. bool isVisible(int3 pos) const;
  220. int getMyColor() const;
  221. int getHeroSerial(const CGHeroInstance * hero) const;
  222. int getMySerial() const;
  223. const CCreatureSet* getGarrison(const CGObjectInstance *obj) const;
  224. UpgradeInfo getUpgradeInfo(const CArmedInstance *obj, int stackPos) const;
  225. const StartInfo * getStartInfo() const;
  226. const CMapHeader * getMapHeader()const ;
  227. int getSpellCost(const CSpell * sp, const CGHeroInstance * caster) const; //when called during battle, takes into account creatures' spell cost reduction
  228. int estimateSpellDamage(const CSpell * sp) const; //estimates damage of given spell; returns 0 if spell causes no dmg
  229. void getThievesGuildInfo(SThievesGuildInfo & thi, const CGObjectInstance * obj); //get thieves' guild info obtainable while visiting given object
  230. int3 getGrailPos(float &outKnownRatio); //returns pos and (via arg) percent of discovered obelisks; TODO: relies on fairness of GUI/AI... :/
  231. std::vector < const CGObjectInstance * > getBlockingObjs(int3 pos) const;
  232. std::vector < const CGObjectInstance * > getVisitableObjs(int3 pos) const;
  233. void getMarketOffer(int t1, int t2, int &give, int &rec, int mode=0) const; //t1 - type of given resource, t2 - type of received resource; give is the amount of resource t1 that can be traded for amount rec of resource t2 (one of them is 1)
  234. std::vector < const CGObjectInstance * > getFlaggableObjects(int3 pos) const;
  235. int3 getMapSize() const; //returns size of map - z is 1 for one - level map and 2 for two level map
  236. std::vector<const CGHeroInstance *> getAvailableHeroes(const CGTownInstance * town) const; //heroes that can be recruited
  237. const TerrainTile * getTileInfo(int3 tile) const;
  238. int canBuildStructure(const CGTownInstance *t, int ID);//// 0 - no more than one capitol, 1 - lack of water, 2 - forbidden, 3 - Add another level to Mage Guild, 4 - already built, 5 - cannot build, 6 - cannot afford, 7 - build, 8 - lack of requirements
  239. std::set<int> getBuildingRequiments(const CGTownInstance *t, int ID);
  240. bool getPath(int3 src, int3 dest, const CGHeroInstance * hero, CPath &ret);
  241. const CGPathNode *getPathInfo(int3 tile);
  242. bool getPath2(int3 dest, CGPath &ret);
  243. void calculatePaths(const CGHeroInstance *hero, CPathsInfo &out, int3 src = int3(-1,-1,-1), int movement = -1); //calculates possible paths for hero, by default uses current hero position and movement left;
  244. void recalculatePaths(); //updates pathfinder info (should be called when moving hero is over)
  245. bool getHeroInfo(const CGObjectInstance *hero, InfoAboutHero &dest) const;
  246. bool getTownInfo(const CGObjectInstance *town, InfoAboutTown &dest) const;
  247. //battle
  248. int battleGetBattlefieldType(); // 1. sand/shore 2. sand/mesas 3. dirt/birches 4. dirt/hills 5. dirt/pines 6. grass/hills 7. grass/pines 8. lava 9. magic plains 10. snow/mountains 11. snow/trees 12. subterranean 13. swamp/trees 14. fiery fields 15. rock lands 16. magic clouds 17. lucid pools 18. holy ground 19. clover field 20. evil fog 21. "favourable winds" text on magic plains background 22. cursed ground 23. rough 24. ship to ship 25. ship
  249. int battleGetObstaclesAtTile(int tile); //returns bitfield
  250. std::vector<CObstacleInstance> battleGetAllObstacles(); //returns all obstacles on the battlefield
  251. int battleGetStack(int pos, bool onlyAlive = true); //returns ID of stack on the tile
  252. const CStack * battleGetStackByID(int ID, bool onlyAlive = true); //returns stack info by given ID
  253. const CStack * battleGetStackByPos(int pos, bool onlyAlive = true); //returns stack info by given pos
  254. int battleGetPos(int stack); //returns position (tile ID) of stack
  255. int battleMakeAction(BattleAction* action);//for casting spells by hero - DO NOT use it for moving active stack
  256. std::map<int, CStack> battleGetStacks(); //returns stacks on battlefield
  257. void getStackQueue( std::vector<const CStack *> &out, int howMany ); //returns vector of stack in order of their move sequence
  258. CCreature battleGetCreature(int number); //returns type of creature by given number of stack
  259. std::vector<int> battleGetAvailableHexes(int ID, bool addOccupiable); //reutrns numbers of hexes reachable by creature with id ID
  260. bool battleIsStackMine(int ID); //returns true if stack with id ID belongs to caller
  261. bool battleCanShoot(int ID, int dest); //returns true if unit with id ID can shoot to dest
  262. bool battleCanCastSpell(); //returns true, if caller can cast a spell
  263. bool battleCanFlee(); //returns true if caller can flee from the battle
  264. const CGTownInstance * battleGetDefendedTown(); //returns defended town if current battle is a siege, NULL instead
  265. ui8 battleGetWallState(int partOfWall); //for determining state of a part of the wall; format: parameter [0] - keep, [1] - bottom tower, [2] - bottom wall, [3] - below gate, [4] - over gate, [5] - upper wall, [6] - uppert tower, [7] - gate; returned value: 1 - intact, 2 - damaged, 3 - destroyed; 0 - no battle
  266. int battleGetWallUnderHex(int hex); //returns part of destructible wall / gate / keep under given hex or -1 if not found
  267. std::pair<ui32, ui32> battleEstimateDamage(int attackerID, int defenderID); //estimates damage dealt by attacker to defender; it may be not precise especially when stack has randomly working bonuses; returns pair <min dmg, max dmg>
  268. ui8 battleGetSiegeLevel(); //returns 0 when there is no siege, 1 if fort, 2 is citadel, 3 is castle
  269. const CGHeroInstance * battleGetFightingHero(ui8 side) const; //returns hero corresponding ot given side (0 - attacker, 1 - defender)
  270. si8 battleGetStackMorale(int stackID); //returns morale of given stack
  271. si8 battleGetStackLuck(int stackID); //returns luck of given stack
  272. //XXX hmmm _tmain on _GNUC_ wtf?
  273. //friends
  274. friend class CClient;
  275. #ifndef __GNUC__
  276. friend int _tmain(int argc, _TCHAR* argv[]);
  277. #else
  278. friend int main(int argc, char** argv);
  279. #endif
  280. };
  281. #endif // __CCALLBACK_H__