MezzanineEngine 
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
Public Member Functions | Friends | List of all members
Mezzanine::EventManager Class Reference

This is a container for Events and facilitates the transfer of data. More...

#include <eventmanager.h>

+ Inheritance diagram for Mezzanine::EventManager:
+ Collaboration diagram for Mezzanine::EventManager:

Public Member Functions

 EventManager ()
 Default constructor. More...
 
 EventManager (XML::Node &XMLNode)
 XML constructor. More...
 
virtual ~EventManager ()
 Default Deconstructor.
 
void AddEvent (EventBase *EventToAdd)
 Adds an event of any kind to the end of the Event Queue. More...
 
void AddPollingCheck (const Input::MetaCode &InputToTryPolling)
 Generates extra events each iteration of the main loop, based on user input polling. More...
 
virtual void Deinitialize ()
 Removes this manager from any necessary configuration so it can be safely disposed of. More...
 
std::list< EventGameWindow * > * GetAllGameWindowEvents ()
 This returns a complete list of all the Render Time events. More...
 
std::list< EventQuit * > * GetAllQuitEvents ()
 This returns a complete list of all the quit events. More...
 
std::list< EventBase * > * GetAllSpecificEvents (EventBase::EventType SpecificType)
 This returns a complete list of all the specified events. More...
 
std::list< EventUserInput * > * GetAllUserInputEvents ()
 This returns a complete list of all the User Input events. More...
 
EventPumpWorkUnitGetEventPumpWork ()
 Gets the work unit responsible for pumping events from the OS. More...
 
virtual String GetImplementationTypeName () const
 This Allows any manager name to be sent to a stream. Primarily used for logging. More...
 
virtual ManagerType GetInterfaceType () const
 This returns the type of this manager. More...
 
EventBaseGetNextEvent ()
 Return a pointer to the Next event. More...
 
EventGameWindowGetNextGameWindowEvent ()
 Returns a pointer to the Next GameWindow event. More...
 
EventQuitGetNextQuitEvent ()
 Returns a pointer to the Next EventQuit. More...
 
EventBaseGetNextSpecificEvent (EventBase::EventType SpecificType)
 Returns a pointer to the Next kind event of the Specified type. More...
 
EventUserInputGetNextUserInputEvent ()
 Returns a pointer to the Next User Input event. More...
 
size_t GetRemainingEventCount ()
 Gets a count of events. More...
 
virtual void Initialize ()
 Configures this manager for use prior to entering the main loop. More...
 
EventBasePopNextEvent ()
 Return a pointer to the Next event, and removes the Event from storage. More...
 
EventGameWindowPopNextGameWindowEvent ()
 Returns a pointer to the Next GameWindow event and removes it from the Que. More...
 
EventQuitPopNextQuitEvent ()
 Returns a pointer to the Next EventQuit and removes it from the Que. More...
 
EventBasePopNextSpecificEvent (EventBase::EventType SpecificType)
 Returns a pointer to the Next kind event of the Specified type, and removes it from the Que. More...
 
EventUserInputPopNextUserInputEvent ()
 Returns a pointer to the Next User Input event and removes it from the Que. More...
 
void RemoveAllSpecificEvents (EventBase::EventType SpecificType)
 This removes all the events of the specified type. More...
 
void RemoveEvent (EventBase *EventToRemove)
 Removes an event of any kind from the Event Queue. More...
 
void RemoveNextEvent ()
 Removes an Event From the que without looking at it. More...
 
void RemoveNextGameWindowEvent ()
 Removes the First GameWindow Event From the que without looking at it. More...
 
void RemoveNextQuitEvent ()
 Removes the First EventQuit From the que without looking at it. More...
 
void RemoveNextSpecificEvent (EventBase::EventType SpecificType)
 Returns a pointer to the Next kind event of the Specified type, and removes it from the Que. More...
 
void RemoveNextUserInputEvent ()
 Removes the First User Input Event From the que without looking at it. More...
 
void RemovePollingCheck (const Input::MetaCode &InputToStopPolling)
 Removes Events from the list(s) of what needs to be polled. More...
 
void UpdateEvents ()
 Pulls Events from the all the subsystems for use in the EventManager. More...
 
