Remove ReflectASM (no more warning message)

This commit is contained in:
Felix Cravic 2020-05-19 17:47:47 +02:00
parent 3c0d351f15
commit 5cb31171e6
9 changed files with 70 additions and 61 deletions

View File

@ -26,7 +26,6 @@ dependencies {
api group: 'it.unimi.dsi', name: 'fastutil', version: '8.3.0'
api 'com.github.Querz:NBT:4.1'
api 'com.esotericsoftware:reflectasm:1.11.9'
// https://mvnrepository.com/artifact/com.google.code.gson/gson
api group: 'com.google.code.gson', name: 'gson', version: '2.8.5'

View File

@ -161,7 +161,6 @@ public class InstanceContainer extends Instance {
}
private short executeBlockPlacementRule(short blockId, BlockPosition blockPosition) {
BlockPlacementRule blockPlacementRule = BLOCK_MANAGER.getBlockPlacementRule(blockId);
if (blockPlacementRule != null) {
return blockPlacementRule.blockRefresh(this, blockPosition);

View File

@ -62,7 +62,8 @@ public abstract class CustomBlock {
* Called at digging start to check for custom breaking time
* Can be set to < 0 to be cancelled, in this case vanilla time will be used
*
* @param player the player who is trying to break the block
* @param player the player who is trying to break the block
* @param position
* @return the time in ms to break it
*/
public abstract int getBreakDelay(Player player, BlockPosition position);
@ -78,11 +79,13 @@ public abstract class CustomBlock {
/**
* Defines custom behaviour for entities touching this block.
*
* @param instance
* @param position the position at which the block is
* @param touching the entity currently touching the block
*/
public void handleContact(Instance instance, BlockPosition position, Entity touching) {}
public void handleContact(Instance instance, BlockPosition position, Entity touching) {
}
public short getBlockId() {
return blockId;
@ -105,19 +108,21 @@ public abstract class CustomBlock {
/**
* Update this block from a neighbor. By default calls 'update' if directNeighbor is true
* @param instance current instance
* @param thisPosition this block's position
*
* @param instance current instance
* @param thisPosition this block's position
* @param neighborPosition the neighboring block which triggered the update
* @param directNeighbor is the neighbor directly connected to this block? (No diagonals)
* @param directNeighbor is the neighbor directly connected to this block? (No diagonals)
*/
public void updateFromNeighbor(Instance instance, BlockPosition thisPosition, BlockPosition neighborPosition, boolean directNeighbor) {
if(directNeighbor && hasUpdate()) {
if (directNeighbor && hasUpdate()) {
update(instance, thisPosition, instance.getBlockData(thisPosition));
}
}
/**
* Called when a scheduled update on this block happens. By default, calls 'update'
*
* @param instance
* @param position
* @param blockData
@ -128,9 +133,11 @@ public abstract class CustomBlock {
/**
* Allows custom block to write block entity data to a given NBT compound
* @param instance instance of which the block lives
* @param position position of the block
*
* @param instance instance of which the block lives
* @param position position of the block
* @param blockData equivalent to <pre>instance.getBlockData(position)</pre>
*/
public void writeBlockEntity(Instance instance, BlockPosition position, Data blockData, CompoundTag nbt) {}
public void writeBlockEntity(Instance instance, BlockPosition position, Data blockData, CompoundTag nbt) {
}
}

View File

@ -1,6 +1,7 @@
package net.minestom.server.network.packet;
import io.netty.buffer.ByteBuf;
import io.netty.buffer.Unpooled;
import net.minestom.server.item.ItemStack;
import net.minestom.server.utils.BlockPosition;
import net.minestom.server.utils.SerializerUtils;
@ -14,6 +15,10 @@ public class PacketReader {
this.buffer = buffer;
}
public PacketReader(byte[] bytes) {
this(Unpooled.wrappedBuffer(bytes));
}
public int readVarInt() {
return Utils.readVarInt(buffer);
}

View File

@ -5,7 +5,7 @@ import net.minestom.server.network.packet.client.login.LoginStartPacket;
public class ClientLoginPacketsHandler extends ClientPacketsHandler {
public ClientLoginPacketsHandler() {
register(0, LoginStartPacket.class);
register(0, LoginStartPacket::new);
}
}

View File

@ -1,17 +1,18 @@
package net.minestom.server.network.packet.client.handler;
import com.esotericsoftware.reflectasm.ConstructorAccess;
import net.minestom.server.network.packet.client.ClientPacket;
import java.util.function.Supplier;
public class ClientPacketsHandler {
// Max packet id
private static final int SIZE = 0x2E;
private ConstructorAccess[] constructorAccesses = new ConstructorAccess[SIZE];
private Supplier<? extends ClientPacket>[] supplierAccesses = new Supplier[SIZE];
public void register(int id, Class<? extends ClientPacket> packet) {
constructorAccesses[id] = ConstructorAccess.get(packet);
public void register(int id, Supplier<? extends ClientPacket> packetSupplier) {
supplierAccesses[id] = packetSupplier;
}
public ClientPacket getPacketInstance(int id) {
@ -19,11 +20,11 @@ public class ClientPacketsHandler {
if (id > SIZE)
throw new IllegalStateException("Packet ID 0x" + Integer.toHexString(id) + " has been tried to be parsed, debug needed");
ConstructorAccess<? extends ClientPacket> constructorAccess = constructorAccesses[id];
if (constructorAccess == null)
Supplier<? extends ClientPacket> supplier = supplierAccesses[id];
if (supplierAccesses == null)
throw new IllegalStateException("Packet id 0x" + Integer.toHexString(id) + " isn't registered!");
ClientPacket packet = constructorAccess.newInstance();
ClientPacket packet = supplier.get();
return packet;
}

View File

@ -5,45 +5,45 @@ import net.minestom.server.network.packet.client.play.*;
public class ClientPlayPacketsHandler extends ClientPacketsHandler {
public ClientPlayPacketsHandler() {
register(0x00, ClientTeleportConfirmPacket.class);
register(0x03, ClientChatMessagePacket.class);
register(0x04, ClientStatusPacket.class);
register(0x05, ClientSettingsPacket.class);
register(0x06, ClientTabCompletePacket.class);
register(0x07, ClientWindowConfirmationPacket.class);
register(0x08, ClientClickWindowButtonPacket.class); // Marked as 0x07 on wiki.vg
register(0x09, ClientClickWindowPacket.class);
register(0x0A, ClientCloseWindow.class);
register(0x0B, ClientPluginMessagePacket.class);
register(0x0E, ClientInteractEntityPacket.class);
register(0x0F, ClientKeepAlivePacket.class);
register(0x00, ClientTeleportConfirmPacket::new);
register(0x03, ClientChatMessagePacket::new);
register(0x04, ClientStatusPacket::new);
register(0x05, ClientSettingsPacket::new);
register(0x06, ClientTabCompletePacket::new);
register(0x07, ClientWindowConfirmationPacket::new);
register(0x08, ClientClickWindowButtonPacket::new); // Marked as 0x07 on wiki.vg
register(0x09, ClientClickWindowPacket::new);
register(0x0A, ClientCloseWindow::new);
register(0x0B, ClientPluginMessagePacket::new);
register(0x0E, ClientInteractEntityPacket::new);
register(0x0F, ClientKeepAlivePacket::new);
// 0x10 packet not used server-side
register(0x11, ClientPlayerPositionPacket.class);
register(0x12, ClientPlayerPositionAndLookPacket.class);
register(0x13, ClientPlayerLookPacket.class);
register(0x14, ClientPlayerPacket.class);
register(0x15, ClientVehicleMovePacket.class);
register(0x16, ClientSteerBoatPacket.class);
register(0x17, ClientPickItemPacket.class);
register(0x18, ClientCraftRecipeRequest.class);
register(0x19, ClientPlayerAbilitiesPacket.class);
register(0x1A, ClientPlayerDiggingPacket.class);
register(0x1B, ClientEntityActionPacket.class);
register(0x1C, ClientSteerVehiclePacket.class);
register(0x1D, ClientRecipeBookData.class);
register(0x1E, ClientNameItemPacket.class);
register(0x1F, ClientResourcePackStatusPacket.class);
register(0x11, ClientPlayerPositionPacket::new);
register(0x12, ClientPlayerPositionAndLookPacket::new);
register(0x13, ClientPlayerLookPacket::new);
register(0x14, ClientPlayerPacket::new);
register(0x15, ClientVehicleMovePacket::new);
register(0x16, ClientSteerBoatPacket::new);
register(0x17, ClientPickItemPacket::new);
register(0x18, ClientCraftRecipeRequest::new);
register(0x19, ClientPlayerAbilitiesPacket::new);
register(0x1A, ClientPlayerDiggingPacket::new);
register(0x1B, ClientEntityActionPacket::new);
register(0x1C, ClientSteerVehiclePacket::new);
register(0x1D, ClientRecipeBookData::new);
register(0x1E, ClientNameItemPacket::new);
register(0x1F, ClientResourcePackStatusPacket::new);
register(0x20, ClientAdvancementTabPacket.class);
register(0x21, ClientSelectTradePacket.class);
register(0x23, ClientHeldItemChangePacket.class);
register(0x24, ClientUpdateCommandBlockPacket.class);
register(0x25, ClientUpdateCommandBlockMinecartPacket.class);
register(0x26, ClientCreativeInventoryActionPacket.class);
register(0x29, ClientUpdateSignPacket.class);
register(0x2A, ClientAnimationPacket.class);
register(0x2C, ClientPlayerBlockPlacementPacket.class);
register(0x2D, ClientUseItemPacket.class);
register(0x20, ClientAdvancementTabPacket::new);
register(0x21, ClientSelectTradePacket::new);
register(0x23, ClientHeldItemChangePacket::new);
register(0x24, ClientUpdateCommandBlockPacket::new);
register(0x25, ClientUpdateCommandBlockMinecartPacket::new);
register(0x26, ClientCreativeInventoryActionPacket::new);
register(0x29, ClientUpdateSignPacket::new);
register(0x2A, ClientAnimationPacket::new);
register(0x2C, ClientPlayerBlockPlacementPacket::new);
register(0x2D, ClientUseItemPacket::new);
}
}

View File

@ -6,8 +6,8 @@ import net.minestom.server.network.packet.client.status.StatusRequestPacket;
public class ClientStatusPacketsHandler extends ClientPacketsHandler {
public ClientStatusPacketsHandler() {
register(0x00, StatusRequestPacket.class);
register(0x01, PingPacket.class);
register(0x00, StatusRequestPacket::new);
register(0x01, PingPacket::new);
}
}

View File

@ -1,6 +1,5 @@
package net.minestom.server.storage;
import io.netty.buffer.ByteBuf;
import io.netty.buffer.Unpooled;
import net.minestom.server.MinecraftServer;
import net.minestom.server.data.DataContainer;
@ -70,8 +69,7 @@ public class StorageFolder {
if (data == null)
return null;
ByteBuf buffer = Unpooled.wrappedBuffer(data);
PacketReader packetReader = new PacketReader(buffer);
PacketReader packetReader = new PacketReader(data);
T value = dataType.decode(packetReader);
return value;
}