mirror of
https://github.com/YatopiaMC/Yatopia.git
synced 2025-01-03 23:17:37 +01:00
commit
1bc6b25f42
@ -1,7 +1,7 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
From: Bud Gidiere <sgidiere@gmail.com>
|
From: Bud Gidiere <sgidiere@gmail.com>
|
||||||
Date: Sat, 1 Aug 2020 15:55:15 -0500
|
Date: Sat, 1 Aug 2020 15:55:15 -0500
|
||||||
Subject: [PATCH] Add NBT API as first class lib
|
Subject: [PATCH] Add NBT API as a first class lib
|
||||||
|
|
||||||
|
|
||||||
diff --git a/pom.xml b/pom.xml
|
diff --git a/pom.xml b/pom.xml
|
||||||
@ -46,95 +46,98 @@ index 3a49ca4b8af1c9715cda8efde3d09efef92354fe..9338a6a97d9ac2ce010928ffe330fc79
|
|||||||
</plugin>
|
</plugin>
|
||||||
<plugin>
|
<plugin>
|
||||||
diff --git a/src/main/java/org/bukkit/block/TileState.java b/src/main/java/org/bukkit/block/TileState.java
|
diff --git a/src/main/java/org/bukkit/block/TileState.java b/src/main/java/org/bukkit/block/TileState.java
|
||||||
index 3b10fcc13893403b29f0260b8605144679e89b82..8e56171795cb9110fa10f5cd98083abc30e67b41 100644
|
index 3b10fcc13893403b29f0260b8605144679e89b82..1e9a96d8b08cc396acf73dc42083009354e89d8a 100644
|
||||||
--- a/src/main/java/org/bukkit/block/TileState.java
|
--- a/src/main/java/org/bukkit/block/TileState.java
|
||||||
+++ b/src/main/java/org/bukkit/block/TileState.java
|
+++ b/src/main/java/org/bukkit/block/TileState.java
|
||||||
@@ -4,6 +4,8 @@ import org.bukkit.persistence.PersistentDataContainer;
|
@@ -36,4 +36,26 @@ public interface TileState extends BlockState, PersistentDataHolder {
|
||||||
import org.bukkit.persistence.PersistentDataHolder;
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
|
|
||||||
+import de.tr7zw.changeme.nbtapi.NBTTileEntity;
|
|
||||||
+
|
|
||||||
/**
|
|
||||||
* Represents a block state that also hosts a tile entity at the given location.
|
|
||||||
*
|
|
||||||
@@ -36,4 +38,12 @@ public interface TileState extends BlockState, PersistentDataHolder {
|
|
||||||
@NotNull
|
@NotNull
|
||||||
@Override
|
@Override
|
||||||
PersistentDataContainer getPersistentDataContainer();
|
PersistentDataContainer getPersistentDataContainer();
|
||||||
+
|
+
|
||||||
+ // Yatopia start
|
+ // Yatopia start
|
||||||
+
|
+ /**
|
||||||
+ public default NBTTileEntity getNBT() {
|
+ * Returns NBT representation of this tile entity.
|
||||||
+ return new NBTTileEntity(this);
|
+ *
|
||||||
|
+ * @return vanilla NBT tags container
|
||||||
|
+ */
|
||||||
|
+ @NotNull
|
||||||
|
+ default de.tr7zw.changeme.nbtapi.NBTTileEntity getNBT() {
|
||||||
|
+ return new de.tr7zw.changeme.nbtapi.NBTTileEntity(this);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
|
+ /**
|
||||||
|
+ * Returns a custom tag container of this tile entity.
|
||||||
|
+ *
|
||||||
|
+ * @return custom NBT tags container
|
||||||
|
+ */
|
||||||
|
+ @NotNull
|
||||||
|
+ default de.tr7zw.changeme.nbtapi.NBTCompound getNBTC() {
|
||||||
|
+ return getNBT().getPersistentDataContainer();
|
||||||
|
+ }
|
||||||
+ // Yatopia end
|
+ // Yatopia end
|
||||||
}
|
}
|
||||||
diff --git a/src/main/java/org/bukkit/entity/Entity.java b/src/main/java/org/bukkit/entity/Entity.java
|
diff --git a/src/main/java/org/bukkit/entity/Entity.java b/src/main/java/org/bukkit/entity/Entity.java
|
||||||
index 7808ade92ccd3553056c57cdf77464fb8bdf9312..7ee13b985d1e408593a84825531e457e9fbcc4b0 100644
|
index 7808ade92ccd3553056c57cdf77464fb8bdf9312..801815e64bb281dbd480258db24a36892f485990 100644
|
||||||
--- a/src/main/java/org/bukkit/entity/Entity.java
|
--- a/src/main/java/org/bukkit/entity/Entity.java
|
||||||
+++ b/src/main/java/org/bukkit/entity/Entity.java
|
+++ b/src/main/java/org/bukkit/entity/Entity.java
|
||||||
@@ -23,6 +23,9 @@ import org.jetbrains.annotations.Contract;
|
@@ -695,4 +695,26 @@ public interface Entity extends Metadatable, CommandSender, Nameable, Persistent
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
import org.jetbrains.annotations.Nullable;
|
|
||||||
|
|
||||||
+import de.tr7zw.changeme.nbtapi.NBTCompound;
|
|
||||||
+import de.tr7zw.changeme.nbtapi.NBTEntity;
|
|
||||||
+
|
|
||||||
/**
|
|
||||||
* Represents a base entity in the world
|
|
||||||
*/
|
|
||||||
@@ -695,4 +698,16 @@ public interface Entity extends Metadatable, CommandSender, Nameable, Persistent
|
|
||||||
*/
|
*/
|
||||||
public boolean isInLava();
|
public boolean isInLava();
|
||||||
// Paper end
|
// Paper end
|
||||||
+
|
+
|
||||||
+ // Yatopia start
|
+ // Yatopia start
|
||||||
+
|
+ /**
|
||||||
+ public default NBTEntity getNBT() {
|
+ * Returns NBT representation of this entity.
|
||||||
+ return new NBTEntity(this);
|
+ *
|
||||||
|
+ * @return vanilla NBT tags container
|
||||||
|
+ */
|
||||||
|
+ @NotNull
|
||||||
|
+ default de.tr7zw.changeme.nbtapi.NBTEntity getNBT() {
|
||||||
|
+ return new de.tr7zw.changeme.nbtapi.NBTEntity(this);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ public default NBTCompound getNBTC() {
|
+ /**
|
||||||
+ return getNBT().getPersistentDataContainer();
|
+ * Returns a custom tag container of this entity.
|
||||||
|
+ *
|
||||||
|
+ * @return custom NBT tags container
|
||||||
|
+ */
|
||||||
|
+ @NotNull
|
||||||
|
+ default de.tr7zw.changeme.nbtapi.NBTCompound getNBTC() {
|
||||||
|
+ return getNBT().getPersistentDataContainer();
|
||||||
+ }
|
+ }
|
||||||
+
|
|
||||||
+ // Yatopia end
|
+ // Yatopia end
|
||||||
}
|
}
|
||||||
diff --git a/src/main/java/org/bukkit/inventory/ItemStack.java b/src/main/java/org/bukkit/inventory/ItemStack.java
|
diff --git a/src/main/java/org/bukkit/inventory/ItemStack.java b/src/main/java/org/bukkit/inventory/ItemStack.java
|
||||||
index ccd81fca25233c2a9c2a8c3f4dda3053d7b2e723..802e6c620c831a7187fc52841c110c2934ab8d1b 100644
|
index ccd81fca25233c2a9c2a8c3f4dda3053d7b2e723..b93df6bea4af1b2d4123be031adecf030bcc3893 100644
|
||||||
--- a/src/main/java/org/bukkit/inventory/ItemStack.java
|
--- a/src/main/java/org/bukkit/inventory/ItemStack.java
|
||||||
+++ b/src/main/java/org/bukkit/inventory/ItemStack.java
|
+++ b/src/main/java/org/bukkit/inventory/ItemStack.java
|
||||||
@@ -1,6 +1,10 @@
|
@@ -791,4 +791,29 @@ public class ItemStack implements Cloneable, ConfigurationSerializable {
|
||||||
package org.bukkit.inventory;
|
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableMap;
|
|
||||||
+
|
|
||||||
+import de.tr7zw.changeme.nbtapi.NBTItem;
|
|
||||||
+import de.tr7zw.changeme.nbtapi.NBTType;
|
|
||||||
+
|
|
||||||
import java.util.LinkedHashMap;
|
|
||||||
import java.util.List; // Paper
|
|
||||||
import java.util.Map;
|
|
||||||
@@ -791,4 +795,20 @@ public class ItemStack implements Cloneable, ConfigurationSerializable {
|
|
||||||
return itemMeta.hasItemFlag(flag);
|
return itemMeta.hasItemFlag(flag);
|
||||||
}
|
}
|
||||||
// Paper end
|
// Paper end
|
||||||
+
|
+
|
||||||
+ // Yatopia start
|
+ // Yatopia start
|
||||||
+
|
+ /**
|
||||||
+ public NBTItem getNBT() {
|
+ * Returns NBT representation of this item.
|
||||||
+ return new NBTItem(this);
|
+ *
|
||||||
|
+ * @return item's NBT tags container
|
||||||
|
+ */
|
||||||
|
+ @NotNull
|
||||||
|
+ public de.tr7zw.changeme.nbtapi.NBTItem getNBT() {
|
||||||
|
+ return new de.tr7zw.changeme.nbtapi.NBTItem(this);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ public void setNBT(NBTItem nbt) {
|
+ /**
|
||||||
+ ItemStack nbtItem = nbt.getItem();
|
+ * Applies NBT data from the provided NBT item.
|
||||||
+ setType(nbtItem.getType());
|
+ *
|
||||||
+ setAmount(nbtItem.getAmount());
|
+ * @param nbt ItemStack's NBT container
|
||||||
+ setData(nbtItem.getData());
|
+ */
|
||||||
+ setItemMeta(nbtItem.getItemMeta());
|
+ public void setNBT(@NotNull de.tr7zw.changeme.nbtapi.NBTItem nbt) {
|
||||||
|
+ ItemStack nbtItem = nbt.getItem();
|
||||||
|
+ setType(nbtItem.getType());
|
||||||
|
+ setAmount(nbtItem.getAmount());
|
||||||
|
+ setData(nbtItem.getData());
|
||||||
|
+ setItemMeta(nbtItem.getItemMeta());
|
||||||
+ }
|
+ }
|
||||||
+
|
|
||||||
+ // Yatopia end
|
+ // Yatopia end
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user