rj-action-library/Runtime/Graphs/Trees/Iterators/SiblingsIterator.cs

66 lines
1.2 KiB
C#
Raw Normal View History

2024-05-04 08:26:16 +00:00
using System.Collections;
using System.Collections.Generic;
namespace Rokojori
{
public class SiblingsIterator<N>: TreeIterator<N> where N:class
{
bool nextSiblings = true;
N parent;
N current;
int index = 0;
int nodeIndex = 0;
TreeWalker<N> walker;
public static SiblingsIterator<N> Create( TreeWalker<N> walker, N node, bool previous = true, bool next = true )
{
var iterator = new SiblingsIterator<N>();
iterator.parent = node;
iterator.walker = walker;
iterator.current = null;
iterator.nodeIndex = walker.ChildIndexOf( node );
iterator.index = previous ? -1 : iterator.nodeIndex;
return iterator;
}
public override bool HasNext()
{
if ( ! nextSiblings )
{
return ( index + 1 ) < nodeIndex;
}
var nextIndex = index + 1;
if ( nextIndex == nodeIndex )
{
nextIndex ++;
}
return nextIndex < walker.NumChildren( parent );
}
public override N Current()
{
return current;
}
protected override void _MoveToNext()
{
index ++;
if ( index == nodeIndex )
{
index ++;
}
current = walker.ChildAt( parent, index );
}
}
}