1
0
mirror of https://github.com/maxartz15/Validator.git synced 2024-10-18 13:35:44 +02:00

Compare commits

..

No commits in common. "5b70e24c3226858428e08169b5060e74e26255e7" and "8399d043f567ac1107954ff9f44fc6f6a5237a67" have entirely different histories.

10 changed files with 413 additions and 413 deletions

View File

@ -1,8 +1,8 @@
namespace Validator.Editor namespace Validator.Editor
{ {
public interface IValidator public interface IValidator
{ {
public string MenuName { get; } public string MenuName { get; }
public Report Validate(); public Report Validate();
} }
} }

View File

@ -8,152 +8,152 @@ using Object = UnityEngine.Object;
namespace Validator.Editor namespace Validator.Editor
{ {
public class ValidatorEditorWindow : EditorWindow public class ValidatorEditorWindow : EditorWindow
{ {
private class ValidatorInfo private class ValidatorInfo
{ {
public IValidator validator = null; public IValidator validator = null;
public bool isEnabled = true; public bool isEnabled = true;
public ValidatorInfo(IValidator validator) public ValidatorInfo(IValidator validator)
{ {
this.validator = validator; this.validator = validator;
} }
} }
private class ReportStats private class ReportStats
{ {
public int infoCount = 0; public int infoCount = 0;
public int warningCount = 0; public int warningCount = 0;
public int errorCount = 0; public int errorCount = 0;
} }
private class Settings private class Settings
{ {
public bool showInfo = true; public bool showInfo = true;
public bool showWarning = true; public bool showWarning = true;
public bool showError = true; public bool showError = true;
public string searchInput = ""; public string searchInput = "";
public readonly Color lightColor = new Color(0.25f, 0.25f, 0.25f, 1); public readonly Color lightColor = new Color(0.25f, 0.25f, 0.25f, 1);
public readonly Color darkColor = new Color(0.22f, 0.22f, 0.22f, 1); public readonly Color darkColor = new Color(0.22f, 0.22f, 0.22f, 1);
} }
private static readonly List<ValidatorInfo> validators = new List<ValidatorInfo>(); private static readonly List<ValidatorInfo> validators = new List<ValidatorInfo>();
private static readonly List<Report> reports = new List<Report>(); private static readonly List<Report> reports = new List<Report>();
private static readonly Settings settings = new Settings(); private static readonly Settings settings = new Settings();
private static ReportStats reportStats = new ReportStats(); private static ReportStats reportStats = new ReportStats();
private MultiColumnHeaderState multiColumnHeaderState; private MultiColumnHeaderState multiColumnHeaderState;
private MultiColumnHeader multiColumnHeader; private MultiColumnHeader multiColumnHeader;
private MultiColumnHeaderState.Column[] columns; private MultiColumnHeaderState.Column[] columns;
private Vector2 scrollPosition; private Vector2 scrollPosition;
private float multiColumnHeaderWidth; private float multiColumnHeaderWidth;
private float rows; private float rows;
[MenuItem("Window/General/Validator")] [MenuItem("Window/General/Validator")]
private static void Init() private static void Init()
{ {
ValidatorEditorWindow window = (ValidatorEditorWindow)GetWindow(typeof(ValidatorEditorWindow)); ValidatorEditorWindow window = (ValidatorEditorWindow)GetWindow(typeof(ValidatorEditorWindow));
window.titleContent = new GUIContent("Validator", EditorGUIUtility.IconContent("d_UnityEditor.ConsoleWindow").image); window.titleContent = new GUIContent("Validator", EditorGUIUtility.IconContent("d_UnityEditor.ConsoleWindow").image);
window.Show(); window.Show();
window.LoadValidators(); window.LoadValidators();
} }
private void OnGUI() private void OnGUI()
{ {
using (new EditorGUILayout.VerticalScope(GUILayout.ExpandWidth(true), GUILayout.ExpandHeight(true))) using (new EditorGUILayout.VerticalScope(GUILayout.ExpandWidth(true), GUILayout.ExpandHeight(true)))
{ {
DrawMenu(); DrawMenu();
GUILayout.Space(EditorGUIUtility.standardVerticalSpacing); GUILayout.Space(EditorGUIUtility.standardVerticalSpacing);
DrawMultiColumnScope(); DrawMultiColumnScope();
} }
} }
private void InitializeMultiColumn() private void InitializeMultiColumn()
{ {
columns = new MultiColumnHeaderState.Column[] columns = new MultiColumnHeaderState.Column[]
{ {
new MultiColumnHeaderState.Column() new MultiColumnHeaderState.Column()
{ {
allowToggleVisibility = false, // At least one column must be there. allowToggleVisibility = false, // At least one column must be there.
autoResize = false, autoResize = false,
width = 36f, width = 36f,
minWidth = 36f, minWidth = 36f,
maxWidth = 36f, maxWidth = 36f,
canSort = false, canSort = false,
sortingArrowAlignment = TextAlignment.Right, sortingArrowAlignment = TextAlignment.Right,
headerContent = EditorGUIUtility.IconContent("d_console.erroricon.inactive.sml", "Warning Type."), headerContent = EditorGUIUtility.IconContent("d_console.erroricon.inactive.sml", "Warning Type."),
headerTextAlignment = TextAlignment.Center, headerTextAlignment = TextAlignment.Center,
}, },
new MultiColumnHeaderState.Column() new MultiColumnHeaderState.Column()
{ {
allowToggleVisibility = true, allowToggleVisibility = true,
autoResize = false, autoResize = false,
width = 36f, width = 36f,
minWidth = 36f, minWidth = 36f,
maxWidth = 36f, maxWidth = 36f,
canSort = false, canSort = false,
sortingArrowAlignment = TextAlignment.Right, sortingArrowAlignment = TextAlignment.Right,
headerContent = EditorGUIUtility.IconContent("Animation.FilterBySelection", "Target Objects"), headerContent = EditorGUIUtility.IconContent("Animation.FilterBySelection", "Target Objects"),
headerTextAlignment = TextAlignment.Center, headerTextAlignment = TextAlignment.Center,
}, },
new MultiColumnHeaderState.Column() new MultiColumnHeaderState.Column()
{ {
allowToggleVisibility = true, allowToggleVisibility = true,
autoResize = true, autoResize = true,
width = 75.0f, width = 75.0f,
minWidth = 75.0f, minWidth = 75.0f,
canSort = false, canSort = false,
sortingArrowAlignment = TextAlignment.Right, sortingArrowAlignment = TextAlignment.Right,
headerContent = new GUIContent("Category", "Warning Category."), headerContent = new GUIContent("Category", "Warning Category."),
headerTextAlignment = TextAlignment.Center, headerTextAlignment = TextAlignment.Center,
}, },
new MultiColumnHeaderState.Column() new MultiColumnHeaderState.Column()
{ {
allowToggleVisibility = true, allowToggleVisibility = true,
autoResize = true, autoResize = true,
width = 200.0f, width = 200.0f,
minWidth = 200.0f, minWidth = 200.0f,
canSort = false, canSort = false,
sortingArrowAlignment = TextAlignment.Right, sortingArrowAlignment = TextAlignment.Right,
headerContent = new GUIContent("Message", "Warning Message."), headerContent = new GUIContent("Message", "Warning Message."),
headerTextAlignment = TextAlignment.Center, headerTextAlignment = TextAlignment.Center,
}, },
new MultiColumnHeaderState.Column() new MultiColumnHeaderState.Column()
{ {
allowToggleVisibility = true, allowToggleVisibility = true,
autoResize = true, autoResize = true,
width = 200.0f, width = 200.0f,
minWidth = 200.0f, minWidth = 200.0f,
canSort = false, canSort = false,
sortingArrowAlignment = TextAlignment.Right, sortingArrowAlignment = TextAlignment.Right,
headerContent = new GUIContent("Solution", "Warning Solution."), headerContent = new GUIContent("Solution", "Warning Solution."),
headerTextAlignment = TextAlignment.Center, headerTextAlignment = TextAlignment.Center,
}, },
}; };
multiColumnHeaderState = new MultiColumnHeaderState(columns); multiColumnHeaderState = new MultiColumnHeaderState(columns);
multiColumnHeader = new MultiColumnHeader(multiColumnHeaderState); multiColumnHeader = new MultiColumnHeader(multiColumnHeaderState);
multiColumnHeader.ResizeToFit(); multiColumnHeader.ResizeToFit();
} }
private void DrawMenu() private void DrawMenu()
{ {
using (new EditorGUILayout.HorizontalScope(EditorStyles.toolbar)) using (new EditorGUILayout.HorizontalScope(EditorStyles.toolbar))
{ {
if (GUILayout.Button(EditorGUIUtility.IconContent("Refresh", "Refresh"), EditorStyles.toolbarButton)) if (GUILayout.Button(EditorGUIUtility.IconContent("Refresh", "Refresh"), EditorStyles.toolbarButton))
{ {
LoadValidators(); LoadValidators();
} }
if (GUILayout.Button(EditorGUIUtility.IconContent("d_Settings", "Select validator"), EditorStyles.toolbarButton)) if (GUILayout.Button(EditorGUIUtility.IconContent("d_Settings", "Select validator"), EditorStyles.toolbarButton))
{ {
GenericMenu validatorOptionsMenu = new GenericMenu(); GenericMenu validatorOptionsMenu = new GenericMenu();
validatorOptionsMenu.AddItem(new GUIContent($"All"), false, OnValidatorInfoVisibilityAllEvent); validatorOptionsMenu.AddItem(new GUIContent($"All"), false, OnValidatorInfoVisibilityAllEvent);
validatorOptionsMenu.AddItem(new GUIContent($"None"), false, OnValidatorInfoVisibilityNoneEvent); validatorOptionsMenu.AddItem(new GUIContent($"None"), false, OnValidatorInfoVisibilityNoneEvent);
validatorOptionsMenu.AddSeparator(""); validatorOptionsMenu.AddSeparator("");
foreach (ValidatorInfo validatorInfo in validators) foreach (ValidatorInfo validatorInfo in validators)
{ {
validatorOptionsMenu.AddItem(new GUIContent($"{validatorInfo.validator.MenuName}"), validatorInfo.isEnabled, OnValidatorInfoVisibilityChangedEvent, validatorInfo); validatorOptionsMenu.AddItem(new GUIContent($"{validatorInfo.validator.MenuName}"), validatorInfo.isEnabled, OnValidatorInfoVisibilityChangedEvent, validatorInfo);
@ -162,278 +162,278 @@ namespace Validator.Editor
} }
if (GUILayout.Button(EditorGUIUtility.IconContent("PlayButton", "Run all"), EditorStyles.toolbarButton)) if (GUILayout.Button(EditorGUIUtility.IconContent("PlayButton", "Run all"), EditorStyles.toolbarButton))
{
RunValidators();
UpdateStats();
}
GUILayout.FlexibleSpace();
settings.searchInput = GUILayout.TextField(settings.searchInput, EditorStyles.toolbarSearchField, GUILayout.MaxWidth(300));
if(reportStats != null)
{ {
RunValidators(); settings.showInfo = GUILayout.Toggle(settings.showInfo, new GUIContent($"{reportStats.infoCount}", EditorGUIUtility.IconContent(GetWarningIconName(WarningType.Info)).image), EditorStyles.toolbarButton);
UpdateStats(); settings.showWarning = GUILayout.Toggle(settings.showWarning, new GUIContent($"{reportStats.warningCount}", EditorGUIUtility.IconContent(GetWarningIconName(WarningType.Warning)).image), EditorStyles.toolbarButton);
settings.showError = GUILayout.Toggle(settings.showError, new GUIContent($"{reportStats.errorCount}", EditorGUIUtility.IconContent(GetWarningIconName(WarningType.Error)).image), EditorStyles.toolbarButton);
} }
}
}
GUILayout.FlexibleSpace(); private void DrawMultiColumnScope()
{
//GUILayout.FlexibleSpace(); // If nothing has been drawn yet, uncomment this because GUILayoutUtility.GetLastRect() needs it.
Rect windowRect = GUILayoutUtility.GetLastRect();
windowRect.width = position.width;
windowRect.height = position.height;
settings.searchInput = GUILayout.TextField(settings.searchInput, EditorStyles.toolbarSearchField, GUILayout.MaxWidth(300)); if (multiColumnHeader == null)
{
InitializeMultiColumn();
}
if(reportStats != null) float columnHeight = EditorGUIUtility.singleLineHeight * 2;
{
settings.showInfo = GUILayout.Toggle(settings.showInfo, new GUIContent($"{reportStats.infoCount}", EditorGUIUtility.IconContent(GetWarningIconName(WarningType.Info)).image), EditorStyles.toolbarButton);
settings.showWarning = GUILayout.Toggle(settings.showWarning, new GUIContent($"{reportStats.warningCount}", EditorGUIUtility.IconContent(GetWarningIconName(WarningType.Warning)).image), EditorStyles.toolbarButton);
settings.showError = GUILayout.Toggle(settings.showError, new GUIContent($"{reportStats.errorCount}", EditorGUIUtility.IconContent(GetWarningIconName(WarningType.Error)).image), EditorStyles.toolbarButton);
}
}
}
private void DrawMultiColumnScope() Rect headerRect = new Rect(windowRect)
{ {
//GUILayout.FlexibleSpace(); // If nothing has been drawn yet, uncomment this because GUILayoutUtility.GetLastRect() needs it. height = EditorGUIUtility.singleLineHeight,
Rect windowRect = GUILayoutUtility.GetLastRect(); };
windowRect.width = position.width;
windowRect.height = position.height;
if (multiColumnHeader == null) Rect scrollViewPositionRect = GUILayoutUtility.GetRect(0, float.MaxValue, 0, float.MaxValue);
scrollViewPositionRect.y += headerRect.height - EditorGUIUtility.standardVerticalSpacing;
scrollViewPositionRect.height -= headerRect.height - EditorGUIUtility.standardVerticalSpacing;
Rect scrollViewRect = new Rect(windowRect)
{
width = multiColumnHeaderState.widthOfAllVisibleColumns,
height = rows * columnHeight
};
Rect rowRect = new Rect(windowRect)
{
width = multiColumnHeaderWidth,
height = columnHeight,
};
// Draw column header.
multiColumnHeader.OnGUI(headerRect, scrollPosition.x);
// Draw scroll view.
using (GUI.ScrollViewScope scope = new GUI.ScrollViewScope(scrollViewPositionRect, scrollPosition, scrollViewRect, false, false))
{ {
InitializeMultiColumn(); scrollPosition = scope.scrollPosition;
} multiColumnHeaderWidth = Mathf.Max(scrollViewPositionRect.width + scrollPosition.x, multiColumnHeaderWidth);
float columnHeight = EditorGUIUtility.singleLineHeight * 2; rows = 0;
for (int i = 0; i < reports.Count; i++)
Rect headerRect = new Rect(windowRect) {
{ for (int j = 0; j < reports[i].Reports.Count; j++)
height = EditorGUIUtility.singleLineHeight, {
}; // Type filter.
Rect scrollViewPositionRect = GUILayoutUtility.GetRect(0, float.MaxValue, 0, float.MaxValue);
scrollViewPositionRect.y += headerRect.height - EditorGUIUtility.standardVerticalSpacing;
scrollViewPositionRect.height -= headerRect.height - EditorGUIUtility.standardVerticalSpacing;
Rect scrollViewRect = new Rect(windowRect)
{
width = multiColumnHeaderState.widthOfAllVisibleColumns,
height = rows * columnHeight
};
Rect rowRect = new Rect(windowRect)
{
width = multiColumnHeaderWidth,
height = columnHeight,
};
// Draw column header.
multiColumnHeader.OnGUI(headerRect, scrollPosition.x);
// Draw scroll view.
using (GUI.ScrollViewScope scope = new GUI.ScrollViewScope(scrollViewPositionRect, scrollPosition, scrollViewRect, false, false))
{
scrollPosition = scope.scrollPosition;
multiColumnHeaderWidth = Mathf.Max(scrollViewPositionRect.width + scrollPosition.x, multiColumnHeaderWidth);
rows = 0;
for (int i = 0; i < reports.Count; i++)
{
for (int j = 0; j < reports[i].Reports.Count; j++)
{
// Type filter.
switch (reports[i].Reports[j].WarningType) switch (reports[i].Reports[j].WarningType)
{ {
case WarningType.Info: case WarningType.Info:
if (!settings.showInfo) if (!settings.showInfo)
continue; continue;
break; break;
case WarningType.Warning: case WarningType.Warning:
if (!settings.showWarning) if (!settings.showWarning)
continue; continue;
break; break;
case WarningType.Error: case WarningType.Error:
if (!settings.showError) if (!settings.showError)
continue; continue;
break; break;
default: default:
break; break;
} }
// Search filter. // Search filter.
if (!string.IsNullOrWhiteSpace(settings.searchInput)) if (!string.IsNullOrWhiteSpace(settings.searchInput))
{ {
if (!reports[i].Reports[j].Category.Contains(settings.searchInput) && !reports[i].Reports[j].Message.Contains(settings.searchInput) && !reports[i].Reports[j].Solution.Contains(settings.searchInput)) if (!reports[i].Reports[j].Category.Contains(settings.searchInput) && !reports[i].Reports[j].Message.Contains(settings.searchInput) && !reports[i].Reports[j].Solution.Contains(settings.searchInput))
{ {
continue; continue;
} }
} }
// Only draw what is visible within the view. // Only draw what is visible within the view.
if (rowRect.yMax > windowRect.y + scrollPosition.y && rowRect.yMin < windowRect.height + scrollPosition.y) if (rowRect.yMax > windowRect.y + scrollPosition.y && rowRect.yMin < windowRect.height + scrollPosition.y)
{ {
if (rows % 2 == 0) if (rows % 2 == 0)
{ {
EditorGUI.DrawRect(rowRect, settings.darkColor); EditorGUI.DrawRect(rowRect, settings.darkColor);
} }
else else
{ {
EditorGUI.DrawRect(rowRect, settings.lightColor); EditorGUI.DrawRect(rowRect, settings.lightColor);
} }
// Warning Field. // Warning Field.
int columnIndex = 0; int columnIndex = 0;
if (multiColumnHeader.IsColumnVisible(columnIndex)) if (multiColumnHeader.IsColumnVisible(columnIndex))
{ {
int visibleColumnIndex = multiColumnHeader.GetVisibleColumnIndex(columnIndex); int visibleColumnIndex = multiColumnHeader.GetVisibleColumnIndex(columnIndex);
Rect columnRect = multiColumnHeader.GetColumnRect(visibleColumnIndex); Rect columnRect = multiColumnHeader.GetColumnRect(visibleColumnIndex);
columnRect.y = rowRect.y; columnRect.y = rowRect.y;
columnRect.height = rowRect.height; columnRect.height = rowRect.height;
Rect labelFieldRect = multiColumnHeader.GetCellRect(visibleColumnIndex, columnRect); Rect labelFieldRect = multiColumnHeader.GetCellRect(visibleColumnIndex, columnRect);
labelFieldRect.x += 9; labelFieldRect.x += 9;
labelFieldRect.width -= 9; labelFieldRect.width -= 9;
EditorGUI.LabelField( EditorGUI.LabelField(
labelFieldRect, labelFieldRect,
EditorGUIUtility.IconContent(GetWarningIconName(reports[i].Reports[j].WarningType), $"{reports[i].Reports[j].WarningType}") EditorGUIUtility.IconContent(GetWarningIconName(reports[i].Reports[j].WarningType), $"{reports[i].Reports[j].WarningType}")
); );
} }
// Target Field. // Target Field.
columnIndex = 1; columnIndex = 1;
if (multiColumnHeader.IsColumnVisible(columnIndex)) if (multiColumnHeader.IsColumnVisible(columnIndex))
{ {
int visibleColumnIndex = multiColumnHeader.GetVisibleColumnIndex(columnIndex); int visibleColumnIndex = multiColumnHeader.GetVisibleColumnIndex(columnIndex);
Rect columnRect = multiColumnHeader.GetColumnRect(visibleColumnIndex); Rect columnRect = multiColumnHeader.GetColumnRect(visibleColumnIndex);
columnRect.y = rowRect.y; columnRect.y = rowRect.y;
columnRect.height = rowRect.height; columnRect.height = rowRect.height;
if(reports[i].Reports[j].Target != null) if(reports[i].Reports[j].Target != null)
{ {
if (GUI.Button( if (GUI.Button(
multiColumnHeader.GetCellRect(visibleColumnIndex, columnRect), multiColumnHeader.GetCellRect(visibleColumnIndex, columnRect),
EditorGUIUtility.IconContent("Animation.FilterBySelection", "Ping Object") EditorGUIUtility.IconContent("Animation.FilterBySelection", "Ping Object")
)) ))
{ {
Selection.objects = new Object[] { reports[i].Reports[j].Target }; Selection.objects = new Object[] { reports[i].Reports[j].Target };
if (!Selection.activeObject) if (!Selection.activeObject)
{ {
Debug.Log($"{nameof(Selection.activeObject)} is null."); Debug.Log($"{nameof(Selection.activeObject)} is null.");
continue; continue;
} }
foreach (Object o in Selection.objects) foreach (Object o in Selection.objects)
{ {
EditorGUIUtility.PingObject(o); EditorGUIUtility.PingObject(o);
} }
} }
} }
} }
// Category Field. // Category Field.
columnIndex = 2; columnIndex = 2;
if (multiColumnHeader.IsColumnVisible(columnIndex)) if (multiColumnHeader.IsColumnVisible(columnIndex))
{ {
int visibleColumnIndex = multiColumnHeader.GetVisibleColumnIndex(columnIndex); int visibleColumnIndex = multiColumnHeader.GetVisibleColumnIndex(columnIndex);
Rect columnRect = multiColumnHeader.GetColumnRect(visibleColumnIndex); Rect columnRect = multiColumnHeader.GetColumnRect(visibleColumnIndex);
columnRect.y = rowRect.y; columnRect.y = rowRect.y;
columnRect.height = rowRect.height; columnRect.height = rowRect.height;
Rect labelFieldRect = multiColumnHeader.GetCellRect(visibleColumnIndex, columnRect); Rect labelFieldRect = multiColumnHeader.GetCellRect(visibleColumnIndex, columnRect);
labelFieldRect.x += 7; labelFieldRect.x += 7;
labelFieldRect.width -= 7; labelFieldRect.width -= 7;
EditorGUI.LabelField( EditorGUI.LabelField(
labelFieldRect, labelFieldRect,
new GUIContent($"{reports[i].Reports[j].Category}") new GUIContent($"{reports[i].Reports[j].Category}")
); );
} }
// Message Field. // Message Field.
columnIndex = 3; columnIndex = 3;
if (multiColumnHeader.IsColumnVisible(columnIndex)) if (multiColumnHeader.IsColumnVisible(columnIndex))
{ {
int visibleColumnIndex = multiColumnHeader.GetVisibleColumnIndex(columnIndex); int visibleColumnIndex = multiColumnHeader.GetVisibleColumnIndex(columnIndex);
Rect columnRect = multiColumnHeader.GetColumnRect(visibleColumnIndex); Rect columnRect = multiColumnHeader.GetColumnRect(visibleColumnIndex);
columnRect.y = rowRect.y; columnRect.y = rowRect.y;
columnRect.height = rowRect.height; columnRect.height = rowRect.height;
Rect labelFieldRect = multiColumnHeader.GetCellRect(visibleColumnIndex, columnRect); Rect labelFieldRect = multiColumnHeader.GetCellRect(visibleColumnIndex, columnRect);
labelFieldRect.x += 7; labelFieldRect.x += 7;
labelFieldRect.width -= 7; labelFieldRect.width -= 7;
EditorGUI.LabelField( EditorGUI.LabelField(
labelFieldRect, labelFieldRect,
new GUIContent($"{reports[i].Reports[j].Message}") new GUIContent($"{reports[i].Reports[j].Message}")
); );
} }
// Solution Field. // Solution Field.
columnIndex = 4; columnIndex = 4;
if (multiColumnHeader.IsColumnVisible(columnIndex)) if (multiColumnHeader.IsColumnVisible(columnIndex))
{ {
int visibleColumnIndex = multiColumnHeader.GetVisibleColumnIndex(columnIndex); int visibleColumnIndex = multiColumnHeader.GetVisibleColumnIndex(columnIndex);
Rect columnRect = multiColumnHeader.GetColumnRect(visibleColumnIndex); Rect columnRect = multiColumnHeader.GetColumnRect(visibleColumnIndex);
columnRect.y = rowRect.y; columnRect.y = rowRect.y;
columnRect.height = rowRect.height; columnRect.height = rowRect.height;
Rect labelFieldRect = multiColumnHeader.GetCellRect(visibleColumnIndex, columnRect); Rect labelFieldRect = multiColumnHeader.GetCellRect(visibleColumnIndex, columnRect);
labelFieldRect.x += 7; labelFieldRect.x += 7;
labelFieldRect.width -= 7; labelFieldRect.width -= 7;
EditorGUI.LabelField( EditorGUI.LabelField(
labelFieldRect, labelFieldRect,
new GUIContent($"{reports[i].Reports[j].Solution}") new GUIContent($"{reports[i].Reports[j].Solution}")
); );
} }
} }
rowRect.y += columnHeight; rowRect.y += columnHeight;
rows++; rows++;
} }
} }
scope.handleScrollWheel = true; scope.handleScrollWheel = true;
} }
} }
private void LoadValidators() private void LoadValidators()
{ {
for (int i = validators.Count - 1; i >= 0; i--) for (int i = validators.Count - 1; i >= 0; i--)
{ {
if (validators[i].validator == null) if (validators[i].validator == null)
{ {
validators.RemoveAt(i); validators.RemoveAt(i);
} }
} }
foreach (Type type in GetValidatorTypes()) foreach (Type type in GetValidatorTypes())
{ {
bool hasValidator = false; bool hasValidator = false;
foreach (ValidatorInfo validatorInfo in validators) foreach (ValidatorInfo validatorInfo in validators)
{ {
if (validatorInfo.validator.GetType() == type) if (validatorInfo.validator.GetType() == type)
{ {
hasValidator = true; hasValidator = true;
} }
} }
if (!hasValidator) if (!hasValidator)
{ {
IValidator validator = (IValidator)Activator.CreateInstance(type); IValidator validator = (IValidator)Activator.CreateInstance(type);
if (validator != null) if (validator != null)
{ {
validators.Add(new ValidatorInfo(validator)); validators.Add(new ValidatorInfo(validator));
} }
} }
} }
} }
private void RunValidators() private void RunValidators()
{ {
reports.Clear(); reports.Clear();
foreach (ValidatorInfo validatorInfo in validators) foreach (ValidatorInfo validatorInfo in validators)
{ {
if (validatorInfo.isEnabled) if (validatorInfo.isEnabled)
{ {
reports.Add(validatorInfo.validator.Validate()); reports.Add(validatorInfo.validator.Validate());
} }
} }
} }
private void UpdateStats() private void UpdateStats()
{ {
reportStats = new ReportStats(); reportStats = new ReportStats();
foreach (Report report in reports) foreach (Report report in reports)
{ {
@ -442,7 +442,7 @@ namespace Validator.Editor
switch (report.Reports[i].WarningType) switch (report.Reports[i].WarningType)
{ {
case WarningType.Info: case WarningType.Info:
reportStats.infoCount++; reportStats.infoCount++;
break; break;
case WarningType.Warning: case WarningType.Warning:
reportStats.warningCount++; reportStats.warningCount++;
@ -451,26 +451,26 @@ namespace Validator.Editor
reportStats.errorCount++; reportStats.errorCount++;
break; break;
default: default:
break; break;
} }
} }
} }
} }
private void OnValidatorInfoVisibilityChangedEvent(object info) private void OnValidatorInfoVisibilityChangedEvent(object info)
{ {
if(info is ValidatorInfo validatorInfo) if(info is ValidatorInfo validatorInfo)
{ {
validatorInfo.isEnabled = !validatorInfo.isEnabled; validatorInfo.isEnabled = !validatorInfo.isEnabled;
} }
} }
private void OnValidatorInfoVisibilityAllEvent() private void OnValidatorInfoVisibilityAllEvent()
{ {
foreach (ValidatorInfo validatorInfo in validators) foreach (ValidatorInfo validatorInfo in validators)
{ {
validatorInfo.isEnabled = true; validatorInfo.isEnabled = true;
} }
} }
private void OnValidatorInfoVisibilityNoneEvent() private void OnValidatorInfoVisibilityNoneEvent()
@ -483,10 +483,10 @@ namespace Validator.Editor
private static Type[] GetValidatorTypes() private static Type[] GetValidatorTypes()
{ {
return TypeCache.GetTypesDerivedFrom<IValidator>().ToArray(); return TypeCache.GetTypesDerivedFrom<IValidator>().ToArray();
} }
private static string GetWarningIconName(WarningType warningType) private static string GetWarningIconName(WarningType warningType)
{ {
return warningType switch return warningType switch
{ {

View File

@ -4,13 +4,13 @@ using UnityEngine;
namespace Validator.Editor namespace Validator.Editor
{ {
public class ValidatableAssetValidator : IValidator public class AssetValidator : IValidator
{ {
public string MenuName => nameof(ValidatableAssetValidator); public string MenuName => nameof(AssetValidator);
public Report Validate() public Report Validate()
{ {
Report report = new Report(nameof(ValidatableAssetValidator)); Report report = new Report(nameof(AssetValidator));
List<Object> objects = FindAssetsByType<Object>(); List<Object> objects = FindAssetsByType<Object>();
for (int i = 0; i < objects.Count; i++) for (int i = 0; i < objects.Count; i++)

View File

@ -8,7 +8,7 @@ namespace Validator.Editor
{ {
public class RequiredAttributeAssetValidator : IValidator public class RequiredAttributeAssetValidator : IValidator
{ {
public string MenuName => nameof(RequiredAttributeAssetValidator); public string MenuName => "Attributes/RequiredAttributeAssetValidator";
private const BindingFlags flags = BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance; private const BindingFlags flags = BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance;
@ -16,7 +16,7 @@ namespace Validator.Editor
{ {
Report report = new Report(nameof(RequiredAttributeAssetValidator)); Report report = new Report(nameof(RequiredAttributeAssetValidator));
List<Object> objects = ValidatableAssetValidator.FindAssetsByType<Object>(); List<Object> objects = AssetValidator.FindAssetsByType<Object>();
for (int i = 0; i < objects.Count; i++) for (int i = 0; i < objects.Count; i++)
{ {
@ -44,7 +44,7 @@ namespace Validator.Editor
public class RequiredAttributeSceneValidator : IValidator public class RequiredAttributeSceneValidator : IValidator
{ {
public string MenuName => nameof(RequiredAttributeSceneValidator); public string MenuName => "Attributes/RequiredAttributeSceneValidator";
private const BindingFlags flags = BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance; private const BindingFlags flags = BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance;
@ -52,7 +52,7 @@ namespace Validator.Editor
{ {
Report report = new Report(nameof(RequiredAttributeSceneValidator)); Report report = new Report(nameof(RequiredAttributeSceneValidator));
List<MonoBehaviour> objects = ValidatableSceneValidator.FindAllObjectsOfType<MonoBehaviour>(); List<MonoBehaviour> objects = SceneValidator.FindAllObjectsOfType<MonoBehaviour>();
for (int i = 0; i < objects.Count; i++) for (int i = 0; i < objects.Count; i++)
{ {

View File

@ -0,0 +1,57 @@
using System.Collections.Generic;
using UnityEditor;
using UnityEngine;
using UnityEngine.SceneManagement;
namespace Validator.Editor
{
public class SceneValidator : IValidator
{
public string MenuName => nameof(SceneValidator);
public Report Validate()
{
Report report = new Report(nameof(SceneValidator));
List<IValidatable> objects = FindAllObjectsOfType<IValidatable>();
for (int i = 0; i < objects.Count; i++)
{
EditorUtility.DisplayProgressBar("SceneValidator", "Validate...", (float)i / objects.Count);
objects[i].Validate(report);
}
EditorUtility.ClearProgressBar();
return report;
}
private static List<GameObject> GetAllRootGameObjects()
{
List<GameObject> gameObjects = new List<GameObject>();
for (int i = 0; i < SceneManager.sceneCount; i++)
{
EditorUtility.DisplayProgressBar("SceneValidator", "GetAllRootGameObjects...", (float)i / SceneManager.sceneCount);
gameObjects.AddRange(SceneManager.GetSceneAt(i).GetRootGameObjects());
}
EditorUtility.ClearProgressBar();
return gameObjects;
}
public static List<T> FindAllObjectsOfType<T>()
{
List<T> objects = new List<T>();
List<GameObject> gameObjects = GetAllRootGameObjects();
for (int i = 0; i < gameObjects.Count; i++)
{
EditorUtility.DisplayProgressBar("SceneValidator", "FindAllObjectsOfType...", (float)i / gameObjects.Count);
objects.AddRange(gameObjects[i].GetComponentsInChildren<T>(true));
}
EditorUtility.ClearProgressBar();
return objects;
}
}
}

View File

@ -1,57 +0,0 @@
using System.Collections.Generic;
using UnityEditor;
using UnityEngine;
using UnityEngine.SceneManagement;
namespace Validator.Editor
{
public class ValidatableSceneValidator : IValidator
{
public string MenuName => nameof(ValidatableSceneValidator);
public Report Validate()
{
Report report = new Report(nameof(ValidatableSceneValidator));
List<IValidatable> objects = FindAllObjectsOfType<IValidatable>();
for (int i = 0; i < objects.Count; i++)
{
EditorUtility.DisplayProgressBar("SceneValidator", "Validate...", (float)i / objects.Count);
objects[i].Validate(report);
}
EditorUtility.ClearProgressBar();
return report;
}
private static List<GameObject> GetAllRootGameObjects()
{
List<GameObject> gameObjects = new List<GameObject>();
for (int i = 0; i < SceneManager.sceneCount; i++)
{
EditorUtility.DisplayProgressBar("SceneValidator", "GetAllRootGameObjects...", (float)i / SceneManager.sceneCount);
gameObjects.AddRange(SceneManager.GetSceneAt(i).GetRootGameObjects());
}
EditorUtility.ClearProgressBar();
return gameObjects;
}
public static List<T> FindAllObjectsOfType<T>()
{
List<T> objects = new List<T>();
List<GameObject> gameObjects = GetAllRootGameObjects();
for (int i = 0; i < gameObjects.Count; i++)
{
EditorUtility.DisplayProgressBar("SceneValidator", "FindAllObjectsOfType...", (float)i / gameObjects.Count);
objects.AddRange(gameObjects[i].GetComponentsInChildren<T>(true));
}
EditorUtility.ClearProgressBar();
return objects;
}
}
}

View File

@ -1,9 +1,9 @@
namespace Validator namespace Validator
{ {
public static partial class ReportCategories public static partial class ReportCategories
{ {
public const string Art = "Art"; public const string Art = "Art";
public const string Design = "Design"; public const string Design = "Design";
public const string Code = "Code"; public const string Code = "Code";
} }
} }

View File

@ -2,10 +2,10 @@ using System;
namespace Validator namespace Validator
{ {
[AttributeUsage(AttributeTargets.Field, Inherited = true, AllowMultiple = false)] [AttributeUsage(AttributeTargets.Field, Inherited = true, AllowMultiple = false)]
public class RequiredAttribute : Attribute public class RequiredAttribute : Attribute
{ {
public WarningType WarningType { get; private set; } = WarningType.Error; public WarningType WarningType { get; private set; } = WarningType.Error;
public string Category { get; private set; } = ReportCategories.Design; public string Category { get; private set; } = ReportCategories.Design;
public RequiredAttribute() { } public RequiredAttribute() { }