Package org.richfaces.log

Source Code of org.richfaces.log.JavaLogger

/*
* 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;

/**
* <p class="changed_added_4_0">
* That logger delegates all calls to the JDK {@link java.util.logging.Logger}
* </p>
*
* @author asmirnov@exadel.com
* @author nick
*/
public class JavaLogger implements Logger {
    public static final String RICHFACES_LOG = "org.richfaces";
    static final Map<Level, java.util.logging.Level> LEVELS_MAP = new EnumMap<Level, java.util.logging.Level>(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));
        }
    }
}
TOP

Related Classes of org.richfaces.log.JavaLogger

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.