Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
3b2b835
commit 425edfa
Showing
4 changed files
with
260 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,96 @@ | ||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 | ||
From: Jake Potrebic <jake.m.potrebic@gmail.com> | ||
Date: Fri, 28 May 2021 21:47:39 -0700 | ||
Subject: [PATCH] More CommandBlock API | ||
|
||
|
||
diff --git a/src/main/java/io/papermc/paper/command/CommandBlockHolder.java b/src/main/java/io/papermc/paper/command/CommandBlockHolder.java | ||
new file mode 100644 | ||
index 0000000000000000000000000000000000000000..09e57f495e3cbf3c6f434d12ab34830862faeb88 | ||
--- /dev/null | ||
+++ b/src/main/java/io/papermc/paper/command/CommandBlockHolder.java | ||
@@ -0,0 +1,58 @@ | ||
+package io.papermc.paper.command; | ||
+ | ||
+import net.kyori.adventure.text.Component; | ||
+import org.jetbrains.annotations.NotNull; | ||
+import org.jetbrains.annotations.Nullable; | ||
+ | ||
+public interface CommandBlockHolder { | ||
+ | ||
+ /** | ||
+ * Gets the command that this CommandBlock will run when powered. | ||
+ * This will never return null. If the CommandBlock does not have a | ||
+ * command, an empty String will be returned instead. | ||
+ * | ||
+ * @return Command that this CommandBlock will run when activated. | ||
+ */ | ||
+ @NotNull | ||
+ String getCommand(); | ||
+ | ||
+ /** | ||
+ * Sets the command that this CommandBlock will run when powered. | ||
+ * Setting the command to null is the same as setting it to an empty | ||
+ * String. | ||
+ * | ||
+ * @param command Command that this CommandBlock will run when activated. | ||
+ */ | ||
+ void setCommand(@Nullable String command); | ||
+ | ||
+ /** | ||
+ * Gets the last output from this command block. | ||
+ * | ||
+ * @return the last output | ||
+ */ | ||
+ @NotNull | ||
+ Component lastOutput(); | ||
+ | ||
+ /** | ||
+ * Sets the last output from this command block. | ||
+ * | ||
+ * @param lastOutput the last output | ||
+ */ | ||
+ void lastOutput(@Nullable Component lastOutput); | ||
+ | ||
+ /** | ||
+ * Gets the success count from this command block. | ||
+ * @see <a href="https://minecraft.fandom.com/wiki/Command_Block#Success_count">Command_Block#Success_count</a> | ||
+ * | ||
+ * @return the success count | ||
+ */ | ||
+ int getSuccessCount(); | ||
+ | ||
+ /** | ||
+ * Sets the success count from this command block. | ||
+ * @see <a href="https://minecraft.fandom.com/wiki/Command_Block#Success_count">Command_Block#Success_count</a> | ||
+ * | ||
+ * @param successCount the success count | ||
+ */ | ||
+ void setSuccessCount(int successCount); | ||
+} | ||
diff --git a/src/main/java/org/bukkit/block/CommandBlock.java b/src/main/java/org/bukkit/block/CommandBlock.java | ||
index 73dce588d1f7a5048300073bf8c2b14d6da1e857..d63da691fb8cfa04bb699adb2eb55278e8b76200 100644 | ||
--- a/src/main/java/org/bukkit/block/CommandBlock.java | ||
+++ b/src/main/java/org/bukkit/block/CommandBlock.java | ||
@@ -6,7 +6,7 @@ import org.jetbrains.annotations.Nullable; | ||
/** | ||
* Represents a captured state of a command block. | ||
*/ | ||
-public interface CommandBlock extends TileState { | ||
+public interface CommandBlock extends TileState, io.papermc.paper.command.CommandBlockHolder { // Paper | ||
|
||
/** | ||
* Gets the command that this CommandBlock will run when powered. | ||
diff --git a/src/main/java/org/bukkit/entity/minecart/CommandMinecart.java b/src/main/java/org/bukkit/entity/minecart/CommandMinecart.java | ||
index 91cab8b13d5bba34007f124838b32a1df58c5ac7..6a6021ad3a0e6aaf51f5144fa126e81bada9cfcf 100644 | ||
--- a/src/main/java/org/bukkit/entity/minecart/CommandMinecart.java | ||
+++ b/src/main/java/org/bukkit/entity/minecart/CommandMinecart.java | ||
@@ -4,7 +4,7 @@ import org.bukkit.entity.Minecart; | ||
import org.jetbrains.annotations.NotNull; | ||
import org.jetbrains.annotations.Nullable; | ||
|
||
-public interface CommandMinecart extends Minecart { | ||
+public interface CommandMinecart extends Minecart, io.papermc.paper.command.CommandBlockHolder { // Paper | ||
|
||
/** | ||
* Gets the command that this CommandMinecart will run when activated. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,100 @@ | ||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 | ||
From: Jake Potrebic <jake.m.potrebic@gmail.com> | ||
Date: Thu, 23 Sep 2021 10:40:09 -0700 | ||
Subject: [PATCH] More CommmandBlock API | ||
|
||
|
||
diff --git a/src/main/java/io/papermc/paper/commands/PaperCommandBlockHolder.java b/src/main/java/io/papermc/paper/commands/PaperCommandBlockHolder.java | ||
new file mode 100644 | ||
index 0000000000000000000000000000000000000000..0b42306f17bf8850a13a51067c2d19e7583187e5 | ||
--- /dev/null | ||
+++ b/src/main/java/io/papermc/paper/commands/PaperCommandBlockHolder.java | ||
@@ -0,0 +1,33 @@ | ||
+package io.papermc.paper.commands; | ||
+ | ||
+import io.papermc.paper.adventure.PaperAdventure; | ||
+import io.papermc.paper.command.CommandBlockHolder; | ||
+import net.kyori.adventure.text.Component; | ||
+import net.minecraft.world.level.BaseCommandBlock; | ||
+import org.jetbrains.annotations.NotNull; | ||
+import org.jetbrains.annotations.Nullable; | ||
+ | ||
+public interface PaperCommandBlockHolder extends CommandBlockHolder { | ||
+ | ||
+ BaseCommandBlock getCommandBlockHandle(); | ||
+ | ||
+ @Override | ||
+ default @NotNull Component lastOutput() { | ||
+ return PaperAdventure.asAdventure(getCommandBlockHandle().getLastOutput()); | ||
+ } | ||
+ | ||
+ @Override | ||
+ default void lastOutput(@Nullable Component lastOutput) { | ||
+ getCommandBlockHandle().setLastOutput(PaperAdventure.asVanilla(lastOutput)); | ||
+ } | ||
+ | ||
+ @Override | ||
+ default int getSuccessCount() { | ||
+ return getCommandBlockHandle().getSuccessCount(); | ||
+ } | ||
+ | ||
+ @Override | ||
+ default void setSuccessCount(int successCount) { | ||
+ getCommandBlockHandle().setSuccessCount(successCount); | ||
+ } | ||
+} | ||
diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftCommandBlock.java b/src/main/java/org/bukkit/craftbukkit/block/CraftCommandBlock.java | ||
index c7af598a039f0d41aa4d1943714ed06986828c2a..ed10b13b29880459d68b6a7a60a5a9e1e1107d71 100644 | ||
--- a/src/main/java/org/bukkit/craftbukkit/block/CraftCommandBlock.java | ||
+++ b/src/main/java/org/bukkit/craftbukkit/block/CraftCommandBlock.java | ||
@@ -6,7 +6,7 @@ import org.bukkit.block.Block; | ||
import org.bukkit.block.CommandBlock; | ||
import org.bukkit.craftbukkit.util.CraftChatMessage; | ||
|
||
-public class CraftCommandBlock extends CraftBlockEntityState<CommandBlockEntity> implements CommandBlock { | ||
+public class CraftCommandBlock extends CraftBlockEntityState<CommandBlockEntity> implements CommandBlock, io.papermc.paper.commands.PaperCommandBlockHolder { | ||
|
||
public CraftCommandBlock(Block block) { | ||
super(block, CommandBlockEntity.class); | ||
@@ -46,5 +46,10 @@ public class CraftCommandBlock extends CraftBlockEntityState<CommandBlockEntity> | ||
public void name(net.kyori.adventure.text.Component name) { | ||
getSnapshot().getCommandBlock().setName(name == null ? new net.minecraft.network.chat.TextComponent("@") : io.papermc.paper.adventure.PaperAdventure.asVanilla(name)); | ||
} | ||
+ | ||
+ @Override | ||
+ public net.minecraft.world.level.BaseCommandBlock getCommandBlockHandle() { | ||
+ return getSnapshot().getCommandBlock(); | ||
+ } | ||
// Paper end | ||
} | ||
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecartCommand.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecartCommand.java | ||
index f9863e138994f6c7a7975a852f106faa96d52315..b709a1d909c189f60d0c3aa97b4b96623e7c1db0 100644 | ||
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecartCommand.java | ||
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftMinecartCommand.java | ||
@@ -14,7 +14,7 @@ import org.bukkit.permissions.PermissionAttachment; | ||
import org.bukkit.permissions.PermissionAttachmentInfo; | ||
import org.bukkit.plugin.Plugin; | ||
|
||
-public class CraftMinecartCommand extends CraftMinecart implements CommandMinecart { | ||
+public class CraftMinecartCommand extends CraftMinecart implements CommandMinecart, io.papermc.paper.commands.PaperCommandBlockHolder { | ||
private final PermissibleBase perm = new PermissibleBase(this); | ||
|
||
public CraftMinecartCommand(CraftServer server, MinecartCommandBlock entity) { | ||
@@ -70,6 +70,17 @@ public class CraftMinecartCommand extends CraftMinecart implements CommandMineca | ||
public net.kyori.adventure.text.@org.jetbrains.annotations.NotNull Component name() { | ||
return io.papermc.paper.adventure.PaperAdventure.asAdventure(this.getHandle().getCommandBlock().getName()); | ||
} | ||
+ | ||
+ @Override | ||
+ public net.minecraft.world.level.BaseCommandBlock getCommandBlockHandle() { | ||
+ return getHandle().getCommandBlock(); | ||
+ } | ||
+ | ||
+ @Override | ||
+ public void lastOutput(net.kyori.adventure.text.Component lastOutput) { | ||
+ io.papermc.paper.commands.PaperCommandBlockHolder.super.lastOutput(lastOutput); | ||
+ getCommandBlockHandle().onUpdated(); | ||
+ } | ||
// Paper end | ||
|
||
@Override |