IGameCallback.h 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. /*
  2. * IGameCallback.h, part of VCMI engine
  3. *
  4. * Authors: listed in file AUTHORS in main folder
  5. *
  6. * License: GNU General Public License v2.0 or later
  7. * Full text of license available in license.txt file, in main folder
  8. *
  9. */
  10. #pragma once
  11. #include <vcmi/Metatype.h>
  12. #include "CGameInfoCallback.h" // for CGameInfoCallback
  13. #include "CRandomGenerator.h"
  14. VCMI_LIB_NAMESPACE_BEGIN
  15. struct SetMovePoints;
  16. struct GiveBonus;
  17. struct BlockingDialog;
  18. struct TeleportDialog;
  19. struct MetaString;
  20. struct StackLocation;
  21. struct ArtifactLocation;
  22. class CCreatureSet;
  23. class CStackBasicDescriptor;
  24. class CGCreature;
  25. namespace spells
  26. {
  27. class Caster;
  28. }
  29. #if SCRIPTING_ENABLED
  30. namespace scripting
  31. {
  32. class Pool;
  33. }
  34. #endif
  35. class DLL_LINKAGE CPrivilegedInfoCallback : public CGameInfoCallback
  36. {
  37. public:
  38. enum class MapTerrainFilterMode
  39. {
  40. NONE = 0,
  41. LAND = 1,
  42. WATER = 2,
  43. LAND_CARTOGRAPHER = 3,
  44. UNDERGROUND_CARTOGRAPHER = 4
  45. };
  46. CGameState *gameState();
  47. //used for random spawns
  48. void getFreeTiles(std::vector<int3> &tiles) const;
  49. //mode 1 - only unrevealed tiles; mode 0 - all, mode -1 - only revealed
  50. void getTilesInRange(std::unordered_set<int3> & tiles,
  51. const int3 & pos,
  52. int radious,
  53. std::optional<PlayerColor> player = std::optional<PlayerColor>(),
  54. int mode = 0,
  55. int3::EDistanceFormula formula = int3::DIST_2D) const;
  56. //returns all tiles on given level (-1 - both levels, otherwise number of level)
  57. void getAllTiles(std::unordered_set<int3> &tiles, std::optional<PlayerColor> player = std::optional<PlayerColor>(),
  58. int level = -1, MapTerrainFilterMode tileFilterMode = MapTerrainFilterMode::NONE) const;
  59. //gives 3 treasures, 3 minors, 1 major -> used by Black Market and Artifact Merchant
  60. void pickAllowedArtsSet(std::vector<const CArtifact *> & out, CRandomGenerator & rand) const;
  61. void getAllowedSpells(std::vector<SpellID> &out, ui16 level);
  62. template<typename Saver>
  63. void saveCommonState(Saver &out) const; //stores GS and VLC
  64. template<typename Loader>
  65. void loadCommonState(Loader &in); //loads GS and VLC
  66. };
  67. class DLL_LINKAGE IGameEventCallback
  68. {
  69. public:
  70. virtual void setObjProperty(ObjectInstanceID objid, int prop, si64 val) = 0;
  71. virtual void showInfoDialog(InfoWindow * iw) = 0;
  72. virtual void showInfoDialog(const std::string & msg, PlayerColor player) = 0;
  73. virtual void changeSpells(const CGHeroInstance * hero, bool give, const std::set<SpellID> &spells)=0;
  74. virtual bool removeObject(const CGObjectInstance * obj)=0;
  75. virtual void setOwner(const CGObjectInstance * objid, PlayerColor owner)=0;
  76. virtual void changePrimSkill(const CGHeroInstance * hero, PrimarySkill::PrimarySkill which, si64 val, bool abs=false)=0;
  77. virtual void changeSecSkill(const CGHeroInstance * hero, SecondarySkill which, int val, bool abs=false)=0;
  78. virtual void showBlockingDialog(BlockingDialog *iw) =0;
  79. virtual void showGarrisonDialog(ObjectInstanceID upobj, ObjectInstanceID hid, bool removableUnits) =0; //cb will be called when player closes garrison window
  80. virtual void showTeleportDialog(TeleportDialog *iw) =0;
  81. virtual void showThievesGuildWindow(PlayerColor player, ObjectInstanceID requestingObjId) =0;
  82. virtual void giveResource(PlayerColor player, GameResID which, int val)=0;
  83. virtual void giveResources(PlayerColor player, TResources resources)=0;
  84. virtual void giveCreatures(const CArmedInstance *objid, const CGHeroInstance * h, const CCreatureSet &creatures, bool remove) =0;
  85. virtual void takeCreatures(ObjectInstanceID objid, const std::vector<CStackBasicDescriptor> &creatures) =0;
  86. virtual bool changeStackCount(const StackLocation &sl, TQuantity count, bool absoluteValue = false) =0;
  87. virtual bool changeStackType(const StackLocation &sl, const CCreature *c) =0;
  88. virtual bool insertNewStack(const StackLocation &sl, const CCreature *c, TQuantity count = -1) =0; //count -1 => moves whole stack
  89. virtual bool eraseStack(const StackLocation &sl, bool forceRemoval = false) =0;
  90. virtual bool swapStacks(const StackLocation &sl1, const StackLocation &sl2) =0;
  91. virtual bool addToSlot(const StackLocation &sl, const CCreature *c, TQuantity count) =0; //makes new stack or increases count of already existing
  92. virtual void tryJoiningArmy(const CArmedInstance *src, const CArmedInstance *dst, bool removeObjWhenFinished, bool allowMerging) =0; //merges army from src do dst or opens a garrison window
  93. virtual bool moveStack(const StackLocation &src, const StackLocation &dst, TQuantity count) = 0;
  94. virtual void removeAfterVisit(const CGObjectInstance *object) = 0; //object will be destroyed when interaction is over. Do not call when interaction is not ongoing!
  95. virtual bool giveHeroNewArtifact(const CGHeroInstance * h, const CArtifact * artType, ArtifactPosition pos) = 0;
  96. virtual bool giveHeroArtifact(const CGHeroInstance * h, const CArtifactInstance * a, ArtifactPosition pos) = 0;
  97. virtual void putArtifact(const ArtifactLocation &al, const CArtifactInstance *a) = 0;
  98. virtual void removeArtifact(const ArtifactLocation &al) = 0;
  99. virtual bool moveArtifact(const ArtifactLocation &al1, const ArtifactLocation &al2) = 0;
  100. virtual void heroVisitCastle(const CGTownInstance * obj, const CGHeroInstance * hero)=0;
  101. virtual void visitCastleObjects(const CGTownInstance * obj, const CGHeroInstance * hero)=0;
  102. virtual void stopHeroVisitCastle(const CGTownInstance * obj, const CGHeroInstance * hero)=0;
  103. virtual void startBattlePrimary(const CArmedInstance *army1, const CArmedInstance *army2, int3 tile, const CGHeroInstance *hero1, const CGHeroInstance *hero2, bool creatureBank = false, const CGTownInstance *town = nullptr)=0; //use hero=nullptr for no hero
  104. virtual void startBattleI(const CArmedInstance *army1, const CArmedInstance *army2, int3 tile, bool creatureBank = false)=0; //if any of armies is hero, hero will be used
  105. virtual void startBattleI(const CArmedInstance *army1, const CArmedInstance *army2, bool creatureBank = false)=0; //if any of armies is hero, hero will be used, visitable tile of second obj is place of battle
  106. virtual bool moveHero(ObjectInstanceID hid, int3 dst, ui8 teleporting, bool transit = false, PlayerColor asker = PlayerColor::NEUTRAL)=0;
  107. virtual bool swapGarrisonOnSiege(ObjectInstanceID tid)=0;
  108. virtual void giveHeroBonus(GiveBonus * bonus)=0;
  109. virtual void setMovePoints(SetMovePoints * smp)=0;
  110. virtual void setManaPoints(ObjectInstanceID hid, int val)=0;
  111. virtual void giveHero(ObjectInstanceID id, PlayerColor player)=0;
  112. virtual void changeObjPos(ObjectInstanceID objid, int3 newPos)=0;
  113. virtual void sendAndApply(CPackForClient * pack) = 0;
  114. virtual void heroExchange(ObjectInstanceID hero1, ObjectInstanceID hero2)=0; //when two heroes meet on adventure map
  115. virtual void changeFogOfWar(int3 center, ui32 radius, PlayerColor player, bool hide) = 0;
  116. virtual void changeFogOfWar(std::unordered_set<int3> &tiles, PlayerColor player, bool hide) = 0;
  117. virtual void castSpell(const spells::Caster * caster, SpellID spellID, const int3 &pos) = 0;
  118. };
  119. class DLL_LINKAGE CNonConstInfoCallback : public CPrivilegedInfoCallback
  120. {
  121. public:
  122. //keep const version of callback accessible
  123. using CGameInfoCallback::getPlayerState;
  124. using CGameInfoCallback::getTeam;
  125. using CGameInfoCallback::getPlayerTeam;
  126. using CGameInfoCallback::getHero;
  127. using CGameInfoCallback::getTown;
  128. using CGameInfoCallback::getTile;
  129. using CGameInfoCallback::getArtInstance;
  130. using CGameInfoCallback::getObjInstance;
  131. PlayerState * getPlayerState(const PlayerColor & color, bool verbose = true);
  132. TeamState * getTeam(const TeamID & teamID); //get team by team ID
  133. TeamState * getPlayerTeam(const PlayerColor & color); // get team by player color
  134. CGHeroInstance * getHero(const ObjectInstanceID & objid);
  135. CGTownInstance * getTown(const ObjectInstanceID & objid);
  136. TerrainTile * getTile(const int3 & pos);
  137. CArtifactInstance * getArtInstance(const ArtifactInstanceID & aid);
  138. CGObjectInstance * getObjInstance(const ObjectInstanceID & oid);
  139. CArmedInstance * getArmyInstance(const ObjectInstanceID & oid);
  140. virtual void updateEntity(Metatype metatype, int32_t index, const JsonNode & data) = 0;
  141. };
  142. /// Interface class for handling general game logic and actions
  143. class DLL_LINKAGE IGameCallback : public CPrivilegedInfoCallback, public IGameEventCallback
  144. {
  145. public:
  146. virtual ~IGameCallback(){};
  147. #if SCRIPTING_ENABLED
  148. virtual scripting::Pool * getGlobalContextPool() const = 0;
  149. #endif
  150. //get info
  151. virtual bool isVisitCoveredByAnotherQuery(const CGObjectInstance *obj, const CGHeroInstance *hero);
  152. friend struct CPack;
  153. friend struct CPackForClient;
  154. friend struct CPackForServer;
  155. };
  156. VCMI_LIB_NAMESPACE_END