Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * JBoss, Home of Professional Open Source.
   *
   * Copyright 2010 Red Hat, Inc.
   *
   * 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 org.jboss.logging;
 
 import  org.slf4j.spi.LocationAwareLogger;
 
 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 LocationAwareLogger.ERROR_INT;
            case :  return LocationAwareLogger.WARN_INT;
            case :  return LocationAwareLogger.INFO_INT;
            case return LocationAwareLogger.DEBUG_INT;
            case return LocationAwareLogger.TRACE_INT;
        }
        return LocationAwareLogger.TRACE_INT;
    }
New to GrepCode? Check out our FAQ X