Class SimpleLogger
- All Implemented Interfaces:
Serializable
,Logger
Simple implementation of Logger
that sends all enabled log messages,
for all defined loggers, to the console (System.err
). The following
system properties are supported to configure the behavior of this logger:
org.slf4j.simpleLogger.logFile
- The output target which can be the path to a file, or the special values "System.out" and "System.err". Default is "System.err".org.slf4j.simpleLogger.cacheOutputStream
- If the output target is set to "System.out" or "System.err" (see preceding entry), by default, logs will be output to the latest value referenced bySystem.out/err
variables. By setting this parameter to true, the output stream will be cached, i.e. assigned once at initialization time and re-used independently of the current value referenced bySystem.out/err
.org.slf4j.simpleLogger.defaultLogLevel
- Default log level for all instances of SimpleLogger. Must be one of ("trace", "debug", "info", "warn", "error" or "off"). If not specified, defaults to "info".org.slf4j.simpleLogger.log.a.b.c
- Logging detail level for a SimpleLogger instance named "a.b.c". Right-side value must be one of "trace", "debug", "info", "warn", "error" or "off". When a SimpleLogger named "a.b.c" is initialized, its level is assigned from this property. If unspecified, the level of nearest parent logger will be used, and if none is set, then the value specified byorg.slf4j.simpleLogger.defaultLogLevel
will be used.org.slf4j.simpleLogger.showDateTime
- Set totrue
if you want the current date and time to be included in output messages. Default isfalse
org.slf4j.simpleLogger.dateTimeFormat
- The date and time format to be used in the output messages. The pattern describing the date and time format is defined bySimpleDateFormat
. If the format is not specified or is invalid, the number of milliseconds since start up will be output.org.slf4j.simpleLogger.showThreadName
-Set totrue
if you want to output the current thread name. Defaults totrue
.- (since version 1.7.33 and 2.0.0-alpha6)
org.slf4j.simpleLogger.showThreadId
- If you would like to output the current thread id, then set totrue
. Defaults tofalse
. org.slf4j.simpleLogger.showLogName
- Set totrue
if you want the Logger instance name to be included in output messages. Defaults totrue
.org.slf4j.simpleLogger.showShortLogName
- Set totrue
if you want the last component of the name to be included in output messages. Defaults tofalse
.org.slf4j.simpleLogger.levelInBrackets
- Should the level string be output in brackets? Defaults tofalse
.org.slf4j.simpleLogger.warnLevelString
- The string value output for the warn level. Defaults toWARN
.
In addition to looking for system properties with the names specified above,
this implementation also checks for a class loader resource named
"simplelogger.properties"
, and includes any matching definitions
from this resource (if it exists).
With no configuration, the default output includes the relative time in milliseconds, thread name, the level, logger name, and the message followed by the line separator for the host. In log4j terms it amounts to the "%r [%t] %level %logger - %m%n" pattern.
Sample output follows.
176 [main] INFO examples.Sort - Populating an array of 2 elements in reverse order. 225 [main] INFO examples.SortAlgo - Entered the sort method. 304 [main] INFO examples.SortAlgo - Dump of integer array: 317 [main] INFO examples.SortAlgo - Element [0] = 0 331 [main] INFO examples.SortAlgo - Element [1] = 1 343 [main] INFO examples.Sort - The next log statement should be an error message. 346 [main] ERROR examples.SortAlgo - Tried to dump an uninitialized array. at org.log4j.examples.SortAlgo.dump(SortAlgo.java:58) at org.log4j.examples.Sort.main(Sort.java:64) 467 [main] INFO examples.Sort - Exiting main method.
This implementation is heavily inspired by Apache Commons Logging's SimpleLog.
- Author:
- Ceki Gülcü, Scott Sanders, Rod Waldhoff, Robert Burrell Donkin, Cédrik LIME
- See Also:
-
Field Summary
Modifier and TypeFieldDescriptionstatic final String
protected int
The current log levelstatic final String
static final String
static final String
static final String
static final String
protected static final int
protected static final int
protected static final int
protected static final int
protected static final int
protected static final int
static final String
static final String
static final String
static final String
static final String
static final String
All system properties used bySimpleLogger
start with this prefixstatic final String
Fields inherited from class org.slf4j.helpers.AbstractLogger
name
Fields inherited from interface org.slf4j.Logger
ROOT_LOGGER_NAME
-
Constructor Summary
ModifierConstructorDescriptionprotected
SimpleLogger
(String name) Protected access allows onlySimpleLoggerFactory
and also derived classes to instantiate SimpleLogger instances. -
Method Summary
Modifier and TypeMethodDescriptionprotected String
protected void
handleNormalizedLoggingCall
(Level level, Marker marker, String messagePattern, Object[] arguments, Throwable throwable) SimpleLogger's implementation ofAbstractLogger#handleNormalizedLoggingCall
}boolean
Aredebug
messages currently enabled?boolean
Areerror
messages currently enabled?boolean
Areinfo
messages currently enabled?protected boolean
isLevelEnabled
(int logLevel) Is the given log level currently enabled?boolean
Aretrace
messages currently enabled?boolean
Arewarn
messages currently enabled?void
log
(LoggingEvent event) protected String
renderLevel
(int levelInt) protected void
writeThrowable
(Throwable t, PrintStream targetStream) Methods inherited from class org.slf4j.helpers.LegacyAbstractLogger
isDebugEnabled, isErrorEnabled, isInfoEnabled, isTraceEnabled, isWarnEnabled
Methods inherited from class org.slf4j.helpers.AbstractLogger
debug, debug, debug, debug, debug, debug, debug, debug, debug, debug, error, error, error, error, error, error, error, error, error, error, getName, info, info, info, info, info, info, info, info, info, info, readResolve, trace, trace, trace, trace, trace, trace, trace, trace, trace, trace, warn, warn, warn, warn, warn, warn, warn, warn, warn, warn
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface org.slf4j.Logger
atDebug, atError, atInfo, atLevel, atTrace, atWarn, isEnabledForLevel, makeLoggingEventBuilder
-
Field Details
-
LOG_LEVEL_TRACE
- See Also:
-
LOG_LEVEL_DEBUG
- See Also:
-
LOG_LEVEL_INFO
- See Also:
-
LOG_LEVEL_WARN
- See Also:
-
LOG_LEVEL_ERROR
- See Also:
-
LOG_LEVEL_OFF
- See Also:
-
currentLogLevel
The current log level -
SYSTEM_PREFIX
All system properties used bySimpleLogger
start with this prefix- See Also:
-
LOG_KEY_PREFIX
- See Also:
-
CACHE_OUTPUT_STREAM_STRING_KEY
- See Also:
-
WARN_LEVEL_STRING_KEY
- See Also:
-
LEVEL_IN_BRACKETS_KEY
- See Also:
-
LOG_FILE_KEY
- See Also:
-
SHOW_SHORT_LOG_NAME_KEY
- See Also:
-
SHOW_LOG_NAME_KEY
- See Also:
-
SHOW_THREAD_NAME_KEY
- See Also:
-
SHOW_THREAD_ID_KEY
- See Also:
-
DATE_TIME_FORMAT_KEY
- See Also:
-
SHOW_DATE_TIME_KEY
- See Also:
-
DEFAULT_LOG_LEVEL_KEY
- See Also:
-
-
Constructor Details
-
SimpleLogger
Protected access allows onlySimpleLoggerFactory
and also derived classes to instantiate SimpleLogger instances.
-
-
Method Details
-
writeThrowable
-
isLevelEnabled
Is the given log level currently enabled?- Parameters:
logLevel
- is this level enabled?- Returns:
- whether the logger is enabled for the given level
-
isTraceEnabled
Aretrace
messages currently enabled?- Returns:
- True if this Logger is enabled for the TRACE level, false otherwise.
-
isDebugEnabled
Aredebug
messages currently enabled?- Returns:
- True if this Logger is enabled for the DEBUG level, false otherwise.
-
isInfoEnabled
Areinfo
messages currently enabled?- Returns:
- True if this Logger is enabled for the INFO level, false otherwise.
-
isWarnEnabled
Arewarn
messages currently enabled?- Returns:
- True if this Logger is enabled for the WARN level, false otherwise.
-
isErrorEnabled
Areerror
messages currently enabled?- Returns:
- True if this Logger is enabled for the ERROR level, false otherwise.
-
handleNormalizedLoggingCall
protected void handleNormalizedLoggingCall(Level level, Marker marker, String messagePattern, Object[] arguments, Throwable throwable) SimpleLogger's implementation ofAbstractLogger#handleNormalizedLoggingCall
}- Specified by:
handleNormalizedLoggingCall
in classAbstractLogger
- Parameters:
level
- the SLF4J level for this eventmarker
- The marker to be used for this event, may be null.messagePattern
- The message pattern which will be parsed and formattedarguments
- the array of arguments to be formatted, may be nullthrowable
- The exception whose stack trace should be logged, may be null
-
renderLevel
-
log
-
getFullyQualifiedCallerName
- Specified by:
getFullyQualifiedCallerName
in classAbstractLogger
-