Ask First

- Fixed Arms and Ejectors sending their placement configuration too early
This commit is contained in:
simibubi 2022-08-19 14:35:33 +02:00
parent 7ea13cd6b1
commit caa498875c
6 changed files with 85 additions and 16 deletions

View file

@ -1,6 +1,9 @@
package com.simibubi.create.content.logistics.block.depot; package com.simibubi.create.content.logistics.block.depot;
import com.simibubi.create.foundation.networking.AllPackets;
import net.minecraft.core.BlockPos; import net.minecraft.core.BlockPos;
import net.minecraft.server.level.ServerPlayer;
import net.minecraft.world.InteractionResult; import net.minecraft.world.InteractionResult;
import net.minecraft.world.entity.player.Player; import net.minecraft.world.entity.player.Player;
import net.minecraft.world.item.BlockItem; import net.minecraft.world.item.BlockItem;
@ -10,9 +13,8 @@ import net.minecraft.world.item.context.UseOnContext;
import net.minecraft.world.level.Level; import net.minecraft.world.level.Level;
import net.minecraft.world.level.block.Block; import net.minecraft.world.level.block.Block;
import net.minecraft.world.level.block.state.BlockState; import net.minecraft.world.level.block.state.BlockState;
import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.fml.DistExecutor;
import net.minecraftforge.fml.common.Mod.EventBusSubscriber; import net.minecraftforge.fml.common.Mod.EventBusSubscriber;
import net.minecraftforge.network.PacketDistributor;
@EventBusSubscriber @EventBusSubscriber
public class EjectorItem extends BlockItem { public class EjectorItem extends BlockItem {
@ -36,11 +38,12 @@ public class EjectorItem extends BlockItem {
} }
@Override @Override
protected boolean updateCustomBlockEntityTag(BlockPos pos, Level world, Player p_195943_3_, ItemStack p_195943_4_, protected boolean updateCustomBlockEntityTag(BlockPos pos, Level world, Player player, ItemStack p_195943_4_,
BlockState p_195943_5_) { BlockState p_195943_5_) {
if (world.isClientSide) if (!world.isClientSide && player instanceof ServerPlayer sp)
DistExecutor.unsafeRunWhenOn(Dist.CLIENT, () -> () -> EjectorTargetHandler.flushSettings(pos)); AllPackets.channel.send(PacketDistributor.PLAYER.with(() -> sp),
return super.updateCustomBlockEntityTag(pos, world, p_195943_3_, p_195943_4_, p_195943_5_); new EjectorPlacementPacket.ClientBoundRequest(pos));
return super.updateCustomBlockEntityTag(pos, world, player, p_195943_4_, p_195943_5_);
} }
@Override @Override

View file

@ -12,6 +12,8 @@ import net.minecraft.server.level.ServerPlayer;
import net.minecraft.world.level.Level; import net.minecraft.world.level.Level;
import net.minecraft.world.level.block.entity.BlockEntity; import net.minecraft.world.level.block.entity.BlockEntity;
import net.minecraft.world.level.block.state.BlockState; import net.minecraft.world.level.block.state.BlockState;
import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.fml.DistExecutor;
import net.minecraftforge.network.NetworkEvent.Context; import net.minecraftforge.network.NetworkEvent.Context;
public class EjectorPlacementPacket extends SimplePacketBase { public class EjectorPlacementPacket extends SimplePacketBase {
@ -65,4 +67,32 @@ public class EjectorPlacementPacket extends SimplePacketBase {
} }
public static class ClientBoundRequest extends SimplePacketBase {
BlockPos pos;
public ClientBoundRequest(BlockPos pos) {
this.pos = pos;
}
public ClientBoundRequest(FriendlyByteBuf buffer) {
this.pos = buffer.readBlockPos();
}
@Override
public void write(FriendlyByteBuf buffer) {
buffer.writeBlockPos(pos);
}
@Override
public void handle(Supplier<Context> context) {
context.get()
.enqueueWork(() -> DistExecutor.unsafeRunWhenOn(Dist.CLIENT,
() -> () -> EjectorTargetHandler.flushSettings(pos)));
context.get()
.setPacketHandled(true);
}
}
} }

View file

