001package ca.uhn.fhir.util;
002
003/*-
004 * #%L
005 * HAPI FHIR - Core Library
006 * %%
007 * Copyright (C) 2014 - 2021 Smile CDR, Inc.
008 * %%
009 * Licensed under the Apache License, Version 2.0 (the "License");
010 * you may not use this file except in compliance with the License.
011 * You may obtain a copy of the License at
012 *
013 *      http://www.apache.org/licenses/LICENSE-2.0
014 *
015 * Unless required by applicable law or agreed to in writing, software
016 * distributed under the License is distributed on an "AS IS" BASIS,
017 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
018 * See the License for the specific language governing permissions and
019 * limitations under the License.
020 * #L%
021 */
022
023import org.slf4j.Logger;
024import org.slf4j.event.Level;
025
026/**
027 * Utility to fill a glaring gap in SLF4j's API - The fact that you can't
028 * specify a log level at runtime.
029 *
030 * See here for a discussion:
031 * https://jira.qos.ch/browse/SLF4J-124
032 */
033public class LogUtil {
034
035        public static void log(Logger theLogger, Level theLevel, String theMessage, Object... theArgs) {
036                switch (theLevel) {
037                        case TRACE:
038                                theLogger.trace(theMessage, theArgs);
039                                break;
040                        case DEBUG:
041                                theLogger.debug(theMessage, theArgs);
042                                break;
043                        case INFO:
044                                theLogger.info(theMessage, theArgs);
045                                break;
046                        case WARN:
047                                theLogger.warn(theMessage, theArgs);
048                                break;
049                        case ERROR:
050                                theLogger.error(theMessage, theArgs);
051                                break;
052                }
053        }
054
055}