1
0
mirror of https://github.com/maxartz15/Validator.git synced 2024-11-22 03:55:35 +01:00

Compare commits

...

2 Commits

Author SHA1 Message Date
max
8399d043f5 Update RequiredAttributeValidator
Fix required attribute validator by adding flags when getting the fields.
2022-05-04 00:39:01 +02:00
max
b4dd8744df Fix attribute 2022-05-03 21:11:12 +02:00
3 changed files with 14 additions and 3 deletions

View File

@ -1,4 +1,10 @@
# Change Log: # Change Log:
## 0.1.4
- Fix attribute validator..?
## 0.1.3
- Fix attribute validator..?
## 0.1.2
- ...
## 0.1.1 ## 0.1.1
- First prototype of Attribute validator. - First prototype of Attribute validator.
## 0.1.1 ## 0.1.1

View File

@ -10,6 +10,8 @@ namespace Validator.Editor
{ {
public string MenuName => "Attributes/RequiredAttributeAssetValidator"; public string MenuName => "Attributes/RequiredAttributeAssetValidator";
private const BindingFlags flags = BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance;
public Report Validate() public Report Validate()
{ {
Report report = new Report(nameof(RequiredAttributeAssetValidator)); Report report = new Report(nameof(RequiredAttributeAssetValidator));
@ -19,7 +21,8 @@ namespace Validator.Editor
for (int i = 0; i < objects.Count; i++) for (int i = 0; i < objects.Count; i++)
{ {
EditorUtility.DisplayProgressBar("RequiredAttributeAssetValidator", "RequiredAttribute...", (float)i / objects.Count); EditorUtility.DisplayProgressBar("RequiredAttributeAssetValidator", "RequiredAttribute...", (float)i / objects.Count);
IEnumerable<(FieldInfo FieldInfo, RequiredAttribute Attribute)> fieldsWithRequiredAttribute = from fi in objects[i].GetType().GetFields()
IEnumerable<(FieldInfo FieldInfo, RequiredAttribute Attribute)> fieldsWithRequiredAttribute = from fi in objects[i].GetType().GetFields(flags)
let attr = fi.GetCustomAttributes(typeof(RequiredAttribute), true) let attr = fi.GetCustomAttributes(typeof(RequiredAttribute), true)
where attr.Length == 1 where attr.Length == 1
select (FieldInfo: fi, Attribute: attr.First() as RequiredAttribute); select (FieldInfo: fi, Attribute: attr.First() as RequiredAttribute);
@ -43,6 +46,8 @@ namespace Validator.Editor
{ {
public string MenuName => "Attributes/RequiredAttributeSceneValidator"; public string MenuName => "Attributes/RequiredAttributeSceneValidator";
private const BindingFlags flags = BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance;
public Report Validate() public Report Validate()
{ {
Report report = new Report(nameof(RequiredAttributeSceneValidator)); Report report = new Report(nameof(RequiredAttributeSceneValidator));
@ -52,7 +57,7 @@ namespace Validator.Editor
for (int i = 0; i < objects.Count; i++) for (int i = 0; i < objects.Count; i++)
{ {
EditorUtility.DisplayProgressBar("RequiredAttributeSceneValidator", "RequiredAttribute...", (float)i / objects.Count); EditorUtility.DisplayProgressBar("RequiredAttributeSceneValidator", "RequiredAttribute...", (float)i / objects.Count);
IEnumerable<(FieldInfo FieldInfo, RequiredAttribute Attribute)> fieldsWithRequiredAttribute = from fi in objects[i].GetType().GetFields() IEnumerable<(FieldInfo FieldInfo, RequiredAttribute Attribute)> fieldsWithRequiredAttribute = from fi in objects[i].GetType().GetFields(flags)
let attr = fi.GetCustomAttributes(typeof(RequiredAttribute), true) let attr = fi.GetCustomAttributes(typeof(RequiredAttribute), true)
where attr.Length == 1 where attr.Length == 1
select (FieldInfo: fi, Attribute: attr.First() as RequiredAttribute); select (FieldInfo: fi, Attribute: attr.First() as RequiredAttribute);

View File

@ -1,7 +1,7 @@
{ {
"name": "com.vertexcolor.validator", "name": "com.vertexcolor.validator",
"displayName": "Validator", "displayName": "Validator",
"version": "0.1.2", "version": "0.1.4",
"unity": "2019.3", "unity": "2019.3",
"description": "Unity project validator framework.", "description": "Unity project validator framework.",
"category": "Tool", "category": "Tool",