From 4df61db1e13aa7692fb1c5c728a10e366a8d30f9 Mon Sep 17 00:00:00 2001 From: VladV Date: Fri, 16 Jun 2023 19:38:47 +0400 Subject: [PATCH] Drop support of Tri-drawn properties in Odin editors --- Editor.Integrations/Odin/OdinFieldDrawer.cs | 11 ++++++++--- Editor.Integrations/Odin/OdinFieldValidator.cs | 11 ++++++++--- 2 files changed, 16 insertions(+), 6 deletions(-) diff --git a/Editor.Integrations/Odin/OdinFieldDrawer.cs b/Editor.Integrations/Odin/OdinFieldDrawer.cs index 4b68a8c..ad86df1 100644 --- a/Editor.Integrations/Odin/OdinFieldDrawer.cs +++ b/Editor.Integrations/Odin/OdinFieldDrawer.cs @@ -3,7 +3,7 @@ using Sirenix.OdinInspector.Editor; using Sirenix.Utilities.Editor; using UnityEngine; -#if !TRIINSPECTOR_DISABLE_ODIN_FIELDS_INJECTOR +#if TRIINSPECTOR_ODIN_FIELDS_INJECTOR namespace TriInspector.Editor.Integrations.Odin { @@ -43,8 +43,13 @@ namespace TriInspector.Editor.Integrations.Odin for (var parent = property.Parent; parent != null; parent = parent.Parent) { - var parentType = parent.ValueEntry.TypeOfValue; - if (TriOdinUtility.IsDrawnByTri(parentType)) + var valueEntry = parent.ValueEntry; + if (valueEntry == null) + { + continue; + } + + if (TriOdinUtility.IsDrawnByTri(valueEntry.TypeOfValue)) { return false; } diff --git a/Editor.Integrations/Odin/OdinFieldValidator.cs b/Editor.Integrations/Odin/OdinFieldValidator.cs index f56a506..8ef15f8 100644 --- a/Editor.Integrations/Odin/OdinFieldValidator.cs +++ b/Editor.Integrations/Odin/OdinFieldValidator.cs @@ -3,7 +3,7 @@ using Sirenix.OdinInspector.Editor; using Sirenix.OdinInspector.Editor.Validation; using TriInspector.Editor.Integrations.Odin; -#if !TRIINSPECTOR_DISABLE_ODIN_FIELDS_INJECTOR +#if TRIINSPECTOR_ODIN_FIELDS_INJECTOR [assembly: RegisterValidator(typeof(OdinFieldValidator<>))] @@ -43,8 +43,13 @@ namespace TriInspector.Editor.Integrations.Odin for (var parent = property.Parent; parent != null; parent = parent.Parent) { - var parentType = parent.Info.TypeOfValue; - if (TriOdinUtility.IsDrawnByTri(parentType)) + var valueEntry = parent.ValueEntry; + if (valueEntry == null) + { + continue; + } + + if (TriOdinUtility.IsDrawnByTri(valueEntry.TypeOfValue)) { return false; }