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

org.richfaces.log.JavaLogger Maven / Gradle / Ivy

/*
 * JBoss, Home of Professional Open Source
 * Copyright 2013, Red Hat, Inc. and individual contributors
 * by the @authors tag. See the copyright.txt 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.richfaces.log;

import java.util.EnumMap;
import java.util.Locale;
import java.util.Map;
import java.util.logging.LogRecord;

import org.richfaces.l10n.BundleLoader;
import org.richfaces.l10n.InterpolationException;
import org.richfaces.l10n.MessageInterpolator;

/**
 * 

* That logger delegates all calls to the JDK {@link java.util.logging.Logger} *

* * @author [email protected] * @author nick */ public class JavaLogger implements Logger { public static final String RICHFACES_LOG = "org.richfaces"; static final Map LEVELS_MAP = new EnumMap(Level.class); static { LEVELS_MAP.put(Level.ERROR, java.util.logging.Level.SEVERE); LEVELS_MAP.put(Level.INFO, java.util.logging.Level.INFO); LEVELS_MAP.put(Level.WARNING, java.util.logging.Level.WARNING); LEVELS_MAP.put(Level.DEBUG, java.util.logging.Level.FINE); } private static final String CLASS_NAME = JavaLogger.class.getName(); private final java.util.logging.Logger jdkLogger; private MessageInterpolator messageInterpolator; JavaLogger(String category) { jdkLogger = java.util.logging.Logger.getLogger(category); messageInterpolator = new MessageInterpolator(new BundleLoader()); } JavaLogger() { this(RICHFACES_LOG); } private void fillCallerData(String fqn, LogRecord record) { StackTraceElement[] stackTrace = new Exception().getStackTrace(); int i = 0; for (; i < stackTrace.length; i++) { if (fqn.equals(stackTrace[i].getClassName())) { break; } } int idx = i + 1; for (; idx < stackTrace.length; idx++) { if (!fqn.equals(stackTrace[idx].getClassName())) { break; } } if (idx < stackTrace.length) { record.setSourceMethodName(stackTrace[idx].getMethodName()); record.setSourceClassName(stackTrace[idx].getClassName()); } } private String interpolate(Enum messageKey, Object... args) { try { return messageInterpolator.interpolate(Locale.getDefault(), messageKey, args); } catch (InterpolationException e) { return "???" + e.getMessageKey() + "???"; } } private LogRecord createRecord(java.util.logging.Level level, CharSequence message, Throwable thrown) { // millis and thread are filled by the constructor LogRecord record = new LogRecord(level, message != null ? message.toString() : null); // TODO resource bundle? record.setLoggerName(jdkLogger.getName()); record.setThrown(thrown); fillCallerData(CLASS_NAME, record); return record; } public boolean isDebugEnabled() { return isLogEnabled(Level.DEBUG); } public void debug(CharSequence content) { log(Level.DEBUG, content); } public void debug(Enum messageKey, Object... args) { log(Level.DEBUG, messageKey, args); } public void debug(CharSequence content, Throwable thrown) { log(Level.DEBUG, content, thrown); } public void debug(Throwable error, Enum messageKey, Object... args) { log(Level.DEBUG, error, messageKey, args); } public void debug(Throwable thrown) { log(Level.DEBUG, thrown); } public boolean isInfoEnabled() { return isLogEnabled(Level.INFO); } public void info(CharSequence content) { log(Level.INFO, content); } public void info(Enum messageKey, Object... args) { log(Level.INFO, messageKey, args); } public void info(CharSequence content, Throwable thrown) { log(Level.INFO, content, thrown); } public void info(Throwable error, Enum messageKey, Object... args) { log(Level.INFO, error, messageKey, args); } public void info(Throwable thrown) { log(Level.INFO, thrown); } public boolean isWarnEnabled() { return isLogEnabled(Level.WARNING); } public void warn(CharSequence content) { log(Level.WARNING, content); } public void warn(Enum messageKey, Object... args) { log(Level.WARNING, messageKey, args); } public void warn(CharSequence content, Throwable thrown) { log(Level.WARNING, content, thrown); } public void warn(Throwable error, Enum messageKey, Object... args) { log(Level.WARNING, error, messageKey, args); } public void warn(Throwable thrown) { log(Level.WARNING, thrown); } public boolean isErrorEnabled() { return isLogEnabled(Level.ERROR); } public void error(CharSequence content) { log(Level.ERROR, content); } public void error(Enum messageKey, Object... args) { log(Level.ERROR, messageKey, args); } public void error(CharSequence content, Throwable thrown) { log(Level.ERROR, content, thrown); } public void error(Throwable error, Enum messageKey, Object... args) { log(Level.ERROR, error, messageKey, args); } public void error(Throwable thrown) { log(Level.ERROR, thrown); } public boolean isLogEnabled(Level level) { return jdkLogger.isLoggable(LEVELS_MAP.get(level)); } public void log(Level level, CharSequence content) { java.util.logging.Level julLevel = LEVELS_MAP.get(level); if (jdkLogger.isLoggable(julLevel)) { jdkLogger.log(createRecord(julLevel, content, null)); } } public void log(Level level, Enum messageKey, Object... args) { java.util.logging.Level julLevel = LEVELS_MAP.get(level); if (jdkLogger.isLoggable(julLevel)) { jdkLogger.log(createRecord(julLevel, interpolate(messageKey, args), null)); } } public void log(Level level, CharSequence content, Throwable thrown) { java.util.logging.Level julLevel = LEVELS_MAP.get(level); if (jdkLogger.isLoggable(julLevel)) { jdkLogger.log(createRecord(julLevel, content, thrown)); } } public void log(Level level, Throwable thrown, Enum messageKey, Object... args) { java.util.logging.Level julLevel = LEVELS_MAP.get(level); if (jdkLogger.isLoggable(julLevel)) { jdkLogger.log(createRecord(julLevel, interpolate(messageKey, args), thrown)); } } public void log(Level level, Throwable thrown) { java.util.logging.Level julLevel = LEVELS_MAP.get(level); if (jdkLogger.isLoggable(julLevel)) { jdkLogger.log(createRecord(julLevel, null, thrown)); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy