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

bboss.org.jgroups.logging.LogFactory Maven / Gradle / Ivy

The newest version!
package bboss.org.jgroups.logging;

import bboss.org.jgroups.Global;


/**
 * Factory that creates {@link Log} instances.
 *
 * @author Manik Surtani
 * @author Bela Ban
 * @since 4.0
 */
public class LogFactory {
    public static final boolean IS_LOG4J_AVAILABLE;

    private static final CustomLogFactory custom_log_factory;

    static {
        String customLogFactoryClass=System.getProperty(Global.CUSTOM_LOG_FACTORY);
        CustomLogFactory customLogFactoryX=null;
        if(customLogFactoryClass != null) {
            try {
                // customLogFactoryX=(CustomLogFactory)Util.loadClass(customLogFactoryClass, null).newInstance();
                customLogFactoryX=(CustomLogFactory)Class.forName(customLogFactoryClass).newInstance();
            }
            catch(Exception e) {
                // failed to create the custom log factory, ignore?
            }
        }
        custom_log_factory=customLogFactoryX;
        boolean available;
        try {
            Class.forName("org.apache.log4j.Logger");
            available=true;
        }
        catch(ClassNotFoundException cnfe) {
            available=false;
        }
        IS_LOG4J_AVAILABLE=available;
    }

    public static Log getLog(Class clazz) {
        if(custom_log_factory != null)
            return custom_log_factory.getLog(clazz);

        // this call is not executed frequently, so we don't need to move the check for USE_JDK_LOGGER to class init time
        final boolean use_jdk_logger=Boolean.parseBoolean(System.getProperty(Global.USE_JDK_LOGGER));
        if(IS_LOG4J_AVAILABLE && !use_jdk_logger) {
            return new Log4JLogImpl(clazz);
        }
        else {
            return new JDKLogImpl(clazz);
        }
    }

    public static Log getLog(String category) {
        if(custom_log_factory != null)
            return custom_log_factory.getLog(category);
        
        final boolean use_jdk_logger=Boolean.parseBoolean(System.getProperty(Global.USE_JDK_LOGGER));
        if(IS_LOG4J_AVAILABLE && !use_jdk_logger) {
            return new Log4JLogImpl(category);
        }
        else {
            return new JDKLogImpl(category);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy