#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.Collections.Generic; using OpenRA.Mods.Common.Traits; using OpenRA.Support; using OpenRA.Traits; namespace OpenRA.Mods.Common.Pathfinder { /// /// A decorator used to cache FindUnitPath and FindUnitPathToRange (Decorator design pattern) /// public class PathFinderUnitPathCacheDecorator : IPathFinder { readonly IPathFinder pathFinder; readonly ICacheStorage> cacheStorage; public PathFinderUnitPathCacheDecorator(IPathFinder pathFinder, ICacheStorage> cacheStorage) { this.pathFinder = pathFinder; this.cacheStorage = cacheStorage; } public List FindUnitPath(CPos source, CPos target, Actor self) { using (new PerfSample("Pathfinder")) { var key = "FindUnitPath" + self.ActorID + source.X + source.Y + target.X + target.Y; var cachedPath = cacheStorage.Retrieve(key); if (cachedPath != null) return cachedPath; var pb = pathFinder.FindUnitPath(source, target, self); cacheStorage.Store(key, pb); return pb; } } public List FindUnitPathToRange(CPos source, SubCell srcSub, WPos target, WDist range, Actor self) { using (new PerfSample("Pathfinder")) { var key = "FindUnitPathToRange" + self.ActorID + source.X + source.Y + target.X + target.Y; var cachedPath = cacheStorage.Retrieve(key); if (cachedPath != null) return cachedPath; var pb = pathFinder.FindUnitPathToRange(source, srcSub, target, range, self); cacheStorage.Store(key, pb); return pb; } } public List FindPath(IPathSearch search) { using (new PerfSample("Pathfinder")) return pathFinder.FindPath(search); } public List FindBidiPath(IPathSearch fromSrc, IPathSearch fromDest) { using (new PerfSample("Pathfinder")) return pathFinder.FindBidiPath(fromSrc, fromDest); } } }