From 7c4ef996d26f46bbb1ce421897e938cf58c232fd Mon Sep 17 00:00:00 2001 From: Justin Aquadro Date: Sun, 14 Aug 2011 19:32:46 +0000 Subject: [PATCH] Fixed cache bug that would lose dirty chunks. --- .../SubstrateCS/Source/Core/ChunkCache.cs | 38 +++++-------------- 1 file changed, 9 insertions(+), 29 deletions(-) diff --git a/Substrate/SubstrateCS/Source/Core/ChunkCache.cs b/Substrate/SubstrateCS/Source/Core/ChunkCache.cs index 3afc72f..807e3b7 100644 --- a/Substrate/SubstrateCS/Source/Core/ChunkCache.cs +++ b/Substrate/SubstrateCS/Source/Core/ChunkCache.cs @@ -22,6 +22,8 @@ namespace Substrate.Core { ChunkKey key = new ChunkKey(chunk.X, chunk.Z); + _dirty.Remove(key); + ChunkRef c; if (!_cache.TryGetValue(key, out c)) { _cache[key] = chunk; @@ -40,11 +42,15 @@ namespace Substrate.Core public ChunkRef Fetch (ChunkKey key) { ChunkRef c; - if (!_cache.TryGetValue(key, out c)) { - return null; + if (_dirty.TryGetValue(key, out c)) { + return c; } - return c; + if (_cache.TryGetValue(key, out c)) { + return c; + } + + return null; } public IEnumerator GetDirtyEnumerator () @@ -74,32 +80,6 @@ namespace Substrate.Core } } - /*public bool MarkChunkDirty (ChunkRef chunk) - { - int cx = chunk.X; - int cz = chunk.Z; - - ChunkKey k = new ChunkKey(cx, cz); - if (!_dirty.ContainsKey(k)) { - _dirty.Add(k, chunk); - return true; - } - return false; - } - - public bool MarkChunkClean (ChunkRef chunk) - { - int cx = chunk.X; - int cz = chunk.Z; - - ChunkKey k = new ChunkKey(cx, cz); - if (_dirty.ContainsKey(k)) { - _dirty.Remove(k); - return true; - } - return false; - }*/ - #endregion } }