2014-04-19 01:15:23 +02:00
|
|
|
From 296a8b176d18def1f52aec81873d7c68083d39fe Mon Sep 17 00:00:00 2001
|
2013-06-11 03:54:45 +02:00
|
|
|
From: md_5 <md_5@live.com.au>
|
|
|
|
Date: Tue, 11 Jun 2013 11:54:32 +1000
|
|
|
|
Subject: [PATCH] Prevent Shutdown Hang
|
|
|
|
|
|
|
|
Prevents server hanging if players disconnect during the shutdown sequence.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/PlayerList.java b/src/main/java/net/minecraft/server/PlayerList.java
|
2014-04-19 01:15:23 +02:00
|
|
|
index 1dbce5c..2a15271 100644
|
2013-06-11 03:54:45 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/PlayerList.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/PlayerList.java
|
2014-04-12 06:18:37 +02:00
|
|
|
@@ -1152,8 +1152,15 @@ public abstract class PlayerList {
|
2013-12-01 04:40:53 +01:00
|
|
|
}
|
2013-06-11 03:54:45 +02:00
|
|
|
|
2014-04-12 06:18:37 +02:00
|
|
|
public void u() {
|
2013-12-01 04:40:53 +01:00
|
|
|
- for (int i = 0; i < this.players.size(); ++i) {
|
|
|
|
- ((EntityPlayer) this.players.get(i)).playerConnection.disconnect(this.server.server.getShutdownMessage()); // CraftBukkit - add custom shutdown message
|
|
|
|
+ while (!this.players.isEmpty()) {
|
2013-06-11 03:54:45 +02:00
|
|
|
+ // Spigot start
|
|
|
|
+ EntityPlayer p = (EntityPlayer) this.players.get( 0 );
|
|
|
|
+ p.playerConnection.disconnect( this.server.server.getShutdownMessage() );
|
|
|
|
+ if ( ( !this.players.isEmpty() ) && ( this.players.get( 0 ) == p ) )
|
|
|
|
+ {
|
|
|
|
+ this.players.remove( 0 ); // Prevent shutdown hang if already disconnected
|
|
|
|
+ }
|
|
|
|
+ // Spigot end
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
--
|
2014-04-19 01:15:23 +02:00
|
|
|
1.9.1
|
2013-06-11 03:54:45 +02:00
|
|
|
|