/* * 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 TDistances; typedef std::array TPredecessors; enum { INFINITE_DIST = 1000000 }; struct DLL_LINKAGE Parameters { const CStack * stack; //stack for which calculation is mage => not required (kept for debugging mostly), following variables are enough bool attackerOwned; bool doubleWide; bool flying; std::vector 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(); Parameters(const CStack * Stack); }; Parameters params; AccessibilityInfo accessibility; TDistances distances; TPredecessors predecessors; ReachabilityInfo(); bool isReachable(BattleHex hex) const; };