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

com.helger.poi.POISLF4JLogger Maven / Gradle / Ivy

/**
 * Copyright (C) 2014-2016 Philip Helger (www.helger.com)
 * philip[at]helger[dot]com
 *
 * 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 com.helger.poi;

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

import org.apache.poi.util.SystemOutLogger;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * A special {@link org.apache.poi.util.POILogger} implementation that uses
 * SLF4J. Set the system property "org.apache.poi.util.POILogger" to this class,
 * to use it (see {@link com.helger.poi.POISetup} for the code). It is derived
 * from {@link SystemOutLogger}, because the super class
 * {@link org.apache.poi.util.POILogger} only has a package-private ctor.
 *
 * @author Philip Helger
 */
public class POISLF4JLogger extends SystemOutLogger
{
  private static final String BLA = "An exception occurred";

  private Logger m_aLogger;

  public POISLF4JLogger ()
  {}

  @Override
  public void initialize (final String sCat)
  {
    m_aLogger = LoggerFactory.getLogger (sCat);
  }

  /**
   * Log a message
   *
   * @param nLevel
   *        One of DEBUG, INFO, WARN, ERROR, FATAL
   * @param aObj
   *        The object to log.
   */
  @Override
  public void log (final int nLevel, final Object aObj)
  {
    log (nLevel, aObj, null);
  }

  /**
   * Log a message
   *
   * @param nLevel
   *        One of DEBUG, INFO, WARN, ERROR, FATAL
   * @param aMsg
   *        The object to log. This is converted to a string.
   * @param aThrowable
   *        An exception to be logged
   */
  @Override
  public void log (final int nLevel, @Nonnull final Object aMsg, @Nullable final Throwable aThrowable)
  {
    if (nLevel == FATAL || nLevel == ERROR)
    {
      if (m_aLogger.isErrorEnabled ())
      {
        if (aMsg != null)
          m_aLogger.error ("{}", aMsg, aThrowable);
        else
          m_aLogger.error (BLA, aThrowable);
      }
    }
    else
      if (nLevel == WARN)
      {
        if (m_aLogger.isWarnEnabled ())
        {
          if (aMsg != null)
            m_aLogger.warn ("{}", aMsg, aThrowable);
          else
            m_aLogger.warn (BLA, aThrowable);
        }
      }
      else
        if (nLevel == INFO)
        {
          if (m_aLogger.isInfoEnabled ())
          {
            if (aMsg != null)
              m_aLogger.info ("{}", aMsg, aThrowable);
            else
              m_aLogger.info (BLA, aThrowable);
          }
        }
        else
          if (nLevel == DEBUG)
          {
            if (m_aLogger.isDebugEnabled ())
            {
              if (aMsg != null)
                m_aLogger.debug ("{}", aMsg, aThrowable);
              else
                m_aLogger.debug (BLA, aThrowable);
            }
          }
          else
          {
            if (m_aLogger.isTraceEnabled ())
            {
              if (aMsg != null)
                m_aLogger.trace ("{}", aMsg, aThrowable);
              else
                m_aLogger.trace (BLA, aThrowable);
            }
          }
  }

  /**
   * Check if a logger is enabled to log at the specified level
   *
   * @param nLevel
   *        One of DEBUG, INFO, WARN, ERROR, FATAL
   * @return true if the logger can handle the specified error
   *         level
   */
  @Override
  public boolean check (final int nLevel)
  {
    if (nLevel == FATAL || nLevel == ERROR)
      return m_aLogger.isErrorEnabled ();
    if (nLevel == WARN)
      return m_aLogger.isWarnEnabled ();
    if (nLevel == INFO)
      return m_aLogger.isInfoEnabled ();
    if (nLevel == DEBUG)
      return m_aLogger.isDebugEnabled ();
    return m_aLogger.isTraceEnabled ();
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy