diff options
author | chai <chaifix@163.com> | 2020-10-15 19:05:22 +0800 |
---|---|---|
committer | chai <chaifix@163.com> | 2020-10-15 19:05:22 +0800 |
commit | f049177e20a276049c61edbad631c1b2bbdd5706 (patch) | |
tree | 7d1a1cd9b690a5d9a8b9a65554a191d6ec769601 /Assets/Plugins/AdvancedInspector/Attributes/Constructor.cs | |
parent | 6990a0d1fbdcbbf404f40713363ac1a148c8840a (diff) |
-advanced inspector
+odin
Diffstat (limited to 'Assets/Plugins/AdvancedInspector/Attributes/Constructor.cs')
-rw-r--r-- | Assets/Plugins/AdvancedInspector/Attributes/Constructor.cs | 82 |
1 files changed, 0 insertions, 82 deletions
diff --git a/Assets/Plugins/AdvancedInspector/Attributes/Constructor.cs b/Assets/Plugins/AdvancedInspector/Attributes/Constructor.cs deleted file mode 100644 index 1b3f7438..00000000 --- a/Assets/Plugins/AdvancedInspector/Attributes/Constructor.cs +++ /dev/null @@ -1,82 +0,0 @@ -using System; -using System.Collections.Generic; -using System.Reflection; - -using UnityEngine; - -namespace AdvancedInspector -{ - /// <summary> - /// Some object cannot be created with an empty constructor. - /// This runtime attribute lets you create the object by yourself. - /// </summary> - [AttributeUsage(AttributeTargets.Field | AttributeTargets.Property)] - public class ConstructorAttribute : Attribute, IRuntimeAttribute<object> - { - 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<Delegate> delegates = new List<Delegate>(); - - public List<Delegate> 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 |