ltd-graph-builder/src/main/java/grafos/Visitador.java

94 lines
2.7 KiB
Java
Raw Normal View History

2019-03-26 20:11:14 +01:00
package grafos;
import com.github.javaparser.ast.NodeList;
import com.github.javaparser.ast.body.MethodDeclaration;
import com.github.javaparser.ast.stmt.BlockStmt;
import com.github.javaparser.ast.stmt.ExpressionStmt;
import com.github.javaparser.ast.stmt.Statement;
import com.github.javaparser.ast.visitor.VoidVisitorAdapter;
import java.util.List;
2019-03-26 20:11:14 +01:00
public class Visitador extends VoidVisitorAdapter<List<String>> {
2019-03-26 20:25:29 +01:00
//********************************************************/
//********************** Atributos ***********************/
//********************************************************/
2019-03-26 20:11:14 +01:00
// Usamos un contador para numerar las instrucciones
private int contador = 1;
2019-03-26 20:25:29 +01:00
private String nodoAnterior = "Start";
private String nodoActual = "";
2019-03-26 20:25:29 +01:00
//********************************************************/
//*********************** Metodos ************************/
//********************************************************/
2019-03-26 20:11:14 +01:00
// Visitador de métodos
2019-03-26 20:11:14 +01:00
// Este visitador añade el nodo final al CFG
@Override
public void visit(MethodDeclaration methodDeclaration, List<String> collector) {
// Visitamos el método
2019-03-26 20:11:14 +01:00
super.visit(methodDeclaration, collector);
2019-03-26 20:11:14 +01:00
// Añadimos el nodo final al CFG
collector.add(nodoAnterior + "-> Stop;");
2019-03-26 20:11:14 +01:00
}
2019-03-26 20:11:14 +01:00
// Visitador de expresiones
// Cada expresión encontrada genera un nodo en el CFG
@Override
public void visit(ExpressionStmt es, List<String> collector) {
2019-03-26 20:11:14 +01:00
// Creamos el nodo actual
nodoActual = crearNodo(es);
2019-03-26 20:11:14 +01:00
crearArcos(collector);
2019-03-26 20:11:14 +01:00
nodoAnterior = nodoActual;
2019-03-26 20:11:14 +01:00
// Seguimos visitando...
super.visit(es, collector);
}
2019-03-26 20:11:14 +01:00
// Añade un arco desde el último nodo hasta el nodo actual (se le pasa como parametro)
private void añadirArcoSecuencialCFG(List<String> collector) {
2019-03-26 20:11:14 +01:00
System.out.println("NODO: " + nodoActual);
2019-03-26 20:11:14 +01:00
String arco = nodoAnterior + "->" + nodoActual + ";";
collector.add(arco);
}
2019-03-26 20:11:14 +01:00
// Crear arcos
private void crearArcos(List<String> collector) {
añadirArcoSecuencialCFG(collector);
2019-03-26 20:11:14 +01:00
}
// Crear nodo
// Añade un arco desde el nodo actual hasta el último control
private String crearNodo(Object objeto) {
return "\"(" + contador++ + ") " + quitarComillas(objeto.toString()) + "\"";
2019-03-26 20:11:14 +01:00
}
2019-03-26 20:11:14 +01:00
// Sustituye " por \" en un string: Sirve para eliminar comillas.
private static String quitarComillas(String texto) {
return texto.replace("\"", "\\\"");
2019-03-26 20:11:14 +01:00
}
2019-03-26 20:11:14 +01:00
// Dada una sentencia,
// Si es una <20>nica instrucci<63>n, devuelve un bloque equivalente
// Si es un bloque, lo devuelve
private BlockStmt convertirEnBloque(Statement statement) {
2019-03-26 20:11:14 +01:00
if (statement instanceof BlockStmt)
return (BlockStmt) statement;
BlockStmt block = new BlockStmt();
NodeList<Statement> blockStmts = new NodeList<Statement>();
blockStmts.add(statement);
block.setStatements(blockStmts);
return block;
}
2019-03-26 20:11:14 +01:00
}