mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-01 08:56:23 +01:00
Further safety for player collision setting
Hopefully the end of similar problems Fixes GH-415
This commit is contained in:
parent
53bb048935
commit
3a128de0c1
1 changed files with 15 additions and 12 deletions
|
@ -1,4 +1,4 @@
|
||||||
From 298ae9e91ce8416d2942e74a935e11b6764c3e84 Mon Sep 17 00:00:00 2001
|
From da5892eee2a2ac6740883752a020de6c4a06d355 Mon Sep 17 00:00:00 2001
|
||||||
From: Aikar <aikar@aikar.co>
|
From: Aikar <aikar@aikar.co>
|
||||||
Date: Wed, 13 Apr 2016 02:10:49 -0400
|
Date: Wed, 13 Apr 2016 02:10:49 -0400
|
||||||
Subject: [PATCH] Configurable Player Collision
|
Subject: [PATCH] Configurable Player Collision
|
||||||
|
@ -50,7 +50,7 @@ index d8ec504..eb45d3c 100644
|
||||||
}
|
}
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/PlayerList.java b/src/main/java/net/minecraft/server/PlayerList.java
|
diff --git a/src/main/java/net/minecraft/server/PlayerList.java b/src/main/java/net/minecraft/server/PlayerList.java
|
||||||
index a41bc5f..6dc0abb 100644
|
index a41bc5f..ea4c7ee 100644
|
||||||
--- a/src/main/java/net/minecraft/server/PlayerList.java
|
--- a/src/main/java/net/minecraft/server/PlayerList.java
|
||||||
+++ b/src/main/java/net/minecraft/server/PlayerList.java
|
+++ b/src/main/java/net/minecraft/server/PlayerList.java
|
||||||
@@ -67,6 +67,7 @@ public abstract class PlayerList {
|
@@ -67,6 +67,7 @@ public abstract class PlayerList {
|
||||||
|
@ -61,42 +61,45 @@ index a41bc5f..6dc0abb 100644
|
||||||
|
|
||||||
public PlayerList(MinecraftServer minecraftserver) {
|
public PlayerList(MinecraftServer minecraftserver) {
|
||||||
this.cserver = minecraftserver.server = new CraftServer(minecraftserver, this);
|
this.cserver = minecraftserver.server = new CraftServer(minecraftserver, this);
|
||||||
@@ -234,6 +235,11 @@ public abstract class PlayerList {
|
@@ -234,6 +235,12 @@ public abstract class PlayerList {
|
||||||
}
|
}
|
||||||
|
|
||||||
entityplayer.syncInventory();
|
entityplayer.syncInventory();
|
||||||
+ // Paper start - Add to collideRule team if needed
|
+ // Paper start - Add to collideRule team if needed
|
||||||
+ if (this.collideRuleTeamName != null) {
|
+ final Scoreboard scoreboard = this.getServer().getWorld().getScoreboard();
|
||||||
+ this.server.getWorld().getScoreboard().addPlayerToTeam(entityplayer.getName(), collideRuleTeamName);
|
+ if (this.collideRuleTeamName != null && scoreboard.getTeam(collideRuleTeamName) != null && entityplayer.getTeam() == null) {
|
||||||
|
+ scoreboard.addPlayerToTeam(entityplayer.getName(), collideRuleTeamName);
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
// CraftBukkit - Moved from above, added world
|
// CraftBukkit - Moved from above, added world
|
||||||
PlayerList.f.info(entityplayer.getName() + "[" + s1 + "] logged in with entity id " + entityplayer.getId() + " at ([" + entityplayer.world.worldData.getName() + "]" + entityplayer.locX + ", " + entityplayer.locY + ", " + entityplayer.locZ + ")");
|
PlayerList.f.info(entityplayer.getName() + "[" + s1 + "] logged in with entity id " + entityplayer.getId() + " at ([" + entityplayer.world.worldData.getName() + "]" + entityplayer.locX + ", " + entityplayer.locY + ", " + entityplayer.locZ + ")");
|
||||||
}
|
}
|
||||||
@@ -404,6 +410,14 @@ public abstract class PlayerList {
|
@@ -404,6 +411,16 @@ public abstract class PlayerList {
|
||||||
entityplayer.k_();// SPIGOT-924 // PAIL: rename - playerTick
|
entityplayer.k_();// SPIGOT-924 // PAIL: rename - playerTick
|
||||||
// CraftBukkit end
|
// CraftBukkit end
|
||||||
|
|
||||||
+ // Paper start - Remove from collideRule team if needed
|
+ // Paper start - Remove from collideRule team if needed
|
||||||
+ if (this.collideRuleTeamName != null) {
|
+ if (this.collideRuleTeamName != null) {
|
||||||
+ Scoreboard scoreBoard = this.server.getWorld().getScoreboard();
|
+ final Scoreboard scoreBoard = this.server.getWorld().getScoreboard();
|
||||||
+ ScoreboardTeam team = scoreBoard.getTeam(this.collideRuleTeamName);
|
+ final ScoreboardTeam team = scoreBoard.getTeam(this.collideRuleTeamName);
|
||||||
+ if (team != null) scoreBoard.removePlayerFromTeam(entityplayer.getName(), team);
|
+ if (entityplayer.getTeam() == team && team != null) {
|
||||||
|
+ scoreBoard.removePlayerFromTeam(entityplayer.getName(), team);
|
||||||
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
+
|
+
|
||||||
this.savePlayerFile(entityplayer);
|
this.savePlayerFile(entityplayer);
|
||||||
if (entityplayer.isPassenger()) {
|
if (entityplayer.isPassenger()) {
|
||||||
Entity entity = entityplayer.getVehicle();
|
Entity entity = entityplayer.getVehicle();
|
||||||
@@ -1302,7 +1316,13 @@ public abstract class PlayerList {
|
@@ -1302,7 +1319,13 @@ public abstract class PlayerList {
|
||||||
player.playerConnection.disconnect(this.server.server.getShutdownMessage()); // CraftBukkit - add custom shutdown message
|
player.playerConnection.disconnect(this.server.server.getShutdownMessage()); // CraftBukkit - add custom shutdown message
|
||||||
}
|
}
|
||||||
// CraftBukkit end
|
// CraftBukkit end
|
||||||
-
|
-
|
||||||
+ // Paper start - Remove collideRule team if it exists
|
+ // Paper start - Remove collideRule team if it exists
|
||||||
+ if (this.collideRuleTeamName != null) {
|
+ if (this.collideRuleTeamName != null) {
|
||||||
+ Scoreboard scoreboard = this.getServer().getWorld().getScoreboard();
|
+ final Scoreboard scoreboard = this.getServer().getWorld().getScoreboard();
|
||||||
+ ScoreboardTeam team = scoreboard.getTeam(this.collideRuleTeamName);
|
+ final ScoreboardTeam team = scoreboard.getTeam(this.collideRuleTeamName);
|
||||||
+ if (team != null) scoreboard.removeTeam(team);
|
+ if (team != null) scoreboard.removeTeam(team);
|
||||||
+ }
|
+ }
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
|
|
Loading…
Reference in a new issue