From d9740556987966e3701616ba6c5d503da01b11f9 Mon Sep 17 00:00:00 2001 From: Basique Date: Tue, 27 Aug 2024 20:34:45 +0300 Subject: [PATCH 1/2] add NETWORK serialization attribute and make MinecraftEndecs#ofRegistry use it --- .../owo/serialization/CodecUtils.java | 4 ++ .../MinecraftSerializationAttributes.java | 14 +++++++ .../serialization/endec/MinecraftEndecs.java | 37 +++++++++++++++++-- .../uwu/network/DispatchedSubclassThree.java | 11 ++++++ .../uwu/network/UwuNetworkExample.java | 5 ++- 5 files changed, 67 insertions(+), 4 deletions(-) create mode 100644 src/main/java/io/wispforest/owo/serialization/MinecraftSerializationAttributes.java create mode 100644 src/testmod/java/io/wispforest/uwu/network/DispatchedSubclassThree.java diff --git a/src/main/java/io/wispforest/owo/serialization/CodecUtils.java b/src/main/java/io/wispforest/owo/serialization/CodecUtils.java index 4a2ddd9d..ae75e445 100644 --- a/src/main/java/io/wispforest/owo/serialization/CodecUtils.java +++ b/src/main/java/io/wispforest/owo/serialization/CodecUtils.java @@ -271,6 +271,8 @@ public T decode(B buf) { ? SerializationContext.attributes(RegistriesAttribute.of(registryByteBuf.getRegistryManager())) : SerializationContext.empty(); + ctx = ctx.withAttributes(MinecraftSerializationAttributes.NETWORK); + return endec.decode(ctx, ByteBufDeserializer.of(buf)); } @@ -280,6 +282,8 @@ public void encode(B buf, T value) { ? SerializationContext.attributes(RegistriesAttribute.of(registryByteBuf.getRegistryManager())) : SerializationContext.empty(); + ctx = ctx.withAttributes(MinecraftSerializationAttributes.NETWORK); + endec.encode(ctx, ByteBufSerializer.of(buf), value); } }; diff --git a/src/main/java/io/wispforest/owo/serialization/MinecraftSerializationAttributes.java b/src/main/java/io/wispforest/owo/serialization/MinecraftSerializationAttributes.java new file mode 100644 index 00000000..596e7df6 --- /dev/null +++ b/src/main/java/io/wispforest/owo/serialization/MinecraftSerializationAttributes.java @@ -0,0 +1,14 @@ +package io.wispforest.owo.serialization; + +import io.wispforest.endec.SerializationAttribute; + +public final class MinecraftSerializationAttributes { + private MinecraftSerializationAttributes() { } + + /** + * This format will be sent over the network. + *

