parent
e67bde9e9e
commit
286777b824
8 changed files with 240 additions and 4 deletions
|
@ -60,7 +60,7 @@
|
||||||
return p_77621_1_.func_147447_a(vec3d, vec3d1, p_77621_3_, !p_77621_3_, false);
|
return p_77621_1_.func_147447_a(vec3d, vec3d1, p_77621_3_, !p_77621_3_, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -433,11 +440,625 @@
|
@@ -433,11 +440,632 @@
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -145,6 +145,13 @@
|
||||||
+ * Override this method to change the NBT data being sent to the client.
|
+ * Override this method to change the NBT data being sent to the client.
|
||||||
+ * You should ONLY override this when you have no other choice, as this might change behavior client side!
|
+ * You should ONLY override this when you have no other choice, as this might change behavior client side!
|
||||||
+ *
|
+ *
|
||||||
|
+ * Note that this will sometimes be applied multiple times, the following MUST be supported:
|
||||||
|
+ * Item item = stack.getItem();
|
||||||
|
+ * NBTTagCompound nbtShare1 = item.getNBTShareTag(stack);
|
||||||
|
+ * stack.setTagCompound(nbtShare1);
|
||||||
|
+ * NBTTagCompound nbtShare2 = item.getNBTShareTag(stack);
|
||||||
|
+ * assert nbtShare1.equals(nbtShare2);
|
||||||
|
+ *
|
||||||
+ * @param stack The stack to send the NBT tag for
|
+ * @param stack The stack to send the NBT tag for
|
||||||
+ * @return The NBT tag
|
+ * @return The NBT tag
|
||||||
+ */
|
+ */
|
||||||
|
@ -686,7 +693,7 @@
|
||||||
public static void func_150900_l()
|
public static void func_150900_l()
|
||||||
{
|
{
|
||||||
func_179214_a(Blocks.field_150350_a, new ItemAir(Blocks.field_150350_a));
|
func_179214_a(Blocks.field_150350_a, new ItemAir(Blocks.field_150350_a));
|
||||||
@@ -972,6 +1593,8 @@
|
@@ -972,6 +1600,8 @@
|
||||||
private final float field_78010_h;
|
private final float field_78010_h;
|
||||||
private final float field_78011_i;
|
private final float field_78011_i;
|
||||||
private final int field_78008_j;
|
private final int field_78008_j;
|
||||||
|
@ -695,7 +702,7 @@
|
||||||
|
|
||||||
private ToolMaterial(int p_i1874_3_, int p_i1874_4_, float p_i1874_5_, float p_i1874_6_, int p_i1874_7_)
|
private ToolMaterial(int p_i1874_3_, int p_i1874_4_, float p_i1874_5_, float p_i1874_6_, int p_i1874_7_)
|
||||||
{
|
{
|
||||||
@@ -1007,9 +1630,26 @@
|
@@ -1007,9 +1637,26 @@
|
||||||
return this.field_78008_j;
|
return this.field_78008_j;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -283,7 +283,7 @@
|
||||||
@SideOnly(Side.CLIENT)
|
@SideOnly(Side.CLIENT)
|
||||||
public int func_190921_D()
|
public int func_190921_D()
|
||||||
{
|
{
|
||||||
@@ -1013,4 +1085,28 @@
|
@@ -1013,4 +1085,66 @@
|
||||||
{
|
{
|
||||||
this.func_190917_f(-p_190918_1_);
|
this.func_190917_f(-p_190918_1_);
|
||||||
}
|
}
|
||||||
|
@ -310,5 +310,43 @@
|
||||||
+ private Item getItemRaw()
|
+ private Item getItemRaw()
|
||||||
+ {
|
+ {
|
||||||
+ return this.field_151002_e;
|
+ return this.field_151002_e;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Modeled after ItemStack.areItemStacksEqual
|
||||||
|
+ * Uses Item.getNBTShareTag for comparison instead of NBT and capabilities.
|
||||||
|
+ * Only used for comparing itemStacks that were transferred from server to client using Item.getNBTShareTag.
|
||||||
|
+ */
|
||||||
|
+ public static boolean areItemStacksEqualUsingNBTShareTag(ItemStack stackA, ItemStack stackB)
|
||||||
|
+ {
|
||||||
|
+ if (stackA.func_190926_b())
|
||||||
|
+ return stackB.func_190926_b();
|
||||||
|
+ else
|
||||||
|
+ return !stackB.func_190926_b() && stackA.isItemStackEqualUsingNBTShareTag(stackB);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Modeled after ItemStack.isItemStackEqual
|
||||||
|
+ * Uses Item.getNBTShareTag for comparison instead of NBT and capabilities.
|
||||||
|
+ * Only used for comparing itemStacks that were transferred from server to client using Item.getNBTShareTag.
|
||||||
|
+ */
|
||||||
|
+ private boolean isItemStackEqualUsingNBTShareTag(ItemStack other)
|
||||||
|
+ {
|
||||||
|
+ return this.field_77994_a == other.field_77994_a && this.func_77973_b() == other.func_77973_b() && this.field_77991_e == other.field_77991_e && areItemStackShareTagsEqual(this, other);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Modeled after ItemStack.areItemStackTagsEqual
|
||||||
|
+ * Uses Item.getNBTShareTag for comparison instead of NBT and capabilities.
|
||||||
|
+ * Only used for comparing itemStacks that were transferred from server to client using Item.getNBTShareTag.
|
||||||
|
+ */
|
||||||
|
+ public static boolean areItemStackShareTagsEqual(ItemStack stackA, ItemStack stackB)
|
||||||
|
+ {
|
||||||
|
+ NBTTagCompound shareTagA = stackA.func_77973_b().getNBTShareTag(stackA);
|
||||||
|
+ NBTTagCompound shareTagB = stackB.func_77973_b().getNBTShareTag(stackB);
|
||||||
|
+ if (shareTagA == null)
|
||||||
|
+ return shareTagB == null;
|
||||||
|
+ else
|
||||||
|
+ return shareTagB != null && shareTagA.equals(shareTagB);
|
||||||
+ }
|
+ }
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,3 +51,12 @@
|
||||||
|
|
||||||
if (this.field_147367_d.func_71199_h())
|
if (this.field_147367_d.func_71199_h())
|
||||||
{
|
{
|
||||||
|
@@ -1097,7 +1105,7 @@
|
||||||
|
{
|
||||||
|
ItemStack itemstack2 = this.field_147369_b.field_71070_bA.func_184996_a(p_147351_1_.func_149544_d(), p_147351_1_.func_149543_e(), p_147351_1_.func_186993_f(), this.field_147369_b);
|
||||||
|
|
||||||
|
- if (ItemStack.func_77989_b(p_147351_1_.func_149546_g(), itemstack2))
|
||||||
|
+ if (ItemStack.areItemStacksEqualUsingNBTShareTag(p_147351_1_.func_149546_g(), itemstack2))
|
||||||
|
{
|
||||||
|
this.field_147369_b.field_71135_a.func_147359_a(new SPacketConfirmTransaction(p_147351_1_.func_149548_c(), p_147351_1_.func_149547_f(), true));
|
||||||
|
this.field_147369_b.field_71137_h = true;
|
||||||
|
|
|
@ -0,0 +1,11 @@
|
||||||
|
--- ../src-base/minecraft/net/minecraft/network/play/client/CPacketClickWindow.java
|
||||||
|
+++ ../src-work/minecraft/net/minecraft/network/play/client/CPacketClickWindow.java
|
||||||
|
@@ -55,7 +55,7 @@
|
||||||
|
p_148840_1_.writeByte(this.field_149553_c);
|
||||||
|
p_148840_1_.writeShort(this.field_149550_d);
|
||||||
|
p_148840_1_.func_179249_a(this.field_149549_f);
|
||||||
|
- p_148840_1_.func_150788_a(this.field_149551_e);
|
||||||
|
+ net.minecraftforge.common.util.PacketUtil.writeItemStackFromClientToServer(p_148840_1_, this.field_149551_e);
|
||||||
|
}
|
||||||
|
|
||||||
|
public int func_149548_c()
|
|
@ -0,0 +1,11 @@
|
||||||
|
--- ../src-base/minecraft/net/minecraft/network/play/client/CPacketCreativeInventoryAction.java
|
||||||
|
+++ ../src-work/minecraft/net/minecraft/network/play/client/CPacketCreativeInventoryAction.java
|
||||||
|
@@ -38,7 +38,7 @@
|
||||||
|
public void func_148840_b(PacketBuffer p_148840_1_) throws IOException
|
||||||
|
{
|
||||||
|
p_148840_1_.writeShort(this.field_149629_a);
|
||||||
|
- p_148840_1_.func_150788_a(this.field_149628_b);
|
||||||
|
+ net.minecraftforge.common.util.PacketUtil.writeItemStackFromClientToServer(p_148840_1_, this.field_149628_b);
|
||||||
|
}
|
||||||
|
|
||||||
|
public int func_149627_c()
|
58
src/main/java/net/minecraftforge/common/util/PacketUtil.java
Normal file
58
src/main/java/net/minecraftforge/common/util/PacketUtil.java
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
/*
|
||||||
|
* Minecraft Forge
|
||||||
|
* Copyright (c) 2016.
|
||||||
|
*
|
||||||
|
* This library is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Lesser General Public
|
||||||
|
* License as published by the Free Software Foundation version 2.1
|
||||||
|
* of the License.
|
||||||
|
*
|
||||||
|
* This library is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public
|
||||||
|
* License along with this library; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
package net.minecraftforge.common.util;
|
||||||
|
|
||||||
|
import net.minecraft.item.Item;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
|
import net.minecraft.network.PacketBuffer;
|
||||||
|
|
||||||
|
public class PacketUtil
|
||||||
|
{
|
||||||
|
private PacketUtil() {}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Most ItemStack serialization is Server to Client, and must go through PacketBuffer.writeItemStack which uses Item.getNBTShareTag.
|
||||||
|
* One exception is items from the creative menu, which must be sent from Client to Server with their full NBT.
|
||||||
|
* <br/>
|
||||||
|
* This method matches PacketBuffer.writeItemStack but without the Item.getNBTShareTag patch.
|
||||||
|
* It is compatible with PacketBuffer.readItemStack.
|
||||||
|
*/
|
||||||
|
public static void writeItemStackFromClientToServer(PacketBuffer buffer, ItemStack stack)
|
||||||
|
{
|
||||||
|
if (stack.isEmpty())
|
||||||
|
{
|
||||||
|
buffer.writeShort(-1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
buffer.writeShort(Item.getIdFromItem(stack.getItem()));
|
||||||
|
buffer.writeByte(stack.getCount());
|
||||||
|
buffer.writeShort(stack.getMetadata());
|
||||||
|
NBTTagCompound nbttagcompound = null;
|
||||||
|
|
||||||
|
if (stack.getItem().isDamageable() || stack.getItem().getShareTag())
|
||||||
|
{
|
||||||
|
nbttagcompound = stack.getTagCompound();
|
||||||
|
}
|
||||||
|
|
||||||
|
buffer.writeCompoundTag(nbttagcompound);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,96 @@
|
||||||
|
package net.minecraftforge.debug;
|
||||||
|
|
||||||
|
import net.minecraft.client.renderer.block.model.ModelResourceLocation;
|
||||||
|
import net.minecraft.creativetab.CreativeTabs;
|
||||||
|
import net.minecraft.init.Items;
|
||||||
|
import net.minecraft.item.Item;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
|
import net.minecraft.item.crafting.CraftingManager;
|
||||||
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
|
import net.minecraft.util.NonNullList;
|
||||||
|
import net.minecraft.util.ResourceLocation;
|
||||||
|
import net.minecraftforge.client.model.ModelLoader;
|
||||||
|
import net.minecraftforge.fml.common.Mod;
|
||||||
|
import net.minecraftforge.fml.common.event.FMLPreInitializationEvent;
|
||||||
|
import net.minecraftforge.fml.common.registry.GameRegistry;
|
||||||
|
import net.minecraftforge.fml.relauncher.Side;
|
||||||
|
|
||||||
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
|
@Mod(modid = NBTShareTagItemTest.MOD_ID, name = "NBTShareTag Item Test", version = "1.0.0", acceptableRemoteVersions = "*")
|
||||||
|
public class NBTShareTagItemTest
|
||||||
|
{
|
||||||
|
public static final String MOD_ID = "nbtsharetagitemtest";
|
||||||
|
private static final ResourceLocation itemName = new ResourceLocation(MOD_ID, "nbt_share_tag_item");
|
||||||
|
|
||||||
|
@Mod.EventHandler
|
||||||
|
public void preInit(FMLPreInitializationEvent event)
|
||||||
|
{
|
||||||
|
ShareTagItem item = new ShareTagItem();
|
||||||
|
item.setRegistryName(itemName);
|
||||||
|
GameRegistry.register(item);
|
||||||
|
|
||||||
|
if (event.getSide() == Side.CLIENT)
|
||||||
|
{
|
||||||
|
ModelLoader.setCustomModelResourceLocation(item, 0, new ModelResourceLocation(itemName, "inventory"));
|
||||||
|
}
|
||||||
|
|
||||||
|
ItemStack crafted = new ItemStack(item);
|
||||||
|
NBTTagCompound craftedNBT = new NBTTagCompound();
|
||||||
|
craftedNBT.setBoolean("crafted", true);
|
||||||
|
crafted.setTagCompound(craftedNBT);
|
||||||
|
CraftingManager.getInstance().addShapelessRecipe(crafted, new ItemStack(Items.STICK));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class ShareTagItem extends Item
|
||||||
|
{
|
||||||
|
public ShareTagItem()
|
||||||
|
{
|
||||||
|
setCreativeTab(CreativeTabs.MISC);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
@Override
|
||||||
|
public NBTTagCompound getNBTShareTag(ItemStack stack)
|
||||||
|
{
|
||||||
|
NBTTagCompound networkNBT = stack.getTagCompound();
|
||||||
|
if (networkNBT == null)
|
||||||
|
networkNBT = new NBTTagCompound();
|
||||||
|
networkNBT.setBoolean("nbtShareTag", true);
|
||||||
|
return networkNBT;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void getSubItems(Item itemIn, CreativeTabs tab, NonNullList<ItemStack> subItems)
|
||||||
|
{
|
||||||
|
ItemStack creativeMenuItem = new ItemStack(itemIn);
|
||||||
|
NBTTagCompound creativeMenuNBT = new NBTTagCompound();
|
||||||
|
creativeMenuNBT.setBoolean("creativeMenu", true);
|
||||||
|
creativeMenuItem.setTagCompound(creativeMenuNBT);
|
||||||
|
subItems.add(creativeMenuItem);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getItemStackDisplayName(ItemStack stack)
|
||||||
|
{
|
||||||
|
NBTTagCompound tagCompound = stack.getTagCompound();
|
||||||
|
String name = "NBTShareTagItem: ";
|
||||||
|
if (tagCompound == null)
|
||||||
|
{
|
||||||
|
name += "From /give. ";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (tagCompound.getBoolean("nbtShareTag"))
|
||||||
|
name += "Sent from server. ";
|
||||||
|
|
||||||
|
if (tagCompound.getBoolean("creativeMenu"))
|
||||||
|
name += "From creative menu. ";
|
||||||
|
|
||||||
|
if (tagCompound.getBoolean("crafted"))
|
||||||
|
name += "From crafting. ";
|
||||||
|
}
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
{
|
||||||
|
"parent": "item/generated",
|
||||||
|
"textures": {
|
||||||
|
"layer0": "items/stick"
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue