From 854fc05c5b3a3d1d1ed40a0755eac401043b92b4 Mon Sep 17 00:00:00 2001 From: snowleo Date: Wed, 7 Dec 2011 00:08:14 +0100 Subject: [PATCH] Fix serious bug in Dev2.7.137 - Dev2.7.144: if spawn.yml is not present, the server will run into a deadlock. --- .../AbstractDelayedYamlFileReader.java | 43 +++++++++---------- 1 file changed, 21 insertions(+), 22 deletions(-) diff --git a/Essentials/src/com/earth2me/essentials/storage/AbstractDelayedYamlFileReader.java b/Essentials/src/com/earth2me/essentials/storage/AbstractDelayedYamlFileReader.java index 1f2887d88..43bfc358d 100644 --- a/Essentials/src/com/earth2me/essentials/storage/AbstractDelayedYamlFileReader.java +++ b/Essentials/src/com/earth2me/essentials/storage/AbstractDelayedYamlFileReader.java @@ -6,6 +6,7 @@ import java.io.FileNotFoundException; import java.io.FileReader; import java.io.IOException; import java.util.logging.Level; +import java.util.logging.Logger; import org.bukkit.Bukkit; import org.bukkit.plugin.Plugin; import org.yaml.snakeyaml.error.YAMLException; @@ -30,39 +31,37 @@ public abstract class AbstractDelayedYamlFileReader imp @Override public void run() { - FileReader reader = null; + onStart(); try { - onStart(); + final FileReader reader = new FileReader(file); try { - reader = new FileReader(file); - T object = new YamlStorageReader(reader, plugin).load(clazz); + final T object = new YamlStorageReader(reader, plugin).load(clazz); onSuccess(object); } - catch (ObjectLoadException ex) + finally { - onException(); - Bukkit.getLogger().log(Level.SEVERE, "File broken: " + file.toString(), ex.getCause()); - } - } - catch (FileNotFoundException ex) - { - Bukkit.getLogger().log(Level.SEVERE, file.toString(), ex); - } - finally - { - try - { - if (reader != null) + try { reader.close(); } + catch (IOException ex) + { + Bukkit.getLogger().log(Level.SEVERE, "File can't be closed: " + file.toString(), ex); + } } - catch (IOException ex) - { - Bukkit.getLogger().log(Level.SEVERE, ex.getMessage(), ex); - } + + } + catch (FileNotFoundException ex) + { + onException(); + Bukkit.getLogger().log(Level.WARNING, "File not found: " + file.toString()); + } + catch (ObjectLoadException ex) + { + onException(); + Bukkit.getLogger().log(Level.SEVERE, "File broken: " + file.toString(), ex.getCause()); } }