Вот как я бы сделал это, чтобы покрыть список узлов, независимо от его глубины:
Класс узла:
public class Node
{
public Guid Id { get; set; }
public DateTime Created { get; set; }
public List<Node> Nodes { get; set; }
public Node()
{
this.Nodes = new List<Node>();
}
public List<Node> FindNodes(Func<Node, bool> condition)
{
List<Node> resList = new List<Node>();
if (this.Nodes != null && this.Nodes.Count > 0)
{
this.Nodes.ForEach(x =>
{
resList.AddRange(x.FindNodes(condition));
if (condition(x))
resList.Add(x);
}
);
}
return resList;
}
}
Имея этот список узлов, например:
List<Node> nodeList = new List<Node>()
{
new Node() { Id = Guid.NewGuid(), Created = new DateTime(2009, 01, 10),
Nodes = {
new Node() { Id = Guid.NewGuid(), Created = new DateTime(2009, 01, 11) },
new Node() { Id = Guid.NewGuid(), Created = new DateTime(2009, 01, 12) } } },
new Node() { Id = Guid.NewGuid(), Created = new DateTime(2009, 02, 10),
Nodes = {
new Node() { Id = Guid.NewGuid(), Created = new DateTime(2009, 02, 11),
Nodes = {
new Node() { Id = Guid.NewGuid(), Created = new DateTime(2009, 11, 11) },
new Node() { Id = Guid.NewGuid(), Created = new DateTime(2009, 12, 12),
Nodes = {
new Node() { Id = Guid.NewGuid(), Created = new DateTime(2011, 11, 11) },
new Node() { Id = Guid.NewGuid(), Created = new DateTime(2011, 12, 12) } } } } },
new Node() { Id = Guid.NewGuid(), Created = new DateTime(2009, 02, 12) } } },
new Node() { Id = Guid.NewGuid(), Created = new DateTime(2009, 03, 10),
Nodes = {
new Node() { Id = Guid.NewGuid(), Created = new DateTime(2009, 03, 11) },
new Node() { Id = Guid.NewGuid(), Created = new DateTime(2009, 03, 12) } } },
};
Я могу найти любой подузел, который мне нужен:
List<Node> resList = new List<Node>();
nodeList.ForEach(x =>
resList.AddRange(x.FindNodes(y => y.Created.Day == 12)));
Вы можете смотреть на что угодно. В приведенном выше примере я ищу узлы, созданные в 12-й день любого месяца и года.