From 2b389d932377213abc5e41ee90b8ea1d740d525f Mon Sep 17 00:00:00 2001 From: VladV Date: Sun, 29 May 2022 14:04:20 +0300 Subject: [PATCH] Makes InspectorElement creation lazy to avoid tree generation on validation --- Editor/TriPropertyTree.cs | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/Editor/TriPropertyTree.cs b/Editor/TriPropertyTree.cs index 86163e9..b924eb0 100644 --- a/Editor/TriPropertyTree.cs +++ b/Editor/TriPropertyTree.cs @@ -1,5 +1,6 @@ using System; using System.Collections.Generic; +using JetBrains.Annotations; using TriInspector.Elements; using UnityEditor; using UnityEngine; @@ -8,7 +9,7 @@ namespace TriInspector { public abstract class TriPropertyTree : ITriPropertyParent { - private TriInspectorElement _inspectorElement; + [CanBeNull] private TriInspectorElement _inspectorElement; public IReadOnlyList Properties { get; protected set; } @@ -21,21 +22,16 @@ namespace TriInspector public void Initialize() { - _inspectorElement = new TriInspectorElement(TargetObjectType, Properties); - _inspectorElement.AttachInternal(); - Update(); RunValidation(); } public virtual void Dispose() { - if (!_inspectorElement.IsAttached) + if (_inspectorElement != null && _inspectorElement.IsAttached) { - return; + _inspectorElement.DetachInternal(); } - - _inspectorElement.DetachInternal(); } public virtual void Update() @@ -62,6 +58,12 @@ namespace TriInspector { RepaintRequired = false; + if (_inspectorElement == null) + { + _inspectorElement = new TriInspectorElement(TargetObjectType, Properties); + _inspectorElement.AttachInternal(); + } + _inspectorElement.Update(); var width = EditorGUIUtility.currentViewWidth; var height = _inspectorElement.GetHeight(width);