From 64acfb63bc20a60ccdec6fbdcdf063682aa445ca Mon Sep 17 00:00:00 2001 From: Byteflux Date: Sun, 21 Sep 2014 22:05:59 -0500 Subject: [PATCH] Update with latest patches from upstream SpigotMC --- .../0032-Spigot-Update-20140909a.patch | 99 ++ .../0033-Spigot-Update-20140909b.patch | 25 + .../0034-Spigot-Update-20140911a.patch | 30 + .../0181-Spigot-Update-20140909a.patch | 40 + .../0182-Spigot-Update-20140909b.patch | 192 ++++ .../0183-Spigot-Update-20140916a.patch | 31 +- .../0184-Spigot-Update-20140921a.patch | 973 ++++++++++++++++++ .../Player-affects-spawning-API.patch | 7 +- ...Show-paperspigot-in-protocol-warning.patch | 23 - 9 files changed, 1379 insertions(+), 41 deletions(-) create mode 100644 Bukkit-Patches/0032-Spigot-Update-20140909a.patch create mode 100644 Bukkit-Patches/0033-Spigot-Update-20140909b.patch create mode 100644 Bukkit-Patches/0034-Spigot-Update-20140911a.patch create mode 100644 CraftBukkit-Patches/0181-Spigot-Update-20140909a.patch create mode 100644 CraftBukkit-Patches/0182-Spigot-Update-20140909b.patch rename Spigot-Server-Patches/Add-SportBukkit-fix-for-certain-visually-offset-enti.patch => CraftBukkit-Patches/0183-Spigot-Update-20140916a.patch (75%) create mode 100644 CraftBukkit-Patches/0184-Spigot-Update-20140921a.patch delete mode 100644 Spigot-Server-Patches/Show-paperspigot-in-protocol-warning.patch diff --git a/Bukkit-Patches/0032-Spigot-Update-20140909a.patch b/Bukkit-Patches/0032-Spigot-Update-20140909a.patch new file mode 100644 index 0000000000..198f1850df --- /dev/null +++ b/Bukkit-Patches/0032-Spigot-Update-20140909a.patch @@ -0,0 +1,99 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: md_5 +Date: Thu, 11 Sep 2014 01:06:54 -0700 +Subject: [PATCH] Spigot Update - 20140909a + + +diff --git a/pom.xml b/pom.xml +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/pom.xml ++++ b/pom.xml +@@ -0,0 +0,0 @@ + ../pom.xml + + ++ ++ ++ sonatype-snapshots ++ https://oss.sonatype.org/content/repositories/public ++ ++ ++ + + + +@@ -0,0 +0,0 @@ + + + ++ net.md-5 ++ bungeecord-chat ++ 1.8-SNAPSHOT ++ jar ++ compile ++ ++ + org.yaml + snakeyaml + 1.12 +diff --git a/src/main/java/org/bukkit/Server.java b/src/main/java/org/bukkit/Server.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/bukkit/Server.java ++++ b/src/main/java/org/bukkit/Server.java +@@ -0,0 +0,0 @@ import java.util.Set; + import java.util.UUID; + import java.util.logging.Logger; + ++import net.md_5.bungee.api.chat.BaseComponent; + import org.bukkit.Warning.WarningState; + import org.bukkit.command.CommandException; + import org.bukkit.command.CommandSender; +@@ -0,0 +0,0 @@ public interface Server extends PluginMessageRecipient { + { + throw new UnsupportedOperationException( "Not supported yet." ); + } ++ ++ public void broadcast(BaseComponent component) ++ { ++ throw new UnsupportedOperationException( "Not supported yet." ); ++ } ++ ++ public void broadcast(BaseComponent... components) ++ { ++ throw new UnsupportedOperationException( "Not supported yet." ); ++ } + } + + Spigot spigot(); +diff --git a/src/main/java/org/bukkit/entity/Player.java b/src/main/java/org/bukkit/entity/Player.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/bukkit/entity/Player.java ++++ b/src/main/java/org/bukkit/entity/Player.java +@@ -0,0 +0,0 @@ package org.bukkit.entity; + + import java.net.InetSocketAddress; + ++import net.md_5.bungee.api.chat.BaseComponent; + import org.bukkit.Achievement; + import org.bukkit.ChatColor; + import org.bukkit.Effect; +@@ -0,0 +0,0 @@ public interface Player extends HumanEntity, Conversable, CommandSender, Offline + { + throw new UnsupportedOperationException( "Not supported yet." ); + } ++ ++ public void sendMessage(BaseComponent component) ++ { ++ throw new UnsupportedOperationException( "Not supported yet." ); ++ } ++ ++ public void sendMessage(BaseComponent... components) ++ { ++ throw new UnsupportedOperationException( "Not supported yet." ); ++ } + } + + Spigot spigot(); +-- +1.9.4.msysgit.0 + diff --git a/Bukkit-Patches/0033-Spigot-Update-20140909b.patch b/Bukkit-Patches/0033-Spigot-Update-20140909b.patch new file mode 100644 index 0000000000..3b61dd99e9 --- /dev/null +++ b/Bukkit-Patches/0033-Spigot-Update-20140909b.patch @@ -0,0 +1,25 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: md_5 +Date: Fri, 12 Sep 2014 17:16:11 -0700 +Subject: [PATCH] Spigot Update - 20140909b + + +diff --git a/src/main/java/org/bukkit/plugin/SimplePluginManager.java b/src/main/java/org/bukkit/plugin/SimplePluginManager.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/bukkit/plugin/SimplePluginManager.java ++++ b/src/main/java/org/bukkit/plugin/SimplePluginManager.java +@@ -0,0 +0,0 @@ public final class SimplePluginManager implements PluginManager { + server.getLogger().log( Level.WARNING, "Skipping loading of Orebfuscator as it does not work with Spigot 1.8 builds!" ); + continue; + } +- if ( name.equalsIgnoreCase( "EchoPet" ) ) +- { +- server.getLogger().log( Level.WARNING, "Skipping loading of EchoPet as it does not work with Spigot 1.8 builds!" ); +- continue; +- } + // Spigot End + if (name.equalsIgnoreCase("bukkit") || name.equalsIgnoreCase("minecraft") || name.equalsIgnoreCase("mojang")) { + server.getLogger().log(Level.SEVERE, "Could not load '" + file.getPath() + "' in folder '" + directory.getPath() + "': Restricted Name"); +-- +1.9.4.msysgit.0 + diff --git a/Bukkit-Patches/0034-Spigot-Update-20140911a.patch b/Bukkit-Patches/0034-Spigot-Update-20140911a.patch new file mode 100644 index 0000000000..b057b73f4b --- /dev/null +++ b/Bukkit-Patches/0034-Spigot-Update-20140911a.patch @@ -0,0 +1,30 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: md_5 +Date: Fri, 12 Sep 2014 18:20:53 -0700 +Subject: [PATCH] Spigot Update - 20140911a + + +diff --git a/pom.xml b/pom.xml +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/pom.xml ++++ b/pom.xml +@@ -0,0 +0,0 @@ + 1.8-SNAPSHOT + jar + compile ++ ++ ++ com.google.code.gson ++ gson ++ ++ ++ net.sf.trove4j ++ trove4j ++ ++ + + + org.yaml +-- +1.9.4.msysgit.0 + diff --git a/CraftBukkit-Patches/0181-Spigot-Update-20140909a.patch b/CraftBukkit-Patches/0181-Spigot-Update-20140909a.patch new file mode 100644 index 0000000000..da8e1760a9 --- /dev/null +++ b/CraftBukkit-Patches/0181-Spigot-Update-20140909a.patch @@ -0,0 +1,40 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: md_5 +Date: Thu, 11 Sep 2014 01:07:52 -0700 +Subject: [PATCH] Spigot Update - 20140909a + + +diff --git a/src/main/java/org/bukkit/craftbukkit/Main.java b/src/main/java/org/bukkit/craftbukkit/Main.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/bukkit/craftbukkit/Main.java ++++ b/src/main/java/org/bukkit/craftbukkit/Main.java +@@ -0,0 +0,0 @@ public class Main { + + "Please report any such issues to http://www.spigotmc.org/, stating your client, server, and if applicable BungeeCord versions.\n" + + "*** Any bug reports not running the very latest versions of these softwares will be ignored ***\n\n" ); + +- Enumeration resources = Main.class.getClassLoader().getResources( "META-INF/MANIFEST.MF" ); +- while ( resources.hasMoreElements() ) +- { +- Manifest manifest = new Manifest( resources.nextElement().openStream() ); +- String ts = manifest.getMainAttributes().getValue( "Timestamp" ); +- if ( ts != null ) +- { +- Date buildDate = new SimpleDateFormat( "yyyyMMdd-hhmm" ).parse( ts ); +- +- Calendar cal = Calendar.getInstance(); +- cal.add( Calendar.DAY_OF_YEAR, -2 ); +- if ( buildDate.before(cal.getTime() ) ) +- { +- System.err.println( "WARNING: This build is more than 2 days old and there are likely updates available!" ); +- System.err.println( "You will get no support with this build unless you update from http://ci.md-5.net/job/Spigot/" ); +- System.err.println( "The server will start in 10 seconds!" ); +- Thread.sleep( TimeUnit.SECONDS.toMillis( 10 ) ); +- } +- } +- } + // Spigot End + // Todo: Installation script + OptionParser parser = new OptionParser() { +-- +1.9.4.msysgit.0 + diff --git a/CraftBukkit-Patches/0182-Spigot-Update-20140909b.patch b/CraftBukkit-Patches/0182-Spigot-Update-20140909b.patch new file mode 100644 index 0000000000..4a5b25dc87 --- /dev/null +++ b/CraftBukkit-Patches/0182-Spigot-Update-20140909b.patch @@ -0,0 +1,192 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: md_5 +Date: Fri, 12 Sep 2014 17:16:43 -0700 +Subject: [PATCH] Spigot Update - 20140909b + + +diff --git a/src/main/java/net/minecraft/server/PacketPlayOutChat.java b/src/main/java/net/minecraft/server/PacketPlayOutChat.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/net/minecraft/server/PacketPlayOutChat.java ++++ b/src/main/java/net/minecraft/server/PacketPlayOutChat.java +@@ -0,0 +0,0 @@ + package net.minecraft.server; + ++import net.md_5.bungee.api.chat.BaseComponent; ++import net.md_5.bungee.chat.ComponentSerializer; ++ + import java.io.IOException; + + public class PacketPlayOutChat extends Packet { + + private IChatBaseComponent a; ++ public BaseComponent[] components; // Spigot - Update 20140909b + private boolean b; + + public PacketPlayOutChat() { +@@ -0,0 +0,0 @@ public class PacketPlayOutChat extends Packet { + } + + public void b(PacketDataSerializer packetdataserializer) throws IOException { +- packetdataserializer.a(ChatSerializer.a(this.a)); ++ // Spigot start - Update 20140909b ++ if (components != null) ++ { ++ packetdataserializer.a( ComponentSerializer.toString(components) ); ++ } ++ else { ++ packetdataserializer.a( ChatSerializer.a(a) ); ++ } ++ // Spigot end ++ + // Spigot start - protocol patch + if ( packetdataserializer.version >= 16 ) + { +diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java ++++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java +@@ -0,0 +0,0 @@ import java.util.regex.Pattern; + + import javax.imageio.ImageIO; + ++import net.md_5.bungee.api.chat.BaseComponent; + import net.minecraft.server.ChunkCoordinates; + import net.minecraft.server.CommandAchievement; + import net.minecraft.server.CommandBan; +@@ -0,0 +0,0 @@ public final class CraftServer implements Server { + { + return org.spigotmc.SpigotConfig.config; + } ++ ++ @Override ++ public void broadcast( BaseComponent component ) ++ { ++ for ( Player player : getOnlinePlayers() ) ++ { ++ player.spigot().sendMessage( component ); ++ } ++ } ++ ++ @Override ++ public void broadcast( BaseComponent... components ) ++ { ++ for ( Player player : getOnlinePlayers() ) ++ { ++ player.spigot().sendMessage( components ); ++ } ++ } + }; + + public Spigot spigot() +diff --git a/src/main/java/org/bukkit/craftbukkit/Main.java b/src/main/java/org/bukkit/craftbukkit/Main.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/bukkit/craftbukkit/Main.java ++++ b/src/main/java/org/bukkit/craftbukkit/Main.java +@@ -0,0 +0,0 @@ public class Main { + public static boolean useConsole = true; + + public static void main(String[] args) throws Exception { +- // Spigot Start +- File lock = new File( ".update-lock" ); +- if ( !new File( "update-lock" ).exists() && !lock.exists() && System.getProperty( "IReallyKnowWhatIAmDoingThisUpdate" ) == null ) +- { +- System.err.println( "WARNING: This Minecraft update alters the way in which saved data is stored." ); +- System.err.println( "Please ensure your server is in the correct online/offline mode state, as the changes made are PERMANENT" ); +- System.err.println( "If you are running in offline mode, but your BungeeCord is in online mode, it is imperative that BungeeCord support is enabled in spigot.yml and BungeeCord's config.yml" ); +- System.err.println( "By typing `yes` you acknowledge that you have taken the necessary backups and are aware of this conversion" ); +- System.err.println( "Please type yes to continue starting the server. You have been warned :)" ); +- System.err.println( "See http://www.spigotmc.org/wiki/uuid-conversion/ if you have any questions and remember BACKUP BACKUP BACKUP" ); +- System.err.println( "=================================================================================" ); +- System.err.println( "Starting server in 10 seconds" ); +- lock.createNewFile(); +- try +- { +- Thread.sleep( TimeUnit.SECONDS.toMillis( 10 ) ); +- } catch ( InterruptedException ex ) +- { +- } +- } +- +- System.err.println( "This Spigot build supports Minecraft clients both of versions 1.7.x and of 1.8.x.\n" +- + "*** It is imperative that backups be taken before running this build on your server! ***\n" +- + "Please report any such issues to http://www.spigotmc.org/, stating your client, server, and if applicable BungeeCord versions.\n" +- + "*** Any bug reports not running the very latest versions of these softwares will be ignored ***\n\n" ); +- +- // Spigot End + // Todo: Installation script + OptionParser parser = new OptionParser() { + { +@@ -0,0 +0,0 @@ public class Main { + } else if (options.has("v")) { + System.out.println(CraftServer.class.getPackage().getImplementationVersion()); + } else { ++ // Spigot start - Update 20140909b ++ File lock = new File( ".update-lock" ); ++ if ( !new File( "update-lock" ).exists() && !lock.exists() && System.getProperty( "IReallyKnowWhatIAmDoingThisUpdate" ) == null ) ++ { ++ System.err.println( "WARNING: This Minecraft update alters the way in which saved data is stored." ); ++ System.err.println( "Please ensure your server is in the correct online/offline mode state, as the changes made are PERMANENT" ); ++ System.err.println( "If you are running in offline mode, but your BungeeCord is in online mode, it is imperative that BungeeCord support is enabled in spigot.yml and BungeeCord's config.yml" ); ++ System.err.println( "By typing `yes` you acknowledge that you have taken the necessary backups and are aware of this conversion" ); ++ System.err.println( "Please type yes to continue starting the server. You have been warned :)" ); ++ System.err.println( "See http://www.spigotmc.org/wiki/uuid-conversion/ if you have any questions and remember BACKUP BACKUP BACKUP" ); ++ System.err.println( "=================================================================================" ); ++ System.err.println( "Starting server in 10 seconds" ); ++ lock.createNewFile(); ++ try ++ { ++ Thread.sleep( TimeUnit.SECONDS.toMillis( 10 ) ); ++ } catch ( InterruptedException ex ) ++ { ++ } ++ } ++ ++ System.err.println( "This Spigot build supports Minecraft clients both of versions 1.7.x and of 1.8.x.\n" ++ + "*** It is imperative that backups be taken before running this build on your server! ***\n" ++ + "Please report any such issues to http://www.spigotmc.org/, stating your client, server, and if applicable BungeeCord versions.\n" ++ + "*** Any bug reports not running the very latest versions of these softwares will be ignored ***\n\n" ); ++ ++ // Spigot end ++ + try { + // This trick bypasses Maven Shade's clever rewriting of our getProperty call when using String literals + String jline_UnsupportedTerminal = new String(new char[] {'j','l','i','n','e','.','U','n','s','u','p','p','o','r','t','e','d','T','e','r','m','i','n','a','l'}); +diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java ++++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java +@@ -0,0 +0,0 @@ import java.util.UUID; + import java.util.logging.Level; + import java.util.logging.Logger; + ++import net.md_5.bungee.api.chat.BaseComponent; + import net.minecraft.server.*; + + import net.minecraft.util.com.mojang.authlib.GameProfile; +@@ -0,0 +0,0 @@ public class CraftPlayer extends CraftHumanEntity implements Player { + + return java.util.Collections.unmodifiableSet( ret ); + } ++ ++ @Override ++ public void sendMessage( BaseComponent component ) ++ { ++ sendMessage( new BaseComponent[] { component } ); ++ } ++ ++ @Override ++ public void sendMessage( BaseComponent... components ) ++ { ++ if ( getHandle().playerConnection != null ) ++ { ++ PacketPlayOutChat packet = new PacketPlayOutChat(); ++ packet.components = components; ++ getHandle().playerConnection.sendPacket( packet ); ++ } ++ } + }; + + public Player.Spigot spigot() +-- +1.9.4.msysgit.0 + diff --git a/Spigot-Server-Patches/Add-SportBukkit-fix-for-certain-visually-offset-enti.patch b/CraftBukkit-Patches/0183-Spigot-Update-20140916a.patch similarity index 75% rename from Spigot-Server-Patches/Add-SportBukkit-fix-for-certain-visually-offset-enti.patch rename to CraftBukkit-Patches/0183-Spigot-Update-20140916a.patch index 139e777c9d..fd36e32fd9 100644 --- a/Spigot-Server-Patches/Add-SportBukkit-fix-for-certain-visually-offset-enti.patch +++ b/CraftBukkit-Patches/0183-Spigot-Update-20140916a.patch @@ -1,7 +1,7 @@ From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 -From: Zach Brown <1254957+zachbr@users.noreply.github.com> -Date: Mon, 8 Sep 2014 23:25:48 -0500 -Subject: [PATCH] Add SportBukkit fix for certain visually offset entities +From: md_5 +Date: Sun, 21 Sep 2014 12:57:40 -0700 +Subject: [PATCH] Spigot Update - 20140916a diff --git a/src/main/java/net/minecraft/server/EntityTrackerEntry.java b/src/main/java/net/minecraft/server/EntityTrackerEntry.java @@ -13,8 +13,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 } // CraftBukkit end - object = new PacketPlayOutEntityTeleport(this.tracker.getId(), i, j, k, (byte) l, (byte) i1, tracker.onGround); // Spigot - protocol patch -+ // PaperSpigot - Fix visual offset of falling block entities in proto patch -+ object = new PacketPlayOutEntityTeleport(this.tracker.getId(), i, j, k, (byte) l, (byte) i1, tracker.onGround, tracker instanceof EntityFallingBlock || tracker instanceof EntityTNTPrimed); // Spigot - protocol patch ++ object = new PacketPlayOutEntityTeleport(this.tracker.getId(), i, j, k, (byte) l, (byte) i1, tracker.onGround, tracker instanceof EntityFallingBlock || tracker instanceof EntityTNTPrimed); // Spigot - protocol patch // Spigot Update - 20140916a } } @@ -26,7 +25,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 private byte e; private byte f; private boolean onGround; // Spigot - protocol patch -+ private boolean heightCorrection; // PaperSpigot - Fix visual offset of falling block entities in proto patch ++ private boolean heightCorrection; // Spigot Update - 20140916a public PacketPlayOutEntityTeleport() {} @@ -35,7 +34,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 } - public PacketPlayOutEntityTeleport(int i, int j, int k, int l, byte b0, byte b1, boolean onGround) { // Spigot - protocol patch -+ public PacketPlayOutEntityTeleport(int i, int j, int k, int l, byte b0, byte b1, boolean onGround, boolean heightCorrection) { // Spigot - protocol patch ++ public PacketPlayOutEntityTeleport(int i, int j, int k, int l, byte b0, byte b1, boolean onGround, boolean heightCorrection) { // Spigot - protocol patch // Spigot Update - 20140916a this.a = i; this.b = j; this.c = k; @@ -43,7 +42,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 this.e = b0; this.f = b1; this.onGround = onGround; // Spigot - protocol patch -+ this.heightCorrection = heightCorrection; // PaperSpigot - Fix visual offset of falling block entities in proto patch ++ this.heightCorrection = heightCorrection; // Spigot Update - 20140916a } public void a(PacketDataSerializer packetdataserializer) { @@ -52,8 +51,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 // Spigot end packetdataserializer.writeInt(this.b); - packetdataserializer.writeInt(this.c); -+ // PaperSpigot - Fix visual offset of falling block entities in proto patch -+ packetdataserializer.writeInt(packetdataserializer.version >= 16 && this.heightCorrection ? this.c - 16 : this.c); // Spigot - protocol patch ++ packetdataserializer.writeInt((packetdataserializer.version >= 16 && heightCorrection) ? (this.c - 16) : this.c); // Spigot Update - 20140916a packetdataserializer.writeInt(this.d); packetdataserializer.writeByte(this.e); packetdataserializer.writeByte(this.f); @@ -65,12 +63,15 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 int data = k >> 16; k = id | ( data << 12 ); } -+ // PaperSpigot start - Fix visual offset of falling block entities on proto patch -+ if ((j == 50 || j == 70 || j == 74) && packetdataserializer.version >= 16) { // TNTPrimed, FallingSand, DragonEgg -+ this.c -= 16; ++ ++ if ( ( j == 50 || j == 70 || j == 74 ) && packetdataserializer.version >= 16 ) // Spigot Update - 20140916a ++ { ++ c -= 16; + } -+ // PaperSpigot end ++ // Spigot end packetdataserializer.writeInt(this.b); packetdataserializer.writeInt(this.c); --- \ No newline at end of file +-- +1.9.4.msysgit.0 + diff --git a/CraftBukkit-Patches/0184-Spigot-Update-20140921a.patch b/CraftBukkit-Patches/0184-Spigot-Update-20140921a.patch new file mode 100644 index 0000000000..a665403c79 --- /dev/null +++ b/CraftBukkit-Patches/0184-Spigot-Update-20140921a.patch @@ -0,0 +1,973 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: md_5 +Date: Sun, 21 Sep 2014 18:11:43 -0700 +Subject: [PATCH] Spigot Update - 20140921a + + +diff --git a/src/main/java/net/minecraft/server/EnchantmentManager.java b/src/main/java/net/minecraft/server/EnchantmentManager.java +new file mode 100644 +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 +--- /dev/null ++++ b/src/main/java/net/minecraft/server/EnchantmentManager.java +@@ -0,0 +0,0 @@ ++package net.minecraft.server; ++ ++import java.util.ArrayList; ++import java.util.HashMap; ++import java.util.Iterator; ++import java.util.LinkedHashMap; ++import java.util.List; ++import java.util.Map; ++import java.util.Random; ++ ++public class EnchantmentManager { ++ ++ private static final Random random = new Random(); ++ private static final EnchantmentModifierProtection b = new EnchantmentModifierProtection((EmptyClass) null); ++ private static final EnchantmentModifierDamage c = new EnchantmentModifierDamage((EmptyClass) null); ++ private static final EnchantmentModifierThorns d = new EnchantmentModifierThorns((EmptyClass) null); ++ private static final EnchantmentModifierArthropods e = new EnchantmentModifierArthropods((EmptyClass) null); ++ ++ public static int getEnchantmentLevel(int i, ItemStack itemstack) { ++ if (itemstack == null) { ++ return 0; ++ } else { ++ NBTTagList nbttaglist = itemstack.getEnchantments(); ++ ++ if (nbttaglist == null) { ++ return 0; ++ } else { ++ for (int j = 0; j < nbttaglist.size(); ++j) { ++ short short1 = nbttaglist.get(j).getShort("id"); ++ short short2 = nbttaglist.get(j).getShort("lvl"); ++ ++ if (short1 == i) { ++ return short2; ++ } ++ } ++ ++ return 0; ++ } ++ } ++ } ++ ++ public static Map a(ItemStack itemstack) { ++ LinkedHashMap linkedhashmap = new LinkedHashMap(); ++ NBTTagList nbttaglist = itemstack.getItem() == Items.ENCHANTED_BOOK ? Items.ENCHANTED_BOOK.g(itemstack) : itemstack.getEnchantments(); ++ ++ if (nbttaglist != null) { ++ for (int i = 0; i < nbttaglist.size(); ++i) { ++ short short1 = nbttaglist.get(i).getShort("id"); ++ short short2 = nbttaglist.get(i).getShort("lvl"); ++ ++ linkedhashmap.put(Integer.valueOf(short1), Integer.valueOf(short2)); ++ } ++ } ++ ++ return linkedhashmap; ++ } ++ ++ public static void a(Map map, ItemStack itemstack) { ++ NBTTagList nbttaglist = new NBTTagList(); ++ Iterator iterator = map.keySet().iterator(); ++ ++ while (iterator.hasNext()) { ++ int i = ((Integer) iterator.next()).intValue(); ++ NBTTagCompound nbttagcompound = new NBTTagCompound(); ++ ++ nbttagcompound.setShort("id", (short) i); ++ nbttagcompound.setShort("lvl", (short) ((Integer) map.get(Integer.valueOf(i))).intValue()); ++ nbttaglist.add(nbttagcompound); ++ if (itemstack.getItem() == Items.ENCHANTED_BOOK) { ++ Items.ENCHANTED_BOOK.a(itemstack, new EnchantmentInstance(i, ((Integer) map.get(Integer.valueOf(i))).intValue())); ++ } ++ } ++ ++ if (nbttaglist.size() > 0) { ++ if (itemstack.getItem() != Items.ENCHANTED_BOOK) { ++ itemstack.a("ench", (NBTBase) nbttaglist); ++ } ++ } else if (itemstack.hasTag()) { ++ itemstack.getTag().remove("ench"); ++ } ++ } ++ ++ public static int getEnchantmentLevel(int i, ItemStack[] aitemstack) { ++ if (aitemstack == null) { ++ return 0; ++ } else { ++ int j = 0; ++ ItemStack[] aitemstack1 = aitemstack; ++ int k = aitemstack.length; ++ ++ for (int l = 0; l < k; ++l) { ++ ItemStack itemstack = aitemstack1[l]; ++ int i1 = getEnchantmentLevel(i, itemstack); ++ ++ if (i1 > j) { ++ j = i1; ++ } ++ } ++ ++ return j; ++ } ++ } ++ ++ private static void a(EnchantmentModifier enchantmentmodifier, ItemStack itemstack) { ++ if (itemstack != null) { ++ NBTTagList nbttaglist = itemstack.getEnchantments(); ++ ++ if (nbttaglist != null) { ++ for (int i = 0; i < nbttaglist.size(); ++i) { ++ short short1 = nbttaglist.get(i).getShort("id"); ++ short short2 = nbttaglist.get(i).getShort("lvl"); ++ ++ if (Enchantment.byId[short1] != null) { ++ enchantmentmodifier.a(Enchantment.byId[short1], short2); ++ } ++ } ++ } ++ } ++ } ++ ++ private static void a(EnchantmentModifier enchantmentmodifier, ItemStack[] aitemstack) { ++ ItemStack[] aitemstack1 = aitemstack; ++ int i = aitemstack.length; ++ ++ for (int j = 0; j < i; ++j) { ++ ItemStack itemstack = aitemstack1[j]; ++ ++ a(enchantmentmodifier, itemstack); ++ } ++ } ++ ++ public static int a(ItemStack[] aitemstack, DamageSource damagesource) { ++ b.a = 0; ++ b.b = damagesource; ++ a((EnchantmentModifier) b, aitemstack); ++ if (b.a > 25) { ++ b.a = 25; ++ } ++ ++ return (b.a + 1 >> 1) + random.nextInt((b.a >> 1) + 1); ++ } ++ ++ public static float a(EntityLiving entityliving, EntityLiving entityliving1) { ++ return a(entityliving.be(), entityliving1.getMonsterType()); ++ } ++ ++ public static float a(ItemStack itemstack, EnumMonsterType enummonstertype) { ++ c.a = 0.0F; ++ c.b = enummonstertype; ++ a((EnchantmentModifier) c, itemstack); ++ return c.a; ++ } ++ ++ public static void a(EntityLiving entityliving, Entity entity) { ++ d.b = entity; ++ d.a = entityliving; ++ a((EnchantmentModifier) d, entityliving.getEquipment()); ++ if (entity instanceof EntityHuman) { ++ a((EnchantmentModifier) d, entityliving.be()); ++ } ++ d.b = null; ++ d.a = null; ++ } ++ ++ public static void b(EntityLiving entityliving, Entity entity) { ++ e.a = entityliving; ++ e.b = entity; ++ a((EnchantmentModifier) e, entityliving.getEquipment()); ++ if (entityliving instanceof EntityHuman) { ++ a((EnchantmentModifier) e, entityliving.be()); ++ } ++ e.a = null; ++ e.b = null; ++ } ++ ++ public static int getKnockbackEnchantmentLevel(EntityLiving entityliving, EntityLiving entityliving1) { ++ return getEnchantmentLevel(Enchantment.KNOCKBACK.id, entityliving.be()); ++ } ++ ++ public static int getFireAspectEnchantmentLevel(EntityLiving entityliving) { ++ return getEnchantmentLevel(Enchantment.FIRE_ASPECT.id, entityliving.be()); ++ } ++ ++ public static int getOxygenEnchantmentLevel(EntityLiving entityliving) { ++ return getEnchantmentLevel(Enchantment.OXYGEN.id, entityliving.getEquipment()); ++ } ++ ++ public static int getDigSpeedEnchantmentLevel(EntityLiving entityliving) { ++ return getEnchantmentLevel(Enchantment.DIG_SPEED.id, entityliving.be()); ++ } ++ ++ public static boolean hasSilkTouchEnchantment(EntityLiving entityliving) { ++ return getEnchantmentLevel(Enchantment.SILK_TOUCH.id, entityliving.be()) > 0; ++ } ++ ++ public static int getBonusBlockLootEnchantmentLevel(EntityLiving entityliving) { ++ return getEnchantmentLevel(Enchantment.LOOT_BONUS_BLOCKS.id, entityliving.be()); ++ } ++ ++ public static int getLuckEnchantmentLevel(EntityLiving entityliving) { ++ return getEnchantmentLevel(Enchantment.LUCK.id, entityliving.be()); ++ } ++ ++ public static int getLureEnchantmentLevel(EntityLiving entityliving) { ++ return getEnchantmentLevel(Enchantment.LURE.id, entityliving.be()); ++ } ++ ++ public static int getBonusMonsterLootEnchantmentLevel(EntityLiving entityliving) { ++ return getEnchantmentLevel(Enchantment.LOOT_BONUS_MOBS.id, entityliving.be()); ++ } ++ ++ public static boolean hasWaterWorkerEnchantment(EntityLiving entityliving) { ++ return getEnchantmentLevel(Enchantment.WATER_WORKER.id, entityliving.getEquipment()) > 0; ++ } ++ ++ public static ItemStack a(Enchantment enchantment, EntityLiving entityliving) { ++ ItemStack[] aitemstack = entityliving.getEquipment(); ++ int i = aitemstack.length; ++ ++ for (int j = 0; j < i; ++j) { ++ ItemStack itemstack = aitemstack[j]; ++ ++ if (itemstack != null && getEnchantmentLevel(enchantment.id, itemstack) > 0) { ++ return itemstack; ++ } ++ } ++ ++ return null; ++ } ++ ++ public static int a(Random random, int i, int j, ItemStack itemstack) { ++ Item item = itemstack.getItem(); ++ int k = item.c(); ++ ++ if (k <= 0) { ++ return 0; ++ } else { ++ if (j > 15) { ++ j = 15; ++ } ++ ++ int l = random.nextInt(8) + 1 + (j >> 1) + random.nextInt(j + 1); ++ ++ return i == 0 ? Math.max(l / 3, 1) : (i == 1 ? l * 2 / 3 + 1 : Math.max(l, j * 2)); ++ } ++ } ++ ++ public static ItemStack a(Random random, ItemStack itemstack, int i) { ++ List list = b(random, itemstack, i); ++ boolean flag = itemstack.getItem() == Items.BOOK; ++ ++ if (flag) { ++ itemstack.setItem(Items.ENCHANTED_BOOK); ++ } ++ ++ if (list != null) { ++ Iterator iterator = list.iterator(); ++ ++ while (iterator.hasNext()) { ++ EnchantmentInstance enchantmentinstance = (EnchantmentInstance) iterator.next(); ++ ++ if (flag) { ++ Items.ENCHANTED_BOOK.a(itemstack, enchantmentinstance); ++ } else { ++ itemstack.addEnchantment(enchantmentinstance.enchantment, enchantmentinstance.level); ++ } ++ } ++ } ++ ++ return itemstack; ++ } ++ ++ public static List b(Random random, ItemStack itemstack, int i) { ++ Item item = itemstack.getItem(); ++ int j = item.c(); ++ ++ if (j <= 0) { ++ return null; ++ } else { ++ j /= 2; ++ j = 1 + random.nextInt((j >> 1) + 1) + random.nextInt((j >> 1) + 1); ++ int k = j + i; ++ float f = (random.nextFloat() + random.nextFloat() - 1.0F) * 0.15F; ++ int l = (int) ((float) k * (1.0F + f) + 0.5F); ++ ++ if (l < 1) { ++ l = 1; ++ } ++ ++ ArrayList arraylist = null; ++ Map map = b(l, itemstack); ++ ++ if (map != null && !map.isEmpty()) { ++ EnchantmentInstance enchantmentinstance = (EnchantmentInstance) WeightedRandom.a(random, map.values()); ++ ++ if (enchantmentinstance != null) { ++ arraylist = new ArrayList(); ++ arraylist.add(enchantmentinstance); ++ ++ for (int i1 = l; random.nextInt(50) <= i1; i1 >>= 1) { ++ Iterator iterator = map.keySet().iterator(); ++ ++ while (iterator.hasNext()) { ++ Integer integer = (Integer) iterator.next(); ++ boolean flag = true; ++ Iterator iterator1 = arraylist.iterator(); ++ ++ while (true) { ++ if (iterator1.hasNext()) { ++ EnchantmentInstance enchantmentinstance1 = (EnchantmentInstance) iterator1.next(); ++ ++ if (enchantmentinstance1.enchantment.a(Enchantment.byId[integer.intValue()])) { ++ continue; ++ } ++ ++ flag = false; ++ } ++ ++ if (!flag) { ++ iterator.remove(); ++ } ++ break; ++ } ++ } ++ ++ if (!map.isEmpty()) { ++ EnchantmentInstance enchantmentinstance2 = (EnchantmentInstance) WeightedRandom.a(random, map.values()); ++ ++ arraylist.add(enchantmentinstance2); ++ } ++ } ++ } ++ } ++ ++ return arraylist; ++ } ++ } ++ ++ public static Map b(int i, ItemStack itemstack) { ++ Item item = itemstack.getItem(); ++ HashMap hashmap = null; ++ boolean flag = itemstack.getItem() == Items.BOOK; ++ Enchantment[] aenchantment = Enchantment.byId; ++ int j = aenchantment.length; ++ ++ for (int k = 0; k < j; ++k) { ++ Enchantment enchantment = aenchantment[k]; ++ ++ if (enchantment != null && (enchantment.slot.canEnchant(item) || flag)) { ++ for (int l = enchantment.getStartLevel(); l <= enchantment.getMaxLevel(); ++l) { ++ if (i >= enchantment.a(l) && i <= enchantment.b(l)) { ++ if (hashmap == null) { ++ hashmap = new HashMap(); ++ } ++ ++ hashmap.put(Integer.valueOf(enchantment.id), new EnchantmentInstance(enchantment, l)); ++ } ++ } ++ } ++ } ++ ++ return hashmap; ++ } ++} +diff --git a/src/main/java/net/minecraft/server/EnchantmentModifierArthropods.java b/src/main/java/net/minecraft/server/EnchantmentModifierArthropods.java +new file mode 100644 +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 +--- /dev/null ++++ b/src/main/java/net/minecraft/server/EnchantmentModifierArthropods.java +@@ -0,0 +0,0 @@ ++package net.minecraft.server; ++ ++final class EnchantmentModifierArthropods implements EnchantmentModifier { ++ ++ public EntityLiving a; ++ public Entity b; ++ ++ private EnchantmentModifierArthropods() {} ++ ++ public void a(Enchantment enchantment, int i) { ++ enchantment.a(this.a, this.b, i); ++ } ++ ++ EnchantmentModifierArthropods(EmptyClass emptyclass) { ++ this(); ++ } ++} +diff --git a/src/main/java/net/minecraft/server/EnchantmentModifierDamage.java b/src/main/java/net/minecraft/server/EnchantmentModifierDamage.java +new file mode 100644 +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 +--- /dev/null ++++ b/src/main/java/net/minecraft/server/EnchantmentModifierDamage.java +@@ -0,0 +0,0 @@ ++package net.minecraft.server; ++ ++final class EnchantmentModifierDamage implements EnchantmentModifier { ++ ++ public float a; ++ public EnumMonsterType b; ++ ++ private EnchantmentModifierDamage() {} ++ ++ public void a(Enchantment enchantment, int i) { ++ this.a += enchantment.a(i, this.b); ++ } ++ ++ EnchantmentModifierDamage(EmptyClass emptyclass) { ++ this(); ++ } ++} +diff --git a/src/main/java/net/minecraft/server/EnchantmentModifierProtection.java b/src/main/java/net/minecraft/server/EnchantmentModifierProtection.java +new file mode 100644 +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 +--- /dev/null ++++ b/src/main/java/net/minecraft/server/EnchantmentModifierProtection.java +@@ -0,0 +0,0 @@ ++package net.minecraft.server; ++ ++final class EnchantmentModifierProtection implements EnchantmentModifier { ++ ++ public int a; ++ public DamageSource b; ++ ++ private EnchantmentModifierProtection() {} ++ ++ public void a(Enchantment enchantment, int i) { ++ this.a += enchantment.a(i, this.b); ++ } ++ ++ EnchantmentModifierProtection(EmptyClass emptyclass) { ++ this(); ++ } ++} +diff --git a/src/main/java/net/minecraft/server/EnchantmentModifierThorns.java b/src/main/java/net/minecraft/server/EnchantmentModifierThorns.java +new file mode 100644 +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 +--- /dev/null ++++ b/src/main/java/net/minecraft/server/EnchantmentModifierThorns.java +@@ -0,0 +0,0 @@ ++package net.minecraft.server; ++ ++final class EnchantmentModifierThorns implements EnchantmentModifier { ++ ++ public EntityLiving a; ++ public Entity b; ++ ++ private EnchantmentModifierThorns() {} ++ ++ public void a(Enchantment enchantment, int i) { ++ enchantment.b(this.a, this.b, i); ++ } ++ ++ EnchantmentModifierThorns(EmptyClass emptyclass) { ++ this(); ++ } ++} +diff --git a/src/main/java/net/minecraft/server/EnchantmentThorns.java b/src/main/java/net/minecraft/server/EnchantmentThorns.java +new file mode 100644 +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 +--- /dev/null ++++ b/src/main/java/net/minecraft/server/EnchantmentThorns.java +@@ -0,0 +0,0 @@ ++package net.minecraft.server; ++ ++import java.util.Random; ++ ++public class EnchantmentThorns extends Enchantment { ++ ++ public EnchantmentThorns(int i, int j) { ++ super(i, j, EnchantmentSlotType.ARMOR_TORSO); ++ this.b("thorns"); ++ } ++ ++ public int a(int n) { ++ return 10 + 20 * (n - 1); ++ } ++ ++ public int b(int i) { ++ return super.a(i) + 50; ++ } ++ ++ public int getMaxLevel() { ++ return 3; ++ } ++ ++ public boolean canEnchant(ItemStack itemstack) { ++ return itemstack.getItem() instanceof ItemArmor ? true : super.canEnchant(itemstack); ++ } ++ ++ public void b(EntityLiving entityliving, Entity entity, int n) { ++ Random ai = entityliving.aI(); ++ ItemStack a = EnchantmentManager.a(Enchantment.THORNS, entityliving); ++ ++ if (a(n, ai)) { ++ entity.damageEntity(DamageSource.a(entityliving), b(n, ai)); ++ entity.makeSound("damage.thorns", 0.5F, 1.0F); ++ if (a != null) { ++ a.damage(3, entityliving); ++ } ++ } else if (a != null) { ++ a.damage(1, entityliving); ++ } ++ } ++ ++ public static boolean a(int n, Random random) { ++ return n > 0 && random.nextFloat() < 0.15f * n; ++ } ++ ++ public static int b(int n, Random random) { ++ if (n > 10) { ++ return n - 10; ++ } ++ ++ return 1 + random.nextInt(4); ++ } ++} +diff --git a/src/main/java/net/minecraft/server/EntityInsentient.java b/src/main/java/net/minecraft/server/EntityInsentient.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/net/minecraft/server/EntityInsentient.java ++++ b/src/main/java/net/minecraft/server/EntityInsentient.java +@@ -0,0 +0,0 @@ + package net.minecraft.server; + ++import java.lang.ref.WeakReference; + import java.util.Iterator; + import java.util.List; + import java.util.UUID; +@@ -0,0 +0,0 @@ public abstract class EntityInsentient extends EntityLiving { + private Navigation navigation; + protected final PathfinderGoalSelector goalSelector; + protected final PathfinderGoalSelector targetSelector; +- private EntityLiving goalTarget; ++ private WeakReference goalTarget = new WeakReference(null); // Spigot Update - 20140921a + private EntitySenses bq; + private ItemStack[] equipment = new ItemStack[5]; + public float[] dropChances = new float[5]; // CraftBukkit - protected -> public +@@ -0,0 +0,0 @@ public abstract class EntityInsentient extends EntityLiving { + } + + public EntityLiving getGoalTarget() { +- return this.goalTarget; ++ return this.goalTarget.get(); + } + + public void setGoalTarget(EntityLiving entityliving) { +- this.goalTarget = entityliving; ++ this.goalTarget = new WeakReference(entityliving); + } + + public boolean a(Class oclass) { +diff --git a/src/main/java/net/minecraft/server/ItemEnchantedBook.java b/src/main/java/net/minecraft/server/ItemEnchantedBook.java +new file mode 100644 +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 +--- /dev/null ++++ b/src/main/java/net/minecraft/server/ItemEnchantedBook.java +@@ -0,0 +0,0 @@ ++package net.minecraft.server; ++ ++import java.util.Random; ++ ++public class ItemEnchantedBook extends Item { ++ ++ public ItemEnchantedBook() {} ++ ++ public boolean e_(ItemStack itemStack) { ++ return false; ++ } ++ ++ public EnumItemRarity f(ItemStack itemstack) { ++ if (this.g(itemstack).size() > 0) { ++ return EnumItemRarity.UNCOMMON; ++ } ++ return super.f(itemstack); ++ } ++ ++ public NBTTagList g(ItemStack itemStack) { ++ if (itemStack.tag == null || !itemStack.tag.hasKeyOfType("StoredEnchantments", 9)) { ++ return new NBTTagList(); ++ } ++ return (NBTTagList)itemStack.tag.get("StoredEnchantments"); ++ } ++ ++ public void a(ItemStack itemStack, EnchantmentInstance enchantmentInstance) { ++ NBTTagList g = this.g(itemStack); ++ boolean b = true; ++ for (int i = 0; i < g.size(); ++i) { ++ NBTTagCompound value = g.get(i); ++ if (value.getShort("id") == enchantmentInstance.enchantment.id) { ++ if (value.getShort("lvl") < enchantmentInstance.level) { ++ value.setShort("lvl", (short)enchantmentInstance.level); ++ } ++ ++ b = false; ++ break; ++ } ++ } ++ ++ if (b) { ++ NBTTagCompound nbtTagCompound = new NBTTagCompound(); ++ nbtTagCompound.setShort("id", (short)enchantmentInstance.enchantment.id); ++ nbtTagCompound.setShort("lvl", (short)enchantmentInstance.level); ++ g.add(nbtTagCompound); ++ } ++ ++ if (!itemStack.hasTag()) { ++ itemStack.setTag(new NBTTagCompound()); ++ } ++ ++ itemStack.getTag().set("StoredEnchantments", g); ++ } ++ ++ public ItemStack a(EnchantmentInstance enchantmentInstance) { ++ ItemStack itemStack = new ItemStack(this); ++ this.a(itemStack, enchantmentInstance); ++ return itemStack; ++ } ++ ++ public StructurePieceTreasure b(Random random) { ++ return this.a(random, 1, 1, 1); ++ } ++ ++ public StructurePieceTreasure a(final Random random, final int n, final int n2, final int n3) { ++ ItemStack itemstack = new ItemStack(Items.BOOK, 1, 0); ++ ++ EnchantmentManager.a(random, itemstack, 30); ++ return new StructurePieceTreasure(itemstack, n, n2, n3); ++ } ++} +diff --git a/src/main/java/net/minecraft/server/NetworkManager.java b/src/main/java/net/minecraft/server/NetworkManager.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/net/minecraft/server/NetworkManager.java ++++ b/src/main/java/net/minecraft/server/NetworkManager.java +@@ -0,0 +0,0 @@ public class NetworkManager extends SimpleChannelInboundHandler { + public void close(IChatBaseComponent ichatbasecomponent) { + // Spigot Start + this.preparing = false; ++ this.k.clear(); // Spigot Update - 20140921a ++ this.l.clear(); // Spigot Update - 20140921a + // Spigot End + if (this.m.isOpen()) { + this.m.close(); +diff --git a/src/main/java/net/minecraft/server/PathfinderGoalNearestAttackableTarget.java b/src/main/java/net/minecraft/server/PathfinderGoalNearestAttackableTarget.java +new file mode 100644 +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 +--- /dev/null ++++ b/src/main/java/net/minecraft/server/PathfinderGoalNearestAttackableTarget.java +@@ -0,0 +0,0 @@ ++package net.minecraft.server; ++ ++import java.lang.ref.WeakReference; ++import java.util.Collections; ++import java.util.List; ++ ++public class PathfinderGoalNearestAttackableTarget extends PathfinderGoalTarget { ++ ++ private final Class a; ++ private final int b; ++ private final DistanceComparator e; ++ private final IEntitySelector f; ++ private WeakReference g; // Spigot Update - 20140921a ++ ++ public PathfinderGoalNearestAttackableTarget(EntityCreature entitycreature, Class oclass, int i, boolean flag) { ++ this(entitycreature, oclass, i, flag, false); ++ } ++ ++ public PathfinderGoalNearestAttackableTarget(EntityCreature entitycreature, Class oclass, int i, boolean flag, boolean flag1) { ++ this(entitycreature, oclass, i, flag, flag1, (IEntitySelector) null); ++ } ++ ++ public PathfinderGoalNearestAttackableTarget(EntityCreature entitycreature, Class oclass, int i, boolean flag, boolean flag1, IEntitySelector ientityselector) { ++ super(entitycreature, flag, flag1); ++ this.g = new WeakReference(null); ++ this.a = oclass; ++ this.b = i; ++ this.e = new DistanceComparator(entitycreature); ++ this.a(1); ++ this.f = new EntitySelectorNearestAttackableTarget(this, ientityselector); ++ } ++ ++ public boolean a() { ++ if (this.b > 0 && this.c.aI().nextInt(this.b) != 0) { ++ return false; ++ } else { ++ double d0 = this.f(); ++ List list = this.c.world.a(this.a, this.c.boundingBox.grow(d0, 4.0D, d0), this.f); ++ ++ Collections.sort(list, this.e); ++ if (list.isEmpty()) { ++ return false; ++ } else { ++ this.g = new WeakReference((EntityLiving) list.get(0)); ++ return true; ++ } ++ } ++ } ++ ++ public void c() { ++ this.c.setGoalTarget(this.g.get()); ++ super.c(); ++ } ++} +diff --git a/src/main/java/net/minecraft/server/PathfinderGoalSwell.java b/src/main/java/net/minecraft/server/PathfinderGoalSwell.java +new file mode 100644 +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 +--- /dev/null ++++ b/src/main/java/net/minecraft/server/PathfinderGoalSwell.java +@@ -0,0 +0,0 @@ ++package net.minecraft.server; ++ ++public class PathfinderGoalSwell extends PathfinderGoal { ++ ++ EntityCreeper a; ++ ++ public PathfinderGoalSwell(EntityCreeper entitycreeper) { ++ this.a = entitycreeper; ++ this.a(1); ++ } ++ ++ public boolean a() { ++ EntityLiving entityliving = this.a.getGoalTarget(); ++ ++ return this.a.cb() > 0 || entityliving != null && this.a.f(entityliving) < 9.0D; ++ } ++ ++ public void c() { ++ this.a.getNavigation().h(); ++ } ++ ++ public void d() {} ++ ++ public void e() { ++ EntityLiving b = this.a.getGoalTarget(); // Spigot Update - 20140921a ++ if (b == null) { ++ this.a.a(-1); ++ } else if (this.a.f(b) > 49.0D) { ++ this.a.a(-1); ++ } else if (!this.a.getEntitySenses().canSee(b)) { ++ this.a.a(-1); ++ } else { ++ this.a.a(1); ++ } ++ } ++} +diff --git a/src/main/java/org/bukkit/craftbukkit/util/LongHash.java b/src/main/java/org/bukkit/craftbukkit/util/LongHash.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/bukkit/craftbukkit/util/LongHash.java ++++ b/src/main/java/org/bukkit/craftbukkit/util/LongHash.java +@@ -0,0 +0,0 @@ public class LongHash { + } + + public static int lsw(long l) { +- return (int) (l) + Integer.MIN_VALUE; // Spigot - remove redundant & ++ return (int) (l & -1L) + Integer.MIN_VALUE; // Spigot - remove redundant & // Spigot Update - 20140921a + } + } +diff --git a/src/main/java/org/bukkit/craftbukkit/util/LongHashSet.java b/src/main/java/org/bukkit/craftbukkit/util/LongHashSet.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/bukkit/craftbukkit/util/LongHashSet.java ++++ b/src/main/java/org/bukkit/craftbukkit/util/LongHashSet.java +@@ -0,0 +0,0 @@ public class LongHashSet { + private int elements; + private long[] values; + private int modCount; +- private org.spigotmc.FlatMap flat = new org.spigotmc.FlatMap(); // Spigot + + public LongHashSet() { + this(INITIAL_SIZE); +@@ -0,0 +0,0 @@ public class LongHashSet { + } + + public boolean contains(int msw, int lsw) { +- // Spigot start +- if ( elements == 0 ) +- { +- return false; +- } +- if ( flat.contains( msw, lsw ) ) +- { +- return true; +- } +- // Spigot end + return contains(LongHash.toLong(msw, lsw)); + } + + public boolean contains(long value) { +- // Spigot start +- if ( elements == 0 ) +- { +- return false; +- } +- if ( flat.contains( value ) ) +- { +- return true; +- } +- // Spigot end + int hash = hash(value); + int index = (hash & 0x7FFFFFFF) % values.length; + int offset = 1; +@@ -0,0 +0,0 @@ public class LongHashSet { + } + + public boolean add(long value) { +- flat.put( value, Boolean.TRUE ); // Spigot + int hash = hash(value); + int index = (hash & 0x7FFFFFFF) % values.length; + int offset = 1; +@@ -0,0 +0,0 @@ public class LongHashSet { + } + + public void remove(int msw, int lsw) { +- // Spigot start +- flat.remove(msw, lsw); +- remove0(LongHash.toLong(msw, lsw)); ++ remove(LongHash.toLong(msw, lsw)); + } + + public boolean remove(long value) { +- flat.remove(value); +- return remove0(value); +- } +- +- private boolean remove0(long value) { +- // Spigot end + int hash = hash(value); + int index = (hash & 0x7FFFFFFF) % values.length; + int offset = 1; +@@ -0,0 +0,0 @@ public class LongHashSet { + + freeEntries = values.length; + modCount++; +- flat = new org.spigotmc.FlatMap(); + } + + public long[] toArray() { +diff --git a/src/main/java/org/bukkit/craftbukkit/util/LongObjectHashMap.java b/src/main/java/org/bukkit/craftbukkit/util/LongObjectHashMap.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/bukkit/craftbukkit/util/LongObjectHashMap.java ++++ b/src/main/java/org/bukkit/craftbukkit/util/LongObjectHashMap.java +@@ -0,0 +0,0 @@ public class LongObjectHashMap implements Cloneable, Serializable { + private transient V[][] values; + private transient int modCount; + private transient int size; +- private transient org.spigotmc.FlatMap flat = new org.spigotmc.FlatMap(); // Spigot + + public LongObjectHashMap() { + initialize(); +@@ -0,0 +0,0 @@ public class LongObjectHashMap implements Cloneable, Serializable { + } + + public V get(long key) { +- // Spigot start +- if ( size == 0 ) +- { +- return null; +- } +- V val = flat.get( key ); +- if ( val != null ) +- { +- return val; +- } +- // Spigot end + int index = (int) (keyIndex(key) & (BUCKET_SIZE - 1)); + long[] inner = keys[index]; + if (inner == null) return null; +@@ -0,0 +0,0 @@ public class LongObjectHashMap implements Cloneable, Serializable { + } + + public V put(long key, V value) { +- flat.put(key, value); // Spigot + int index = (int) (keyIndex(key) & (BUCKET_SIZE - 1)); + long[] innerKeys = keys[index]; + V[] innerValues = values[index]; +@@ -0,0 +0,0 @@ public class LongObjectHashMap implements Cloneable, Serializable { + } + + public V remove(long key) { +- flat.remove(key); // Spigot + int index = (int) (keyIndex(key) & (BUCKET_SIZE - 1)); + long[] inner = keys[index]; + if (inner == null) { +@@ -0,0 +0,0 @@ public class LongObjectHashMap implements Cloneable, Serializable { + size = 0; + Arrays.fill(keys, null); + Arrays.fill(values, null); +- flat = new org.spigotmc.FlatMap(); + } + + public Set keySet() { +diff --git a/src/main/java/org/spigotmc/FlatMap.java b/src/main/java/org/spigotmc/FlatMap.java +deleted file mode 100644 +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 +--- a/src/main/java/org/spigotmc/FlatMap.java ++++ /dev/null +@@ -0,0 +0,0 @@ +-package org.spigotmc; +- +-import org.bukkit.craftbukkit.util.LongHash; +- +-public class FlatMap +-{ +- +- private static final int FLAT_LOOKUP_SIZE = 512; +- private final Object[][] flatLookup = new Object[ FLAT_LOOKUP_SIZE * 2 ][ FLAT_LOOKUP_SIZE * 2 ]; +- +- public void put(long msw, long lsw, V value) +- { +- long acx = Math.abs( msw ); +- long acz = Math.abs( lsw ); +- if ( acx < FLAT_LOOKUP_SIZE && acz < FLAT_LOOKUP_SIZE ) +- { +- flatLookup[(int) ( msw + FLAT_LOOKUP_SIZE )][(int) ( lsw + FLAT_LOOKUP_SIZE )] = value; +- } +- } +- +- public void put(long key, V value) +- { +- put( LongHash.msw( key ), LongHash.lsw( key ), value ); +- +- } +- +- public void remove(long key) +- { +- put( key, null ); +- } +- +- public void remove(long msw, long lsw) +- { +- put( msw, lsw, null ); +- } +- +- public boolean contains(long msw, long lsw) +- { +- return get( msw, lsw ) != null; +- } +- +- public boolean contains(long key) +- { +- return get( key ) != null; +- } +- +- public V get(long msw, long lsw) +- { +- long acx = Math.abs( msw ); +- long acz = Math.abs( lsw ); +- if ( acx < FLAT_LOOKUP_SIZE && acz < FLAT_LOOKUP_SIZE ) +- { +- return (V) flatLookup[(int) ( msw + FLAT_LOOKUP_SIZE )][(int) ( lsw + FLAT_LOOKUP_SIZE )]; +- } else +- { +- return null; +- } +- } +- +- public V get(long key) +- { +- return get( LongHash.msw( key ), LongHash.lsw( key ) ); +- } +-} +-- +1.9.4.msysgit.0 + diff --git a/Spigot-Server-Patches/Player-affects-spawning-API.patch b/Spigot-Server-Patches/Player-affects-spawning-API.patch index 5e73523fc8..ce9bf4417c 100644 --- a/Spigot-Server-Patches/Player-affects-spawning-API.patch +++ b/Spigot-Server-Patches/Player-affects-spawning-API.patch @@ -1,6 +1,6 @@ From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: Jedediah Smith -Date: Fri, 8 Aug 2014 22:51:26 -0500 +Date: Sun, 21 Sep 2014 22:02:02 -0500 Subject: [PATCH] Player affects spawning API @@ -110,8 +110,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java @@ -0,0 +0,0 @@ public class CraftPlayer extends CraftHumanEntity implements Player { - - return java.util.Collections.unmodifiableSet( ret ); + getHandle().playerConnection.sendPacket( packet ); + } } + + // PaperSpigot start - Add affects spawning API @@ -123,6 +123,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 + return getHandle().affectsSpawning; + } + // PaperSpigot end ++ }; public Player.Spigot spigot() diff --git a/Spigot-Server-Patches/Show-paperspigot-in-protocol-warning.patch b/Spigot-Server-Patches/Show-paperspigot-in-protocol-warning.patch deleted file mode 100644 index 7a4f04f0f3..0000000000 --- a/Spigot-Server-Patches/Show-paperspigot-in-protocol-warning.patch +++ /dev/null @@ -1,23 +0,0 @@ -From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 -From: Zach Brown <1254957+zachbr@users.noreply.github.com> -Date: Mon, 1 Sep 2014 14:41:31 -0500 -Subject: [PATCH] Show paperspigot in protocol warning - - -diff --git a/src/main/java/org/bukkit/craftbukkit/Main.java b/src/main/java/org/bukkit/craftbukkit/Main.java -index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 ---- a/src/main/java/org/bukkit/craftbukkit/Main.java -+++ b/src/main/java/org/bukkit/craftbukkit/Main.java -@@ -0,0 +0,0 @@ public class Main { - } - } - -- System.err.println( "This Spigot build supports Minecraft clients both of versions 1.7.x and of 1.8.x.\n" -+ System.err.println( "This PaperSpigot build supports Minecraft clients both of versions 1.7.x and of 1.8.x.\n" - + "*** It is imperative that backups be taken before running this build on your server! ***\n" -- + "Please report any such issues to http://www.spigotmc.org/, stating your client, server, and if applicable BungeeCord versions.\n" -+ + "Please report any such issues to the PaperSpigot project, stating your client, server, and if applicable BungeeCord versions.\n" - + "*** Any bug reports not running the very latest versions of these softwares will be ignored ***\n\n" ); - - Enumeration resources = Main.class.getClassLoader().getResources( "META-INF/MANIFEST.MF" ); --- \ No newline at end of file