#region Copyright & License Information /* * Copyright 2007-2015 The OpenRA Developers (see AUTHORS) * This file is part of OpenRA, which is free software. It is made * available to you under the terms of the GNU General Public License * as published by the Free Software Foundation. For more information, * see COPYING. */ #endregion using System; using System.Collections.Generic; namespace OpenRA.Mods.Common.Pathfinder { /// /// Describes the three states that a node in the graph can have. /// Based on A* algorithm specification /// public enum CellStatus { Unvisited, Open, Closed } /// /// Stores information about nodes in the pathfinding graph /// public struct CellInfo { /// /// The cost to move from the start up to this node /// public readonly int CostSoFar; /// /// The estimation of how far is the node from our goal /// public readonly int EstimatedTotal; /// /// The previous node of this one that follows the shortest path /// public readonly CPos PreviousPos; /// /// The status of this node /// public readonly CellStatus Status; public CellInfo(int costSoFar, int estimatedTotal, CPos previousPos, CellStatus status) { CostSoFar = costSoFar; PreviousPos = previousPos; Status = status; EstimatedTotal = estimatedTotal; } } }