2024-12-11 22:26:55 +01:00
--- a/net/minecraft/server/level/ServerPlayer.java
+++ b/net/minecraft/server/level/ServerPlayer.java
@@ -103,10 +103,6 @@
import net.minecraft.util.Unit;
import net.minecraft.util.profiling.Profiler;
import net.minecraft.util.profiling.ProfilerFiller;
-import net.minecraft.world.Container;
-import net.minecraft.world.Difficulty;
-import net.minecraft.world.InteractionHand;
-import net.minecraft.world.MenuProvider;
import net.minecraft.world.damagesource.DamageSource;
import net.minecraft.world.damagesource.DamageTypes;
import net.minecraft.world.effect.MobEffectInstance;
@@ -135,15 +131,16 @@
import net.minecraft.world.entity.player.ChatVisiblity;
import net.minecraft.world.entity.player.Input;
import net.minecraft.world.entity.player.Inventory;
-import net.minecraft.world.entity.player.Player;
import net.minecraft.world.entity.projectile.AbstractArrow;
import net.minecraft.world.entity.projectile.ThrownEnderpearl;
import net.minecraft.world.entity.vehicle.AbstractBoat;
import net.minecraft.world.entity.vehicle.AbstractMinecart;
+import net.minecraft.world.food.FoodData;
import net.minecraft.world.inventory.AbstractContainerMenu;
import net.minecraft.world.inventory.ContainerListener;
import net.minecraft.world.inventory.ContainerSynchronizer;
import net.minecraft.world.inventory.HorseInventoryMenu;
+import net.minecraft.world.inventory.InventoryMenu;
import net.minecraft.world.inventory.ResultSlot;
import net.minecraft.world.inventory.Slot;
import net.minecraft.world.item.Item;
@@ -154,8 +151,6 @@
import net.minecraft.world.item.WrittenBookItem;
import net.minecraft.world.item.crafting.Recipe;
import net.minecraft.world.item.crafting.RecipeHolder;
-import net.minecraft.world.item.enchantment.EnchantmentHelper;
-import net.minecraft.world.item.trading.MerchantOffers;
import net.minecraft.world.level.ChunkPos;
import net.minecraft.world.level.GameRules;
import net.minecraft.world.level.GameType;
@@ -163,12 +158,14 @@
import net.minecraft.world.level.biome.BiomeManager;
import net.minecraft.world.level.block.BedBlock;
import net.minecraft.world.level.block.Block;
+import net.minecraft.world.level.block.ChestBlock;
import net.minecraft.world.level.block.HorizontalDirectionalBlock;
import net.minecraft.world.level.block.RespawnAnchorBlock;
import net.minecraft.world.level.block.entity.BlockEntity;
import net.minecraft.world.level.block.entity.CommandBlockEntity;
import net.minecraft.world.level.block.entity.SignBlockEntity;
import net.minecraft.world.level.block.state.BlockState;
+import net.minecraft.world.level.dimension.LevelStem;
import net.minecraft.world.level.gameevent.GameEvent;
import net.minecraft.world.level.portal.TeleportTransition;
import net.minecraft.world.level.saveddata.maps.MapId;
@@ -179,11 +176,47 @@
import net.minecraft.world.scores.PlayerTeam;
import net.minecraft.world.scores.ScoreAccess;
import net.minecraft.world.scores.ScoreHolder;
+import org.slf4j.Logger;
+import net.minecraft.world.Container;
+import net.minecraft.world.Difficulty;
+import net.minecraft.world.InteractionHand;
+import net.minecraft.world.MenuProvider;
2014-11-26 08:32:16 +11:00
+// CraftBukkit start
2021-03-16 09:00:00 +11:00
+import net.minecraft.world.damagesource.CombatTracker;
2024-06-14 01:05:00 +10:00
+import net.minecraft.world.item.enchantment.EnchantmentEffectComponents;
2024-12-11 22:26:55 +01:00
+import net.minecraft.world.item.enchantment.EnchantmentHelper;
+import net.minecraft.world.item.trading.MerchantOffers;
2021-03-16 09:00:00 +11:00
+import net.minecraft.world.scores.Scoreboard;
2024-12-11 22:26:55 +01:00
import net.minecraft.world.scores.Team;
import net.minecraft.world.scores.criteria.ObjectiveCriteria;
-import org.slf4j.Logger;
2014-11-26 08:32:16 +11:00
+import org.bukkit.Bukkit;
2018-07-15 10:00:00 +10:00
+import org.bukkit.Location;
2014-11-26 08:32:16 +11:00
+import org.bukkit.WeatherType;
2024-10-23 02:15:00 +11:00
+import org.bukkit.command.CommandSender;
2014-11-26 08:32:16 +11:00
+import org.bukkit.craftbukkit.CraftWorld;
2022-04-09 09:39:33 +10:00
+import org.bukkit.craftbukkit.CraftWorldBorder;
2014-11-26 08:32:16 +11:00
+import org.bukkit.craftbukkit.entity.CraftPlayer;
+import org.bukkit.craftbukkit.event.CraftEventFactory;
2020-08-14 08:26:40 +10:00
+import org.bukkit.craftbukkit.event.CraftPortalEvent;
2014-11-26 08:32:16 +11:00
+import org.bukkit.craftbukkit.inventory.CraftItemStack;
2021-05-15 10:06:25 +10:00
+import org.bukkit.craftbukkit.util.CraftDimensionUtil;
2023-04-19 19:59:19 +10:00
+import org.bukkit.craftbukkit.util.CraftLocation;
2024-06-14 01:05:00 +10:00
+import org.bukkit.entity.Player;
2023-12-06 03:40:00 +11:00
+import org.bukkit.event.entity.EntityExhaustionEvent;
2021-01-29 11:22:42 +11:00
+import org.bukkit.event.player.PlayerBedLeaveEvent;
2016-05-27 18:53:36 +10:00
+import org.bukkit.event.player.PlayerChangedMainHandEvent;
2019-05-06 08:38:29 +10:00
+import org.bukkit.event.player.PlayerChangedWorldEvent;
2024-10-23 02:15:00 +11:00
+import org.bukkit.event.player.PlayerDropItemEvent;
2017-05-26 23:37:06 +02:00
+import org.bukkit.event.player.PlayerLocaleChangeEvent;
2019-04-23 12:00:00 +10:00
+import org.bukkit.event.player.PlayerPortalEvent;
2024-06-14 01:05:00 +10:00
+import org.bukkit.event.player.PlayerRespawnEvent;
2023-04-17 19:33:17 +10:00
+import org.bukkit.event.player.PlayerSpawnChangeEvent;
2019-04-23 12:00:00 +10:00
+import org.bukkit.event.player.PlayerTeleportEvent;
2014-11-26 08:32:16 +11:00
+import org.bukkit.event.player.PlayerTeleportEvent.TeleportCause;
2016-05-27 18:53:36 +10:00
+import org.bukkit.inventory.MainHand;
2014-11-26 08:32:16 +11:00
+// CraftBukkit end
2024-12-11 22:26:55 +01:00
-public class ServerPlayer extends Player {
+public class ServerPlayer extends net.minecraft.world.entity.player.Player {
2014-11-26 08:32:16 +11:00
2022-03-01 02:00:00 +11:00
private static final Logger LOGGER = LogUtils.getLogger();
2024-12-11 22:26:55 +01:00
private static final int NEUTRAL_MOB_DEATH_NOTIFICATION_RADII_XZ = 32;
@@ -225,7 +258,7 @@
2023-09-22 02:40:00 +10:00
private int levitationStartTime;
private boolean disconnected;
private int requestedViewDistance;
- public String language;
+ public String language = "en_us"; // CraftBukkit - default
@Nullable
2024-12-11 22:26:55 +01:00
private Vec3 startingToFallPosition;
2023-09-22 02:40:00 +10:00
@Nullable
2024-12-11 22:26:55 +01:00
@@ -259,6 +292,22 @@
2023-09-22 02:40:00 +10:00
private int containerCounter;
2021-06-11 15:00:00 +10:00
public boolean wonGame;
2015-02-26 22:41:06 +00:00
2014-11-26 08:32:16 +11:00
+ // CraftBukkit start
2024-04-24 01:15:00 +10:00
+ public CraftPlayer.TransferCookieConnection transferCookieConnection;
2014-11-26 08:32:16 +11:00
+ public String displayName;
2024-12-11 22:26:55 +01:00
+ public Component listName;
2024-10-23 02:15:00 +11:00
+ public int listOrder = 0;
2014-11-26 08:32:16 +11:00
+ public org.bukkit.Location compassTarget;
+ public int newExp = 0;
+ public int newLevel = 0;
+ public int newTotalExp = 0;
+ public boolean keepLevel = false;
+ public double maxHealthCache;
+ public boolean joining = true;
2017-04-27 21:53:31 -07:00
+ public boolean sentListPacket = false;
2022-03-16 19:49:07 +11:00
+ public String kickLeaveMessage = null; // SPIGOT-3034: Forward leave message to PlayerQuitEvent
2014-11-26 08:32:16 +11:00
+ // CraftBukkit end
2015-02-26 22:41:06 +00:00
+
2024-12-11 22:26:55 +01:00
public ServerPlayer(MinecraftServer server, ServerLevel world, GameProfile profile, ClientInformation clientOptions) {
super(world, world.getSharedSpawnPos(), world.getSharedSpawnAngle(), profile);
this.chatVisibility = ChatVisiblity.FULL;
@@ -340,6 +389,13 @@
public void sendSystemMessage(Component message) {
ServerPlayer.this.sendSystemMessage(message);
2024-10-23 02:15:00 +11:00
}
+
+ // CraftBukkit start
+ @Override
2024-12-11 22:26:55 +01:00
+ public CommandSender getBukkitSender(CommandSourceStack wrapper) {
+ return ServerPlayer.this.getBukkitEntity();
2024-10-23 02:15:00 +11:00
+ }
+ // CraftBukkit end
};
2024-12-11 22:26:55 +01:00
this.textFilter = server.createTextFilterForPlayer(this);
this.gameMode = server.createGameModeForPlayer(this);
@@ -352,14 +408,67 @@
this.moveTo(this.adjustSpawnLocation(world, world.getSharedSpawnPos()).getBottomCenter(), 0.0F, 0.0F);
this.updateOptions(clientOptions);
2024-04-24 01:15:00 +10:00
this.object = null;
2018-03-07 21:43:33 +11:00
+
2014-11-26 08:32:16 +11:00
+ // CraftBukkit start
2021-11-22 09:00:00 +11:00
+ this.displayName = this.getScoreboardName();
2021-06-11 15:00:00 +10:00
+ this.bukkitPickUpLoot = true;
2014-11-26 08:32:16 +11:00
+ this.maxHealthCache = this.getMaxHealth();
2024-12-11 22:26:55 +01:00
}
2024-04-28 07:27:19 +10:00
+ // Use method to resend items in hands in case of client desync, because the item use got cancelled.
+ // For example, when cancelling the leash event
+ public void resendItemInHands() {
2024-12-11 22:26:55 +01:00
+ this.containerMenu.findSlot(this.getInventory(), this.getInventory().selected).ifPresent(s -> {
+ this.containerSynchronizer.sendSlotChange(this.containerMenu, s, this.getMainHandItem());
2024-04-28 07:27:19 +10:00
+ });
2024-12-11 22:26:55 +01:00
+ this.containerSynchronizer.sendSlotChange(this.inventoryMenu, InventoryMenu.SHIELD_SLOT, this.getOffhandItem());
2024-04-28 07:27:19 +10:00
+ }
+
2018-07-15 10:00:00 +10:00
+ // Yes, this doesn't match Vanilla, but it's the best we can do for now.
+ // If this is an issue, PRs are welcome
2024-12-11 22:26:55 +01:00
+ public final BlockPos getSpawnPoint(ServerLevel worldserver) {
+ BlockPos blockposition = worldserver.getSharedSpawnPos();
2018-07-15 10:00:00 +10:00
+
2024-12-11 22:26:55 +01:00
+ if (worldserver.dimensionType().hasSkyLight() && worldserver.serverLevelData.getGameType() != GameType.ADVENTURE) {
2021-11-22 09:00:00 +11:00
+ int i = Math.max(0, this.server.getSpawnRadius(worldserver));
2024-12-11 22:26:55 +01:00
+ int j = Mth.floor(worldserver.getWorldBorder().getDistanceToBorder((double) blockposition.getX(), (double) blockposition.getZ()));
2018-07-15 10:00:00 +10:00
+
+ if (j < i) {
+ i = j;
+ }
+
+ if (j <= 1) {
+ i = 1;
+ }
+
2020-06-25 10:00:00 +10:00
+ long k = (long) (i * 2 + 1);
+ long l = k * k;
+ int i1 = l > 2147483647L ? Integer.MAX_VALUE : (int) l;
2021-11-22 09:00:00 +11:00
+ int j1 = this.getCoprime(i1);
2022-06-08 02:00:00 +10:00
+ int k1 = RandomSource.create().nextInt(i1);
2018-07-15 10:00:00 +10:00
+
2020-06-25 10:00:00 +10:00
+ for (int l1 = 0; l1 < i1; ++l1) {
+ int i2 = (k1 + j1 * l1) % i1;
+ int j2 = i2 % (i * 2 + 1);
+ int k2 = i2 / (i * 2 + 1);
2024-12-11 22:26:55 +01:00
+ BlockPos blockposition1 = PlayerRespawnLogic.getOverworldRespawnPos(worldserver, blockposition.getX() + j2 - i, blockposition.getZ() + k2 - i);
2018-07-15 10:00:00 +10:00
+
+ if (blockposition1 != null) {
2020-06-30 10:35:28 +10:00
+ return blockposition1;
2018-07-15 10:00:00 +10:00
+ }
+ }
+ }
+
2018-03-07 21:43:33 +11:00
+ return blockposition;
2024-12-11 22:26:55 +01:00
+ }
2018-03-07 21:43:33 +11:00
+ // CraftBukkit end
2024-12-11 22:26:55 +01:00
+
2024-06-14 01:05:00 +10:00
@Override
2024-12-11 22:26:55 +01:00
public BlockPos adjustSpawnLocation(ServerLevel world, BlockPos basePos) {
AABB axisalignedbb = this.getDimensions(Pose.STANDING).makeBoundingBox(Vec3.ZERO);
BlockPos blockposition1 = basePos;
2020-07-17 08:56:56 +10:00
2024-12-11 22:26:55 +01:00
- if (world.dimensionType().hasSkyLight() && world.getServer().getWorldData().getGameType() != GameType.ADVENTURE) {
+ if (world.dimensionType().hasSkyLight() && world.serverLevelData.getGameType() != GameType.ADVENTURE) { // CraftBukkit
int i = Math.max(0, this.server.getSpawnRadius(world));
int j = Mth.floor(world.getWorldBorder().getDistanceToBorder((double) basePos.getX(), (double) basePos.getZ()));
2020-07-17 08:56:56 +10:00
2024-12-11 22:26:55 +01:00
@@ -395,14 +504,20 @@
2024-10-23 02:15:00 +11:00
2024-12-11 22:26:55 +01:00
Objects.requireNonNull(basePos);
crashreportsystemdetails.setDetail("Origin", basePos::toString);
2024-10-23 02:15:00 +11:00
+ // CraftBukkit start - decompile error
+ int finalI = i;
crashreportsystemdetails.setDetail("Radius", () -> {
- return Integer.toString(i);
+ return Integer.toString(finalI);
+ // CraftBukkit end
});
crashreportsystemdetails.setDetail("Candidate", () -> {
return "[" + l2 + "," + i3 + "]";
});
+ // CraftBukkit start - decompile error
+ int finalL1 = l1;
crashreportsystemdetails.setDetail("Progress", () -> {
- return "" + l1 + " out of " + i1;
+ return "" + finalL1 + " out of " + i1;
+ // CraftBukkit end
});
throw new ReportedException(crashreport);
}
2024-12-11 22:26:55 +01:00
@@ -440,7 +555,7 @@
dataresult = WardenSpawnTracker.CODEC.parse(new Dynamic(NbtOps.INSTANCE, nbt.get("warden_spawn_tracker")));
logger = ServerPlayer.LOGGER;
2022-12-08 03:00:00 +11:00
Objects.requireNonNull(logger);
2024-04-24 01:15:00 +10:00
- dataresult.resultOrPartial(logger::error).ifPresent((wardenspawntracker) -> {
+ ((DataResult<WardenSpawnTracker>) dataresult).resultOrPartial(logger::error).ifPresent((wardenspawntracker) -> {
this.wardenSpawnTracker = wardenspawntracker;
});
}
2024-12-11 22:26:55 +01:00
@@ -457,17 +572,26 @@
2024-10-23 02:15:00 +11:00
return this.server.getRecipeManager().byKey(resourcekey).isPresent();
});
2014-11-26 08:32:16 +11:00
}
2024-12-11 22:26:55 +01:00
+ this.getBukkitEntity().readExtraData(nbt); // CraftBukkit
2017-05-14 12:00:00 +10:00
2019-04-23 12:00:00 +10:00
if (this.isSleeping()) {
2021-11-22 09:00:00 +11:00
this.stopSleeping();
2020-06-25 10:00:00 +10:00
}
+ // CraftBukkit start
2024-12-11 22:26:55 +01:00
+ String spawnWorld = nbt.getString("SpawnWorld");
2020-06-25 10:00:00 +10:00
+ CraftWorld oldWorld = (CraftWorld) Bukkit.getWorld(spawnWorld);
+ if (oldWorld != null) {
2021-11-22 09:00:00 +11:00
+ this.respawnDimension = oldWorld.getHandle().dimension();
2020-06-25 10:00:00 +10:00
+ }
+ // CraftBukkit end
+
2024-12-11 22:26:55 +01:00
if (nbt.contains("SpawnX", 99) && nbt.contains("SpawnY", 99) && nbt.contains("SpawnZ", 99)) {
this.respawnPosition = new BlockPos(nbt.getInt("SpawnX"), nbt.getInt("SpawnY"), nbt.getInt("SpawnZ"));
this.respawnForced = nbt.getBoolean("SpawnForced");
this.respawnAngle = nbt.getFloat("SpawnAngle");
if (nbt.contains("SpawnDimension")) {
- DataResult dataresult1 = Level.RESOURCE_KEY_CODEC.parse(NbtOps.INSTANCE, nbt.get("SpawnDimension"));
+ DataResult<ResourceKey<Level>> dataresult1 = Level.RESOURCE_KEY_CODEC.parse(NbtOps.INSTANCE, nbt.get("SpawnDimension")); // CraftBukkit - decompile error
Logger logger1 = ServerPlayer.LOGGER;
2022-03-01 02:00:00 +11:00
2022-12-08 03:00:00 +11:00
Objects.requireNonNull(logger1);
2024-12-11 22:26:55 +01:00
@@ -482,7 +606,7 @@
dataresult = BlockPos.CODEC.parse(NbtOps.INSTANCE, nbtbase);
logger = ServerPlayer.LOGGER;
2024-04-24 01:15:00 +10:00
Objects.requireNonNull(logger);
- dataresult.resultOrPartial(logger::error).ifPresent((blockposition) -> {
2024-12-11 22:26:55 +01:00
+ ((DataResult<BlockPos>) dataresult).resultOrPartial(logger::error).ifPresent((blockposition) -> { // CraftBukkit - decompile error
2024-04-24 01:15:00 +10:00
this.raidOmenPosition = blockposition;
});
}
2024-12-11 22:26:55 +01:00
@@ -492,7 +616,7 @@
2022-12-08 03:00:00 +11:00
@Override
2024-12-11 22:26:55 +01:00
public void addAdditionalSaveData(CompoundTag nbt) {
super.addAdditionalSaveData(nbt);
- DataResult dataresult = WardenSpawnTracker.CODEC.encodeStart(NbtOps.INSTANCE, this.wardenSpawnTracker);
+ DataResult<Tag> dataresult = WardenSpawnTracker.CODEC.encodeStart(NbtOps.INSTANCE, this.wardenSpawnTracker); // CraftBukkit - decompile error
Logger logger = ServerPlayer.LOGGER;
2022-12-08 03:00:00 +11:00
Objects.requireNonNull(logger);
2024-12-11 22:26:55 +01:00
@@ -526,6 +650,7 @@
nbt.put("SpawnDimension", nbtbase);
2024-10-23 02:15:00 +11:00
});
}
2024-12-11 22:26:55 +01:00
+ this.getBukkitEntity().setExtraData(nbt); // CraftBukkit
2024-10-23 02:15:00 +11:00
2024-12-11 22:26:55 +01:00
nbt.putBoolean("spawn_extra_particles_on_fall", this.spawnExtraParticlesOnFall);
2024-10-23 02:15:00 +11:00
if (this.raidOmenPosition != null) {
2024-12-11 22:26:55 +01:00
@@ -544,7 +669,20 @@
2018-06-14 19:59:21 +02:00
Entity entity = this.getRootVehicle();
Entity entity1 = this.getVehicle();
2021-11-22 09:00:00 +11:00
- if (entity1 != null && entity != this && entity.hasExactlyOnePlayerPassenger()) {
2018-06-14 19:59:21 +02:00
+ // CraftBukkit start - handle non-persistent vehicles
+ boolean persistVehicle = true;
+ if (entity1 != null) {
+ Entity vehicle;
+ for (vehicle = entity1; vehicle != null; vehicle = vehicle.getVehicle()) {
+ if (!vehicle.persist) {
+ persistVehicle = false;
+ break;
+ }
+ }
+ }
+
2021-11-22 09:00:00 +11:00
+ if (persistVehicle && entity1 != null && entity != this && entity.hasExactlyOnePlayerPassenger()) {
2018-06-14 19:59:21 +02:00
+ // CraftBukkit end
2024-12-11 22:26:55 +01:00
CompoundTag nbttagcompound1 = new CompoundTag();
CompoundTag nbttagcompound2 = new CompoundTag();
2018-06-14 19:59:21 +02:00
2024-12-11 22:26:55 +01:00
@@ -598,12 +736,12 @@
2024-04-24 01:15:00 +10:00
2024-10-23 02:15:00 +11:00
if (!this.isPassenger()) {
2024-12-11 22:26:55 +01:00
ServerPlayer.LOGGER.warn("Couldn't reattach entity to player");
2024-10-23 02:15:00 +11:00
- entity.discard();
+ entity.discard(null); // CraftBukkit - add Bukkit remove cause
iterator = entity.getIndirectPassengers().iterator();
while (iterator.hasNext()) {
entity1 = (Entity) iterator.next();
- entity1.discard();
+ entity1.discard(null); // CraftBukkit - add Bukkit remove cause
}
}
}
2024-12-11 22:26:55 +01:00
@@ -625,7 +763,7 @@
CompoundTag nbttagcompound1 = new CompoundTag();
2024-10-23 02:15:00 +11:00
entityenderpearl.save(nbttagcompound1);
2024-12-11 22:26:55 +01:00
- DataResult dataresult = ResourceLocation.CODEC.encodeStart(NbtOps.INSTANCE, entityenderpearl.level().dimension().location());
+ DataResult<Tag> dataresult = ResourceLocation.CODEC.encodeStart(NbtOps.INSTANCE, entityenderpearl.level().dimension().location()); // CraftBukkit - decompile error
Logger logger = ServerPlayer.LOGGER;
2024-10-23 02:15:00 +11:00
Objects.requireNonNull(logger);
2024-12-11 22:26:55 +01:00
@@ -651,7 +789,7 @@
2024-10-23 02:15:00 +11:00
nbttaglist.forEach((nbtbase1) -> {
2024-12-11 22:26:55 +01:00
if (nbtbase1 instanceof CompoundTag nbttagcompound) {
2024-10-23 02:15:00 +11:00
if (nbttagcompound.contains("ender_pearl_dimension")) {
2024-12-11 22:26:55 +01:00
- DataResult dataresult = Level.RESOURCE_KEY_CODEC.parse(NbtOps.INSTANCE, nbttagcompound.get("ender_pearl_dimension"));
+ DataResult<ResourceKey<Level>> dataresult = Level.RESOURCE_KEY_CODEC.parse(NbtOps.INSTANCE, nbttagcompound.get("ender_pearl_dimension")); // CraftBukkit - decompile error
Logger logger = ServerPlayer.LOGGER;
2024-10-23 02:15:00 +11:00
Objects.requireNonNull(logger);
2024-12-11 22:26:55 +01:00
@@ -684,7 +822,30 @@
}
}
2020-06-25 10:00:00 +10:00
2024-12-11 22:26:55 +01:00
+ }
+
2014-11-26 08:32:16 +11:00
+ // CraftBukkit start - World fallback code, either respawn location or global spawn
2024-12-11 22:26:55 +01:00
+ public void spawnIn(Level world) {
2023-06-08 01:30:00 +10:00
+ this.setLevel(world);
2014-11-26 08:32:16 +11:00
+ if (world == null) {
2021-06-11 15:00:00 +10:00
+ this.unsetRemoved();
2024-12-11 22:26:55 +01:00
+ Vec3 position = null;
2021-06-11 15:00:00 +10:00
+ if (this.respawnDimension != null) {
2023-04-19 19:59:19 +10:00
+ world = this.server.getLevel(this.respawnDimension);
2021-11-22 09:00:00 +11:00
+ if (world != null && this.getRespawnPosition() != null) {
2024-12-11 22:26:55 +01:00
+ position = ServerPlayer.findRespawnAndUseSpawnBlock((ServerLevel) world, this.getRespawnPosition(), this.getRespawnAngle(), false, false).map(ServerPlayer.RespawnPosAngle::position).orElse(null);
2014-11-26 08:32:16 +11:00
+ }
+ }
+ if (world == null || position == null) {
+ world = ((CraftWorld) Bukkit.getServer().getWorlds().get(0)).getHandle();
2024-12-11 22:26:55 +01:00
+ position = Vec3.atCenterOf(world.getSharedSpawnPos());
2014-11-26 08:32:16 +11:00
+ }
2023-06-08 01:30:00 +10:00
+ this.setLevel(world);
2023-04-19 19:59:19 +10:00
+ this.setPos(position);
2014-11-26 08:32:16 +11:00
+ }
2024-12-11 22:26:55 +01:00
+ this.gameMode.setLevel((ServerLevel) world);
}
2014-11-26 08:32:16 +11:00
+ // CraftBukkit end
2024-12-11 22:26:55 +01:00
public void setExperiencePoints(int points) {
2021-11-22 09:00:00 +11:00
float f = (float) this.getXpNeededForNextLevel();
2024-12-11 22:26:55 +01:00
@@ -744,6 +905,11 @@
2014-11-26 08:32:16 +11:00
2019-04-23 12:00:00 +10:00
@Override
2018-07-15 10:00:00 +10:00
public void tick() {
2014-11-26 08:32:16 +11:00
+ // CraftBukkit start
+ if (this.joining) {
+ this.joining = false;
+ }
+ // CraftBukkit end
2024-12-04 03:20:00 +11:00
this.tickClientLoadTimeout();
2021-11-22 09:00:00 +11:00
this.gameMode.tick();
2022-12-08 03:00:00 +11:00
this.wardenSpawnTracker.tick();
2024-12-11 22:26:55 +01:00
@@ -820,7 +986,7 @@
2016-03-06 08:38:01 +11:00
}
2021-06-11 15:00:00 +10:00
if (this.getHealth() != this.lastSentHealth || this.lastSentFood != this.foodData.getFoodLevel() || this.foodData.getSaturationLevel() == 0.0F != this.lastFoodSaturationZero) {
2024-12-11 22:26:55 +01:00
- this.connection.send(new ClientboundSetHealthPacket(this.getHealth(), this.foodData.getFoodLevel(), this.foodData.getSaturationLevel()));
+ this.connection.send(new ClientboundSetHealthPacket(this.getBukkitEntity().getScaledHealth(), this.foodData.getFoodLevel(), this.foodData.getSaturationLevel())); // CraftBukkit
2021-06-11 15:00:00 +10:00
this.lastSentHealth = this.getHealth();
this.lastSentFood = this.foodData.getFoodLevel();
this.lastFoodSaturationZero = this.foodData.getSaturationLevel() == 0.0F;
2024-12-11 22:26:55 +01:00
@@ -851,6 +1017,12 @@
this.updateScoreForCriteria(ObjectiveCriteria.EXPERIENCE, Mth.ceil((float) this.lastRecordedExperience));
2014-11-26 08:32:16 +11:00
}
+ // CraftBukkit start - Force max health updates
+ if (this.maxHealthCache != this.getMaxHealth()) {
+ this.getBukkitEntity().updateScaledHealth();
2016-06-09 11:43:49 +10:00
+ }
2014-11-26 08:32:16 +11:00
+ // CraftBukkit end
2016-06-09 11:43:49 +10:00
+
2021-06-11 15:00:00 +10:00
if (this.experienceLevel != this.lastRecordedLevel) {
this.lastRecordedLevel = this.experienceLevel;
2024-12-11 22:26:55 +01:00
this.updateScoreForCriteria(ObjectiveCriteria.LEVEL, Mth.ceil((float) this.lastRecordedLevel));
@@ -863,8 +1035,22 @@
2015-02-26 22:41:06 +00:00
2024-12-11 22:26:55 +01:00
if (this.tickCount % 20 == 0) {
CriteriaTriggers.LOCATION.trigger(this);
+ }
+
2022-04-09 09:39:33 +10:00
+ // CraftBukkit start - initialize oldLevel, fire PlayerLevelChangeEvent, and tick client-sided world border
2014-11-26 08:32:16 +11:00
+ if (this.oldLevel == -1) {
2021-06-11 15:00:00 +10:00
+ this.oldLevel = this.experienceLevel;
2024-12-11 22:26:55 +01:00
}
2021-06-11 15:00:00 +10:00
+ if (this.oldLevel != this.experienceLevel) {
2021-06-20 09:27:32 +10:00
+ CraftEventFactory.callPlayerLevelChangeEvent(this.getBukkitEntity(), this.oldLevel, this.experienceLevel);
2021-06-11 15:00:00 +10:00
+ this.oldLevel = this.experienceLevel;
2014-11-26 08:32:16 +11:00
+ }
2022-04-09 09:39:33 +10:00
+
+ if (this.getBukkitEntity().hasClientWorldBorder()) {
+ ((CraftWorldBorder) this.getBukkitEntity().getWorldBorder()).getHandle().tick();
+ }
2015-02-26 22:41:06 +00:00
+ // CraftBukkit end
2014-11-26 08:32:16 +11:00
} catch (Throwable throwable) {
2021-11-22 09:00:00 +11:00
CrashReport crashreport = CrashReport.forThrowable(throwable, "Ticking player");
2024-12-11 22:26:55 +01:00
CrashReportCategory crashreportsystemdetails = crashreport.addCategory("Player being ticked");
@@ -893,7 +1079,7 @@
if (this.level().getDifficulty() == Difficulty.PEACEFUL && this.serverLevel().getGameRules().getBoolean(GameRules.RULE_NATURAL_REGENERATION)) {
2024-10-23 02:15:00 +11:00
if (this.tickCount % 20 == 0) {
if (this.getHealth() < this.getMaxHealth()) {
- this.heal(1.0F);
+ this.heal(1.0F, org.bukkit.event.entity.EntityRegainHealthEvent.RegainReason.REGEN); // CraftBukkit - added regain reason of "REGEN" for filtering purposes.
}
float f = this.foodData.getSaturationLevel();
2024-12-11 22:26:55 +01:00
@@ -946,7 +1132,8 @@
2016-03-12 17:57:40 +11:00
}
2024-12-11 22:26:55 +01:00
private void updateScoreForCriteria(ObjectiveCriteria criterion, int score) {
- this.getScoreboard().forAllObjectives(criterion, this, (scoreaccess) -> {
2018-07-15 10:00:00 +10:00
+ // CraftBukkit - Use our scores instead
2024-12-11 22:26:55 +01:00
+ this.level().getCraftServer().getScoreboardManager().forAllObjectives(criterion, this, (scoreaccess) -> {
scoreaccess.set(score);
2018-07-15 10:00:00 +10:00
});
}
2024-12-11 22:26:55 +01:00
@@ -955,10 +1142,48 @@
public void die(DamageSource damageSource) {
2022-06-08 02:00:00 +10:00
this.gameEvent(GameEvent.ENTITY_DIE);
2024-10-23 02:15:00 +11:00
boolean flag = this.serverLevel().getGameRules().getBoolean(GameRules.RULE_SHOWDEATHMESSAGES);
2014-11-26 08:32:16 +11:00
+ // CraftBukkit start - fire PlayerDeathEvent
2021-06-11 15:00:00 +10:00
+ if (this.isRemoved()) {
2014-11-26 08:32:16 +11:00
+ return;
+ }
2024-06-29 14:03:10 +10:00
+ java.util.List<org.bukkit.inventory.ItemStack> loot = new java.util.ArrayList<>(this.getInventory().getContainerSize());
2024-10-23 02:15:00 +11:00
+ boolean keepInventory = this.serverLevel().getGameRules().getBoolean(GameRules.RULE_KEEPINVENTORY) || this.isSpectator();
2023-09-22 02:57:13 +10:00
- if (flag) {
2024-12-11 22:26:55 +01:00
- Component ichatbasecomponent = this.getCombatTracker().getDeathMessage();
2014-11-26 08:32:16 +11:00
+ if (!keepInventory) {
2021-06-11 15:00:00 +10:00
+ for (ItemStack item : this.getInventory().getContents()) {
2024-12-11 22:26:55 +01:00
+ if (!item.isEmpty() && !EnchantmentHelper.has(item, EnchantmentEffectComponents.PREVENT_EQUIPMENT_DROP)) {
2024-07-06 17:25:39 +10:00
+ loot.add(CraftItemStack.asCraftMirror(item).markForInventoryDrop());
2016-03-01 08:32:46 +11:00
+ }
2014-11-26 08:32:16 +11:00
+ }
2019-07-22 12:12:48 +10:00
+ }
+ // SPIGOT-5071: manually add player loot tables (SPIGOT-5195 - ignores keepInventory rule)
2024-12-11 22:26:55 +01:00
+ this.dropFromLootTable(this.serverLevel(), damageSource, this.lastHurtByPlayerTime > 0);
+ this.dropCustomDeathLoot(this.serverLevel(), damageSource, flag);
2024-06-29 14:03:10 +10:00
+ loot.addAll(this.drops);
2019-07-22 12:12:48 +10:00
+ this.drops.clear(); // SPIGOT-5188: make sure to clear
2023-09-22 02:57:13 +10:00
+
2024-12-11 22:26:55 +01:00
+ Component defaultMessage = this.getCombatTracker().getDeathMessage();
2018-06-14 19:59:21 +02:00
+
2018-08-26 12:00:00 +10:00
+ String deathmessage = defaultMessage.getString();
2024-12-11 22:26:55 +01:00
+ this.keepLevel = keepInventory; // SPIGOT-2222: pre-set keepLevel
+ org.bukkit.event.entity.PlayerDeathEvent event = CraftEventFactory.callPlayerDeathEvent(this, damageSource, loot, deathmessage, keepInventory);
2018-08-26 12:00:00 +10:00
+
2018-12-27 11:36:53 +11:00
+ // SPIGOT-943 - only call if they have an inventory open
2021-06-11 15:00:00 +10:00
+ if (this.containerMenu != this.inventoryMenu) {
2021-11-22 09:00:00 +11:00
+ this.closeContainer();
2018-12-27 11:36:53 +11:00
+ }
+
2014-11-26 08:32:16 +11:00
+ String deathMessage = event.getDeathMessage();
+
2016-03-01 08:32:46 +11:00
+ if (deathMessage != null && deathMessage.length() > 0 && flag) { // TODO: allow plugins to override?
2024-12-11 22:26:55 +01:00
+ Component ichatbasecomponent;
2014-11-26 08:32:16 +11:00
+ if (deathMessage.equals(deathmessage)) {
2018-08-26 12:00:00 +10:00
+ ichatbasecomponent = this.getCombatTracker().getDeathMessage();
+ } else {
+ ichatbasecomponent = org.bukkit.craftbukkit.util.CraftChatMessage.fromStringOrNull(deathMessage);
+ }
2024-12-11 22:26:55 +01:00
+
2023-06-08 01:30:00 +10:00
this.connection.send(new ClientboundPlayerCombatKillPacket(this.getId(), ichatbasecomponent), PacketSendListener.exceptionallySend(() -> {
2022-07-28 04:00:00 +10:00
boolean flag1 = true;
2024-12-11 22:26:55 +01:00
String s = ichatbasecomponent.getString(256);
@@ -988,12 +1213,18 @@
2024-10-23 02:15:00 +11:00
if (this.serverLevel().getGameRules().getBoolean(GameRules.RULE_FORGIVE_DEAD_PLAYERS)) {
2021-11-22 09:00:00 +11:00
this.tellNeutralMobsThatIDied();
2014-11-26 08:32:16 +11:00
}
2020-06-25 10:00:00 +10:00
-
2019-04-23 12:00:00 +10:00
- if (!this.isSpectator()) {
2024-12-11 22:26:55 +01:00
- this.dropAllDeathLoot(this.serverLevel(), damageSource);
2019-12-24 14:07:25 +11:00
+ // SPIGOT-5478 must be called manually now
2024-12-11 22:26:55 +01:00
+ this.dropExperience(this.serverLevel(), damageSource.getEntity());
2014-11-26 08:32:16 +11:00
+ // we clean the player's inventory after the EntityDeathEvent is called so plugins can get the exact state of the inventory.
+ if (!event.getKeepInventory()) {
2021-11-22 09:00:00 +11:00
+ this.getInventory().clearContent();
2019-04-23 14:00:30 +10:00
}
2018-12-27 11:36:53 +11:00
2024-12-11 22:26:55 +01:00
- this.getScoreboard().forAllObjectives(ObjectiveCriteria.DEATH_COUNT, this, ScoreAccess::increment);
2021-11-22 09:00:00 +11:00
+ this.setCamera(this); // Remove spectated target
2019-04-23 14:00:30 +10:00
+ // CraftBukkit end
+
2014-11-26 08:32:16 +11:00
+ // CraftBukkit - Get our scores instead
2024-12-11 22:26:55 +01:00
+ this.level().getCraftServer().getScoreboardManager().forAllObjectives(ObjectiveCriteria.DEATH_COUNT, this, ScoreAccess::increment);
LivingEntity entityliving = this.getKillCredit();
2014-11-26 08:32:16 +11:00
2018-07-15 10:00:00 +10:00
if (entityliving != null) {
2024-12-11 22:26:55 +01:00
@@ -1028,10 +1259,12 @@
public void awardKillScore(Entity entityKilled, DamageSource damageSource) {
if (entityKilled != this) {
super.awardKillScore(entityKilled, damageSource);
- this.getScoreboard().forAllObjectives(ObjectiveCriteria.KILL_COUNT_ALL, this, ScoreAccess::increment);
- if (entityKilled instanceof Player) {
2017-05-14 12:00:00 +10:00
+ // CraftBukkit - Get our scores instead
2024-12-11 22:26:55 +01:00
+ this.level().getCraftServer().getScoreboardManager().forAllObjectives(ObjectiveCriteria.KILL_COUNT_ALL, this, ScoreAccess::increment);
+ if (entityKilled instanceof net.minecraft.world.entity.player.Player) {
this.awardStat(Stats.PLAYER_KILLS);
- this.getScoreboard().forAllObjectives(ObjectiveCriteria.KILL_COUNT_PLAYERS, this, ScoreAccess::increment);
2017-05-14 12:00:00 +10:00
+ // CraftBukkit - Get our scores instead
2024-12-11 22:26:55 +01:00
+ this.level().getCraftServer().getScoreboardManager().forAllObjectives(ObjectiveCriteria.KILL_COUNT_PLAYERS, this, ScoreAccess::increment);
2017-05-14 12:00:00 +10:00
} else {
2024-12-11 22:26:55 +01:00
this.awardStat(Stats.MOB_KILLS);
2017-05-14 12:00:00 +10:00
}
2024-12-11 22:26:55 +01:00
@@ -1049,7 +1282,8 @@
2021-11-22 09:00:00 +11:00
int i = scoreboardteam.getColor().getId();
2017-05-14 12:00:00 +10:00
2024-12-11 22:26:55 +01:00
if (i >= 0 && i < criterions.length) {
- this.getScoreboard().forAllObjectives(criterions[i], targetScoreHolder, ScoreAccess::increment);
2017-05-14 12:00:00 +10:00
+ // CraftBukkit - Get our scores instead
2024-12-11 22:26:55 +01:00
+ this.level().getCraftServer().getScoreboardManager().forAllObjectives(criterions[i], targetScoreHolder, ScoreAccess::increment);
2017-05-14 12:00:00 +10:00
}
}
2024-12-11 22:26:55 +01:00
@@ -1062,8 +1296,8 @@
} else {
Entity entity = source.getEntity();
- if (entity instanceof Player) {
- Player entityhuman = (Player) entity;
+ if (entity instanceof net.minecraft.world.entity.player.Player) {
+ net.minecraft.world.entity.player.Player entityhuman = (net.minecraft.world.entity.player.Player) entity;
if (!this.canHarmPlayer(entityhuman)) {
return false;
@@ -1074,8 +1308,8 @@
AbstractArrow entityarrow = (AbstractArrow) entity;
Entity entity1 = entityarrow.getOwner();
- if (entity1 instanceof Player) {
- Player entityhuman1 = (Player) entity1;
+ if (entity1 instanceof net.minecraft.world.entity.player.Player) {
+ net.minecraft.world.entity.player.Player entityhuman1 = (net.minecraft.world.entity.player.Player) entity1;
if (!this.canHarmPlayer(entityhuman1)) {
return false;
@@ -1088,33 +1322,58 @@
}
@Override
- public boolean canHarmPlayer(Player player) {
+ public boolean canHarmPlayer(net.minecraft.world.entity.player.Player player) {
return !this.isPvpAllowed() ? false : super.canHarmPlayer(player);
2014-11-26 08:32:16 +11:00
}
2021-11-22 09:00:00 +11:00
private boolean isPvpAllowed() {
- return this.server.isPvpAllowed();
+ // CraftBukkit - this.server.isPvpAllowed() -> this.world.pvpMode
2023-06-08 01:30:00 +10:00
+ return this.level().pvpMode;
2014-11-26 08:32:16 +11:00
}
2024-12-11 22:26:55 +01:00
- public TeleportTransition findRespawnPositionAndUseSpawnBlock(boolean alive, TeleportTransition.PostTeleportTransition postDimensionTransition) {
2024-06-14 01:05:00 +10:00
+ // CraftBukkit start
2024-12-11 22:26:55 +01:00
+ public TeleportTransition findRespawnPositionAndUseSpawnBlock(boolean flag, TeleportTransition.PostTeleportTransition teleporttransition_a, PlayerRespawnEvent.RespawnReason reason) {
2024-10-23 02:15:00 +11:00
+ TeleportTransition teleportTransition;
2024-06-14 01:05:00 +10:00
+ boolean isBedSpawn = false;
+ boolean isAnchorSpawn = false;
+ // CraftBukkit end
2024-12-11 22:26:55 +01:00
BlockPos blockposition = this.getRespawnPosition();
2024-06-14 01:05:00 +10:00
float f = this.getRespawnAngle();
boolean flag1 = this.isRespawnForced();
2024-12-11 22:26:55 +01:00
ServerLevel worldserver = this.server.getLevel(this.getRespawnDimension());
if (worldserver != null && blockposition != null) {
- Optional<ServerPlayer.RespawnPosAngle> optional = ServerPlayer.findRespawnAndUseSpawnBlock(worldserver, blockposition, f, flag1, alive);
+ Optional<ServerPlayer.RespawnPosAngle> optional = ServerPlayer.findRespawnAndUseSpawnBlock(worldserver, blockposition, f, flag1, flag);
2024-06-14 01:05:00 +10:00
if (optional.isPresent()) {
2024-12-11 22:26:55 +01:00
ServerPlayer.RespawnPosAngle entityplayer_respawnposangle = (ServerPlayer.RespawnPosAngle) optional.get();
2024-06-14 01:05:00 +10:00
2024-12-11 22:26:55 +01:00
- return new TeleportTransition(worldserver, entityplayer_respawnposangle.position(), Vec3.ZERO, entityplayer_respawnposangle.yaw(), 0.0F, postDimensionTransition);
2024-06-14 01:05:00 +10:00
+ // CraftBukkit start
+ isBedSpawn = entityplayer_respawnposangle.isBedSpawn();
+ isAnchorSpawn = entityplayer_respawnposangle.isAnchorSpawn();
2024-12-11 22:26:55 +01:00
+ teleportTransition = new TeleportTransition(worldserver, entityplayer_respawnposangle.position(), Vec3.ZERO, entityplayer_respawnposangle.yaw(), 0.0F, teleporttransition_a);
2024-06-14 01:05:00 +10:00
+ // CraftBukkit end
} else {
2024-12-11 22:26:55 +01:00
- return TeleportTransition.missingRespawnBlock(this.server.overworld(), this, postDimensionTransition);
2024-10-23 02:15:00 +11:00
+ teleportTransition = TeleportTransition.missingRespawnBlock(this.server.overworld(), this, teleporttransition_a); // CraftBukkit
2024-06-14 01:05:00 +10:00
}
2020-08-12 07:00:00 +10:00
} else {
2024-12-11 22:26:55 +01:00
- return new TeleportTransition(this.server.overworld(), this, postDimensionTransition);
2024-10-23 02:15:00 +11:00
+ teleportTransition = new TeleportTransition(this.server.overworld(), this, teleporttransition_a); // CraftBukkit
2024-07-06 17:25:39 +10:00
}
2019-04-23 12:00:00 +10:00
+ // CraftBukkit start
2024-06-14 01:05:00 +10:00
+ if (reason == null) {
2024-10-23 02:15:00 +11:00
+ return teleportTransition;
2024-07-06 17:25:39 +10:00
+ }
2019-04-23 12:00:00 +10:00
+
2024-06-14 01:05:00 +10:00
+ Player respawnPlayer = this.getBukkitEntity();
2024-10-23 02:15:00 +11:00
+ Location location = CraftLocation.toBukkit(teleportTransition.position(), teleportTransition.newLevel().getWorld(), teleportTransition.yRot(), teleportTransition.xRot());
2024-06-14 01:05:00 +10:00
+
+ PlayerRespawnEvent respawnEvent = new PlayerRespawnEvent(respawnPlayer, location, isBedSpawn, isAnchorSpawn, reason);
+ this.level().getCraftServer().getPluginManager().callEvent(respawnEvent);
+
+ location = respawnEvent.getRespawnLocation();
+
2024-10-23 02:15:00 +11:00
+ return new TeleportTransition(((CraftWorld) location.getWorld()).getHandle(), CraftLocation.toVec3D(location), teleportTransition.deltaMovement(), location.getYaw(), location.getPitch(), teleportTransition.missingRespawnBlock(), teleportTransition.asPassenger(), teleportTransition.relatives(), teleportTransition.postTeleportTransition(), teleportTransition.cause());
2019-04-23 12:00:00 +10:00
+ // CraftBukkit end
2024-06-14 01:05:00 +10:00
}
2019-12-11 12:36:03 +11:00
2024-12-11 22:26:55 +01:00
public static Optional<ServerPlayer.RespawnPosAngle> findRespawnAndUseSpawnBlock(ServerLevel world, BlockPos pos, float spawnAngle, boolean spawnForced, boolean alive) {
@@ -1129,11 +1388,11 @@
2024-06-14 01:05:00 +10:00
}
2020-08-12 07:00:00 +10:00
2024-06-14 01:05:00 +10:00
return optional.map((vec3d) -> {
2024-12-11 22:26:55 +01:00
- return ServerPlayer.RespawnPosAngle.of(vec3d, pos);
+ return ServerPlayer.RespawnPosAngle.of(vec3d, pos, false, true); // CraftBukkit
2024-06-14 01:05:00 +10:00
});
2024-12-11 22:26:55 +01:00
} else if (block instanceof BedBlock && BedBlock.canSetSpawn(world)) {
return BedBlock.findStandUpPosition(EntityType.PLAYER, world, pos, (Direction) iblockdata.getValue(BedBlock.FACING), spawnAngle).map((vec3d) -> {
- return ServerPlayer.RespawnPosAngle.of(vec3d, pos);
+ return ServerPlayer.RespawnPosAngle.of(vec3d, pos, true, false); // CraftBukkit
2024-06-14 01:05:00 +10:00
});
2024-12-11 22:26:55 +01:00
} else if (!spawnForced) {
2024-06-14 01:05:00 +10:00
return Optional.empty();
2024-12-11 22:26:55 +01:00
@@ -1142,7 +1401,7 @@
BlockState iblockdata1 = world.getBlockState(pos.above());
2024-06-14 01:05:00 +10:00
boolean flag3 = iblockdata1.getBlock().isPossibleToRespawnInThis(iblockdata1);
2024-12-11 22:26:55 +01:00
- return flag2 && flag3 ? Optional.of(new ServerPlayer.RespawnPosAngle(new Vec3((double) pos.getX() + 0.5D, (double) pos.getY() + 0.1D, (double) pos.getZ() + 0.5D), spawnAngle)) : Optional.empty();
+ return flag2 && flag3 ? Optional.of(new ServerPlayer.RespawnPosAngle(new Vec3((double) pos.getX() + 0.5D, (double) pos.getY() + 0.1D, (double) pos.getZ() + 0.5D), spawnAngle, false, false)) : Optional.empty(); // CraftBukkit
2024-06-14 01:05:00 +10:00
}
}
2024-12-11 22:26:55 +01:00
@@ -1160,6 +1419,7 @@
2024-06-14 01:05:00 +10:00
@Nullable
@Override
2024-12-11 22:26:55 +01:00
public ServerPlayer teleport(TeleportTransition teleportTarget) {
2024-06-14 01:05:00 +10:00
+ if (this.isSleeping()) return null; // CraftBukkit - SPIGOT-3154
if (this.isRemoved()) {
return null;
} else {
2024-12-11 22:26:55 +01:00
@@ -1169,39 +1429,73 @@
2024-06-14 01:05:00 +10:00
2024-12-11 22:26:55 +01:00
ServerLevel worldserver = teleportTarget.newLevel();
ServerLevel worldserver1 = this.serverLevel();
- ResourceKey<Level> resourcekey = worldserver1.dimension();
2024-06-14 01:05:00 +10:00
+ // CraftBukkit start
2024-12-11 22:26:55 +01:00
+ ResourceKey<LevelStem> resourcekey = worldserver1.getTypeKey();
2024-10-23 02:15:00 +11:00
+ Location enter = this.getBukkitEntity().getLocation();
2024-12-11 22:26:55 +01:00
+ PositionMoveRotation absolutePosition = PositionMoveRotation.calculateAbsolute(PositionMoveRotation.of(this), PositionMoveRotation.of(teleportTarget), teleportTarget.relatives());
2024-10-23 02:15:00 +11:00
+ Location exit = (worldserver == null) ? null : CraftLocation.toBukkit(absolutePosition.position(), worldserver.getWorld(), absolutePosition.yRot(), absolutePosition.xRot());
2024-12-11 22:26:55 +01:00
+ PlayerTeleportEvent tpEvent = new PlayerTeleportEvent(this.getBukkitEntity(), enter, exit, teleportTarget.cause());
2024-10-23 02:15:00 +11:00
+ Bukkit.getServer().getPluginManager().callEvent(tpEvent);
+ Location newExit = tpEvent.getTo();
+ if (tpEvent.isCancelled() || newExit == null) {
+ return null;
+ }
+ if (!newExit.equals(exit)) {
+ worldserver = ((CraftWorld) newExit.getWorld()).getHandle();
2024-12-11 22:26:55 +01:00
+ teleportTarget = new TeleportTransition(worldserver, CraftLocation.toVec3D(newExit), Vec3.ZERO, newExit.getYaw(), newExit.getPitch(), teleportTarget.missingRespawnBlock(), teleportTarget.asPassenger(), Set.of(), teleportTarget.postTeleportTransition(), teleportTarget.cause());
2024-10-23 02:15:00 +11:00
+ }
+ // CraftBukkit end
2024-12-11 22:26:55 +01:00
+
if (!teleportTarget.asPassenger()) {
2024-10-23 02:15:00 +11:00
this.stopRiding();
}
2024-06-14 01:05:00 +10:00
- if (worldserver.dimension() == resourcekey) {
2024-12-11 22:26:55 +01:00
- this.connection.teleport(PositionMoveRotation.of(teleportTarget), teleportTarget.relatives());
2024-10-23 02:15:00 +11:00
+ // CraftBukkit start
+ if (worldserver != null && worldserver.dimension() == worldserver1.dimension()) {
2024-12-11 22:26:55 +01:00
+ this.connection.internalTeleport(PositionMoveRotation.of(teleportTarget), teleportTarget.relatives());
2024-06-14 01:05:00 +10:00
+ // CraftBukkit end
this.connection.resetPosition();
2024-12-11 22:26:55 +01:00
teleportTarget.postTeleportTransition().onTransition(this);
2024-06-14 01:05:00 +10:00
return this;
} else {
+ // CraftBukkit start
+ /*
this.isChangingDimension = true;
2024-12-11 22:26:55 +01:00
- LevelData worlddata = worldserver.getLevelData();
+ WorldData worlddata = worldserver.getLevelData();
- this.connection.send(new ClientboundRespawnPacket(this.createCommonSpawnInfo(worldserver), (byte) 3));
- this.connection.send(new ClientboundChangeDifficultyPacket(worlddata.getDifficulty(), worlddata.isDifficultyLocked()));
+ this.connection.send(new PacketPlayOutRespawn(this.createCommonSpawnInfo(worldserver), (byte) 3));
+ this.connection.send(new PacketPlayOutServerDifficulty(worlddata.getDifficulty(), worlddata.isDifficultyLocked()));
PlayerList playerlist = this.server.getPlayerList();
2024-06-14 01:05:00 +10:00
playerlist.sendPlayerPermissionLevel(this);
worldserver1.removePlayerImmediately(this, Entity.RemovalReason.CHANGED_DIMENSION);
this.unsetRemoved();
+ */
+ // CraftBukkit end
2024-12-11 22:26:55 +01:00
ProfilerFiller gameprofilerfiller = Profiler.get();
2024-10-23 02:15:00 +11:00
gameprofilerfiller.push("moving");
2024-12-11 22:26:55 +01:00
- if (resourcekey == Level.OVERWORLD && worldserver.dimension() == Level.NETHER) {
+ if (worldserver != null && resourcekey == LevelStem.OVERWORLD && worldserver.getTypeKey() == LevelStem.NETHER) { // CraftBukkit - empty to fall through to null to event
2021-11-22 09:00:00 +11:00
this.enteredNetherPosition = this.position();
2020-06-25 10:00:00 +10:00
}
2023-09-22 02:57:13 +10:00
2024-10-23 02:15:00 +11:00
gameprofilerfiller.pop();
gameprofilerfiller.push("placing");
2024-06-14 01:05:00 +10:00
+ // CraftBukkit start
2021-06-11 15:00:00 +10:00
+ this.isChangingDimension = true; // CraftBukkit - Set teleport invulnerability only if player changing worlds
2024-12-11 22:26:55 +01:00
+ LevelData worlddata = worldserver.getLevelData();
2020-01-12 01:02:13 +01:00
+
2024-12-11 22:26:55 +01:00
+ this.connection.send(new ClientboundRespawnPacket(this.createCommonSpawnInfo(worldserver), (byte) 3));
+ this.connection.send(new ClientboundChangeDifficultyPacket(worlddata.getDifficulty(), worlddata.isDifficultyLocked()));
2020-08-12 07:00:00 +10:00
+ PlayerList playerlist = this.server.getPlayerList();
2020-01-12 01:02:13 +01:00
+
2021-11-22 09:00:00 +11:00
+ playerlist.sendPlayerPermissionLevel(this);
+ worldserver1.removePlayerImmediately(this, Entity.RemovalReason.CHANGED_DIMENSION);
2021-06-11 15:00:00 +10:00
+ this.unsetRemoved();
2020-08-12 07:00:00 +10:00
+ // CraftBukkit end
2023-06-08 01:30:00 +10:00
this.setServerLevel(worldserver);
2024-12-11 22:26:55 +01:00
- this.connection.teleport(PositionMoveRotation.of(teleportTarget), teleportTarget.relatives());
+ this.connection.internalTeleport(PositionMoveRotation.of(teleportTarget), teleportTarget.relatives()); // CraftBukkit - use internal teleport without event
2022-12-08 03:00:00 +11:00
this.connection.resetPosition();
2024-06-14 01:05:00 +10:00
worldserver.addDuringTeleport(this);
2024-10-23 02:15:00 +11:00
gameprofilerfiller.pop();
2024-12-11 22:26:55 +01:00
@@ -1215,12 +1509,30 @@
2020-08-12 07:00:00 +10:00
this.lastSentExp = -1;
2021-06-11 15:00:00 +10:00
this.lastSentHealth = -1.0F;
this.lastSentFood = -1;
2020-08-12 07:00:00 +10:00
+
+ // CraftBukkit start
+ PlayerChangedWorldEvent changeEvent = new PlayerChangedWorldEvent(this.getBukkitEntity(), worldserver1.getWorld());
2023-06-08 01:30:00 +10:00
+ this.level().getCraftServer().getPluginManager().callEvent(changeEvent);
2020-08-12 07:00:00 +10:00
+ // CraftBukkit end
2024-06-14 01:05:00 +10:00
return this;
2020-08-12 07:00:00 +10:00
}
2020-08-14 08:26:40 +10:00
}
}
+ // CraftBukkit start
2024-12-11 22:26:55 +01:00
@Override
2024-06-14 01:05:00 +10:00
+ public CraftPortalEvent callPortalEvent(Entity entity, Location exit, TeleportCause cause, int searchRadius, int creationRadius) {
2020-08-14 08:26:40 +10:00
+ Location enter = this.getBukkitEntity().getLocation();
2020-11-13 18:06:34 +11:00
+ PlayerPortalEvent event = new PlayerPortalEvent(this.getBukkitEntity(), enter, exit, cause, searchRadius, true, creationRadius);
2020-08-14 08:26:40 +10:00
+ Bukkit.getServer().getPluginManager().callEvent(event);
+ if (event.isCancelled() || event.getTo() == null || event.getTo().getWorld() == null) {
+ return null;
+ }
+ return new CraftPortalEvent(event);
+ }
+ // CraftBukkit end
+
2024-12-11 22:26:55 +01:00
+ @Override
public void forceSetRotation(float yaw, float pitch) {
this.connection.send(new ClientboundPlayerRotationPacket(yaw, pitch));
}
@@ -1228,13 +1540,21 @@
public void triggerDimensionChangeTriggers(ServerLevel origin) {
ResourceKey<Level> resourcekey = origin.dimension();
ResourceKey<Level> resourcekey1 = this.level().dimension();
2021-05-15 10:06:25 +10:00
+ // CraftBukkit start
2024-12-11 22:26:55 +01:00
+ ResourceKey<Level> maindimensionkey = CraftDimensionUtil.getMainDimensionKey(origin);
+ ResourceKey<Level> maindimensionkey1 = CraftDimensionUtil.getMainDimensionKey(this.level());
2023-09-22 02:57:13 +10:00
2024-12-11 22:26:55 +01:00
- CriteriaTriggers.CHANGED_DIMENSION.trigger(this, resourcekey, resourcekey1);
- if (resourcekey == Level.NETHER && resourcekey1 == Level.OVERWORLD && this.enteredNetherPosition != null) {
+ CriteriaTriggers.CHANGED_DIMENSION.trigger(this, maindimensionkey, maindimensionkey1);
2021-05-15 10:06:25 +10:00
+ if (maindimensionkey != resourcekey || maindimensionkey1 != resourcekey1) {
2024-12-11 22:26:55 +01:00
+ CriteriaTriggers.CHANGED_DIMENSION.trigger(this, resourcekey, resourcekey1);
2021-05-15 10:06:25 +10:00
+ }
2023-09-22 02:57:13 +10:00
+
2024-12-11 22:26:55 +01:00
+ if (maindimensionkey == Level.NETHER && maindimensionkey1 == Level.OVERWORLD && this.enteredNetherPosition != null) {
2021-05-15 10:06:25 +10:00
+ // CraftBukkit end
2024-12-11 22:26:55 +01:00
CriteriaTriggers.NETHER_TRAVEL.trigger(this, this.enteredNetherPosition);
2021-05-15 10:06:25 +10:00
}
2024-12-11 22:26:55 +01:00
- if (resourcekey1 != Level.NETHER) {
+ if (maindimensionkey1 != Level.NETHER) { // CraftBukkit
2021-06-11 15:00:00 +10:00
this.enteredNetherPosition = null;
2021-05-15 10:06:25 +10:00
}
2024-12-11 22:26:55 +01:00
@@ -1251,36 +1571,63 @@
2021-11-22 09:00:00 +11:00
this.containerMenu.broadcastChanges();
2019-03-13 04:48:19 +01:00
}
2019-04-23 12:00:00 +10:00
- @Override
2024-12-11 22:26:55 +01:00
- public Either<Player.BedSleepingProblem, Unit> startSleepInBed(BlockPos pos) {
- Direction enumdirection = (Direction) this.level().getBlockState(pos).getValue(HorizontalDirectionalBlock.FACING);
2020-06-25 10:00:00 +10:00
-
+ // CraftBukkit start - moved bed result checks from below into separate method
2024-12-11 22:26:55 +01:00
+ private Either<net.minecraft.world.entity.player.Player.BedSleepingProblem, Unit> getBedResult(BlockPos blockposition, Direction enumdirection) {
2020-06-25 10:00:00 +10:00
if (!this.isSleeping() && this.isAlive()) {
2023-06-08 01:30:00 +10:00
- if (!this.level().dimensionType().natural()) {
2024-12-11 22:26:55 +01:00
- return Either.left(Player.BedSleepingProblem.NOT_POSSIBLE_HERE);
- } else if (!this.bedInRange(pos, enumdirection)) {
- return Either.left(Player.BedSleepingProblem.TOO_FAR_AWAY);
- } else if (this.bedBlocked(pos, enumdirection)) {
- return Either.left(Player.BedSleepingProblem.OBSTRUCTED);
2023-06-08 01:30:00 +10:00
+ if (!this.level().dimensionType().natural() || !this.level().dimensionType().bedWorks()) {
2024-12-11 22:26:55 +01:00
+ return Either.left(net.minecraft.world.entity.player.Player.BedSleepingProblem.NOT_POSSIBLE_HERE);
+ } else if (!this.bedInRange(blockposition, enumdirection)) {
+ return Either.left(net.minecraft.world.entity.player.Player.BedSleepingProblem.TOO_FAR_AWAY);
+ } else if (this.bedBlocked(blockposition, enumdirection)) {
+ return Either.left(net.minecraft.world.entity.player.Player.BedSleepingProblem.OBSTRUCTED);
2023-04-17 19:33:17 +10:00
} else {
2024-12-11 22:26:55 +01:00
- this.setRespawnPosition(this.level().dimension(), pos, this.getYRot(), false, true);
2023-06-08 01:30:00 +10:00
+ this.setRespawnPosition(this.level().dimension(), blockposition, this.getYRot(), false, true, PlayerSpawnChangeEvent.Cause.BED); // CraftBukkit
if (this.level().isDay()) {
2024-12-11 22:26:55 +01:00
- return Either.left(Player.BedSleepingProblem.NOT_POSSIBLE_NOW);
+ return Either.left(net.minecraft.world.entity.player.Player.BedSleepingProblem.NOT_POSSIBLE_NOW);
2023-04-17 19:33:17 +10:00
} else {
2024-12-11 22:26:55 +01:00
if (!this.isCreative()) {
double d0 = 8.0D;
double d1 = 5.0D;
- Vec3 vec3d = Vec3.atBottomCenterOf(pos);
+ Vec3 vec3d = Vec3.atBottomCenterOf(blockposition);
List<Monster> list = this.level().getEntitiesOfClass(Monster.class, new AABB(vec3d.x() - 8.0D, vec3d.y() - 5.0D, vec3d.z() - 8.0D, vec3d.x() + 8.0D, vec3d.y() + 5.0D, vec3d.z() + 8.0D), (entitymonster) -> {
return entitymonster.isPreventingPlayerRest(this.serverLevel(), this);
});
if (!list.isEmpty()) {
- return Either.left(Player.BedSleepingProblem.NOT_SAFE);
+ return Either.left(net.minecraft.world.entity.player.Player.BedSleepingProblem.NOT_SAFE);
2020-06-25 10:00:00 +10:00
}
}
2024-12-11 22:26:55 +01:00
- Either<Player.BedSleepingProblem, Unit> either = super.startSleepInBed(pos).ifRight((unit) -> {
2020-06-25 10:00:00 +10:00
+ return Either.right(Unit.INSTANCE);
+ }
+ }
+ } else {
2024-12-11 22:26:55 +01:00
+ return Either.left(net.minecraft.world.entity.player.Player.BedSleepingProblem.OTHER_PROBLEM);
2020-06-25 10:00:00 +10:00
+ }
2019-03-13 04:48:19 +01:00
+ }
+
2019-04-23 12:00:00 +10:00
+ @Override
2024-12-11 22:26:55 +01:00
+ public Either<net.minecraft.world.entity.player.Player.BedSleepingProblem, Unit> startSleepInBed(BlockPos blockposition, boolean force) {
+ Direction enumdirection = (Direction) this.level().getBlockState(blockposition).getValue(HorizontalDirectionalBlock.FACING);
+ Either<net.minecraft.world.entity.player.Player.BedSleepingProblem, Unit> bedResult = this.getBedResult(blockposition, enumdirection);
2020-06-25 10:00:00 +10:00
+
2024-12-11 22:26:55 +01:00
+ if (bedResult.left().orElse(null) == net.minecraft.world.entity.player.Player.BedSleepingProblem.OTHER_PROBLEM) {
2020-06-25 10:00:00 +10:00
+ return bedResult; // return immediately if the result is not bypassable by plugins
+ }
+
+ if (force) {
+ bedResult = Either.right(Unit.INSTANCE);
+ }
+
+ bedResult = org.bukkit.craftbukkit.event.CraftEventFactory.callPlayerBedEnterEvent(this, blockposition, bedResult);
+ if (bedResult.left().isPresent()) {
+ return bedResult;
+ }
+
+ {
+ {
+ {
2024-12-11 22:26:55 +01:00
+ Either<net.minecraft.world.entity.player.Player.BedSleepingProblem, Unit> either = super.startSleepInBed(blockposition, force).ifRight((unit) -> {
this.awardStat(Stats.SLEEP_IN_BED);
CriteriaTriggers.SLEPT_IN_BED.trigger(this);
2020-06-25 10:00:00 +10:00
});
2024-12-11 22:26:55 +01:00
@@ -1293,9 +1640,8 @@
2020-06-25 10:00:00 +10:00
return either;
}
}
- } else {
2024-12-11 22:26:55 +01:00
- return Either.left(Player.BedSleepingProblem.OTHER_PROBLEM);
2020-06-25 10:00:00 +10:00
}
2019-03-13 04:48:19 +01:00
+ // CraftBukkit end
2020-06-25 10:00:00 +10:00
}
@Override
2024-12-11 22:26:55 +01:00
@@ -1322,13 +1668,31 @@
2014-11-26 08:32:16 +11:00
2019-04-23 12:00:00 +10:00
@Override
2024-12-11 22:26:55 +01:00
public void stopSleepInBed(boolean skipSleepTimer, boolean updateSleepingPlayers) {
2019-04-23 12:00:00 +10:00
+ if (!this.isSleeping()) return; // CraftBukkit - Can't leave bed if not in one!
2021-01-29 11:22:42 +11:00
+ // CraftBukkit start - fire PlayerBedLeaveEvent
+ CraftPlayer player = this.getBukkitEntity();
2024-12-11 22:26:55 +01:00
+ BlockPos bedPosition = this.getSleepingPos().orElse(null);
2021-01-29 11:22:42 +11:00
+
+ org.bukkit.block.Block bed;
+ if (bedPosition != null) {
2023-06-08 01:30:00 +10:00
+ bed = this.level().getWorld().getBlockAt(bedPosition.getX(), bedPosition.getY(), bedPosition.getZ());
2021-01-29 11:22:42 +11:00
+ } else {
2023-06-08 01:30:00 +10:00
+ bed = this.level().getWorld().getBlockAt(player.getLocation());
2021-01-29 11:22:42 +11:00
+ }
+
+ PlayerBedLeaveEvent event = new PlayerBedLeaveEvent(player, bed, true);
2023-06-08 01:30:00 +10:00
+ this.level().getCraftServer().getPluginManager().callEvent(event);
2021-01-29 11:22:42 +11:00
+ if (event.isCancelled()) {
+ return;
+ }
+ // CraftBukkit end
2014-11-26 08:32:16 +11:00
if (this.isSleeping()) {
2024-12-11 22:26:55 +01:00
this.serverLevel().getChunkSource().broadcastAndSend(this, new ClientboundAnimatePacket(this, 2));
2015-02-20 15:37:17 +11:00
}
2023-07-29 09:58:01 +10:00
2024-12-11 22:26:55 +01:00
super.stopSleepInBed(skipSleepTimer, updateSleepingPlayers);
2023-07-29 09:58:01 +10:00
if (this.connection != null) {
- this.connection.teleport(this.getX(), this.getY(), this.getZ(), this.getYRot(), this.getXRot());
+ this.connection.teleport(this.getX(), this.getY(), this.getZ(), this.getYRot(), this.getXRot(), TeleportCause.EXIT_BED); // CraftBukkit
}
}
2024-12-11 22:26:55 +01:00
@@ -1387,8 +1751,9 @@
this.connection.send(new ClientboundOpenSignEditorPacket(sign.getBlockPos(), front));
2014-11-26 08:32:16 +11:00
}
2016-03-01 08:32:46 +11:00
- public void nextContainerCounter() {
+ public int nextContainerCounter() { // CraftBukkit - void -> int
2014-11-26 08:32:16 +11:00
this.containerCounter = this.containerCounter % 100 + 1;
2024-12-11 22:26:55 +01:00
+ return this.containerCounter; // CraftBukkit
2014-11-26 08:32:16 +11:00
}
2019-04-23 12:00:00 +10:00
@Override
2024-12-11 22:26:55 +01:00
@@ -1396,13 +1761,35 @@
if (factory == null) {
2021-07-30 19:08:43 +10:00
return OptionalInt.empty();
} else {
+ // CraftBukkit start - SPIGOT-6552: Handle inventory closing in CraftEventFactory#callInventoryOpenEvent(...)
+ /*
if (this.containerMenu != this.inventoryMenu) {
2021-11-22 09:00:00 +11:00
this.closeContainer();
2021-07-30 19:08:43 +10:00
}
+ */
+ // CraftBukkit end
2016-11-17 12:41:03 +11:00
this.nextContainerCounter();
2024-12-11 22:26:55 +01:00
AbstractContainerMenu container = factory.createMenu(this.containerCounter, this.getInventory(), this);
2014-11-26 08:32:16 +11:00
2019-04-23 12:00:00 +10:00
+ // CraftBukkit start - Inventory open hook
+ if (container != null) {
2024-12-11 22:26:55 +01:00
+ container.setTitle(factory.getDisplayName());
2014-12-28 15:14:53 +00:00
+
2019-04-23 12:00:00 +10:00
+ boolean cancelled = false;
+ container = CraftEventFactory.callInventoryOpenEvent(this, container, cancelled);
+ if (container == null && !cancelled) { // Let pre-cancelled events fall through
2019-08-24 20:02:14 +10:00
+ // SPIGOT-5263 - close chest if cancelled
2024-12-11 22:26:55 +01:00
+ if (factory instanceof Container) {
+ ((Container) factory).stopOpen(this);
+ } else if (factory instanceof ChestBlock.DoubleInventory) {
2019-10-09 19:51:18 +11:00
+ // SPIGOT-5355 - double chests too :(
2024-12-11 22:26:55 +01:00
+ ((ChestBlock.DoubleInventory) factory).inventorylargechest.stopOpen(this);
2019-08-24 20:02:14 +10:00
+ }
2019-04-23 12:00:00 +10:00
+ return OptionalInt.empty();
+ }
2017-01-10 09:56:20 +11:00
+ }
2019-04-23 12:00:00 +10:00
+ // CraftBukkit end
if (container == null) {
if (this.isSpectator()) {
2024-12-11 22:26:55 +01:00
this.displayClientMessage(Component.translatable("container.spectatorCantOpen").withStyle(ChatFormatting.RED), true);
@@ -1410,9 +1797,11 @@
2014-11-26 08:32:16 +11:00
2019-04-23 12:00:00 +10:00
return OptionalInt.empty();
2016-03-01 08:32:46 +11:00
} else {
2024-12-11 22:26:55 +01:00
- this.connection.send(new ClientboundOpenScreenPacket(container.containerId, container.getType(), factory.getDisplayName()));
2021-06-11 15:00:00 +10:00
- this.initMenu(container);
2019-04-23 12:00:00 +10:00
+ // CraftBukkit start
2021-06-11 15:00:00 +10:00
this.containerMenu = container;
2024-12-11 22:26:55 +01:00
+ this.connection.send(new ClientboundOpenScreenPacket(container.containerId, container.getType(), container.getTitle()));
2019-04-23 12:00:00 +10:00
+ // CraftBukkit end
2021-06-11 15:00:00 +10:00
+ this.initMenu(container);
2019-04-23 12:00:00 +10:00
return OptionalInt.of(this.containerCounter);
2016-03-01 08:32:46 +11:00
}
2019-04-23 12:00:00 +10:00
}
2024-12-11 22:26:55 +01:00
@@ -1425,15 +1814,26 @@
2014-11-26 08:32:16 +11:00
2019-04-23 12:00:00 +10:00
@Override
2024-12-11 22:26:55 +01:00
public void openHorseInventory(AbstractHorse horse, Container inventory) {
2014-11-26 08:32:16 +11:00
+ // CraftBukkit start - Inventory open hook
2019-04-23 12:00:00 +10:00
+ this.nextContainerCounter();
2024-12-11 22:26:55 +01:00
+ AbstractContainerMenu container = new HorseInventoryMenu(this.containerCounter, this.getInventory(), inventory, horse, horse.getInventoryColumns());
+ container.setTitle(horse.getDisplayName());
2019-05-10 17:41:05 +10:00
+ container = CraftEventFactory.callInventoryOpenEvent(this, container);
+
2014-11-26 08:32:16 +11:00
+ if (container == null) {
2024-12-11 22:26:55 +01:00
+ inventory.stopOpen(this);
2014-11-26 08:32:16 +11:00
+ return;
+ }
2015-02-26 22:41:06 +00:00
+ // CraftBukkit end
2021-06-11 15:00:00 +10:00
if (this.containerMenu != this.inventoryMenu) {
2021-11-22 09:00:00 +11:00
this.closeContainer();
2014-11-26 08:32:16 +11:00
}
2019-04-23 12:00:00 +10:00
- this.nextContainerCounter();
+ // this.nextContainerCounter(); // CraftBukkit - moved up
2024-12-11 22:26:55 +01:00
int i = horse.getInventoryColumns();
2024-06-14 01:05:00 +10:00
2024-12-11 22:26:55 +01:00
this.connection.send(new ClientboundHorseScreenOpenPacket(this.containerCounter, i, horse.getId()));
- this.containerMenu = new HorseInventoryMenu(this.containerCounter, this.getInventory(), inventory, horse, i);
2021-06-11 15:00:00 +10:00
+ this.containerMenu = container; // CraftBukkit
this.initMenu(this.containerMenu);
2014-11-26 08:32:16 +11:00
}
2024-12-11 22:26:55 +01:00
@@ -1456,6 +1856,7 @@
2014-11-26 08:32:16 +11:00
2019-04-23 12:00:00 +10:00
@Override
2021-11-22 09:00:00 +11:00
public void closeContainer() {
2014-11-26 08:32:16 +11:00
+ CraftEventFactory.handleInventoryCloseEvent(this); // CraftBukkit
2024-12-11 22:26:55 +01:00
this.connection.send(new ClientboundContainerClosePacket(this.containerMenu.containerId));
2021-11-22 09:00:00 +11:00
this.doCloseContainer();
2018-07-15 10:00:00 +10:00
}
2024-12-11 22:26:55 +01:00
@@ -1485,19 +1886,19 @@
i = Math.round((float) Math.sqrt(deltaX * deltaX + deltaY * deltaY + deltaZ * deltaZ) * 100.0F);
2023-12-06 03:40:00 +11:00
if (i > 0) {
2024-12-11 22:26:55 +01:00
this.awardStat(Stats.SWIM_ONE_CM, i);
2023-12-06 03:40:00 +11:00
- this.causeFoodExhaustion(0.01F * (float) i * 0.01F);
+ this.causeFoodExhaustion(0.01F * (float) i * 0.01F, EntityExhaustionEvent.ExhaustionReason.SWIM); // CraftBukkit - EntityExhaustionEvent
}
2024-12-11 22:26:55 +01:00
} else if (this.isEyeInFluid(FluidTags.WATER)) {
i = Math.round((float) Math.sqrt(deltaX * deltaX + deltaY * deltaY + deltaZ * deltaZ) * 100.0F);
2023-12-06 03:40:00 +11:00
if (i > 0) {
2024-12-11 22:26:55 +01:00
this.awardStat(Stats.WALK_UNDER_WATER_ONE_CM, i);
2023-12-06 03:40:00 +11:00
- this.causeFoodExhaustion(0.01F * (float) i * 0.01F);
+ this.causeFoodExhaustion(0.01F * (float) i * 0.01F, EntityExhaustionEvent.ExhaustionReason.WALK_UNDERWATER); // CraftBukkit - EntityExhaustionEvent
}
} else if (this.isInWater()) {
2024-12-11 22:26:55 +01:00
i = Math.round((float) Math.sqrt(deltaX * deltaX + deltaZ * deltaZ) * 100.0F);
2023-12-06 03:40:00 +11:00
if (i > 0) {
2024-12-11 22:26:55 +01:00
this.awardStat(Stats.WALK_ON_WATER_ONE_CM, i);
2023-12-06 03:40:00 +11:00
- this.causeFoodExhaustion(0.01F * (float) i * 0.01F);
+ this.causeFoodExhaustion(0.01F * (float) i * 0.01F, EntityExhaustionEvent.ExhaustionReason.WALK_ON_WATER); // CraftBukkit - EntityExhaustionEvent
}
} else if (this.onClimbable()) {
2024-12-11 22:26:55 +01:00
if (deltaY > 0.0D) {
@@ -1508,13 +1909,13 @@
2023-12-06 03:40:00 +11:00
if (i > 0) {
if (this.isSprinting()) {
2024-12-11 22:26:55 +01:00
this.awardStat(Stats.SPRINT_ONE_CM, i);
2023-12-06 03:40:00 +11:00
- this.causeFoodExhaustion(0.1F * (float) i * 0.01F);
+ this.causeFoodExhaustion(0.1F * (float) i * 0.01F, EntityExhaustionEvent.ExhaustionReason.SPRINT); // CraftBukkit - EntityExhaustionEvent
} else if (this.isCrouching()) {
2024-12-11 22:26:55 +01:00
this.awardStat(Stats.CROUCH_ONE_CM, i);
2023-12-06 03:40:00 +11:00
- this.causeFoodExhaustion(0.0F * (float) i * 0.01F);
+ this.causeFoodExhaustion(0.0F * (float) i * 0.01F, EntityExhaustionEvent.ExhaustionReason.CROUCH); // CraftBukkit - EntityExhaustionEvent
} else {
2024-12-11 22:26:55 +01:00
this.awardStat(Stats.WALK_ONE_CM, i);
2023-12-06 03:40:00 +11:00
- this.causeFoodExhaustion(0.0F * (float) i * 0.01F);
+ this.causeFoodExhaustion(0.0F * (float) i * 0.01F, EntityExhaustionEvent.ExhaustionReason.WALK); // CraftBukkit - EntityExhaustionEvent
}
}
} else if (this.isFallFlying()) {
2024-12-11 22:26:55 +01:00
@@ -1557,7 +1958,7 @@
2019-04-23 12:00:00 +10:00
@Override
2024-12-11 22:26:55 +01:00
public void awardStat(Stat<?> stat, int amount) {
this.stats.increment(this, stat, amount);
- this.getScoreboard().forAllObjectives(stat, this, (scoreaccess) -> {
+ this.level().getCraftServer().getScoreboardManager().forAllObjectives(stat, this, (scoreaccess) -> {
scoreaccess.add(amount);
2018-07-15 10:00:00 +10:00
});
2017-05-14 12:00:00 +10:00
}
2024-12-11 22:26:55 +01:00
@@ -1565,7 +1966,7 @@
2019-04-23 12:00:00 +10:00
@Override
2024-12-11 22:26:55 +01:00
public void resetStat(Stat<?> stat) {
this.stats.setValue(this, stat, 0);
- this.getScoreboard().forAllObjectives(stat, this, ScoreAccess::reset);
+ this.level().getCraftServer().getScoreboardManager().forAllObjectives(stat, this, ScoreAccess::reset); // CraftBukkit - Get our scores instead
2014-11-26 08:32:16 +11:00
}
2017-05-14 12:00:00 +10:00
2019-04-23 12:00:00 +10:00
@Override
2024-12-11 22:26:55 +01:00
@@ -1597,9 +1998,9 @@
2024-10-23 02:15:00 +11:00
super.jumpFromGround();
2024-12-11 22:26:55 +01:00
this.awardStat(Stats.JUMP);
2024-10-23 02:15:00 +11:00
if (this.isSprinting()) {
- this.causeFoodExhaustion(0.2F);
+ this.causeFoodExhaustion(0.2F, EntityExhaustionEvent.ExhaustionReason.JUMP_SPRINT); // CraftBukkit - EntityExhaustionEvent
} else {
- this.causeFoodExhaustion(0.05F);
+ this.causeFoodExhaustion(0.05F, EntityExhaustionEvent.ExhaustionReason.JUMP); // CraftBukkit - EntityExhaustionEvent
}
}
2024-12-11 22:26:55 +01:00
@@ -1625,6 +2026,7 @@
2014-11-26 08:32:16 +11:00
2021-11-22 09:00:00 +11:00
public void resetSentInfo() {
2021-06-11 15:00:00 +10:00
this.lastSentHealth = -1.0E8F;
2014-11-26 08:32:16 +11:00
+ this.lastSentExp = -1; // CraftBukkit - Added to reset
2022-04-09 09:39:33 +10:00
}
2019-04-23 12:00:00 +10:00
@Override
2024-12-11 22:26:55 +01:00
@@ -1661,7 +2063,7 @@
2024-11-12 20:51:01 +11:00
this.onUpdateAbilities();
2024-12-11 22:26:55 +01:00
if (alive) {
this.getAttributes().assignBaseValues(oldPlayer.getAttributes());
- this.getAttributes().assignPermanentModifiers(oldPlayer.getAttributes());
2024-11-12 20:51:01 +11:00
+ // this.getAttributes().assignPermanentModifiers(entityplayer.getAttributes()); // CraftBukkit
2024-12-11 22:26:55 +01:00
this.setHealth(oldPlayer.getHealth());
this.foodData = oldPlayer.foodData;
Iterator iterator = oldPlayer.getActiveEffects().iterator();
@@ -1669,7 +2071,7 @@
2024-06-23 16:45:29 +10:00
while (iterator.hasNext()) {
2024-12-11 22:26:55 +01:00
MobEffectInstance mobeffect = (MobEffectInstance) iterator.next();
2024-06-23 16:45:29 +10:00
2024-12-11 22:26:55 +01:00
- this.addEffect(new MobEffectInstance(mobeffect));
2024-06-23 16:45:29 +10:00
+ // this.addEffect(new MobEffect(mobeffect)); // CraftBukkit
}
2024-12-11 22:26:55 +01:00
this.getInventory().replaceWith(oldPlayer.getInventory());
@@ -1680,7 +2082,7 @@
this.portalProcess = oldPlayer.portalProcess;
2024-10-23 02:15:00 +11:00
} else {
2024-12-11 22:26:55 +01:00
this.getAttributes().assignBaseValues(oldPlayer.getAttributes());
2024-10-23 02:15:00 +11:00
- this.setHealth(this.getMaxHealth());
+ // this.setHealth(this.getMaxHealth()); // CraftBukkit
2024-12-11 22:26:55 +01:00
if (this.serverLevel().getGameRules().getBoolean(GameRules.RULE_KEEPINVENTORY) || oldPlayer.isSpectator()) {
this.getInventory().replaceWith(oldPlayer.getInventory());
this.experienceLevel = oldPlayer.experienceLevel;
@@ -1696,7 +2098,7 @@
2017-05-15 18:11:48 +10:00
this.lastSentExp = -1;
2021-06-11 15:00:00 +10:00
this.lastSentHealth = -1.0F;
this.lastSentFood = -1;
2024-12-11 22:26:55 +01:00
- this.recipeBook.copyOverData(oldPlayer.recipeBook);
2021-11-22 09:00:00 +11:00
+ // this.recipeBook.copyOverData(entityplayer.recipeBook); // CraftBukkit
2024-12-11 22:26:55 +01:00
this.seenCredits = oldPlayer.seenCredits;
this.enteredNetherPosition = oldPlayer.enteredNetherPosition;
this.chunkTrackingView = oldPlayer.chunkTrackingView;
@@ -1752,19 +2154,19 @@
2024-10-23 02:15:00 +11:00
}
2023-03-15 03:30:00 +11:00
@Override
2024-12-11 22:26:55 +01:00
- public boolean teleportTo(ServerLevel world, double destX, double destY, double destZ, Set<Relative> flags, float yaw, float pitch, boolean resetCamera) {
+ public boolean teleportTo(ServerLevel worldserver, double d0, double d1, double d2, Set<Relative> set, float f, float f1, boolean flag, TeleportCause cause) { // CraftBukkit
2024-12-04 03:20:00 +11:00
if (this.isSleeping()) {
this.stopSleepInBed(true, true);
}
2024-12-11 22:26:55 +01:00
- if (resetCamera) {
+ if (flag) {
2024-10-23 02:15:00 +11:00
this.setCamera(this);
2023-03-15 03:30:00 +11:00
}
2024-12-11 22:26:55 +01:00
- boolean flag1 = super.teleportTo(world, destX, destY, destZ, flags, yaw, pitch, resetCamera);
2024-10-23 02:15:00 +11:00
+ boolean flag1 = super.teleportTo(worldserver, d0, d1, d2, set, f, f1, flag, cause); // CraftBukkit
2023-03-15 03:30:00 +11:00
2024-10-23 02:15:00 +11:00
if (flag1) {
2024-12-11 22:26:55 +01:00
- this.setYHeadRot(flags.contains(Relative.Y_ROT) ? this.getYHeadRot() + yaw : yaw);
+ this.setYHeadRot(set.contains(Relative.Y_ROT) ? this.getYHeadRot() + f : f);
}
return flag1;
@@ -1878,6 +2280,16 @@
2016-05-27 18:53:36 +10:00
}
2024-12-11 22:26:55 +01:00
public void updateOptions(ClientInformation clientOptions) {
2016-05-27 18:53:36 +10:00
+ // CraftBukkit start
2024-12-11 22:26:55 +01:00
+ if (this.getMainArm() != clientOptions.mainHand()) {
+ PlayerChangedMainHandEvent event = new PlayerChangedMainHandEvent(this.getBukkitEntity(), this.getMainArm() == HumanoidArm.LEFT ? MainHand.LEFT : MainHand.RIGHT);
2016-05-27 18:53:36 +10:00
+ this.server.server.getPluginManager().callEvent(event);
+ }
2024-12-11 22:26:55 +01:00
+ if (!this.language.equals(clientOptions.language())) {
+ PlayerLocaleChangeEvent event = new PlayerLocaleChangeEvent(this.getBukkitEntity(), clientOptions.language());
2017-05-26 23:37:06 +02:00
+ this.server.server.getPluginManager().callEvent(event);
+ }
2016-05-27 18:53:36 +10:00
+ // CraftBukkit end
2024-12-11 22:26:55 +01:00
this.language = clientOptions.language();
this.requestedViewDistance = clientOptions.viewDistance();
this.chatVisibility = clientOptions.chatVisibility();
@@ -1962,7 +2374,7 @@
if (world instanceof ServerLevel) {
ServerLevel worldserver = (ServerLevel) world;
2023-03-15 03:30:00 +11:00
2024-10-23 02:15:00 +11:00
- this.teleportTo(worldserver, this.camera.getX(), this.camera.getY(), this.camera.getZ(), Set.of(), this.getYRot(), this.getXRot(), false);
+ this.teleportTo(worldserver, this.camera.getX(), this.camera.getY(), this.camera.getZ(), Set.of(), this.getYRot(), this.getXRot(), false, TeleportCause.SPECTATE); // CraftBukkit
2023-03-15 03:30:00 +11:00
}
2017-03-24 15:08:19 +11:00
2023-03-15 03:30:00 +11:00
if (entity != null) {
2024-12-11 22:26:55 +01:00
@@ -1999,11 +2411,11 @@
2016-03-02 18:32:06 +11:00
2016-05-10 21:47:39 +10:00
@Nullable
2024-12-11 22:26:55 +01:00
public Component getTabListDisplayName() {
2016-03-02 18:32:06 +11:00
- return null;
2024-12-11 22:26:55 +01:00
+ return this.listName; // CraftBukkit
2016-03-02 18:32:06 +11:00
}
2024-10-23 02:15:00 +11:00
public int getTabListOrder() {
- return 0;
2024-12-11 22:26:55 +01:00
+ return this.listOrder; // CraftBukkit
2019-04-23 12:00:00 +10:00
}
2024-10-23 02:15:00 +11:00
@Override
2024-12-11 22:26:55 +01:00
@@ -2046,17 +2458,43 @@
2023-04-17 19:33:17 +10:00
}
2024-12-11 22:26:55 +01:00
public void setRespawnPosition(ResourceKey<Level> dimension, @Nullable BlockPos pos, float angle, boolean forced, boolean sendMessage) {
- if (pos != null) {
- boolean flag2 = pos.equals(this.respawnPosition) && dimension.equals(this.respawnDimension);
2023-04-17 19:33:17 +10:00
+ // CraftBukkit start
2024-12-11 22:26:55 +01:00
+ this.setRespawnPosition(dimension, pos, angle, forced, sendMessage, PlayerSpawnChangeEvent.Cause.UNKNOWN);
2023-04-17 19:33:17 +10:00
+ }
2024-12-11 22:26:55 +01:00
- if (sendMessage && !flag2) {
+ public void setRespawnPosition(ResourceKey<Level> resourcekey, @Nullable BlockPos blockposition, float f, boolean flag, boolean flag1, PlayerSpawnChangeEvent.Cause cause) {
+ ServerLevel newWorld = this.server.getLevel(resourcekey);
2023-04-19 19:59:19 +10:00
+ Location newSpawn = (blockposition != null) ? CraftLocation.toBukkit(blockposition, newWorld.getWorld(), f, 0) : null;
2023-04-17 19:33:17 +10:00
+
+ PlayerSpawnChangeEvent event = new PlayerSpawnChangeEvent(this.getBukkitEntity(), newSpawn, flag, cause);
+ Bukkit.getServer().getPluginManager().callEvent(event);
+ if (event.isCancelled()) {
+ return;
+ }
+ newSpawn = event.getNewSpawn();
+ flag = event.isForced();
+
+ if (newSpawn != null) {
+ resourcekey = ((CraftWorld) newSpawn.getWorld()).getHandle().dimension();
2024-12-11 22:26:55 +01:00
+ blockposition = BlockPos.containing(newSpawn.getX(), newSpawn.getY(), newSpawn.getZ());
2023-04-17 19:33:17 +10:00
+ f = newSpawn.getYaw();
+ } else {
2024-12-11 22:26:55 +01:00
+ resourcekey = Level.OVERWORLD;
2023-04-17 19:33:17 +10:00
+ blockposition = null;
+ f = 0.0F;
+ }
+ // CraftBukkit end
2024-12-11 22:26:55 +01:00
+ if (blockposition != null) {
+ boolean flag2 = blockposition.equals(this.respawnPosition) && resourcekey.equals(this.respawnDimension);
+
+ if (flag1 && !flag2) {
this.sendSystemMessage(Component.translatable("block.minecraft.set_spawn"));
}
2023-04-17 19:33:17 +10:00
2024-12-11 22:26:55 +01:00
- this.respawnPosition = pos;
- this.respawnDimension = dimension;
- this.respawnAngle = angle;
- this.respawnForced = forced;
+ this.respawnPosition = blockposition;
+ this.respawnDimension = resourcekey;
+ this.respawnAngle = f;
+ this.respawnForced = flag;
} else {
this.respawnPosition = null;
this.respawnDimension = Level.OVERWORLD;
@@ -2088,18 +2526,44 @@
2024-10-23 02:15:00 +11:00
}
2024-06-29 14:03:10 +10:00
@Override
2024-12-11 22:26:55 +01:00
- public ItemEntity drop(ItemStack stack, boolean throwRandomly, boolean retainOwnership) {
- ItemEntity entityitem = this.createItemStackToDrop(stack, throwRandomly, retainOwnership);
+ public ItemEntity drop(ItemStack itemstack, boolean flag, boolean flag1, boolean callEvent) { // CraftBukkit - SPIGOT-2942: Add boolean to call event
+ ItemEntity entityitem = this.createItemStackToDrop(itemstack, flag, flag1);
2024-06-29 14:03:10 +10:00
if (entityitem == null) {
return null;
2024-10-23 02:15:00 +11:00
} else {
+ // CraftBukkit start - fire PlayerDropItemEvent
+ if (callEvent) {
+ Player player = (Player) this.getBukkitEntity();
+ org.bukkit.entity.Item drop = (org.bukkit.entity.Item) entityitem.getBukkitEntity();
+
+ PlayerDropItemEvent event = new PlayerDropItemEvent(player, drop);
+ this.level().getCraftServer().getPluginManager().callEvent(event);
+
+ if (event.isCancelled()) {
+ org.bukkit.inventory.ItemStack cur = player.getInventory().getItemInHand();
+ if (flag1 && (cur == null || cur.getAmount() == 0)) {
+ // The complete stack was dropped
+ player.getInventory().setItemInHand(drop.getItemStack());
+ } else if (flag1 && cur.isSimilar(drop.getItemStack()) && cur.getAmount() < cur.getMaxStackSize() && drop.getItemStack().getAmount() == 1) {
+ // Only one item is dropped
+ cur.setAmount(cur.getAmount() + 1);
+ player.getInventory().setItemInHand(cur);
+ } else {
+ // Fallback
+ player.getInventory().addItem(drop.getItemStack());
+ }
+ return null;
+ }
+ }
+ // CraftBukkit end
+
this.level().addFreshEntity(entityitem);
ItemStack itemstack1 = entityitem.getItem();
2024-12-11 22:26:55 +01:00
- if (retainOwnership) {
+ if (flag1) {
if (!itemstack1.isEmpty()) {
- this.awardStat(Stats.ITEM_DROPPED.get(itemstack1.getItem()), stack.getCount());
+ this.awardStat(Stats.ITEM_DROPPED.get(itemstack1.getItem()), itemstack.getCount());
}
this.awardStat(Stats.DROP);
@@ -2375,16 +2839,160 @@
2024-10-23 02:15:00 +11:00
return TicketType.ENDER_PEARL.timeout();
2024-06-14 01:05:00 +10:00
}
2024-12-11 22:26:55 +01:00
- public static record RespawnPosAngle(Vec3 position, float yaw) {
2024-06-14 01:05:00 +10:00
+ // CraftBukkit start
2024-12-11 22:26:55 +01:00
+ public static record RespawnPosAngle(Vec3 position, float yaw, boolean isBedSpawn, boolean isAnchorSpawn) {
2024-06-14 01:05:00 +10:00
2024-12-11 22:26:55 +01:00
- public static ServerPlayer.RespawnPosAngle of(Vec3 respawnPos, BlockPos currentPos) {
- return new ServerPlayer.RespawnPosAngle(respawnPos, calculateLookAtYaw(respawnPos, currentPos));
+ public static ServerPlayer.RespawnPosAngle of(Vec3 vec3d, BlockPos blockposition, boolean isBedSpawn, boolean isAnchorSpawn) {
+ return new ServerPlayer.RespawnPosAngle(vec3d, calculateLookAtYaw(vec3d, blockposition), isBedSpawn, isAnchorSpawn);
2024-06-14 01:05:00 +10:00
+ // CraftBukkit end
}
2024-12-11 22:26:55 +01:00
private static float calculateLookAtYaw(Vec3 respawnPos, BlockPos currentPos) {
Vec3 vec3d1 = Vec3.atBottomCenterOf(currentPos).subtract(respawnPos).normalize();
return (float) Mth.wrapDegrees(Mth.atan2(vec3d1.z, vec3d1.x) * 57.2957763671875D - 90.0D);
+ }
+ }
2014-11-26 08:32:16 +11:00
+
+ // CraftBukkit start - Add per-player time and weather.
+ public long timeOffset = 0;
+ public boolean relativeTime = true;
+
+ public long getPlayerTime() {
+ if (this.relativeTime) {
+ // Adds timeOffset to the current server time.
2023-06-08 01:30:00 +10:00
+ return this.level().getDayTime() + this.timeOffset;
2014-11-26 08:32:16 +11:00
+ } else {
+ // Adds timeOffset to the beginning of this day.
2023-06-08 01:30:00 +10:00
+ return this.level().getDayTime() - (this.level().getDayTime() % 24000) + this.timeOffset;
2014-11-26 08:32:16 +11:00
+ }
+ }
+
+ public WeatherType weather = null;
+
+ public WeatherType getPlayerWeather() {
+ return this.weather;
+ }
+
+ public void setPlayerWeather(WeatherType type, boolean plugin) {
+ if (!plugin && this.weather != null) {
+ return;
+ }
+
+ if (plugin) {
+ this.weather = type;
+ }
+
+ if (type == WeatherType.DOWNFALL) {
2024-12-11 22:26:55 +01:00
+ this.connection.send(new ClientboundGameEventPacket(ClientboundGameEventPacket.STOP_RAINING, 0));
2020-06-29 08:25:59 +10:00
+ } else {
2024-12-11 22:26:55 +01:00
+ this.connection.send(new ClientboundGameEventPacket(ClientboundGameEventPacket.START_RAINING, 0));
2014-11-26 08:32:16 +11:00
+ }
+ }
2015-02-26 22:41:06 +00:00
+
2014-12-02 15:13:07 +00:00
+ private float pluginRainPosition;
+ private float pluginRainPositionPrevious;
2015-02-26 22:41:06 +00:00
+
2014-12-02 15:13:07 +00:00
+ public void updateWeather(float oldRain, float newRain, float oldThunder, float newThunder) {
+ if (this.weather == null) {
+ // Vanilla
+ if (oldRain != newRain) {
2024-12-11 22:26:55 +01:00
+ this.connection.send(new ClientboundGameEventPacket(ClientboundGameEventPacket.RAIN_LEVEL_CHANGE, newRain));
2015-02-26 22:41:06 +00:00
+ }
2014-12-02 15:13:07 +00:00
+ } else {
+ // Plugin
2024-12-11 22:26:55 +01:00
+ if (this.pluginRainPositionPrevious != this.pluginRainPosition) {
+ this.connection.send(new ClientboundGameEventPacket(ClientboundGameEventPacket.RAIN_LEVEL_CHANGE, this.pluginRainPosition));
2015-02-26 22:41:06 +00:00
+ }
2024-12-11 22:26:55 +01:00
}
2014-12-02 15:13:07 +00:00
+
+ if (oldThunder != newThunder) {
2024-12-11 22:26:55 +01:00
+ if (this.weather == WeatherType.DOWNFALL || this.weather == null) {
+ this.connection.send(new ClientboundGameEventPacket(ClientboundGameEventPacket.THUNDER_LEVEL_CHANGE, newThunder));
2014-12-02 15:13:07 +00:00
+ } else {
2024-12-11 22:26:55 +01:00
+ this.connection.send(new ClientboundGameEventPacket(ClientboundGameEventPacket.THUNDER_LEVEL_CHANGE, 0));
2014-12-02 15:13:07 +00:00
+ }
+ }
2024-12-11 22:26:55 +01:00
}
2015-02-26 22:41:06 +00:00
+
2014-12-02 15:13:07 +00:00
+ public void tickWeather() {
+ if (this.weather == null) return;
+
2024-12-11 22:26:55 +01:00
+ this.pluginRainPositionPrevious = this.pluginRainPosition;
+ if (this.weather == WeatherType.DOWNFALL) {
+ this.pluginRainPosition += 0.01;
2014-12-02 15:13:07 +00:00
+ } else {
2024-12-11 22:26:55 +01:00
+ this.pluginRainPosition -= 0.01;
2014-12-02 15:13:07 +00:00
+ }
+
2024-12-11 22:26:55 +01:00
+ this.pluginRainPosition = Mth.clamp(this.pluginRainPosition, 0.0F, 1.0F);
2014-12-02 15:13:07 +00:00
+ }
2014-11-26 08:32:16 +11:00
+
+ public void resetPlayerWeather() {
+ this.weather = null;
2023-06-08 01:30:00 +10:00
+ this.setPlayerWeather(this.level().getLevelData().isRaining() ? WeatherType.DOWNFALL : WeatherType.CLEAR, false);
2014-11-26 08:32:16 +11:00
+ }
+
+ @Override
+ public String toString() {
2021-11-22 09:00:00 +11:00
+ return super.toString() + "(" + this.getScoreboardName() + " at " + this.getX() + "," + this.getY() + "," + this.getZ() + ")";
2014-11-26 08:32:16 +11:00
+ }
+
2016-10-23 14:00:35 +11:00
+ // SPIGOT-1903, MC-98153
+ public void forceSetPositionRotation(double x, double y, double z, float yaw, float pitch) {
2021-11-22 09:00:00 +11:00
+ this.moveTo(x, y, z, yaw, pitch);
+ this.connection.resetPosition();
2016-10-23 14:00:35 +11:00
+ }
+
2016-11-30 09:16:01 +11:00
+ @Override
2021-11-22 09:00:00 +11:00
+ public boolean isImmobile() {
2024-12-11 22:26:55 +01:00
+ return super.isImmobile() || !this.getBukkitEntity().isOnline();
2016-11-30 09:16:01 +11:00
+ }
+
2017-08-05 09:15:52 +10:00
+ @Override
+ public Scoreboard getScoreboard() {
2024-12-11 22:26:55 +01:00
+ return this.getBukkitEntity().getScoreboard().getHandle();
2017-08-05 09:15:52 +10:00
+ }
+
2014-11-26 08:32:16 +11:00
+ public void reset() {
+ float exp = 0;
+
2021-08-11 18:49:49 +10:00
+ if (this.keepLevel) { // CraftBukkit - SPIGOT-6687: Only use keepLevel (was pre-set with RULE_KEEPINVENTORY value in PlayerDeathEvent)
2021-06-11 15:00:00 +10:00
+ exp = this.experienceProgress;
+ this.newTotalExp = this.totalExperience;
+ this.newLevel = this.experienceLevel;
2014-11-26 08:32:16 +11:00
+ }
+
+ this.setHealth(this.getMaxHealth());
2021-11-22 09:00:00 +11:00
+ this.stopUsingItem(); // CraftBukkit - SPIGOT-6682: Clear active item on reset
2023-06-11 17:30:03 +10:00
+ this.setRemainingFireTicks(0);
2014-11-26 08:32:16 +11:00
+ this.fallDistance = 0;
2024-12-11 22:26:55 +01:00
+ this.foodData = new FoodData();
2021-06-11 15:00:00 +10:00
+ this.experienceLevel = this.newLevel;
+ this.totalExperience = this.newTotalExp;
+ this.experienceProgress = 0;
+ this.deathTime = 0;
2020-09-02 18:52:40 +10:00
+ this.setArrowCount(0, true); // CraftBukkit - ArrowBodyCountChangeEvent
2018-07-20 16:04:37 +10:00
+ this.removeAllEffects(org.bukkit.event.entity.EntityPotionEffectEvent.Cause.DEATH);
2021-06-11 15:00:00 +10:00
+ this.effectsDirty = true;
+ this.containerMenu = this.inventoryMenu;
+ this.lastHurtByPlayer = null;
+ this.lastHurtByMob = null;
2014-11-26 08:32:16 +11:00
+ this.combatTracker = new CombatTracker(this);
+ this.lastSentExp = -1;
2021-08-11 18:49:49 +10:00
+ if (this.keepLevel) { // CraftBukkit - SPIGOT-6687: Only use keepLevel (was pre-set with RULE_KEEPINVENTORY value in PlayerDeathEvent)
2021-06-11 15:00:00 +10:00
+ this.experienceProgress = exp;
2014-11-26 08:32:16 +11:00
+ } else {
2021-11-22 09:00:00 +11:00
+ this.giveExperiencePoints(this.newExp);
2014-11-26 08:32:16 +11:00
+ }
+ this.keepLevel = false;
2022-05-17 19:22:58 +10:00
+ this.setDeltaMovement(0, 0, 0); // CraftBukkit - SPIGOT-6948: Reset velocity on death
2023-12-26 07:42:19 +11:00
+ this.skipDropExperience = false; // CraftBukkit - SPIGOT-7462: Reset experience drop skip, so that further deaths drop xp
2014-11-26 08:32:16 +11:00
+ }
2019-04-23 12:00:00 +10:00
+
2014-11-26 08:32:16 +11:00
+ @Override
+ public CraftPlayer getBukkitEntity() {
+ return (CraftPlayer) super.getBukkitEntity();
2019-04-23 12:00:00 +10:00
+ }
2014-11-26 08:32:16 +11:00
+ // CraftBukkit end
}