Я делаю проект, в котором мне нужно зарегистрировать все свойства, поскольку система настолько огромна, что потребуется много работы, чтобы зарегистрировать все свойства, которые я хочу использовать для целей Xaml.
Цель состоит в том, чтобы найти все свойства, которые находятся на вершине дерева.
так что в основном
public class A{
public int Property1 { get; set; }
}
public class B : A{
public int Property2 { get; set; }
public virtual int Property3 { get; set; }
}
public class C : B{
public override int Property3 { get; set; }
public int Property4 { get; set; }
public int Property5 { get; set; }
}
Конечный результат будет примерно таким
A.Property1
B.Property2
B.Property3
C.Property4
C.Property5
Если вы заметили, что я не хочу принимать переопределенные свойства из-за того, как я ищу свойства, если я делаю что-то вроде этого
Например, C.Property3, и он не может его найти, он проверит базовый тип C и найдет его.
Это то, что у меня есть до сих пор.
public static void RegisterType( Type type )
{
PropertyInfo[] properties = type.GetProperties( BindingFlags.Public | BindingFlags.Instance | BindingFlags.DeclaredOnly | BindingFlags.GetProperty | BindingFlags.SetProperty );
if ( properties != null && properties.Length > 0 )
{
foreach ( PropertyInfo property in properties )
{
// if the property is an indexers then we ignore them
if ( property.Name == "Item" && property.GetIndexParameters().Length > 0 )
continue;
// We don't want Arrays or Generic Property Types
if ( (property.PropertyType.IsArray || property.PropertyType.IsGenericType) )
continue;
// Register Property
}
}
}
Я хочу следующее:
- Общедоступные свойства, которые не переопределены, не статичны, не закрыты
- Допускаются либо свойства get, либо set
- Они не являются массивом или универсальным типом.
- Они являются вершиной дерева, т.е. класс C в примере является самым высоким (пример списка свойств - это именно то, что я ищу)
- Они не являются свойством индексатора ( this[index] )