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 } }