generated from NeoForgeMDKs/MDK-1.21-NeoGradle
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge remote-tracking branch 'origin/main'
- Loading branch information
Showing
15 changed files
with
486 additions
and
14 deletions.
There are no files selected for viewing
285 changes: 285 additions & 0 deletions
285
src/main/java/com/portingdeadmods/modjam/api/blockentities/ContainerBlockEntity.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,285 @@ | ||
package com.portingdeadmods.modjam.api.blockentities; | ||
|
||
import com.google.common.collect.ImmutableMap; | ||
import com.portingdeadmods.modjam.capabilities.IOActions; | ||
import com.portingdeadmods.modjam.capabilities.fluid.SidedFluidHandler; | ||
import com.portingdeadmods.modjam.capabilities.item.SidedItemHandler; | ||
import com.portingdeadmods.modjam.capabilities.power.IPowerStorage; | ||
import com.portingdeadmods.modjam.capabilities.power.PowerStorage; | ||
import it.unimi.dsi.fastutil.Pair; | ||
import net.minecraft.SharedConstants; | ||
import net.minecraft.core.BlockPos; | ||
import net.minecraft.core.Direction; | ||
import net.minecraft.core.HolderLookup; | ||
import net.minecraft.nbt.CompoundTag; | ||
import net.minecraft.network.Connection; | ||
import net.minecraft.network.protocol.Packet; | ||
import net.minecraft.network.protocol.game.ClientGamePacketListener; | ||
import net.minecraft.network.protocol.game.ClientboundBlockEntityDataPacket; | ||
import net.minecraft.world.Containers; | ||
import net.minecraft.world.SimpleContainer; | ||
import net.minecraft.world.item.Item; | ||
import net.minecraft.world.item.ItemStack; | ||
import net.minecraft.world.level.block.entity.BlockEntity; | ||
import net.minecraft.world.level.block.entity.BlockEntityType; | ||
import net.minecraft.world.level.block.state.BlockState; | ||
import net.minecraft.world.level.block.state.properties.BlockStateProperties; | ||
import net.neoforged.neoforge.capabilities.BlockCapability; | ||
import net.neoforged.neoforge.capabilities.Capabilities; | ||
import net.neoforged.neoforge.fluids.FluidStack; | ||
import net.neoforged.neoforge.fluids.capability.IFluidHandler; | ||
import net.neoforged.neoforge.fluids.capability.templates.FluidTank; | ||
import net.neoforged.neoforge.items.IItemHandler; | ||
import net.neoforged.neoforge.items.ItemStackHandler; | ||
import org.jetbrains.annotations.NotNull; | ||
import org.jetbrains.annotations.Nullable; | ||
|
||
import java.util.Map; | ||
import java.util.function.BiPredicate; | ||
import java.util.function.Predicate; | ||
|
||
public abstract class ContainerBlockEntity extends BlockEntity { | ||
private @Nullable ItemStackHandler itemHandler; | ||
private @Nullable FluidTank fluidTank; | ||
private @Nullable PowerStorage powerStorage; | ||
|
||
public ContainerBlockEntity(BlockEntityType<?> blockEntityType, BlockPos blockPos, BlockState blockState) { | ||
super(blockEntityType, blockPos, blockState); | ||
} | ||
|
||
public void commonTick() { | ||
} | ||
|
||
public IItemHandler getItemHandler() { | ||
return itemHandler; | ||
} | ||
|
||
public IFluidHandler getFluidHandler() { | ||
return fluidTank; | ||
} | ||
|
||
public IPowerStorage getPowerStorage() { | ||
return powerStorage; | ||
} | ||
|
||
protected ItemStackHandler getItemStackHandler() { | ||
return itemHandler; | ||
} | ||
|
||
protected FluidTank getFluidTank() { | ||
return fluidTank; | ||
} | ||
|
||
protected PowerStorage getEnergyStorageImpl() { | ||
return powerStorage; | ||
} | ||
|
||
@Override | ||
protected void loadAdditional(@NotNull CompoundTag nbt, HolderLookup.@NotNull Provider provider) { | ||
super.loadAdditional(nbt, provider); | ||
if (this.getFluidTank() != null) | ||
this.getFluidTank().readFromNBT(provider, nbt); | ||
if (this.getItemStackHandler() != null) | ||
this.getItemStackHandler().deserializeNBT(provider, nbt.getCompound("itemhandler")); | ||
if (this.getEnergyStorageImpl() != null) | ||
this.getEnergyStorageImpl().deserializeNBT(provider, nbt.getCompound("energy_storage")); | ||
loadData(nbt, provider); | ||
} | ||
|
||
@Override | ||
protected void saveAdditional(@NotNull CompoundTag nbt, HolderLookup.@NotNull Provider provider) { | ||
super.saveAdditional(nbt, provider); | ||
if (getFluidTank() != null) | ||
getFluidTank().writeToNBT(provider, nbt); | ||
if (getItemStackHandler() != null) | ||
nbt.put("itemhandler", getItemStackHandler().serializeNBT(provider)); | ||
if (getEnergyStorageImpl() != null) | ||
nbt.put("energy_storage", getEnergyStorageImpl().serializeNBT(provider)); | ||
saveData(nbt, provider); | ||
} | ||
|
||
protected void loadData(CompoundTag tag, HolderLookup.Provider provider) { | ||
} | ||
|
||
protected void saveData(CompoundTag tag, HolderLookup.Provider provider) { | ||
} | ||
|
||
protected final void addItemHandler(int slots) { | ||
addItemHandler(slots, (slot, itemStack) -> true); | ||
} | ||
|
||
protected final void addItemHandler(int slots, int slotLimit) { | ||
addItemHandler(slots, slotLimit, (slot, itemStack) -> true); | ||
} | ||
|
||
protected final void addItemHandler(int slots, BiPredicate<Integer, ItemStack> validation) { | ||
addItemHandler(slots, 64, validation); | ||
} | ||
|
||
protected final void addFluidTank(int capacityInMb) { | ||
addFluidTank(capacityInMb, fluidStack -> true); | ||
} | ||
|
||
protected final void addItemHandler(int slots, int slotLimit, BiPredicate<Integer, ItemStack> validation) { | ||
this.itemHandler = new ItemStackHandler(slots) { | ||
@Override | ||
protected void onContentsChanged(int slot) { | ||
update(); | ||
setChanged(); | ||
onItemsChanged(slot); | ||
invalidateCapabilities(); | ||
} | ||
|
||
@Override | ||
public boolean isItemValid(int slot, @NotNull ItemStack stack) { | ||
return validation.test(slot, stack); | ||
} | ||
|
||
@Override | ||
public int getSlotLimit(int slot) { | ||
return slotLimit; | ||
} | ||
}; | ||
} | ||
|
||
protected final void addFluidTank(int capacityInMb, Predicate<FluidStack> validation) { | ||
this.fluidTank = new FluidTank(capacityInMb) { | ||
@Override | ||
protected void onContentsChanged() { | ||
update(); | ||
setChanged(); | ||
onFluidChanged(); | ||
} | ||
|
||
@Override | ||
public boolean isFluidValid(FluidStack stack) { | ||
return validation.test(stack); | ||
} | ||
}; | ||
} | ||
|
||
protected final void addEnergyStorage(int powerCapacity) { | ||
this.powerStorage = new PowerStorage() { | ||
@Override | ||
public void onEnergyChanged() { | ||
update(); | ||
setChanged(); | ||
ContainerBlockEntity.this.onPowerChanged(); | ||
} | ||
}; | ||
this.powerStorage.setPowerCapacity(powerCapacity); | ||
} | ||
|
||
private void update() { | ||
if (!level.isClientSide()) { | ||
level.sendBlockUpdated(getBlockPos(), getBlockState(), getBlockState(), 3); | ||
} | ||
} | ||
|
||
protected void onItemsChanged(int slot) { | ||
} | ||
|
||
protected void onFluidChanged() { | ||
} | ||
|
||
public void onPowerChanged() { | ||
} | ||
|
||
public void onHeatChanged() { | ||
} | ||
|
||
public void drop() { | ||
ItemStack[] stacks = getItemHandlerStacks(); | ||
SimpleContainer inventory = new SimpleContainer(stacks); | ||
Containers.dropContents(this.level, this.worldPosition, inventory); | ||
} | ||
|
||
public @Nullable ItemStack[] getItemHandlerStacks() { | ||
IItemHandler itemStackHandler = getItemHandler(); | ||
|
||
if (itemStackHandler == null) return null; | ||
|
||
ItemStack[] itemStacks = new ItemStack[itemStackHandler.getSlots()]; | ||
for (int i = 0; i < itemStackHandler.getSlots(); i++) { | ||
itemStacks[i] = itemStackHandler.getStackInSlot(i); | ||
} | ||
return itemStacks; | ||
} | ||
|
||
public <T> T getHandlerOnSide(BlockCapability<T, @Nullable Direction> capability, SidedHandlerSupplier<T> handlerSupplier, Direction direction, T baseHandler) { | ||
if (direction == null) { | ||
return baseHandler; | ||
} | ||
|
||
Map<Direction, Pair<IOActions, int[]>> ioPorts = getSidedInteractions(capability); | ||
if (ioPorts.containsKey(direction)) { | ||
|
||
if (direction == Direction.UP || direction == Direction.DOWN) { | ||
return handlerSupplier.get(baseHandler, ioPorts.get(direction)); | ||
} | ||
|
||
if (!this.getBlockState().hasProperty(BlockStateProperties.HORIZONTAL_FACING)) { | ||
return null; | ||
} | ||
|
||
Direction localDir = this.getBlockState().getValue(BlockStateProperties.HORIZONTAL_FACING); | ||
|
||
return switch (localDir) { | ||
case NORTH -> handlerSupplier.get(baseHandler, ioPorts.get(direction.getOpposite())); | ||
case EAST -> handlerSupplier.get(baseHandler, ioPorts.get(direction.getClockWise())); | ||
case SOUTH -> handlerSupplier.get(baseHandler, ioPorts.get(direction)); | ||
case WEST -> handlerSupplier.get(baseHandler, ioPorts.get(direction.getCounterClockWise())); | ||
default -> null; | ||
}; | ||
} | ||
|
||
return null; | ||
} | ||
|
||
public IItemHandler getItemHandlerOnSide(Direction direction) { | ||
return getHandlerOnSide( | ||
Capabilities.ItemHandler.BLOCK, | ||
SidedItemHandler::new, | ||
direction, | ||
getItemHandler() | ||
); | ||
} | ||
|
||
public IFluidHandler getFluidHandlerOnSide(Direction direction) { | ||
return getHandlerOnSide( | ||
Capabilities.FluidHandler.BLOCK, | ||
SidedFluidHandler::new, | ||
direction, | ||
getFluidHandler() | ||
); | ||
} | ||
|
||
/** | ||
* Get the input/output config for the blockenitity. | ||
* If directions are not defined in the map, they are assumed to be {@link IOActions#NONE} and do not affect any slot. | ||
* | ||
* @return Map of directions that each map to a pair that defines the IOAction as well as the tanks that are affected. Return an empty map if you do not have an itemhandler | ||
*/ | ||
public abstract <T> ImmutableMap<Direction, Pair<IOActions, int[]>> getSidedInteractions(BlockCapability<T, @Nullable Direction> capability); | ||
|
||
@Nullable | ||
@Override | ||
public Packet<ClientGamePacketListener> getUpdatePacket() { | ||
return ClientboundBlockEntityDataPacket.create(this); | ||
} | ||
|
||
@Override | ||
public @NotNull CompoundTag getUpdateTag(HolderLookup.Provider provider) { | ||
return saveWithoutMetadata(provider); | ||
} | ||
|
||
@Override | ||
public void onDataPacket(Connection net, ClientboundBlockEntityDataPacket pkt, HolderLookup.Provider lookupProvider) { | ||
super.onDataPacket(net, pkt, lookupProvider); | ||
} | ||
|
||
@FunctionalInterface | ||
public interface SidedHandlerSupplier<T> { | ||
T get(T handler, Pair<IOActions, int[]> supportedActions); | ||
} | ||
} |
19 changes: 19 additions & 0 deletions
19
src/main/java/com/portingdeadmods/modjam/api/blockentities/IFluidBE.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package com.portingdeadmods.modjam.api.blockentities; | ||
|
||
import net.neoforged.neoforge.fluids.capability.IFluidHandler; | ||
|
||
public interface IFluidBE { | ||
default ContainerBlockEntity self() { | ||
if (this instanceof ContainerBlockEntity containerBlockEntity) { | ||
return containerBlockEntity; | ||
} | ||
return null; | ||
} | ||
|
||
/** | ||
* Override this if your blockentity does not extend the containerblockentity class | ||
*/ | ||
default IFluidHandler getFluidStorage() { | ||
return self().getFluidHandler(); | ||
} | ||
} |
19 changes: 19 additions & 0 deletions
19
src/main/java/com/portingdeadmods/modjam/api/blockentities/IItemBE.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package com.portingdeadmods.modjam.api.blockentities; | ||
|
||
import net.neoforged.neoforge.items.IItemHandler; | ||
|
||
public interface IItemBE { | ||
default ContainerBlockEntity self() { | ||
if (this instanceof ContainerBlockEntity containerBlockEntity) { | ||
return containerBlockEntity; | ||
} | ||
return null; | ||
} | ||
|
||
/** | ||
* Override this if your blockentity does not extend the containerblockentity class | ||
*/ | ||
default IItemHandler getItemStorage() { | ||
return self().getItemHandler(); | ||
} | ||
} |
19 changes: 19 additions & 0 deletions
19
src/main/java/com/portingdeadmods/modjam/api/blockentities/IPowerBE.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package com.portingdeadmods.modjam.api.blockentities; | ||
|
||
import com.portingdeadmods.modjam.capabilities.power.IPowerStorage; | ||
|
||
public interface IPowerBE { | ||
default ContainerBlockEntity self() { | ||
if (this instanceof ContainerBlockEntity containerBlockEntity) { | ||
return containerBlockEntity; | ||
} | ||
return null; | ||
} | ||
|
||
/** | ||
* Override this if your blockentity does not extend the containerblockentity class | ||
*/ | ||
default IPowerStorage getPowerStorage() { | ||
return self().getPowerStorage(); | ||
} | ||
} |
8 changes: 8 additions & 0 deletions
8
src/main/java/com/portingdeadmods/modjam/capabilities/IOActions.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
package com.portingdeadmods.modjam.capabilities; | ||
|
||
public enum IOActions { | ||
INSERT, | ||
EXTRACT, | ||
BOTH, | ||
NONE, | ||
} |
Oops, something went wrong.