| 
 | WebObjects 5.2.3 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||
java.lang.Objectcom.webobjects.eocontrol.EOEventCenter
EOEventCenter collects and manages EOEvents to measure the duration of operations in any applications. Measurements allow you to profile an application and optimize its execution time. For this, Enterprise Objects Framework and WebObjects instrument key portions of their code to measure the elapsed time of functions and methods.
The event logging system defined by EOEventCenter and EOEvent allow the measurement of the length of certain instrumented operations. An EOEvent keeps information (such as duration and type) about a logged event, and an EOEventCenter manages those events. EOEvent is an abstract class whose subclasses are responsible for defining the events they track. For example, there are (private) subclasses for adaptor events, editing context events, WOApplication events, and so on. To enable event logging in an application, simply open the WOEventSetup page as described in WOEventSetup and enable logging for the event classes.
In addition to the framework support, the WOExtensions framework provides components for using the feature. WOEventSetup is a page used to configure event logging, and WOEventDisplay is a page that displays event information.
See EOEventCenterConcepts for more information.
EOEvent, 
WOEventSetup| Nested Class Summary | |
| static interface | EOEventCenter.EventRecordingHandlerThe EOEventCenter.EventRecordingHandler interface declares the setLoggingEnabledmethod, which is invoked by the event-logging
 system when logging is enabled or disabled for an event class. | 
| Field Summary | |
| static String | EventLoggingEnabledName of the system property (a Boolean value) defining whether or not to log registered event classes by default. | 
| static String | EventLoggingLimitName of the system property (an Integer value) defining the maximum size of the event logging stack. | 
| static String | EventLoggingOverflowDisplayName of the system property (a Boolean value) defining whether an event log overflow should be logged. | 
| static String | EventLoggingPasswordName of the system property (a String value) defining the password which allows access to event logging information. | 
| Constructor Summary | |
| EOEventCenter()Creates a new event center. | |
| Method Summary | |
| static NSArray | allCenters()Returns all event centers. | 
|  NSArray | allEvents()Returns an array of the receiver's events (in no particular order). | 
| static NSArray | allEventsForAllCenters()Returns an array of all events logged in all the event centers (in no particular order). | 
| static void | cancelEvent(EOEvent anEvent)Cancels the recording of an in-progress event. | 
| static EOEventCenter | currentCenter()Returns the event center for the calling thread. | 
|  NSArray | eventsOfClass(Class aClass,
              String type)Returns the subset of the receiver's events that are instances of aClassand that have the typetype. | 
| static NSArray | eventsOfClassForAllCenters(Class aClass,
                           String type)Returns an array of all events (from all the event centers) that are instances of aClassand whose type istype. | 
| static void | markAtomicEvent(EOEvent anEvent,
                Object info)Marks anEvent, a newly created event, as an atomic event,
 and assigns it's info toinfo. | 
| static void | markEndOfEvent(EOEvent anEvent)Marks the time anEventended. | 
| static void | markStartOfEvent(EOEvent anEvent,
                 Object info)Marks anEvent, a newly created event, to be a branch event (that
 possibly has nested subevents), and assigns it's info toinfo. | 
| static EOEvent | newEventOfClass(Class aClass,
                String type)Creates an event of the desired class and type. | 
| static String | password()Returns the password which allows access to event logging information. | 
| static boolean | recordsEventsForClass(Class eventClass)Returns trueif the application logs events of theeventClassclass, orfalseotherwise. | 
| static NSArray | registeredEventClasses()Returns an array of all event classes registered in the application. | 
| static void | registerEventClass(Class aClass,
                   EOEventCenter.EventRecordingHandler handler)Registers aClassas an event class. | 
|  void | resetLogging()Discards all events in the event center for the calling thread. | 
| static void | resetLoggingForAllCenters()Discards all events in all event centers, restarting event collection for the entire application (that is, for all threads). | 
| static void | resumeLogging()Resumes event logging in all centers. | 
|  NSArray | rootEvents()Returns the receiver's events that were recorded at the root level; that is, returns the events that don't have a parent event. | 
| static NSArray | rootEventsByDuration()Returns the events from all event centers that are recorded at root level, sorted by decreasing duration. | 
| static NSArray | rootEventsForAllCenters()Returns the events from all event centers that are recorded at root level. | 
| static void | setPassword(String p)Sets the password which allows access to event logging information. | 
| static void | setRecordsEvents(boolean flag,
                 Class eventClass)Sets according to flagwhether event centers record events of theeventClassclass (and its subclasses). | 
| static void | suspendLogging()Suspends event logging in all event centers. | 
| Methods inherited from class java.lang.Object | 
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Field Detail | 
public static final String EventLoggingEnabled
public static final String EventLoggingLimit
public static final String EventLoggingOverflowDisplay
public static final String EventLoggingPassword
The String value is "EOEventLoggingPassword".
| Constructor Detail | 
public EOEventCenter()
currentCenter
 instead of via this constructor.
