mirror of
https://github.com/SparklyPower/SparklyPaper.git
synced 2025-12-19 15:09:27 +00:00
145 lines
8.0 KiB
Diff
145 lines
8.0 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: MrPowerGamerBR <git@mrpowergamerbr.com>
|
|
Date: Mon, 10 Jun 2024 13:06:30 -0300
|
|
Subject: [PATCH] Helpful NMS packet changes
|
|
|
|
Some nice changes to the packet internals to make packet sending and manipulation easier for us to avoid Reflection and JVM internals (ooo theUnsafe spooky) usage
|
|
|
|
diff --git a/net/minecraft/network/protocol/game/ClientboundAddEntityPacket.java b/net/minecraft/network/protocol/game/ClientboundAddEntityPacket.java
|
|
index 1373977b339405ef59bb3ea03d195285c96dd3fe..20a782d1bb7355bbdc0822a02204e1e05dc44145 100644
|
|
--- a/net/minecraft/network/protocol/game/ClientboundAddEntityPacket.java
|
|
+++ b/net/minecraft/network/protocol/game/ClientboundAddEntityPacket.java
|
|
@@ -22,7 +22,7 @@ public class ClientboundAddEntityPacket implements Packet<ClientGamePacketListen
|
|
private static final double LIMIT = 3.9;
|
|
private final int id;
|
|
private final UUID uuid;
|
|
- private final EntityType<?> type;
|
|
+ public EntityType<?> type; // SparklyPaper - Helpful NMS packet changes: remove final and make public
|
|
private final double x;
|
|
private final double y;
|
|
private final double z;
|
|
@@ -180,6 +180,32 @@ public class ClientboundAddEntityPacket implements Packet<ClientGamePacketListen
|
|
return Mth.unpackDegrees(this.yHeadRot);
|
|
}
|
|
|
|
+ // SparklyPaper - Helpful NMS packet changes: expose raw rotational fields
|
|
+ public int getXaRaw() {
|
|
+ return this.xa;
|
|
+ }
|
|
+
|
|
+ public int getYaRaw() {
|
|
+ return this.ya;
|
|
+ }
|
|
+
|
|
+ public int getZaRaw() {
|
|
+ return this.za;
|
|
+ }
|
|
+
|
|
+ public byte getXRotRaw() {
|
|
+ return this.xRot;
|
|
+ }
|
|
+
|
|
+ public byte getYRotRaw() {
|
|
+ return this.yRot;
|
|
+ }
|
|
+
|
|
+ public byte getYHeadRotRaw() {
|
|
+ return this.yHeadRot;
|
|
+ }
|
|
+ // SparklyPaper end
|
|
+
|
|
public int getData() {
|
|
return this.data;
|
|
}
|
|
diff --git a/net/minecraft/network/protocol/game/ClientboundBlockUpdatePacket.java b/net/minecraft/network/protocol/game/ClientboundBlockUpdatePacket.java
|
|
index 8fca836e63731c5cef95bbc07e6e1414c9f02bea..c412dcab882abe11ecae34700df3e62ece464b82 100644
|
|
--- a/net/minecraft/network/protocol/game/ClientboundBlockUpdatePacket.java
|
|
+++ b/net/minecraft/network/protocol/game/ClientboundBlockUpdatePacket.java
|
|
@@ -19,7 +19,7 @@ public class ClientboundBlockUpdatePacket implements Packet<ClientGamePacketList
|
|
ClientboundBlockUpdatePacket::new
|
|
);
|
|
private final BlockPos pos;
|
|
- public final BlockState blockState;
|
|
+ public BlockState blockState; // SparklyPaper - Helpful NMS packet changes: remove final
|
|
|
|
public ClientboundBlockUpdatePacket(BlockPos pos, BlockState blockState) {
|
|
this.pos = pos;
|
|
diff --git a/net/minecraft/network/protocol/game/ClientboundLevelChunkPacketData.java b/net/minecraft/network/protocol/game/ClientboundLevelChunkPacketData.java
|
|
index 9e321ef1c3d5803519b243685f4ee598dc0cf640..851931062c4401817aad14721ac7fb0362c3b418 100644
|
|
--- a/net/minecraft/network/protocol/game/ClientboundLevelChunkPacketData.java
|
|
+++ b/net/minecraft/network/protocol/game/ClientboundLevelChunkPacketData.java
|
|
@@ -25,7 +25,7 @@ import net.minecraft.world.level.levelgen.Heightmap;
|
|
public class ClientboundLevelChunkPacketData {
|
|
private static final int TWO_MEGABYTES = 2097152;
|
|
private final CompoundTag heightmaps;
|
|
- private final byte[] buffer;
|
|
+ public byte[] buffer; // SparklyPaper - Helpful NMS packet changes: remove final and make public
|
|
private final List<ClientboundLevelChunkPacketData.BlockEntityInfo> blockEntitiesData;
|
|
// Paper start - Handle oversized block entities in chunks
|
|
private final java.util.List<net.minecraft.network.protocol.Packet<?>> extraPackets = new java.util.ArrayList<>();
|
|
diff --git a/net/minecraft/network/protocol/game/ClientboundRotateHeadPacket.java b/net/minecraft/network/protocol/game/ClientboundRotateHeadPacket.java
|
|
index 4bcbf4bff67d4d4958d56764a273cf4a66b9dd0c..fd621a5d02170f6aa297dbd6a08ba1fef60e54c9 100644
|
|
--- a/net/minecraft/network/protocol/game/ClientboundRotateHeadPacket.java
|
|
+++ b/net/minecraft/network/protocol/game/ClientboundRotateHeadPacket.java
|
|
@@ -20,6 +20,13 @@ public class ClientboundRotateHeadPacket implements Packet<ClientGamePacketListe
|
|
this.yHeadRot = yHeadRot;
|
|
}
|
|
|
|
+ // SparklyPaper start - Helpful NMS packet changes: add entity ID constructor
|
|
+ public ClientboundRotateHeadPacket(int entityId, byte headYaw) {
|
|
+ this.entityId = entityId;
|
|
+ this.yHeadRot = headYaw;
|
|
+ }
|
|
+ // SparklyPaper end
|
|
+
|
|
private ClientboundRotateHeadPacket(FriendlyByteBuf buffer) {
|
|
this.entityId = buffer.readVarInt();
|
|
this.yHeadRot = buffer.readByte();
|
|
diff --git a/net/minecraft/network/protocol/game/ClientboundSectionBlocksUpdatePacket.java b/net/minecraft/network/protocol/game/ClientboundSectionBlocksUpdatePacket.java
|
|
index 10b46c59d83d1274cf491f217df2355d13b594c1..de8767eb8a01e1fed06fbb9d8d5904a83fd19bf5 100644
|
|
--- a/net/minecraft/network/protocol/game/ClientboundSectionBlocksUpdatePacket.java
|
|
+++ b/net/minecraft/network/protocol/game/ClientboundSectionBlocksUpdatePacket.java
|
|
@@ -17,9 +17,9 @@ public class ClientboundSectionBlocksUpdatePacket implements Packet<ClientGamePa
|
|
ClientboundSectionBlocksUpdatePacket::write, ClientboundSectionBlocksUpdatePacket::new
|
|
);
|
|
private static final int POS_IN_SECTION_BITS = 12;
|
|
- private final SectionPos sectionPos;
|
|
- private final short[] positions;
|
|
- private final BlockState[] states;
|
|
+ public SectionPos sectionPos; // SparklyPaper - Helpful NMS packet changes: remove final and make public
|
|
+ public short[] positions; // SparklyPaper - Helpful NMS packet changes: remove final and make public
|
|
+ public BlockState[] states; // SparklyPaper - Helpful NMS packet changes: remove final and make public
|
|
|
|
public ClientboundSectionBlocksUpdatePacket(SectionPos sectionPos, ShortSet positions, LevelChunkSection section) {
|
|
this.sectionPos = sectionPos;
|
|
diff --git a/net/minecraft/network/protocol/game/ClientboundSetCameraPacket.java b/net/minecraft/network/protocol/game/ClientboundSetCameraPacket.java
|
|
index 2545057c7f1f355f59f1e7da06ce08fd2d997b43..9920fe2d2f2f74f372731f1be5abaa4953344632 100644
|
|
--- a/net/minecraft/network/protocol/game/ClientboundSetCameraPacket.java
|
|
+++ b/net/minecraft/network/protocol/game/ClientboundSetCameraPacket.java
|
|
@@ -22,6 +22,12 @@ public class ClientboundSetCameraPacket implements Packet<ClientGamePacketListen
|
|
this.cameraId = buffer.readVarInt();
|
|
}
|
|
|
|
+ // SparklyPaper - Helpful NMS packet changes: add direct entityId constructor
|
|
+ public ClientboundSetCameraPacket(int entityId) {
|
|
+ this.cameraId = entityId;
|
|
+ }
|
|
+ // SparklyPaper end
|
|
+
|
|
private void write(FriendlyByteBuf buffer) {
|
|
buffer.writeVarInt(this.cameraId);
|
|
}
|
|
diff --git a/net/minecraft/world/entity/Display.java b/net/minecraft/world/entity/Display.java
|
|
index ff49fdcddb43ee479a377aa219eb18fcaefeffca..33a47487f79fdc5164ff6a6d639dfe5834deed0d 100644
|
|
--- a/net/minecraft/world/entity/Display.java
|
|
+++ b/net/minecraft/world/entity/Display.java
|
|
@@ -800,7 +800,7 @@ public abstract class Display extends Entity {
|
|
public static final byte FLAG_ALIGN_RIGHT = 16;
|
|
private static final byte INITIAL_TEXT_OPACITY = -1;
|
|
public static final int INITIAL_BACKGROUND = 1073741824;
|
|
- private static final EntityDataAccessor<Component> DATA_TEXT_ID = SynchedEntityData.defineId(Display.TextDisplay.class, EntityDataSerializers.COMPONENT);
|
|
+ public static final EntityDataAccessor<Component> DATA_TEXT_ID = SynchedEntityData.defineId(Display.TextDisplay.class, EntityDataSerializers.COMPONENT); // SparklyPaper - Helpful NMS packet changes: make public
|
|
public static final EntityDataAccessor<Integer> DATA_LINE_WIDTH_ID = SynchedEntityData.defineId(Display.TextDisplay.class, EntityDataSerializers.INT);
|
|
public static final EntityDataAccessor<Integer> DATA_BACKGROUND_COLOR_ID = SynchedEntityData.defineId(
|
|
Display.TextDisplay.class, EntityDataSerializers.INT
|