Skip to content

Commit

Permalink
Fix villagers, polymer blocks not having correct default shape
Browse files Browse the repository at this point in the history
  • Loading branch information
Patbox committed Nov 2, 2024
1 parent 9968f7c commit 30794a1
Show file tree
Hide file tree
Showing 8 changed files with 51 additions and 17 deletions.
2 changes: 1 addition & 1 deletion gradle.properties
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ fabric_version=0.106.1+1.21.3

maven_group = eu.pb4

mod_version = 0.10.1
mod_version = 0.10.2

minecraft_version_supported = ">=1.21.2-"

Expand Down
2 changes: 1 addition & 1 deletion polymer-autohost/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ dependencies {

compileOnly (project(path: ':polymer-virtual-entity', configuration: 'namedElements'))
localRuntime (project(path: ':polymer-virtual-entity', configuration: 'namedElements'))
//modLocalRuntime("xyz.nucleoid:server-translations-api:2.0.0-beta.2+1.19.4-pre2")
modLocalRuntime("xyz.nucleoid:server-translations-api:2.4.0+1.21.2-rc1")
api include('io.netty:netty-codec-http:4.1.82.Final')

project(":polymer-core").afterEvaluate {
Expand Down
3 changes: 1 addition & 2 deletions polymer-core/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -67,8 +67,7 @@ dependencies {

modCompileOnly "xyz.nucleoid:disguiselib-fabric:1.2.2"

modCompileOnly("xyz.nucleoid:server-translations-api:2.3.0+1.20.5-rc2")
//modLocalRuntime("xyz.nucleoid:server-translations-api:2.0.0-beta.2+1.19.4-pre2")
modCompileOnly("xyz.nucleoid:server-translations-api:2.4.0+1.21.2-rc1")

modCompileOnly 'com.github.iPortalTeam:ImmersivePortalsMod:v5.1.0-mc1.20.4'

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,7 @@ public static BlockState getBlockStateSafely(PolymerBlock block, BlockState bloc

int req = 0;
while (out.getBlock() instanceof PolymerBlock newBlock && newBlock != block && req < maxDistance) {
out = newBlock.getPolymerBlockState(blockState, context);
out = newBlock.getPolymerBlockState(out, context);
req++;
}
return out;
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
package eu.pb4.polymer.core.impl.other;

import net.minecraft.component.ComponentChanges;
import net.minecraft.component.ComponentMap;
import net.minecraft.component.ComponentType;
import org.jetbrains.annotations.Nullable;

import java.util.HashSet;
import java.util.Set;

public record ComponentChangesMap(ComponentChanges changes) implements ComponentMap {
@Nullable
@Override
public <T> T get(ComponentType<? extends T> type) {
var x = this.changes.get(type);
//noinspection OptionalAssignedToNull
return x != null ? x.orElse(null) : null;
}

@Override
public Set<ComponentType<?>> getTypes() {
var set = new HashSet<ComponentType<?>>();
for (var entry : this.changes.entrySet()) {
if (entry.getValue().isPresent()) {
set.add(entry.getKey());
}
}
return set;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -24,16 +24,16 @@ public class MicroUiElements {
EMPTY.set(DataComponentTypes.HIDE_TOOLTIP, Unit.INSTANCE);

BUTTON_PREVIOUS = Items.GREEN_STAINED_GLASS_PANE.getDefaultStack();
BUTTON_PREVIOUS.set(DataComponentTypes.CUSTOM_NAME, Text.translatable("createWorld.customize.custom.prev").setStyle(Style.EMPTY.withItalic(false).withColor(Formatting.GREEN)));
BUTTON_PREVIOUS.set(DataComponentTypes.CUSTOM_NAME, Text.translatable("spectatorMenu.previous_page").setStyle(Style.EMPTY.withItalic(false).withColor(Formatting.GREEN)));

BUTTON_PREVIOUS_LOCK = Items.WHITE_STAINED_GLASS_PANE.getDefaultStack();
BUTTON_PREVIOUS_LOCK.set(DataComponentTypes.CUSTOM_NAME, Text.translatable("createWorld.customize.custom.prev").setStyle(Style.EMPTY.withItalic(false).withColor(Formatting.DARK_GRAY)));
BUTTON_PREVIOUS_LOCK.set(DataComponentTypes.CUSTOM_NAME, Text.translatable("spectatorMenu.previous_page").setStyle(Style.EMPTY.withItalic(false).withColor(Formatting.DARK_GRAY)));

BUTTON_NEXT = Items.GREEN_STAINED_GLASS_PANE.getDefaultStack();
BUTTON_NEXT.set(DataComponentTypes.CUSTOM_NAME, Text.translatable("createWorld.customize.custom.next").setStyle(Style.EMPTY.withItalic(false).withColor(Formatting.GREEN)));
BUTTON_NEXT.set(DataComponentTypes.CUSTOM_NAME, Text.translatable("spectatorMenu.next_page").setStyle(Style.EMPTY.withItalic(false).withColor(Formatting.GREEN)));

BUTTON_NEXT_LOCK = Items.WHITE_STAINED_GLASS_PANE.getDefaultStack();
BUTTON_NEXT_LOCK.set(DataComponentTypes.CUSTOM_NAME, Text.translatable("createWorld.customize.custom.next").setStyle(Style.EMPTY.withItalic(false).withColor(Formatting.DARK_GRAY)));
BUTTON_NEXT_LOCK.set(DataComponentTypes.CUSTOM_NAME, Text.translatable("spectatorMenu.next_page").setStyle(Style.EMPTY.withItalic(false).withColor(Formatting.DARK_GRAY)));

BUTTON_BACK = Items.BARRIER.getDefaultStack();
BUTTON_BACK.set(DataComponentTypes.CUSTOM_NAME, Text.translatable("gui.back").setStyle(Style.EMPTY.withItalic(false).withColor(Formatting.RED)));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,9 @@
public class AbstractBlockMixin {
@Inject(method = "getOutlineShape", at = @At("HEAD"), cancellable = true)
private void polymer$replaceOutlineShape(BlockState state, BlockView world, BlockPos pos, ShapeContext context, CallbackInfoReturnable<VoxelShape> cir) {
if (this instanceof PolymerBlock block && world instanceof World realWorld) {
var clientState = PolymerBlockUtils.getBlockStateSafely(block, state, PacketContext.create(realWorld.getRegistryManager()));
if (this instanceof PolymerBlock block) {
var clientState = PolymerBlockUtils.getBlockStateSafely(block, state,
world instanceof World realWorld ? PacketContext.create(realWorld.getRegistryManager()) : PacketContext.create());
if (!(clientState.getBlock() instanceof PolymerBlock)) {
cir.setReturnValue(clientState.getOutlineShape(world, pos, context));
}
Expand All @@ -31,11 +32,11 @@ public class AbstractBlockMixin {

@Inject(method = "getCollisionShape", at = @At("HEAD"), cancellable = true)
private void polymer$replaceCollision(BlockState state, BlockView world, BlockPos pos, ShapeContext context, CallbackInfoReturnable<VoxelShape> cir) {
if (this instanceof PolymerBlock block && world instanceof World realWorld) {
if (this instanceof PolymerBlock block) {
var clientState = context instanceof EntityShapeContext entityShapeContext
&& entityShapeContext.getEntity() instanceof ServerPlayerEntity player
? PolymerBlockUtils.getBlockStateSafely(block, state, PacketContext.create(player))
: PolymerBlockUtils.getBlockStateSafely(block, state, PacketContext.create(realWorld.getRegistryManager()));
: PolymerBlockUtils.getBlockStateSafely(block, state, world instanceof World realWorld ? PacketContext.create(realWorld.getRegistryManager()) : PacketContext.create());
if (!(clientState.getBlock() instanceof PolymerBlock)) {
cir.setReturnValue(clientState.getCollisionShape(world, pos, context));
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
import com.llamalad7.mixinextras.injector.ModifyExpressionValue;
import eu.pb4.polymer.core.api.item.PolymerItemUtils;
import eu.pb4.polymer.core.impl.networking.TransformingPacketCodec;
import eu.pb4.polymer.core.impl.other.ComponentChangesMap;
import net.minecraft.component.ComponentMap;
import net.minecraft.network.RegistryByteBuf;
import net.minecraft.network.codec.PacketCodec;
import net.minecraft.predicate.ComponentPredicate;
Expand All @@ -16,11 +18,13 @@ public class TradedItemMixin {
@ModifyExpressionValue(method = "<clinit>", at = @At(value = "INVOKE", target = "Lnet/minecraft/network/codec/PacketCodec;tuple(Lnet/minecraft/network/codec/PacketCodec;Ljava/util/function/Function;Lnet/minecraft/network/codec/PacketCodec;Ljava/util/function/Function;Lnet/minecraft/network/codec/PacketCodec;Ljava/util/function/Function;Lcom/mojang/datafixers/util/Function3;)Lnet/minecraft/network/codec/PacketCodec;"))
private static PacketCodec<RegistryByteBuf, TradedItem> polymerifyTheStack(PacketCodec<RegistryByteBuf, TradedItem> original) {
return new TransformingPacketCodec<>(original, (buf, tradedItem) -> {
var stack = PolymerItemUtils.getPolymerItemStack(tradedItem.itemStack(), PacketContext.get());
return new TradedItem(stack.getItem().getRegistryEntry(), stack.getCount(), ComponentPredicate.of(stack.getComponents()));
var input = tradedItem.itemStack();
var stack = PolymerItemUtils.getPolymerItemStack(input, PacketContext.get());
return stack != input ? new TradedItem(stack.getItem().getRegistryEntry(), stack.getCount(), ComponentPredicate.of(new ComponentChangesMap(stack.getComponentChanges()))) : tradedItem;
}, (buf, tradedItem) -> {
var stack = PolymerItemUtils.getRealItemStack(tradedItem.itemStack(), buf.getRegistryManager());
return new TradedItem(stack.getItem().getRegistryEntry(), stack.getCount(), ComponentPredicate.of(stack.getComponents()));
var input = tradedItem.itemStack();
var stack = PolymerItemUtils.getRealItemStack(input, buf.getRegistryManager());
return stack != input ? new TradedItem(stack.getItem().getRegistryEntry(), stack.getCount(), ComponentPredicate.of(new ComponentChangesMap(stack.getComponentChanges()))) : tradedItem;
});
}
}

0 comments on commit 30794a1

Please sign in to comment.