InventoryUtils.java 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. package me.km.inventory;
  2. import net.minecraft.inventory.IInventory;
  3. import net.minecraft.item.Item;
  4. import net.minecraft.item.ItemStack;
  5. public class InventoryUtils
  6. {
  7. public static int searchInventoryFor(IInventory inv, ItemStack searchfor, boolean useData)
  8. {
  9. if(searchfor.isEmpty())
  10. {
  11. return 0;
  12. }
  13. int counter = 0;
  14. if(useData)
  15. {
  16. int size = inv.getSizeInventory();
  17. ItemStack stack;
  18. for(int i = 0; i < size; i++)
  19. {
  20. stack = inv.getStackInSlot(i);
  21. if(stackEqualExact(stack, searchfor))
  22. {
  23. counter += stack.getCount();
  24. }
  25. }
  26. }
  27. else
  28. {
  29. int size = inv.getSizeInventory();
  30. Item item = searchfor.getItem();
  31. ItemStack stack;
  32. for(int i = 0; i < size; i++)
  33. {
  34. stack = inv.getStackInSlot(i);
  35. if(stack.getItem() == item)
  36. {
  37. counter += stack.getCount();
  38. }
  39. }
  40. }
  41. return counter;
  42. }
  43. public static int removeFromInventory(IInventory inv, ItemStack remove)
  44. {
  45. if(remove.isEmpty())
  46. {
  47. return 0;
  48. }
  49. ItemStack stack;
  50. int sub;
  51. int amount = remove.getCount();
  52. for(int i = 0; i < inv.getSizeInventory(); i++)
  53. {
  54. stack = inv.getStackInSlot(i);
  55. if(stackEqualExact(stack, remove))
  56. {
  57. sub = stack.getCount();
  58. if(amount > sub)
  59. {
  60. amount -= sub;
  61. inv.setInventorySlotContents(i, ItemStack.EMPTY);
  62. }
  63. else if(amount == sub)
  64. {
  65. inv.setInventorySlotContents(i, ItemStack.EMPTY);
  66. return 0;
  67. }
  68. else
  69. {
  70. stack.setCount(sub - amount);
  71. return 0;
  72. }
  73. }
  74. }
  75. return amount;
  76. }
  77. public static int addToInventory(IInventory inv, ItemStack add)
  78. {
  79. if(add.isEmpty())
  80. {
  81. return 0;
  82. }
  83. else
  84. {
  85. if(add.isDamaged())
  86. {
  87. int j = getFirstEmptyStack(inv);
  88. if(j >= 0)
  89. {
  90. inv.setInventorySlotContents(j, add.copy());
  91. inv.getStackInSlot(j).setAnimationsToGo(5);
  92. return 0;
  93. }
  94. return add.getCount();
  95. }
  96. else
  97. {
  98. ItemStack copy = add.copy();
  99. int i;
  100. while(true)
  101. {
  102. i = copy.getCount();
  103. copy.setCount(storePartialItemStack(inv, copy));
  104. if(copy.isEmpty() || copy.getCount() >= i)
  105. {
  106. break;
  107. }
  108. }
  109. return copy.getCount();
  110. }
  111. }
  112. }
  113. private static int storePartialItemStack(IInventory inv, ItemStack add)
  114. {
  115. int i = add.getCount();
  116. int j = storeItemStack(inv, add);
  117. if(j == -1)
  118. {
  119. j = getFirstEmptyStack(inv);
  120. }
  121. if (j == -1)
  122. {
  123. return i;
  124. }
  125. ItemStack stack = inv.getStackInSlot(j);
  126. if(stack.isEmpty())
  127. {
  128. stack = add.copy();
  129. stack.setCount(0);
  130. if(add.hasTag())
  131. {
  132. stack.setTag(add.getTag().copy());
  133. }
  134. inv.setInventorySlotContents(j, stack);
  135. }
  136. int k = i;
  137. if(i > stack.getMaxStackSize() - stack.getCount())
  138. {
  139. k = stack.getMaxStackSize() - stack.getCount();
  140. }
  141. if(k > inv.getInventoryStackLimit() - stack.getCount())
  142. {
  143. k = inv.getInventoryStackLimit() - stack.getCount();
  144. }
  145. if(k == 0)
  146. {
  147. return i;
  148. }
  149. else
  150. {
  151. i -= k;
  152. stack.grow(k);
  153. stack.setAnimationsToGo(5);
  154. return i;
  155. }
  156. }
  157. private static int storeItemStack(IInventory inv, ItemStack add)
  158. {
  159. for (int i = 0; i < inv.getSizeInventory(); i++)
  160. {
  161. if(canMergeStacks(inv, inv.getStackInSlot(i), add))
  162. {
  163. return i;
  164. }
  165. }
  166. return -1;
  167. }
  168. private static boolean canMergeStacks(IInventory inv, ItemStack first, ItemStack sec)
  169. {
  170. return !first.isEmpty() && stackEqualExact(first, sec) && first.isStackable() && first.getCount() < first.getMaxStackSize() && first.getCount() < inv.getInventoryStackLimit();
  171. }
  172. public static boolean stackEqualExact(ItemStack first, ItemStack sec)
  173. {
  174. return first.getItem() == sec.getItem() && ItemStack.areItemStackTagsEqual(first, sec);
  175. }
  176. public static int getFirstEmptyStack(IInventory inv)
  177. {
  178. for(int i = 0; i < inv.getSizeInventory(); i++)
  179. {
  180. if(inv.getStackInSlot(i).isEmpty())
  181. {
  182. return i;
  183. }
  184. }
  185. return -1;
  186. }
  187. }