2020-04-19 10:01:07 +00:00
|
|
|
From a6b5edccaf9bf86cd8c10cfa0156902839a41c93 Mon Sep 17 00:00:00 2001
|
2016-12-27 20:06:14 +00:00
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Tue, 27 Dec 2016 15:02:42 -0500
|
|
|
|
Subject: [PATCH] String based Action Bar API
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/MCUtil.java b/src/main/java/net/minecraft/server/MCUtil.java
|
2020-04-19 10:01:07 +00:00
|
|
|
index 9fb9a96ccb..48f88eaba4 100644
|
2016-12-27 20:06:14 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/MCUtil.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/MCUtil.java
|
2018-09-03 23:59:54 +00:00
|
|
|
@@ -2,6 +2,7 @@ package net.minecraft.server;
|
2016-12-27 20:06:14 +00:00
|
|
|
|
2018-09-03 23:59:54 +00:00
|
|
|
import com.destroystokyo.paper.block.TargetBlockInfo;
|
2016-12-27 20:06:14 +00:00
|
|
|
import com.google.common.util.concurrent.ThreadFactoryBuilder;
|
|
|
|
+import org.apache.commons.lang.exception.ExceptionUtils;
|
|
|
|
import org.bukkit.Location;
|
2018-09-03 23:59:54 +00:00
|
|
|
import org.bukkit.block.BlockFace;
|
|
|
|
import org.bukkit.craftbukkit.CraftWorld;
|
2020-04-19 10:01:07 +00:00
|
|
|
@@ -122,6 +123,24 @@ public final class MCUtil {
|
2016-12-27 20:06:14 +00:00
|
|
|
|
|
|
|
private MCUtil() {}
|
|
|
|
|
|
|
|
+ /**
|
|
|
|
+ * Quickly generate a stack trace for current location
|
|
|
|
+ *
|
|
|
|
+ * @return Stacktrace
|
|
|
|
+ */
|
|
|
|
+ public static String stack() {
|
|
|
|
+ return ExceptionUtils.getFullStackTrace(new Throwable());
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Quickly generate a stack trace for current location with message
|
|
|
|
+ *
|
|
|
|
+ * @param str
|
|
|
|
+ * @return Stacktrace
|
|
|
|
+ */
|
|
|
|
+ public static String stack(String str) {
|
|
|
|
+ return ExceptionUtils.getFullStackTrace(new Throwable(str));
|
|
|
|
+ }
|
|
|
|
|
2018-07-22 04:45:49 +00:00
|
|
|
public static boolean isMainThread() {
|
|
|
|
return MinecraftServer.getServer().isMainThread();
|
2016-12-27 20:06:14 +00:00
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
2020-04-19 10:01:07 +00:00
|
|
|
index 060a21840f..d1745c4e93 100644
|
2016-12-27 20:06:14 +00:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
2020-04-08 07:49:15 +00:00
|
|
|
@@ -216,6 +216,18 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
|
2018-03-10 13:07:40 +00:00
|
|
|
}
|
2016-12-27 20:06:14 +00:00
|
|
|
|
|
|
|
// Paper start
|
2018-03-10 13:07:40 +00:00
|
|
|
+ @Override
|
2016-12-27 20:06:14 +00:00
|
|
|
+ public void sendActionBar(String message) {
|
|
|
|
+ if (getHandle().playerConnection == null || message == null || message.isEmpty()) return;
|
2018-07-19 04:42:43 +00:00
|
|
|
+ getHandle().playerConnection.sendPacket(new PacketPlayOutChat(new net.minecraft.server.ChatComponentText(message), net.minecraft.server.ChatMessageType.GAME_INFO));
|
2016-12-27 20:06:14 +00:00
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public void sendActionBar(char alternateChar, String message) {
|
|
|
|
+ if (message == null || message.isEmpty()) return;
|
|
|
|
+ sendActionBar(org.bukkit.ChatColor.translateAlternateColorCodes(alternateChar, message));
|
|
|
|
+ }
|
|
|
|
+
|
2018-03-10 13:07:40 +00:00
|
|
|
@Override
|
2016-12-27 20:06:14 +00:00
|
|
|
public void setPlayerListHeaderFooter(BaseComponent[] header, BaseComponent[] footer) {
|
2018-09-01 10:09:13 +00:00
|
|
|
if (header != null) {
|
2016-12-27 20:06:14 +00:00
|
|
|
--
|
2020-04-19 10:01:07 +00:00
|
|
|
2.25.1
|
2016-12-27 20:06:14 +00:00
|
|
|
|