Package org.apache.commons.logging.impl
Class SLF4JLogFactory
java.lang.Object
org.apache.commons.logging.LogFactory
org.apache.commons.logging.impl.SLF4JLogFactory
Concrete subclass of LogFactory
which always delegates to the
org.slf4j.LoggerFactory
class.
This factory generates instances of SLF4JLog
. It will remember
previously created instances for the same name, and will return them on
repeated requests to the getInstance()
method.
This implementation ignores any configured attributes.
- Author:
- Rod Waldhoff, Craig R. McClanahan, Richard A. Sitze, Ceki Gülcü
-
Field Summary
Modifier and TypeFieldDescriptionprotected Hashtable
Configuration attributes.static final String
The name of the system property identifying ourLog
implementation class.Fields inherited from class org.apache.commons.logging.LogFactory
DIAGNOSTICS_DEST_PROPERTY, factories, FACTORY_DEFAULT, FACTORY_PROPERTIES, FACTORY_PROPERTY, HASHTABLE_IMPLEMENTATION_PROPERTY, nullClassLoaderFactory, PRIORITY_KEY, SERVICE_ID, TCCL_KEY
-
Constructor Summary
ConstructorDescriptionPublic no-arguments constructor required by the lookup mechanism. -
Method Summary
Modifier and TypeMethodDescriptiongetAttribute
(String name) Return the configuration attribute with the specified name (if any), ornull
if there is no such attribute.String[]
Return an array containing the names of all currently defined configuration attributes.getInstance
(Class clazz) Convenience method to derive a name from the specified class and callgetInstance(String)
with it.getInstance
(String name) Construct (if necessary) and return aLog
instance, using the factory's current set of configuration attributes.void
release()
Release any internal references to previously createdLog
instances returned by this factory.void
removeAttribute
(String name) Remove any configuration attribute associated with the specified name.void
setAttribute
(String name, Object value) Set the configuration attribute with the specified name.Methods inherited from class org.apache.commons.logging.LogFactory
createFactory, directGetContextClassLoader, getClassLoader, getContextClassLoader, getFactory, getLog, getLog, isDiagnosticsEnabled, logRawDiagnostic, newFactory, newFactory, objectId, release, releaseAll
-
Field Details
-
LOG_PROPERTY
The name of the system property identifying ourLog
implementation class.- See Also:
-
attributes
Configuration attributes.
-
-
Constructor Details
-
SLF4JLogFactory
public SLF4JLogFactory()Public no-arguments constructor required by the lookup mechanism.
-
-
Method Details
-
getAttribute
Return the configuration attribute with the specified name (if any), ornull
if there is no such attribute.- Specified by:
getAttribute
in classLogFactory
- Parameters:
name
- Name of the attribute to return- Returns:
- configuration attribute
-
getAttributeNames
Return an array containing the names of all currently defined configuration attributes. If there are no such attributes, a zero length array is returned.- Specified by:
getAttributeNames
in classLogFactory
- Returns:
- names of all currently defined configuration attributes
-
getInstance
Convenience method to derive a name from the specified class and callgetInstance(String)
with it.- Specified by:
getInstance
in classLogFactory
- Parameters:
clazz
- Class for which a suitable Log name will be derived- Throws:
LogConfigurationException
- if a suitableLog
instance cannot be returned
-
getInstance
Construct (if necessary) and return a
Log
instance, using the factory's current set of configuration attributes.- Specified by:
getInstance
in classLogFactory
- Parameters:
name
- Logical name of theLog
instance to be returned (the meaning of this name is only known to the underlying logging implementation that is being wrapped)- Throws:
LogConfigurationException
- if a suitableLog
instance cannot be returned
-
release
Release any internal references to previously createdLog
instances returned by this factory. This is useful in environments like servlet containers, which implement application reloading by throwing away a ClassLoader. Dangling references to objects in that class loader would prevent garbage collection.- Specified by:
release
in classLogFactory
-
removeAttribute
Remove any configuration attribute associated with the specified name. If there is no such attribute, no action is taken.- Specified by:
removeAttribute
in classLogFactory
- Parameters:
name
- Name of the attribute to remove
-
setAttribute
Set the configuration attribute with the specified name. Calling this with anull
value is equivalent to callingremoveAttribute(name)
.- Specified by:
setAttribute
in classLogFactory
- Parameters:
name
- Name of the attribute to setvalue
- Value of the attribute to set, ornull
to remove any setting for this attribute
-