mirror of
https://github.com/Ellpeck/PrettyPipes.git
synced 2025-01-09 22:57:44 +01:00
fixed recipes with crafting dependencies not waiting for them before emitting a redstone signal
This commit is contained in:
parent
1d05d1c906
commit
1d6272b574
2 changed files with 17 additions and 7 deletions
|
@ -17,18 +17,19 @@ public class ActiveCraft implements INBTSerializable<CompoundTag> {
|
||||||
|
|
||||||
public BlockPos pipe;
|
public BlockPos pipe;
|
||||||
public int moduleSlot;
|
public int moduleSlot;
|
||||||
public List<ItemStack> travelingIngredients = new ArrayList<>();
|
|
||||||
public List<NetworkLock> ingredientsToRequest;
|
public List<NetworkLock> ingredientsToRequest;
|
||||||
|
public List<ItemStack> travelingIngredients;
|
||||||
public BlockPos resultDestPipe;
|
public BlockPos resultDestPipe;
|
||||||
public ItemStack resultStackRemain;
|
public ItemStack resultStackRemain;
|
||||||
public boolean inProgress;
|
public boolean inProgress;
|
||||||
// we only remove canceled requests from the queue once their items are fully delivered to the crafting location, so that unfinished recipes don't get stuck in crafters etc.
|
// we only remove canceled requests from the queue once their items are fully delivered to the crafting location, so that unfinished recipes don't get stuck in crafters etc.
|
||||||
public boolean canceled;
|
public boolean canceled;
|
||||||
|
|
||||||
public ActiveCraft(BlockPos pipe, int moduleSlot, List<NetworkLock> ingredientsToRequest, BlockPos resultDestPipe, ItemStack resultStackRemain) {
|
public ActiveCraft(BlockPos pipe, int moduleSlot, List<NetworkLock> ingredientsToRequest, List<ItemStack> travelingIngredients, BlockPos resultDestPipe, ItemStack resultStackRemain) {
|
||||||
this.pipe = pipe;
|
this.pipe = pipe;
|
||||||
this.moduleSlot = moduleSlot;
|
this.moduleSlot = moduleSlot;
|
||||||
this.ingredientsToRequest = ingredientsToRequest;
|
this.ingredientsToRequest = ingredientsToRequest;
|
||||||
|
this.travelingIngredients = travelingIngredients;
|
||||||
this.resultDestPipe = resultDestPipe;
|
this.resultDestPipe = resultDestPipe;
|
||||||
this.resultStackRemain = resultStackRemain;
|
this.resultStackRemain = resultStackRemain;
|
||||||
}
|
}
|
||||||
|
|
|
@ -177,23 +177,29 @@ public class CraftingModuleItem extends ModuleItem {
|
||||||
var allCrafts = new ArrayList<ActiveCraft>();
|
var allCrafts = new ArrayList<ActiveCraft>();
|
||||||
// if we're ensuring item order, all items for a single recipe should be sent in order first before starting on the next one!
|
// if we're ensuring item order, all items for a single recipe should be sent in order first before starting on the next one!
|
||||||
for (var c = contents.ensureItemOrder ? toCraft : 1; c > 0; c--) {
|
for (var c = contents.ensureItemOrder ? toCraft : 1; c > 0; c--) {
|
||||||
|
var crafts = new ArrayList<ItemStack>();
|
||||||
var locks = new ArrayList<NetworkLock>();
|
var locks = new ArrayList<NetworkLock>();
|
||||||
for (var i = 0; i < contents.input.getSlots(); i++) {
|
for (var i = 0; i < contents.input.getSlots(); i++) {
|
||||||
var in = contents.input.getStackInSlot(i);
|
var in = contents.input.getStackInSlot(i);
|
||||||
if (in.isEmpty())
|
if (in.isEmpty())
|
||||||
continue;
|
continue;
|
||||||
var copy = in.copy();
|
var request = in.copy();
|
||||||
if (!contents.ensureItemOrder)
|
if (!contents.ensureItemOrder)
|
||||||
copy.setCount(in.getCount() * toCraft);
|
request.setCount(in.getCount() * toCraft);
|
||||||
var ret = network.requestLocksAndStartCrafting(tile.getBlockPos(), items, unavailableConsumer, copy, CraftingModuleItem.addDependency(dependencyChain, module), equalityTypes);
|
var ret = network.requestLocksAndStartCrafting(tile.getBlockPos(), items, unavailableConsumer, request, CraftingModuleItem.addDependency(dependencyChain, module), equalityTypes);
|
||||||
// set crafting dependencies as in progress immediately so that, when canceling, they don't leave behind half-crafted inbetween dependencies
|
// set crafting dependencies as in progress immediately so that, when canceling, they don't leave behind half-crafted inbetween dependencies
|
||||||
// TODO to be more optimal, we should really do this when setting the main craft as in progress, but that would require storing references to all of the dependencies
|
// TODO to be more optimal, we should really do this when setting the main craft as in progress, but that would require storing references to all of the dependencies
|
||||||
ret.getRight().forEach(a -> a.inProgress = true);
|
ret.getRight().forEach(a -> a.inProgress = true);
|
||||||
locks.addAll(ret.getLeft());
|
locks.addAll(ret.getLeft());
|
||||||
allCrafts.addAll(ret.getRight());
|
allCrafts.addAll(ret.getRight());
|
||||||
|
// the items we started crafting are the ones we didn't request normally (ie ones we didn't create locks for)
|
||||||
|
var startedCrafting = request.copyWithCount(request.getCount() - ret.getLeft().stream().mapToInt(l -> l.stack.getCount()).sum());
|
||||||
|
if (!startedCrafting.isEmpty())
|
||||||
|
crafts.add(startedCrafting);
|
||||||
}
|
}
|
||||||
var crafted = contents.ensureItemOrder ? resultAmount : resultAmount * toCraft;
|
var crafted = contents.ensureItemOrder ? resultAmount : resultAmount * toCraft;
|
||||||
var activeCraft = new ActiveCraft(tile.getBlockPos(), slot, locks, destPipe, stack.copyWithCount(Math.min(crafted, leftOfRequest)));
|
// items we started craft dependencies for are ones that will be sent to us (so we're waiting for them immediately!)
|
||||||
|
var activeCraft = new ActiveCraft(tile.getBlockPos(), slot, locks, crafts, destPipe, stack.copyWithCount(Math.min(crafted, leftOfRequest)));
|
||||||
tile.getActiveCrafts().add(activeCraft);
|
tile.getActiveCrafts().add(activeCraft);
|
||||||
allCrafts.add(activeCraft);
|
allCrafts.add(activeCraft);
|
||||||
leftOfRequest -= crafted;
|
leftOfRequest -= crafted;
|
||||||
|
@ -211,7 +217,10 @@ public class CraftingModuleItem extends ModuleItem {
|
||||||
var equalityTypes = ItemFilter.getEqualityTypes(tile);
|
var equalityTypes = ItemFilter.getEqualityTypes(tile);
|
||||||
var allCrafts = tile.getActiveCrafts();
|
var allCrafts = tile.getActiveCrafts();
|
||||||
for (var craft : allCrafts.stream().filter(c -> c.moduleSlot == slot && !c.getTravelingIngredient(stack, equalityTypes).isEmpty()).toList()) {
|
for (var craft : allCrafts.stream().filter(c -> c.moduleSlot == slot && !c.getTravelingIngredient(stack, equalityTypes).isEmpty()).toList()) {
|
||||||
craft.travelingIngredients.remove(craft.getTravelingIngredient(stack, equalityTypes));
|
var traveling = craft.getTravelingIngredient(stack, equalityTypes);
|
||||||
|
traveling.shrink(stack.getCount());
|
||||||
|
if (traveling.isEmpty())
|
||||||
|
craft.travelingIngredients.remove(traveling);
|
||||||
|
|
||||||
if (contents.insertSingles) {
|
if (contents.insertSingles) {
|
||||||
var handler = tile.getItemHandler(direction);
|
var handler = tile.getItemHandler(direction);
|
||||||
|
|
Loading…
Reference in a new issue