Mostly fixed chat formatting #60
2 changed files with 52 additions and 32 deletions
|
@ -2,6 +2,7 @@ package buttondevteam.chat;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
|
@ -46,6 +47,39 @@ public class ChatProcessing {
|
||||||
"dark_purple" }; // TODO
|
"dark_purple" }; // TODO
|
||||||
private static boolean pingedconsole = false;
|
private static boolean pingedconsole = false;
|
||||||
|
|
||||||
|
private static ArrayList<ChatFormatter> commonFormatters = new ArrayList<>();
|
||||||
|
|
||||||
|
public static final ChatFormatter ESCAPE_FORMATTER = new ChatFormatterBuilder().setRegex(ESCAPE_PATTERN)
|
||||||
|
.setRemoveCharPos((short) 0).build();
|
||||||
|
|
||||||
|
private ChatProcessing() {
|
||||||
|
}
|
||||||
|
|
||||||
|
static {
|
||||||
|
commonFormatters.add(new ChatFormatterBuilder().setRegex(BOLD_PATTERN).setFormat(Format.Bold)
|
||||||
|
.setRemoveCharCount((short) 2).build());
|
||||||
|
commonFormatters.add(new ChatFormatterBuilder().setRegex(ITALIC_PATTERN).setFormat(Format.Italic)
|
||||||
|
.setRemoveCharCount((short) 1).build());
|
||||||
|
commonFormatters.add(new ChatFormatterBuilder().setRegex(UNDERLINED_PATTERN).setFormat(Format.Underlined)
|
||||||
|
.setRemoveCharCount((short) 1).build());
|
||||||
|
commonFormatters.add(ESCAPE_FORMATTER);
|
||||||
|
// URLs + Rainbow text
|
||||||
|
commonFormatters.add(new ChatFormatterBuilder().setRegex(URL_PATTERN).setFormat(Format.Underlined)
|
||||||
|
.setOpenlink("$1").build());
|
||||||
|
commonFormatters.add(new ChatFormatterBuilder().setRegex(NULL_MENTION_PATTERN).setColor(Color.DarkRed).build()); // Properly added a bug as a feature
|
||||||
|
commonFormatters.add(new ChatFormatterBuilder().setRegex(CONSOLE_PING_PATTERN).setColor(Color.Aqua)
|
||||||
|
.setOnmatch((String match) -> {
|
||||||
|
if (!pingedconsole) {
|
||||||
|
System.out.print("\007");
|
||||||
|
pingedconsole = true; // Will set it to false in ProcessChat
|
||||||
|
}
|
||||||
|
return match;
|
||||||
|
}).setPriority(Priority.High).build());
|
||||||
|
|
||||||
|
commonFormatters.add(new ChatFormatterBuilder().setRegex(HASHTAG_PATTERN).setColor(Color.Blue)
|
||||||
|
.setOpenlink("https://twitter.com/hashtag/$1").setPriority(Priority.High).build());
|
||||||
|
}
|
||||||
|
|
||||||
// Returns e.setCancelled
|
// Returns e.setCancelled
|
||||||
public static boolean ProcessChat(Channel channel, CommandSender sender, String message) {
|
public static boolean ProcessChat(Channel channel, CommandSender sender, String message) {
|
||||||
long processstart = System.nanoTime();
|
long processstart = System.nanoTime();
|
||||||
|
@ -84,7 +118,8 @@ public class ChatProcessing {
|
||||||
}
|
}
|
||||||
Channel currentchannel = channel;
|
Channel currentchannel = channel;
|
||||||
|
|
||||||
ArrayList<ChatFormatter> formatters = new ArrayList<ChatFormatter>();
|
@SuppressWarnings("unchecked")
|
||||||
|
ArrayList<ChatFormatter> formatters = (ArrayList<ChatFormatter>) commonFormatters.clone();
|
||||||
|
|
||||||
Color colormode = currentchannel.color;
|
Color colormode = currentchannel.color;
|
||||||
if (mp != null && mp.OtherColorMode != null)
|
if (mp != null && mp.OtherColorMode != null)
|
||||||
|
@ -102,17 +137,6 @@ public class ChatProcessing {
|
||||||
|
|
||||||
String suggestmsg = formattedmessage;
|
String suggestmsg = formattedmessage;
|
||||||
|
|
||||||
formatters.add(new ChatFormatterBuilder().setRegex(BOLD_PATTERN).setFormat(Format.Bold)
|
|
||||||
.setRemoveCharCount((short) 2).build());
|
|
||||||
formatters.add(new ChatFormatterBuilder().setRegex(ITALIC_PATTERN).setFormat(Format.Italic)
|
|
||||||
.setRemoveCharCount((short) 1).build());
|
|
||||||
formatters.add(new ChatFormatterBuilder().setRegex(UNDERLINED_PATTERN).setFormat(Format.Underlined)
|
|
||||||
.setRemoveCharCount((short) 1).build());
|
|
||||||
formatters.add(new ChatFormatterBuilder().setRegex(ESCAPE_PATTERN).setRemoveCharPos((short) 0).build());
|
|
||||||
|
|
||||||
// URLs + Rainbow text
|
|
||||||
formatters.add(new ChatFormatterBuilder().setRegex(URL_PATTERN).setFormat(Format.Underlined).setOpenlink("$1")
|
|
||||||
.build());
|
|
||||||
if (PluginMain.GetPlayers().size() > 0) {
|
if (PluginMain.GetPlayers().size() > 0) {
|
||||||
StringBuilder namesb = new StringBuilder();
|
StringBuilder namesb = new StringBuilder();
|
||||||
namesb.append("(?i)(");
|
namesb.append("(?i)(");
|
||||||
|
@ -130,8 +154,6 @@ public class ChatProcessing {
|
||||||
nicksb.deleteCharAt(nicksb.length() - 1);
|
nicksb.deleteCharAt(nicksb.length() - 1);
|
||||||
nicksb.append(")");
|
nicksb.append(")");
|
||||||
|
|
||||||
formatters.add(new ChatFormatterBuilder().setRegex(NULL_MENTION_PATTERN).setColor(Color.DarkRed).build()); // Properly added a bug as a feature
|
|
||||||
|
|
||||||
formatters.add(new ChatFormatterBuilder().setRegex(Pattern.compile(namesb.toString())).setColor(Color.Aqua)
|
formatters.add(new ChatFormatterBuilder().setRegex(Pattern.compile(namesb.toString())).setColor(Color.Aqua)
|
||||||
.setOnmatch((String match) -> {
|
.setOnmatch((String match) -> {
|
||||||
Player p = Bukkit.getPlayer(match);
|
Player p = Bukkit.getPlayer(match);
|
||||||
|
@ -172,24 +194,7 @@ public class ChatProcessing {
|
||||||
}).setPriority(Priority.High).build());
|
}).setPriority(Priority.High).build());
|
||||||
}
|
}
|
||||||
|
|
||||||
pingedconsole = false;
|
pingedconsole = false; // Will set it to true onmatch (static constructor)
|
||||||
formatters.add(new ChatFormatterBuilder().setRegex(CONSOLE_PING_PATTERN).setColor(Color.Aqua)
|
|
||||||
.setOnmatch((String match) -> {
|
|
||||||
if (!pingedconsole) {
|
|
||||||
System.out.print("\007");
|
|
||||||
pingedconsole = true;
|
|
||||||
}
|
|
||||||
return match;
|
|
||||||
}).setPriority(Priority.High).build());
|
|
||||||
|
|
||||||
formatters.add(new ChatFormatterBuilder().setRegex(HASHTAG_PATTERN).setColor(Color.Blue)
|
|
||||||
.setOpenlink("https://twitter.com/hashtag/$1").setPriority(Priority.High).build());
|
|
||||||
|
|
||||||
/*
|
|
||||||
* if (!hadurls) { if (formattedmessage.matches("(?i).*" + Pattern.quote("@console") + ".*")) { formattedmessage = formattedmessage.replaceAll( "(?i)" + Pattern.quote("@console"),
|
|
||||||
* "§b@console§r"); formattedmessage = formattedmessage .replaceAll( "(?i)" + Pattern.quote("@console"), String.format(
|
|
||||||
* "\",\"color\":\"%s\"},{\"text\":\"§b@console§r\",\"color\":\"blue\"},{\"text\":\"" , colormode)); System.out.println("\007"); } }
|
|
||||||
*/
|
|
||||||
|
|
||||||
TellrawPart json = new TellrawPart("");
|
TellrawPart json = new TellrawPart("");
|
||||||
if (mp != null && mp.ChatOnly) {
|
if (mp != null && mp.ChatOnly) {
|
||||||
|
|
|
@ -2,11 +2,14 @@ package buttondevteam.chat.formatting;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
import buttondevteam.chat.ChatProcessing;
|
||||||
import buttondevteam.chat.commands.ucmds.admin.DebugCommand;
|
import buttondevteam.chat.commands.ucmds.admin.DebugCommand;
|
||||||
import buttondevteam.lib.chat.*;
|
import buttondevteam.lib.chat.*;
|
||||||
|
|
||||||
|
@ -62,8 +65,20 @@ public final class ChatFormatter {
|
||||||
return Integer.compare(s1.Start, s2.Start);
|
return Integer.compare(s1.Start, s2.Start);
|
||||||
});
|
});
|
||||||
List<FormattedSection> combined = new ArrayList<>();
|
List<FormattedSection> combined = new ArrayList<>();
|
||||||
|
Map<ChatFormatter, FormattedSection> nextSection = new HashMap<>();
|
||||||
|
boolean escaped = false;
|
||||||
for (int i = 0; i < sections.size(); i++) {
|
for (int i = 0; i < sections.size(); i++) {
|
||||||
// Set ending to -1 until closed with another 1 long "section" - only do this if IsRange is true
|
// Set ending to -1 until closed with another 1 long "section" - only do this if IsRange is true
|
||||||
|
final FormattedSection section = sections.get(i);
|
||||||
|
if (!section.IsRange) {
|
||||||
|
escaped = section.Formatters.contains(ChatProcessing.ESCAPE_FORMATTER);
|
||||||
|
continue; // TODO: Escape \ and check and fix escape logic
|
||||||
|
}
|
||||||
|
if (nextSection.containsKey(section.Formatters.get(0)) && !escaped) {
|
||||||
|
FormattedSection s = nextSection.remove(section.Formatters.get(0));
|
||||||
|
s.End = section.Start;
|
||||||
|
combined.add(s);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
for (int i = 0; i < sections.size(); i++) {
|
for (int i = 0; i < sections.size(); i++) {
|
||||||
FormattedSection section = sections.get(i);
|
FormattedSection section = sections.get(i);
|
||||||
|
|
Loading…
Reference in a new issue