package edu.uci.ics.jung.graph;
import java.io.Serializable;
import java.util.Collection;
import edu.uci.ics.jung.graph.util.EdgeType;
import edu.uci.ics.jung.graph.util.Pair;
/**
* An implementation of <code>Graph</code> that delegates its method calls to a
* constructor-specified <code>Graph</code> instance. This is useful for adding
* additional behavior (such as synchronization or unmodifiability) to an
* existing instance.
*/
@SuppressWarnings("serial")
public class GraphDecorator<V, E> implements Graph<V, E>, Serializable {
protected Graph<V, E> delegate;
/**
* Creates a new instance based on the provided {@code delegate}.
*
* @param delegate
*/
public GraphDecorator(Graph<V, E> delegate) {
this.delegate = delegate;
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#addEdge(java.lang.Object,
* java.util.Collection)
*/
@Override
public boolean addEdge(E edge, Collection<? extends V> vertices) {
return delegate.addEdge(edge, vertices);
}
/**
* @see Hypergraph#addEdge(Object, Collection, EdgeType)
*/
@Override
public boolean addEdge(E edge, Collection<? extends V> vertices,
EdgeType edge_type) {
return delegate.addEdge(edge, vertices, edge_type);
}
/**
* @see edu.uci.ics.jung.graph.Graph#addEdge(java.lang.Object,
* java.lang.Object, java.lang.Object,
* edu.uci.ics.jung.graph.util.EdgeType)
*/
@Override
public boolean addEdge(E e, V v1, V v2, EdgeType edgeType) {
return delegate.addEdge(e, v1, v2, edgeType);
}
/**
* @see edu.uci.ics.jung.graph.Graph#addEdge(java.lang.Object,
* java.lang.Object, java.lang.Object)
*/
@Override
public boolean addEdge(E e, V v1, V v2) {
return delegate.addEdge(e, v1, v2);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#addVertex(java.lang.Object)
*/
@Override
public boolean addVertex(V vertex) {
return delegate.addVertex(vertex);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#isIncident(java.lang.Object,
* java.lang.Object)
*/
@Override
public boolean isIncident(V vertex, E edge) {
return delegate.isIncident(vertex, edge);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#isNeighbor(java.lang.Object,
* java.lang.Object)
*/
@Override
public boolean isNeighbor(V v1, V v2) {
return delegate.isNeighbor(v1, v2);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#degree(java.lang.Object)
*/
@Override
public int degree(V vertex) {
return delegate.degree(vertex);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#findEdge(java.lang.Object,
* java.lang.Object)
*/
@Override
public E findEdge(V v1, V v2) {
return delegate.findEdge(v1, v2);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#findEdgeSet(java.lang.Object,
* java.lang.Object)
*/
@Override
public Collection<E> findEdgeSet(V v1, V v2) {
return delegate.findEdgeSet(v1, v2);
}
/**
* @see edu.uci.ics.jung.graph.Graph#getDest(java.lang.Object)
*/
@Override
public V getDest(E directed_edge) {
return delegate.getDest(directed_edge);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#getEdgeCount()
*/
@Override
public int getEdgeCount() {
return delegate.getEdgeCount();
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#getEdgeCount(EdgeType)
*/
@Override
public int getEdgeCount(EdgeType edge_type) {
return delegate.getEdgeCount(edge_type);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#getEdges()
*/
@Override
public Collection<E> getEdges() {
return delegate.getEdges();
}
/**
* @see edu.uci.ics.jung.graph.Graph#getEdges(edu.uci.ics.jung.graph.util.EdgeType)
*/
@Override
public Collection<E> getEdges(EdgeType edgeType) {
return delegate.getEdges(edgeType);
}
/**
* @see edu.uci.ics.jung.graph.Graph#getEdgeType(java.lang.Object)
*/
@Override
public EdgeType getEdgeType(E edge) {
return delegate.getEdgeType(edge);
}
/**
* @see edu.uci.ics.jung.graph.Graph#getDefaultEdgeType()
*/
@Override
public EdgeType getDefaultEdgeType() {
return delegate.getDefaultEdgeType();
}
/**
* @see edu.uci.ics.jung.graph.Graph#getEndpoints(java.lang.Object)
*/
@Override
public Pair<V> getEndpoints(E edge) {
return delegate.getEndpoints(edge);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#getIncidentCount(java.lang.Object)
*/
@Override
public int getIncidentCount(E edge) {
return delegate.getIncidentCount(edge);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#getIncidentEdges(java.lang.Object)
*/
@Override
public Collection<E> getIncidentEdges(V vertex) {
return delegate.getIncidentEdges(vertex);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#getIncidentVertices(java.lang.Object)
*/
@Override
public Collection<V> getIncidentVertices(E edge) {
return delegate.getIncidentVertices(edge);
}
/**
* @see edu.uci.ics.jung.graph.Graph#getInEdges(java.lang.Object)
*/
@Override
public Collection<E> getInEdges(V vertex) {
return delegate.getInEdges(vertex);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#getNeighborCount(java.lang.Object)
*/
@Override
public int getNeighborCount(V vertex) {
return delegate.getNeighborCount(vertex);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#getNeighbors(java.lang.Object)
*/
@Override
public Collection<V> getNeighbors(V vertex) {
return delegate.getNeighbors(vertex);
}
/**
* @see edu.uci.ics.jung.graph.Graph#getOpposite(java.lang.Object,
* java.lang.Object)
*/
@Override
public V getOpposite(V vertex, E edge) {
return delegate.getOpposite(vertex, edge);
}
/**
* @see edu.uci.ics.jung.graph.Graph#getOutEdges(java.lang.Object)
*/
@Override
public Collection<E> getOutEdges(V vertex) {
return delegate.getOutEdges(vertex);
}
/**
* @see edu.uci.ics.jung.graph.Graph#getPredecessorCount(java.lang.Object)
*/
@Override
public int getPredecessorCount(V vertex) {
return delegate.getPredecessorCount(vertex);
}
/**
* @see edu.uci.ics.jung.graph.Graph#getPredecessors(java.lang.Object)
*/
@Override
public Collection<V> getPredecessors(V vertex) {
return delegate.getPredecessors(vertex);
}
/**
* @see edu.uci.ics.jung.graph.Graph#getSource(java.lang.Object)
*/
@Override
public V getSource(E directed_edge) {
return delegate.getSource(directed_edge);
}
/**
* @see edu.uci.ics.jung.graph.Graph#getSuccessorCount(java.lang.Object)
*/
@Override
public int getSuccessorCount(V vertex) {
return delegate.getSuccessorCount(vertex);
}
/**
* @see edu.uci.ics.jung.graph.Graph#getSuccessors(java.lang.Object)
*/
@Override
public Collection<V> getSuccessors(V vertex) {
return delegate.getSuccessors(vertex);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#getVertexCount()
*/
@Override
public int getVertexCount() {
return delegate.getVertexCount();
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#getVertices()
*/
@Override
public Collection<V> getVertices() {
return delegate.getVertices();
}
/**
* @see edu.uci.ics.jung.graph.Graph#inDegree(java.lang.Object)
*/
@Override
public int inDegree(V vertex) {
return delegate.inDegree(vertex);
}
/**
* @see edu.uci.ics.jung.graph.Graph#isDest(java.lang.Object,
* java.lang.Object)
*/
@Override
public boolean isDest(V vertex, E edge) {
return delegate.isDest(vertex, edge);
}
/**
* @see edu.uci.ics.jung.graph.Graph#isPredecessor(java.lang.Object,
* java.lang.Object)
*/
@Override
public boolean isPredecessor(V v1, V v2) {
return delegate.isPredecessor(v1, v2);
}
/**
* @see edu.uci.ics.jung.graph.Graph#isSource(java.lang.Object,
* java.lang.Object)
*/
@Override
public boolean isSource(V vertex, E edge) {
return delegate.isSource(vertex, edge);
}
/**
* @see edu.uci.ics.jung.graph.Graph#isSuccessor(java.lang.Object,
* java.lang.Object)
*/
@Override
public boolean isSuccessor(V v1, V v2) {
return delegate.isSuccessor(v1, v2);
}
/**
* @see edu.uci.ics.jung.graph.Graph#outDegree(java.lang.Object)
*/
@Override
public int outDegree(V vertex) {
return delegate.outDegree(vertex);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#removeEdge(java.lang.Object)
*/
@Override
public boolean removeEdge(E edge) {
return delegate.removeEdge(edge);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#removeVertex(java.lang.Object)
*/
@Override
public boolean removeVertex(V vertex) {
return delegate.removeVertex(vertex);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#containsEdge(java.lang.Object)
*/
@Override
public boolean containsEdge(E edge) {
return delegate.containsEdge(edge);
}
/**
* @see edu.uci.ics.jung.graph.Hypergraph#containsVertex(java.lang.Object)
*/
@Override
public boolean containsVertex(V vertex) {
return delegate.containsVertex(vertex);
}
@Override
public Graph<V, E> newInstance() {
return delegate.newInstance();
}
}