package railo.commons.io.log.sl4j;
import org.slf4j.Marker;
import org.slf4j.helpers.MarkerIgnoringBase;
import org.slf4j.spi.LocationAwareLogger;
import railo.commons.io.log.Log;
import railo.commons.io.log.LogAndSource;
import railo.commons.lang.ExceptionUtil;
import railo.runtime.op.Caster;
public final class LoggerAdapterImpl extends MarkerIgnoringBase implements LocationAwareLogger {
private static final long serialVersionUID = 3875268250734654111L;
private LogAndSource logger;
private String _name;
public LoggerAdapterImpl(LogAndSource logger, String name){
this.logger=logger;
this._name=name;
}
public void debug(String msg) {log(Log.LEVEL_DEBUG,msg);}
public void error(String msg) {log(Log.LEVEL_ERROR,msg);}
public void info(String msg) {log(Log.LEVEL_INFO,msg);}
public void trace(String msg) {}
public void warn(String msg) {log(Log.LEVEL_WARN,msg);}
public void debug(String format, Object arg) {log(Log.LEVEL_DEBUG,format,arg);}
public void error(String format, Object arg) {log(Log.LEVEL_ERROR,format,arg);}
public void info(String format, Object arg) {log(Log.LEVEL_INFO,format,arg);}
public void trace(String format, Object arg) {}
public void warn(String format, Object arg) {log(Log.LEVEL_WARN,format,arg);}
public void debug(String format, Object arg1, Object arg2) {log(Log.LEVEL_DEBUG,format,arg1,arg2);}
public void error(String format, Object arg1, Object arg2) {log(Log.LEVEL_DEBUG,format,arg1,arg2);}
public void info(String format, Object arg1, Object arg2) {log(Log.LEVEL_DEBUG,format,arg1,arg2);}
public void trace(String format, Object arg1, Object arg2) {}
public void warn(String format, Object arg1, Object arg2) {log(Log.LEVEL_DEBUG,format,arg1,arg2);}
public void debug(String format, Object[] args) {log(Log.LEVEL_DEBUG,format,args);}
public void error(String format, Object[] args) {log(Log.LEVEL_DEBUG,format,args);}
public void info(String format, Object[] args) {log(Log.LEVEL_DEBUG,format,args);}
public void trace(String format, Object[] args) {}
public void warn(String format, Object[] args) {log(Log.LEVEL_DEBUG,format,args);}
public void debug(String msg, Throwable t) {log(Log.LEVEL_DEBUG,msg,t);}
public void error(String msg, Throwable t) {log(Log.LEVEL_DEBUG,msg,t);}
public void info(String msg, Throwable t) {log(Log.LEVEL_DEBUG,msg,t);}
public void trace(String msg, Throwable t) {}
public void warn(String msg, Throwable t) {log(Log.LEVEL_DEBUG,msg,t);}
private void log(int level, String msg) {
logger.log(level, _name, msg);
}
private void log(int level, String msg, Throwable t) {
log(level, msg+"\n"+ExceptionUtil.getStacktrace(t,true));
}
private void log(int level, String format, Object arg) {
log(level, Caster.toString(arg,""));
}
private void log(int level, String format, Object arg1, Object arg2) {
log(level, Caster.toString(arg1,"")+"\n"+Caster.toString(arg2,""));
}
private void log(int level, String format, Object[] args) {
StringBuilder sb=new StringBuilder();
for(int i=0;i<args.length;i++){
sb.append(Caster.toString(args[i],""));
sb.append("\n");
}
log(level, sb.toString().trim());
}
public boolean isDebugEnabled() {
return logger.getLogLevel()<=Log.LEVEL_DEBUG;
}
public boolean isErrorEnabled() {
return logger.getLogLevel()<=Log.LEVEL_ERROR;
}
public boolean isInfoEnabled() {
return logger.getLogLevel()<=Log.LEVEL_INFO;
}
public boolean isTraceEnabled() {
return false;
}
public boolean isWarnEnabled() {
return logger.getLogLevel()<=Log.LEVEL_WARN;
}
public void log(Marker marker, String arg1, int arg2, String arg3,Throwable arg4) {
// log(level, Caster.toString(arg1,"")+"\n"+Caster.toString(arg2,"")+"\n"+Caster.toString(arg3,""));
}
public void log(Marker arg0, String arg1, int arg2, String arg3,
Object[] arg4, Throwable arg5) {
// TODO Auto-generated method stub
}
}