Skip to content
Node.java 4.96 KiB
Newer Older
Javier Costa's avatar
Javier Costa committed
package tfm.nodes;
Javier Costa's avatar
Javier Costa committed

Javier Costa's avatar
Javier Costa committed
import com.github.javaparser.ast.stmt.Statement;
Javier Costa's avatar
Javier Costa committed
import edg.graphlib.Arrow;
Javier Costa's avatar
Javier Costa committed
import edg.graphlib.Vertex;
Javier Costa's avatar
Javier Costa committed
import org.checkerframework.checker.nullness.qual.NonNull;
Javier Costa's avatar
Javier Costa committed
import org.jetbrains.annotations.NotNull;
Javier Costa's avatar
Javier Costa committed
import tfm.arcs.data.ArcData;
Javier Costa's avatar
Javier Costa committed
import tfm.utils.Utils;
Javier Costa's avatar
Javier Costa committed
import tfm.variables.VariableExtractor;
Javier Costa's avatar
Javier Costa committed

Javier Costa's avatar
Javier Costa committed
import java.util.*;
Javier Costa's avatar
Javier Costa committed
import java.util.stream.Collectors;

public class Node<ASTNode extends com.github.javaparser.ast.Node> extends Vertex<String, ArcData> {
Javier Costa's avatar
Javier Costa committed

    private ASTNode astNode;
Javier Costa's avatar
Javier Costa committed
    protected Set<String> declaredVariables;
    protected Set<String> definedVariables;
    protected Set<String> usedVariables;
    public <N extends Node<ASTNode>> Node(N node) {
Javier Costa's avatar
Javier Costa committed
        this(
                node.getId(),
                node.getData(),
                node.getAstNode(),
                node.getIncomingArrows(),
                node.getOutgoingArrows(),
                node.getDeclaredVariables(),
                node.getDefinedVariables(),
                node.getUsedVariables()
        );
Javier Costa's avatar
Javier Costa committed
    }

Javier Costa's avatar
Javier Costa committed
    public Node(int id, String representation, @NotNull ASTNode astNode) {
        this(
                id,
                representation,
                astNode,
                Utils.emptyList(),
                Utils.emptyList(),
                Utils.emptySet(),
                Utils.emptySet(),
                Utils.emptySet()
        );
    }

    public Node(
                int id,
                String representation,
                @NonNull ASTNode astNode,
                Collection<? extends Arrow<String, ArcData>> incomingArcs,
                Collection<? extends Arrow<String, ArcData>> outgoingArcs,
                Set<String> declaredVariables,
                Set<String> definedVariables,
                Set<String> usedVariables
    ) {
Javier Costa's avatar
Javier Costa committed
        super(String.valueOf(id), representation);
        this.astNode = astNode;
Javier Costa's avatar
Javier Costa committed

Javier Costa's avatar
Javier Costa committed
        this.declaredVariables = declaredVariables;
        this.definedVariables = definedVariables;
        this.usedVariables = usedVariables;

        this.setIncomingArcs(incomingArcs);
        this.setOutgoingArcs(outgoingArcs);
Javier Costa's avatar
Javier Costa committed

        if (astNode instanceof Statement) {
            extractVariables((Statement) astNode);
        }
Javier Costa's avatar
Javier Costa committed
    }

    private void extractVariables(@NonNull Statement statement) {
        new VariableExtractor()
                .setOnVariableDeclarationListener(variable -> this.declaredVariables.add(variable))
                .setOnVariableDefinitionListener(variable -> this.definedVariables.add(variable))
                .setOnVariableUseListener(variable -> this.usedVariables.add(variable))
                .visit(statement);
Javier Costa's avatar
Javier Costa committed
    }

    public int getId() {
        return Integer.parseInt(getName());
    }

    public String toString() {
Javier Costa's avatar
Javier Costa committed
        return String.format("Node{id: %s, data: '%s', in: %s, out: %s}",
Javier Costa's avatar
Javier Costa committed
                getName(),
                getData(),
                getIncomingArrows().stream().map(arrow -> arrow.getFrom().getName()).collect(Collectors.toList()),
                getOutgoingArrows().stream().map(arc -> arc.getTo().getName()).collect(Collectors.toList()));
    }
    public ASTNode getAstNode() {
        return astNode;
Javier Costa's avatar
Javier Costa committed
    public Optional<Integer> getFileLineNumber() {
        return astNode.getBegin().isPresent() ? Optional.of(astNode.getBegin().get().line) : Optional.empty();
Javier Costa's avatar
Javier Costa committed

Javier Costa's avatar
Javier Costa committed
    public void addDeclaredVariable(String variable) {
        declaredVariables.add(variable);
    }

    public void addDefinedVariable(String variable) {
        definedVariables.add(variable);
    }

    public void addUsedVariable(String variable) {
        usedVariables.add(variable);
    }

Javier Costa's avatar
Javier Costa committed
    @Override
    public boolean equals(Object o) {
        if (this == o)
            return true;

Javier Costa's avatar
Javier Costa committed
        if (!(o instanceof Node))
Javier Costa's avatar
Javier Costa committed
            return false;

Javier Costa's avatar
Javier Costa committed
        Node other = (Node) o;
Javier Costa's avatar
Javier Costa committed

        return Objects.equals(getData(), other.getData())
Javier Costa's avatar
Javier Costa committed
//                && Objects.equals(getIncomingArrows(), other.getIncomingArrows())
//                && Objects.equals(getOutgoingArrows(), other.getOutgoingArrows())
                && Objects.equals(astNode, other.astNode);
Javier Costa's avatar
Javier Costa committed
                // && Objects.equals(getName(), other.getName()) ID IS ALWAYS UNIQUE, SO IT WILL NEVER BE THE SAME
    }
Javier Costa's avatar
Javier Costa committed

    public String toGraphvizRepresentation() {
        return String.format("%s[label=\"%s: %s\"];", getId(), getId(), getData());
    }
Javier Costa's avatar
Javier Costa committed

    public Set<String> getDeclaredVariables() {
        return declaredVariables;
    }

    public Set<String> getDefinedVariables() {
        return definedVariables;
    }

    public Set<String> getUsedVariables() {
        return usedVariables;
    }
Javier Costa's avatar
Javier Costa committed

    public <A extends Arrow<String, ArcData>, C extends Collection<A>> void setIncomingArcs(C arcs) {
        for (A arc : arcs) {
            this.addIncomingEdge(arc.getFrom(), arc.getCost());
        }
    }

    public <A extends Arrow<String, ArcData>, C extends Collection<A>> void setOutgoingArcs(C arcs) {
        for (A arc : arcs) {
            this.addOutgoingEdge(arc.getTo(), arc.getCost());
        }
    }
Javier Costa's avatar
Javier Costa committed
}