Skip to content
GraphNode.java 4.14 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.Node;
Javier Costa's avatar
Javier Costa committed
import com.github.javaparser.ast.stmt.Statement;
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;
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

Javier Costa's avatar
Javier Costa committed
public class GraphNode<N extends Node> {
Javier Costa's avatar
Javier Costa committed

Javier Costa's avatar
Javier Costa committed
    private int id;
Javier Costa's avatar
Javier Costa committed
    private String instruction;
Javier Costa's avatar
Javier Costa committed

Javier Costa's avatar
Javier Costa committed
    protected N astNode;
Javier Costa's avatar
Javier Costa committed
    protected Set<String> declaredVariables;
    protected Set<String> definedVariables;
    protected Set<String> usedVariables;
Javier Costa's avatar
Javier Costa committed
    public <N1 extends GraphNode<N>> GraphNode(N1 node) {
Javier Costa's avatar
Javier Costa committed
        this(
                node.getId(),
Javier Costa's avatar
Javier Costa committed
                node.getInstruction(),
Javier Costa's avatar
Javier Costa committed
                node.getAstNode(),
                node.getDeclaredVariables(),
                node.getDefinedVariables(),
                node.getUsedVariables()
        );
Javier Costa's avatar
Javier Costa committed
    }

Javier Costa's avatar
Javier Costa committed
    public GraphNode(int id, String instruction, @NotNull N astNode) {
Javier Costa's avatar
Javier Costa committed
        this(
                id,
Javier Costa's avatar
Javier Costa committed
                instruction,
Javier Costa's avatar
Javier Costa committed
                astNode,
                Utils.emptySet(),
                Utils.emptySet(),
                Utils.emptySet()
        );
    }

Javier Costa's avatar
Javier Costa committed
    public GraphNode(
Javier Costa's avatar
Javier Costa committed
                int id,
Javier Costa's avatar
Javier Costa committed
                String instruction,
Javier Costa's avatar
Javier Costa committed
                @NonNull N astNode,
Javier Costa's avatar
Javier Costa committed
                Set<String> declaredVariables,
                Set<String> definedVariables,
                Set<String> usedVariables
    ) {
Javier Costa's avatar
Javier Costa committed
        this.id = id;
Javier Costa's avatar
Javier Costa committed
        this.instruction = instruction;
        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;

        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
    }

Javier Costa's avatar
Javier Costa committed
    public void setId(int id) {
        this.id = id;
    }

Javier Costa's avatar
Javier Costa committed
    public int getId() {
Javier Costa's avatar
Javier Costa committed
        return id;
Javier Costa's avatar
Javier Costa committed
    }

    public String toString() {
Javier Costa's avatar
Javier Costa committed
        return String.format("GraphNode{id: %s, instruction: '%s'}",
Javier Costa's avatar
Javier Costa committed
                getId(),
Javier Costa's avatar
Javier Costa committed
                getInstruction()
        );
Javier Costa's avatar
Javier Costa committed
    }
Javier Costa's avatar
Javier Costa committed
    public N getAstNode() {
        return astNode;
Javier Costa's avatar
Javier Costa committed
    public void setAstNode(N node) {
        this.astNode = node;
    }

Javier Costa's avatar
Javier Costa committed
    public Optional<Integer> getFileLineNumber() {
Javier Costa's avatar
Javier Costa committed
        return astNode.getBegin()
                .map(begin -> begin.line);
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 GraphNode))
Javier Costa's avatar
Javier Costa committed
            return false;

Javier Costa's avatar
Javier Costa committed
        GraphNode<?> other = (GraphNode<?>) o;
Javier Costa's avatar
Javier Costa committed

Javier Costa's avatar
Javier Costa committed
        return Objects.equals(getId(), other.getId())
                && Objects.equals(getInstruction(), other.getInstruction())
Javier Costa's avatar
Javier Costa committed
                && Objects.equals(astNode, other.astNode);
Javier Costa's avatar
Javier Costa committed
    }

    @Override
    public int hashCode() {
        return Objects.hash(getId(), getInstruction(), getAstNode());
Javier Costa's avatar
Javier Costa committed
    }
Javier Costa's avatar
Javier Costa committed

    public String toGraphvizRepresentation() {
Javier Costa's avatar
Javier Costa committed
        String text = getInstruction().replace("\\", "\\\\")
                .replace("\"", "\\\"");
        return String.format("%s[label=\"%s: %s\"];", getId(), getId(), text);
Javier Costa's avatar
Javier Costa committed
    }
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

Javier Costa's avatar
Javier Costa committed
    public String getInstruction() {
        return instruction;
Javier Costa's avatar
Javier Costa committed
    public void setInstruction(String instruction) {
        this.instruction = instruction;
Javier Costa's avatar
Javier Costa committed
    }
Javier Costa's avatar
Javier Costa committed
}