package org.neo4j.graphdb.traversal; import java.util.Iterator; import org.neo4j.graphdb.Node; import org.neo4j.graphdb.Path; import org.neo4j.graphdb.Relationship; /** * The interface which represents the traverser which is used to step through * the results of a traversal. Each step can be represented in different ways. * The default is as {@link Position} objects which all over representations * can be derived from, i.e {@link Node}, {@link Relationship}, {@link Path}. * Or each step can be represented in one of those representations directly. */ public interface Traverser extends Iterable<Position> { /** * Represents the traversal in the form of {@link Node}s. This is a * convenient way of iterating over {@link Position}s and getting the * {@link Position#node()} for each position. * * @return the traversal in the form of {@link Node} objects. */ Iterable<Node> nodes(); /** * Represents the traversal in the form of {@link Relationship}s. This is a * convenient way of iterating over {@link Position}s and getting the * {@link Position#lastRelationship()} for each position. * * @return the traversal in the form of {@link Relationship} objects. */ Iterable<Relationship> relationships(); /** * Represents the traversal in the form of {@link Path}s. This is a * convenient way of iterating over {@link Position}s and getting the * {@link Position#path()} for each position. * * @return the traversal in the form of {@link Path} objects. */ Iterable<Path> paths(); /** * Represents the traversal in the default form, i.e {@link Position}s. * @return the iterator of this traversal in the form of {@link Position}s. */ Iterator<Position> iterator(); }