- Public Member Functions inherited from Mezzanine::ManagerBase
 ManagerBase ()
 Class constructor.
 
virtual ~ManagerBase ()
 Class destructor.
 
virtual String GetInterfaceTypeAsString () const
 Gets a string of the interface type of this manager. More...
 
bool IsInitialized () const
 Gets whether or not this manager has been initialized. More...
 
- Public Member Functions inherited from Mezzanine::Singleton< EventManager >
 Singleton ()
 Class constructor.
 
 ~Singleton ()
 Class destructor.
 

Friends

class EventWorkUnit
 
std::ostream & operator<< (std::ostream &stream, const Mezzanine::EventManager &Mgr)
 Serializes the passed Mezzanine::EventManager to XML. More...
 
std::istream & operator>> (std::istream &stream, Mezzanine::EventManager &Mgr)
 Deserialize a Mezzanine::EventManager. More...
 

Additional Inherited Members

- Public Types inherited from Mezzanine::ManagerBase
enum  ManagerType {
  MT_AudioManager = 1, MT_AnimationManager, MT_CollisionShapeManager, MT_CompositorManager,
  MT_GraphicsManager, MT_EventManager, MT_InputManager, MT_LogManager,
  MT_MaterialManager, MT_MeshManager, MT_NetworkManager, MT_ResourceManager,
  MT_ScriptingManager, MT_UIManager, MT_ActorManager = 100, MT_AreaEffectManager,
  MT_CameraManager, MT_DebrisManager, MT_PagingManager, MT_PhysicsManager,
  MT_SceneManager, MT_SoundScapeManager, MT_TerrainManager, MT_VehicleManager,
  MT_UserCreated = 512
}
 
- Static Public Member Functions inherited from Mezzanine::ManagerBase
static String GetTypeAsString (const ManagerType &ManagerType)
 Gets the string form of the type of manager. More...
 
static ManagerType GetTypeFromString (const String &ManagerName)
 Gets the type of manager requested from a string. More...
 
- Static Public Member Functions inherited from Mezzanine::Singleton< EventManager >
static EventManagerGetSingletonPtr ()
 Fetches a pointer to the singleton. More...
 
static bool SingletonValid ()
 Checks to see if the singleton pointer is valid. More...
 
- Protected Attributes inherited from Mezzanine::ManagerBase
bool Initialized
 Simple bool indicating whether or not this manager has been initialized. More...
 
EntresolTheEntresol
 The actual pointer to the Entresol core class. More...
 
- Static Protected Attributes inherited from Mezzanine::Singleton< EventManager >
static EventManagerSingletonPtr
 

Detailed Description

This is a container for Events and facilitates the transfer of data.

The Event Manager Exists to passed important information about Gamestate from where it is generated to where it is needed. It is the Game Developers option whether they want to grab events directly using the get functions that have filters, or if they want to get all the events at once from a central location and dispatch form there.
Since all User input comes in the form of events, this is also where user input Polling and optional input sources like Joysticks are controlled from.
All of these event are stored in an internal Queue and order is preserved. So the First item In will be the First Out (FIFO). This is not strictly a FIFO buffer, there are a number of functions for getting of managing specific kinds of events. Generally these 'Filtered' management functions Still return the first of those kinds of event.

Warning
Delete pointers you get from this. Anything can create events and Put them here, and anything can get them out, This means the simple way to not cause memory leaks is to have the routines extracting the events delete the events.
Currently this is not thread safe, even though it should be.

Definition at line 158 of file eventmanager.h.

Constructor & Destructor Documentation

Mezzanine::EventManager::EventManager ( )

Default constructor.

Todo:
TODO: Make the EventManager completely thread safe. IF this is completely thread safe, we can spawn numerous individual thread each accessing this and and the performance gain would almost scale directly with cpu core count increases. Look at boost scoped_lock

Definition at line 274 of file eventmanager.cpp.

Mezzanine::EventManager::EventManager ( XML::Node XMLNode)

XML constructor.

Parameters
XMLNodeThe node of the xml document to construct from.
Todo:
This class currently doesn't initialize anything from XML, if that changes this constructor needs to be expanded.

