com.alee.managers.log.Log Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of weblaf-core Show documentation
Show all versions of weblaf-core Show documentation
Core components for WebLaf
/*
* This file is part of WebLookAndFeel library.
*
* WebLookAndFeel library is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* WebLookAndFeel library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with WebLookAndFeel library. If not, see .
*/
package com.alee.managers.log;
import com.alee.utils.ReflectUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.Map;
import java.util.WeakHashMap;
/**
* Base logging class which can be used anywhere to log messages and exceptions.
*
* @author Mikle Garin
*/
public class Log
{
/**
* todo 1. Replace "get()" with inner caller resolvers
* todo 2. Add option to log within a separate thread to improve overall performance
*/
/**
* Loggers cache.
*/
protected static final Map loggers = new WeakHashMap ();
/**
* Logging enabled/disabled conditions.
*/
protected static final Map loggingEnabled = new WeakHashMap ();
/**
* Logger synchronization lock object.
*/
protected static final Object logLock = new Object ();
/**
* Whether debug messages are enabled or not.
*/
protected static boolean debugEnabled = false;
/**
* Custom log messages prefix supplier.
*/
protected static LogPrefixSupplier prefixSupplier = null;
/**
* Whether Log is initialized or not.
*/
protected static boolean initialized = false;
/**
* Initializes SettingsManager.
*/
public static synchronized void initialize ()
{
if ( !initialized )
{
initialized = true;
// Settings for SLF4J simple logger
System.setProperty ( "org.slf4j.simpleLogger.logFile", "System.out" );
System.setProperty ( "org.slf4j.simpleLogger.levelInBrackets", "true" );
}
}
/**
* Returns whether debug messages are enabled or not.
*
* @return true if debug messages are enabled, false otherwise
*/
public static boolean isDebugEnabled ()
{
return debugEnabled;
}
/**
* Sets whether debug messages are enabled or not.
*
* @param debugEnabled whether debug messages are enabled or not
*/
public static void setDebugEnabled ( final boolean debugEnabled )
{
synchronized ( logLock )
{
Log.debugEnabled = debugEnabled;
}
}
/**
* Returns custom log prefix supplier.
*
* @return custom log prefix supplier
*/
public static LogPrefixSupplier getPrefixSupplier ()
{
return prefixSupplier;
}
/**
* Sets custom log prefix supplier
*
* @param supplier custom log prefix supplier
*/
public static void setPrefixSupplier ( final LogPrefixSupplier supplier )
{
synchronized ( logLock )
{
Log.prefixSupplier = supplier;
}
}
/**
* Writes specified information message into log.
*
* @param message information message
* @param data formatting data
*/
public static void info ( final String message, final Object... data )
{
info ( ReflectUtils.getCallerClass (), message, data );
}
/**
* Writes specified information message into log.
*
* @param logFor where to log message is attached
* @param message information message
* @param data formatting data
*/
public static void info ( final Object logFor, final String message, final Object... data )
{
synchronized ( logLock )
{
if ( isLoggingEnabled ( logFor ) )
{
final String msg = data == null || data.length == 0 ? message : String.format ( message, data );
getLogger ( logFor ).info ( getPrefix ( LogMessageType.info, msg ) + msg );
}
}
}
/**
* Writes specified information message into log.
*
* @param message debugEnabled message
* @param data formatting data
*/
public static void debug ( final String message, final Object... data )
{
debug ( ReflectUtils.getCallerClass (), message, data );
}
/**
* Writes specified information message into log.
*
* @param logFor where to log message is attached
* @param message debugEnabled message
* @param data formatting data
*/
public static void debug ( final Object logFor, final String message, final Object... data )
{
synchronized ( logLock )
{
if ( debugEnabled )
{
if ( isLoggingEnabled ( logFor ) )
{
final String msg = data == null || data.length == 0 ? message : String.format ( message, data );
getLogger ( logFor ).debug ( getPrefix ( LogMessageType.debug, msg ) + msg );
}
}
}
}
/**
* Writes specified warning message into log.
*
* @param message warning message
*/
public static void warn ( final String message )
{
warn ( ReflectUtils.getCallerClass (), message );
}
/**
* Writes specified warning message into log.
*
* @param logFor where to log message is attached
* @param message warning message
*/
public static void warn ( final Object logFor, final String message )
{
synchronized ( logLock )
{
if ( isLoggingEnabled ( logFor ) )
{
getLogger ( logFor ).warn ( getPrefix ( LogMessageType.warn, message ) + message );
}
}
}
/**
* Writes specified warning message into log.
*
* @param message warning message
* @param throwable exception
*/
public static void warn ( final String message, final Throwable throwable )
{
warn ( ReflectUtils.getCallerClass (), message, throwable );
}
/**
* Writes specified warning message into log.
*
* @param logFor where to log message is attached
* @param message warning message
* @param throwable exception
*/
public static void warn ( final Object logFor, final String message, final Throwable throwable )
{
synchronized ( logLock )
{
if ( isLoggingEnabled ( logFor ) )
{
getLogger ( logFor ).warn ( getPrefix ( LogMessageType.warn, message, throwable ) + message, throwable );
}
}
}
/**
* Writes specified exception into log.
*
* @param throwable exception
*/
public static void error ( final Throwable throwable )
{
error ( ReflectUtils.getCallerClass (), throwable );
}
/**
* Writes specified exception into log.
*
* @param logFor where to log message is attached
* @param throwable exception
*/
public static void error ( final Object logFor, final Throwable throwable )
{
synchronized ( logLock )
{
if ( isLoggingEnabled ( logFor ) )
{
final String msg = throwable.toString ();
getLogger ( logFor ).error ( getPrefix ( LogMessageType.info, msg, throwable ) + msg, throwable );
}
}
}
/**
* Writes specified exception message into log.
*
* @param message exception message
* @param throwable exception
*/
public static void error ( final String message, final Throwable throwable )
{
error ( ReflectUtils.getCallerClass (), message, throwable );
}
/**
* Writes specified exception message into log.
*
* @param logFor where to log message is attached
* @param message exception message
* @param throwable exception
*/
public static void error ( final Object logFor, final String message, final Throwable throwable )
{
synchronized ( logLock )
{
if ( isLoggingEnabled ( logFor ) )
{
getLogger ( logFor ).error ( getPrefix ( LogMessageType.info, message, throwable ) + message, throwable );
}
}
}
/**
* Writes specified exception message into log.
*
* @param message exception message
*/
public static void error ( final String message )
{
error ( ReflectUtils.getCallerClass (), message );
}
/**
* Writes specified exception message into log.
*
* @param logFor where to log message is attached
* @param message exception message
*/
public static void error ( final Object logFor, final String message )
{
synchronized ( logLock )
{
if ( isLoggingEnabled ( logFor ) )
{
getLogger ( logFor ).error ( getPrefix ( LogMessageType.info, message ) + message );
}
}
}
/**
* Returns prefix for specific log message.
*
* @param type message type
* @param message message
* @return prefix for specific log message
*/
public static String getPrefix ( final LogMessageType type, final String message )
{
return getPrefix ( type, message, null );
}
/**
* Returns prefix for specific log message.
*
* @param type message type
* @param message message
* @param throwable exception
* @return prefix for specific log message
*/
public static String getPrefix ( final LogMessageType type, final String message, final Throwable throwable )
{
if ( prefixSupplier != null )
{
final String prefix = prefixSupplier.get ( type, message, throwable );
return prefix != null ? prefix : "";
}
else
{
return "";
}
}
/**
* Returns logger for the requesting class.
*
* @return logger for the requesting class
*/
public static Logger get ()
{
return getLogger ( ReflectUtils.getCallerClass () );
}
/**
* Returns logger for the requesting class.
*
* @return logger for the requesting class
*/
public static Logger getLogger ()
{
return getLogger ( ReflectUtils.getCallerClass () );
}
/**
* Returns logger for the specified class type.
*
* @param object class type or object type
* @return logger for the specified class type
*/
public static Logger getLogger ( final Object object )
{
synchronized ( logLock )
{
final Class type = object instanceof Class ? ( Class ) object : object.getClass ();
Logger logger = loggers.get ( type );
if ( logger == null )
{
logger = LoggerFactory.getLogger ( type );
loggers.put ( type, logger );
}
return logger;
}
}
/**
* Disables logging for the specified class type.
*
* @param object class type or object type
*/
public static void disableLogging ( final Object object )
{
setLoggingEnabled ( object, false );
}
/**
* Enables logging for the specified class type.
*
* @param object class type or object type
*/
public static void enableLogging ( final Object object )
{
setLoggingEnabled ( object, true );
}
/**
* Sets whether logging for the specified class type is enabled or not.
*
* @param object class type or object type
* @param enabled whether logging is enabled or not
*/
public static void setLoggingEnabled ( final Object object, final boolean enabled )
{
synchronized ( logLock )
{
final Class type = object instanceof Class ? ( Class ) object : object.getClass ();
if ( !enabled )
{
loggingEnabled.put ( type, enabled );
}
else
{
loggingEnabled.remove ( type );
}
}
}
/**
* Returns whether logging for the specified class type is enabled or not.
*
* @param object class type or object type
* @return true if logging for the specified class type is enabled, false otherwise
*/
public static boolean isLoggingEnabled ( final Object object )
{
synchronized ( logLock )
{
if ( loggingEnabled.size () == 0 )
{
return true;
}
final Class type = object instanceof Class ? ( Class ) object : object.getClass ();
final Boolean enabled = loggingEnabled.get ( type );
return enabled == null || enabled;
}
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy