StephaneLenclud@234: //
StephaneLenclud@234: using System;
StephaneLenclud@234: using System.Collections.Generic;
StephaneLenclud@234: using System.ComponentModel;
StephaneLenclud@234: using System.Linq;
StephaneLenclud@234: using System.Reflection;
StephaneLenclud@234: using System.Runtime.Serialization;
StephaneLenclud@234: using SharpLib.Utils;
StephaneLenclud@234:
StephaneLenclud@235:
StephaneLenclud@234: namespace SharpLib.Ear
StephaneLenclud@234: {
StephaneLenclud@234: ///
StephaneLenclud@234: /// Event Action Router (Ear) is a generic and extensible framework allowing users to execute actions in response to events.
StephaneLenclud@234: /// Users can implement their own events and actions.
StephaneLenclud@234: ///
StephaneLenclud@234: [DataContract]
Stephane@243: public class Manager: Object
StephaneLenclud@234: {
StephaneLenclud@234: ///
StephaneLenclud@234: /// Our events instances.
StephaneLenclud@234: ///
StephaneLenclud@234: [DataMember]
StephaneLenclud@234: public List Events;
StephaneLenclud@234:
StephaneLenclud@234:
StephaneLenclud@234: ///
StephaneLenclud@234: /// Executes after internalization took place.
StephaneLenclud@234: ///
Stephane@243: protected override void DoConstruct()
StephaneLenclud@234: {
Stephane@243: base.DoConstruct();
Stephane@243:
StephaneLenclud@234: if (Events == null)
StephaneLenclud@234: {
StephaneLenclud@234: Events = new List();
StephaneLenclud@234: }
Stephane@243:
Stephane@243: // TODO: Object properties should be constructed too
Stephane@243: foreach (Event e in Events)
Stephane@243: {
Stephane@243: e.Construct();
Stephane@243: }
StephaneLenclud@234:
StephaneLenclud@234: }
StephaneLenclud@234:
StephaneLenclud@234: ///
StephaneLenclud@234: /// Trigger the given event.
StephaneLenclud@234: ///
StephaneLenclud@234: ///
StephaneLenclud@260: public async void TriggerEvents() where T: class
StephaneLenclud@234: {
StephaneLenclud@234: //Only trigger enabled events matching the desired type
StephaneLenclud@234: foreach (Event e in Events.Where(e => e.GetType() == typeof(T) && e.Enabled))
StephaneLenclud@234: {
StephaneLenclud@260: await e.Trigger();
StephaneLenclud@234: }
StephaneLenclud@234: }
StephaneLenclud@234:
StephaneLenclud@237: ///
StephaneLenclud@237: /// Trigger the given event.
StephaneLenclud@237: ///
StephaneLenclud@237: ///
StephaneLenclud@260: public async void TriggerEvents(T aEvent) where T : class
StephaneLenclud@237: {
StephaneLenclud@237: //Only trigger events matching the desired type
StephaneLenclud@237: foreach (Event e in Events.Where(e => e.Equals(aEvent) && e.Enabled))
StephaneLenclud@237: {
StephaneLenclud@260: await e.Trigger();
StephaneLenclud@237: }
StephaneLenclud@237: }
StephaneLenclud@237:
StephaneLenclud@260: ///
StephaneLenclud@260: ///
StephaneLenclud@260: ///
StephaneLenclud@260: ///
StephaneLenclud@260: ///
StephaneLenclud@260: public async void TriggerEventsByName(string aName)
StephaneLenclud@260: {
StephaneLenclud@260: if (string.IsNullOrEmpty(aName))
StephaneLenclud@260: {
StephaneLenclud@262: //Just don't do that, that would be silly
StephaneLenclud@260: return;
StephaneLenclud@260: }
StephaneLenclud@262: // Only trigger events matching the desired type
StephaneLenclud@262: // Doing some safety checks as well to prevent crashing if name was left null for some reason
StephaneLenclud@262: // This was the case when loading existing settings after event Name was introduced
StephaneLenclud@262: foreach (Event e in Events.Where(e => !string.IsNullOrEmpty(e.Name) && aName.Equals(e.Name)))
StephaneLenclud@260: {
StephaneLenclud@260: await e.Trigger();
StephaneLenclud@260: }
StephaneLenclud@260: }
StephaneLenclud@260:
StephaneLenclud@260:
StephaneLenclud@260:
StephaneLenclud@234:
StephaneLenclud@234: ///
StephaneLenclud@234: /// Remove the specified action from the event it belongs too.
StephaneLenclud@234: ///
StephaneLenclud@234: ///
StephaneLenclud@234: public void RemoveAction(Action aAction)
StephaneLenclud@234: {
StephaneLenclud@234: foreach (Event e in Events)
StephaneLenclud@234: {
StephaneLenclud@234: if (e.Actions.Remove(aAction))
StephaneLenclud@234: {
StephaneLenclud@234: //We removed our action, we are done here.
StephaneLenclud@234: return;
StephaneLenclud@234: }
StephaneLenclud@234: }
StephaneLenclud@234: }
StephaneLenclud@234: }
StephaneLenclud@234: }