using System; using UnityEngine; using UnityEngine.Assertions; namespace UnityAtoms { /// /// A Variable Instancer is a MonoBehaviour that takes a variable as a base and creates an in memory copy of it OnEnable. /// This is handy when you want to use atoms for prefabs that are instantiated at runtime. Use together with AtomCollection to /// react accordingly when a prefab with an assoicated atom is added or deleted to the scene. /// /// Variable of type T. /// IPair of type `T`. /// The value type. /// Event of type T. /// Event x 2 of type T. /// Function of type T => T [EditorIcon("atom-icon-hotpink")] [DefaultExecutionOrder(Runtime.ExecutionOrder.VARIABLE_INSTANCER)] public abstract class AtomBaseVariableInstancer : MonoBehaviour, IVariable where V : AtomBaseVariable { /// /// Getter for retrieving the in memory runtime variable. /// public V Variable { get => _inMemoryCopy; } /// /// Getter for retrieving the value of the in memory runtime variable. /// public T Value { get => _inMemoryCopy.Value; set => _inMemoryCopy.Value = value; } public virtual V Base { get => _base; } [SerializeField] [ReadOnly] protected V _inMemoryCopy = default(V); /// /// The variable that the in memory copy will be based on when created at runtime. /// [SerializeField] protected V _base = null; /// /// Override to add implementation specific setup on `OnEnable`. /// protected virtual void ImplSpecificSetup() { } private void OnEnable() { if (Base == null) { _inMemoryCopy = ScriptableObject.CreateInstance(); } else { _inMemoryCopy = Instantiate(Base); } ImplSpecificSetup(); } } }