Class Graph<V>
- java.lang.Object
-
- org.eclipse.viatra.query.runtime.base.itc.graphimpl.Graph<V>
-
- All Implemented Interfaces:
IBiDirectionalGraphDataSource<V>,IGraphDataSource<V>
public class Graph<V> extends java.lang.Object implements IGraphDataSource<V>, IBiDirectionalGraphDataSource<V>
-
-
Constructor Summary
Constructors Constructor Description Graph()
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidattachAsFirstObserver(IGraphObserver<V> observer)Attaches a new graph observer to this graph data source as the first one.voidattachObserver(IGraphObserver<V> go)Attaches a new graph observer to this graph data source.voiddeleteEdge(V source, V target)Deprecated.use explicitlydeleteEdgeThatExists(Object, Object)ordeleteEdgeIfExists(Object, Object)instead.voiddeleteEdgeIfExists(V source, V target)No-op if trying to delete edge that does not existvoiddeleteEdgeThatExists(V source, V target)voiddeleteNode(V node)Deletes the given node AND all of the edges going in and out from the node.voiddetachObserver(IGraphObserver<V> go)Detaches an already registered graph observer from this graph data source.java.util.Set<V>getAllNodes()Returns the complete set of nodes in the graph data source.IMemoryView<V>getSourceNodes(V target)Returns the source nodes for the given target node.IMemoryView<V>getTargetNodes(V source)Returns the target nodes for the given source node.voidinsertEdge(V source, V target)voidinsertNode(V node)Insert the given node into the graph.java.lang.StringtoString()
-
-
-
Method Detail
-
deleteEdgeIfExists
public void deleteEdgeIfExists(V source, V target)
No-op if trying to delete edge that does not exist- Since:
- 2.0
- See Also:
deleteEdgeIfExists(Object, Object)
-
deleteEdgeThatExists
public void deleteEdgeThatExists(V source, V target)
- Throws:
java.lang.IllegalStateException- if trying to delete edge that does not exist- Since:
- 2.0
- See Also:
deleteEdgeIfExists(Object, Object)
-
deleteEdge
@Deprecated public void deleteEdge(V source, V target)
Deprecated.use explicitlydeleteEdgeThatExists(Object, Object)ordeleteEdgeIfExists(Object, Object)instead. To preserve backwards compatibility, this method delegates to the latter.
-
insertNode
public void insertNode(V node)
Insert the given node into the graph.
-
deleteNode
public void deleteNode(V node)
Deletes the given node AND all of the edges going in and out from the node.
-
attachObserver
public void attachObserver(IGraphObserver<V> go)
Description copied from interface:IGraphDataSourceAttaches a new graph observer to this graph data source. Observers will be notified in the order they have been registered.- Specified by:
attachObserverin interfaceIGraphDataSource<V>- Parameters:
go- the graph observer
-
attachAsFirstObserver
public void attachAsFirstObserver(IGraphObserver<V> observer)
Description copied from interface:IGraphDataSourceAttaches a new graph observer to this graph data source as the first one. In the notification order this observer will be the first one as long as another call to this method happens.- Specified by:
attachAsFirstObserverin interfaceIGraphDataSource<V>- Parameters:
observer- the graph observer
-
detachObserver
public void detachObserver(IGraphObserver<V> go)
Description copied from interface:IGraphDataSourceDetaches an already registered graph observer from this graph data source.- Specified by:
detachObserverin interfaceIGraphDataSource<V>- Parameters:
go- the graph observer
-
getAllNodes
public java.util.Set<V> getAllNodes()
Description copied from interface:IGraphDataSourceReturns the complete set of nodes in the graph data source.- Specified by:
getAllNodesin interfaceIGraphDataSource<V>- Returns:
- the set of all nodes
-
getTargetNodes
public IMemoryView<V> getTargetNodes(V source)
Description copied from interface:IGraphDataSourceReturns the target nodes for the given source node. The returned data structure is anIMultisetbecause of potential parallel edges in the graph data source. The method must not return null.- Specified by:
getTargetNodesin interfaceIGraphDataSource<V>- Parameters:
source- the source node- Returns:
- the multiset of target nodes
-
getSourceNodes
public IMemoryView<V> getSourceNodes(V target)
Description copied from interface:IBiDirectionalGraphDataSourceReturns the source nodes for the given target node. The returned data structure is anIMultisetbecause of potential parallel edges in the graph data source. The method must not return null.- Specified by:
getSourceNodesin interfaceIBiDirectionalGraphDataSource<V>- Parameters:
target- the target node- Returns:
- the multiset of source nodes
-
toString
public java.lang.String toString()
- Overrides:
toStringin classjava.lang.Object
-
-