2017-06-24 15:51:07 +02:00
/*
* ReachabilityInfo . 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
*
*/
# pragma once
# include "BattleHex.h"
# include "CBattleInfoEssentials.h"
# include "AccessibilityInfo.h"
class CStack ;
// Reachability info is result of BFS calculation. It's dependent on stack (it's owner, whether it's flying),
// startPosition and perpective.
struct DLL_LINKAGE ReachabilityInfo
{
typedef std : : array < int , GameConstants : : BFIELD_SIZE > TDistances ;
typedef std : : array < BattleHex , GameConstants : : BFIELD_SIZE > TPredecessors ;
2017-06-26 18:50:35 +02:00
enum { INFINITE_DIST = 1000000 } ;
2017-06-24 15:51:07 +02:00
struct DLL_LINKAGE Parameters
{
2017-06-26 18:50:35 +02:00
const CStack * stack ; //stack for which calculation is mage => not required (kept for debugging mostly), following variables are enough
2017-06-24 15:51:07 +02:00
bool attackerOwned ;
bool doubleWide ;
bool flying ;
std : : vector < BattleHex > knownAccessible ; //hexes that will be treated as accessible, even if they're occupied by stack (by default - tiles occupied by stack we do reachability for, so it doesn't block itself)
BattleHex startPosition ; //assumed position of stack
BattlePerspective : : BattlePerspective perspective ; //some obstacles (eg. quicksands) may be invisible for some side
Parameters ( ) ;
2017-06-26 18:50:35 +02:00
Parameters ( const CStack * Stack ) ;
2017-06-24 15:51:07 +02:00
} ;
Parameters params ;
AccessibilityInfo accessibility ;
TDistances distances ;
TPredecessors predecessors ;
ReachabilityInfo ( ) ;
bool isReachable ( BattleHex hex ) const ;
} ;