com.salesforce.jgrapht.experimental.GraphSquare Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of AptSpringProcessor Show documentation
Show all versions of AptSpringProcessor Show documentation
This project contains the apt processor that implements all the checks enumerated in @Verify. It is a self contained, and
shaded jar.
/*
* (C) Copyright 2004-2017, by Michael Behrisch and Contributors.
*
* JGraphT : a free Java graph-theory library
*
* This program and the accompanying materials are dual-licensed under
* either
*
* (a) the terms of the GNU Lesser General Public License version 2.1
* as published by the Free Software Foundation, or (at your option) any
* later version.
*
* or (per the licensee's choosing)
*
* (b) the terms of the Eclipse Public License v1.0 as published by
* the Eclipse Foundation.
*/
package com.salesforce.jgrapht.experimental;
import java.util.*;
import com.salesforce.jgrapht.*;
import com.salesforce.jgrapht.event.*;
import com.salesforce.jgrapht.graph.*;
/**
* A unmodifiable graph which is the squared graph of another.
*
* @param the graph vertex type
* @param the graph edge type
*
* @author Michael Behrisch
* @since Sep 14, 2004
*/
public class GraphSquare
extends AbstractBaseGraph
{
private static final long serialVersionUID = -2642034600395594304L;
private static final String UNMODIFIABLE = "this graph is unmodifiable";
/**
* Constructor for GraphSquare.
*
* @param g the graph of which a square is to be created.
* @param createLoops whether to create self loops
*/
public GraphSquare(final Graph g, final boolean createLoops)
{
super(g.getEdgeFactory(), false, createLoops);
Graphs.addAllVertices(this, g.vertexSet());
addSquareEdges(g, createLoops);
if (g instanceof ListenableGraph) {
((ListenableGraph) g).addGraphListener(new GraphListener()
{
@Override
public void edgeAdded(GraphEdgeChangeEvent e)
{
E edge = e.getEdge();
addEdgesStartingAt(
g, g.getEdgeSource(edge), g.getEdgeTarget(edge), createLoops);
addEdgesStartingAt(
g, g.getEdgeTarget(edge), g.getEdgeSource(edge), createLoops);
}
@Override
public void edgeRemoved(GraphEdgeChangeEvent e)
{ // this is not a very efficient implementation
GraphSquare.super.removeAllEdges(edgeSet());
addSquareEdges(g, createLoops);
}
@Override
public void vertexAdded(GraphVertexChangeEvent e)
{
}
@Override
public void vertexRemoved(GraphVertexChangeEvent e)
{
}
});
}
}
/**
* {@inheritDoc}
*/
@Override
public E addEdge(V sourceVertex, V targetVertex)
{
throw new UnsupportedOperationException(UNMODIFIABLE);
}
/**
* {@inheritDoc}
*/
@Override
public boolean addEdge(V sourceVertex, V targetVertex, E e)
{
throw new UnsupportedOperationException(UNMODIFIABLE);
}
/**
* {@inheritDoc}
*/
@Override
public boolean addVertex(V v)
{
throw new UnsupportedOperationException(UNMODIFIABLE);
}
/**
* {@inheritDoc}
*/
@Override
public boolean removeAllEdges(Collection extends E> edges)
{
throw new UnsupportedOperationException(UNMODIFIABLE);
}
/**
* {@inheritDoc}
*/
@Override
public Set removeAllEdges(V sourceVertex, V targetVertex)
{
throw new UnsupportedOperationException(UNMODIFIABLE);
}
/**
* {@inheritDoc}
*/
@Override
public boolean removeAllVertices(Collection extends V> vertices)
{
throw new UnsupportedOperationException(UNMODIFIABLE);
}
/**
* {@inheritDoc}
*/
@Override
public boolean removeEdge(E e)
{
throw new UnsupportedOperationException(UNMODIFIABLE);
}
/**
* {@inheritDoc}
*/
@Override
public E removeEdge(V sourceVertex, V targetVertex)
{
throw new UnsupportedOperationException(UNMODIFIABLE);
}
/**
* {@inheritDoc}
*/
@Override
public boolean removeVertex(V v)
{
throw new UnsupportedOperationException(UNMODIFIABLE);
}
private void addEdgesStartingAt(final Graph g, final V v, final V u, boolean createLoops)
{
if (!g.containsEdge(v, u)) {
return;
}
final List adjVertices = Graphs.neighborListOf(g, u);
for (final V w : adjVertices) {
if (g.containsEdge(u, w) && ((v != w) || createLoops)) {
super.addEdge(v, w);
}
}
}
private void addSquareEdges(Graph g, boolean createLoops)
{
for (V v : g.vertexSet()) {
List adjVertices = Graphs.neighborListOf(g, v);
for (V adjVertice : adjVertices) {
addEdgesStartingAt(g, v, adjVertice, createLoops);
}
}
}
}
// End GraphSquare.java
© 2015 - 2025 Weber Informatics LLC | Privacy Policy