Remove custom break delay code

This commit is contained in:
TheMode 2021-06-17 15:50:28 +02:00
parent b978eba0fd
commit 6e0598c16a

View File

@ -45,7 +45,6 @@ import net.minestom.server.inventory.PlayerInventory;
import net.minestom.server.item.ItemStack; import net.minestom.server.item.ItemStack;
import net.minestom.server.item.Material; import net.minestom.server.item.Material;
import net.minestom.server.item.metadata.WrittenBookMeta; import net.minestom.server.item.metadata.WrittenBookMeta;
import net.minestom.server.listener.PlayerDiggingListener;
import net.minestom.server.message.ChatMessageType; import net.minestom.server.message.ChatMessageType;
import net.minestom.server.message.ChatPosition; import net.minestom.server.message.ChatPosition;
import net.minestom.server.message.Messenger; import net.minestom.server.message.Messenger;
@ -143,17 +142,6 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
// Game state (https://wiki.vg/Protocol#Change_Game_State) // Game state (https://wiki.vg/Protocol#Change_Game_State)
private boolean enableRespawnScreen; private boolean enableRespawnScreen;
// TODO: CustomBlock break delay
private BlockPosition targetBlockPosition;
// The last break delay requested
private long targetBreakDelay;
// Number of tick since the last stage change
private long targetBlockBreakCount;
// The current stage of the target block, only if multi player breaking is disabled
private byte targetStage;
// Only used if multi player breaking is disabled, contains only this player
private final Set<Player> targetBreakers = Collections.singleton(this);
// Experience orb pickup // Experience orb pickup
protected Cooldown experiencePickupCooldown = new Cooldown(new UpdateOption(10, TimeUnit.TICK)); protected Cooldown experiencePickupCooldown = new Cooldown(new UpdateOption(10, TimeUnit.TICK));
@ -328,54 +316,6 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
super.update(time); // Super update (item pickup/fire management) super.update(time); // Super update (item pickup/fire management)
// Target block stage
// TODO: CustomBlock break delay
// Old code feel free to remove.
// if (targetCustomBlock != null) {
// this.targetBlockBreakCount++;
//
// final boolean processStage = targetBreakDelay < 0 || targetBlockBreakCount >= targetBreakDelay;
//
// // Check if the player did finish his current break delay
// if (processStage) {
//
// // Negative value should skip abs(value) stage
// final byte stageIncrease = (byte) (targetBreakDelay > 0 ? 1 : Math.abs(targetBreakDelay));
//
// // Should increment the target block stage
// if (targetCustomBlock.enableMultiPlayerBreaking()) {
// // Let the custom block object manages the breaking
// final boolean canContinue = targetCustomBlock.processStage(instance, targetBlockPosition, this, stageIncrease);
// if (canContinue) {
// final Set<Player> breakers = targetCustomBlock.getBreakers(instance, targetBlockPosition);
// refreshBreakDelay(breakers);
// } else {
// resetTargetBlock();
// }
// } else {
// // Let the player object manages the breaking
// // The custom block doesn't support multi player breaking
// if (targetStage + stageIncrease >= CustomBlock.MAX_STAGE) {
// // Break the block
// instance.breakBlock(this, targetBlockPosition);
// resetTargetBlock();
// } else {
// // Send the new block break animation packet and refresh data
//
// final Chunk chunk = instance.getChunkAt(targetBlockPosition);
// final int entityId = targetCustomBlock.getBreakEntityId(this);
// final BlockBreakAnimationPacket blockBreakAnimationPacket =
// new BlockBreakAnimationPacket(entityId, targetBlockPosition, targetStage);
// Check.notNull(chunk, "Tried to interact with an unloaded chunk.");
// chunk.sendPacketToViewers(blockBreakAnimationPacket);
//
// refreshBreakDelay(targetBreakers);
// this.targetStage += stageIncrease;
// }
// }
// }
// }
// Experience orb pickup // Experience orb pickup
if (experiencePickupCooldown.isReady(time)) { if (experiencePickupCooldown.isReady(time)) {
experiencePickupCooldown.refreshLastUpdate(time); experiencePickupCooldown.refreshLastUpdate(time);
@ -537,7 +477,6 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
if (chunk.isLoaded()) if (chunk.isLoaded())
chunk.removeViewer(this); chunk.removeViewer(this);
}); });
resetTargetBlock();
playerConnection.disconnect(); playerConnection.disconnect();
} }
@ -2101,11 +2040,9 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
/** /**
* Changes the player ability "Creative Mode". * Changes the player ability "Creative Mode".
* <a href="https://wiki.vg/Protocol#Player_Abilities_.28clientbound.29">see</a>
* <p>
* WARNING: this has nothing to do with {@link CustomBlock#getBreakDelay(Player, BlockPosition, byte, Set)}.
* *
* @param instantBreak true to allow instant break * @param instantBreak true to allow instant break
* @see <a href="https://wiki.vg/Protocol#Player_Abilities_.28clientbound.29">player abilities</a>
*/ */
public void setInstantBreak(boolean instantBreak) { public void setInstantBreak(boolean instantBreak) {
this.instantBreak = instantBreak; this.instantBreak = instantBreak;
@ -2294,45 +2231,6 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
return callItemUpdateStateEvent(true, hand); return callItemUpdateStateEvent(true, hand);
} }
/**
* Refreshes the break delay for the next block break stage.
*
* @param breakers the list of breakers, can be null if {@code this} is the only breaker
*/
private void refreshBreakDelay(@Nullable Set<Player> breakers) {
breakers = breakers == null ? targetBreakers : breakers;
// Refresh the last tick update
this.targetBlockBreakCount = 0;
// TODO: Handle custom blocks break delay.
// // Get if multi player breaking is enabled
// final boolean multiPlayerBreaking = targetCustomBlock.enableMultiPlayerBreaking();
// // Get the stage from the custom block object if it is, otherwise use the local field
// final byte stage = multiPlayerBreaking ? targetCustomBlock.getBreakStage(instance, targetBlockPosition) : targetStage;
// // Retrieve the break delay for the current stage
// this.targetBreakDelay = targetCustomBlock.getBreakDelay(this, targetBlockPosition, stage, breakers);
}
/**
* Resets data from the current block the player is mining.
* If the currently mined block (or if there isn't any) is not a {@link CustomBlock}, nothing happen.
*/
public void resetTargetBlock() {
// Remove effect
PlayerDiggingListener.removeEffect(this);
// TODO: Handle custom blocks break delay.
// if (targetCustomBlock != null) {
// targetCustomBlock.stopDigging(instance, targetBlockPosition, this);
// this.targetCustomBlock = null;
// this.targetBlockPosition = null;
// this.targetBreakDelay = 0;
// this.targetBlockBreakCount = 0;
// this.targetStage = 0;
// }
}
public void refreshVehicleSteer(float sideways, float forward, boolean jump, boolean unmount) { public void refreshVehicleSteer(float sideways, float forward, boolean jump, boolean unmount) {
this.vehicleInformation.refresh(sideways, forward, jump, unmount); this.vehicleInformation.refresh(sideways, forward, jump, unmount);
} }