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

org.gradle.api.internal.project.ant.AntLoggingAdapter Maven / Gradle / Ivy

/*
 * Copyright 2009 the original author or authors.
 *
 * 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 org.gradle.api.internal.project.ant;

import org.apache.tools.ant.BuildEvent;
import org.apache.tools.ant.BuildLogger;
import org.gradle.api.AntBuilder.AntMessagePriority;
import org.gradle.api.logging.LogLevel;
import org.gradle.api.logging.Logger;
import org.gradle.api.logging.Logging;
import org.gradle.internal.logging.LogLevelMapping;

import java.io.PrintStream;

public class AntLoggingAdapter implements BuildLogger {
    private final Logger logger = Logging.getLogger(AntLoggingAdapter.class);

    private AntMessagePriority lifecycleLogLevel;

    @Override
    public void setMessageOutputLevel(int level) {
        // ignore
    }

    @Override
    public void setOutputPrintStream(PrintStream output) {
        // ignore
    }

    @Override
    public void setEmacsMode(boolean emacsMode) {
        // ignore
    }

    @Override
    public void setErrorPrintStream(PrintStream err) {
        // ignore
    }

    @Override
    public void buildStarted(BuildEvent event) {
        // ignore
    }

    @Override
    public void buildFinished(BuildEvent event) {
        // ignore
    }

    @Override
    public void targetStarted(BuildEvent event) {
        // ignore
    }

    @Override
    public void targetFinished(BuildEvent event) {
        // ignore
    }

    @Override
    public void taskStarted(BuildEvent event) {
        // ignore
    }

    @Override
    public void taskFinished(BuildEvent event) {
        // ignore
    }

    @Override
    public void messageLogged(BuildEvent event) {
        final StringBuffer message = new StringBuffer();
        if (event.getTask() != null) {
            String taskName = event.getTask().getTaskName();
            message.append("[ant:").append(taskName).append("] ");
        }
        final String messageText = event.getMessage();
        message.append(messageText);

        LogLevel level = getLogLevelForMessagePriority(event.getPriority());

        if (event.getException() != null) {
            logger.log(level, message.toString(), event.getException());
        } else {
            logger.log(level, message.toString());
        }
    }

    public void setLifecycleLogLevel(String lifecycleLogLevel) {
        setLifecycleLogLevel(lifecycleLogLevel == null ? null : AntMessagePriority.valueOf(lifecycleLogLevel));
    }

    public void setLifecycleLogLevel(AntMessagePriority lifecycleLogLevel) {
        this.lifecycleLogLevel = lifecycleLogLevel;
    }

    public AntMessagePriority getLifecycleLogLevel() {
        return lifecycleLogLevel;
    }

    private LogLevel getLogLevelForMessagePriority(int messagePriority) {
        LogLevel defaultLevel = LogLevelMapping.ANT_IVY_2_SLF4J.get(messagePriority);

        // Check to see if we should adjust the level based on a set lifecycle log level
        if (lifecycleLogLevel != null) {
            if (defaultLevel.ordinal() < LogLevel.LIFECYCLE.ordinal()
                && AntMessagePriority.from(messagePriority).ordinal() >= lifecycleLogLevel.ordinal()) {
                // we would normally log at a lower level than lifecycle, but the Ant message priority is actually higher
                // than (or equal to) the set lifecycle log level
                return LogLevel.LIFECYCLE;
            } else if (defaultLevel.ordinal() >= LogLevel.LIFECYCLE.ordinal()
                && AntMessagePriority.from(messagePriority).ordinal() < lifecycleLogLevel.ordinal()) {
                // would normally log at a level higher than (or equal to) lifecycle, but the Ant message priority is
                // actually lower than the set lifecycle log level
                return LogLevel.INFO;
            }
        }

        return defaultLevel;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy