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

pascal.taie.util.graph.SimpleGraph Maven / Gradle / Ivy

/*
 * Tai-e: A Static Analysis Framework for Java
 *
 * Copyright (C) 2022 Tian Tan 
 * Copyright (C) 2022 Yue Li 
 *
 * This file is part of Tai-e.
 *
 * Tai-e 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
 * of the License, or (at your option) any later version.
 *
 * Tai-e 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 General
 * Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with Tai-e. If not, see .
 */

package pascal.taie.util.graph;

import pascal.taie.util.collection.Maps;
import pascal.taie.util.collection.MultiMap;
import pascal.taie.util.collection.Sets;

import java.util.Collections;
import java.util.Set;

/**
 * A simple map-based implementation of {@link Graph}.
 *
 * @param  type of nodes
 */
public class SimpleGraph implements Graph {

    private final Set nodes = Sets.newSet();

    private final MultiMap preds = Maps.newMultiMap();

    private final MultiMap succs = Maps.newMultiMap();

    /**
     * Constructs an empty graph.
     */
    public SimpleGraph() {
    }

    /**
     * Constructs a new graph containing the same node and edge sets
     * as the specified graph.
     */
    public SimpleGraph(Graph graph) {
        for (N node : graph) {
            addNode(node);
            for (N succ : graph.getSuccsOf(node)) {
                addEdge(node, succ);
            }
        }
    }

    public void addNode(N node) {
        nodes.add(node);
    }

    public void addEdge(N source, N target) {
        nodes.add(source);
        nodes.add(target);
        preds.put(target, source);
        succs.put(source, target);
    }

    /**
     * Removes a node from this graph.
     * All edges from/to the node will also be removed.
     */
    public void removeNode(N node) {
        nodes.remove(node);
        preds.removeAll(node);
        succs.removeAll(node);
    }

    /**
     * Removes an edge from this graph.
     */
    public void removeEdge(N source, N target) {
        preds.remove(target, source);
        succs.remove(source, target);
    }

    @Override
    public Set getPredsOf(N node) {
        return preds.get(node);
    }

    @Override
    public Set getSuccsOf(N node) {
        return succs.get(node);
    }

    @Override
    public int getInDegreeOf(N node) {
        return preds.get(node).size();
    }

    @Override
    public Set getNodes() {
        return Collections.unmodifiableSet(nodes);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy