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

org.apache.logging.log4j.jul.ApiLogger Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements. See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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.apache.logging.log4j.jul;

import java.util.logging.Filter;
import java.util.logging.Level;
import java.util.logging.LogRecord;
import java.util.logging.Logger;

import org.apache.logging.log4j.message.Message;
import org.apache.logging.log4j.message.MessageFactory;
import org.apache.logging.log4j.spi.ExtendedLogger;

/**
 * Log4j API implementation of the JUL {@link Logger} class. Note that this implementation does
 * not use the {@link java.util.logging.Handler} class. Instead, logging is delegated to the
 * underlying Log4j {@link org.apache.logging.log4j.Logger} which may be implemented in one of many different ways.
 * Consult the documentation for your Log4j Provider for more details.
 * 

Note that the methods {@link #getParent()} and {@link #setLevel(java.util.logging.Level)} are not supported by * this implementation. If you need support for these methods, then you'll need to use log4j-core. The * {@link #getParent()} method will not fail (thanks to JUL API limitations), but it won't necessarily be * accurate!

*

Also note that {@link #setParent(java.util.logging.Logger)} is explicitly unsupported. Parent loggers are * determined using the syntax of the logger name; not through an arbitrary graph of loggers.

* * @since 2.1 */ public class ApiLogger extends Logger { private final WrappedLogger logger; private static final String FQCN = ApiLogger.class.getName(); ApiLogger(final ExtendedLogger logger) { super(logger.getName(), null); super.setLevel(LevelTranslator.toJavaLevel(logger.getLevel())); this.logger = new WrappedLogger(logger); } @Override public void log(final LogRecord record) { if (isFiltered(record)) { return; } final org.apache.logging.log4j.Level level = LevelTranslator.toLevel(record.getLevel()); final Object[] parameters = record.getParameters(); final MessageFactory messageFactory = logger.getMessageFactory(); final Message message = parameters == null ? messageFactory.newMessage(record.getMessage()) /* LOG4J2-1251: not formatted case */ : messageFactory.newMessage(record.getMessage(), parameters); final Throwable thrown = record.getThrown(); logger.logIfEnabled(FQCN, level, null, message, thrown); } // support for Logger.getFilter()/Logger.setFilter() boolean isFiltered(final LogRecord logRecord) { final Filter filter = getFilter(); return filter != null && !filter.isLoggable(logRecord); } @Override public boolean isLoggable(final Level level) { return logger.isEnabled(LevelTranslator.toLevel(level)); } @Override public String getName() { return logger.getName(); } @Override public void setLevel(final Level newLevel) throws SecurityException { throw new UnsupportedOperationException("Cannot set level through log4j-api"); } /** * Provides access to {@link Logger#setLevel(java.util.logging.Level)}. This method should only be used by child * classes. * * @see Logger#setLevel(java.util.logging.Level) */ protected void doSetLevel(final Level newLevel) throws SecurityException { super.setLevel(newLevel); } /** * Unsupported operation. * * @throws UnsupportedOperationException always */ @Override public void setParent(final Logger parent) { throw new UnsupportedOperationException("Cannot set parent logger"); } @Override public void log(final Level level, final String msg) { logger.log(LevelTranslator.toLevel(level), msg); } @Override public void log(final Level level, final String msg, final Object param1) { logger.log(LevelTranslator.toLevel(level), msg, param1); } @Override public void log(final Level level, final String msg, final Object[] params) { logger.log(LevelTranslator.toLevel(level), msg, params); } @Override public void log(final Level level, final String msg, final Throwable thrown) { logger.log(LevelTranslator.toLevel(level), msg, thrown); } @Override public void logp(final Level level, final String sourceClass, final String sourceMethod, final String msg) { log(level, msg); } @Override public void logp(final Level level, final String sourceClass, final String sourceMethod, final String msg, final Object param1) { log(level, msg, param1); } @Override public void logp(final Level level, final String sourceClass, final String sourceMethod, final String msg, final Object[] params) { log(level, msg, params); } @Override public void logp(final Level level, final String sourceClass, final String sourceMethod, final String msg, final Throwable thrown) { log(level, msg, thrown); } @Override public void logrb(final Level level, final String sourceClass, final String sourceMethod, final String bundleName, final String msg) { log(level, msg); } @Override public void logrb(final Level level, final String sourceClass, final String sourceMethod, final String bundleName, final String msg, final Object param1) { log(level, msg, param1); } @Override public void logrb(final Level level, final String sourceClass, final String sourceMethod, final String bundleName, final String msg, final Object[] params) { log(level, msg, params); } @Override public void logrb(final Level level, final String sourceClass, final String sourceMethod, final String bundleName, final String msg, final Throwable thrown) { log(level, msg, thrown); } @Override public void entering(final String sourceClass, final String sourceMethod) { logger.entry(); } @Override public void entering(final String sourceClass, final String sourceMethod, final Object param1) { logger.entry(param1); } @Override public void entering(final String sourceClass, final String sourceMethod, final Object[] params) { logger.entry(params); } @Override public void exiting(final String sourceClass, final String sourceMethod) { logger.exit(); } @Override public void exiting(final String sourceClass, final String sourceMethod, final Object result) { logger.exit(result); } @Override public void throwing(final String sourceClass, final String sourceMethod, final Throwable thrown) { logger.throwing(thrown); } @Override public void severe(final String msg) { logger.logIfEnabled(FQCN, org.apache.logging.log4j.Level.ERROR, null, msg); } @Override public void warning(final String msg) { logger.logIfEnabled(FQCN, org.apache.logging.log4j.Level.WARN, null, msg); } @Override public void info(final String msg) { logger.logIfEnabled(FQCN, org.apache.logging.log4j.Level.INFO, null, msg); } @Override public void config(final String msg) { logger.logIfEnabled(FQCN, LevelTranslator.CONFIG, null, msg); } @Override public void fine(final String msg) { logger.logIfEnabled(FQCN, org.apache.logging.log4j.Level.DEBUG, null, msg); } @Override public void finer(final String msg) { logger.logIfEnabled(FQCN, org.apache.logging.log4j.Level.TRACE, null, msg); } @Override public void finest(final String msg) { logger.logIfEnabled(FQCN, LevelTranslator.FINEST, null, msg); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy