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

org.prorefactor.treeparser.ExecutionGraph Maven / Gradle / Ivy

There is a newer version: 2.29.1
Show newest version
/********************************************************************************
 * Copyright (c) 2015-2024 Riverside Software
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0.
 *
 * This Source Code may also be made available under the following Secondary
 * Licenses when the conditions for such availability set forth in the Eclipse
 * Public License, v. 2.0 are satisfied: GNU Lesser General Public License v3.0
 * which is available at https://www.gnu.org/licenses/lgpl-3.0.txt
 *
 * SPDX-License-Identifier: EPL-2.0 OR LGPL-3.0
 ********************************************************************************/
package org.prorefactor.treeparser;

import java.util.ArrayList;
import java.util.List;

import org.prorefactor.core.JPNode;

public class ExecutionGraph {
  private final List vertices = new ArrayList<>();
  private final List> edges = new ArrayList<>();

  public ExecutionGraph() {
    // No-op
  }

  public void addVertex(JPNode vertex) {
    if (!vertices.contains(vertex)) {
      vertices.add(vertex);
      edges.add(new ArrayList<>());
    }
  }

  public void addEdge(JPNode from, JPNode to) {
    int fromIndex = vertices.indexOf(from);
    int toIndex = vertices.indexOf(to);

    if ((fromIndex == -1) || (toIndex == -1))
      return;

    List list = edges.get(fromIndex);
    if (!list.contains(toIndex))
      list.add(toIndex);
  }

  public List getVertices() {
    return vertices;
  }

  public List> getEdges() {
    return edges;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy