Moved from List<String> to CFG object
This commit is contained in:
parent
0e5667582b
commit
221c9e6b23
3 changed files with 95 additions and 82 deletions
|
@ -1,24 +1,16 @@
|
|||
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;
|
||||
|
||||
|
||||
public class Visitador extends VoidVisitorAdapter<List<String>> {
|
||||
public class Visitador extends VoidVisitorAdapter<CFG> {
|
||||
//********************************************************/
|
||||
//********************** Atributos ***********************/
|
||||
//********************************************************/
|
||||
|
||||
// Usamos un contador para numerar las instrucciones
|
||||
private int contador = 1;
|
||||
private String nodoAnterior = "Start";
|
||||
private String nodoActual = "";
|
||||
private Statement prevNode;
|
||||
|
||||
//********************************************************/
|
||||
//*********************** Metodos ************************/
|
||||
|
@ -27,67 +19,27 @@ public class Visitador extends VoidVisitorAdapter<List<String>> {
|
|||
// Visitador de métodos
|
||||
// Este visitador añade el nodo final al CFG
|
||||
@Override
|
||||
public void visit(MethodDeclaration methodDeclaration, List<String> collector) {
|
||||
public void visit(MethodDeclaration methodDeclaration, CFG graph) {
|
||||
prevNode = graph.beginNode();
|
||||
|
||||
// Visitamos el método
|
||||
super.visit(methodDeclaration, collector);
|
||||
super.visit(methodDeclaration, graph);
|
||||
|
||||
// Añadimos el nodo final al CFG
|
||||
collector.add(nodoAnterior + "-> Stop;");
|
||||
Statement end = graph.endNode();
|
||||
if (prevNode != end)
|
||||
graph.connect(prevNode, end);
|
||||
}
|
||||
|
||||
// Visitador de expresiones
|
||||
// Cada expresión encontrada genera un nodo en el CFG
|
||||
@Override
|
||||
public void visit(ExpressionStmt es, List<String> collector) {
|
||||
// Creamos el nodo actual
|
||||
nodoActual = crearNodo(es);
|
||||
|
||||
crearArcos(collector);
|
||||
|
||||
nodoAnterior = nodoActual;
|
||||
public void visit(ExpressionStmt es, CFG graph) {
|
||||
graph.addNode(es);
|
||||
graph.connect(prevNode, es);
|
||||
prevNode = es;
|
||||
|
||||
// Seguimos visitando...
|
||||
super.visit(es, collector);
|
||||
super.visit(es, graph);
|
||||
}
|
||||
|
||||
// Añade un arco desde el último nodo hasta el nodo actual (se le pasa como parametro)
|
||||
private void añadirArcoSecuencialCFG(List<String> collector) {
|
||||
System.out.println("NODO: " + nodoActual);
|
||||
|
||||
String arco = nodoAnterior + "->" + nodoActual + ";";
|
||||
collector.add(arco);
|
||||
}
|
||||
|
||||
// Crear arcos
|
||||
private void crearArcos(List<String> collector) {
|
||||
añadirArcoSecuencialCFG(collector);
|
||||
}
|
||||
|
||||
// Crear nodo
|
||||
// Añade un arco desde el nodo actual hasta el último control
|
||||
private String crearNodo(Object objeto) {
|
||||
return "\"(" + contador++ + ") " + quitarComillas(objeto.toString()) + "\"";
|
||||
}
|
||||
|
||||
// Sustituye " por \" en un string: Sirve para eliminar comillas.
|
||||
private static String quitarComillas(String texto) {
|
||||
return texto.replace("\"", "\\\"");
|
||||
}
|
||||
|
||||
// Dada una sentencia,
|
||||
// Si es una <EFBFBD>nica instrucci<EFBFBD>n, devuelve un bloque equivalente
|
||||
// Si es un bloque, lo devuelve
|
||||
private BlockStmt convertirEnBloque(Statement statement) {
|
||||
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;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue