Skip to content

Commit

Permalink
feat: LogisticsPipes crafting integration
Browse files Browse the repository at this point in the history
reference issue: xsun2001#8
  • Loading branch information
leytilera committed Jan 26, 2023
1 parent 0b182ae commit b8563aa
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 8 deletions.
27 changes: 23 additions & 4 deletions src/main/java/appeng/integration/modules/LogisticsPipes.java
Original file line number Diff line number Diff line change
Expand Up @@ -84,12 +84,25 @@ public Set<IAEItemStack> getRequestableItems(TileEntity te) {
Map<IAEItemStack, IAEItemStack> stacks = new HashMap<>();
for(ItemStack s : api.getProvidedItems()) {
IAEItemStack stack = AEItemStack.create(s);
int stacksize = s.stackSize;
stack.reset();
stack.setCountRequestable(stacksize);
if (stacks.containsKey(stack)) {
stacks.get(stack).incStackSize(stack.getStackSize());
stacks.get(stack).incCountRequestable(stack.getCountRequestable());
} else {
stacks.put(stack, stack);
}
}
for(ItemStack s : api.getCraftedItems()) {
IAEItemStack stack = AEItemStack.create(s);
stack.reset();
if (stacks.containsKey(stack)) {
stacks.get(stack).setCraftable(true);
} else {
stack.setCraftable(true);
stacks.put(stack, stack);
}
}
return stacks.keySet();
}
return new HashSet<>();
Expand All @@ -104,15 +117,21 @@ public IAEItemStack requestStack(TileEntity te, IAEItemStack request, Actionable
if (res.missing.isEmpty()) {
return null;
} else {
return AEItemStack.create(res.missing.get(0));
ItemStack m = res.missing.get(0);
if (request.equals(m)) {
return AEItemStack.create(res.missing.get(0));
} else {
return request;
}
}
} else {
List<ItemStack> returned = api.performRequest(request.getItemStack());
if (returned.isEmpty()) {
return null;
} else {
int missing = returned.get(0).stackSize;
if (missing > 0) {
ItemStack m = returned.get(0);
int missing = m.stackSize;
if (missing > 0 && request.equals(m)) {
IAEItemStack newRequest = request.copy();
newRequest.decStackSize(missing);
// LP should still request the items, which are available
Expand Down
18 changes: 14 additions & 4 deletions src/main/java/appeng/me/cache/RequestGridCache.java
Original file line number Diff line number Diff line change
Expand Up @@ -93,9 +93,12 @@ public void recalcRequestable() {
if (requestable.containsKey(stack)) {
Requestable r = requestable.get(stack);
r.addProvider(provider);
r.increaseAmount(stack.getStackSize());
r.increaseAmount(stack.getCountRequestable());
if (stack.isCraftable()) {
r.setCraftable();
}
} else {
Requestable r = new Requestable(stack.getStackSize());
Requestable r = new Requestable(stack);
r.addProvider(provider);
requestable.put(stack, r);
}
Expand Down Expand Up @@ -151,6 +154,7 @@ public IItemList<IAEItemStack> getAvailableItems(IItemList<IAEItemStack> out) {
stack.reset();
Requestable r = requestable.get(s);
stack.setCountRequestable(r.amount);
stack.setCraftable(r.craftable);
out.add(stack);
}
return out;
Expand Down Expand Up @@ -212,10 +216,12 @@ public List<IMEInventoryHandler> getCellArray(StorageChannel channel) {
static class Requestable {
public Set<IRequestProvider> providers;
public long amount;
public boolean craftable;

public Requestable(long amount) {
public Requestable(IAEItemStack stack) {
this.providers = new HashSet<>();
this.amount = amount;
this.amount = stack.getCountRequestable();
this.craftable = stack.isCraftable();
}

public void addProvider(IRequestProvider provider) {
Expand All @@ -225,5 +231,9 @@ public void addProvider(IRequestProvider provider) {
public void increaseAmount(long amount) {
this.amount += amount;
}

public void setCraftable() {
this.craftable = true;
}
}
}

0 comments on commit b8563aa

Please sign in to comment.