Class ConfigurationEvent
java.lang.Object
java.util.EventObject
org.apache.commons.configuration2.event.Event
org.apache.commons.configuration2.event.ConfigurationEvent
- All Implemented Interfaces:
Serializable
An event class for reporting updates on a configuration object.
Event objects of this type are used for "raw" events, i.e. unfiltered modifications of any kind. A level with semantically higher events (e.g. for property changes) may be built on top of this fundamental event mechanism.
Each event can contain the following data:
- A source object, which is usually the configuration object that was modified.
- The event's type. This is an object that corresponds to constant declarations in specific event classes. It describes what exactly has happened.
- If available, the name of the property whose modification caused the event.
- If available, the value of the property that caused this event.
- A flag whether this event was generated before or after the update of the source configuration. A modification of a configuration typically causes two events: one event before and one event after the modification is performed. This allows event listeners to react at the correct point of time.
The following standard events are generated by typical configuration implementations (the constants for the event types are defined in this class:
- ADD_PROPERTY
- This event is triggered for each call of the
addProperty()
method of a configuration object. It contains the name of the property, to which new data is added, and the value object that is added to this property (this may be an array or a list if multiple values are added). - SET_PROPERTY
- Calling the
setProperty()
method triggers this event. The event object stores the name of the affected property and its new value. - CLEAR_PROPERTY
- If a property is removed from a configuration (by calling the
clearProperty()
method), an event of this type is fired. In this case the event object only stores the name of the removed property, the value is null. - CLEAR
- This event is fired when the whole configuration is cleared. The corresponding event object contains no additional data.
- Since:
- 1.3
- See Also:
-
Field Summary
Modifier and TypeFieldDescriptionstatic final EventType<ConfigurationEvent>
Constant for the event type for an add nodes operation.static final EventType<ConfigurationEvent>
Constant for the event type for an add property operation.static final EventType<ConfigurationEvent>
Constant for the common super type of all configuration update events.static final EventType<ConfigurationEvent>
Constant for the common base event type for all hierarchical update events.static final EventType<ConfigurationEvent>
Constant for the event type for a clear operation.static final EventType<ConfigurationEvent>
Constant for the event type for a clear property operation.static final EventType<ConfigurationEvent>
Constant for the event type for a clear tree operation.static final EventType<ConfigurationEvent>
Constant for the event type for a set property operation.static final EventType<ConfigurationEvent>
Constant for the event type indicating a change on a sub configuration.Fields inherited from class java.util.EventObject
source
-
Constructor Summary
ConstructorDescriptionConfigurationEvent
(Object source, EventType<? extends ConfigurationEvent> type, String propertyName, Object propertyValue, boolean beforeUpdate) Creates a new instance ofConfigurationEvent
and initializes it. -
Method Summary
Modifier and TypeMethodDescriptionGets the name of the affected property.Gets the value of the affected property if available.boolean
Returns a flag if this event was generated before or after an update.Methods inherited from class org.apache.commons.configuration2.event.Event
appendPropertyRepresentation, getEventType, toString
Methods inherited from class java.util.EventObject
getSource
-
Field Details
-
ANY
Constant for the common super type of all configuration update events.- Since:
- 2.0
-
ADD_PROPERTY
Constant for the event type for an add property operation.- Since:
- 2.0
-
SET_PROPERTY
Constant for the event type for a set property operation.- Since:
- 2.0
-
CLEAR_PROPERTY
Constant for the event type for a clear property operation.- Since:
- 2.0
-
CLEAR
Constant for the event type for a clear operation.- Since:
- 2.0
-
ANY_HIERARCHICAL
Constant for the common base event type for all hierarchical update events. Events derived from this type are generated by some specific methods of hierarchical configurations.- Since:
- 2.0
-
ADD_NODES
Constant for the event type for an add nodes operation.- Since:
- 2.0
-
CLEAR_TREE
Constant for the event type for a clear tree operation.- Since:
- 2.0
-
SUBNODE_CHANGED
Constant for the event type indicating a change on a sub configuration.- Since:
- 2.0
-
-
Constructor Details
-
ConfigurationEvent
public ConfigurationEvent(Object source, EventType<? extends ConfigurationEvent> type, String propertyName, Object propertyValue, boolean beforeUpdate) Creates a new instance ofConfigurationEvent
and initializes it.- Parameters:
source
- the event sourcetype
- the event's typepropertyName
- the name of the affected propertypropertyValue
- the value of the affected propertybeforeUpdate
- the before update flag
-
-
Method Details
-
getPropertyName
Gets the name of the affected property. This can be null if no property change has lead to this event.- Returns:
- the name of the property
-
getPropertyValue
Gets the value of the affected property if available.- Returns:
- the value of the property; can be null
-
isBeforeUpdate
Returns a flag if this event was generated before or after an update.- Returns:
- true if this event was generated before an update; false otherwise
-