/** * Copyright 2005-2014 Restlet * * The contents of this file are subject to the terms of one of the following * open source licenses: Apache 2.0 or or EPL 1.0 (the "Licenses"). You can * select the license that you prefer but you may not use this file except in * compliance with one of these Licenses. * * You can obtain a copy of the Apache 2.0 license at * http://www.opensource.org/licenses/apache-2.0 * * You can obtain a copy of the EPL 1.0 license at * http://www.opensource.org/licenses/eclipse-1.0 * * See the Licenses for the specific language governing permissions and * limitations under the Licenses. * * Alternatively, you can obtain a royalty free commercial license with less * limitations, transferable or non-transferable, directly at * http://restlet.com/products/restlet-framework * * Restlet is a registered trademark of Restlet S.A.S. */ package org.restlet.ext.servlet.internal; import java.util.logging.LogRecord; import java.util.logging.Logger; /** * Logger that wraps the logging methods of javax.servlet.ServletContext. * * @author Jerome Louvel */ public class ServletLogger extends Logger { /** The Servlet context to use for logging. */ private volatile javax.servlet.ServletContext context; /** * Constructor. * * @param context * The Servlet context to use. */ public ServletLogger(javax.servlet.ServletContext context) { super(null, null); this.context = context; } /** * Returns the Servlet context to use for logging. * * @return The Servlet context to use for logging. */ private javax.servlet.ServletContext getContext() { return this.context; } /** * Log a LogRecord. * * @param record * The LogRecord to be published */ @Override public void log(LogRecord record) { if (record.getThrown() != null) { getContext().log(record.getMessage(), record.getThrown()); } else { getContext().log(record.getMessage()); } } }