ActuallyAdditions/src/main/java/de/ellpeck/actuallyadditions/mod/tile/TileEntityItemRepairer.java

169 lines
6.4 KiB
Java
Raw Normal View History

2015-08-29 14:33:25 +02:00
/*
2016-05-16 22:52:27 +02:00
* This file ("TileEntityItemRepairer.java") is part of the Actually Additions mod for Minecraft.
2015-08-29 14:33:25 +02:00
* It is created and owned by Ellpeck and distributed
* under the Actually Additions License to be found at
2016-05-16 22:52:27 +02:00
* http://ellpeck.de/actaddlicense
2015-08-29 14:33:25 +02:00
* View the source code at https://github.com/Ellpeck/ActuallyAdditions
*
2017-01-01 16:23:26 +01:00
* © 2015-2017 Ellpeck
2015-08-29 14:33:25 +02:00
*/
2016-01-05 04:47:35 +01:00
package de.ellpeck.actuallyadditions.mod.tile;
2015-04-02 12:06:42 +02:00
2019-05-02 09:54:52 +02:00
import java.util.ArrayList;
import java.util.List;
import org.apache.commons.lang3.tuple.Pair;
import de.ellpeck.actuallyadditions.mod.ActuallyAdditions;
import de.ellpeck.actuallyadditions.mod.config.values.ConfigStringListValues;
2018-08-10 05:04:07 +02:00
import de.ellpeck.actuallyadditions.mod.util.ItemStackHandlerAA.IAcceptor;
import de.ellpeck.actuallyadditions.mod.util.ItemStackHandlerAA.IRemover;
import de.ellpeck.actuallyadditions.mod.util.StackUtil;
import net.minecraft.item.Item;
2015-04-02 12:06:42 +02:00
import net.minecraft.item.ItemStack;
import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.util.EnumFacing;
2019-05-02 09:54:52 +02:00
import net.minecraft.util.ResourceLocation;
2016-11-26 08:58:42 +01:00
import net.minecraftforge.energy.IEnergyStorage;
2019-05-02 09:54:52 +02:00
import net.minecraftforge.fml.common.registry.ForgeRegistries;
2016-01-07 18:20:59 +01:00
import net.minecraftforge.fml.relauncher.Side;
import net.minecraftforge.fml.relauncher.SideOnly;
2015-04-02 12:06:42 +02:00
2018-08-10 05:04:07 +02:00
public class TileEntityItemRepairer extends TileEntityInventoryBase {
2015-04-02 12:06:42 +02:00
2015-05-20 22:39:43 +02:00
public static final int SLOT_INPUT = 0;
public static final int SLOT_OUTPUT = 1;
public static final int ENERGY_USE = 2500;
2016-11-26 20:43:50 +01:00
public final CustomEnergyStorage storage = new CustomEnergyStorage(300000, 6000, 0);
2015-04-02 12:06:42 +02:00
public int nextRepairTick;
2015-10-03 10:16:18 +02:00
private int lastEnergy;
2015-04-02 12:06:42 +02:00
2018-08-10 05:04:07 +02:00
public TileEntityItemRepairer() {
2015-05-20 22:39:43 +02:00
super(2, "repairer");
2015-04-02 12:06:42 +02:00
}
2018-08-10 05:04:07 +02:00
public static boolean canBeRepaired(ItemStack stack) {
if (StackUtil.isValid(stack)) {
Item item = stack.getItem();
2018-08-10 05:04:07 +02:00
if (item != null) {
if (item.isRepairable() && item.getMaxDamage(stack) > 0) {
return true;
2018-08-10 05:04:07 +02:00
} else {
String reg = item.getRegistryName().toString();
2018-08-10 05:04:07 +02:00
if (reg != null) {
for (String strg : ConfigStringListValues.REPAIRER_EXTRA_WHITELIST.getValue()) {
if (reg.equals(strg)) { return true; }
}
}
}
}
}
return false;
2016-02-01 20:39:11 +01:00
}
@Override
2018-08-10 05:04:07 +02:00
public void writeSyncableNBT(NBTTagCompound compound, NBTType type) {
if (type != NBTType.SAVE_BLOCK) {
compound.setInteger("NextRepairTick", this.nextRepairTick);
}
super.writeSyncableNBT(compound, type);
this.storage.writeToNBT(compound);
}
@Override
2018-08-10 05:04:07 +02:00
public void readSyncableNBT(NBTTagCompound compound, NBTType type) {
if (type != NBTType.SAVE_BLOCK) {
this.nextRepairTick = compound.getInteger("NextRepairTick");
}
super.readSyncableNBT(compound, type);
this.storage.readFromNBT(compound);
}
2015-04-02 12:06:42 +02:00
@Override
2018-08-10 05:04:07 +02:00
public void updateEntity() {
super.updateEntity();
2018-08-10 05:04:07 +02:00
if (!this.world.isRemote) {
ItemStack input = this.inv.getStackInSlot(SLOT_INPUT);
2018-08-10 05:04:07 +02:00
if (!StackUtil.isValid(this.inv.getStackInSlot(SLOT_OUTPUT)) && canBeRepaired(input)) {
if (input.getItemDamage() <= 0) {
this.inv.setStackInSlot(SLOT_OUTPUT, input.copy());
this.inv.setStackInSlot(SLOT_INPUT, StackUtil.getEmpty());
2015-05-20 22:39:43 +02:00
this.nextRepairTick = 0;
2018-08-10 05:04:07 +02:00
} else {
if (this.storage.getEnergyStored() >= ENERGY_USE) {
2015-05-20 22:39:43 +02:00
this.nextRepairTick++;
this.storage.extractEnergyInternal(ENERGY_USE, false);
2018-08-10 05:04:07 +02:00
if (this.nextRepairTick >= 4) {
2015-05-20 22:39:43 +02:00
this.nextRepairTick = 0;
2018-08-10 05:04:07 +02:00
input.setItemDamage(input.getItemDamage() - 1);
2018-08-10 05:04:07 +02:00
if (input.hasTagCompound()) {
//TiCon un-break tools
2018-08-10 05:04:07 +02:00
if ("tconstruct".equalsIgnoreCase(input.getItem().getRegistryName().getNamespace())) {
NBTTagCompound stats = input.getTagCompound().getCompoundTag("Stats");
stats.removeTag("Broken");
}
}
2015-04-02 12:06:42 +02:00
}
}
}
2018-08-10 05:04:07 +02:00
} else {
2015-10-02 16:48:01 +02:00
this.nextRepairTick = 0;
}
2018-08-10 05:04:07 +02:00
if (this.lastEnergy != this.storage.getEnergyStored() && this.sendUpdateWithInterval()) {
this.lastEnergy = this.storage.getEnergyStored();
}
2015-04-02 12:06:42 +02:00
}
}
@SideOnly(Side.CLIENT)
2018-08-10 05:04:07 +02:00
public int getEnergyScaled(int i) {
return this.storage.getEnergyStored() * i / this.storage.getMaxEnergyStored();
2015-04-02 12:06:42 +02:00
}
2018-08-10 05:04:07 +02:00
public int getItemDamageToScale(int i) {
if (StackUtil.isValid(this.inv.getStackInSlot(SLOT_INPUT))) { return (this.inv.getStackInSlot(SLOT_INPUT).getMaxDamage() - this.inv.getStackInSlot(SLOT_INPUT).getItemDamage()) * i / this.inv.getStackInSlot(SLOT_INPUT).getMaxDamage(); }
2015-04-02 12:06:42 +02:00
return 0;
}
2019-05-02 09:54:52 +02:00
@Override
public IEnergyStorage getEnergyStorage(EnumFacing facing) {
return this.storage;
}
@Override
public IAcceptor getAcceptor() {
return (slot, stack, automation) -> !isBlacklisted(stack) && (!automation || slot == SLOT_INPUT);
}
2015-04-02 12:06:42 +02:00
@Override
2018-08-10 05:04:07 +02:00
public IRemover getRemover() {
return (slot, automation) -> !automation || slot == SLOT_OUTPUT;
2015-04-02 12:06:42 +02:00
}
2019-05-02 09:54:52 +02:00
private static final List<Pair<Item, Integer>> BLACKLIST = new ArrayList<>();
private static boolean runOnce = false;
public static boolean isBlacklisted(ItemStack stack) {
if (!runOnce) {
runOnce = true;
for (String s : ConfigStringListValues.REPAIR_BLACKLIST.getValue()) {
String[] split = s.split("@");
Item item = ForgeRegistries.ITEMS.getValue(new ResourceLocation(split[0]));
if (item == null) {
ActuallyAdditions.LOGGER.error("Invalid item in repair blacklist: " + s);
continue;
}
if (split.length == 1) BLACKLIST.add(Pair.of(item, 0));
else if (split.length == 2) {
BLACKLIST.add(Pair.of(item, Integer.parseInt(split[1])));
}
}
}
return BLACKLIST.contains(Pair.of(stack.getItem(), stack.getMetadata()));
2016-11-26 08:58:42 +01:00
}
2015-04-02 12:06:42 +02:00
}