org.apache.ivy.util.MessageLoggerEngine Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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.apache.ivy.util;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Stack;
/**
* A {@link MessageLogger} implementation delegating the work to the current top logger on a stack.
*
* When the logger stack is empty, it delegates the work to a default logger, which by default is
* the {@link Message#getDefaultLogger()}.
*
*
* {@link #pushLogger(MessageLogger)} should be called to delegate to a new logger, and
* {@link #popLogger()} should be called when the context of this logger is finished.
*
*/
public class MessageLoggerEngine implements MessageLogger {
private final Stack/**/ loggerStack = new Stack();
private MessageLogger defaultLogger = null;
private List problems = new ArrayList();
private List warns = new ArrayList();
private List errors = new ArrayList();
public MessageLoggerEngine() {
}
/**
* Sets the logger used when the stack is empty.
*
* @param defaultLogger the logger to use when the stack is empty.
*/
public void setDefaultLogger(MessageLogger defaultLogger) {
this.defaultLogger = defaultLogger;
}
/**
* Push a logger on the stack.
*
* @param logger
* the logger to push. Must not be null
.
*/
public void pushLogger(MessageLogger logger) {
Checks.checkNotNull(logger, "logger");
loggerStack.push(logger);
}
/**
* Pops a logger from the logger stack.
*
* Does nothing if the logger stack is empty
*
*/
public void popLogger() {
if (!loggerStack.isEmpty()) {
loggerStack.pop();
}
}
/**
* Returns the current logger, or the default one if there is no logger in the stack
* @return the current logger, or the default one if there is no logger in the stack
*/
public MessageLogger peekLogger() {
if (loggerStack.isEmpty()) {
return getDefaultLogger();
}
return (MessageLogger) loggerStack.peek();
}
private MessageLogger getDefaultLogger() {
// we don't store the logger returned by Message.getDefaultLogger() to always stay in sync
// as long as our default logger has not been set explicitly with setDefaultLogger()
return defaultLogger == null ? Message.getDefaultLogger() : defaultLogger;
}
// consolidated methods
public void warn(String msg) {
peekLogger().warn(msg);
problems.add("WARN: " + msg);
warns.add(msg);
}
public void error(String msg) {
peekLogger().error(msg);
problems.add("\tERROR: " + msg);
errors.add(msg);
}
public List getErrors() {
return errors;
}
public List getProblems() {
return problems;
}
public List getWarns() {
return warns;
}
public void sumupProblems() {
MessageLoggerHelper.sumupProblems(this);
clearProblems();
}
public void clearProblems() {
getDefaultLogger().clearProblems();
for (Iterator iter = loggerStack.iterator(); iter.hasNext();) {
MessageLogger l = (MessageLogger) iter.next();
l.clearProblems();
}
problems.clear();
errors.clear();
warns.clear();
}
public void setShowProgress(boolean progress) {
getDefaultLogger().setShowProgress(progress);
// updates all loggers in the stack
for (Iterator iter = loggerStack.iterator(); iter.hasNext();) {
MessageLogger l = (MessageLogger) iter.next();
l.setShowProgress(progress);
}
}
public boolean isShowProgress() {
// testing the default logger is enough, all loggers should be in sync
return getDefaultLogger().isShowProgress();
}
// delegation methods
public void debug(String msg) {
peekLogger().debug(msg);
}
public void deprecated(String msg) {
peekLogger().deprecated(msg);
}
public void endProgress() {
peekLogger().endProgress();
}
public void endProgress(String msg) {
peekLogger().endProgress(msg);
}
public void info(String msg) {
peekLogger().info(msg);
}
public void rawinfo(String msg) {
peekLogger().rawinfo(msg);
}
public void log(String msg, int level) {
peekLogger().log(msg, level);
}
public void progress() {
peekLogger().progress();
}
public void rawlog(String msg, int level) {
peekLogger().rawlog(msg, level);
}
public void verbose(String msg) {
peekLogger().verbose(msg);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy