From 39c2c5f25f86ad205414b3ca68cd6174d4373c17 Mon Sep 17 00:00:00 2001 From: NuclearW Date: Tue, 29 May 2012 21:02:36 -0400 Subject: [PATCH] Handle EOFException in Chunklets by returning a new empty ChunkletStore and printing an error. --- .../gmail/nossr50/util/blockmeta/HashChunkletManager.java | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/src/main/java/com/gmail/nossr50/util/blockmeta/HashChunkletManager.java b/src/main/java/com/gmail/nossr50/util/blockmeta/HashChunkletManager.java index 7e8e696df..721dd013c 100644 --- a/src/main/java/com/gmail/nossr50/util/blockmeta/HashChunkletManager.java +++ b/src/main/java/com/gmail/nossr50/util/blockmeta/HashChunkletManager.java @@ -1,5 +1,6 @@ package com.gmail.nossr50.util.blockmeta; +import java.io.EOFException; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; @@ -12,6 +13,8 @@ import org.bukkit.Bukkit; import org.bukkit.World; import org.bukkit.block.Block; +import com.gmail.nossr50.mcMMO; + public class HashChunkletManager implements ChunkletManager { private HashMap store = new HashMap(); @@ -211,6 +214,11 @@ public class HashChunkletManager implements ChunkletManager { objIn.close(); fileIn.close(); } catch (IOException ex) { + if (ex instanceof EOFException) { + // EOF should only happen on Chunklets that somehow have been corrupted. + mcMMO.p.getLogger().severe("Chunklet data at " + location.toString() + " could not be read, data in this are will be lost."); + return ChunkletStoreFactory.getChunkletStore(); + } ex.printStackTrace(); } catch (ClassNotFoundException ex) { ex.printStackTrace();