1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-14 02:33:51 +02:00
vcmi/AI/Nullkiller/Pathfinding/Rules/AIPreviousNodeRule.cpp

52 lines
1.3 KiB
C++
Raw Normal View History

2021-05-15 18:22:44 +02:00
/*
* AIPreviousNodeRule.cpp, 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
*
*/
#include "StdInc.h"
#include "AIPreviousNodeRule.h"
2022-09-26 20:01:07 +02:00
namespace NKAI
{
2021-05-15 18:22:44 +02:00
namespace AIPathfinding
{
AIPreviousNodeRule::AIPreviousNodeRule(std::shared_ptr<AINodeStorage> nodeStorage)
: nodeStorage(nodeStorage)
{
}
void AIPreviousNodeRule::process(
const PathNodeInfo & source,
CDestinationNodeInfo & destination,
const PathfinderConfig * pathfinderConfig,
CPathfinderHelper * pathfinderHelper) const
{
if(source.node->action == CGPathNode::ENodeAction::BLOCKING_VISIT
|| source.node->action == CGPathNode::ENodeAction::VISIT)
2021-05-15 18:22:44 +02:00
{
if(source.nodeObject
&& isObjectPassable(source.nodeObject, pathfinderHelper->hero->tempOwner, source.objectRelations))
{
return;
}
2021-05-15 18:22:44 +02:00
// we can not directly bypass objects, we need to interact with them first
destination.node->theNodeBefore = source.node;
2022-09-26 20:01:07 +02:00
#if NKAI_PATHFINDER_TRACE_LEVEL >= 1
2021-05-15 18:22:44 +02:00
logAi->trace(
"Link src node %s to destination node %s while bypassing visitable obj",
source.coord.toString(),
destination.coord.toString());
#endif
return;
}
}
}
2022-09-26 20:01:07 +02:00
}