/********************************************************* begin of preamble
**
** Copyright (C) 2003-2010 Software- und Organisations-Service GmbH.
** All rights reserved.
**
** This file may be used under the terms of either the
**
** GNU General Public License version 2.0 (GPL)
**
** as published by the Free Software Foundation
** http://www.gnu.org/licenses/gpl-2.0.txt and appearing in the file
** LICENSE.GPL included in the packaging of this file.
**
** or the
**
** Agreement for Purchase and Licensing
**
** as offered by Software- und Organisations-Service GmbH
** in the respective terms of supply that ship with this file.
**
** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
** IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
** THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
** PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
** BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
** CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
** SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
** INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
** CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
** ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
** POSSIBILITY OF SUCH DAMAGE.
********************************************************** end of preamble*/
/**
* I18N Messages and Logging
* Copyright (C) 2006 John J. Mazzitelli
*
* This library 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 library 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 library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
package com.sos.i18n.logging.jdk;
import com.sos.i18n.Msg;
import com.sos.i18n.Msg.BundleBaseName;
import com.sos.i18n.exception.LocalizedException;
import com.sos.i18n.exception.LocalizedRuntimeException;
import java.io.ByteArrayOutputStream;
import java.io.PrintStream;
import java.util.Locale;
import java.util.logging.Level;
import java.util.logging.Logger;
/**
* <p>This class provides alot of static methods to assist in logging localized messages via a JDK logging log
* object.</p>
*
* <p>There is a method to the madness in the parameter ordering. Anytime you want to specify a localized message,
* you always specify the base bundle name first, followed by the locale, the bundle key and the variable list of
* arguments that go with the keyed message (all in that order). Bundle name and locale are both optional. This is
* consistent with the way localized messages are specified in constructors for {@link LocalizedException} and
* {@link LocalizedRuntimeException}. When you need to specify a <code>Throwable</code> with your localized
* message, it is specified before those parameters. Again, this is consistent both in this class and the localized
* exception classes (see {@link JDKLogMsg#fatal(Logger, Throwable, Msg.BundleBaseName, Locale, String, Object[])}
* and {@link LocalizedException#LocalizedException(Throwable, Msg.BundleBaseName, Locale, String, Object[])} as
* examples).</p>
*
* <p>These static utility methods respect the settings defined by
* {@link com.sos.i18n.Logger#setDumpStackTraces(boolean)} and {@link com.sos.i18n.Logger#setDumpLogKeys(boolean)}.</p>
*
* <p>These are the mappings between the logical log levels and the actual JDK log levels:
*
* <ul>
* <li>FATAL -> SEVERE</li>
* <li>ERROR -> SEVERE</li>
* <li>WARN -> WARNING</li>
* <li>INFO -> INFO</li>
* <li>DEBUG -> FINE</li>
* <li>TRACE -> FINEST</li>
* </ul>
* </p>
*
* @author <a href="mailto:jmazzitelli@users.sourceforge.net">John Mazzitelli</a>
* @version $Revision: 1.1 $
* @see Msg
* @see LocalizedException
* @see LocalizedRuntimeException
*/
public class JDKLogMsg
{
/**
* Prevents instantiation.
*/
private JDKLogMsg()
{
}
/**
* Logs the given message to the log at the fatal level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param basename the base name of the resource bundle
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*
* @see Msg#createMsg(com.sos.i18n.Msg.BundleBaseName, Locale, String, Object[])
*/
public static Msg fatal( Logger log,
BundleBaseName basename,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( basename, locale, key, varargs );
log.severe( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the fatal level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param basename the base name of the resource bundle
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*
* @see Msg#createMsg(com.sos.i18n.Msg.BundleBaseName, Locale, String, Object[])
*/
public static Msg fatal( Logger log,
Throwable throwable,
BundleBaseName basename,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( basename, locale, key, varargs );
logFatalWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the fatal level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg fatal( Logger log,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( locale, key, varargs );
log.severe( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the fatal level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg fatal( Logger log,
Throwable throwable,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( locale, key, varargs );
logFatalWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the fatal level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param basename the base name of the resource bundle
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg fatal( Logger log,
BundleBaseName basename,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( basename, key, varargs );
log.severe( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the fatal level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param basename the base name of the resource bundle
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg fatal( Logger log,
Throwable throwable,
BundleBaseName basename,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( basename, key, varargs );
logFatalWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the fatal level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg fatal( Logger log,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( key, varargs );
log.severe( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the fatal level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg fatal( Logger log,
Throwable throwable,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( key, varargs );
logFatalWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the error level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param basename the base name of the resource bundle
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg error( Logger log,
BundleBaseName basename,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( basename, locale, key, varargs );
log.severe( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the error level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param basename the base name of the resource bundle
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg error( Logger log,
Throwable throwable,
BundleBaseName basename,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( basename, locale, key, varargs );
logErrorWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the error level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg error( Logger log,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( locale, key, varargs );
log.severe( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the error level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg error( Logger log,
Throwable throwable,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( locale, key, varargs );
logErrorWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the error level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param basename the base name of the resource bundle
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg error( Logger log,
BundleBaseName basename,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( basename, key, varargs );
log.severe( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the error level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param basename the base name of the resource bundle
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg error( Logger log,
Throwable throwable,
BundleBaseName basename,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( basename, key, varargs );
logErrorWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the error level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg error( Logger log,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( key, varargs );
log.severe( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the error level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg error( Logger log,
Throwable throwable,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.SEVERE ) )
{
Msg msg = Msg.createMsg( key, varargs );
logErrorWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the warn level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param basename the base name of the resource bundle
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg warn( Logger log,
BundleBaseName basename,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.WARNING ) )
{
Msg msg = Msg.createMsg( basename, locale, key, varargs );
log.warning( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the warn level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param basename the base name of the resource bundle
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg warn( Logger log,
Throwable throwable,
BundleBaseName basename,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.WARNING ) )
{
Msg msg = Msg.createMsg( basename, locale, key, varargs );
logWarnWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the warn level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg warn( Logger log,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.WARNING ) )
{
Msg msg = Msg.createMsg( locale, key, varargs );
log.warning( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the warn level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg warn( Logger log,
Throwable throwable,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.WARNING ) )
{
Msg msg = Msg.createMsg( locale, key, varargs );
logWarnWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the warn level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param basename the base name of the resource bundle
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg warn( Logger log,
BundleBaseName basename,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.WARNING ) )
{
Msg msg = Msg.createMsg( basename, key, varargs );
log.warning( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the warn level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param basename the base name of the resource bundle
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg warn( Logger log,
Throwable throwable,
BundleBaseName basename,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.WARNING ) )
{
Msg msg = Msg.createMsg( basename, key, varargs );
logWarnWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the warn level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg warn( Logger log,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.WARNING ) )
{
Msg msg = Msg.createMsg( key, varargs );
log.warning( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the warn level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg warn( Logger log,
Throwable throwable,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.WARNING ) )
{
Msg msg = Msg.createMsg( key, varargs );
logWarnWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the info level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param basename the base name of the resource bundle
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg info( Logger log,
BundleBaseName basename,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.INFO ) )
{
Msg msg = Msg.createMsg( basename, locale, key, varargs );
log.info( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the info level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param basename the base name of the resource bundle
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg info( Logger log,
Throwable throwable,
BundleBaseName basename,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.INFO ) )
{
Msg msg = Msg.createMsg( basename, locale, key, varargs );
logInfoWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the info level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg info( Logger log,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.INFO ) )
{
Msg msg = Msg.createMsg( locale, key, varargs );
log.info( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the info level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg info( Logger log,
Throwable throwable,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.INFO ) )
{
Msg msg = Msg.createMsg( locale, key, varargs );
logInfoWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the info level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param basename the base name of the resource bundle
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg info( Logger log,
BundleBaseName basename,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.INFO ) )
{
Msg msg = Msg.createMsg( basename, key, varargs );
log.info( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the info level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param basename the base name of the resource bundle
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg info( Logger log,
Throwable throwable,
BundleBaseName basename,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.INFO ) )
{
Msg msg = Msg.createMsg( basename, key, varargs );
logInfoWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the info level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg info( Logger log,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.INFO ) )
{
Msg msg = Msg.createMsg( key, varargs );
log.info( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the info level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg info( Logger log,
Throwable throwable,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.INFO ) )
{
Msg msg = Msg.createMsg( key, varargs );
logInfoWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the debug level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param basename the base name of the resource bundle
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg debug( Logger log,
BundleBaseName basename,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINE ) )
{
Msg msg = Msg.createMsg( basename, locale, key, varargs );
log.fine( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the debug level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param basename the base name of the resource bundle
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg debug( Logger log,
Throwable throwable,
BundleBaseName basename,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINE ) )
{
Msg msg = Msg.createMsg( basename, locale, key, varargs );
logDebugWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the debug level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg debug( Logger log,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINE ) )
{
Msg msg = Msg.createMsg( locale, key, varargs );
log.fine( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the debug level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg debug( Logger log,
Throwable throwable,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINE ) )
{
Msg msg = Msg.createMsg( locale, key, varargs );
logDebugWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the debug level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param basename the base name of the resource bundle
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg debug( Logger log,
BundleBaseName basename,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINE ) )
{
Msg msg = Msg.createMsg( basename, key, varargs );
log.fine( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the debug level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param basename the base name of the resource bundle
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg debug( Logger log,
Throwable throwable,
BundleBaseName basename,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINE ) )
{
Msg msg = Msg.createMsg( basename, key, varargs );
logDebugWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the debug level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg debug( Logger log,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINE ) )
{
Msg msg = Msg.createMsg( key, varargs );
log.fine( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the debug level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg debug( Logger log,
Throwable throwable,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINE ) )
{
Msg msg = Msg.createMsg( key, varargs );
logDebugWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the trace level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param basename the base name of the resource bundle
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg trace( Logger log,
BundleBaseName basename,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINEST ) )
{
Msg msg = Msg.createMsg( basename, locale, key, varargs );
log.finest( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the trace level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param basename the base name of the resource bundle
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg trace( Logger log,
Throwable throwable,
BundleBaseName basename,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINEST ) )
{
Msg msg = Msg.createMsg( basename, locale, key, varargs );
logTraceWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the trace level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg trace( Logger log,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINEST ) )
{
Msg msg = Msg.createMsg( locale, key, varargs );
log.finest( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the trace level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param locale the locale to determine what bundle to use
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg trace( Logger log,
Throwable throwable,
Locale locale,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINEST ) )
{
Msg msg = Msg.createMsg( locale, key, varargs );
logTraceWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the trace level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param basename the base name of the resource bundle
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg trace( Logger log,
BundleBaseName basename,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINEST ) )
{
Msg msg = Msg.createMsg( basename, key, varargs );
log.finest( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the trace level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param basename the base name of the resource bundle
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg trace( Logger log,
Throwable throwable,
BundleBaseName basename,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINEST ) )
{
Msg msg = Msg.createMsg( basename, key, varargs );
logTraceWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the trace level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* @param log the log where the messages will go
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg trace( Logger log,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINEST ) )
{
Msg msg = Msg.createMsg( key, varargs );
log.finest( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
return msg;
}
return null;
}
/**
* Logs the given message to the log at the trace level. If the log level is not enabled, this method does
* nothing and returns <code>null</code>. If a message was logged, its {@link Msg} will be returned.
*
* <p>The given Throwable will be passed to the logger so its stack can be dumped when appropriate.</p>
*
* @param log the log where the messages will go
* @param throwable the throwable associated with the log message
* @param key the resource bundle key name
* @param varargs arguments to help fill in the resource bundle message
*
* @return if the message was logged, a non-<code>null</code> Msg object is returned
*/
public static Msg trace( Logger log,
Throwable throwable,
String key,
Object... varargs )
{
if ( log.isLoggable( Level.FINEST ) )
{
Msg msg = Msg.createMsg( key, varargs );
logTraceWithThrowable( log, key, msg, throwable );
return msg;
}
return null;
}
/**
* Logs the message, along with the given <code>throwable</code>, at the fatal level. If
* {@link com.sos.i18n.Logger#getDumpStackTraces() stack traces are not to be dumped}, it doesn't matter. FATAL log
* level messages should be very rare and normally indicate a very bad condition. In this case, we should always
* dump the stack trace no matter how we are configured.
*
* @param log where to log the message
* @param key the resource key that is associated with the message
* @param msg the message to log
* @param throwable the throwable associated with the message
*/
private static void logFatalWithThrowable( Logger log,
String key,
Msg msg,
Throwable throwable )
{
log.severe( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() );
log.severe( getThrowableStackTrace( throwable ) );
}
/**
* Logs the message, along with the given <code>throwable</code>, at the error level. If
* {@link com.sos.i18n.Logger#getDumpStackTraces() stack traces are not to be dumped}, the logged message will be
* appended with the throwable's <code>Throwable.toString()</code> contents.
*
* @param log where to log the message
* @param key the resource key that is associated with the message
* @param msg the message to log
* @param throwable the throwable associated with the message
*/
private static void logErrorWithThrowable( Logger log,
String key,
Msg msg,
Throwable throwable )
{
if ( com.sos.i18n.Logger.getDumpStackTraces() )
{
log.severe( ( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() ) );
log.severe( getThrowableStackTrace( throwable ) );
}
else
{
log.severe( ( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg )
+ ". Cause: " + throwable.toString() );
}
}
/**
* Logs the message, along with the given <code>throwable</code>, at the warn level. If
* {@link com.sos.i18n.Logger#getDumpStackTraces() stack traces are not to be dumped}, the logged message will be
* appended with the throwable's <code>Throwable.toString()</code> contents.
*
* @param log where to log the message
* @param key the resource key that is associated with the message
* @param msg the message to log
* @param throwable the throwable associated with the message
*/
private static void logWarnWithThrowable( Logger log,
String key,
Msg msg,
Throwable throwable )
{
if ( com.sos.i18n.Logger.getDumpStackTraces() )
{
log.warning( ( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() ) );
log.warning( getThrowableStackTrace( throwable ) );
}
else
{
log.warning( ( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg )
+ ". Cause: " + throwable.toString() );
}
}
/**
* Logs the message, along with the given <code>throwable</code>, at the info level. If
* {@link com.sos.i18n.Logger#getDumpStackTraces() stack traces are not to be dumped}, the logged message will be
* appended with the throwable's <code>Throwable.toString()</code> contents.
*
* @param log where to log the message
* @param key the resource key that is associated with the message
* @param msg the message to log
* @param throwable the throwable associated with the message
*/
private static void logInfoWithThrowable( Logger log,
String key,
Msg msg,
Throwable throwable )
{
if ( com.sos.i18n.Logger.getDumpStackTraces() )
{
log.info( ( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() ) );
log.info( getThrowableStackTrace( throwable ) );
}
else
{
log.info( ( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg )
+ ". Cause: " + throwable.toString() );
}
}
/**
* Logs the message, along with the given <code>throwable</code>, at the debug level. If
* {@link com.sos.i18n.Logger#getDumpStackTraces() stack traces are not to be dumped}, the logged message will be
* appended with the throwable's <code>Throwable.toString()</code> contents.
*
* @param log where to log the message
* @param key the resource key that is associated with the message
* @param msg the message to log
* @param throwable the throwable associated with the message
*/
private static void logDebugWithThrowable( Logger log,
String key,
Msg msg,
Throwable throwable )
{
if ( com.sos.i18n.Logger.getDumpStackTraces() )
{
log.fine( ( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() ) );
log.fine( getThrowableStackTrace( throwable ) );
}
else
{
log.fine( ( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg )
+ ". Cause: " + throwable.toString() );
}
}
/**
* Logs the message, along with the given <code>throwable</code>, at the trace level. If
* {@link com.sos.i18n.Logger#getDumpStackTraces() stack traces are not to be dumped}, the logged message will be
* appended with the throwable's <code>Throwable.toString()</code> contents.
*
* @param log where to log the message
* @param key the resource key that is associated with the message
* @param msg the message to log
* @param throwable the throwable associated with the message
*/
private static void logTraceWithThrowable( Logger log,
String key,
Msg msg,
Throwable throwable )
{
if ( com.sos.i18n.Logger.getDumpStackTraces() )
{
log.finest( ( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg.toString() ) );
log.finest( getThrowableStackTrace( throwable ) );
}
else
{
log.finest( ( ( com.sos.i18n.Logger.getDumpLogKeys() ) ? ( '{' + key + '}' + msg ) : msg )
+ ". Cause: " + throwable.toString() );
}
}
/**
* Returns the stack trace of the given throwable.
*
* @param t the throwable whose stack trace is to be returned
*
* @return the stack trace as a multi-line string
*/
private static String getThrowableStackTrace( Throwable t )
{
ByteArrayOutputStream baos = new ByteArrayOutputStream();
t.printStackTrace( new PrintStream( baos ) );
return baos.toString();
}
}