EDIT: It looks like their is no simpler way to do this. Given the size of the class structure, the foreach approach seems to be the easiest (and probably the best) way to achieve my goal. I leave the question opened just in case someone has a brilliant idea. :)
Hi all,
I have a list of classes with a structure similar to this:
class A
{
...
}
class B
{
...
public List<A> ListOfA {...}
}
class C
{
...
public List<A> ListOfA {...}
public List<B> ListOfB {...}
}
class D
{
...
public List<A> ListOfA {...}
public List<B> ListOfB {...}
public List<C> ListOfC {...}
}
[...]
I need to create a method in the outer-most class (D in that case), that would have the following signature:
public IEnumerable<A> GetListOfA();
It would recursively (yield) return the list of instances of A contained in an instance of D.
The current implementation is a list of hard-coded foreach's. I'd like to make thing a little more flexible by dynamically looking through the properties of each class and subclass.
Just to give you some more details, the class structure is created from the FxCop XML report. The FxCop messages can be linked to a namespace, a module, a type, a member, etc. The XML is deserialized into this class structure and the messages can be found at different levels of the structure.
What I want to achieve is actually the equivalent of XPath //A
over a class structure.
Would you have an idea on how implement such a method?
Thank you very much for your help