Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * JBoss, Home of Professional Open Source.
   * Copyright 2010, Red Hat Middleware LLC, and individual contributors
   * as indicated by the @author tags. See the copyright.txt file in the
   * distribution for a full listing of individual contributors.
   *
   * This is free software; you can redistribute it and/or modify it
   * under the terms of the GNU Lesser General Public License as
   * published by the Free Software Foundation; either version 2.1 of
  * the License, or (at your option) any later version.
  *
  * This software is distributed in the hope that it will be useful,
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  * Lesser General Public License for more details.
  *
  * You should have received a copy of the GNU Lesser General Public
  * License along with this software; if not, write to the Free
  * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
  * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
  */
 
 package org.jboss.logging;
 
 
 final class Slf4jLocationAwareLogger extends Logger {
 
     private static final long serialVersionUID = 8685757928087758380L;
 
     private static final Object[] EMPTY = new Object[0];
     private static final boolean POST_1_6;
     private static final Method LOG_METHOD;
 
     static {
         Method[] methods = LocationAwareLogger.class.getDeclaredMethods();
         Method logMethod = null;
         boolean post16 = false;
         for (Method method : methods) {
             if (method.getName().equals("log")) {
                 logMethod = method;
                 Class<?>[] parameterTypes = method.getParameterTypes();
                 post16 = parameterTypes.length == 6;
             }
         }
         if (logMethod == null) {
             throw new NoSuchMethodError("Cannot find LocationAwareLogger.log() method");
         }
          = post16;
          = logMethod;
     }
 
     private final LocationAwareLogger logger;
 
     Slf4jLocationAwareLogger(final String namefinal LocationAwareLogger logger) {
         super(name);
         this. = logger;
     }
 
     public boolean isEnabled(final Level level) {
         if (level != nullswitch (level) {
             case return .isErrorEnabled();
             case return .isErrorEnabled();
             case :  return .isWarnEnabled();
             case :  return .isInfoEnabled();
             case return .isDebugEnabled();
             case return .isTraceEnabled();
         }
         return true;
     }
 
     protected void doLog(final Level levelfinal String loggerClassNamefinal Object messagefinal Object[] parametersfinal Throwable thrown) {
         if (isEnabled(level)) {
             final String text = parameters == null || parameters.length == 0 ? String.valueOf(message) : MessageFormat.format(String.valueOf(message), parameters);
             doLog(loggerClassNametranslate(level), textthrown);
         }
     }
 
     protected void doLogf(final Level levelfinal String loggerClassNamefinal String formatfinal Object[] parametersfinal Throwable thrown) {
         if (isEnabled(level)) {
             final String text = parameters == null ? String.format(format) : String.format(formatparameters);
             doLog(loggerClassNametranslate(level), textthrown);
         }
     }
 
     private static void doLog(LocationAwareLogger loggerString classNameint levelString textThrowable thrown) {
         try {
             if () {
                 .invoke(loggernullclassName, Integer.valueOf(level), textthrown);
             } else {
                 .invoke(loggernullclassName, Integer.valueOf(level), textthrown);
             }
         } catch (InvocationTargetException e) {
             try {
                 throw e.getCause();
            } catch (RuntimeException ex) {
                throw ex;
            } catch (Error er) {
                throw er;
            } catch (Throwable throwable) {
                throw new UndeclaredThrowableException(throwable);
            }
        } catch (IllegalAccessException e) {
            throw new IllegalAccessError(e.getMessage());
        }
    }
    private static int translate(Level level) {
        if (level != nullswitch (level) {
            case :
            case return .;
            case :  return .;
            case :  return .;
            case return .;
            case return .;
        }
        return .;
    }
New to GrepCode? Check out our FAQ X