From 03461857def0837ec1a4157a4d5973f74a31a1dd Mon Sep 17 00:00:00 2001 From: DmitriyMX Date: Fri, 12 May 2017 16:22:38 +0300 Subject: [PATCH] =?UTF-8?q?=D0=90=D0=B4=D0=B0=D0=BF=D1=82=D0=B5=D1=80=20QC?= =?UTF-8?q?onsole-Log4j2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- resources/log4j2.xml | 10 ++-- .../logger/log4j2/QConsoleAppender.java | 47 +++++++++++++++++++ 2 files changed, 54 insertions(+), 3 deletions(-) create mode 100644 src/lwjake2/logger/log4j2/QConsoleAppender.java diff --git a/resources/log4j2.xml b/resources/log4j2.xml index f86c176..2f274d3 100644 --- a/resources/log4j2.xml +++ b/resources/log4j2.xml @@ -1,16 +1,20 @@  - + - + - + + + + + diff --git a/src/lwjake2/logger/log4j2/QConsoleAppender.java b/src/lwjake2/logger/log4j2/QConsoleAppender.java new file mode 100644 index 0000000..aca5cee --- /dev/null +++ b/src/lwjake2/logger/log4j2/QConsoleAppender.java @@ -0,0 +1,47 @@ +/* + * DmitriyMX + * 2017-05-12 + */ +package lwjake2.logger.log4j2; + +import lwjake2.client.Console; +import org.apache.logging.log4j.core.Filter; +import org.apache.logging.log4j.core.Layout; +import org.apache.logging.log4j.core.LogEvent; +import org.apache.logging.log4j.core.appender.AbstractAppender; +import org.apache.logging.log4j.core.config.plugins.Plugin; +import org.apache.logging.log4j.core.config.plugins.PluginAttribute; +import org.apache.logging.log4j.core.config.plugins.PluginElement; +import org.apache.logging.log4j.core.config.plugins.PluginFactory; +import org.apache.logging.log4j.core.layout.PatternLayout; + +import java.io.Serializable; + +@Plugin(name = "QConsole", category = "Core", elementType = "appender", printObject = true) +public class QConsoleAppender extends AbstractAppender { + @PluginFactory + public static QConsoleAppender createAppender ( + @PluginAttribute("name") String name, + @PluginElement("Layout") Layout layout, + @PluginElement("Filter") final Filter filter + ) { + if (name == null) { + LOGGER.error("No name provided for QConsoleAppender"); + return null; + } + if (layout == null) { + layout = PatternLayout.createDefaultLayout(); + } + return new QConsoleAppender(name, filter, layout, true); + } + + protected QConsoleAppender(String name, Filter filter, Layout layout, boolean ignoreExceptions) { + super(name, filter, layout, ignoreExceptions); + } + + @Override + public void append(LogEvent event) { + String msg = new String(getLayout().toByteArray(event)); + Console.Print(msg+"\n"); + } +}