Definition at line 291 of file eventmanager.cpp.

Member Function Documentation

void Mezzanine::EventManager::AddEvent ( EventBase EventToAdd)

Adds an event of any kind to the end of the Event Queue.

Parameters
EventToAddThis is a pointer to an Event.

This adds the existing event to the Queue. Be careful this is not delete, and does not go out of scope. Deleting the Event is now the responsibilty of the code that pulls it out of Event Manager.

Definition at line 376 of file eventmanager.cpp.

void Mezzanine::EventManager::AddPollingCheck ( const Input::MetaCode InputToTryPolling)

Generates extra events each iteration of the main loop, based on user input polling.

Parameters
InputToTryPollingThis accepts a MetaCode and will try to watch for occurences like this one

This will trigger the input system to generate an event (or add to an exiting event) when polling for the given kind of event. Each Iteration of the main loop there will be a EventUserInput that created. That Event will Include all the normal metacodes for user input that happened, and it will also have a meta code for each time this function was called. The added metacode may be partialky ignored, the Metavalue is almost always ignored, and in a situation where the can only be one of a given input on a system, the ID is ignore and 0 is assumed.

Exceptions
Unsupported Polling Check on this PlatformWhen the metacode passed cannot be polled on this platform

Definition at line 645 of file eventmanager.cpp.

void Mezzanine::EventManager::Deinitialize ( )
virtual

Removes this manager from any necessary configuration so it can be safely disposed of.

Implements Mezzanine::ManagerBase.

Definition at line 672 of file eventmanager.cpp.

std::list< EventGameWindow * > * Mezzanine::EventManager::GetAllGameWindowEvents ( )

This returns a complete list of all the Render Time events.

This finds all the EventUserInput Events then creates a new list and returns that. This runs in linear time relative to the amounts of events.

Returns
This returns a list<EventGameWindow*> pointer which is this a subset of this classes event pointer list. Use this carefully, it can cause errors if used improperly. This list pointer must be deleted, but not the events in it.

Definition at line 538 of file eventmanager.cpp.

std::list< EventQuit * > * Mezzanine::EventManager::GetAllQuitEvents ( )

This returns a complete list of all the quit events.

This finds all the EventQuit Events then creates a new list and returns that. This runs in linear time relative to the amounts of events.

Warning
Something is wrong if you have more than a few quit events. These should be checked for in each iteration of the main loop.
Returns
This returns a std::list<EventQuit*> pointer which is this a subset of this classes event pointer list. Use this carefully, it can cause errors if used improperly. Additionally this list pointer must be deleted, but not the events in it.

Definition at line 568 of file eventmanager.cpp.

std::list< EventBase * > * Mezzanine::EventManager::GetAllSpecificEvents ( EventBase::EventType  SpecificType)

This returns a complete list of all the specified events.

This finds all the events that are of the specified type in the event manager, then creates a new list and return that. This runs in linear time relative to the amounts of events.

Warning
The pointers contained in this list must be used carefully. Do not delete them, this will cause errors.
Returns
This returns a std::list<EventBase*> pointer which is this a subset of this classes event pointer list. Use this carefully, it can cause errors if used improperly. Additionally this list pointer must be deleted, but not the events in it.

Definition at line 615 of file eventmanager.cpp.

std::list< EventUserInput * > * Mezzanine::EventManager::GetAllUserInputEvents ( )

This returns a complete list of all the User Input events.

This finds all the EventUserInput Events then creates a new list and returns that. This runs in linear time relative to the amounts of events.

Returns
This returns a std::list<EventUserInput*> pointer which is this a subset of this classes event pointer list. Use this carefully, it can cause errors if used improperly. Additionally this list pointer must be deleted, but not the events in it.

Definition at line 553 of file eventmanager.cpp.

EventPumpWorkUnit * Mezzanine::EventManager::GetEventPumpWork ( )

Gets the work unit responsible for pumping events from the OS.

Returns
Returns a pointer to the ActorUpdateWorkUnit used by this manager.

Definition at line 681 of file eventmanager.cpp.

String Mezzanine::EventManager::GetImplementationTypeName ( ) const
virtual

