IGameCallback.h 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  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 StackLocation;
  20. struct ArtifactLocation;
  21. class CCreatureSet;
  22. class CStackBasicDescriptor;
  23. class CGCreature;
  24. enum class EOpenWindowMode : uint8_t;
  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. CGameState *gameState();
  39. //used for random spawns
  40. void getFreeTiles(std::vector<int3> &tiles) const;
  41. //mode 1 - only unrevealed tiles; mode 0 - all, mode -1 - only revealed
  42. void getTilesInRange(std::unordered_set<int3> & tiles,
  43. const int3 & pos,
  44. int radius,
  45. ETileVisibility mode,
  46. std::optional<PlayerColor> player = std::optional<PlayerColor>(),
  47. int3::EDistanceFormula formula = int3::DIST_2D) const;
  48. //returns all tiles on given level (-1 - both levels, otherwise number of level)
  49. void getAllTiles(std::unordered_set<int3> &tiles, std::optional<PlayerColor> player, int level, std::function<bool(const TerrainTile *)> filter) const;
  50. //gives 3 treasures, 3 minors, 1 major -> used by Black Market and Artifact Merchant
  51. void pickAllowedArtsSet(std::vector<const CArtifact *> & out, CRandomGenerator & rand) const;
  52. void getAllowedSpells(std::vector<SpellID> &out, std::optional<ui16> level = std::nullopt);
  53. template<typename Saver>
  54. void saveCommonState(Saver &out) const; //stores GS and VLC
  55. template<typename Loader>
  56. void loadCommonState(Loader &in); //loads GS and VLC
  57. };
  58. class DLL_LINKAGE IGameEventCallback
  59. {
  60. public:
  61. virtual void setObjProperty(ObjectInstanceID objid, int prop, si64 val) = 0;
  62. virtual void showInfoDialog(InfoWindow * iw) = 0;
  63. virtual void showInfoDialog(const std::string & msg, PlayerColor player) = 0;
  64. virtual void changeSpells(const CGHeroInstance * hero, bool give, const std::set<SpellID> &spells)=0;
  65. virtual bool removeObject(const CGObjectInstance * obj, const PlayerColor & initiator) = 0;
  66. virtual void createObject(const int3 & visitablePosition, const PlayerColor & initiator, Obj type, int32_t subtype = 0) = 0;
  67. virtual void setOwner(const CGObjectInstance * objid, PlayerColor owner)=0;
  68. virtual void changePrimSkill(const CGHeroInstance * hero, PrimarySkill which, si64 val, bool abs=false)=0;
  69. virtual void changeSecSkill(const CGHeroInstance * hero, SecondarySkill which, int val, bool abs=false)=0;
  70. virtual void showBlockingDialog(BlockingDialog *iw) =0;
  71. virtual void showGarrisonDialog(ObjectInstanceID upobj, ObjectInstanceID hid, bool removableUnits) =0; //cb will be called when player closes garrison window
  72. virtual void showTeleportDialog(TeleportDialog *iw) =0;
  73. virtual void showObjectWindow(const CGObjectInstance * object, EOpenWindowMode window, const CGHeroInstance * visitor, bool addQuery) = 0;
  74. virtual void giveResource(PlayerColor player, GameResID which, int val)=0;
  75. virtual void giveResources(PlayerColor player, TResources resources)=0;
  76. virtual void giveCreatures(const CArmedInstance *objid, const CGHeroInstance * h, const CCreatureSet &creatures, bool remove) =0;
  77. virtual void takeCreatures(ObjectInstanceID objid, const std::vector<CStackBasicDescriptor> &creatures) =0;
  78. virtual bool changeStackCount(const StackLocation &sl, TQuantity count, bool absoluteValue = false) =0;
  79. virtual bool changeStackType(const StackLocation &sl, const CCreature *c) =0;
  80. virtual bool insertNewStack(const StackLocation &sl, const CCreature *c, TQuantity count = -1) =0; //count -1 => moves whole stack
  81. virtual bool eraseStack(const StackLocation &sl, bool forceRemoval = false) =0;
  82. virtual bool swapStacks(const StackLocation &sl1, const StackLocation &sl2) =0;
  83. virtual bool addToSlot(const StackLocation &sl, const CCreature *c, TQuantity count) =0; //makes new stack or increases count of already existing
  84. 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
  85. virtual bool moveStack(const StackLocation &src, const StackLocation &dst, TQuantity count) = 0;
  86. virtual void removeAfterVisit(const CGObjectInstance *object) = 0; //object will be destroyed when interaction is over. Do not call when interaction is not ongoing!
  87. virtual bool giveHeroNewArtifact(const CGHeroInstance * h, const CArtifact * artType, ArtifactPosition pos) = 0;
  88. virtual bool giveHeroArtifact(const CGHeroInstance * h, const CArtifactInstance * a, ArtifactPosition pos) = 0;
  89. virtual void putArtifact(const ArtifactLocation &al, const CArtifactInstance *a) = 0;
  90. virtual void removeArtifact(const ArtifactLocation &al) = 0;
  91. virtual bool moveArtifact(const ArtifactLocation &al1, const ArtifactLocation &al2) = 0;
  92. virtual void heroVisitCastle(const CGTownInstance * obj, const CGHeroInstance * hero)=0;
  93. virtual void visitCastleObjects(const CGTownInstance * obj, const CGHeroInstance * hero)=0;
  94. virtual void stopHeroVisitCastle(const CGTownInstance * obj, const CGHeroInstance * hero)=0;
  95. 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
  96. 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
  97. 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
  98. virtual bool moveHero(ObjectInstanceID hid, int3 dst, ui8 teleporting, bool transit = false, PlayerColor asker = PlayerColor::NEUTRAL)=0;
  99. virtual bool swapGarrisonOnSiege(ObjectInstanceID tid)=0;
  100. virtual void giveHeroBonus(GiveBonus * bonus)=0;
  101. virtual void setMovePoints(SetMovePoints * smp)=0;
  102. virtual void setManaPoints(ObjectInstanceID hid, int val)=0;
  103. virtual void giveHero(ObjectInstanceID id, PlayerColor player, ObjectInstanceID boatId = ObjectInstanceID()) = 0;
  104. virtual void changeObjPos(ObjectInstanceID objid, int3 newPos, const PlayerColor & initiator)=0;
  105. virtual void sendAndApply(CPackForClient * pack) = 0;
  106. virtual void heroExchange(ObjectInstanceID hero1, ObjectInstanceID hero2)=0; //when two heroes meet on adventure map
  107. virtual void changeFogOfWar(int3 center, ui32 radius, PlayerColor player, ETileVisibility mode) = 0;
  108. virtual void changeFogOfWar(std::unordered_set<int3> &tiles, PlayerColor player, ETileVisibility mode) = 0;
  109. virtual void castSpell(const spells::Caster * caster, SpellID spellID, const int3 &pos) = 0;
  110. };
  111. class DLL_LINKAGE CNonConstInfoCallback : public CPrivilegedInfoCallback
  112. {
  113. public:
  114. //keep const version of callback accessible
  115. using CGameInfoCallback::getPlayerState;
  116. using CGameInfoCallback::getTeam;
  117. using CGameInfoCallback::getPlayerTeam;
  118. using CGameInfoCallback::getHero;
  119. using CGameInfoCallback::getTown;
  120. using CGameInfoCallback::getTile;
  121. using CGameInfoCallback::getArtInstance;
  122. using CGameInfoCallback::getObjInstance;
  123. PlayerState * getPlayerState(const PlayerColor & color, bool verbose = true);
  124. TeamState * getTeam(const TeamID & teamID); //get team by team ID
  125. TeamState * getPlayerTeam(const PlayerColor & color); // get team by player color
  126. CGHeroInstance * getHero(const ObjectInstanceID & objid);
  127. CGTownInstance * getTown(const ObjectInstanceID & objid);
  128. TerrainTile * getTile(const int3 & pos);
  129. CArtifactInstance * getArtInstance(const ArtifactInstanceID & aid);
  130. CGObjectInstance * getObjInstance(const ObjectInstanceID & oid);
  131. CArmedInstance * getArmyInstance(const ObjectInstanceID & oid);
  132. virtual void updateEntity(Metatype metatype, int32_t index, const JsonNode & data) = 0;
  133. };
  134. /// Interface class for handling general game logic and actions
  135. class DLL_LINKAGE IGameCallback : public CPrivilegedInfoCallback, public IGameEventCallback
  136. {
  137. public:
  138. virtual ~IGameCallback(){};
  139. #if SCRIPTING_ENABLED
  140. virtual scripting::Pool * getGlobalContextPool() const = 0;
  141. #endif
  142. //get info
  143. virtual bool isVisitCoveredByAnotherQuery(const CGObjectInstance *obj, const CGHeroInstance *hero);
  144. friend struct CPack;
  145. friend struct CPackForClient;
  146. friend struct CPackForServer;
  147. };
  148. VCMI_LIB_NAMESPACE_END