+ * Registries and block states can be represented as integer IDs. + */ + public static final SerializationAttribute.Marker NETWORK = SerializationAttribute.marker("network"); +} diff --git a/src/main/java/io/wispforest/owo/serialization/endec/MinecraftEndecs.java b/src/main/java/io/wispforest/owo/serialization/endec/MinecraftEndecs.java index 96df755f..9c14c849 100644 --- a/src/main/java/io/wispforest/owo/serialization/endec/MinecraftEndecs.java +++ b/src/main/java/io/wispforest/owo/serialization/endec/MinecraftEndecs.java @@ -1,14 +1,19 @@ package io.wispforest.owo.serialization.endec; import com.mojang.datafixers.util.Function3; -import io.wispforest.endec.Endec; -import io.wispforest.endec.SerializationAttributes; +import io.wispforest.endec.*; import io.wispforest.endec.impl.ReflectiveEndecBuilder; import io.wispforest.endec.impl.StructEndecBuilder; import io.wispforest.owo.serialization.CodecUtils; +import io.wispforest.owo.serialization.MinecraftSerializationAttributes; +import net.fabricmc.fabric.api.event.registry.RegistryAttribute; +import net.fabricmc.fabric.api.event.registry.RegistryAttributeHolder; import net.fabricmc.fabric.api.networking.v1.PacketByteBufs; +import net.minecraft.block.Block; +import net.minecraft.item.Item; import net.minecraft.item.ItemStack; import net.minecraft.network.PacketByteBuf; +import net.minecraft.registry.Registries; import net.minecraft.registry.Registry; import net.minecraft.registry.RegistryKey; import net.minecraft.registry.tag.TagKey; @@ -105,11 +110,37 @@ public static ReflectiveEndecBuilder addDefaults(ReflectiveEndecBuilder builder) builder.register(BLOCK_HIT_RESULT, BlockHitResult.class); + builder.register(ofRegistry(Registries.ITEM), Item.class) + .register(ofRegistry(Registries.BLOCK), Block.class); + return builder; } public static Endec ofRegistry(Registry registry) { - return IDENTIFIER.xmap(registry::get, registry::getId); + Endec idEndec = IDENTIFIER.xmap(registry::get, registry::getId); + Endec rawIdEndec = Endec.VAR_INT.xmap(registry::get, registry::getRawId); + + return new Endec<>() { + @Override + public void encode(SerializationContext ctx, Serializer serializer, T value) { + if (RegistryAttributeHolder.get(registry).hasAttribute(RegistryAttribute.SYNCED) + && ctx.hasAttribute(MinecraftSerializationAttributes.NETWORK)) { + rawIdEndec.encode(ctx, serializer, value); + } else { + idEndec.encode(ctx, serializer, value); + } + } + + @Override + public T decode(SerializationContext ctx, Deserializer deserializer) { + if (RegistryAttributeHolder.get(registry).hasAttribute(RegistryAttribute.SYNCED) + && ctx.hasAttribute(MinecraftSerializationAttributes.NETWORK)) { + return rawIdEndec.decode(ctx, deserializer); + } else { + return idEndec.decode(ctx, deserializer); + } + } + }; } public static Endec> unprefixedTagKey(RegistryKey> registry) { diff --git a/src/testmod/java/io/wispforest/uwu/network/DispatchedSubclassThree.java b/src/testmod/java/io/wispforest/uwu/network/DispatchedSubclassThree.java new file mode 100644 index 00000000..ad5b07c8 --- /dev/null +++ b/src/testmod/java/io/wispforest/uwu/network/DispatchedSubclassThree.java @@ -0,0 +1,11 @@ +package io.wispforest.uwu.network; + +import net.minecraft.block.Block; +import net.minecraft.item.Item; + +public record DispatchedSubclassThree(Item item, Block block) implements DispatchedInterface { + @Override + public String getName() { + return "three"; + } +} diff --git a/src/testmod/java/io/wispforest/uwu/network/UwuNetworkExample.java b/src/testmod/java/io/wispforest/uwu/network/UwuNetworkExample.java index a8a82d25..a9e8bdb7 100644 --- a/src/testmod/java/io/wispforest/uwu/network/UwuNetworkExample.java +++ b/src/testmod/java/io/wispforest/uwu/network/UwuNetworkExample.java @@ -1,7 +1,6 @@ package io.wispforest.uwu.network; import io.wispforest.endec.impl.RecordEndec; -import io.wispforest.endec.impl.ReflectiveEndecBuilder; import io.wispforest.owo.network.OwoNetChannel; import io.wispforest.endec.Endec; import io.wispforest.endec.StructEndec; @@ -9,7 +8,9 @@ import net.fabricmc.api.Environment; import net.fabricmc.fabric.api.client.event.lifecycle.v1.ClientTickEvents; import net.fabricmc.fabric.api.client.keybinding.v1.KeyBindingHelper; +import net.minecraft.block.Blocks; import net.minecraft.client.option.KeyBinding; +import net.minecraft.item.Items; import net.minecraft.text.Text; import net.minecraft.util.Identifier; import org.lwjgl.glfw.GLFW; @@ -28,6 +29,7 @@ public static void init() { REGISTRY.put("one", RecordEndec.create(CHANNEL.builder(), DispatchedSubclassOne.class)); REGISTRY.put("two", RecordEndec.create(CHANNEL.builder(), DispatchedSubclassTwo.class)); + REGISTRY.put("three", RecordEndec.create(CHANNEL.builder(), DispatchedSubclassThree.class)); CHANNEL.registerClientbound(StringPacket.class, (message, access) -> { access.player().sendMessage(Text.of(message.value()), false); @@ -67,6 +69,7 @@ public static void init() { CHANNEL.clientHandle().send(new MaldingPacket(new DispatchedSubclassOne("base"))); CHANNEL.clientHandle().send(new MaldingPacket(new DispatchedSubclassTwo(20))); + CHANNEL.clientHandle().send(new MaldingPacket(new DispatchedSubclassThree(Items.ACACIA_BOAT, Blocks.DRAGON_EGG))); CHANNEL.clientHandle().send(new NullablePacket(null, null)); CHANNEL.clientHandle().send(new NullablePacket("Weeee", null)); From 24389cd3b462114a8958a82de608ad2dab4b5f63 Mon Sep 17 00:00:00 2001 From: Basique Date: Fri, 30 Aug 2024 23:55:14 +0300 Subject: [PATCH 2/2] add block state endec --- .../owo/serialization/endec/MinecraftEndecs.java | 8 ++++++++ .../wispforest/uwu/network/DispatchedSubclassThree.java | 3 ++- .../java/io/wispforest/uwu/network/UwuNetworkExample.java | 8 +++++++- 3 files changed, 17 insertions(+), 2 deletions(-) diff --git a/src/main/java/io/wispforest/owo/serialization/endec/MinecraftEndecs.java b/src/main/java/io/wispforest/owo/serialization/endec/MinecraftEndecs.java index 9c14c849..c4b8eb76 100644 --- a/src/main/java/io/wispforest/owo/serialization/endec/MinecraftEndecs.java +++ b/src/main/java/io/wispforest/owo/serialization/endec/MinecraftEndecs.java @@ -10,6 +10,7 @@ import net.fabricmc.fabric.api.event.registry.RegistryAttributeHolder; import net.fabricmc.fabric.api.networking.v1.PacketByteBufs; import net.minecraft.block.Block; +import net.minecraft.block.BlockState; import net.minecraft.item.Item; import net.minecraft.item.ItemStack; import net.minecraft.network.PacketByteBuf; @@ -92,6 +93,11 @@ private MinecraftEndecs() {} : BlockHitResult.createMissed(pos, side, blockPos) ); + public static final Endec BLOCK_STATE = Endec.ifAttr( + MinecraftSerializationAttributes.NETWORK, Endec.VAR_INT.xmap(Block.STATE_IDS::get, Block.STATE_IDS::getRawId) + ) + .orElse(CodecUtils.toEndec(BlockState.CODEC)); + // --- Constructors for MC types --- public static ReflectiveEndecBuilder addDefaults(ReflectiveEndecBuilder builder) { @@ -113,6 +119,8 @@ public static ReflectiveEndecBuilder addDefaults(ReflectiveEndecBuilder builder) builder.register(ofRegistry(Registries.ITEM), Item.class) .register(ofRegistry(Registries.BLOCK), Block.class); + builder.register(BLOCK_STATE, BlockState.class); + return builder; } diff --git a/src/testmod/java/io/wispforest/uwu/network/DispatchedSubclassThree.java b/src/testmod/java/io/wispforest/uwu/network/DispatchedSubclassThree.java index ad5b07c8..a722b3ba 100644 --- a/src/testmod/java/io/wispforest/uwu/network/DispatchedSubclassThree.java +++ b/src/testmod/java/io/wispforest/uwu/network/DispatchedSubclassThree.java @@ -1,9 +1,10 @@ package io.wispforest.uwu.network; import net.minecraft.block.Block; +import net.minecraft.block.BlockState; import net.minecraft.item.Item; -public record DispatchedSubclassThree(Item item, Block block) implements DispatchedInterface { +public record DispatchedSubclassThree(Item item, Block block, BlockState state) implements DispatchedInterface { @Override public String getName() { return "three"; diff --git a/src/testmod/java/io/wispforest/uwu/network/UwuNetworkExample.java b/src/testmod/java/io/wispforest/uwu/network/UwuNetworkExample.java index a9e8bdb7..5999dd59 100644 --- a/src/testmod/java/io/wispforest/uwu/network/UwuNetworkExample.java +++ b/src/testmod/java/io/wispforest/uwu/network/UwuNetworkExample.java @@ -9,10 +9,12 @@ import net.fabricmc.fabric.api.client.event.lifecycle.v1.ClientTickEvents; import net.fabricmc.fabric.api.client.keybinding.v1.KeyBindingHelper; import net.minecraft.block.Blocks; +import net.minecraft.block.HorizontalFacingBlock; import net.minecraft.client.option.KeyBinding; import net.minecraft.item.Items; import net.minecraft.text.Text; import net.minecraft.util.Identifier; +import net.minecraft.util.math.Direction; import org.lwjgl.glfw.GLFW; import java.util.HashMap; @@ -69,7 +71,11 @@ public static void init() { CHANNEL.clientHandle().send(new MaldingPacket(new DispatchedSubclassOne("base"))); CHANNEL.clientHandle().send(new MaldingPacket(new DispatchedSubclassTwo(20))); - CHANNEL.clientHandle().send(new MaldingPacket(new DispatchedSubclassThree(Items.ACACIA_BOAT, Blocks.DRAGON_EGG))); + CHANNEL.clientHandle().send(new MaldingPacket(new DispatchedSubclassThree( + Items.ACACIA_BOAT, + Blocks.DRAGON_EGG, + Blocks.OAK_STAIRS.getDefaultState().with(HorizontalFacingBlock.FACING, Direction.EAST) + ))); CHANNEL.clientHandle().send(new NullablePacket(null, null)); CHANNEL.clientHandle().send(new NullablePacket("Weeee", null));