Make GetRegion more readable / Less convoluted and complicated due to multithreading.
This commit is contained in:
parent
e53d1086cc
commit
371989b34d
@ -23,17 +23,13 @@ namespace Pathfinding
|
||||
|
||||
public Region? GetRegion(ulong id)
|
||||
{
|
||||
|
||||
if(_regions.TryGetValue(id, out Region? retRegion))
|
||||
return retRegion;
|
||||
|
||||
Region? loadedRegion = RegionFromId(id);
|
||||
|
||||
if(_regions.TryGetValue(id, out Region? retRegion2)) //Prevent other thread from changing collection
|
||||
return retRegion2;
|
||||
if(loadedRegion is not null)
|
||||
_regions.TryAdd(loadedRegion.regionHash, loadedRegion);
|
||||
|
||||
if (!_regions.ContainsKey(id))
|
||||
{
|
||||
Region? loadedRegion = RegionFromId(id);
|
||||
if (loadedRegion is not null)
|
||||
_regions.TryAdd(loadedRegion.regionHash, loadedRegion);
|
||||
return _regions[id]; //return from _regions instead of loadedRegion for multithreading/pointers
|
||||
}
|
||||
return _regions[id];
|
||||
}
|
||||
|
||||
@ -46,7 +42,7 @@ namespace Pathfinding
|
||||
{
|
||||
if (!File.Exists(filePath))
|
||||
{
|
||||
throw new FileNotFoundException(filePath);
|
||||
//throw new FileNotFoundException(filePath);
|
||||
return null;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user