2020-11-27 18:27:52 +01: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
|
|
|
|
|
|
|
|
|
2021-03-16 08:19:45 +01:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/players/PlayerList.java b/src/main/java/net/minecraft/server/players/PlayerList.java
|
|
|
|
index c7464ee5f29aa5ee0994fd4a352756a59055d9ee..bd318c058a0a99472486d1c3eaf1f9fa2879aaf6 100644
|
|
|
|
--- a/src/main/java/net/minecraft/server/players/PlayerList.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/players/PlayerList.java
|
|
|
|
@@ -886,7 +886,7 @@ public abstract class PlayerList {
|
2020-11-27 18:27:52 +01: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);
|
2021-03-16 08:19:45 +01:00
|
|
|
diff --git a/src/main/java/net/minecraft/world/level/storage/WorldData.java b/src/main/java/net/minecraft/world/level/storage/WorldData.java
|
|
|
|
index 81ad90ba93481decdfaa38fc9fa81bca0e402781..7599488f7d4b168c92078c2d2987cb38f0dee8a9 100644
|
|
|
|
--- a/src/main/java/net/minecraft/world/level/storage/WorldData.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/level/storage/WorldData.java
|
|
|
|
@@ -12,6 +12,7 @@ public interface WorldData {
|
2020-11-27 18:27:52 +01:00
|
|
|
|
|
|
|
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-16 08:19:45 +01:00
|
|
|
index 82d478cfa296be9c8d19e8dbd8d3485443108e40..c64bd5725f287aebff60a86cafe86fac29016191 100644
|
2020-11-27 18:27:52 +01:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
2021-03-16 08:19:45 +01:00
|
|
|
@@ -378,7 +378,7 @@ public class CraftWorld implements World {
|
2020-11-27 18:27:52 +01: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
|