This Allows any manager name to be sent to a stream. Primarily used for logging.

Returns
This returns a String that contains the name.

Implements Mezzanine::ManagerBase.

Definition at line 690 of file eventmanager.cpp.

ManagerBase::ManagerType Mezzanine::EventManager::GetInterfaceType ( ) const
virtual

This returns the type of this manager.

This is intended to make using and casting from Manager base easier. With this is is possible to cast from ManagerBase to the correct Manager Type.

Returns
This returns a ManagerTypeName to identify what this can be safely cast to.

Implements Mezzanine::ManagerBase.

Definition at line 687 of file eventmanager.cpp.

EventBase * Mezzanine::EventManager::GetNextEvent ( )

Return a pointer to the Next event.

This returns a pointer to the next Event. It is advisable to use this for performance reasons because it runs in constant time. However it does not return a specific kind of event, and must be cast in order to use the true content. This returns a pointer to 0 if there are no events in the queue.

Returns
A pointer to a Event, that still needs to be removed from the event manager and deleted.

Definition at line 356 of file eventmanager.cpp.

EventGameWindow * Mezzanine::EventManager::GetNextGameWindowEvent ( )

Returns a pointer to the Next GameWindow event.

This Filtered event management function returns a pointer to the next GameWindow event. It is inadvisable to use this for performance reasons because it runs in linear time relative to the amount of events. However, it will return an immediately usable pointer for case where an extreme level of performance is not required. This returns a pointer to 0 if there are no GameWindow events in the que.

Returns
A pointer to a EventGameWindow, that still needs to be removed from the event manager and deleted.

Definition at line 529 of file eventmanager.cpp.

EventQuit * Mezzanine::EventManager::GetNextQuitEvent ( )

Returns a pointer to the Next EventQuit.

This Filtered event management function returns a pointer to the next EventQuit. It is inadvisable to use this for performance reasons because it runs in linear time relative to the amount of events. However, it will return an immediately usable pointer for case where an extreme level of performance is not required. This returns a pointer to 0 if there are no EventQuit events in the que.

Returns
A pointer to a EventQuit, that still needs to be removed from the event manager and deleted.

Definition at line 559 of file eventmanager.cpp.

EventBase * Mezzanine::EventManager::GetNextSpecificEvent ( EventBase::EventType  SpecificType)

Returns a pointer to the Next kind event of the Specified type.

Parameters
SpecificTypeThis is a Event::EventType that defines the type you want this to work with

This and the other NextSpecificEvent functions are the core of the Event Filtering System. In general the other filtering functions call one of these and does very little work on their own.
This performs a linear search starting with the oldest (first entered Events) and simply checks if it the of the correct type. Then this returns a pointer to the next event of the specified type, or returns a pointer to 0 if there are none of the correct pointers in the Que. It is inadvisable to use this for performance reasons because it runs in linear time relative to the amount of events.

Returns
A pointer to a EventUserInput, that still needs to be removed from the event manager and deleted.

Definition at line 574 of file eventmanager.cpp.

EventUserInput * Mezzanine::EventManager::GetNextUserInputEvent ( )

Returns a pointer to the Next User Input event.

This Filtered event management function returns a pointer to the next User Input event. It is inadvisable to use this for performance reasons because it runs in linear time relative to the amount of events. However, it will return an immediately usable pointer for case where an extreme level of performance is not required. This returns a pointer to 0 if there are no User Input events in the que.

Returns
A pointer to a EventUserInput, that still needs to be removed from the event manager and deleted.

Definition at line 544 of file eventmanager.cpp.

size_t Mezzanine::EventManager::GetRemainingEventCount ( )

Gets a count of events.

This returns a total count of all events stored in this EventManager.

Returns
This returns an unsigned integer with the amount of of total events

Definition at line 353 of file eventmanager.cpp.

void Mezzanine::EventManager::Initialize ( )
virtual

Configures this manager for use prior to entering the main loop.

Implements Mezzanine::ManagerBase.

Definition at line 663 of file eventmanager.cpp.

EventBase * Mezzanine::EventManager::PopNextEvent ( )

Return a pointer to the Next event, and removes the Event from storage.

