net.maizegenetics.util.LoggingUtils Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of tassel Show documentation
Show all versions of tassel Show documentation
TASSEL is a software package to evaluate traits associations, evolutionary patterns, and linkage
disequilibrium.
/*
* LoggingUtils
*/
package net.maizegenetics.util;
import net.maizegenetics.prefs.TasselPrefs;
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.PrintStream;
/**
* @author Terry Casstevens
*/
public class LoggingUtils {
private static final Logger myLogger = Logger.getLogger(LoggingUtils.class);
private static final PrintStream myOriginalOutputStream = System.out;
private static final PrintStream myOriginalErrStream = System.err;
private static PrintStream myPrintStream;
private LoggingUtils() {
// Utility Class
}
/**
* Sends all logging messages (including log4j) to standard out. The logging
* level will be INFO, unless executed by the GUI and the user preference
* has been set level to DEBUG.
*/
public static void setupLogging() {
if (TasselPrefs.getLogDebug()) {
setupDebugLogging();
} else {
System.setOut(myOriginalOutputStream);
System.setErr(myOriginalErrStream);
sendLog4jToStdout();
}
}
/**
* Sends all logging messages (including log4j) to standard out. The logging
* level will be DEBUG.
*/
public static void setupDebugLogging() {
System.setOut(myOriginalOutputStream);
System.setErr(myOriginalErrStream);
sendDebugLog4jToStdout();
}
/**
* Sends all logging messages (including log4j) to specified PrintStream.
* The logging level will be INFO, unless executed by the GUI and the user
* preference has been set level to DEBUG. This is used to direct logging
* messages to the GUI.
*
* @param stream stream
*/
public static void setupLogging(PrintStream stream) {
if (TasselPrefs.getLogDebug()) {
setupDebugLogging(stream);
} else {
System.setOut(stream);
System.setErr(stream);
sendLog4jToStdout();
}
}
/**
* Sends all logging messages (including log4j) to specified PrintStream.
* The logging level will be DEBUG. This is used to direct logging messages
* to the GUI.
*
* @param stream
*/
public static void setupDebugLogging(PrintStream stream) {
System.setOut(stream);
System.setErr(stream);
sendDebugLog4jToStdout();
}
/**
* Sends all logging messages (including log4j) to specified file. The
* logging level will be INFO, unless executed by the GUI and the user
* preference has been set level to DEBUG.
*
* @param logFileName file name
*
* @throws FileNotFoundException
*/
public static void setupLogfile(String logFileName) throws FileNotFoundException {
if (TasselPrefs.getLogDebug()) {
setupDebugLogfile(logFileName);
} else {
File logFile = new File(logFileName);
myPrintStream = new PrintStream(logFile);
System.setOut(myPrintStream);
System.setErr(myPrintStream);
sendLog4jToStdout();
myLogger.info("Log File: " + logFile.getAbsolutePath());
}
}
/**
* Sends all logging messages (including log4j) to specified file. The
* logging level will be DEBUG.
*
* @param logFileName file name
*
* @throws FileNotFoundException
*/
public static void setupDebugLogfile(String logFileName) throws FileNotFoundException {
File logFile = new File(logFileName);
myPrintStream = new PrintStream(logFile);
System.setOut(myPrintStream);
System.setErr(myPrintStream);
sendDebugLog4jToStdout();
myLogger.info("Log File: " + logFile.getAbsolutePath());
}
public static void setupStdOutLogging() {
System.setOut(myOriginalOutputStream);
System.setErr(myOriginalErrStream);
java.util.Properties props = new java.util.Properties();
props.setProperty("log4j.logger.net.maizegenetics", "ERROR, stdout");
props.setProperty("log4j.appender.stdout", "org.apache.log4j.ConsoleAppender");
props.setProperty("log4j.appender.stdout.Threshold", "error");
props.setProperty("log4j.appender.stdout.layout", "org.apache.log4j.TTCCLayout");
PropertyConfigurator.configure(props);
}
public static void closeLogfile() {
if (myPrintStream != null) {
myPrintStream.close();
}
}
/**
* Turns off logging
*/
public static void setupLoggingOff() {
try {
PrintStream nullDev = new PrintStream(new FileOutputStream("/dev/null"));
System.setOut(nullDev);
System.setErr(nullDev);
turnOffLog4j();
} catch (Exception e) {
myLogger.error(e.getMessage(), e);
}
}
private static void sendLog4jToStdout() {
java.util.Properties props = new java.util.Properties();
props.setProperty("log4j.logger.net.maizegenetics", "INFO, stdout");
props.setProperty("log4j.appender.stdout", "org.apache.log4j.ConsoleAppender");
props.setProperty("log4j.appender.stdout.Threshold", "info");
props.setProperty("log4j.appender.stdout.layout", "org.apache.log4j.TTCCLayout");
PropertyConfigurator.configure(props);
}
private static void sendDebugLog4jToStdout() {
java.util.Properties props = new java.util.Properties();
props.setProperty("log4j.logger.net.maizegenetics", "DEBUG, stdout");
props.setProperty("log4j.appender.stdout", "org.apache.log4j.ConsoleAppender");
props.setProperty("log4j.appender.stdout.Threshold", "debug");
props.setProperty("log4j.appender.stdout.layout", "org.apache.log4j.TTCCLayout");
PropertyConfigurator.configure(props);
}
private static void turnOffLog4j() {
java.util.Properties props = new java.util.Properties();
props.setProperty("log4j.logger.net.maizegenetics", "OFF, stdout");
props.setProperty("log4j.appender.stdout", "org.apache.log4j.NullAppender");
props.setProperty("log4j.appender.stdout.Threshold", "off");
props.setProperty("log4j.appender.stdout.layout", "org.apache.log4j.TTCCLayout");
PropertyConfigurator.configure(props);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy