unity-atoms/Packages/Core/Runtime/Actions/AtomAction.cs
IceTrooper be6a479bc1 #84 parameterless atom listener (#86)
* added base class for AtomAction; modified VoidAction; added Register/UnregisterListener to non-generic AtomEvent; added parameterless AtomListener; small polishing

* removed EditorIcon from AtomAction; fixed misspelled word in AtomEvent
2019-11-26 20:12:54 +01:00

200 lines
6.0 KiB
C#

using System;
using UnityEngine;
namespace UnityAtoms
{
/// <summary>
/// Base abstract class for Actions. Inherits from `BaseAtom`.
/// </summary>
public abstract class AtomAction : BaseAtom
{
/// <summary>
/// The actual Action.
/// </summary>
[HideInInspector]
public Action ActionNoValue;
/// <summary>
/// Perform the Action.
/// </summary>
public virtual void Do()
{
if (ActionNoValue != null)
{
ActionNoValue();
return;
}
}
}
/// <summary>
/// Generic abstract base class for Actions. Inherits from `AtomAction`.
/// </summary>
/// <typeparam name="T1">The type for this Action.</typeparam>
public abstract class AtomAction<T1> : AtomAction
{
/// <summary>
/// The actual Action.
/// </summary>
[HideInInspector]
public Action<T1> Action;
/// <summary>
/// Perform the Action.
/// </summary>
/// <param name="t1">The first parameter.</param>
public virtual void Do(T1 t1)
{
base.Do();
if (Action != null)
{
Action(t1);
return;
}
throw new Exception("Either set Action or override the Do method.");
}
}
/// <summary>
/// Generic abstract base class for Actions. Inherits from `AtomAction`.
/// </summary>
/// <typeparam name="T1">The first type for this Action.</typeparam>
/// <typeparam name="T2">The second type for this Action.</typeparam>
public abstract class AtomAction<T1, T2> : AtomAction
{
/// <summary>
/// The actual Action.
/// </summary>
[HideInInspector]
public Action<T1, T2> Action;
/// <summary>
/// Perform the Action.
/// </summary>
/// <param name="t1">The first parameter.</param>
/// <param name="t2">The second parameter.</param>
public virtual void Do(T1 t1, T2 t2)
{
base.Do();
if (Action != null)
{
Action(t1, t2);
return;
}
throw new Exception("Either set Action or override the Do method.");
}
}
/// <summary>
/// Generic abstract base class for Actions. Inherits from `AtomAction`.
/// </summary>
/// <typeparam name="T1">The first type for this Action.</typeparam>
/// <typeparam name="T2">The second type for this Action.</typeparam>
/// <typeparam name="T3">The third type for this Action.</typeparam>
public abstract class AtomAction<T1, T2, T3> : AtomAction
{
/// <summary>
/// The actual Action.
/// </summary>
[HideInInspector]
public Action<T1, T2, T3> Action;
/// <summary>
/// Perform the Action.
/// </summary>
/// <param name="t1">The first parameter.</param>
/// <param name="t2">The second parameter.</param>
/// <param name="t3">The third parameter.</param>
public virtual void Do(T1 t1, T2 t2, T3 t3)
{
base.Do();
if (Action != null)
{
Action(t1, t2, t3);
return;
}
throw new Exception("Either set Action or override the Do method.");
}
}
/// <summary>
/// Generic abstract base class for Actions. Inherits from `AtomAction`.
/// </summary>
/// <typeparam name="T1">The first type for this Action.</typeparam>
/// <typeparam name="T2">The second type for this Action.</typeparam>
/// <typeparam name="T3">The third type for this Action.</typeparam>
/// <typeparam name="T4">The fourth type for this Action.</typeparam>
public abstract class AtomAction<T1, T2, T3, T4> : AtomAction
{
/// <summary>
/// The actual Action.
/// </summary>
[HideInInspector]
public Action<T1, T2, T3, T4> Action;
/// <summary>
/// Perform the Action.
/// </summary>
/// <param name="t1">The first parameter.</param>
/// <param name="t2">The second parameter.</param>
/// <param name="t3">The third parameter.</param>
/// <param name="t4">The fourth parameter.</param>
public virtual void Do(T1 t1, T2 t2, T3 t3, T4 t4)
{
base.Do();
if (Action != null)
{
Action(t1, t2, t3, t4);
return;
}
throw new Exception("Either set Action or override the Do method.");
}
}
/// <summary>
/// Generic abstract base class for Actions. Inherits from `AtomAction`.
/// </summary>
/// <typeparam name="T1">The first type for this Action.</typeparam>
/// <typeparam name="T2">The second type for this Action.</typeparam>
/// <typeparam name="T3">The third type for this Action.</typeparam>
/// <typeparam name="T4">The fourth type for this Action.</typeparam>
/// <typeparam name="T5">The fifth type for this Action.</typeparam>
public abstract class AtomAction<T1, T2, T3, T4, T5> : AtomAction
{
/// <summary>
/// The actual Action.
/// </summary>
[HideInInspector]
public Action<T1, T2, T3, T4, T5> Action;
/// <summary>
/// Perform the Action.
/// </summary>
/// <param name="t1">The first parameter.</param>
/// <param name="t2">The second parameter.</param>
/// <param name="t3">The third parameter.</param>
/// <param name="t4">The fourth parameter.</param>
/// <param name="t5">The fifth parameter.</param>
public virtual void Do(T1 t1, T2 t2, T3 t3, T4 t4, T5 t5)
{
base.Do();
if (Action != null)
{
Action(t1, t2, t3, t4, t5);
return;
}
throw new Exception("Either set Action or override the Do method.");
}
}
}