2008-12-27 03:01:59 +02:00
# ifndef __CGAMESTATE_H__
# define __CGAMESTATE_H__
2009-05-20 13:08:56 +03:00
# include "../global.h"
2009-12-01 23:05:57 +02:00
# include <cassert>
2010-05-02 21:20:26 +03:00
2008-12-27 03:01:59 +02:00
# ifndef _MSC_VER
2009-05-20 13:08:56 +03:00
# include "../hch/CCreatureHandler.h"
# include "VCMI_Lib.h"
2009-01-30 20:36:00 +02:00
# include "map.h"
2008-12-27 03:01:59 +02:00
# endif
2010-05-02 21:20:26 +03:00
2008-12-27 03:01:59 +02:00
# include <set>
# include <vector>
2010-02-01 19:51:33 +02:00
# include <list>
2010-02-10 04:56:00 +02:00
# include "HeroBonus.h"
2010-05-02 21:20:26 +03:00
# include "CCreatureSet.h"
2008-12-27 03:01:59 +02:00
# ifdef _WIN32
# include <tchar.h>
# else
2009-05-21 03:55:30 +03:00
# include "../tchar_amigaos4.h"
2008-12-27 03:01:59 +02:00
# endif
2010-05-02 21:20:26 +03:00
2009-04-15 17:03:31 +03:00
/*
* CGameState . h , part of VCMI engine
*
* Authors : listed in file AUTHORS in main folder
*
* License : GNU General Public License v2 .0 or later
* Full text of license available in license . txt file , in main folder
*
*/
2008-12-27 03:01:59 +02:00
class CTown ;
class CScriptCallback ;
class CCallback ;
2010-06-07 08:28:12 +03:00
class IGameCallback ;
2008-12-27 03:01:59 +02:00
class CLuaCallback ;
class CCPPObjectScript ;
class CCreatureSet ;
class CStack ;
class CGHeroInstance ;
class CGTownInstance ;
class CArmedInstance ;
2009-10-24 22:21:32 +03:00
class CGDwelling ;
2008-12-27 03:01:59 +02:00
class CGDefInfo ;
class CObjectScript ;
class CGObjectInstance ;
class CCreature ;
struct Mapa ;
struct StartInfo ;
struct SDL_Surface ;
class CMapHandler ;
class CPathfinder ;
struct SetObjectProperty ;
struct MetaString ;
2009-03-07 00:25:19 +02:00
struct CPack ;
2009-05-07 18:19:52 +03:00
class CSpell ;
2009-08-30 15:47:40 +03:00
struct TerrainTile ;
2010-02-07 17:06:14 +02:00
class CHeroClass ;
2010-05-08 21:56:38 +03:00
class CCampaign ;
2010-08-04 14:18:13 +03:00
class CCampaignState ;
2008-12-27 03:01:59 +02:00
namespace boost
{
class shared_mutex ;
}
2010-02-07 17:06:14 +02:00
struct DLL_EXPORT InfoAboutHero
{
2010-02-07 19:56:06 +02:00
private :
void assign ( const InfoAboutHero & iah ) ;
public :
2010-02-07 17:06:14 +02:00
struct DLL_EXPORT Details
{
std : : vector < int > primskills ;
int mana , luck , morale ;
} * details ;
char owner ;
const CHeroClass * hclass ;
std : : string name ;
int portrait ;
CCreatureSet army ; //numbers of creatures are exact numbers if detailed else they are quantity ids (0 - a few, 1 - several and so on)
InfoAboutHero ( ) ;
2010-02-07 19:56:06 +02:00
InfoAboutHero ( const InfoAboutHero & iah ) ;
InfoAboutHero & operator = ( const InfoAboutHero & iah ) ;
2010-02-07 17:06:14 +02:00
~ InfoAboutHero ( ) ;
void initFromHero ( const CGHeroInstance * h , bool detailed ) ;
} ;
2010-07-15 06:04:57 +03:00
// typedef si32 TResourceUnit;
// typedef std::vector<si32> TResourceVector;
// typedef std::set<si32> TResourceSet;
2010-02-07 17:06:14 +02:00
2010-02-01 19:51:33 +02:00
struct DLL_EXPORT SThievesGuildInfo
{
std : : vector < ui8 > playerColors ; //colors of players that are in-game
std : : vector < std : : list < ui8 > > numOfTowns , numOfHeroes , gold , woodOre , mercSulfCrystGems , obelisks , artifacts , army , income ; // [place] -> [colours of players]
2010-02-04 20:40:40 +02:00
std : : map < ui8 , InfoAboutHero > colorToBestHero ; //maps player's color to his best heros'
2010-02-01 19:51:33 +02:00
2010-02-06 15:49:14 +02:00
std : : map < ui8 , si8 > personality ; // color to personality // -1 - human, AI -> (00 - random, 01 - warrior, 02 - builder, 03 - explorer)
std : : map < ui8 , si32 > bestCreature ; // color to ID // id or -1 if not known
2010-02-07 17:06:14 +02:00
// template <typename Handler> void serialize(Handler &h, const int version)
// {
// h & playerColors & numOfTowns & numOfHeroes & gold & woodOre & mercSulfCrystGems & obelisks & artifacts & army & income;
// h & colorToBestHero & personality & bestCreature;
// }
2010-02-01 19:51:33 +02:00
} ;
2010-04-03 06:33:46 +03:00
struct DLL_EXPORT PlayerState : public CBonusSystemNode
2008-12-27 03:01:59 +02:00
{
public :
2010-01-29 22:52:45 +02:00
enum EStatus { INGAME , LOSER , WINNER } ;
2010-08-03 14:36:52 +03:00
ui8 color ;
2009-03-09 21:40:43 +02:00
ui8 human ; //true if human controlled player, false for AI
2008-12-27 03:01:59 +02:00
ui32 currentSelection ; //id of hero/town, 0xffffffff if none
2010-08-03 15:34:06 +03:00
ui8 team ;
//std::vector<std::vector<std::vector<ui8> > > * fogOfWarMap; //pointer to team's fog of war
2008-12-27 03:01:59 +02:00
std : : vector < si32 > resources ;
std : : vector < CGHeroInstance * > heroes ;
std : : vector < CGTownInstance * > towns ;
std : : vector < CGHeroInstance * > availableHeroes ; //heroes available in taverns
2009-10-24 22:21:32 +03:00
std : : vector < CGDwelling * > dwellings ; //used for town growth
2009-09-07 05:29:44 +03:00
2010-07-30 14:29:42 +03:00
ui8 enteredWinningCheatCode , enteredLosingCheatCode ; //if true, this player has entered cheat codes for loss / victory
2010-01-29 22:52:45 +02:00
ui8 status ; //0 - in game, 1 - loser, 2 - winner <- uses EStatus enum
ui8 daysWithoutCastle ;
2009-09-07 05:29:44 +03:00
PlayerState ( ) ;
2010-05-14 05:18:37 +03:00
//override
void getParents ( TCNodes & out , const CBonusSystemNode * root = NULL ) const ;
void getBonuses ( BonusList & out , const CSelector & selector , const CBonusSystemNode * root = NULL ) const ;
2009-09-07 05:29:44 +03:00
2008-12-27 03:01:59 +02:00
template < typename Handler > void serialize ( Handler & h , const int version )
{
2010-08-03 15:34:06 +03:00
h & color & human & currentSelection & team & resources & status ;
2010-10-24 14:23:43 +03:00
h & heroes & towns & availableHeroes & dwellings & bonuses & status & daysWithoutCastle ;
2010-07-30 14:29:42 +03:00
h & enteredLosingCheatCode & enteredWinningCheatCode ;
2010-05-02 21:20:26 +03:00
h & static_cast < CBonusSystemNode & > ( * this ) ;
2008-12-27 03:01:59 +02:00
}
} ;
2010-08-03 15:34:06 +03:00
struct DLL_EXPORT TeamState : public CBonusSystemNode
{
public :
2010-08-06 16:14:10 +03:00
ui8 id ; //position in gameState::teams
2010-08-03 15:34:06 +03:00
std : : set < ui8 > players ; // members of this team
std : : vector < std : : vector < std : : vector < ui8 > > > fogOfWarMap ; //true - visible, false - hidden
//TeamState();
template < typename Handler > void serialize ( Handler & h , const int version )
{
h & players & fogOfWarMap ;
h & static_cast < CBonusSystemNode & > ( * this ) ;
}
} ;
2009-02-09 16:50:32 +02:00
struct DLL_EXPORT CObstacleInstance
{
2009-08-19 13:59:42 +03:00
int uniqueID ;
int ID ; //ID of obstacle (defines type of it)
2009-02-09 16:50:32 +02:00
int pos ; //position on battlefield
template < typename Handler > void serialize ( Handler & h , const int version )
{
2009-08-19 13:59:42 +03:00
h & ID & pos & uniqueID ;
2009-02-09 16:50:32 +02:00
}
} ;
2009-08-26 17:09:55 +03:00
//only for use in BattleInfo
struct DLL_EXPORT SiegeInfo
{
2009-09-01 16:54:13 +03:00
ui8 wallState [ 8 ] ; //[0] - keep, [1] - bottom tower, [2] - bottom wall, [3] - below gate, [4] - over gate, [5] - upper wall, [6] - uppert tower, [7] - gate; 1 - intact, 2 - damaged, 3 - destroyed
2009-08-26 17:09:55 +03:00
template < typename Handler > void serialize ( Handler & h , const int version )
{
h & wallState ;
}
} ;
2010-05-02 21:20:26 +03:00
struct DLL_EXPORT BattleInfo : public CBonusSystemNode
2008-12-27 03:01:59 +02:00
{
2009-04-16 17:01:27 +03:00
ui8 side1 , side2 ; //side1 - attacker, side2 - defender
2008-12-27 03:01:59 +02:00
si32 round , activeStack ;
ui8 siege ; // = 0 ordinary battle = 1 a siege with a Fort = 2 a siege with a Citadel = 3 a siege with a Castle
2009-08-22 16:59:15 +03:00
si32 tid ; //used during town siege - id of attacked town; -1 if not town defence
2008-12-27 03:01:59 +02:00
int3 tile ; //for background and bonuses
2009-10-06 03:32:33 +03:00
CGHeroInstance * heroes [ 2 ] ;
2010-05-02 21:20:26 +03:00
CArmedInstance * belligerents [ 2 ] ; //may be same as heroes
2008-12-27 03:01:59 +02:00
std : : vector < CStack * > stacks ;
2009-02-09 16:50:32 +02:00
std : : vector < CObstacleInstance > obstacles ;
2009-05-12 06:35:51 +03:00
ui8 castSpells [ 2 ] ; //[0] - attacker, [1] - defender
2009-08-26 17:09:55 +03:00
SiegeInfo si ;
2008-12-27 03:01:59 +02:00
template < typename Handler > void serialize ( Handler & h , const int version )
{
2010-05-02 21:20:26 +03:00
h & side1 & side2 & round & activeStack & siege & tid & tile & stacks & belligerents & obstacles
2009-08-26 17:09:55 +03:00
& castSpells & si ;
2009-10-06 03:32:33 +03:00
h & heroes ;
2010-05-02 21:20:26 +03:00
h & static_cast < CBonusSystemNode & > ( * this ) ;
2008-12-27 03:01:59 +02:00
}
2010-05-02 21:20:26 +03:00
//////////////////////////////////////////////////////////////////////////
void getBonuses ( BonusList & out , const CSelector & selector , const CBonusSystemNode * root = NULL ) const ;
//////////////////////////////////////////////////////////////////////////
2009-09-07 05:29:44 +03:00
const CStack * getNextStack ( ) const ; //which stack will have turn after current one
2009-09-20 15:47:40 +03:00
void getStackQueue ( std : : vector < const CStack * > & out , int howMany , int turn = 0 , int lastMoved = - 1 ) const ; //returns stack in order of their movement action
2009-08-05 15:46:08 +03:00
CStack * getStack ( int stackID , bool onlyAlive = true ) ;
2009-09-02 17:10:19 +03:00
const CStack * getStack ( int stackID , bool onlyAlive = true ) const ;
2009-08-05 15:46:08 +03:00
CStack * getStackT ( int tileID , bool onlyAlive = true ) ;
2009-09-02 17:10:19 +03:00
const CStack * getStackT ( int tileID , bool onlyAlive = true ) const ;
void getAccessibilityMap ( bool * accessibility , bool twoHex , bool attackerOwned , bool addOccupiable , std : : set < int > & occupyable , bool flying , int stackToOmmit = - 1 ) const ; //send pointer to at least 187 allocated bytes
2009-08-04 18:38:26 +03:00
static bool isAccessible ( int hex , bool * accessibility , bool twoHex , bool attackerOwned , bool flying , bool lastPos ) ; //helper for makeBFS
2009-09-06 20:46:20 +03:00
void makeBFS ( int start , bool * accessibility , int * predecessor , int * dists , bool twoHex , bool attackerOwned , bool flying , bool fillPredecessors ) const ; //*accessibility must be prepared bool[187] array; last two pointers must point to the at least 187-elements int arrays - there is written result
2009-08-02 17:21:18 +03:00
std : : pair < std : : vector < int > , int > getPath ( int start , int dest , bool * accessibility , bool flyingCreature , bool twoHex , bool attackerOwned ) ; //returned value: pair<path, length>; length may be different than number of elements in path since flying vreatures jump between distant hexes
2009-09-02 17:10:19 +03:00
std : : vector < int > getAccessibility ( int stackID , bool addOccupiable ) const ; //returns vector of accessible tiles (taking into account the creature range)
2008-12-27 03:01:59 +02:00
2010-04-06 16:19:54 +03:00
bool isStackBlocked ( int ID ) ; //returns true if there is neighboring enemy stack
2008-12-27 03:01:59 +02:00
static signed char mutualPosition ( int hex1 , int hex2 ) ; //returns info about mutual position of given hexes (-1 - they're distant, 0 - left top, 1 - right top, 2 - right, 3 - right bottom, 4 - left bottom, 5 - left)
static std : : vector < int > neighbouringTiles ( int hex ) ;
2010-07-29 15:54:30 +03:00
static si8 getDistance ( int hex1 , int hex2 ) ; //returns distance between given hexes
2010-04-06 16:19:54 +03:00
ui32 calculateDmg ( const CStack * attacker , const CStack * defender , const CGHeroInstance * attackerHero , const CGHeroInstance * defendingHero , bool shooting , ui8 charge , bool lucky ) ; //charge - number of hexes travelled before attack (for champion's jousting)
std : : pair < ui32 , ui32 > calculateDmgRange ( const CStack * attacker , const CStack * defender , const CGHeroInstance * attackerHero , const CGHeroInstance * defendingHero , bool shooting , ui8 charge , bool lucky ) ; //charge - number of hexes travelled before attack (for champion's jousting); returns pair <min dmg, max dmg>
2009-09-24 16:23:52 +03:00
void calculateCasualties ( std : : map < ui32 , si32 > * casualties ) const ; //casualties are array of maps size 2 (attacker, defeneder), maps are (crid => amount)
2010-02-23 17:39:31 +02:00
std : : set < CStack * > getAttackedCreatures ( const CSpell * s , int skillLevel , ui8 attackerOwner , int destinationTile ) ; //calculates stack affected by given spell
2010-05-19 21:06:16 +03:00
static int calculateSpellDuration ( const CSpell * spell , const CGHeroInstance * caster , int usedSpellPower ) ;
2010-05-02 21:20:26 +03:00
CStack * generateNewStack ( const CStackInstance & base , int stackID , bool attackerOwned , int slot , int /*TerrainTile::EterrainType*/ terrain , int position ) const ; //helper for CGameHandler::setupBattle and spells addign new stacks to the battlefield
2009-09-02 17:10:19 +03:00
ui32 getSpellCost ( const CSpell * sp , const CGHeroInstance * caster ) const ; //returns cost of given spell
int hexToWallPart ( int hex ) const ; //returns part of destructible wall / gate / keep under given hex or -1 if not found
2010-04-06 16:19:54 +03:00
int lineToWallHex ( int line ) const ; //returns hex with wall in given line
2009-09-02 17:10:19 +03:00
std : : pair < const CStack * , int > getNearestStack ( const CStack * closest , boost : : logic : : tribool attackerOwned ) const ; //if attackerOwned is indetermnate, returened stack is of any owner; hex is the number of hex we should be looking from; returns (nerarest creature, predecessorHex)
2010-08-29 21:29:00 +03:00
ui32 calculateSpellBonus ( ui32 baseDamage , const CSpell * sp , const CGHeroInstance * caster , const CStack * affectedCreature ) const ;
2010-02-24 20:11:08 +02:00
ui32 calculateSpellDmg ( const CSpell * sp , const CGHeroInstance * caster , const CStack * affectedCreature , int spellSchoolLevel , int usedSpellPower ) const ; //calculates damage inflicted by spell
2010-08-29 21:29:00 +03:00
ui32 calculateHealedHP ( const CGHeroInstance * caster , const CSpell * spell , const CStack * stack ) const ;
2010-04-06 16:19:54 +03:00
si8 hasDistancePenalty ( int stackID , int destHex ) ; //determines if given stack has distance penalty shooting given pos
2010-05-07 17:05:48 +03:00
si8 sameSideOfWall ( int pos1 , int pos2 ) ; //determines if given positions are on the same side of wall
2010-04-06 16:19:54 +03:00
si8 hasWallPenalty ( int stackID , int destHex ) ; //determines if given stack has wall penalty shooting given pos
2010-05-07 17:05:48 +03:00
si8 canTeleportTo ( int stackID , int destHex , int telportLevel ) ; //determines if given stack can teleport to given place
2008-12-27 03:01:59 +02:00
} ;
2010-05-02 21:20:26 +03:00
class DLL_EXPORT CStack : public CStackInstance
2008-12-27 03:01:59 +02:00
{
public :
ui32 ID ; //unique ID of stack
2010-05-02 21:20:26 +03:00
ui32 baseAmount ;
2008-12-27 03:01:59 +02:00
ui32 firstHPleft ; //HP of first creature in stack
ui8 owner , slot ; //owner - player colour (255 for neutrals), slot - position in garrison (may be 255 for neutrals/called creatures)
ui8 attackerOwned ; //if true, this stack is owned by attakcer (this one from left hand side of battle)
2009-09-04 17:11:42 +03:00
si16 position ; //position on battlefield; -2 - keep, -3 - lower tower, -4 - upper tower
2008-12-27 03:01:59 +02:00
ui8 counterAttacks ; //how many counter attacks can be performed more in this turn (by default set at the beginning of the round to 1)
si16 shots ; //how many shots left
std : : set < ECombatInfo > state ;
2010-05-02 21:20:26 +03:00
//overrides
const CCreature * getCreature ( ) const { return type ; }
2009-05-08 19:55:04 +03:00
2010-05-02 21:20:26 +03:00
CStack ( const CStackInstance * base , int O , int I , bool AO , int S ) ; //c-tor
CStack ( ) : ID ( - 1 ) , baseAmount ( - 1 ) , firstHPleft ( - 1 ) , owner ( 255 ) , slot ( 255 ) , attackerOwned ( true ) , position ( - 1 ) , counterAttacks ( 1 ) { } //c-tor
2010-08-30 21:06:17 +03:00
const Bonus * getEffect ( ui16 id , int turn = 0 ) const ; //effect id (SP)
2009-04-21 20:32:43 +03:00
ui8 howManyEffectsSet ( ui16 id ) const ; //returns amount of effects with given id set for this stack
2009-09-20 15:47:40 +03:00
bool willMove ( int turn = 0 ) const ; //if stack has remaining move this turn
bool moved ( int turn = 0 ) const ; //if stack was already moved this turn
bool canMove ( int turn = 0 ) const ; //if stack can move
ui32 Speed ( int turn = 0 ) const ; //get speed of creature with all modificators
2010-08-31 13:22:21 +03:00
BonusList getSpellBonuses ( ) const ;
2010-08-30 21:06:17 +03:00
void stackEffectToFeature ( BonusList & sf , const Bonus & sse ) ;
2010-08-31 13:22:21 +03:00
std : : vector < si32 > activeSpells ( ) const ; //returns vector of active spell IDs sorted by time of cast
2010-08-30 21:06:17 +03:00
static inline Bonus featureGenerator ( Bonus : : BonusType type , si16 subtype , si32 value , ui16 turnsRemain , si32 additionalInfo = 0 , si32 limit = Bonus : : NO_LIMIT )
{
Bonus hb ( makeFeature ( type , Bonus : : N_TURNS , subtype , value , Bonus : : SPELL_EFFECT , turnsRemain , additionalInfo ) ) ;
hb . effectRange = limit ;
2010-08-30 22:46:38 +03:00
hb . source = Bonus : : CASTED_SPELL ; //right?
2010-08-30 21:06:17 +03:00
return hb ;
}
static inline Bonus featureGeneratorVT ( Bonus : : BonusType type , si16 subtype , si32 value , ui16 turnsRemain , ui8 valType )
{
Bonus ret ( makeFeature ( type , Bonus : : N_TURNS , subtype , value , Bonus : : SPELL_EFFECT , turnsRemain ) ) ;
ret . valType = valType ;
2010-08-30 22:46:38 +03:00
ret . source = Bonus : : CASTED_SPELL ; //right?
2010-08-30 21:06:17 +03:00
return ret ;
}
2010-05-02 21:20:26 +03:00
bool doubleWide ( ) const ;
2010-07-28 15:31:34 +03:00
int occupiedHex ( ) const ; //returns number of occupied hex (not the position) if stack is double wide; otherwise -1
2010-05-02 21:20:26 +03:00
2008-12-27 03:01:59 +02:00
template < typename Handler > void serialize ( Handler & h , const int version )
{
2010-05-02 21:20:26 +03:00
h & static_cast < CStackInstance & > ( * this ) ;
h & ID & baseAmount & firstHPleft & owner & slot & attackerOwned & position & state & counterAttacks
& shots ;
2008-12-27 03:01:59 +02:00
}
2009-05-01 16:42:41 +03:00
bool alive ( ) const //determines if stack is alive
2008-12-27 03:01:59 +02:00
{
return vstd : : contains ( state , ALIVE ) ;
}
} ;
2009-09-07 05:29:44 +03:00
class DLL_EXPORT CMP_stack
{
int phase ; //rules of which phase will be used
2009-09-20 15:47:40 +03:00
int turn ;
2009-09-07 05:29:44 +03:00
public :
bool operator ( ) ( const CStack * a , const CStack * b ) ;
2009-09-20 15:47:40 +03:00
CMP_stack ( int Phase = 1 , int Turn = 0 ) ;
2009-09-07 05:29:44 +03:00
} ;
2008-12-27 03:01:59 +02:00
struct UpgradeInfo
{
int oldID ; //creature to be upgraded
std : : vector < int > newID ; //possible upgrades
std : : vector < std : : set < std : : pair < int , int > > > cost ; // cost[upgrade_serial] -> set of pairs<resource_ID,resource_amount>
UpgradeInfo ( ) { oldID = - 1 ; } ;
} ;
2009-03-19 21:04:46 +02:00
struct CPathNode
{
2009-10-16 05:09:58 +03:00
bool accessible ; //true if a hero can be on this node
2009-03-19 21:04:46 +02:00
int dist ; //distance from the first node of searching; -1 is infinity
CPathNode * theNodeBefore ;
int3 coord ; //coordiantes
bool visited ;
} ;
2009-08-28 12:03:58 +03:00
struct CGPathNode
{
2009-12-20 19:14:14 +02:00
enum
{
ACCESSIBLE = 1 , //tile can be entered and passed
VISITABLE , //tile can be entered as the last tile in path
BLOCKVIS , //visitable from neighbouring tile but not passable
2010-05-15 18:00:19 +03:00
BLOCKED , //tile can't be entered nor visited
FLYABLE //if hero flies, he can pass this tile
2009-12-20 19:14:14 +02:00
} ;
2009-08-28 12:03:58 +03:00
ui8 accessible ; //the enum above
2009-08-30 15:47:40 +03:00
ui8 land ;
2009-08-28 12:03:58 +03:00
ui8 turns ;
ui32 moveRemains ;
2009-08-30 15:47:40 +03:00
CGPathNode * theNodeBefore ;
int3 coord ; //coordinates
2009-08-28 12:03:58 +03:00
CGPathNode ( ) ;
} ;
2009-03-19 21:04:46 +02:00
struct DLL_EXPORT CPath
{
std : : vector < CPathNode > nodes ; //just get node by node
int3 startPos ( ) const ; // start point
int3 endPos ( ) const ; //destination point
void convert ( ui8 mode ) ; //mode=0 -> from 'manifest' to 'object'
2009-03-19 16:17:19 +02:00
} ;
2009-08-30 15:47:40 +03:00
struct DLL_EXPORT CGPath
{
std : : vector < CGPathNode > nodes ; //just get node by node
int3 startPos ( ) const ; // start point
int3 endPos ( ) const ; //destination point
void convert ( ui8 mode ) ; //mode=0 -> from 'manifest' to 'object'
} ;
struct DLL_EXPORT CPathsInfo
2009-08-28 12:03:58 +03:00
{
2009-09-07 05:29:44 +03:00
const CGHeroInstance * hero ;
int3 hpos ;
2009-08-28 12:03:58 +03:00
int3 sizes ;
CGPathNode * * * nodes ; //[w][h][level]
2009-08-30 15:47:40 +03:00
bool getPath ( const int3 & dst , CGPath & out ) ;
CPathsInfo ( const int3 & Sizes ) ;
2009-08-28 12:03:58 +03:00
~ CPathsInfo ( ) ;
} ;
2008-12-27 03:01:59 +02:00
class DLL_EXPORT CGameState
{
2009-03-07 00:11:17 +02:00
public :
2008-12-27 03:01:59 +02:00
StartInfo * scenarioOps ;
2010-05-08 21:56:38 +03:00
CCampaignState * campaign ;
2008-12-27 03:01:59 +02:00
ui32 seed ;
ui8 currentPlayer ; //ID of player currently having turn
BattleInfo * curB ; //current battle
ui32 day ; //total number of days in game
Mapa * map ;
2010-01-29 22:52:45 +02:00
std : : map < ui8 , PlayerState > players ; //ID <-> player state
2010-08-03 15:34:06 +03:00
std : : map < ui8 , TeamState > teams ; //ID <-> team state
2008-12-27 03:01:59 +02:00
std : : map < int , CGDefInfo * > villages , forts , capitols ; //def-info for town graphics
2010-05-02 21:20:26 +03:00
CBonusSystemNode globalEffects ;
2008-12-27 03:01:59 +02:00
struct DLL_EXPORT HeroesPool
{
std : : map < ui32 , CGHeroInstance * > heroesPool ; //[subID] - heroes available to buy; NULL if not available
2009-11-15 16:06:25 +02:00
std : : map < ui32 , ui8 > pavailable ; // [subid] -> which players can recruit hero (binary flags)
2008-12-27 03:01:59 +02:00
2010-07-08 08:52:11 +03:00
CGHeroInstance * pickHeroFor ( bool native , int player , const CTown * town , std : : map < ui32 , CGHeroInstance * > & available , const CHeroClass * bannedClass = NULL ) const ;
2009-01-06 20:42:20 +02:00
template < typename Handler > void serialize ( Handler & h , const int version )
{
h & heroesPool & pavailable ;
}
2008-12-27 03:01:59 +02:00
} hpool ; //we have here all heroes available on this map that are not hired
boost : : shared_mutex * mx ;
2010-02-10 04:56:00 +02:00
PlayerState * getPlayer ( ui8 color , bool verbose = true ) ;
2010-08-03 15:34:06 +03:00
TeamState * getTeam ( ui8 teamID ) ; //get team by team ID
TeamState * getPlayerTeam ( ui8 color ) ; // get team by player color
2010-02-10 04:56:00 +02:00
const PlayerState * getPlayer ( ui8 color , bool verbose = true ) const ;
2010-08-03 15:34:06 +03:00
const TeamState * getTeam ( ui8 teamID ) const ;
const TeamState * getPlayerTeam ( ui8 color ) const ;
2010-05-08 21:56:38 +03:00
void init ( StartInfo * si , ui32 checksum , int Seed ) ;
2008-12-27 03:01:59 +02:00
void loadTownDInfos ( ) ;
void randomizeObject ( CGObjectInstance * cur ) ;
2009-09-28 17:21:48 +03:00
std : : pair < int , int > pickObject ( CGObjectInstance * obj ) ; //chooses type of object to be randomized, returns <type, subtype>
2008-12-27 03:01:59 +02:00
int pickHero ( int owner ) ;
2009-03-07 00:25:19 +02:00
void apply ( CPack * pack ) ;
2008-12-27 03:01:59 +02:00
CGHeroInstance * getHero ( int objid ) ;
CGTownInstance * getTown ( int objid ) ;
2010-01-29 22:52:45 +02:00
const CGHeroInstance * getHero ( int objid ) const ;
const CGTownInstance * getTown ( int objid ) const ;
2009-08-16 16:44:17 +03:00
bool battleCanFlee ( int player ) ; //returns true if player can flee from the battle
2009-08-05 15:46:08 +03:00
int battleGetStack ( int pos , bool onlyAlive ) ; //returns ID of stack at given tile
2009-02-09 16:50:32 +02:00
int battleGetBattlefieldType ( int3 tile = int3 ( ) ) ; // 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
2009-09-05 17:10:26 +03:00
const CGHeroInstance * battleGetOwner ( int stackID ) ; //returns hero that owns given stack; NULL if none
2009-05-10 16:00:15 +03:00
si8 battleMaxSpellLevel ( ) ; //calculates maximum spell level possible to be cast on battlefield - takes into account artifacts of both heroes; if no effects are set, SPELL_LEVELS is returned
2009-09-04 17:11:42 +03:00
bool battleCanShoot ( int ID , int dest ) ; //determines if stack with given ID shoot at the selected destination
2010-07-15 06:04:57 +03:00
UpgradeInfo getUpgradeInfo ( const CStackInstance & stack ) ;
2010-08-13 13:46:08 +03:00
int getPlayerRelations ( ui8 color1 , ui8 color2 ) ; // 0 = enemy, 1 = ally, 2 = same player
2010-05-18 10:01:54 +03:00
//float getMarketEfficiency(int player, int mode=0);
2009-12-29 15:40:16 +02:00
std : : set < int > getBuildingRequiments ( const CGTownInstance * t , int ID ) ;
2009-02-20 17:44:49 +02:00
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
2009-08-30 15:47:40 +03:00
bool checkForVisitableDir ( const int3 & src , const int3 & dst ) const ; //check if src tile is visitable from dst tile
bool checkForVisitableDir ( const int3 & src , const TerrainTile * pom , const int3 & dst ) const ; //check if src tile is visitable from dst tile
2009-06-11 20:21:06 +03:00
bool getPath ( int3 src , int3 dest , const CGHeroInstance * hero , CPath & ret ) ; //calculates path between src and dest; returns pointer to newly allocated CPath or NULL if path does not exists
2009-08-30 15:47:40 +03:00
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; returns pointer to newly allocated CPath or NULL if path does not exists
2010-05-06 15:13:31 +03:00
int3 guardingCreaturePosition ( int3 pos ) const ;
2010-01-29 22:52:45 +02:00
int victoryCheck ( ui8 player ) const ; //checks if given player is winner; -1 if std victory, 1 if special victory, 0 else
int lossCheck ( ui8 player ) const ; //checks if given player is loser; -1 if std loss, 1 if special, 0 else
ui8 checkForStandardWin ( ) const ; //returns color of player that accomplished standard victory conditions or 255 if no winner
bool checkForStandardLoss ( ui8 player ) const ; //checks if given player lost the game
2010-02-01 19:51:33 +02:00
void obtainPlayersStats ( SThievesGuildInfo & tgi , int level ) ; //fills tgi with info about other players that is available at given level of thieves' guild
2010-07-08 08:52:11 +03:00
std : : map < ui32 , CGHeroInstance * > unusedHeroesFromPool ( ) ; //heroes pool without heroes that are available in taverns
2009-03-07 00:11:17 +02:00
2009-07-30 15:49:45 +03:00
bool isVisible ( int3 pos , int player ) ;
bool isVisible ( const CGObjectInstance * obj , int player ) ;
2009-05-07 20:20:41 +03:00
CGameState ( ) ; //c-tor
~ CGameState ( ) ; //d-tor
2010-07-10 05:15:49 +03:00
void getNeighbours ( const TerrainTile & srct , int3 tile , std : : vector < int3 > & vec , const boost : : logic : : tribool & onLand , bool limitCoastSailing ) ;
2009-08-30 15:47:40 +03:00
int getMovementCost ( const CGHeroInstance * h , const int3 & src , const int3 & dest , int remainingMovePoints = - 1 , bool checkLast = true ) ;
2008-12-27 03:01:59 +02:00
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
template < typename Handler > void serialize ( Handler & h , const int version )
{
2010-08-12 18:54:25 +03:00
h & scenarioOps & seed & currentPlayer & day & map & players & teams & hpool & globalEffects & campaign ;
2010-08-01 17:04:48 +03:00
h & villages & forts & capitols ;
2008-12-27 03:01:59 +02:00
if ( ! h . saving )
{
loadTownDInfos ( ) ;
}
}
friend class CCallback ;
friend class CLuaCallback ;
friend class CClient ;
friend void initGameState ( Mapa * map , CGameInfo * cgi ) ;
friend class IGameCallback ;
friend class CMapHandler ;
friend class CGameHandler ;
} ;
# endif // __CGAMESTATE_H__
2010-02-23 17:39:31 +02:00