@ -1,6 +1,9 @@
package com.simibubi.create.content.logistics.block.mechanicalArm; package com.simibubi.create.content.logistics.block.mechanicalArm;
import com.simibubi.create.foundation.networking.AllPackets;
import net.minecraft.core.BlockPos; import net.minecraft.core.BlockPos;
import net.minecraft.server.level.ServerPlayer;
import net.minecraft.world.InteractionResult; import net.minecraft.world.InteractionResult;
import net.minecraft.world.entity.player.Player; import net.minecraft.world.entity.player.Player;
import net.minecraft.world.item.BlockItem; import net.minecraft.world.item.BlockItem;
@ -9,9 +12,8 @@ import net.minecraft.world.item.context.UseOnContext;
import net.minecraft.world.level.Level; import net.minecraft.world.level.Level;
import net.minecraft.world.level.block.Block; import net.minecraft.world.level.block.Block;
import net.minecraft.world.level.block.state.BlockState; import net.minecraft.world.level.block.state.BlockState;
import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.fml.DistExecutor;
import net.minecraftforge.fml.common.Mod.EventBusSubscriber; import net.minecraftforge.fml.common.Mod.EventBusSubscriber;
import net.minecraftforge.network.PacketDistributor;
@EventBusSubscriber @EventBusSubscriber
public class ArmItem extends BlockItem { public class ArmItem extends BlockItem {
@ -30,16 +32,16 @@ public class ArmItem extends BlockItem {
} }
@Override @Override
protected boolean updateCustomBlockEntityTag(BlockPos pos, Level world, Player p_195943_3_, ItemStack p_195943_4_, protected boolean updateCustomBlockEntityTag(BlockPos pos, Level world, Player player, ItemStack p_195943_4_,
BlockState p_195943_5_) { BlockState p_195943_5_) {
if (world.isClientSide) if (!world.isClientSide && player instanceof ServerPlayer sp)
DistExecutor.unsafeRunWhenOn(Dist.CLIENT, () -> () -> ArmInteractionPointHandler.flushSettings(pos)); AllPackets.channel.send(PacketDistributor.PLAYER.with(() -> sp),
return super.updateCustomBlockEntityTag(pos, world, p_195943_3_, p_195943_4_, p_195943_5_); new ArmPlacementPacket.ClientBoundRequest(pos));
return super.updateCustomBlockEntityTag(pos, world, player, p_195943_4_, p_195943_5_);
} }
@Override @Override
public boolean canAttackBlock(BlockState state, Level world, BlockPos pos, public boolean canAttackBlock(BlockState state, Level world, BlockPos pos, Player p_195938_4_) {
Player p_195938_4_) {
return !ArmInteractionPoint.isInteractable(world, pos, state); return !ArmInteractionPoint.isInteractable(world, pos, state);
} }

View file

@ -13,6 +13,8 @@ import net.minecraft.network.FriendlyByteBuf;
import net.minecraft.server.level.ServerPlayer; import net.minecraft.server.level.ServerPlayer;
import net.minecraft.world.level.Level; import net.minecraft.world.level.Level;
import net.minecraft.world.level.block.entity.BlockEntity; import net.minecraft.world.level.block.entity.BlockEntity;
import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.fml.DistExecutor;
import net.minecraftforge.network.NetworkEvent.Context; import net.minecraftforge.network.NetworkEvent.Context;
public class ArmPlacementPacket extends SimplePacketBase { public class ArmPlacementPacket extends SimplePacketBase {
@ -67,4 +69,32 @@ public class ArmPlacementPacket extends SimplePacketBase {
} }
public static class ClientBoundRequest extends SimplePacketBase {
BlockPos pos;
public ClientBoundRequest(BlockPos pos) {
this.pos = pos;
}
public ClientBoundRequest(FriendlyByteBuf buffer) {
this.pos = buffer.readBlockPos();
}
@Override
public void write(FriendlyByteBuf buffer) {
buffer.writeBlockPos(pos);
}
@Override
public void handle(Supplier<Context> context) {
context.get()
.enqueueWork(() -> DistExecutor.unsafeRunWhenOn(Dist.CLIENT,
() -> () -> ArmInteractionPointHandler.flushSettings(pos)));
context.get()
.setPacketHandled(true);
}
}
} }

View file

@ -81,7 +81,7 @@ public class ArmTileEntity extends KineticTileEntity implements ITransformableTE
super(typeIn, pos, state); super(typeIn, pos, state);
inputs = new ArrayList<>(); inputs = new ArrayList<>();
outputs = new ArrayList<>(); outputs = new ArrayList<>();
interactionPointTag = new ListTag(); interactionPointTag = null;
heldItem = ItemStack.EMPTY; heldItem = ItemStack.EMPTY;
phase = Phase.SEARCH_INPUTS; phase = Phase.SEARCH_INPUTS;
previousTarget = ArmAngleTarget.NO_TARGET; previousTarget = ArmAngleTarget.NO_TARGET;
@ -480,7 +480,7 @@ public class ArmTileEntity extends KineticTileEntity implements ITransformableTE
} }
public void writeInteractionPoints(CompoundTag compound) { public void writeInteractionPoints(CompoundTag compound) {
if (updateInteractionPoints) { if (updateInteractionPoints && interactionPointTag != null) {
compound.put("InteractionPoints", interactionPointTag); compound.put("InteractionPoints", interactionPointTag);
} else { } else {
ListTag pointsNBT = new ListTag(); ListTag pointsNBT = new ListTag();

View file

@ -184,6 +184,10 @@ public enum AllPackets {
S_TRAIN_PROMPT(TrainPromptPacket.class, TrainPromptPacket::new, PLAY_TO_CLIENT), S_TRAIN_PROMPT(TrainPromptPacket.class, TrainPromptPacket::new, PLAY_TO_CLIENT),
CONTRAPTION_RELOCATION(ContraptionRelocationPacket.class, ContraptionRelocationPacket::new, PLAY_TO_CLIENT), CONTRAPTION_RELOCATION(ContraptionRelocationPacket.class, ContraptionRelocationPacket::new, PLAY_TO_CLIENT),
TRACK_GRAPH_ROLL_CALL(TrackGraphRollCallPacket.class, TrackGraphRollCallPacket::new, PLAY_TO_CLIENT), TRACK_GRAPH_ROLL_CALL(TrackGraphRollCallPacket.class, TrackGraphRollCallPacket::new, PLAY_TO_CLIENT),
S_PLACE_EJECTOR(ArmPlacementPacket.ClientBoundRequest.class, ArmPlacementPacket.ClientBoundRequest::new,
PLAY_TO_CLIENT),
S_PLACE_ARM(EjectorPlacementPacket.ClientBoundRequest.class, EjectorPlacementPacket.ClientBoundRequest::new,
PLAY_TO_CLIENT),
; ;