This functions just like GetNextEvent , except that it also removes the item from the internal storage of the EventManager. This returns a pointer to 0 if there are no events in the que.

Returns
A pointer to a Event, that will need to be deleted once it has been used.

Definition at line 364 of file eventmanager.cpp.

EventGameWindow * Mezzanine::EventManager::PopNextGameWindowEvent ( )

Returns a pointer to the Next GameWindow event and removes it from the Que.

This Filtered event management function returns a pointer to the next GameWindow event. It is inadvisable to use this for performance reasons because it runs in linear time relative to the amount of events. However, it will return an immediately usable pointer for case where an extreme level of performance is not required. This returns a pointer to 0 if there are no GameWindow events in the que. This also removes the returned pointer form the Que.

Returns
A pointer to a EventGameWindow, that still needs to be removed from the event manager and deleted.

Definition at line 532 of file eventmanager.cpp.

EventQuit * Mezzanine::EventManager::PopNextQuitEvent ( )

Returns a pointer to the Next EventQuit and removes it from the Que.

This Filtered event management function returns a pointer to the next EventQuit. It is inadvisable to use this for performance reasons because it runs in linear time relative to the amount of events. However, it will return an immediately usable pointer for case where an extreme level of performance is not required. This returns a pointer to 0 if there are no EventQuit events in the que. This also removes the returned pointer form the Que.

Returns
A pointer to a EventQuit, that still needs to be removed from the event manager and deleted.

Definition at line 562 of file eventmanager.cpp.

EventBase * Mezzanine::EventManager::PopNextSpecificEvent ( EventBase::EventType  SpecificType)

Returns a pointer to the Next kind event of the Specified type, and removes it from the Que.

Parameters
SpecificTypeThis is a Event::EventType that defines the type you want this to work with

This is just like GetNextSpecificEvent(Event::EventType SpecificType) but it also removes the item from the Que.

Returns
A pointer to a EventUserInput, that still needs to be removed from the event manager and deleted.

Definition at line 588 of file eventmanager.cpp.

EventUserInput * Mezzanine::EventManager::PopNextUserInputEvent ( )

Returns a pointer to the Next User Input event and removes it from the Que.

This Filtered event management function returns a pointer to the next User Input event. It is inadvisable to use this for performance reasons because it runs in linear time relative to the amount of events. However, it will return an immediately usable pointer for case where an extreme level of performance is not required. This returns a pointer to 0 if there are no User Input events in the que. This also removes the returned pointer form the Que.

Returns
A pointer to a EventUserInput, that still needs to be removed from the event manager and deleted.

Definition at line 547 of file eventmanager.cpp.

void Mezzanine::EventManager::RemoveAllSpecificEvents ( EventBase::EventType  SpecificType)

This removes all the events of the specified type.

This finds all the events that are of the specified type in the event manager, then removes them.

Warning
This does not delete the events. This is a memory leak unless used with GetAllSpecificEvents so that the events can be tracked indeendantly, and deleted.

Definition at line 629 of file eventmanager.cpp.

void Mezzanine::EventManager::RemoveEvent ( EventBase EventToRemove)

Removes an event of any kind from the Event Queue.

Parameters
EventToRemovePointer to the event that will be removed.

In most cases you will want to use the PopNextEvent() methods when going through events. In some expert use cases however you may want to remove a specific event at an arbitrary place in the Queue. This is the method for doing so.

Definition at line 379 of file eventmanager.cpp.

void Mezzanine::EventManager::RemoveNextEvent ( )

Removes an Event From the que without looking at it.

This together with GetNextEvent() are the same as call PopNextEvent().

Warning
If you did not call GetNextEvent() and haven't deleted or stored, or somehow dealt with this pointer, then this is a memory leak. Don't use this unless you are certain you have taken care of the pointer appropriately
Exceptions
Thiscan throw any STL exception a que could. Any with likely throw some kind of except if called when there are no Events in the Que.

Definition at line 373 of file eventmanager.cpp.

void Mezzanine::EventManager::RemoveNextGameWindowEvent ( )

Removes the First GameWindow Event From the que without looking at it.

This together with GetNextGameWindowEvent() are the pretty much same as call PopNextGameWindowEvent().

