Merge pull request #41 from SoSeDiK/nbt

Added a shortcut method
This commit is contained in:
tr7zw 2020-08-04 09:35:22 +02:00 committed by GitHub
commit 1bc6b25f42
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -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() { + /**
+ * Returns a custom tag container of this entity.
+ *
+ * @return custom NBT tags container
+ */
+ @NotNull
+ default de.tr7zw.changeme.nbtapi.NBTCompound getNBTC() {
+ return getNBT().getPersistentDataContainer(); + 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) { + /**
+ * Applies NBT data from the provided NBT item.
+ *
+ * @param nbt ItemStack's NBT container
+ */
+ public void setNBT(@NotNull de.tr7zw.changeme.nbtapi.NBTItem nbt) {
+ ItemStack nbtItem = nbt.getItem(); + ItemStack nbtItem = nbt.getItem();
+ setType(nbtItem.getType()); + setType(nbtItem.getType());
+ setAmount(nbtItem.getAmount()); + setAmount(nbtItem.getAmount());
+ setData(nbtItem.getData()); + setData(nbtItem.getData());
+ setItemMeta(nbtItem.getItemMeta()); + setItemMeta(nbtItem.getItemMeta());
+ } + }
+
+ // Yatopia end + // Yatopia end
} }