mirror of
https://github.com/GeyserMC/Geyser.git
synced 2025-01-08 19:33:58 +01:00
Update inventory if request was rejected
This commit is contained in:
parent
4ee3143fe9
commit
95703d2ea7
1 changed files with 17 additions and 6 deletions
|
@ -151,28 +151,39 @@ public abstract class InventoryTranslator {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void translateRequests(GeyserSession session, Inventory inventory, List<ItemStackRequestPacket.Request> requests) {
|
public void translateRequests(GeyserSession session, Inventory inventory, List<ItemStackRequestPacket.Request> requests) {
|
||||||
|
boolean refresh = false;
|
||||||
ItemStackResponsePacket responsePacket = new ItemStackResponsePacket();
|
ItemStackResponsePacket responsePacket = new ItemStackResponsePacket();
|
||||||
for (ItemStackRequestPacket.Request request : requests) {
|
for (ItemStackRequestPacket.Request request : requests) {
|
||||||
|
ItemStackResponsePacket.Response response;
|
||||||
if (request.getActions().length > 0) {
|
if (request.getActions().length > 0) {
|
||||||
StackRequestActionData firstAction = request.getActions()[0];
|
StackRequestActionData firstAction = request.getActions()[0];
|
||||||
if (shouldHandleRequestFirst(firstAction, inventory)) {
|
if (shouldHandleRequestFirst(firstAction, inventory)) {
|
||||||
// Some special request that shouldn't be processed normally
|
// Some special request that shouldn't be processed normally
|
||||||
responsePacket.getEntries().add(translateSpecialRequest(session, inventory, request));
|
response = translateSpecialRequest(session, inventory, request);
|
||||||
} else if (firstAction.getType() == StackRequestActionType.CRAFT_RECIPE) {
|
} else if (firstAction.getType() == StackRequestActionType.CRAFT_RECIPE) {
|
||||||
responsePacket.getEntries().add(translateCraftingRequest(session, inventory, request));
|
response = translateCraftingRequest(session, inventory, request);
|
||||||
} else if (firstAction.getType() == StackRequestActionType.CRAFT_RECIPE_AUTO) {
|
} else if (firstAction.getType() == StackRequestActionType.CRAFT_RECIPE_AUTO) {
|
||||||
responsePacket.getEntries().add(translateAutoCraftingRequest(session, inventory, request));
|
response = translateAutoCraftingRequest(session, inventory, request);
|
||||||
} else if (firstAction.getType() == StackRequestActionType.CRAFT_CREATIVE) {
|
} else if (firstAction.getType() == StackRequestActionType.CRAFT_CREATIVE) {
|
||||||
// This is also used for pulling items out of creative
|
// This is also used for pulling items out of creative
|
||||||
responsePacket.getEntries().add(translateCreativeRequest(session, inventory, request));
|
response = translateCreativeRequest(session, inventory, request);
|
||||||
} else {
|
} else {
|
||||||
responsePacket.getEntries().add(translateRequest(session, inventory, request));
|
response = translateRequest(session, inventory, request);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
responsePacket.getEntries().add(rejectRequest(request));
|
response = rejectRequest(request);
|
||||||
}
|
}
|
||||||
|
if (response.getResult() == ItemStackResponsePacket.ResponseStatus.ERROR) {
|
||||||
|
refresh = true;
|
||||||
|
}
|
||||||
|
responsePacket.getEntries().add(response);
|
||||||
}
|
}
|
||||||
session.sendUpstreamPacket(responsePacket);
|
session.sendUpstreamPacket(responsePacket);
|
||||||
|
|
||||||
|
if (refresh) {
|
||||||
|
InventoryUtils.updateCursor(session);
|
||||||
|
updateInventory(session, inventory);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public ItemStackResponsePacket.Response translateRequest(GeyserSession session, Inventory inventory, ItemStackRequestPacket.Request request) {
|
public ItemStackResponsePacket.Response translateRequest(GeyserSession session, Inventory inventory, ItemStackRequestPacket.Request request) {
|
||||||
|
|
Loading…
Reference in a new issue