Jump to content

[1.8] Dupe bug in InventoryHelper.dropInventoryItems


Failender

Recommended Posts

Hey guys,

I am experiencing problems with InventoryHelper.dropInventoryItems.

I am using the variable inventoryLimit to limit the inventory a player can hold (using ItemPickUp event custom guis etc etc.)

the following code is part of my IEEP.

Basically I want the player to drop parts of his inventory if the newLimit is smaller then the old inventoryLimit, because he cant "hold it anymore".

My problem is that sometimes the items dupe. I check the content of my toDrop inventory via for loop to be sure the problem isnt inside the filling of the inventory.

I checked eveything with 1 stack of stone.

Console output is:

[20:13:29] [server thread/INFO] [sTDOUT]: [de.failender.shadowsrising.util.ExtendedPlayer:setInventoryLimit:90]: 0  64xtile.stone@0

But sometimes there is 64 Items dropped (the stack) sometimes more (biggest I had was 118)

Am I doing something terribly wrong or is the InventoryHelper buggy?

 

public void setInventoryLimit(int newLimit)
{
	if(player.worldObj.isRemote) {
		inventoryLimit = newLimit;
		return;
	}
	if(newLimit<inventoryLimit) {
		InventoryPlayer inv = player.inventory;
		InventoryBasic toDrop = new InventoryBasic("", false, inventoryLimit-newLimit);
		for(int i=newLimit; i<inventoryLimit ; i++) {
			toDrop.setInventorySlotContents(i-newLimit, inv.getStackInSlot(i));
			inv.setInventorySlotContents(i, null);
		}

		for(int i=0; i<toDrop.getSizeInventory(); i++) {
			if(toDrop.getStackInSlot(i)!=null) System.out.println(i+"   "+toDrop.getStackInSlot(i));
		}

		InventoryHelper.dropInventoryItems(player.worldObj, new BlockPos(player.posX, player.posY, player.posZ), toDrop);
	}
	inventoryLimit = newLimit;
}

 

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.