org.apache.ivy.util.Message 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.List;
import org.apache.ivy.Ivy;
import org.apache.ivy.core.IvyContext;
/**
* Logging utility class.
*
* This class provides static methods for easy access to the current logger in {@link IvyContext}.
*
*
* To configure logging, you should use the methods provided by the {@link MessageLoggerEngine}
* associated with the {@link Ivy} engine.
*
*/
public final class Message {
// messages level copied from ant project, to avoid dependency on ant
/** Message priority of "error". */
public static final int MSG_ERR = 0;
/** Message priority of "warning". */
public static final int MSG_WARN = 1;
/** Message priority of "information". */
public static final int MSG_INFO = 2;
/** Message priority of "verbose". */
public static final int MSG_VERBOSE = 3;
/** Message priority of "debug". */
public static final int MSG_DEBUG = 4;
private static boolean showedInfo = false;
private static MessageLogger defaultLogger = new DefaultMessageLogger(Message.MSG_INFO);
/**
* Returns the current default logger.
*
* @return the current default logger; is never null
.
*/
public static MessageLogger getDefaultLogger() {
return defaultLogger;
}
/**
* Change the default logger used when no other logger is currently configured
*
* @param logger
* the new default logger, must not be null
*/
public static void setDefaultLogger(MessageLogger logger) {
Checks.checkNotNull(logger, "logger");
defaultLogger = logger;
}
private static MessageLogger getLogger() {
return IvyContext.getContext().getMessageLogger();
}
public static void showInfo() {
if (!showedInfo) {
info(":: Apache Ivy " + Ivy.getIvyVersion() + " - "
+ Ivy.getIvyDate() + " :: " + Ivy.getIvyHomeURL() + " ::");
showedInfo = true;
}
}
public static void debug(String msg) {
getLogger().debug(msg);
}
public static void verbose(String msg) {
getLogger().verbose(msg);
}
public static void info(String msg) {
getLogger().info(msg);
}
public static void rawinfo(String msg) {
getLogger().rawinfo(msg);
}
public static void deprecated(String msg) {
getLogger().deprecated(msg);
}
public static void warn(String msg) {
getLogger().warn(msg);
}
public static void error(String msg) {
getLogger().error(msg);
}
public static void log(int logLevel, String msg) {
switch (logLevel) {
case MSG_DEBUG:
debug(msg);
break;
case MSG_VERBOSE:
verbose(msg);
break;
case MSG_INFO:
info(msg);
break;
case MSG_WARN:
warn(msg);
break;
case MSG_ERR:
error(msg);
break;
default:
throw new IllegalArgumentException("Unknown log level " + logLevel);
}
}
public static List getProblems() {
return getLogger().getProblems();
}
public static void sumupProblems() {
getLogger().sumupProblems();
}
public static void progress() {
getLogger().progress();
}
public static void endProgress() {
getLogger().endProgress();
}
public static void endProgress(String msg) {
getLogger().endProgress(msg);
}
public static boolean isShowProgress() {
return getLogger().isShowProgress();
}
public static void setShowProgress(boolean progress) {
getLogger().setShowProgress(progress);
}
private Message() {
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy