All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.evosuite.setup.callgraph.Graph Maven / Gradle / Ivy

/**
 * Copyright (C) 2010-2018 Gordon Fraser, Andrea Arcuri and EvoSuite
 * contributors
 *
 * This file is part of EvoSuite.
 *
 * EvoSuite is free software: you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License as published
 * by the Free Software Foundation, either version 3.0 of the License, or
 * (at your option) any later version.
 *
 * EvoSuite is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * Lesser Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with EvoSuite. If not, see .
 */
package org.evosuite.setup.callgraph;

import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.LinkedHashSet;
import java.util.Map;
import java.util.Set;
/**
 * 
 * simple implementation of a graph where edges are not classes.
 * @author mattia
 *
 * @param 
 */
public abstract class Graph {

	private final Map> edges = Collections.synchronizedMap(new HashMap>());
	private final Map> reverseEdges = Collections.synchronizedMap(new HashMap>());
	private final Set vertexSet = Collections.synchronizedSet(new HashSet());
	
	public Map> getEdges() {
		return edges;
	}
	
	public synchronized void removeVertex(E vertex) {
		edges.remove(vertex);
		reverseEdges.remove(vertex);
		vertexSet.remove(vertex);
	}

	public synchronized boolean containsEdge(E src, E dest){
		Set tempSet = edges.get(src);
		if(tempSet==null)
			return false;
		else return tempSet.contains(dest);
	}
	
	public synchronized void addEdge(E src, E dest) {
		vertexSet.add(src);
		vertexSet.add(dest);
		Set srcNeighbors = this.edges.get(src);
		if (srcNeighbors == null) {
			this.edges.put(src, srcNeighbors = new LinkedHashSet());
		}
		srcNeighbors.add(dest);
		
		Set rsrcNeighbors = this.reverseEdges.get(dest);
		if (rsrcNeighbors == null) {
			this.reverseEdges.put(dest, rsrcNeighbors = new LinkedHashSet());
		}
		rsrcNeighbors.add(src);
	}
	
	public synchronized Set getVertexSet() {
		return vertexSet;
	}
	
	public synchronized boolean containsVertex(E e){
		return vertexSet.contains(e);
	}

	public synchronized Iterable getNeighbors(E vertex) {
		Set neighbors = this.edges.get(vertex);
		if (neighbors == null) {
			return Collections.emptyList();
		} else {
			return Collections.unmodifiableSet(neighbors);
		}
	}
	
	public synchronized Iterable getReverseNeighbors(E vertex) {
		Set neighbors = this.reverseEdges.get(vertex);
		if (neighbors == null) {
			return Collections.emptyList();
		} else {
			return Collections.unmodifiableSet(neighbors);
		}
	}

	public synchronized int getNeighborsSize(E vertex) {
		if (this.edges.get(vertex) == null)
			return 0;
		return this.edges.get(vertex).size();
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy