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

de.is24.maven.slf4j.LoggerForMavenLog Maven / Gradle / Ivy

There is a newer version: 2.1.0
Show newest version
package de.is24.maven.slf4j;

import org.apache.maven.plugin.logging.Log;
import org.slf4j.helpers.FormattingTuple;
import org.slf4j.helpers.MarkerIgnoringBase;

import javax.annotation.Nonnull;
import javax.annotation.Nullable;

import static org.slf4j.helpers.MessageFormatter.arrayFormat;
import static org.slf4j.helpers.MessageFormatter.format;

/**
 * An slf4j Logger backed by a Maven Plugin Log.
 *
 * @author Sebastian Kirsch
 * @since 1.5
 */
public class LoggerForMavenLog extends MarkerIgnoringBase {

    private final Log log;

    public LoggerForMavenLog(@Nonnull Log log, @Nullable String name) {
        this.log = log;
        this.name = name;
    }

    private void doDebug(String message, Throwable throwable) {
        String renderedMessage = this.name == null ? message : this.name + ": " + message;
        if (throwable == null) {
            log.debug(renderedMessage);
        } else {
            log.debug(renderedMessage, throwable);
        }
    }

    private void doDebug(String message) {
        doDebug(message, null);
    }

    private void doDebug(FormattingTuple tuple) {
        doDebug(tuple.getMessage(), tuple.getThrowable());
    }

    @Override
    public boolean isTraceEnabled() {
        return log.isDebugEnabled();
    }

    @Override
    public void trace(String msg) {
        if (log.isDebugEnabled()) {
            doDebug(msg);
        }
    }

    @Override
    public void trace(String format, Object arg) {
        if (log.isDebugEnabled()) {
            doDebug(format(format, arg));
        }
    }

    @Override
    public void trace(String format, Object arg1, Object arg2) {
        if (log.isDebugEnabled()) {
            doDebug(format(format, arg1, arg2));
        }
    }

    @Override
    public void trace(String format, Object... arguments) {
        if (log.isDebugEnabled()) {
            doDebug(arrayFormat(format, arguments));
        }
    }

    @Override
    public void trace(String msg, Throwable t) {
        if (log.isDebugEnabled()) {
            doDebug(msg, t);
        }
    }

    @Override
    public boolean isDebugEnabled() {
        return log.isDebugEnabled();
    }

    @Override
    public void debug(String msg) {
        if (log.isDebugEnabled()) {
            doDebug(msg);
        }
    }

    @Override
    public void debug(String format, Object arg) {
        if (log.isDebugEnabled()) {
            doDebug(format(format, arg));
        }
    }

    @Override
    public void debug(String format, Object arg1, Object arg2) {
        if (log.isDebugEnabled()) {
            doDebug(format(format, arg1, arg2));
        }
    }

    @Override
    public void debug(String format, Object... arguments) {
        if (log.isDebugEnabled()) {
            doDebug(arrayFormat(format, arguments));
        }
    }

    @Override
    public void debug(String msg, Throwable t) {
        if (log.isDebugEnabled()) {
            doDebug(msg, t);
        }
    }

    @Override
    public boolean isInfoEnabled() {
        return log.isInfoEnabled();
    }

    @Override
    public void info(String msg) {
        if (log.isInfoEnabled()) {
            log.info(msg);
        }
    }

    @SuppressWarnings("ThrowableResultOfMethodCallIgnored")
    private void doInfo(FormattingTuple tuple) {
        if (tuple.getThrowable() == null) {
            log.info(tuple.getMessage());
        } else {
            log.info(tuple.getMessage(), tuple.getThrowable());
        }
    }

    @Override
    public void info(String format, Object arg) {
        if (log.isInfoEnabled()) {
            doInfo(format(format, arg));
        }
    }

    @Override
    public void info(String format, Object arg1, Object arg2) {
        if (log.isInfoEnabled()) {
            doInfo(format(format, arg1, arg2));
        }
    }

    @Override
    public void info(String format, Object... arguments) {
        if (log.isInfoEnabled()) {
            doInfo(arrayFormat(format, arguments));
        }
    }

    @Override
    public void info(String msg, Throwable t) {
        if (log.isInfoEnabled()) {
            log.info(msg, t);
        }
    }

    @Override
    public boolean isWarnEnabled() {
        return log.isWarnEnabled();
    }

    @Override
    public void warn(String msg) {
        if (log.isWarnEnabled()) {
            log.warn(msg);
        }
    }

    @SuppressWarnings("ThrowableResultOfMethodCallIgnored")
    private void doWarn(FormattingTuple tuple) {
        if (tuple.getThrowable() == null) {
            log.warn(tuple.getMessage());
        } else {
            log.warn(tuple.getMessage(), tuple.getThrowable());
        }
    }

    @Override
    public void warn(String format, Object arg) {
        if (log.isWarnEnabled()) {
            doWarn(format(format, arg));
        }
    }

    @Override
    public void warn(String format, Object arg1, Object arg2) {
        if (log.isWarnEnabled()) {
            doWarn(format(format, arg1, arg2));
        }
    }

    @Override
    public void warn(String format, Object... arguments) {
        if (log.isWarnEnabled()) {
            doWarn(arrayFormat(format, arguments));
        }
    }

    @Override
    public void warn(String msg, Throwable t) {
        if (log.isWarnEnabled()) {
            log.warn(msg, t);
        }
    }

    @Override
    public boolean isErrorEnabled() {
        return log.isErrorEnabled();
    }

    @Override
    public void error(String msg) {
        log.error(msg);
    }

    @SuppressWarnings("ThrowableResultOfMethodCallIgnored")
    private void doError(FormattingTuple tuple) {
        if (tuple.getThrowable() == null) {
            log.error(tuple.getMessage());
        } else {
            log.error(tuple.getMessage(), tuple.getThrowable());
        }
    }

    @Override
    public void error(String format, Object arg) {
        doError(format(format, arg));
    }

    @Override
    public void error(String format, Object arg1, Object arg2) {
        doError(format(format, arg1, arg2));
    }

    @Override
    public void error(String format, Object... arguments) {
        doError(arrayFormat(format, arguments));
    }

    @Override
    public void error(String msg, Throwable t) {
        log.error(msg, t);
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy