All Downloads are FREE. Search and download functionalities are using the official Maven repository.

se.jiderhamn.classloader.leak.prevention.StdLogger Maven / Gradle / Ivy

package se.jiderhamn.classloader.leak.prevention;

/**
 * Implementation of {@link Logger} interface, that uses {@link System#out} and {@link System#err}.
 * Because log frameworks may themselves cause leaks, we may want to avoid them altogether.
 * 
 * To "turn off" a log level, override the corresponding method(s) with an empty implementation.
 * @author Mattias Jiderhamn
 */
public class StdLogger implements Logger {
  
  /** Get prefix to use when logging to {@link System#out}/{@link System#err} */
  protected String getLogPrefix() {
    return "ClassLoader Leak Preventor: ";
  }
  
  @Override
  public void debug(String msg) {
    System.out.println(getLogPrefix() + msg);
  } 

  @Override
  public void info(String s) {
    System.out.println(getLogPrefix() + s);
  } 

  @Override
  public void warn(String s) {
    System.err.println(getLogPrefix() + s);
  } 

  @Override
  public void warn(Throwable t) {
    t.printStackTrace(System.err);
  } 

  @Override
  public void error(String s) {
    System.err.println(getLogPrefix() + s);
  } 

  @Override
  public void error(Throwable t) {
    t.printStackTrace(System.err);
  }
  
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy