2019-05-23 23:02:15 +00:00
--- a/net/minecraft/tileentity/BrewingStandTileEntity.java
+++ b/net/minecraft/tileentity/BrewingStandTileEntity.java
@@ -146,6 +146,7 @@
2018-09-12 01:25:25 +00:00
2018-09-22 03:28:47 +00:00
private boolean func_145934_k() {
ItemStack itemstack = this.field_145945_j.get(3);
+ if (!itemstack.func_190926_b()) return net.minecraftforge.common.brewing.BrewingRecipeRegistry.canBrew(field_145945_j, itemstack, field_145947_i); // divert to VanillaBrewingRegistry
if (itemstack.func_190926_b()) {
2018-09-12 01:25:25 +00:00
return false;
2018-09-22 03:28:47 +00:00
} else if (!PotionBrewing.func_185205_a(itemstack)) {
2020-09-22 19:14:08 +00:00
@@ -163,22 +164,22 @@
2018-09-12 01:25:25 +00:00
}
2018-09-22 03:28:47 +00:00
private void func_145940_l() {
+ if (net.minecraftforge.event.ForgeEventFactory.onPotionAttemptBrew(field_145945_j)) return;
ItemStack itemstack = this.field_145945_j.get(3);
2018-09-12 01:25:25 +00:00
- for(int i = 0; i < 3; ++i) {
2018-09-22 03:28:47 +00:00
- this.field_145945_j.set(i, PotionBrewing.func_185212_d(itemstack, this.field_145945_j.get(i)));
2018-09-12 01:25:25 +00:00
- }
2020-09-22 19:14:08 +00:00
-
- itemstack.func_190918_g(1);
2018-09-22 03:28:47 +00:00
+ net.minecraftforge.common.brewing.BrewingRecipeRegistry.brewPotions(field_145945_j, itemstack, field_145947_i);
2019-05-23 23:02:15 +00:00
+ net.minecraftforge.event.ForgeEventFactory.onPotionBrewed(field_145945_j);
2018-09-22 03:28:47 +00:00
BlockPos blockpos = this.func_174877_v();
- if (itemstack.func_77973_b().func_77634_r()) {
- ItemStack itemstack1 = new ItemStack(itemstack.func_77973_b().func_77668_q());
2018-09-12 01:25:25 +00:00
+ if (itemstack.hasContainerItem()) {
+ ItemStack itemstack1 = itemstack.getContainerItem();
2020-09-22 19:14:08 +00:00
+ itemstack.func_190918_g(1);
2018-09-22 03:28:47 +00:00
if (itemstack.func_190926_b()) {
2018-09-12 01:25:25 +00:00
itemstack = itemstack1;
2019-05-23 23:02:15 +00:00
} else if (!this.field_145850_b.field_72995_K) {
2020-09-22 19:14:08 +00:00
InventoryHelper.func_180173_a(this.field_145850_b, (double)blockpos.func_177958_n(), (double)blockpos.func_177956_o(), (double)blockpos.func_177952_p(), itemstack1);
}
}
+ else itemstack.func_190918_g(1);
this.field_145945_j.set(3, itemstack);
this.field_145850_b.func_217379_c(1035, blockpos, 0);
2019-05-23 23:02:15 +00:00
@@ -229,13 +230,13 @@
2018-09-12 01:25:25 +00:00
2018-09-22 03:28:47 +00:00
public boolean func_94041_b(int p_94041_1_, ItemStack p_94041_2_) {
if (p_94041_1_ == 3) {
- return PotionBrewing.func_185205_a(p_94041_2_);
+ return net.minecraftforge.common.brewing.BrewingRecipeRegistry.isValidIngredient(p_94041_2_);
2018-09-12 01:25:25 +00:00
} else {
2018-09-22 03:28:47 +00:00
Item item = p_94041_2_.func_77973_b();
if (p_94041_1_ == 4) {
return item == Items.field_151065_br;
2018-09-12 01:25:25 +00:00
} else {
2018-09-22 03:28:47 +00:00
- return (item == Items.field_151068_bn || item == Items.field_185155_bH || item == Items.field_185156_bI || item == Items.field_151069_bo) && this.func_70301_a(p_94041_1_).func_190926_b();
+ return net.minecraftforge.common.brewing.BrewingRecipeRegistry.isValidInput(p_94041_2_) && this.func_70301_a(p_94041_1_).func_190926_b();
2018-09-12 01:25:25 +00:00
}
}
}
2019-05-23 23:02:15 +00:00
@@ -267,4 +268,27 @@
protected Container func_213906_a(int p_213906_1_, PlayerInventory p_213906_2_) {
return new BrewingStandContainer(p_213906_1_, p_213906_2_, this, this.field_213954_a);
2018-09-12 01:25:25 +00:00
}
+
2019-01-27 13:47:27 +00:00
+ net.minecraftforge.common.util.LazyOptional<? extends net.minecraftforge.items.IItemHandler>[] handlers =
2019-05-23 23:02:15 +00:00
+ net.minecraftforge.items.wrapper.SidedInvWrapper.create(this, Direction.UP, Direction.DOWN, Direction.NORTH);
2018-09-12 01:25:25 +00:00
+
+ @Override
2019-05-23 23:02:15 +00:00
+ public <T> net.minecraftforge.common.util.LazyOptional<T> getCapability(net.minecraftforge.common.capabilities.Capability<T> capability, @Nullable Direction facing) {
2019-02-07 06:55:17 +00:00
+ if (!this.field_145846_f && facing != null && capability == net.minecraftforge.items.CapabilityItemHandler.ITEM_HANDLER_CAPABILITY) {
2019-05-23 23:02:15 +00:00
+ if (facing == Direction.UP)
2018-09-12 01:25:25 +00:00
+ return handlers[0].cast();
2019-05-23 23:02:15 +00:00
+ else if (facing == Direction.DOWN)
2018-09-12 01:25:25 +00:00
+ return handlers[1].cast();
+ else
+ return handlers[2].cast();
+ }
+ return super.getCapability(capability, facing);
+ }
+
+ @Override
2020-12-08 19:54:29 +00:00
+ protected void invalidateCaps() {
+ super.invalidateCaps();
2018-09-12 01:25:25 +00:00
+ for (int x = 0; x < handlers.length; x++)
2019-02-07 06:55:17 +00:00
+ handlers[x].invalidate();
2018-09-12 01:25:25 +00:00
+ }
}