From 12d17309244463f830ebd0365edc7cf80c16e9a0 Mon Sep 17 00:00:00 2001 From: Dmck2b Date: Fri, 13 Jun 2014 14:48:36 +0100 Subject: [PATCH] Make JSON errors more user friendly and less crash prone --- ...errors-more-friendly-and-less-crashy.patch | 65 +++++++++++++++++++ 1 file changed, 65 insertions(+) create mode 100644 CraftBukkit-Patches/0024-Make-JSON-errors-more-friendly-and-less-crashy.patch diff --git a/CraftBukkit-Patches/0024-Make-JSON-errors-more-friendly-and-less-crashy.patch b/CraftBukkit-Patches/0024-Make-JSON-errors-more-friendly-and-less-crashy.patch new file mode 100644 index 0000000000..09ae2aea5f --- /dev/null +++ b/CraftBukkit-Patches/0024-Make-JSON-errors-more-friendly-and-less-crashy.patch @@ -0,0 +1,65 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: Suddenly +Date: Mon, 16 Jun 2014 14:44:21 +0100 +Subject: [PATCH] Make JSON errors more friendly and less crashy + + +diff --git a/src/main/java/net/minecraft/server/JsonList.java b/src/main/java/net/minecraft/server/JsonList.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/net/minecraft/server/JsonList.java ++++ b/src/main/java/net/minecraft/server/JsonList.java +@@ -0,0 +0,0 @@ import java.util.ArrayList; + import java.util.Collection; + import java.util.Iterator; + import java.util.Map; ++import java.io.FileNotFoundException; // PaperSpigot ++import java.util.logging.Level; // PaperSpigot + + import net.minecraft.util.com.google.common.base.Charsets; + import net.minecraft.util.com.google.common.collect.Lists; +@@ -0,0 +0,0 @@ import net.minecraft.util.com.google.gson.JsonObject; + import net.minecraft.util.org.apache.commons.io.IOUtils; + import org.apache.logging.log4j.LogManager; + import org.apache.logging.log4j.Logger; ++import net.minecraft.util.com.google.gson.JsonSyntaxException; // PaperSpigot + + public class JsonList { + +@@ -0,0 +0,0 @@ public class JsonList { + try { + bufferedreader = Files.newReader(this.c, Charsets.UTF_8); + collection = (Collection) this.b.fromJson(bufferedreader, f); ++ } catch (FileNotFoundException e) { // PaperSpigot Start ++ org.bukkit.Bukkit.getLogger().log(Level.WARNING, "Unable to find file {0}, creating new {0}.", this.c); ++ } catch (JsonSyntaxException jsonSyntaxEception) { ++ org.bukkit.Bukkit.getLogger().log(Level.WARNING, "Unable to read file {0}, backing up {0} at {0}.backup and creating new {0}.", this.c); ++ File backup = new File(this.c + ".backup"); ++ this.c.renameTo(backup); ++ this.c.delete(); // PaperSpigot End + } finally { + IOUtils.closeQuietly(bufferedreader); + } +diff --git a/src/main/java/net/minecraft/server/UserCache.java b/src/main/java/net/minecraft/server/UserCache.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/net/minecraft/server/UserCache.java ++++ b/src/main/java/net/minecraft/server/UserCache.java +@@ -0,0 +0,0 @@ import net.minecraft.util.com.google.gson.GsonBuilder; + import net.minecraft.util.com.mojang.authlib.Agent; + import net.minecraft.util.com.mojang.authlib.GameProfile; + import net.minecraft.util.org.apache.commons.io.IOUtils; ++import net.minecraft.util.com.google.gson.JsonSyntaxException; // PaperSpigot + + public class UserCache { + +@@ -0,0 +0,0 @@ public class UserCache { + break label81; + } catch (FileNotFoundException filenotfoundexception) { + ; ++ } catch (JsonSyntaxException jsonSyntaxEception) { // PaperSpigot Start ++ System.err.printf("Usercache.json is corrupted or has bad formatting."); ++ System.err.printf("Deleting usercache.json to prevent further issues."); ++ this.g.delete(); // PaperSpigot End + } finally { + IOUtils.closeQuietly(bufferedreader); + } +-- \ No newline at end of file