mirror of
https://github.com/TotalFreedomMC/ZeroTelnetClient.git
synced 2025-01-10 17:17:58 +00:00
Improved error/warning ignore & coloring feature.
This commit is contained in:
parent
a6be8fb5a0
commit
e8c146bca3
3 changed files with 91 additions and 25 deletions
src/main/java/me/StevenLawson/BukkitTelnetClient
|
@ -5,7 +5,7 @@ import java.awt.Color;
|
||||||
public class BTC_ConsoleMessage
|
public class BTC_ConsoleMessage
|
||||||
{
|
{
|
||||||
private final String message;
|
private final String message;
|
||||||
private final Color color;
|
private Color color;
|
||||||
|
|
||||||
public BTC_ConsoleMessage(final String message)
|
public BTC_ConsoleMessage(final String message)
|
||||||
{
|
{
|
||||||
|
@ -28,4 +28,9 @@ public class BTC_ConsoleMessage
|
||||||
{
|
{
|
||||||
return color;
|
return color;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setColor(Color color)
|
||||||
|
{
|
||||||
|
this.color = color;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -53,18 +53,66 @@ public class BTC_MainPanel extends javax.swing.JFrame
|
||||||
this.setVisible(true);
|
this.setVisible(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
public final void writeToConsole(final BTC_ConsoleMessage message)
|
private final Queue<BTC_TelnetMessage> telnetErrorQueue = new LinkedList<>();
|
||||||
|
private boolean isQueueing = false;
|
||||||
|
|
||||||
|
private void flushTelnetErrorQueue()
|
||||||
|
{
|
||||||
|
BTC_TelnetMessage queuedMessage;
|
||||||
|
while ((queuedMessage = telnetErrorQueue.poll()) != null)
|
||||||
|
{
|
||||||
|
queuedMessage.setColor(Color.GRAY);
|
||||||
|
writeToConsoleImmediately(queuedMessage, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void writeToConsole(final BTC_ConsoleMessage message)
|
||||||
{
|
{
|
||||||
if (message.getMessage().isEmpty())
|
if (message.getMessage().isEmpty())
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (message instanceof BTC_TelnetMessage)
|
||||||
|
{
|
||||||
|
final BTC_TelnetMessage telnetMessage = (BTC_TelnetMessage) message;
|
||||||
|
|
||||||
|
if (telnetMessage.isInfoMessage())
|
||||||
|
{
|
||||||
|
isQueueing = false;
|
||||||
|
flushTelnetErrorQueue();
|
||||||
|
}
|
||||||
|
else if (telnetMessage.isErrorMessage() || isQueueing)
|
||||||
|
{
|
||||||
|
isQueueing = true;
|
||||||
|
telnetErrorQueue.add(telnetMessage);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isQueueing)
|
||||||
|
{
|
||||||
|
writeToConsoleImmediately(telnetMessage, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
isQueueing = false;
|
||||||
|
flushTelnetErrorQueue();
|
||||||
|
writeToConsoleImmediately(message, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void writeToConsoleImmediately(final BTC_ConsoleMessage message, final boolean isTelnetError)
|
||||||
|
{
|
||||||
SwingUtilities.invokeLater(new Runnable()
|
SwingUtilities.invokeLater(new Runnable()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public void run()
|
public void run()
|
||||||
{
|
{
|
||||||
|
if (isTelnetError && chkIgnoreErrors.isSelected())
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
final StyledDocument styledDocument = mainOutput.getStyledDocument();
|
final StyledDocument styledDocument = mainOutput.getStyledDocument();
|
||||||
|
|
||||||
int startLength = styledDocument.getLength();
|
int startLength = styledDocument.getLength();
|
||||||
|
|
|
@ -9,6 +9,9 @@ public class BTC_TelnetMessage extends BTC_ConsoleMessage
|
||||||
private static final Color PURPLE = new Color(128, 0, 128);
|
private static final Color PURPLE = new Color(128, 0, 128);
|
||||||
private static final Color DARK_GREEN = new Color(86, 130, 3);
|
private static final Color DARK_GREEN = new Color(86, 130, 3);
|
||||||
|
|
||||||
|
private static final Pattern ERROR_MESSAGE = Pattern.compile("^:\\[.+? (?:(WARN)|(ERROR))\\]: ");
|
||||||
|
private static final Pattern INFO_MESSAGE = Pattern.compile(PATTERN_PREFIX);
|
||||||
|
|
||||||
private final BTC_LogMessageType messageType;
|
private final BTC_LogMessageType messageType;
|
||||||
|
|
||||||
public BTC_TelnetMessage(String message)
|
public BTC_TelnetMessage(String message)
|
||||||
|
@ -22,6 +25,21 @@ public class BTC_TelnetMessage extends BTC_ConsoleMessage
|
||||||
return this.messageType;
|
return this.messageType;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isErrorMessage()
|
||||||
|
{
|
||||||
|
return ERROR_MESSAGE.matcher(this.getMessage()).find();
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isInfoMessage()
|
||||||
|
{
|
||||||
|
return INFO_MESSAGE.matcher(this.getMessage()).find();
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isType(final BTC_LogMessageType checkType)
|
||||||
|
{
|
||||||
|
return this.messageType == checkType;
|
||||||
|
}
|
||||||
|
|
||||||
public boolean skip()
|
public boolean skip()
|
||||||
{
|
{
|
||||||
final BTC_MainPanel mainPanel = BukkitTelnetClient.mainPanel;
|
final BTC_MainPanel mainPanel = BukkitTelnetClient.mainPanel;
|
||||||
|
@ -30,37 +48,36 @@ public class BTC_TelnetMessage extends BTC_ConsoleMessage
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mainPanel.getChkShowChatOnly().isSelected())
|
if (mainPanel.getChkShowChatOnly().isSelected())
|
||||||
{
|
{
|
||||||
switch (messageType)
|
if (!isType(BTC_LogMessageType.CHAT_MESSAGE)
|
||||||
|
&& !isType(BTC_LogMessageType.CSAY_MESSAGE)
|
||||||
|
&& !isType(BTC_LogMessageType.SAY_MESSAGE)
|
||||||
|
&& !isType(BTC_LogMessageType.ADMINSAY_MESSAGE))
|
||||||
{
|
{
|
||||||
case CHAT_MESSAGE:
|
|
||||||
case CSAY_MESSAGE:
|
|
||||||
case SAY_MESSAGE:
|
|
||||||
case ADMINSAY_MESSAGE:
|
|
||||||
return false;
|
return false;
|
||||||
default:
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (mainPanel.getChkIgnoreServerCommands().isSelected() && this.messageType == BTC_LogMessageType.ISSUED_SERVER_COMMAND)
|
|
||||||
|
if (mainPanel.getChkIgnoreServerCommands().isSelected() && this.messageType == BTC_LogMessageType.ISSUED_SERVER_COMMAND)
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else if (mainPanel.getChkIgnorePlayerCommands().isSelected() && this.messageType == BTC_LogMessageType.PLAYER_COMMAND)
|
|
||||||
|
if (mainPanel.getChkIgnorePlayerCommands().isSelected() && this.messageType == BTC_LogMessageType.PLAYER_COMMAND)
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else if (mainPanel.getChkIgnoreErrors().isSelected())
|
|
||||||
|
if (mainPanel.getChkIgnoreErrors().isSelected())
|
||||||
{
|
{
|
||||||
switch (this.messageType)
|
if (!isType(BTC_LogMessageType.CHAT_MESSAGE)
|
||||||
|
&& !isType(BTC_LogMessageType.CSAY_MESSAGE)
|
||||||
|
&& !isType(BTC_LogMessageType.SAY_MESSAGE)
|
||||||
|
&& !isType(BTC_LogMessageType.ADMINSAY_MESSAGE))
|
||||||
{
|
{
|
||||||
case ERROR_MESSAGE:
|
|
||||||
case STACK_TRACE:
|
|
||||||
case EXCEPTION_MESSAGE:
|
|
||||||
return false;
|
return false;
|
||||||
default:
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -93,11 +110,7 @@ public class BTC_TelnetMessage extends BTC_ConsoleMessage
|
||||||
PREPROCESS_COMMAND(PATTERN_PREFIX + "\\[PREPROCESS_COMMAND\\] ", DARK_GREEN),
|
PREPROCESS_COMMAND(PATTERN_PREFIX + "\\[PREPROCESS_COMMAND\\] ", DARK_GREEN),
|
||||||
//
|
//
|
||||||
ISSUED_SERVER_COMMAND(PATTERN_PREFIX + ".+? issued server command: "),
|
ISSUED_SERVER_COMMAND(PATTERN_PREFIX + ".+? issued server command: "),
|
||||||
PLAYER_COMMAND(PATTERN_PREFIX + "\\[PLAYER_COMMAND\\] "),
|
PLAYER_COMMAND(PATTERN_PREFIX + "\\[PLAYER_COMMAND\\] ");
|
||||||
//
|
|
||||||
ERROR_MESSAGE("^:\\[.+? (!?(WARN)|(ERROR))\\]: ", Color.LIGHT_GRAY),
|
|
||||||
EXCEPTION_MESSAGE("^[^\\[][^\\s]+: ", Color.LIGHT_GRAY),
|
|
||||||
STACK_TRACE("^\\t", Color.LIGHT_GRAY);
|
|
||||||
|
|
||||||
private final Pattern messagePattern;
|
private final Pattern messagePattern;
|
||||||
private final Color color;
|
private final Color color;
|
||||||
|
|
Loading…
Reference in a new issue