2020-11-27 17:27:52 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Mark Vainomaa <mikroskeem@mikroskeem.eu>
|
|
|
|
Date: Tue, 17 Nov 2020 19:13:09 +0200
|
|
|
|
Subject: [PATCH] Expose world spawn angle
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/PlayerList.java b/src/main/java/net/minecraft/server/PlayerList.java
|
2021-03-08 23:12:31 +00:00
|
|
|
index a6a836c936a687d67c67d861c72addf319b44263..c4abe7bdc1a9b725166eff8b77c123dd832b3cf9 100644
|
2020-11-27 17:27:52 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/PlayerList.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/PlayerList.java
|
2021-03-08 23:12:31 +00:00
|
|
|
@@ -811,7 +811,7 @@ public abstract class PlayerList {
|
2020-11-27 17:27:52 +00:00
|
|
|
if (location == null) {
|
|
|
|
worldserver1 = this.server.getWorldServer(World.OVERWORLD);
|
|
|
|
blockposition = entityplayer1.getSpawnPoint(worldserver1);
|
|
|
|
- location = new Location(worldserver1.getWorld(), (double) ((float) blockposition.getX() + 0.5F), (double) ((float) blockposition.getY() + 0.1F), (double) ((float) blockposition.getZ() + 0.5F));
|
|
|
|
+ location = new Location(worldserver1.getWorld(), (double) ((float) blockposition.getX() + 0.5F), (double) ((float) blockposition.getY() + 0.1F), (double) ((float) blockposition.getZ() + 0.5F), worldserver1.worldData.getSpawnAngle(), 0.0F); // Paper - use world spawn angle
|
|
|
|
}
|
|
|
|
|
|
|
|
Player respawnPlayer = cserver.getPlayer(entityplayer1);
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/WorldData.java b/src/main/java/net/minecraft/server/WorldData.java
|
|
|
|
index faf931785ea35df4525d4a429bdb2363e26e491b..14e1762bf8669ef9e8444f5a73952daa50b3b19e 100644
|
|
|
|
--- a/src/main/java/net/minecraft/server/WorldData.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/WorldData.java
|
|
|
|
@@ -8,6 +8,7 @@ public interface WorldData {
|
|
|
|
|
|
|
|
int c();
|
|
|
|
|
|
|
|
+ default float getSpawnAngle() { return d(); } // Paper - OBFHELPER
|
|
|
|
float d();
|
|
|
|
|
|
|
|
long getTime();
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
2021-03-08 23:12:31 +00:00
|
|
|
index d7954f55061e677b00d27be4b8d0890af75a3aad..7e4bf999a4ccc798480d2b14559e0004c5c0eea6 100644
|
2020-11-27 17:27:52 +00:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
2021-03-08 23:12:31 +00:00
|
|
|
@@ -380,7 +380,7 @@ public class CraftWorld implements World {
|
2020-11-27 17:27:52 +00:00
|
|
|
@Override
|
|
|
|
public Location getSpawnLocation() {
|
|
|
|
BlockPosition spawn = world.getSpawn();
|
|
|
|
- return new Location(this, spawn.getX(), spawn.getY(), spawn.getZ());
|
|
|
|
+ return new Location(this, spawn.getX(), spawn.getY(), spawn.getZ(), world.worldData.getSpawnAngle(), 0.0F); // Paper - expose world spawn angle
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|