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

org.apache.commons.logging.Log Maven / Gradle / Ivy

Go to download

The Pax Logging API Library is to allow for the Pax Logging Service to be reloaded without stopping the many dependent bundles. It also contains the OSGi Log Service API and the Knopflerfish Log API.

There is a newer version: 2.2.8
Show newest version
/*
 * 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.commons.logging;

/**
 * A simple logging interface abstracting logging APIs.  In order to be
 * instantiated successfully by {@link LogFactory}, classes that implement
 * this interface must have a constructor that takes a single String
 * parameter representing the "name" of this Log.
 * 

* The six logging levels used by Log are (in order): *

    *
  1. trace (the least serious)
  2. *
  3. debug
  4. *
  5. info
  6. *
  7. warn
  8. *
  9. error
  10. *
  11. fatal (the most serious)
  12. *
* The mapping of these log levels to the concepts used by the underlying * logging system is implementation dependent. * The implementation should ensure, though, that this ordering behaves * as expected. *

* Performance is often a logging concern. * By examining the appropriate property, * a component can avoid expensive operations (producing information * to be logged). *

* For example, *

 *    if (log.isDebugEnabled()) {
 *        ... do something expensive ...
 *        log.debug(theResult);
 *    }
 * 
*

* Configuration of the underlying logging system will generally be done * external to the Logging APIs, through whatever mechanism is supported by * that system. * * @version $Id: Log.java 1606045 2014-06-27 12:11:56Z tn $ */ public interface Log { /** * Logs a message with debug log level. * * @param message log this message */ void debug(Object message); /** * Logs an error with debug log level. * * @param message log this message * @param t log this cause */ void debug(Object message, Throwable t); /** * Logs a message with error log level. * * @param message log this message */ void error(Object message); /** * Logs an error with error log level. * * @param message log this message * @param t log this cause */ void error(Object message, Throwable t); /** * Logs a message with fatal log level. * * @param message log this message */ void fatal(Object message); /** * Logs an error with fatal log level. * * @param message log this message * @param t log this cause */ void fatal(Object message, Throwable t); /** * Logs a message with info log level. * * @param message log this message */ void info(Object message); /** * Logs an error with info log level. * * @param message log this message * @param t log this cause */ void info(Object message, Throwable t); /** * Is debug logging currently enabled? *

* Call this method to prevent having to perform expensive operations * (for example, String concatenation) * when the log level is more than debug. * * @return true if debug is enabled in the underlying logger. */ boolean isDebugEnabled(); /** * Is error logging currently enabled? *

* Call this method to prevent having to perform expensive operations * (for example, String concatenation) * when the log level is more than error. * * @return true if error is enabled in the underlying logger. */ boolean isErrorEnabled(); /** * Is fatal logging currently enabled? *

* Call this method to prevent having to perform expensive operations * (for example, String concatenation) * when the log level is more than fatal. * * @return true if fatal is enabled in the underlying logger. */ boolean isFatalEnabled(); /** * Is info logging currently enabled? *

* Call this method to prevent having to perform expensive operations * (for example, String concatenation) * when the log level is more than info. * * @return true if info is enabled in the underlying logger. */ boolean isInfoEnabled(); /** * Is trace logging currently enabled? *

* Call this method to prevent having to perform expensive operations * (for example, String concatenation) * when the log level is more than trace. * * @return true if trace is enabled in the underlying logger. */ boolean isTraceEnabled(); /** * Is warn logging currently enabled? *

* Call this method to prevent having to perform expensive operations * (for example, String concatenation) * when the log level is more than warn. * * @return true if warn is enabled in the underlying logger. */ boolean isWarnEnabled(); /** * Logs a message with trace log level. * * @param message log this message */ void trace(Object message); /** * Logs an error with trace log level. * * @param message log this message * @param t log this cause */ void trace(Object message, Throwable t); /** * Logs a message with warn log level. * * @param message log this message */ void warn(Object message); /** * Logs an error with warn log level. * * @param message log this message * @param t log this cause */ void warn(Object message, Throwable t); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy