org.slf4j.impl.MufferoLoggerAdapter Maven / Gradle / Ivy
package org.slf4j.impl;
import net.rumati.logging.muffero.Priority;
import net.rumati.logging.muffero.Logger;
import org.slf4j.Marker;
import org.slf4j.helpers.FormattingTuple;
import org.slf4j.helpers.MarkerIgnoringBase;
import org.slf4j.helpers.MessageFormatter;
import org.slf4j.spi.LocationAwareLogger;
class MufferoLoggerAdapter
extends MarkerIgnoringBase
implements LocationAwareLogger
{
private static final String FQCN = MufferoLoggerAdapter.class.getName();
private final Logger log;
public MufferoLoggerAdapter(Logger log)
{
this.log = log;
}
public boolean isTraceEnabled()
{
return log.isTraceEnabled();
}
public void trace(String msg)
{
trace(msg, new Object[]{});
}
public void trace(String format, Object arg)
{
trace(format, new Object[]{arg});
}
public void trace(String format, Object arg1, Object arg2)
{
trace(format, new Object[]{arg1, arg2});
}
public void trace(String format, Object[] argArray)
{
log(FQCN, Priority.TRACE, format, argArray, null);
}
public void trace(String msg, Throwable t)
{
log(FQCN, Priority.TRACE, msg, new Object[]{}, t);
}
public boolean isDebugEnabled()
{
return log.isDebugEnabled();
}
public void debug(String msg)
{
debug(msg, new Object[]{});
}
public void debug(String format, Object arg)
{
debug(format, new Object[]{arg});
}
public void debug(String format, Object arg1, Object arg2)
{
debug(format, new Object[]{arg1, arg2});
}
public void debug(String format, Object[] argArray)
{
log(FQCN, Priority.DEBUG, format, argArray, null);
}
public void debug(String msg, Throwable t)
{
log(FQCN, Priority.DEBUG, msg, new Object[]{}, t);
}
public boolean isInfoEnabled()
{
return log.isInfoEnabled();
}
public void info(String msg)
{
info(msg, new Object[]{});
}
public void info(String format, Object arg)
{
info(format, new Object[]{arg});
}
public void info(String format, Object arg1, Object arg2)
{
info(format, new Object[]{arg1, arg2});
}
public void info(String format, Object[] argArray)
{
log(FQCN, Priority.INFO, format, argArray, null);
}
public void info(String msg, Throwable t)
{
log(FQCN, Priority.INFO, msg, new Object[]{}, t);
}
public boolean isWarnEnabled()
{
return log.isWarnEnabled();
}
public void warn(String msg)
{
warn(msg, new Object[]{});
}
public void warn(String format, Object arg)
{
warn(format, new Object[]{arg});
}
public void warn(String format, Object arg1, Object arg2)
{
warn(format, new Object[]{arg1, arg2});
}
public void warn(String format, Object[] argArray)
{
log(FQCN, Priority.WARNING, format, argArray, null);
}
public void warn(String msg, Throwable t)
{
log(FQCN, Priority.WARNING, msg, new Object[]{}, t);
}
public boolean isErrorEnabled()
{
return log.isErrorEnabled();
}
public void error(String msg)
{
error(msg, new Object[]{});
}
public void error(String format, Object arg)
{
error(format, new Object[]{arg});
}
public void error(String format, Object arg1, Object arg2)
{
error(format, new Object[]{arg1, arg2});
}
public void error(String format, Object[] argArray)
{
log(FQCN, Priority.ERROR, format, argArray, null);
}
public void error(String msg, Throwable t)
{
log(FQCN, Priority.ERROR, msg, new Object[]{}, t);
}
private void log(String fqcn, Priority level, String message, Object[] argArray, Throwable t)
{
if (argArray == null || argArray.length == 0){
log.log(level, fqcn, message, t);
}else{
FormattingTuple ft = MessageFormatter.arrayFormat(message, argArray);
if (t == null){
t = ft.getThrowable();
}
log.log(level, fqcn, ft.getMessage(), t);
}
}
public void log(Marker marker, String fqcn, int level, String message, Object[] argArray, Throwable t)
{
Priority l = null;
switch (level){
case LocationAwareLogger.TRACE_INT:
l = Priority.TRACE;
break;
case LocationAwareLogger.DEBUG_INT:
l = Priority.DEBUG;
break;
case LocationAwareLogger.INFO_INT:
l = Priority.INFO;
break;
case LocationAwareLogger.WARN_INT:
l = Priority.WARNING;
break;
case LocationAwareLogger.ERROR_INT:
l = Priority.ERROR;
break;
default:
throw new UnsupportedOperationException("Unknown logger level: " + level);
}
log(fqcn, l, message, argArray, t);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy