From e846c64d6f927879cb8a095e62d773a8d7b3c9f4 Mon Sep 17 00:00:00 2001 From: chai Date: Thu, 15 Oct 2020 07:24:10 +0800 Subject: *ability system --- .../AdvancedInspector/Attributes/Constructor.cs | 82 ++++++++++++++++++++++ 1 file changed, 82 insertions(+) create mode 100644 Assets/Plugins/AdvancedInspector/Attributes/Constructor.cs (limited to 'Assets/Plugins/AdvancedInspector/Attributes/Constructor.cs') diff --git a/Assets/Plugins/AdvancedInspector/Attributes/Constructor.cs b/Assets/Plugins/AdvancedInspector/Attributes/Constructor.cs new file mode 100644 index 00000000..1b3f7438 --- /dev/null +++ b/Assets/Plugins/AdvancedInspector/Attributes/Constructor.cs @@ -0,0 +1,82 @@ +using System; +using System.Collections.Generic; +using System.Reflection; + +using UnityEngine; + +namespace AdvancedInspector +{ + /// + /// Some object cannot be created with an empty constructor. + /// This runtime attribute lets you create the object by yourself. + /// + [AttributeUsage(AttributeTargets.Field | AttributeTargets.Property)] + public class ConstructorAttribute : Attribute, IRuntimeAttribute + { + public delegate object ConstructorDelegate(); + public delegate object ConstructorStaticDelegate(ConstructorAttribute constructor, object instance, object value); + + #region IRuntime Implementation + private string methodName = ""; + + public string MethodName + { + get { return methodName; } + } + + public Type Template + { + get { return typeof(ConstructorDelegate); } + } + + public Type TemplateStatic + { + get { return typeof(ConstructorStaticDelegate); } + } + + private List delegates = new List(); + + public List Delegates + { + get { return delegates; } + set { delegates = value; } + } + + public object Invoke(int index, object instance, object value) + { + if (delegates.Count == 0 || index >= delegates.Count) + return null; + + try + { + if (delegates[index].Target == null) + { + return delegates[index].DynamicInvoke(this, instance, value); + } + else + { + return delegates[index].DynamicInvoke(); + } + } + catch (Exception e) + { + if (e is TargetInvocationException) + e = ((TargetInvocationException)e).InnerException; + + Debug.LogError(string.Format("Invoking a method from a constructor failed. The exception was \"{0}\".", e.Message)); + return null; + } + } + #endregion + + public ConstructorAttribute(string methodName) + { + this.methodName = methodName; + } + + public ConstructorAttribute(Delegate method) + { + this.delegates.Add(method); + } + } +} \ No newline at end of file -- cgit v1.1-26-g67d0