mirror of
https://github.com/Ellpeck/PrettyPipes.git
synced 2024-11-22 19:58:35 +01:00
added some more API stuff for Sky <3
This commit is contained in:
parent
585e003327
commit
aba7738a8a
8 changed files with 103 additions and 66 deletions
|
@ -121,8 +121,11 @@ public final class Utility {
|
||||||
|
|
||||||
public static <T extends INBTSerializable<CompoundNBT>> List<T> deserializeAll(ListNBT list, Function<CompoundNBT, T> supplier) {
|
public static <T extends INBTSerializable<CompoundNBT>> List<T> deserializeAll(ListNBT list, Function<CompoundNBT, T> supplier) {
|
||||||
List<T> items = new ArrayList<>();
|
List<T> items = new ArrayList<>();
|
||||||
for (int i = 0; i < list.size(); i++)
|
for (int i = 0; i < list.size(); i++) {
|
||||||
items.add(supplier.apply(list.getCompound(i)));
|
T item = supplier.apply(list.getCompound(i));
|
||||||
|
if (item != null)
|
||||||
|
items.add(item);
|
||||||
|
}
|
||||||
return items;
|
return items;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,25 +1,36 @@
|
||||||
package de.ellpeck.prettypipes.network;
|
package de.ellpeck.prettypipes.network;
|
||||||
|
|
||||||
|
import com.mojang.blaze3d.matrix.MatrixStack;
|
||||||
|
import de.ellpeck.prettypipes.PrettyPipes;
|
||||||
import de.ellpeck.prettypipes.Utility;
|
import de.ellpeck.prettypipes.Utility;
|
||||||
import de.ellpeck.prettypipes.pipe.IPipeConnectable;
|
import de.ellpeck.prettypipes.pipe.IPipeConnectable;
|
||||||
import de.ellpeck.prettypipes.pipe.PipeTileEntity;
|
import de.ellpeck.prettypipes.pipe.PipeTileEntity;
|
||||||
|
import joptsimple.internal.Strings;
|
||||||
import net.minecraft.block.BlockState;
|
import net.minecraft.block.BlockState;
|
||||||
import net.minecraft.block.ILiquidContainer;
|
import net.minecraft.block.ILiquidContainer;
|
||||||
|
import net.minecraft.client.Minecraft;
|
||||||
|
import net.minecraft.client.renderer.IRenderTypeBuffer;
|
||||||
|
import net.minecraft.client.renderer.model.ItemCameraTransforms;
|
||||||
import net.minecraft.entity.item.ItemEntity;
|
import net.minecraft.entity.item.ItemEntity;
|
||||||
import net.minecraft.fluid.Fluid;
|
import net.minecraft.fluid.Fluid;
|
||||||
import net.minecraft.fluid.FluidState;
|
import net.minecraft.fluid.FluidState;
|
||||||
|
import net.minecraft.item.BlockItem;
|
||||||
|
import net.minecraft.item.Item;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.nbt.CompoundNBT;
|
import net.minecraft.nbt.CompoundNBT;
|
||||||
import net.minecraft.nbt.ListNBT;
|
import net.minecraft.nbt.ListNBT;
|
||||||
import net.minecraft.nbt.NBTUtil;
|
import net.minecraft.nbt.NBTUtil;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.util.Direction;
|
import net.minecraft.util.Direction;
|
||||||
|
import net.minecraft.util.ResourceLocation;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.math.MathHelper;
|
import net.minecraft.util.math.MathHelper;
|
||||||
import net.minecraft.util.math.vector.Vector3d;
|
import net.minecraft.util.math.vector.Vector3d;
|
||||||
import net.minecraft.world.IBlockReader;
|
import net.minecraft.world.IBlockReader;
|
||||||
import net.minecraft.world.IWorld;
|
import net.minecraft.world.IWorld;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
||||||
import net.minecraftforge.common.util.Constants;
|
import net.minecraftforge.common.util.Constants;
|
||||||
import net.minecraftforge.common.util.INBTSerializable;
|
import net.minecraftforge.common.util.INBTSerializable;
|
||||||
import net.minecraftforge.items.CapabilityItemHandler;
|
import net.minecraftforge.items.CapabilityItemHandler;
|
||||||
|
@ -28,12 +39,18 @@ import net.minecraftforge.items.ItemHandlerHelper;
|
||||||
import org.jgrapht.Graph;
|
import org.jgrapht.Graph;
|
||||||
import org.jgrapht.GraphPath;
|
import org.jgrapht.GraphPath;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.*;
|
||||||
import java.util.Collection;
|
import java.util.function.BiFunction;
|
||||||
import java.util.List;
|
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
public class PipeItem implements INBTSerializable<CompoundNBT>, ILiquidContainer {
|
public class PipeItem implements INBTSerializable<CompoundNBT> {
|
||||||
|
|
||||||
|
public static final Map<ResourceLocation, BiFunction<ResourceLocation, CompoundNBT, PipeItem>> TYPES = new HashMap<>();
|
||||||
|
public static final ResourceLocation TYPE = new ResourceLocation(PrettyPipes.ID, "pipe_item");
|
||||||
|
|
||||||
|
static {
|
||||||
|
TYPES.put(TYPE, PipeItem::new);
|
||||||
|
}
|
||||||
|
|
||||||
public ItemStack stack;
|
public ItemStack stack;
|
||||||
public float speed;
|
public float speed;
|
||||||
|
@ -51,13 +68,20 @@ public class PipeItem implements INBTSerializable<CompoundNBT>, ILiquidContainer
|
||||||
protected int currentTile;
|
protected int currentTile;
|
||||||
protected boolean retryOnObstruction;
|
protected boolean retryOnObstruction;
|
||||||
protected long lastWorldTick;
|
protected long lastWorldTick;
|
||||||
|
protected ResourceLocation type;
|
||||||
|
|
||||||
public PipeItem(ItemStack stack, float speed) {
|
public PipeItem(ResourceLocation type, ItemStack stack, float speed) {
|
||||||
|
this.type = type;
|
||||||
this.stack = stack;
|
this.stack = stack;
|
||||||
this.speed = speed;
|
this.speed = speed;
|
||||||
}
|
}
|
||||||
|
|
||||||
public PipeItem(CompoundNBT nbt) {
|
public PipeItem(ItemStack stack, float speed) {
|
||||||
|
this(TYPE, stack, speed);
|
||||||
|
}
|
||||||
|
|
||||||
|
private PipeItem(ResourceLocation type, CompoundNBT nbt) {
|
||||||
|
this.type = type;
|
||||||
this.path = new ArrayList<>();
|
this.path = new ArrayList<>();
|
||||||
this.deserializeNBT(nbt);
|
this.deserializeNBT(nbt);
|
||||||
}
|
}
|
||||||
|
@ -224,6 +248,7 @@ public class PipeItem implements INBTSerializable<CompoundNBT>, ILiquidContainer
|
||||||
@Override
|
@Override
|
||||||
public CompoundNBT serializeNBT() {
|
public CompoundNBT serializeNBT() {
|
||||||
CompoundNBT nbt = new CompoundNBT();
|
CompoundNBT nbt = new CompoundNBT();
|
||||||
|
nbt.putString("type", this.type.toString());
|
||||||
nbt.put("stack", this.stack.serializeNBT());
|
nbt.put("stack", this.stack.serializeNBT());
|
||||||
nbt.putFloat("speed", this.speed);
|
nbt.putFloat("speed", this.speed);
|
||||||
nbt.put("start_inv", NBTUtil.writeBlockPos(this.startInventory));
|
nbt.put("start_inv", NBTUtil.writeBlockPos(this.startInventory));
|
||||||
|
@ -259,6 +284,53 @@ public class PipeItem implements INBTSerializable<CompoundNBT>, ILiquidContainer
|
||||||
this.path.add(NBTUtil.readBlockPos(list.getCompound(i)));
|
this.path.add(NBTUtil.readBlockPos(list.getCompound(i)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@OnlyIn(Dist.CLIENT)
|
||||||
|
public void render(PipeTileEntity tile, MatrixStack matrixStack, Random random, float partialTicks, int light, int overlay, IRenderTypeBuffer buffer) {
|
||||||
|
matrixStack.translate(
|
||||||
|
MathHelper.lerp(partialTicks, this.lastX, this.x),
|
||||||
|
MathHelper.lerp(partialTicks, this.lastY, this.y),
|
||||||
|
MathHelper.lerp(partialTicks, this.lastZ, this.z));
|
||||||
|
|
||||||
|
if (this.stack.getItem() instanceof BlockItem) {
|
||||||
|
float scale = 0.7F;
|
||||||
|
matrixStack.scale(scale, scale, scale);
|
||||||
|
matrixStack.translate(0, -0.2F, 0);
|
||||||
|
} else {
|
||||||
|
float scale = 0.45F;
|
||||||
|
matrixStack.scale(scale, scale, scale);
|
||||||
|
matrixStack.translate(0, -0.1F, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
random.setSeed(Item.getIdFromItem(this.stack.getItem()) + this.stack.getDamage());
|
||||||
|
int amount = this.getModelCount();
|
||||||
|
|
||||||
|
for (int i = 0; i < amount; i++) {
|
||||||
|
matrixStack.push();
|
||||||
|
if (amount > 1) {
|
||||||
|
matrixStack.translate(
|
||||||
|
(random.nextFloat() * 2.0F - 1.0F) * 0.25F * 0.5F,
|
||||||
|
(random.nextFloat() * 2.0F - 1.0F) * 0.25F * 0.5F,
|
||||||
|
(random.nextFloat() * 2.0F - 1.0F) * 0.25F * 0.5F);
|
||||||
|
}
|
||||||
|
Minecraft.getInstance().getItemRenderer().renderItem(this.stack, ItemCameraTransforms.TransformType.GROUND, light, overlay, matrixStack, buffer);
|
||||||
|
matrixStack.pop();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private int getModelCount() {
|
||||||
|
int i = 1;
|
||||||
|
if (this.stack.getCount() > 48) {
|
||||||
|
i = 5;
|
||||||
|
} else if (this.stack.getCount() > 32) {
|
||||||
|
i = 4;
|
||||||
|
} else if (this.stack.getCount() > 16) {
|
||||||
|
i = 3;
|
||||||
|
} else if (this.stack.getCount() > 1) {
|
||||||
|
i = 2;
|
||||||
|
}
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
|
||||||
protected static List<BlockPos> compilePath(GraphPath<BlockPos, NetworkEdge> path) {
|
protected static List<BlockPos> compilePath(GraphPath<BlockPos, NetworkEdge> path) {
|
||||||
Graph<BlockPos, NetworkEdge> graph = path.getGraph();
|
Graph<BlockPos, NetworkEdge> graph = path.getGraph();
|
||||||
List<BlockPos> ret = new ArrayList<>();
|
List<BlockPos> ret = new ArrayList<>();
|
||||||
|
@ -292,13 +364,13 @@ public class PipeItem implements INBTSerializable<CompoundNBT>, ILiquidContainer
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
public static PipeItem load(CompoundNBT nbt) {
|
||||||
public boolean canContainFluid(IBlockReader worldIn, BlockPos pos, BlockState state, Fluid fluidIn) {
|
// TODO legacy compat, remove eventually
|
||||||
return true;
|
if (!nbt.contains("type"))
|
||||||
}
|
nbt.putString("type", TYPE.toString());
|
||||||
|
|
||||||
@Override
|
ResourceLocation type = new ResourceLocation(nbt.getString("type"));
|
||||||
public boolean receiveFluid(IWorld worldIn, BlockPos pos, BlockState state, FluidState fluidStateIn) {
|
BiFunction<ResourceLocation, CompoundNBT, PipeItem> func = TYPES.get(type);
|
||||||
return false;
|
return func != null ? func.apply(type, nbt) : null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -100,7 +100,7 @@ public class PipeNetwork implements ICapabilitySerializable<CompoundNBT>, GraphL
|
||||||
ListNBT edges = nbt.getList("edges", NBT.TAG_COMPOUND);
|
ListNBT edges = nbt.getList("edges", NBT.TAG_COMPOUND);
|
||||||
for (int i = 0; i < edges.size(); i++)
|
for (int i = 0; i < edges.size(); i++)
|
||||||
this.addEdge(new NetworkEdge(edges.getCompound(i)));
|
this.addEdge(new NetworkEdge(edges.getCompound(i)));
|
||||||
for (PipeItem item : Utility.deserializeAll(nbt.getList("items", NBT.TAG_COMPOUND), PipeItem::new))
|
for (PipeItem item : Utility.deserializeAll(nbt.getList("items", NBT.TAG_COMPOUND), PipeItem::load))
|
||||||
this.pipeItems.put(item.getCurrentPipe(), item);
|
this.pipeItems.put(item.getCurrentPipe(), item);
|
||||||
for (NetworkLock lock : Utility.deserializeAll(nbt.getList("locks", NBT.TAG_COMPOUND), NetworkLock::new))
|
for (NetworkLock lock : Utility.deserializeAll(nbt.getList("locks", NBT.TAG_COMPOUND), NetworkLock::new))
|
||||||
this.createNetworkLock(lock);
|
this.createNetworkLock(lock);
|
||||||
|
@ -133,7 +133,7 @@ public class PipeNetwork implements ICapabilitySerializable<CompoundNBT>, GraphL
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public ItemStack tryInsertItem(BlockPos startPipePos, BlockPos startInventory, ItemStack stack, boolean preventOversending) {
|
public ItemStack routeItem(BlockPos startPipePos, BlockPos startInventory, ItemStack stack, boolean preventOversending) {
|
||||||
return this.routeItem(startPipePos, startInventory, stack, PipeItem::new, preventOversending);
|
return this.routeItem(startPipePos, startInventory, stack, PipeItem::new, preventOversending);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -212,6 +212,10 @@ public class PipeNetwork implements ICapabilitySerializable<CompoundNBT>, GraphL
|
||||||
}
|
}
|
||||||
|
|
||||||
public ItemStack requestExistingItem(NetworkLocation location, BlockPos destPipe, BlockPos destInventory, NetworkLock ignoredLock, ItemStack stack, ItemEqualityType... equalityTypes) {
|
public ItemStack requestExistingItem(NetworkLocation location, BlockPos destPipe, BlockPos destInventory, NetworkLock ignoredLock, ItemStack stack, ItemEqualityType... equalityTypes) {
|
||||||
|
return this.requestExistingItem(location, destPipe, destInventory, ignoredLock, PipeItem::new, stack, equalityTypes);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ItemStack requestExistingItem(NetworkLocation location, BlockPos destPipe, BlockPos destInventory, NetworkLock ignoredLock, BiFunction<ItemStack, Float, PipeItem> itemSupplier, ItemStack stack, ItemEqualityType... equalityTypes) {
|
||||||
if (location.getPos().equals(destInventory))
|
if (location.getPos().equals(destInventory))
|
||||||
return stack;
|
return stack;
|
||||||
// make sure we don't pull any locked items
|
// make sure we don't pull any locked items
|
||||||
|
@ -230,7 +234,7 @@ public class PipeNetwork implements ICapabilitySerializable<CompoundNBT>, GraphL
|
||||||
// try to extract from that location's inventory and send the item
|
// try to extract from that location's inventory and send the item
|
||||||
IItemHandler handler = location.getItemHandler(this.world);
|
IItemHandler handler = location.getItemHandler(this.world);
|
||||||
ItemStack extracted = handler.extractItem(slot, amount, true);
|
ItemStack extracted = handler.extractItem(slot, amount, true);
|
||||||
if (this.routeItemToLocation(location.pipePos, location.getPos(), destPipe, destInventory, extracted, speed -> new PipeItem(extracted, speed))) {
|
if (this.routeItemToLocation(location.pipePos, location.getPos(), destPipe, destInventory, extracted, speed -> itemSupplier.apply(extracted, speed))) {
|
||||||
handler.extractItem(slot, extracted.getCount(), false);
|
handler.extractItem(slot, extracted.getCount(), false);
|
||||||
amount -= extracted.getCount();
|
amount -= extracted.getCount();
|
||||||
if (amount <= 0)
|
if (amount <= 0)
|
||||||
|
|
|
@ -45,7 +45,7 @@ public class PacketItemEnterPipe {
|
||||||
Minecraft mc = Minecraft.getInstance();
|
Minecraft mc = Minecraft.getInstance();
|
||||||
if (mc.world == null)
|
if (mc.world == null)
|
||||||
return;
|
return;
|
||||||
PipeItem item = new PipeItem(message.item);
|
PipeItem item = PipeItem.load(message.item);
|
||||||
PipeTileEntity pipe = Utility.getTileEntity(PipeTileEntity.class, mc.world, message.tilePos);
|
PipeTileEntity pipe = Utility.getTileEntity(PipeTileEntity.class, mc.world, message.tilePos);
|
||||||
if (pipe != null)
|
if (pipe != null)
|
||||||
pipe.getItems().add(item);
|
pipe.getItems().add(item);
|
||||||
|
|
|
@ -24,7 +24,7 @@ public class PipeRenderer extends TileEntityRenderer<PipeTileEntity> {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void render(PipeTileEntity tile, float v, MatrixStack matrixStack, IRenderTypeBuffer iRenderTypeBuffer, int k, int i1) {
|
public void render(PipeTileEntity tile, float partialTicks, MatrixStack matrixStack, IRenderTypeBuffer iRenderTypeBuffer, int k, int i1) {
|
||||||
if (tile.getItems().isEmpty())
|
if (tile.getItems().isEmpty())
|
||||||
return;
|
return;
|
||||||
matrixStack.push();
|
matrixStack.push();
|
||||||
|
@ -32,51 +32,9 @@ public class PipeRenderer extends TileEntityRenderer<PipeTileEntity> {
|
||||||
matrixStack.translate(-tilePos.getX(), -tilePos.getY(), -tilePos.getZ());
|
matrixStack.translate(-tilePos.getX(), -tilePos.getY(), -tilePos.getZ());
|
||||||
for (PipeItem item : tile.getItems()) {
|
for (PipeItem item : tile.getItems()) {
|
||||||
matrixStack.push();
|
matrixStack.push();
|
||||||
matrixStack.translate(
|
item.render(tile, matrixStack, this.random, partialTicks, k, i1, iRenderTypeBuffer);
|
||||||
MathHelper.lerp(v, item.lastX, item.x),
|
|
||||||
MathHelper.lerp(v, item.lastY, item.y),
|
|
||||||
MathHelper.lerp(v, item.lastZ, item.z));
|
|
||||||
|
|
||||||
if (item.stack.getItem() instanceof BlockItem) {
|
|
||||||
float scale = 0.7F;
|
|
||||||
matrixStack.scale(scale, scale, scale);
|
|
||||||
matrixStack.translate(0, -0.2F, 0);
|
|
||||||
} else {
|
|
||||||
float scale = 0.45F;
|
|
||||||
matrixStack.scale(scale, scale, scale);
|
|
||||||
matrixStack.translate(0, -0.1F, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.random.setSeed(Item.getIdFromItem(item.stack.getItem()) + item.stack.getDamage());
|
|
||||||
int amount = this.getModelCount(item.stack);
|
|
||||||
|
|
||||||
for (int i = 0; i < amount; i++) {
|
|
||||||
matrixStack.push();
|
|
||||||
if (amount > 1) {
|
|
||||||
matrixStack.translate(
|
|
||||||
(this.random.nextFloat() * 2.0F - 1.0F) * 0.25F * 0.5F,
|
|
||||||
(this.random.nextFloat() * 2.0F - 1.0F) * 0.25F * 0.5F,
|
|
||||||
(this.random.nextFloat() * 2.0F - 1.0F) * 0.25F * 0.5F);
|
|
||||||
}
|
|
||||||
Minecraft.getInstance().getItemRenderer().renderItem(item.stack, ItemCameraTransforms.TransformType.GROUND, k, i1, matrixStack, iRenderTypeBuffer);
|
|
||||||
matrixStack.pop();
|
matrixStack.pop();
|
||||||
}
|
}
|
||||||
matrixStack.pop();
|
matrixStack.pop();
|
||||||
}
|
}
|
||||||
matrixStack.pop();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected int getModelCount(ItemStack stack) {
|
|
||||||
int i = 1;
|
|
||||||
if (stack.getCount() > 48) {
|
|
||||||
i = 5;
|
|
||||||
} else if (stack.getCount() > 32) {
|
|
||||||
i = 4;
|
|
||||||
} else if (stack.getCount() > 16) {
|
|
||||||
i = 3;
|
|
||||||
} else if (stack.getCount() > 1) {
|
|
||||||
i = 2;
|
|
||||||
}
|
|
||||||
return i;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -125,7 +125,7 @@ public class PipeTileEntity extends TileEntity implements INamedContainerProvide
|
||||||
this.read(state, nbt);
|
this.read(state, nbt);
|
||||||
List<PipeItem> items = this.getItems();
|
List<PipeItem> items = this.getItems();
|
||||||
items.clear();
|
items.clear();
|
||||||
items.addAll(Utility.deserializeAll(nbt.getList("items", NBT.TAG_COMPOUND), PipeItem::new));
|
items.addAll(Utility.deserializeAll(nbt.getList("items", NBT.TAG_COMPOUND), PipeItem::load));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -48,7 +48,7 @@ public class ExtractionModuleItem extends ModuleItem {
|
||||||
continue;
|
continue;
|
||||||
if (!filter.isAllowed(stack))
|
if (!filter.isAllowed(stack))
|
||||||
continue;
|
continue;
|
||||||
ItemStack remain = network.tryInsertItem(tile.getPos(), tile.getPos().offset(dir), stack, this.preventOversending);
|
ItemStack remain = network.routeItem(tile.getPos(), tile.getPos().offset(dir), stack, this.preventOversending);
|
||||||
if (remain.getCount() != stack.getCount()) {
|
if (remain.getCount() != stack.getCount()) {
|
||||||
handler.extractItem(j, stack.getCount() - remain.getCount(), false);
|
handler.extractItem(j, stack.getCount() - remain.getCount(), false);
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -80,7 +80,7 @@ public class ItemTerminalTileEntity extends TileEntity implements INamedContaine
|
||||||
ItemStack extracted = this.items.extractItem(i, Integer.MAX_VALUE, true);
|
ItemStack extracted = this.items.extractItem(i, Integer.MAX_VALUE, true);
|
||||||
if (extracted.isEmpty())
|
if (extracted.isEmpty())
|
||||||
continue;
|
continue;
|
||||||
ItemStack remain = network.tryInsertItem(pipe.getPos(), this.pos, extracted, true);
|
ItemStack remain = network.routeItem(pipe.getPos(), this.pos, extracted, true);
|
||||||
if (remain.getCount() == extracted.getCount())
|
if (remain.getCount() == extracted.getCount())
|
||||||
continue;
|
continue;
|
||||||
this.items.extractItem(i, extracted.getCount() - remain.getCount(), false);
|
this.items.extractItem(i, extracted.getCount() - remain.getCount(), false);
|
||||||
|
|
Loading…
Reference in a new issue