mirror of
https://github.com/LeavesMC/Leaves.git
synced 2025-12-19 14:59:32 +00:00
117 lines
5.3 KiB
Diff
117 lines
5.3 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: violetc <58360096+s-yh-china@users.noreply.github.com>
|
|
Date: Sat, 30 Oct 2021 21:07:43 +0800
|
|
Subject: [PATCH] Fix gravity block duper
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/Entity.java b/src/main/java/net/minecraft/world/entity/Entity.java
|
|
index 49cf3601df7b145d49b1fe9a71ba0bc60c5394b3..702937e741c8607958f6e0215d11dc347b12ee3c 100644
|
|
--- a/src/main/java/net/minecraft/world/entity/Entity.java
|
|
+++ b/src/main/java/net/minecraft/world/entity/Entity.java
|
|
@@ -398,36 +398,8 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource {
|
|
return chunkMap.playerEntityTrackerTrackMaps[type.ordinal()].getObjectsInRange(MCUtil.getCoordinateKey(this));
|
|
}
|
|
// Paper end - optimise entity tracking
|
|
- // Paper start - make end portalling safe
|
|
- public BlockPos portalBlock;
|
|
- public ServerLevel portalWorld;
|
|
- public void tickEndPortal() {
|
|
- BlockPos pos = this.portalBlock;
|
|
- ServerLevel world = this.portalWorld;
|
|
- this.portalBlock = null;
|
|
- this.portalWorld = null;
|
|
-
|
|
- if (pos == null || world == null || world != this.level) {
|
|
- return;
|
|
- }
|
|
-
|
|
- if (this.isPassenger() || this.isVehicle() || !this.canChangeDimensions() || this.isRemoved() || !this.valid || !this.isAlive()) {
|
|
- return;
|
|
- }
|
|
|
|
- ResourceKey<Level> resourcekey = world.getTypeKey() == LevelStem.END ? Level.OVERWORLD : Level.END; // CraftBukkit - SPIGOT-6152: send back to main overworld in custom ends
|
|
- ServerLevel worldserver = world.getServer().getLevel(resourcekey);
|
|
-
|
|
- org.bukkit.event.entity.EntityPortalEnterEvent event = new org.bukkit.event.entity.EntityPortalEnterEvent(this.getBukkitEntity(), new org.bukkit.Location(world.getWorld(), pos.getX(), pos.getY(), pos.getZ()));
|
|
- event.callEvent();
|
|
-
|
|
- if (this instanceof ServerPlayer) {
|
|
- ((ServerPlayer)this).changeDimension(worldserver, PlayerTeleportEvent.TeleportCause.END_PORTAL);
|
|
- return;
|
|
- }
|
|
- this.teleportTo(worldserver, null);
|
|
- }
|
|
- // Paper end - make end portalling safe
|
|
+ // Leaves - fix gravity block duper
|
|
|
|
// Paper start
|
|
/**
|
|
@@ -2786,7 +2758,7 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource {
|
|
}
|
|
|
|
this.processPortalCooldown();
|
|
- this.tickEndPortal(); // Paper - make end portalling safe
|
|
+ // Leaves - fix gravity block duper
|
|
}
|
|
}
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/item/FallingBlockEntity.java b/src/main/java/net/minecraft/world/entity/item/FallingBlockEntity.java
|
|
index 46102c28d10b11ecbafd3dda2de66982eaed8a00..4fcabda051480cb260194ed6116cb3d43a6d0caa 100644
|
|
--- a/src/main/java/net/minecraft/world/entity/item/FallingBlockEntity.java
|
|
+++ b/src/main/java/net/minecraft/world/entity/item/FallingBlockEntity.java
|
|
@@ -126,11 +126,7 @@ public class FallingBlockEntity extends Entity {
|
|
|
|
@Override
|
|
public void tick() {
|
|
- // Paper start - fix sand duping
|
|
- if (this.isRemoved()) {
|
|
- return;
|
|
- }
|
|
- // Paper end - fix sand duping
|
|
+ // Leaves - fix gravity block duper
|
|
if (this.blockState.isAir()) {
|
|
this.discard();
|
|
} else {
|
|
@@ -143,11 +139,7 @@ public class FallingBlockEntity extends Entity {
|
|
|
|
this.move(MoverType.SELF, this.getDeltaMovement());
|
|
|
|
- // Paper start - fix sand duping
|
|
- if (this.isRemoved()) {
|
|
- return;
|
|
- }
|
|
- // Paper end - fix sand duping
|
|
+ // Leaves - fix gravity block duper
|
|
|
|
// Paper start - Configurable EntityFallingBlock height nerf
|
|
if (this.level.paperConfig.fallingBlockHeightNerf != 0 && this.getY() > this.level.paperConfig.fallingBlockHeightNerf) {
|
|
diff --git a/src/main/java/net/minecraft/world/level/block/EndPortalBlock.java b/src/main/java/net/minecraft/world/level/block/EndPortalBlock.java
|
|
index 19892cb3cb290add4f094dc87bb22106e4f07a24..e2172172019af22b3474456b6d6cc6bd3ff4351a 100644
|
|
--- a/src/main/java/net/minecraft/world/level/block/EndPortalBlock.java
|
|
+++ b/src/main/java/net/minecraft/world/level/block/EndPortalBlock.java
|
|
@@ -53,12 +53,19 @@ public class EndPortalBlock extends BaseEntityBlock {
|
|
// return; // CraftBukkit - always fire event in case plugins wish to change it
|
|
}
|
|
|
|
- // Paper start - move all of this logic into portal tick
|
|
- entity.portalWorld = ((ServerLevel)world);
|
|
- entity.portalBlock = pos.immutable();
|
|
- // Paper end - move all of this logic into portal tick
|
|
- }
|
|
+ // Leaves start - fix gravity block duper
|
|
+ // CraftBukkit start - Entity in portal
|
|
+ EntityPortalEnterEvent event = new EntityPortalEnterEvent(entity.getBukkitEntity(), new org.bukkit.Location(world.getWorld(), pos.getX(), pos.getY(), pos.getZ()));
|
|
+ world.getCraftServer().getPluginManager().callEvent(event);
|
|
|
|
+ if (entity instanceof ServerPlayer) {
|
|
+ ((ServerPlayer) entity).changeDimension(worldserver, PlayerTeleportEvent.TeleportCause.END_PORTAL);
|
|
+ return;
|
|
+ }
|
|
+ // CraftBukkit end
|
|
+ entity.changeDimension(worldserver);
|
|
+ // Leaves end - fix gravity block duper
|
|
+ }
|
|
}
|
|
|
|
@Override
|