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

com.speedment.common.logger.LoggerManager Maven / Gradle / Ivy

Go to download

A Speedment bundle that shades all dependencies into one jar. This is useful when deploying an application on a server.

There is a newer version: 3.1.18
Show newest version
/**
 *
 * Copyright (c) 2006-2019, Speedment, Inc. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); You may not
 * use this file except in compliance with the License. You may obtain a copy of
 * the License at:
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations under
 * the License.
 */
package com.speedment.common.logger;

import com.speedment.common.logger.internal.SystemOutLoggerFactory;

/**
 *
 * @author pemi
 */
public interface LoggerManager {

    enum Holder {
        INST;
        private LoggerFactory defaultFactory = new SystemOutLoggerFactory();
    }

    static void setFactory(LoggerFactory newFactory) {
        Holder.INST.defaultFactory = newFactory;
    }

    static LoggerFactory getFactory() {
        return Holder.INST.defaultFactory;
    }

    /**
     * Creates and returns a new Logger bound to the given
     * binding type using
     *
     * @param binding the java.lang.Class to bind to
     * @return the new Logger instance
     */
    static Logger getLogger(Class binding) {
        return Holder.INST.defaultFactory.create(binding);
    }

    /**
     * Creates and returns a new Logger bound to the given
     * binding string using Platform's LoggerFactoryComponent.
     *
     * @param binding the java.lang.String to bind to
     * @return the new Logger instance
     */
    static Logger getLogger(String binding) {
        return Holder.INST.defaultFactory.create(binding);
    }

    /**
     * Sets the log level for Loggers that fits the initial path. Note that
     * class name are in the form "c.s.i.c.p.c.i.ConnectionPoolComponentImpl"
     *
     * @param path the start of the logger name that is to be changed
     * @param level the new log level
     */
    static void setLevel(String path, Level level) {
        Holder.INST.defaultFactory.setLevel(path, level);
    }

    /**
     * Sets the log level for the specified class logger.
     *
     * @param clazz of the class logger
     * @param level the new log level
     */
    static void setLevel(Class clazz, Level level) {
        Holder.INST.defaultFactory.setLevel(clazz, level);
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy