public class Traversal
extends java.lang.Object
implements java.io.Closeable
Any class implementing this abstract class can be used to traverse a graph.
Once the instance has been created and the allowed node and edge types has been set, it can be used as an iterator, retrieving the next object identifier of the traversal until there are no more.
Check out the 'Algorithms' section in the SPARKSEE User Manual for more details on this.
Modifier and Type | Method and Description |
---|---|
void |
addAllEdgeTypes(EdgesDirection dir)
Allows for traversing all edge types of the graph.
|
void |
addAllNodeTypes()
Allows for traversing all node types of the graph.
|
void |
addEdgeType(int type,
EdgesDirection dir)
Allows for traversing edges of the given type.
|
void |
addNodeType(int type)
Allows for traversing nodes of the given type.
|
void |
close()
Closes the Traversal instance.
|
void |
excludeEdges(Objects edges)
Set which edges can't be used.
|
void |
excludeNodes(Objects nodes)
Set which nodes can't be used.
|
int |
getCurrentDepth()
Returns the depth of the current node.
|
boolean |
hasNext()
Gets if there are more objects to be traversed.
|
boolean |
isClosed()
Gets if Traversal instance has been closed or not.
|
long |
next()
Gets the next object of the traversal.
|
void |
setMaximumHops(int maxhops)
Sets the maximum hops restriction.
|
public void excludeNodes(Objects nodes)
This will replace any previously specified set of excluded nodes. Should only be used to exclude the usage of specific nodes from allowed node types because it's less efficient than not allowing a node type.
nodes
- [in] A set of node identifiers that must be kept intact until the destruction of the class.public boolean hasNext()
public int getCurrentDepth()
That is, it returns the depth of the node returned in the last call to Next().
public void addAllEdgeTypes(EdgesDirection dir)
dir
- [in] Edge direction.public void excludeEdges(Objects edges)
This will replace any previously specified set of excluded edges. Should only be used to exclude the usage of specific edges from allowed edge types because it's less efficient than not allowing an edge type.
edges
- [in] A set of edge identifiers that must be kept intact until the destruction of the class.public void addEdgeType(int type, EdgesDirection dir)
type
- [in] Edge type.dir
- [in] Edge direction.public boolean isClosed()
close()
public void addNodeType(int type)
type
- The node type to addpublic long next()
public void close()
It must be called to ensure the integrity of all data.
close
in interface java.io.Closeable
close
in interface java.lang.AutoCloseable
public void addAllNodeTypes()
public void setMaximumHops(int maxhops)
All paths longer than the maximum hops restriction will be ignored.
maxhops
- [in] The maximum hops restriction. It must be positive or zero. Zero, the default value, means unlimited.