Warning
If you did not call GetNextGameWindowEvent() and haven't deleted or stored, or somehow dealt with this pointer, then this is a memory leak. Don't use this unless you are certain you have taken care of the pointer appropriately
Exceptions
Thiscan throw any STL exception a queue could. And with likely throw some kind of except if called when there are no Events in the Que.

Definition at line 535 of file eventmanager.cpp.

void Mezzanine::EventManager::RemoveNextQuitEvent ( )

Removes the First EventQuit From the que without looking at it.

This together with GetNextQuitEvent() are the pretty much same as call PopNextQuitEvent().

Warning
If you did not call GetNextQuitEvent() and haven't deleted or stored, or somehow dealt with this pointer, then this is a memory leak. Don't use this unless you are certain you have taken care of the pointer appropriately
Exceptions
Thiscan throw any STL exception a queue could. And with likely throw some kind of except if called when there are no Events in the Que.

Definition at line 565 of file eventmanager.cpp.

void Mezzanine::EventManager::RemoveNextSpecificEvent ( EventBase::EventType  SpecificType)

Returns a pointer to the Next kind event of the Specified type, and removes it from the Que.

Parameters
SpecificTypeThis is a Event::EventType that defines the type you want this to work with

This is just like PopNextSpecificEvent(Event::EventType SpecificType) but exept it doesn't bother with any of the needed structure involved with returning data, and just removes the specific event from the Queue.

Warning
If you did not call GetNextSpecificEvent(Event::EventType SpecificType) and haven't deleted or stored, or somehow dealt with this pointer, then this is a memory leak. Don't use this unless you are certain you have taken care of the pointer appropriately.
Exceptions
Thiscan throw any STL exception a queue could. And with likely throw some kind of except if called when there are no Events in the Que.

Definition at line 603 of file eventmanager.cpp.

void Mezzanine::EventManager::RemoveNextUserInputEvent ( )

Removes the First User Input Event From the que without looking at it.

This together with GetNextUserInputEvent() are the pretty much same as call PopNextUserInputEvent().

Warning
If you did not call GetNextUserInputEvent() and haven't deleted or stored, or somehow dealt with this pointer, then this is a memory leak. Don't use this unless you are certain you have taken care of the pointer appropriately
Exceptions
Thiscan throw any STL exception a queue could. And with likely throw some kind of except if called when there are no Events in the Que.

Definition at line 550 of file eventmanager.cpp.

void Mezzanine::EventManager::RemovePollingCheck ( const Input::MetaCode InputToStopPolling)

Removes Events from the list(s) of what needs to be polled.

Parameters
InputToStopPollingThis accepts a MetaCode and will try to Remove Watches like this one

This will remove any check for polling that share the same inputcode and ID. This

Exceptions
Polling check not presentIs thrown

Definition at line 655 of file eventmanager.cpp.

void Mezzanine::EventManager::UpdateEvents ( )

Pulls Events from the all the subsystems for use in the EventManager.

The work this function does is already performed in the main loop. This only really needs to be used If a game developer chooses to use his own main loop. This adds system events, like EventQuit and Other Windows manager events, and if any user input event actions, this generates one EventUserInput that stores everythin that happened.

Definition at line 391 of file eventmanager.cpp.

Friends And Related Function Documentation

std::ostream& operator<< ( std::ostream &  stream,
const Mezzanine::EventManager Mgr 
)
friend

Serializes the passed Mezzanine::EventManager to XML.

Parameters
streamThe ostream to send the xml to.
Mgrthe Mezzanine::EventManager to be serialized
Returns
this returns the ostream, now with the serialized data

Definition at line 737 of file eventmanager.cpp.

std::istream& operator>> ( std::istream &  stream,
Mezzanine::EventManager Mgr 
)
friend

Deserialize a Mezzanine::EventManager.

Parameters
streamThe istream to get the xml from to (re)make the Mezzanine::EventManager.
Mgrthe Mezzanine::EventManager to be deserialized.
Returns
this returns the ostream, advanced past the Mezzanine::EventManager that was recreated onto Ev.

Definition at line 749 of file eventmanager.cpp.


The documentation for this class was generated from the following files: