aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0717-Nameable-Banner-API.patch
diff options
context:
space:
mode:
Diffstat (limited to 'patches/server/0717-Nameable-Banner-API.patch')
-rw-r--r--patches/server/0717-Nameable-Banner-API.patch50
1 files changed, 50 insertions, 0 deletions
diff --git a/patches/server/0717-Nameable-Banner-API.patch b/patches/server/0717-Nameable-Banner-API.patch
new file mode 100644
index 0000000000..21ca7151b4
--- /dev/null
+++ b/patches/server/0717-Nameable-Banner-API.patch
@@ -0,0 +1,50 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Owen1212055 <[email protected]>
+Date: Thu, 7 Apr 2022 17:49:25 -0400
+Subject: [PATCH] Nameable Banner API
+
+
+diff --git a/src/main/java/net/minecraft/world/level/block/entity/BannerBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/BannerBlockEntity.java
+index 925608bfa9c848ed6285de5e35d60aa66e12004a..60c26076e7acf869fa0e20fdc14eeec341387d99 100644
+--- a/src/main/java/net/minecraft/world/level/block/entity/BannerBlockEntity.java
++++ b/src/main/java/net/minecraft/world/level/block/entity/BannerBlockEntity.java
+@@ -29,7 +29,7 @@ public class BannerBlockEntity extends BlockEntity implements Nameable {
+ public static final int MAX_PATTERNS = 6;
+ private static final String TAG_PATTERNS = "patterns";
+ @Nullable
+- private Component name;
++ public Component name; // Paper - public
+ public DyeColor baseColor;
+ private BannerPatternLayers patterns;
+
+diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftBanner.java b/src/main/java/org/bukkit/craftbukkit/block/CraftBanner.java
+index 26ae3fe910964193c7fb22b8b644d5c0476f8d3d..65a9213ce8197d50a58f94edfd60c25c2be848be 100644
+--- a/src/main/java/org/bukkit/craftbukkit/block/CraftBanner.java
++++ b/src/main/java/org/bukkit/craftbukkit/block/CraftBanner.java
+@@ -110,4 +110,26 @@ public class CraftBanner extends CraftBlockEntityState<BannerBlockEntity> implem
+ public CraftBanner copy(Location location) {
+ return new CraftBanner(this, location);
+ }
++
++ // Paper start
++ @Override
++ public net.kyori.adventure.text.Component customName() {
++ return io.papermc.paper.adventure.PaperAdventure.asAdventure(this.getSnapshot().getCustomName());
++ }
++
++ @Override
++ public void customName(net.kyori.adventure.text.Component customName) {
++ this.getSnapshot().name = io.papermc.paper.adventure.PaperAdventure.asVanilla(customName);
++ }
++
++ @Override
++ public String getCustomName() {
++ return net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer.legacySection().serializeOrNull(this.customName());
++ }
++
++ @Override
++ public void setCustomName(String name) {
++ this.customName(net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer.legacySection().deserializeOrNull(name));
++ }
++ // Paper end
+ }