currentCenter()| Method Detail | 
public static NSArray allCenters()
currentCenter()public NSArray allEvents()
allEventsForAllCenters()public static NSArray allEventsForAllCenters()
allEvents()public static void cancelEvent(EOEvent anEvent)
Cancels the recording of an in-progress event. This method doesn't work with atomic events or with events that have already been ended with markEndOfEvent.
Generally an event will be canceled when the operation being logged is
 aborted. For example, an adaptor channel cancels an "Open Channel"
 event if the openChannel method doesn't successfully
 open a connection to the database.
anEvent - the event to cancelmarkEndOfEvent(EOEvent)public static EOEventCenter currentCenter()
allCenters()
public NSArray eventsOfClass(Class aClass,
                             String type)
aClass and that have the type type.
 Specifying null for the class returns events of any class. Similarly,
 specifying null for the type returns events of any type.
aClass - the event class to look fortype - the type of the events to look for
public static NSArray eventsOfClassForAllCenters(Class aClass,
                                                 String type)
aClass and whose type is type.
 Specifying null for the class returns events of any class. Similarly,
 specifying null for the type returns events of any type.
aClass - the event class to look fortype - the type of the events to look for
eventsOfClass(Class, String)
public static void markAtomicEvent(EOEvent anEvent,
                                   Object info)
anEvent, a newly created event, as an atomic event,
 and assigns it's info to info. The new event object is usually
 created with newEventOfClass.
anEvent - the event to markinfo - the event infonewEventOfClass(Class, String)public static void markEndOfEvent(EOEvent anEvent)
anEvent ended.
anEvent - the event whose ending is logged
public static void markStartOfEvent(EOEvent anEvent,
                                    Object info)
Marks anEvent, a newly created event, to be a branch event (that
 possibly has nested subevents), and assigns it's info to info.
 The new event object is usually created with newEventOfClass.
There is a limit on the number of events the event logging system
 logs. This is 200,000 by default, but can be changed using the system
 property EOEventLoggingLimit. When the logging limit is reached,
 the logging system attempts to purge old events before logging new
 ones. If the system is unable to purge old events, event logging
 is aborted.
The system's attempt to purge events can fail if the event logging limit is too small. This happens because the event system can't purge the first event logged, and it can't purge unclosed branch events.
anEvent - the event to markinfo - the event infonewEventOfClass(Class, String)
public static EOEvent newEventOfClass(Class aClass,
                                      String type)
aClass - the event class to instantiatetype - the type of the event for the class
EOEvent.setType(String)public static String password()
public static boolean recordsEventsForClass(Class eventClass)
true if the application logs events of the
 eventClass class, or false otherwise.
eventClass - the event class to check
true if the application logs events of the event class; false otherwisesetRecordsEvents(boolean, Class), 
registerEventClass(Class, EOEventCenter.EventRecordingHandler)
public static void registerEventClass(Class aClass,
                                      EOEventCenter.EventRecordingHandler handler)
Registers aClass as an event class. The handler
 is the object that the event logging system notifies when event logging
 is enabled or disabled for aClass.
If the EOEventLoggingEnabled system property is set to
 true, this method enables logging for aClass.
 Programmatically, you can selectively enable or disable logging for a
 specific class with setRecordsEvents.
When the event logging system enables logging for the event class, it
 sends handler a setLoggingEnabled message with
 true as the flag and aClass as the event class.
 handler is responsible for enabling logging in the instrumented
 code.
aClass - the class to be registeredhandler - the object notified by event logging system when logging is enabled or disabledsetRecordsEvents(boolean, Class), 
EOEventCenter.EventRecordingHandlerpublic static NSArray registeredEventClasses()
public void resetLogging()
resetLoggingForAllCenters()public static void resetLoggingForAllCenters()
resetLogging()public static void resumeLogging()
suspendLogging is paired
 with an invocation of resumeLogging. Invoking
 resumeLogging without a corresponding
 suspendLogging isn't harmful.
suspendLogging()public NSArray rootEvents()
rootEventsForAllCenters(), 
rootEventsByDuration()public static NSArray rootEventsByDuration()
rootEventsForAllCenters(), 
rootEvents()public static NSArray rootEventsForAllCenters()
rootEvents(), 
rootEventsByDuration()public static void setPassword(String p)
p - the password
public static void setRecordsEvents(boolean flag,
                                    Class eventClass)
flag whether event centers record events of the
 eventClass class (and its subclasses). By default, event centers
 don't record events of any class. You can selectively enable logging
 for a particular event class with this method. To enable event logging
 for all event classes, set the system property EOEventLoggingEnabled.
 Then, you can selectively disable logging for a particular event with this method.
flag - true if event centers should record events of the event class; false otherwiseeventClass - the class for which events should be recorded or notrecordsEventsForClass(Class), 
registerEventClass(Class, EOEventCenter.EventRecordingHandler)public static void suspendLogging()
suspendLogging must be paired with an invocation of
 resumeLogging to resume event logging.
resumeLogging()| 
 | Last updated Thu Oct 21 15:04:16 PDT 2004. | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||