mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-17 05:41:26 +01:00
Remove fully dropped patches
This commit is contained in:
parent
78a67f00ea
commit
98682757de
@ -1,64 +0,0 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Hugo Manrique <hugmanrique@gmail.com>
|
|
||||||
Date: Thu, 26 Jul 2018 14:10:23 +0200
|
|
||||||
Subject: [PATCH] Don't call getItemMeta on hasItemMeta
|
|
||||||
|
|
||||||
Spigot 1.13 checks if any field (which are manually copied from the ItemStack's "tag" NBT tag) on the ItemMeta class of an ItemStack is set.
|
|
||||||
|
|
||||||
We could just check if the "tag" NBT tag is empty, albeit that would break some plugins. The only general tag added on 1.13 is "Damage", and we can just check if the "tag" NBT tag contains any other tag that's not "Damage" (https://minecraft.wiki/wiki/Player.dat_format#Item_structure) making the `hasItemStack` method behave as before.
|
|
||||||
|
|
||||||
Returns true if getDamage() == 0 or has damage tag or other tag is set.
|
|
||||||
Check the `ItemMetaTest#testTaggedButNotMeta` method to see how this method behaves.
|
|
||||||
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
|
||||||
@@ -0,0 +0,0 @@ public final class CraftItemStack extends ItemStack {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean hasItemMeta() {
|
|
||||||
- return CraftItemStack.hasItemMeta(this.handle) && !CraftItemFactory.instance().equals(this.getItemMeta(), null);
|
|
||||||
+ return CraftItemStack.hasItemMeta(this.handle) && (this.handle.getDamageValue() != 0 || (this.handle.getTag() != null && this.handle.getTag().tags.size() >= (this.handle.getTag().contains(CraftMetaItem.DAMAGE.NBT) ? 2 : 1))); // Paper - keep 1.12 CraftBukkit behavior without calling getItemMeta
|
|
||||||
}
|
|
||||||
|
|
||||||
static boolean hasItemMeta(net.minecraft.world.item.ItemStack item) {
|
|
||||||
diff --git a/src/test/java/org/bukkit/craftbukkit/inventory/ItemMetaTest.java b/src/test/java/org/bukkit/craftbukkit/inventory/ItemMetaTest.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/test/java/org/bukkit/craftbukkit/inventory/ItemMetaTest.java
|
|
||||||
+++ b/src/test/java/org/bukkit/craftbukkit/inventory/ItemMetaTest.java
|
|
||||||
@@ -0,0 +0,0 @@ public class ItemMetaTest extends AbstractTestingBase {
|
|
||||||
assertThat(itemMeta.hasConflictingEnchant(null), is(false));
|
|
||||||
}
|
|
||||||
|
|
||||||
+ // Paper start
|
|
||||||
+ private void testItemMeta(ItemStack stack) {
|
|
||||||
+ assertThat(stack.hasItemMeta(), is(false), "Should not have ItemMeta");
|
|
||||||
+
|
|
||||||
+ stack.setDurability((short) 0);
|
|
||||||
+ assertThat(stack.hasItemMeta(), is(false), "ItemStack with zero durability should not have ItemMeta");
|
|
||||||
+
|
|
||||||
+ stack.setDurability((short) 2);
|
|
||||||
+ assertThat(stack.hasItemMeta(), is(true), "ItemStack with non-zero durability should have ItemMeta");
|
|
||||||
+
|
|
||||||
+ stack.setLore(java.util.Collections.singletonList("Lore"));
|
|
||||||
+ assertThat(stack.hasItemMeta(), is(true), "ItemStack with lore and durability should have ItemMeta");
|
|
||||||
+
|
|
||||||
+ stack.setDurability((short) 0);
|
|
||||||
+ assertThat(stack.hasItemMeta(), is(true), "ItemStack with lore should have ItemMeta");
|
|
||||||
+
|
|
||||||
+ stack.setLore(null);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ @Test
|
|
||||||
+ public void testHasItemMeta() {
|
|
||||||
+ ItemStack itemStack = new ItemStack(Material.SHEARS);
|
|
||||||
+
|
|
||||||
+ testItemMeta(itemStack);
|
|
||||||
+ testItemMeta(CraftItemStack.asCraftCopy(itemStack));
|
|
||||||
+ }
|
|
||||||
+ // Paper end
|
|
||||||
+
|
|
||||||
@Test
|
|
||||||
public void testConflictingStoredEnchantment() {
|
|
||||||
EnchantmentStorageMeta itemMeta = (EnchantmentStorageMeta) Bukkit.getItemFactory().getItemMeta(Material.ENCHANTED_BOOK);
|
|
@ -1,397 +0,0 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Mark Vainomaa <mikroskeem@mikroskeem.eu>
|
|
||||||
Date: Wed, 12 Sep 2018 18:53:55 +0300
|
|
||||||
Subject: [PATCH] Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
|
||||||
@@ -0,0 +0,0 @@ import org.bukkit.persistence.PersistentDataContainer;
|
|
||||||
import static org.spigotmc.ValidateUtils.*;
|
|
||||||
// Spigot end
|
|
||||||
|
|
||||||
+// Paper start
|
|
||||||
+import com.destroystokyo.paper.Namespaced;
|
|
||||||
+import com.destroystokyo.paper.NamespacedTag;
|
|
||||||
+import java.util.Collections;
|
|
||||||
+// Paper end
|
|
||||||
+
|
|
||||||
/**
|
|
||||||
* Children must include the following:
|
|
||||||
*
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
@Specific(Specific.To.NBT)
|
|
||||||
static final ItemMetaKey BLOCK_DATA = new ItemMetaKey("BlockStateTag");
|
|
||||||
static final ItemMetaKey BUKKIT_CUSTOM_TAG = new ItemMetaKey("PublicBukkitValues");
|
|
||||||
+ // Paper start - Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
+ static final ItemMetaKey CAN_DESTROY = new ItemMetaKey("CanDestroy");
|
|
||||||
+ static final ItemMetaKey CAN_PLACE_ON = new ItemMetaKey("CanPlaceOn");
|
|
||||||
+ // Paper end - Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
|
|
||||||
// We store the raw original JSON representation of all text data. See SPIGOT-5063, SPIGOT-5656, SPIGOT-5304
|
|
||||||
private String displayName;
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
private int hideFlag;
|
|
||||||
private boolean unbreakable;
|
|
||||||
private int damage;
|
|
||||||
+ // Paper start - Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
+ private Set<Namespaced> placeableKeys = Sets.newHashSet();
|
|
||||||
+ private Set<Namespaced> destroyableKeys = Sets.newHashSet();
|
|
||||||
+ // Paper end - Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
|
|
||||||
private static final Set<String> HANDLED_TAGS = Sets.newHashSet();
|
|
||||||
private static final CraftPersistentDataTypeRegistry DATA_TYPE_REGISTRY = new CraftPersistentDataTypeRegistry();
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
this.hideFlag = meta.hideFlag;
|
|
||||||
this.unbreakable = meta.unbreakable;
|
|
||||||
this.damage = meta.damage;
|
|
||||||
+ // Paper start - Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
+ if (meta.hasPlaceableKeys()) {
|
|
||||||
+ this.placeableKeys = new java.util.HashSet<>(meta.placeableKeys);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (meta.hasDestroyableKeys()) {
|
|
||||||
+ this.destroyableKeys = new java.util.HashSet<>(meta.destroyableKeys);
|
|
||||||
+ }
|
|
||||||
+ // Paper end - Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
this.unhandledTags.putAll(meta.unhandledTags);
|
|
||||||
this.persistentDataContainer.putAll(meta.persistentDataContainer.getRaw());
|
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
this.persistentDataContainer.put(key, compound.get(key).copy());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
+ // Paper start - Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
+ if (tag.contains(CAN_DESTROY.NBT)) {
|
|
||||||
+ ListTag list = tag.getList(CAN_DESTROY.NBT, CraftMagicNumbers.NBT.TAG_STRING);
|
|
||||||
+ for (int i = 0; i < list.size(); i++) {
|
|
||||||
+ Namespaced namespaced = this.blockKeyFromString(list.getString(i));
|
|
||||||
+ if (namespaced == null) {
|
|
||||||
+ continue;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ this.destroyableKeys.add(namespaced);
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (tag.contains(CAN_PLACE_ON.NBT)) {
|
|
||||||
+ ListTag list = tag.getList(CAN_PLACE_ON.NBT, CraftMagicNumbers.NBT.TAG_STRING);
|
|
||||||
+ for (int i = 0; i < list.size(); i++) {
|
|
||||||
+ Namespaced namespaced = this.blockKeyFromString(list.getString(i));
|
|
||||||
+ if (namespaced == null) {
|
|
||||||
+ continue;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ this.placeableKeys.add(namespaced);
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ // Paper end - Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
|
|
||||||
Set<String> keys = tag.getAllKeys();
|
|
||||||
for (String key : keys) {
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
this.setDamage(damage);
|
|
||||||
}
|
|
||||||
|
|
||||||
+ // Paper start - Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
+ Iterable<?> canPlaceOnSerialized = SerializableMeta.getObject(Iterable.class, map, CAN_PLACE_ON.BUKKIT, true);
|
|
||||||
+ if (canPlaceOnSerialized != null) {
|
|
||||||
+ for (Object canPlaceOnElement : canPlaceOnSerialized) {
|
|
||||||
+ String canPlaceOnRaw = (String) canPlaceOnElement;
|
|
||||||
+ Namespaced value = this.blockKeyFromString(canPlaceOnRaw);
|
|
||||||
+ if (value == null) {
|
|
||||||
+ continue;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ this.placeableKeys.add(value);
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ Iterable<?> canDestroySerialized = SerializableMeta.getObject(Iterable.class, map, CAN_DESTROY.BUKKIT, true);
|
|
||||||
+ if (canDestroySerialized != null) {
|
|
||||||
+ for (Object canDestroyElement : canDestroySerialized) {
|
|
||||||
+ String canDestroyRaw = (String) canDestroyElement;
|
|
||||||
+ Namespaced value = this.blockKeyFromString(canDestroyRaw);
|
|
||||||
+ if (value == null) {
|
|
||||||
+ continue;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ this.destroyableKeys.add(value);
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ // Paper end - Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
+
|
|
||||||
String internal = SerializableMeta.getString(map, "internal", true);
|
|
||||||
if (internal != null) {
|
|
||||||
ByteArrayInputStream buf = new ByteArrayInputStream(Base64.getDecoder().decode(internal));
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
if (this.hasDamage()) {
|
|
||||||
itemTag.putInt(CraftMetaItem.DAMAGE.NBT, this.damage);
|
|
||||||
}
|
|
||||||
+ // Paper start - Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
+ if (hasPlaceableKeys()) {
|
|
||||||
+ List<String> items = this.placeableKeys.stream()
|
|
||||||
+ .map(this::serializeNamespaced)
|
|
||||||
+ .collect(java.util.stream.Collectors.toList());
|
|
||||||
+
|
|
||||||
+ itemTag.put(CAN_PLACE_ON.NBT, createNonComponentStringList(items));
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (hasDestroyableKeys()) {
|
|
||||||
+ List<String> items = this.destroyableKeys.stream()
|
|
||||||
+ .map(this::serializeNamespaced)
|
|
||||||
+ .collect(java.util.stream.Collectors.toList());
|
|
||||||
+
|
|
||||||
+ itemTag.put(CAN_DESTROY.NBT, createNonComponentStringList(items));
|
|
||||||
+ }
|
|
||||||
+ // Paper end - Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
|
|
||||||
for (Map.Entry<String, Tag> e : this.unhandledTags.entrySet()) {
|
|
||||||
itemTag.put(e.getKey(), e.getValue());
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
+ // Paper start - Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
+ static ListTag createNonComponentStringList(List<String> list) {
|
|
||||||
+ if (list == null || list.isEmpty()) {
|
|
||||||
+ return null;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ ListTag tagList = new ListTag();
|
|
||||||
+ for (String value : list) {
|
|
||||||
+ tagList.add(StringTag.valueOf(value)); // Paper - NBTTagString.of(String str)
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ return tagList;
|
|
||||||
+ }
|
|
||||||
+ // Paper end - Add API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
+
|
|
||||||
ListTag createStringList(List<String> list) {
|
|
||||||
if (list == null) {
|
|
||||||
return null;
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
|
|
||||||
@Overridden
|
|
||||||
boolean isEmpty() {
|
|
||||||
- return !(this.hasDisplayName() || this.hasLocalizedName() || this.hasEnchants() || (this.lore != null) || this.hasCustomModelData() || this.hasBlockData() || this.hasRepairCost() || !this.unhandledTags.isEmpty() || !this.persistentDataContainer.isEmpty() || this.hideFlag != 0 || this.isUnbreakable() || this.hasDamage() || this.hasAttributeModifiers());
|
|
||||||
+ return !(this.hasDisplayName() || this.hasLocalizedName() || this.hasEnchants() || (this.lore != null) || this.hasCustomModelData() || this.hasBlockData() || this.hasRepairCost() || !this.unhandledTags.isEmpty() || !this.persistentDataContainer.isEmpty() || this.hideFlag != 0 || this.isUnbreakable() || this.hasDamage() || this.hasAttributeModifiers() || this.hasPlaceableKeys() || this.hasDestroyableKeys()); // Paper - Implement an API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
}
|
|
||||||
|
|
||||||
// Paper start
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
&& (this.hideFlag == that.hideFlag)
|
|
||||||
&& (this.isUnbreakable() == that.isUnbreakable())
|
|
||||||
&& (this.hasDamage() ? that.hasDamage() && this.damage == that.damage : !that.hasDamage())
|
|
||||||
- && (this.version == that.version);
|
|
||||||
+ && (this.version == that.version)
|
|
||||||
+ // Paper start - Implement an API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
+ && (this.hasPlaceableKeys() ? that.hasPlaceableKeys() && this.placeableKeys.equals(that.placeableKeys) : !that.hasPlaceableKeys())
|
|
||||||
+ && (this.hasDestroyableKeys() ? that.hasDestroyableKeys() && this.destroyableKeys.equals(that.destroyableKeys) : !that.hasDestroyableKeys());
|
|
||||||
+ // Paper end
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
hash = 61 * hash + (this.hasDamage() ? this.damage : 0);
|
|
||||||
hash = 61 * hash + (this.hasAttributeModifiers() ? this.attributeModifiers.hashCode() : 0);
|
|
||||||
hash = 61 * hash + this.version;
|
|
||||||
+ // Paper start - Implement an API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
+ hash = 61 * hash + (this.hasPlaceableKeys() ? this.placeableKeys.hashCode() : 0);
|
|
||||||
+ hash = 61 * hash + (this.hasDestroyableKeys() ? this.destroyableKeys.hashCode() : 0);
|
|
||||||
+ // Paper end
|
|
||||||
return hash;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
clone.unbreakable = this.unbreakable;
|
|
||||||
clone.damage = this.damage;
|
|
||||||
clone.version = this.version;
|
|
||||||
+ // Paper start - Implement an API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
+ if (this.placeableKeys != null) {
|
|
||||||
+ clone.placeableKeys = Sets.newHashSet(this.placeableKeys);
|
|
||||||
+ }
|
|
||||||
+ if (this.destroyableKeys != null) {
|
|
||||||
+ clone.destroyableKeys = Sets.newHashSet(this.destroyableKeys);
|
|
||||||
+ }
|
|
||||||
+ // Paper end
|
|
||||||
return clone;
|
|
||||||
} catch (CloneNotSupportedException e) {
|
|
||||||
throw new Error(e);
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
builder.put(CraftMetaItem.DAMAGE.BUKKIT, this.damage);
|
|
||||||
}
|
|
||||||
|
|
||||||
+ // Paper start - Implement an API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
+ if (this.hasPlaceableKeys()) {
|
|
||||||
+ List<String> cerealPlaceable = this.placeableKeys.stream()
|
|
||||||
+ .map(this::serializeNamespaced)
|
|
||||||
+ .collect(java.util.stream.Collectors.toList());
|
|
||||||
+
|
|
||||||
+ builder.put(CAN_PLACE_ON.BUKKIT, cerealPlaceable);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (this.hasDestroyableKeys()) {
|
|
||||||
+ List<String> cerealDestroyable = this.destroyableKeys.stream()
|
|
||||||
+ .map(this::serializeNamespaced)
|
|
||||||
+ .collect(java.util.stream.Collectors.toList());
|
|
||||||
+
|
|
||||||
+ builder.put(CAN_DESTROY.BUKKIT, cerealDestroyable);
|
|
||||||
+ }
|
|
||||||
+ // Paper end
|
|
||||||
final Map<String, Tag> internalTags = new HashMap<String, Tag>(this.unhandledTags);
|
|
||||||
this.serializeInternal(internalTags);
|
|
||||||
if (!internalTags.isEmpty()) {
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
CraftMetaArmorStand.SHOW_ARMS.NBT,
|
|
||||||
CraftMetaArmorStand.SMALL.NBT,
|
|
||||||
CraftMetaArmorStand.MARKER.NBT,
|
|
||||||
+ CAN_DESTROY.NBT,
|
|
||||||
+ CAN_PLACE_ON.NBT,
|
|
||||||
// Paper end
|
|
||||||
CraftMetaCompass.LODESTONE_DIMENSION.NBT,
|
|
||||||
CraftMetaCompass.LODESTONE_POS.NBT,
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
}
|
|
||||||
// Paper end
|
|
||||||
|
|
||||||
+ // Paper start - Implement an API for CanPlaceOn and CanDestroy NBT values
|
|
||||||
+ @Override
|
|
||||||
+ @SuppressWarnings("deprecation")
|
|
||||||
+ public Set<Material> getCanDestroy() {
|
|
||||||
+ return !hasDestroyableKeys() ? Collections.emptySet() : legacyGetMatsFromKeys(this.destroyableKeys);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ @Override
|
|
||||||
+ @SuppressWarnings("deprecation")
|
|
||||||
+ public void setCanDestroy(Set<Material> canDestroy) {
|
|
||||||
+ Preconditions.checkArgument(canDestroy != null, "Cannot replace with null set!");
|
|
||||||
+ legacyClearAndReplaceKeys(this.destroyableKeys, canDestroy);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ @Override
|
|
||||||
+ @SuppressWarnings("deprecation")
|
|
||||||
+ public Set<Material> getCanPlaceOn() {
|
|
||||||
+ return !hasPlaceableKeys() ? Collections.emptySet() : legacyGetMatsFromKeys(this.placeableKeys);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ @Override
|
|
||||||
+ @SuppressWarnings("deprecation")
|
|
||||||
+ public void setCanPlaceOn(Set<Material> canPlaceOn) {
|
|
||||||
+ Preconditions.checkArgument(canPlaceOn != null, "Cannot replace with null set!");
|
|
||||||
+ legacyClearAndReplaceKeys(this.placeableKeys, canPlaceOn);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ @Override
|
|
||||||
+ public Set<Namespaced> getDestroyableKeys() {
|
|
||||||
+ return !hasDestroyableKeys() ? Collections.emptySet() : Sets.newHashSet(this.destroyableKeys);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ @Override
|
|
||||||
+ public void setDestroyableKeys(Collection<Namespaced> canDestroy) {
|
|
||||||
+ Preconditions.checkArgument(canDestroy != null, "Cannot replace with null collection!");
|
|
||||||
+ Preconditions.checkArgument(ofAcceptableType(canDestroy), "Can only use NamespacedKey or NamespacedTag objects!");
|
|
||||||
+ this.destroyableKeys.clear();
|
|
||||||
+ this.destroyableKeys.addAll(canDestroy);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ @Override
|
|
||||||
+ public Set<Namespaced> getPlaceableKeys() {
|
|
||||||
+ return !hasPlaceableKeys() ? Collections.emptySet() : Sets.newHashSet(this.placeableKeys);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ @Override
|
|
||||||
+ public void setPlaceableKeys(Collection<Namespaced> canPlaceOn) {
|
|
||||||
+ Preconditions.checkArgument(canPlaceOn != null, "Cannot replace with null collection!");
|
|
||||||
+ Preconditions.checkArgument(ofAcceptableType(canPlaceOn), "Can only use NamespacedKey or NamespacedTag objects!");
|
|
||||||
+ this.placeableKeys.clear();
|
|
||||||
+ this.placeableKeys.addAll(canPlaceOn);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ @Override
|
|
||||||
+ public boolean hasPlaceableKeys() {
|
|
||||||
+ return this.placeableKeys != null && !this.placeableKeys.isEmpty();
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ @Override
|
|
||||||
+ public boolean hasDestroyableKeys() {
|
|
||||||
+ return this.destroyableKeys != null && !this.destroyableKeys.isEmpty();
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ @Deprecated
|
|
||||||
+ private void legacyClearAndReplaceKeys(Collection<Namespaced> toUpdate, Collection<Material> beingSet) {
|
|
||||||
+ if (beingSet.stream().anyMatch(Material::isLegacy)) {
|
|
||||||
+ throw new IllegalArgumentException("Set must not contain any legacy materials!");
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ toUpdate.clear();
|
|
||||||
+ toUpdate.addAll(beingSet.stream().map(Material::getKey).collect(java.util.stream.Collectors.toSet()));
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ @Deprecated
|
|
||||||
+ private Set<Material> legacyGetMatsFromKeys(Collection<Namespaced> names) {
|
|
||||||
+ Set<Material> mats = Sets.newHashSet();
|
|
||||||
+ for (Namespaced key : names) {
|
|
||||||
+ if (!(key instanceof org.bukkit.NamespacedKey)) {
|
|
||||||
+ continue;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ Material material = Material.matchMaterial(key.toString(), false);
|
|
||||||
+ if (material != null) {
|
|
||||||
+ mats.add(material);
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ return mats;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ private @Nullable Namespaced blockKeyFromString(String raw) {
|
|
||||||
+ boolean isTag = !raw.isEmpty() && raw.codePointAt(0) == '#';
|
|
||||||
+ com.mojang.datafixers.util.Either<net.minecraft.commands.arguments.blocks.BlockStateParser.BlockResult, net.minecraft.commands.arguments.blocks.BlockStateParser.TagResult> result;
|
|
||||||
+ try {
|
|
||||||
+ result = net.minecraft.commands.arguments.blocks.BlockStateParser.parseForTesting(net.minecraft.core.registries.BuiltInRegistries.BLOCK.asLookup(), raw, false);
|
|
||||||
+ } catch (com.mojang.brigadier.exceptions.CommandSyntaxException e) {
|
|
||||||
+ return null;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ net.minecraft.resources.ResourceLocation key = null;
|
|
||||||
+ if (isTag && result.right().isPresent() && result.right().get().tag() instanceof net.minecraft.core.HolderSet.Named<net.minecraft.world.level.block.Block> namedSet) {
|
|
||||||
+ key = namedSet.key().location();
|
|
||||||
+ } else if (result.left().isPresent()) {
|
|
||||||
+ key = net.minecraft.core.registries.BuiltInRegistries.BLOCK.getKey(result.left().get().blockState().getBlock());
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (key == null) {
|
|
||||||
+ return null;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ try {
|
|
||||||
+ if (isTag) {
|
|
||||||
+ return new NamespacedTag(key.getNamespace(), key.getPath());
|
|
||||||
+
|
|
||||||
+ }
|
|
||||||
+ return CraftNamespacedKey.fromMinecraft(key);
|
|
||||||
+ } catch (IllegalArgumentException ignored) {
|
|
||||||
+ return null;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ private @Nonnull String serializeNamespaced(Namespaced resource) {
|
|
||||||
+ return resource.toString();
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ // not a fan of this
|
|
||||||
+ private boolean ofAcceptableType(Collection<Namespaced> namespacedResources) {
|
|
||||||
+
|
|
||||||
+ for (Namespaced resource : namespacedResources) {
|
|
||||||
+ if (!(resource instanceof org.bukkit.NamespacedKey || resource instanceof com.destroystokyo.paper.NamespacedTag)) {
|
|
||||||
+ return false;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ return true;
|
|
||||||
+ }
|
|
||||||
+ // Paper end
|
|
||||||
}
|
|
@ -1,63 +0,0 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
||||||
From: William Blake Galbreath <Blake.Galbreath@GMail.com>
|
|
||||||
Date: Wed, 1 Jul 2020 11:57:40 -0500
|
|
||||||
Subject: [PATCH] Update itemstack legacy name and lore
|
|
||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/world/item/ItemStack.java b/src/main/java/net/minecraft/world/item/ItemStack.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/net/minecraft/world/item/ItemStack.java
|
|
||||||
+++ b/src/main/java/net/minecraft/world/item/ItemStack.java
|
|
||||||
@@ -0,0 +0,0 @@ public final class ItemStack {
|
|
||||||
list.sort((java.util.Comparator<? super net.minecraft.nbt.Tag>) enchantSorter); // Paper
|
|
||||||
} catch (Exception ignored) {}
|
|
||||||
}
|
|
||||||
+
|
|
||||||
+ private void processText() {
|
|
||||||
+ CompoundTag display = getTagElement("display");
|
|
||||||
+ if (display != null) {
|
|
||||||
+ if (display.contains("Name", net.minecraft.nbt.Tag.TAG_STRING)) {
|
|
||||||
+ String json = display.getString("Name");
|
|
||||||
+ if (json != null && json.contains("\u00A7")) {
|
|
||||||
+ try {
|
|
||||||
+ display.put("Name", convert(json));
|
|
||||||
+ } catch (com.google.gson.JsonParseException jsonparseexception) {
|
|
||||||
+ display.remove("Name");
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ if (display.contains("Lore", net.minecraft.nbt.Tag.TAG_LIST)) {
|
|
||||||
+ ListTag list = display.getList("Lore", net.minecraft.nbt.Tag.TAG_STRING);
|
|
||||||
+ for (int index = 0; index < list.size(); index++) {
|
|
||||||
+ String json = list.getString(index);
|
|
||||||
+ if (json != null && json.contains("\u00A7")) { // Only try if it has legacy in the unparsed json
|
|
||||||
+ try {
|
|
||||||
+ list.set(index, convert(json));
|
|
||||||
+ } catch (com.google.gson.JsonParseException e) {
|
|
||||||
+ list.set(index, net.minecraft.nbt.StringTag.valueOf(org.bukkit.craftbukkit.util.CraftChatMessage.toJSON(net.minecraft.network.chat.Component.literal(""))));
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ private net.minecraft.nbt.StringTag convert(String json) {
|
|
||||||
+ Component component = Component.Serializer.fromJson(json);
|
|
||||||
+ if (component.getContents() instanceof final net.minecraft.network.chat.contents.PlainTextContents plainTextContents && plainTextContents.text().contains("\u00A7") && component.getSiblings().isEmpty()) {
|
|
||||||
+ // Only convert if the root component is a single comp with legacy in it, don't convert already normal components
|
|
||||||
+ component = org.bukkit.craftbukkit.util.CraftChatMessage.fromString(plainTextContents.text())[0];
|
|
||||||
+ }
|
|
||||||
+ return net.minecraft.nbt.StringTag.valueOf(org.bukkit.craftbukkit.util.CraftChatMessage.toJSON(component));
|
|
||||||
+ }
|
|
||||||
// Paper end
|
|
||||||
|
|
||||||
public ItemStack(ItemLike item) {
|
|
||||||
@@ -0,0 +0,0 @@ public final class ItemStack {
|
|
||||||
if (nbttagcompound.contains("tag", 10)) {
|
|
||||||
this.tag = nbttagcompound.getCompound("tag").copy();
|
|
||||||
this.processEnchantOrder(this.tag); // Paper
|
|
||||||
+ this.processText(); // Paper - Update itemstack legacy name and lore
|
|
||||||
this.getItem().verifyTagAfterLoad(this.tag);
|
|
||||||
}
|
|
||||||
|
|
@ -1,28 +0,0 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Spottedleaf <Spottedleaf@users.noreply.github.com>
|
|
||||||
Date: Sat, 25 Apr 2020 17:10:55 -0700
|
|
||||||
Subject: [PATCH] Reduce blockpos allocation from pathfinding
|
|
||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/world/level/pathfinder/WalkNodeEvaluator.java b/src/main/java/net/minecraft/world/level/pathfinder/WalkNodeEvaluator.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/net/minecraft/world/level/pathfinder/WalkNodeEvaluator.java
|
|
||||||
+++ b/src/main/java/net/minecraft/world/level/pathfinder/WalkNodeEvaluator.java
|
|
||||||
@@ -0,0 +0,0 @@ public class WalkNodeEvaluator extends NodeEvaluator {
|
|
||||||
return BlockPathTypes.DANGER_FIRE;
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (world.getFluidState(pos).is(FluidTags.WATER)) {
|
|
||||||
+ if (blockState.getFluidState().is(FluidTags.WATER)) { // Paper - Perf: Reduce blockpos allocation from pathfinding
|
|
||||||
return BlockPathTypes.WATER_BORDER;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -0,0 +0,0 @@ public class WalkNodeEvaluator extends NodeEvaluator {
|
|
||||||
} else if (blockState.is(Blocks.COCOA)) {
|
|
||||||
return BlockPathTypes.COCOA;
|
|
||||||
} else if (!blockState.is(Blocks.WITHER_ROSE) && !blockState.is(Blocks.POINTED_DRIPSTONE)) {
|
|
||||||
- FluidState fluidState = world.getFluidState(pos);
|
|
||||||
+ FluidState fluidState = blockState.getFluidState(); // Paper - Perf: Reduce blockpos allocation from pathfinding
|
|
||||||
if (fluidState.is(FluidTags.LAVA)) {
|
|
||||||
return BlockPathTypes.LAVA;
|
|
||||||
} else if (isBurningBlock(blockState)) {
|
|
@ -1,55 +0,0 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
|
||||||
Date: Fri, 4 Jun 2021 12:12:35 -0700
|
|
||||||
Subject: [PATCH] Make item validations configurable
|
|
||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBook.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBook.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBook.java
|
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBook.java
|
|
||||||
@@ -0,0 +0,0 @@ public class CraftMetaBook extends CraftMetaItem implements BookMeta {
|
|
||||||
super(tag);
|
|
||||||
|
|
||||||
if (tag.contains(CraftMetaBook.BOOK_TITLE.NBT)) {
|
|
||||||
- this.title = limit( tag.getString(CraftMetaBook.BOOK_TITLE.NBT), 8192 ); // Spigot
|
|
||||||
+ this.title = limit( tag.getString(CraftMetaBook.BOOK_TITLE.NBT), io.papermc.paper.configuration.GlobalConfiguration.get().itemValidation.book.title); // Spigot // Paper - make configurable
|
|
||||||
}
|
|
||||||
|
|
||||||
if (tag.contains(CraftMetaBook.BOOK_AUTHOR.NBT)) {
|
|
||||||
- this.author = limit( tag.getString(CraftMetaBook.BOOK_AUTHOR.NBT), 8192 ); // Spigot
|
|
||||||
+ this.author = limit( tag.getString(CraftMetaBook.BOOK_AUTHOR.NBT), io.papermc.paper.configuration.GlobalConfiguration.get().itemValidation.book.author ); // Spigot // Paper - make configurable
|
|
||||||
}
|
|
||||||
|
|
||||||
if (tag.contains(CraftMetaBook.RESOLVED.NBT)) {
|
|
||||||
@@ -0,0 +0,0 @@ public class CraftMetaBook extends CraftMetaItem implements BookMeta {
|
|
||||||
} else {
|
|
||||||
page = this.validatePage(page);
|
|
||||||
}
|
|
||||||
- this.pages.add( limit( page, 16384 ) ); // Spigot
|
|
||||||
+ this.pages.add( limit( page, io.papermc.paper.configuration.GlobalConfiguration.get().itemValidation.book.page ) ); // Spigot // Paper - make configurable
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
CompoundTag display = tag.getCompound(CraftMetaItem.DISPLAY.NBT);
|
|
||||||
|
|
||||||
if (display.contains(CraftMetaItem.NAME.NBT)) {
|
|
||||||
- this.displayName = limit( display.getString(CraftMetaItem.NAME.NBT), 8192 ); // Spigot
|
|
||||||
+ this.displayName = limit( display.getString(CraftMetaItem.NAME.NBT), io.papermc.paper.configuration.GlobalConfiguration.get().itemValidation.displayName ); // Spigot // Paper - make configurable
|
|
||||||
}
|
|
||||||
|
|
||||||
if (display.contains(CraftMetaItem.LOCNAME.NBT)) {
|
|
||||||
@@ -0,0 +0,0 @@ class CraftMetaItem implements ItemMeta, Damageable, Repairable, BlockDataMeta {
|
|
||||||
ListTag list = display.getList(CraftMetaItem.LORE.NBT, CraftMagicNumbers.NBT.TAG_STRING);
|
|
||||||
this.lore = new ArrayList<String>(list.size());
|
|
||||||
for (int index = 0; index < list.size(); index++) {
|
|
||||||
- String line = limit( list.getString(index), 8192 ); // Spigot
|
|
||||||
+ String line = limit( list.getString(index), io.papermc.paper.configuration.GlobalConfiguration.get().itemValidation.loreLine ); // Spigot // Paper - make configurable
|
|
||||||
this.lore.add(line);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,171 +0,0 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Noah van der Aa <ndvdaa@gmail.com>
|
|
||||||
Date: Tue, 3 Aug 2021 17:28:27 +0200
|
|
||||||
Subject: [PATCH] Hide unnecessary itemmeta from clients
|
|
||||||
|
|
||||||
TODO: Needs updating for data components
|
|
||||||
|
|
||||||
diff --git a/src/main/java/io/papermc/paper/util/ItemStackObfuscator.java b/src/main/java/io/papermc/paper/util/ItemStackObfuscator.java
|
|
||||||
new file mode 100644
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/src/main/java/io/papermc/paper/util/ItemStackObfuscator.java
|
|
||||||
@@ -0,0 +0,0 @@
|
|
||||||
+package io.papermc.paper.util;
|
|
||||||
+
|
|
||||||
+import net.minecraft.core.component.DataComponentMap;
|
|
||||||
+import net.minecraft.core.component.DataComponents;
|
|
||||||
+import net.minecraft.nbt.CompoundTag;
|
|
||||||
+import net.minecraft.nbt.ListTag;
|
|
||||||
+import net.minecraft.world.item.ItemStack;
|
|
||||||
+import net.minecraft.world.item.Items;
|
|
||||||
+import net.minecraft.world.item.component.BundleContents;
|
|
||||||
+import net.minecraft.world.item.component.CustomData;
|
|
||||||
+import net.minecraft.world.item.enchantment.EnchantmentHelper;
|
|
||||||
+import net.minecraft.world.item.enchantment.Enchantments;
|
|
||||||
+import net.minecraft.world.item.enchantment.ItemEnchantments;
|
|
||||||
+import net.minecraft.world.level.Level;
|
|
||||||
+import java.util.List;
|
|
||||||
+
|
|
||||||
+public class ItemStackObfuscator {
|
|
||||||
+
|
|
||||||
+ // Paper start - Hide unnecessary item meta
|
|
||||||
+ public static ItemStack stripMeta(final ItemStack itemStack, final boolean copyItemStack, Level level) {
|
|
||||||
+ if (itemStack.isEmpty() || (itemStack.getComponentsPatch().isEmpty() && itemStack.getCount() < 2)) {
|
|
||||||
+ return itemStack;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ final ItemStack copy = copyItemStack ? itemStack.copy() : itemStack;
|
|
||||||
+ if (level.paperConfig().anticheat.obfuscation.items.hideDurability) {
|
|
||||||
+ // Only show damage values for elytra's, since they show a different texture when broken.
|
|
||||||
+ if (!copy.is(Items.ELYTRA) || copy.getDamageValue() < copy.getMaxDamage() - 1) {
|
|
||||||
+ copy.setDamageValue(0);
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ final DataComponentMap components = copy.getComponents();
|
|
||||||
+ if (level.paperConfig().anticheat.obfuscation.items.hideItemmeta) {
|
|
||||||
+ // Some resource packs show different textures when there is more than one item. Since this shouldn't provide a big advantage,
|
|
||||||
+ // we'll tell the client if there's one or (more than) two items.
|
|
||||||
+ copy.setCount(copy.getCount() > 1 ? 2 : 1);
|
|
||||||
+
|
|
||||||
+ // We can't just strip out display, leather helmets still use the display.color tag.
|
|
||||||
+ copy.remove(DataComponents.CUSTOM_NAME);
|
|
||||||
+ copy.remove(DataComponents.ITEM_NAME);
|
|
||||||
+ copy.remove(DataComponents.LORE);
|
|
||||||
+ copy.remove(DataComponents.RARITY); // affects name only
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+ ItemEnchantments enchantments = copy.getEnchantments();
|
|
||||||
+ if (!enchantments.isEmpty()) {
|
|
||||||
+ ItemEnchantments.Mutable mutableEnchantments = new ItemEnchantments.Mutable(ItemEnchantments.EMPTY);
|
|
||||||
+ if (EnchantmentHelper.getItemEnchantmentLevel(Enchantments.SOUL_SPEED, itemStack) > 0) {
|
|
||||||
+ mutableEnchantments.set(Enchantments.SOUL_SPEED, 1);
|
|
||||||
+ }
|
|
||||||
+ if (mutableEnchantments.keySet().isEmpty()) {
|
|
||||||
+ copy.set(DataComponents.ENCHANTMENT_GLINT_OVERRIDE, true); // Add a glint override if there are no enchantments present-- this is so we still get a fake glow
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ copy.set(DataComponents.ENCHANTMENTS, mutableEnchantments.toImmutable());
|
|
||||||
+ }
|
|
||||||
+ copy.remove(DataComponents.ATTRIBUTE_MODIFIERS);
|
|
||||||
+ copy.remove(DataComponents.UNBREAKABLE);
|
|
||||||
+ copy.remove(DataComponents.CUSTOM_DATA); // Persistent data container (remove everything)
|
|
||||||
+
|
|
||||||
+ // Books
|
|
||||||
+ copy.remove(DataComponents.WRITABLE_BOOK_CONTENT);
|
|
||||||
+ copy.remove(DataComponents.WRITTEN_BOOK_CONTENT);
|
|
||||||
+
|
|
||||||
+ // Filled maps
|
|
||||||
+ copy.remove(DataComponents.MAP_ID);
|
|
||||||
+ copy.remove(DataComponents.MAP_POST_PROCESSING);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (level.paperConfig().anticheat.obfuscation.items.hideItemmetaWithVisualEffects) {
|
|
||||||
+ // Lodestone compasses
|
|
||||||
+ copy.remove(DataComponents.LODESTONE_TRACKER);
|
|
||||||
+ copy.set(DataComponents.ENCHANTMENT_GLINT_OVERRIDE, true); // override the glint -- simulate
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ return copy;
|
|
||||||
+ }
|
|
||||||
+ // Paper end - Hide unnecessary item meta
|
|
||||||
+ // Paper start - prevent oversized data
|
|
||||||
+ public static ItemStack sanitizeItemStack(final ItemStack itemStack, final boolean copyItemStack) {
|
|
||||||
+ if (itemStack.isEmpty() || itemStack.getComponentsPatch().isEmpty()) {
|
|
||||||
+ return itemStack;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ final ItemStack copy = copyItemStack ? itemStack.copy() : itemStack;
|
|
||||||
+ final DataComponentMap components = copy.getComponents();
|
|
||||||
+
|
|
||||||
+ final BundleContents contents = components.get(DataComponents.BUNDLE_CONTENTS);
|
|
||||||
+ if (copy.is(Items.BUNDLE) && contents != null && !contents.isEmpty()) {
|
|
||||||
+ // Bundles change their texture based on their fullness.
|
|
||||||
+ // TODO: Check this
|
|
||||||
+ int sizeUsed = 0;
|
|
||||||
+ for (ItemStack item : contents.items()) {
|
|
||||||
+ int scale = 64 / item.getMaxStackSize();
|
|
||||||
+ sizeUsed += scale * item.getCount();
|
|
||||||
+ }
|
|
||||||
+ // Now we add a single fake item that uses the same amount of slots as all other items.
|
|
||||||
+ copy.set(DataComponents.BUNDLE_CONTENTS, new BundleContents(List.of(new ItemStack(Items.PAPER, sizeUsed))));
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+ CustomData blockEntityData = components.get(DataComponents.BLOCK_ENTITY_DATA);
|
|
||||||
+ copy.set(DataComponents.BLOCK_ENTITY_DATA, blockEntityData.update((tag) -> {
|
|
||||||
+ tag.remove("Items");
|
|
||||||
+ }));
|
|
||||||
+
|
|
||||||
+ return copy;
|
|
||||||
+ }
|
|
||||||
+ // Paper end - prevent oversized data
|
|
||||||
+}
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/level/ServerEntity.java b/src/main/java/net/minecraft/server/level/ServerEntity.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/net/minecraft/server/level/ServerEntity.java
|
|
||||||
+++ b/src/main/java/net/minecraft/server/level/ServerEntity.java
|
|
||||||
@@ -0,0 +0,0 @@ public class ServerEntity {
|
|
||||||
ItemStack itemstack = ((LivingEntity) this.entity).getItemBySlot(enumitemslot);
|
|
||||||
|
|
||||||
if (!itemstack.isEmpty()) {
|
|
||||||
- list.add(Pair.of(enumitemslot, itemstack.copy()));
|
|
||||||
+ // Paper start - prevent oversized data
|
|
||||||
+ final ItemStack sanitized = io.papermc.paper.util.ItemStackObfuscator.sanitizeItemStack(itemstack.copy(), false);
|
|
||||||
+ list.add(Pair.of(enumitemslot, io.papermc.paper.util.ItemStackObfuscator.stripMeta(sanitized, false, this.level))); // Paper - Hide unnecessary item meta
|
|
||||||
+ // Paper end - prevent oversized data
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
|
||||||
+++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
|
||||||
@@ -0,0 +0,0 @@ public class ServerGamePacketListenerImpl extends ServerCommonPacketListenerImpl
|
|
||||||
// Refresh the current entity metadata
|
|
||||||
entity.refreshEntityData(ServerGamePacketListenerImpl.this.player);
|
|
||||||
// SPIGOT-7136 - Allays
|
|
||||||
- if (entity instanceof Allay) {
|
|
||||||
- ServerGamePacketListenerImpl.this.send(new ClientboundSetEquipmentPacket(entity.getId(), Arrays.stream(net.minecraft.world.entity.EquipmentSlot.values()).map((slot) -> Pair.of(slot, ((LivingEntity) entity).getItemBySlot(slot).copy())).collect(Collectors.toList())));
|
|
||||||
+ if (entity instanceof Allay allay) { // Paper - Hide unnecessary item meta
|
|
||||||
+ ServerGamePacketListenerImpl.this.send(new ClientboundSetEquipmentPacket(entity.getId(), Arrays.stream(net.minecraft.world.entity.EquipmentSlot.values()).map((slot) -> Pair.of(slot, io.papermc.paper.util.ItemStackObfuscator.stripMeta(allay.getItemBySlot(slot), true, allay.level()))).collect(Collectors.toList()))); // Paper - Hide unnecessary item meta
|
|
||||||
ServerGamePacketListenerImpl.this.player.containerMenu.sendAllDataToRemote();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
diff --git a/src/main/java/net/minecraft/world/entity/LivingEntity.java b/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
|
||||||
+++ b/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
|
||||||
@@ -0,0 +0,0 @@ public abstract class LivingEntity extends Entity implements Attackable {
|
|
||||||
equipmentChanges.forEach((enumitemslot, itemstack) -> {
|
|
||||||
ItemStack itemstack1 = itemstack.copy();
|
|
||||||
|
|
||||||
- list.add(Pair.of(enumitemslot, itemstack1));
|
|
||||||
+ // Paper start - prevent oversized data
|
|
||||||
+ ItemStack toSend = io.papermc.paper.util.ItemStackObfuscator.sanitizeItemStack(itemstack1, true);
|
|
||||||
+ list.add(Pair.of(enumitemslot, io.papermc.paper.util.ItemStackObfuscator.stripMeta(toSend, toSend == itemstack1, this.level()))); // Paper - Hide unnecessary item meta
|
|
||||||
+ // Paper end - prevent oversized data
|
|
||||||
switch (enumitemslot.getType()) {
|
|
||||||
case HAND:
|
|
||||||
this.setLastHandItem(enumitemslot, itemstack1);
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user