Set indent to tabs and applied format to project
This commit is contained in:
parent
782a4361c2
commit
0e5667582b
21 changed files with 586 additions and 634 deletions
14
.idea/codeStyles/Project.xml
Normal file
14
.idea/codeStyles/Project.xml
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
<component name="ProjectCodeStyleConfiguration">
|
||||||
|
<code_scheme name="Project" version="173">
|
||||||
|
<codeStyleSettings language="JAVA">
|
||||||
|
<indentOptions>
|
||||||
|
<option name="USE_TAB_CHARACTER" value="true" />
|
||||||
|
</indentOptions>
|
||||||
|
</codeStyleSettings>
|
||||||
|
<codeStyleSettings language="XML">
|
||||||
|
<indentOptions>
|
||||||
|
<option name="USE_TAB_CHARACTER" value="true" />
|
||||||
|
</indentOptions>
|
||||||
|
</codeStyleSettings>
|
||||||
|
</code_scheme>
|
||||||
|
</component>
|
5
.idea/codeStyles/codeStyleConfig.xml
Normal file
5
.idea/codeStyles/codeStyleConfig.xml
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
<component name="ProjectCodeStyleConfiguration">
|
||||||
|
<state>
|
||||||
|
<option name="USE_PER_PROJECT_SETTINGS" value="true" />
|
||||||
|
</state>
|
||||||
|
</component>
|
|
@ -4,106 +4,94 @@ package grafos;
|
||||||
|
|
||||||
/*$Id$*/
|
/*$Id$*/
|
||||||
/*
|
/*
|
||||||
******************************************************************************
|
******************************************************************************
|
||||||
* *
|
* *
|
||||||
* (c) Copyright Laszlo Szathmary *
|
* (c) Copyright Laszlo Szathmary *
|
||||||
* *
|
* *
|
||||||
* This program is free software; you can redistribute it and/or modify it *
|
* This program is free software; you can redistribute it and/or modify it *
|
||||||
* under the terms of the GNU Lesser General Public License as published by *
|
* under the terms of the GNU Lesser General Public License as published by *
|
||||||
* the Free Software Foundation; either version 2.1 of the License, or *
|
* the Free Software Foundation; either version 2.1 of the License, or *
|
||||||
* (at your option) any later version. *
|
* (at your option) any later version. *
|
||||||
* *
|
* *
|
||||||
* This program is distributed in the hope that it will be useful, but *
|
* This program is distributed in the hope that it will be useful, but *
|
||||||
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY *
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY *
|
||||||
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public *
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public *
|
||||||
* License for more details. *
|
* License for more details. *
|
||||||
* *
|
* *
|
||||||
* You should have received a copy of the GNU Lesser General Public License *
|
* You should have received a copy of the GNU Lesser General Public License *
|
||||||
* along with this program; if not, write to the Free Software Foundation, *
|
* along with this program; if not, write to the Free Software Foundation, *
|
||||||
* Inc., 675 Mass Ave, Cambridge, MA 02139, USA. *
|
* Inc., 675 Mass Ave, Cambridge, MA 02139, USA. *
|
||||||
* *
|
* *
|
||||||
******************************************************************************
|
******************************************************************************
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import java.io.BufferedReader;
|
import java.io.*;
|
||||||
import java.io.BufferedWriter;
|
|
||||||
import java.io.DataInputStream;
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.FileInputStream;
|
|
||||||
import java.io.FileOutputStream;
|
|
||||||
import java.io.FileWriter;
|
|
||||||
import java.io.InputStreamReader;
|
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <dl>
|
* <dl>
|
||||||
* <dt>Purpose: GraphViz Java API
|
* <dt>Purpose: GraphViz Java API
|
||||||
* <dd>
|
* <dd>
|
||||||
*
|
*
|
||||||
* <dt>Description:
|
* <dt>Description:
|
||||||
* <dd> With this Java class you can simply call dot
|
* <dd> With this Java class you can simply call dot
|
||||||
* from your Java programs.
|
* from your Java programs.
|
||||||
* <dt>Example usage:
|
* <dt>Example usage:
|
||||||
* <dd>
|
* <dd>
|
||||||
* <pre>
|
* <pre>
|
||||||
* GraphViz gv = new GraphViz();
|
* GraphViz gv = new GraphViz();
|
||||||
* gv.addln(gv.start_graph());
|
* gv.addln(gv.start_graph());
|
||||||
* gv.addln("A -> B;");
|
* gv.addln("A -> B;");
|
||||||
* gv.addln("A -> C;");
|
* gv.addln("A -> C;");
|
||||||
* gv.addln(gv.end_graph());
|
* gv.addln(gv.end_graph());
|
||||||
* System.out.println(gv.getDotSource());
|
* System.out.println(gv.getDotSource());
|
||||||
*
|
*
|
||||||
* String type = "gif";
|
* String type = "gif";
|
||||||
* File out = new File("out." + type); // out.gif in this example
|
* File out = new File("out." + type); // out.gif in this example
|
||||||
* gv.writeGraphToFile( gv.getGraph( gv.getDotSource(), type ), out );
|
* gv.writeGraphToFile( gv.getGraph( gv.getDotSource(), type ), out );
|
||||||
* </pre>
|
* </pre>
|
||||||
* </dd>
|
* </dd>
|
||||||
*
|
*
|
||||||
* </dl>
|
* </dl>
|
||||||
*
|
*
|
||||||
* @version v0.5.1, 2013/03/18 (March) -- Patch of Juan Hoyos (Mac support)
|
* @author Laszlo Szathmary (<a href="jabba.laci@gmail.com">jabba.laci@gmail.com</a>)
|
||||||
* @version v0.5, 2012/04/24 (April) -- Patch of Abdur Rahman (OS detection + start subgraph +
|
* @version v0.1, 2003/12/04 (December) -- first release
|
||||||
* read config file)
|
*/
|
||||||
* @version v0.4, 2011/02/05 (February) -- Patch of Keheliya Gallaba is added. Now you
|
public class GraphViz {
|
||||||
* can specify the type of the output file: gif, dot, fig, pdf, ps, svg, png, etc.
|
|
||||||
* @version v0.3, 2010/11/29 (November) -- Windows support + ability to read the graph from a text file
|
|
||||||
* @version v0.2, 2010/07/22 (July) -- bug fix
|
|
||||||
* @version v0.1, 2003/12/04 (December) -- first release
|
|
||||||
* @author Laszlo Szathmary (<a href="jabba.laci@gmail.com">jabba.laci@gmail.com</a>)
|
|
||||||
*/
|
|
||||||
public class GraphViz
|
|
||||||
{
|
|
||||||
/**
|
/**
|
||||||
* Detects the client's operating system.
|
* Detects the client's operating system.
|
||||||
*/
|
*/
|
||||||
private final static String osName = System.getProperty("os.name").replaceAll("\\s","");
|
private final static String osName = System.getProperty("os.name").replaceAll("\\s", "");
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Load the config.properties file.
|
* Load the config.properties file.
|
||||||
*/
|
*/
|
||||||
private final static String cfgProp = "./src/main/res/config.properties";
|
private final static String cfgProp = "./src/main/res/config.properties";
|
||||||
private final static Properties configFile = new Properties() {
|
private final static Properties configFile = new Properties() {
|
||||||
private final static long serialVersionUID = 1L; {
|
private final static long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
{
|
||||||
try {
|
try {
|
||||||
load(new FileInputStream(cfgProp));
|
load(new FileInputStream(cfgProp));
|
||||||
} catch (Exception ignored) {}
|
} catch (Exception ignored) {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The dir. where temporary files will be created.
|
* The dir. where temporary files will be created.
|
||||||
*/
|
*/
|
||||||
private static String TEMP_DIR = "/tmp/";
|
private static String TEMP_DIR = "/tmp/";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Where is your dot program located? It will be called externally.
|
* Where is your dot program located? It will be called externally.
|
||||||
*/
|
*/
|
||||||
private static String DOT = configFile.getProperty("dotFor" + osName);
|
private static String DOT = configFile.getProperty("dotFor" + osName);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The image size in dpi. 96 dpi is normal size. Higher values are 10% higher each.
|
* The image size in dpi. 96 dpi is normal size. Higher values are 10% higher each.
|
||||||
* Lower values 10% lower each.
|
* Lower values 10% lower each.
|
||||||
*
|
* <p>
|
||||||
* dpi patch by Peter Mueller
|
* dpi patch by Peter Mueller
|
||||||
*/
|
*/
|
||||||
private int[] dpiSizes = {46, 51, 57, 63, 70, 78, 86, 96, 106, 116, 128, 141, 155, 170, 187, 206, 226, 249};
|
private int[] dpiSizes = {46, 51, 57, 63, 70, 78, 86, 96, 106, 116, 128, 141, 155, 170, 187, 206, 226, 249};
|
||||||
|
@ -117,7 +105,7 @@ private static String DOT = configFile.getProperty("dotFor" + osName);
|
||||||
* Increase the image size (dpi).
|
* Increase the image size (dpi).
|
||||||
*/
|
*/
|
||||||
public void increaseDpi() {
|
public void increaseDpi() {
|
||||||
if ( this.currentDpiPos < (this.dpiSizes.length - 1) ) {
|
if (this.currentDpiPos < (this.dpiSizes.length - 1)) {
|
||||||
++this.currentDpiPos;
|
++this.currentDpiPos;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -149,6 +137,7 @@ private static String DOT = configFile.getProperty("dotFor" + osName);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the graph's source description in dot language.
|
* Returns the graph's source description in dot language.
|
||||||
|
*
|
||||||
* @return Source of the graph in dot language.
|
* @return Source of the graph in dot language.
|
||||||
*/
|
*/
|
||||||
public String getDotSource() {
|
public String getDotSource() {
|
||||||
|
@ -176,80 +165,83 @@ private static String DOT = configFile.getProperty("dotFor" + osName);
|
||||||
this.graph.append('\n');
|
this.graph.append('\n');
|
||||||
}
|
}
|
||||||
|
|
||||||
public void clearGraph(){
|
public void clearGraph() {
|
||||||
this.graph = new StringBuilder();
|
this.graph = new StringBuilder();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the graph as an image in binary format.
|
* Returns the graph as an image in binary format.
|
||||||
|
*
|
||||||
* @param dot_source Source of the graph to be drawn.
|
* @param dot_source Source of the graph to be drawn.
|
||||||
* @param type Type of the output image to be produced, e.g.: gif, dot, fig, pdf, ps, svg, png.
|
* @param type Type of the output image to be produced, e.g.: gif, dot, fig, pdf, ps, svg, png.
|
||||||
* @return A byte array containing the image of the graph.
|
* @return A byte array containing the image of the graph.
|
||||||
*/
|
*/
|
||||||
public byte[] getGraph(String dot_source, String type)
|
public byte[] getGraph(String dot_source, String type) {
|
||||||
{
|
|
||||||
File dot;
|
File dot;
|
||||||
byte[] img_stream;
|
byte[] img_stream;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
dot = writeDotSourceToFile(dot_source);
|
dot = writeDotSourceToFile(dot_source);
|
||||||
if (dot != null)
|
if (dot != null) {
|
||||||
{
|
|
||||||
img_stream = get_img_stream(dot, type);
|
img_stream = get_img_stream(dot, type);
|
||||||
if (!dot.delete())
|
if (!dot.delete())
|
||||||
System.err.println("Warning: " + dot.getAbsolutePath() + " could not be deleted!");
|
System.err.println("Warning: " + dot.getAbsolutePath() + " could not be deleted!");
|
||||||
return img_stream;
|
return img_stream;
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
} catch (java.io.IOException ioe) { return null; }
|
} catch (java.io.IOException ioe) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Writes the graph's image in a file.
|
* Writes the graph's image in a file.
|
||||||
|
*
|
||||||
* @param img A byte array containing the image of the graph.
|
* @param img A byte array containing the image of the graph.
|
||||||
* @param file Name of the file to where we want to write.
|
* @param file Name of the file to where we want to write.
|
||||||
* @return Success: 1, Failure: -1
|
* @return Success: 1, Failure: -1
|
||||||
*/
|
*/
|
||||||
public int writeGraphToFile(byte[] img, String file)
|
public int writeGraphToFile(byte[] img, String file) {
|
||||||
{
|
|
||||||
File to = new File(file);
|
File to = new File(file);
|
||||||
return writeGraphToFile(img, to);
|
return writeGraphToFile(img, to);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Writes the graph's image in a file.
|
* Writes the graph's image in a file.
|
||||||
|
*
|
||||||
* @param img A byte array containing the image of the graph.
|
* @param img A byte array containing the image of the graph.
|
||||||
* @param to A File object to where we want to write.
|
* @param to A File object to where we want to write.
|
||||||
* @return Success: 1, Failure: -1
|
* @return Success: 1, Failure: -1
|
||||||
*/
|
*/
|
||||||
public int writeGraphToFile(byte[] img, File to)
|
public int writeGraphToFile(byte[] img, File to) {
|
||||||
{
|
|
||||||
try {
|
try {
|
||||||
FileOutputStream fos = new FileOutputStream(to);
|
FileOutputStream fos = new FileOutputStream(to);
|
||||||
fos.write(img);
|
fos.write(img);
|
||||||
fos.close();
|
fos.close();
|
||||||
} catch (java.io.IOException ioe) { return -1; }
|
} catch (java.io.IOException ioe) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* It will call the external dot program, and return the image in
|
* It will call the external dot program, and return the image in
|
||||||
* binary format.
|
* binary format.
|
||||||
|
*
|
||||||
* @param dot Source of the graph (in dot language).
|
* @param dot Source of the graph (in dot language).
|
||||||
* @param type Type of the output image to be produced, e.g.: gif, dot, fig, pdf, ps, svg, png.
|
* @param type Type of the output image to be produced, e.g.: gif, dot, fig, pdf, ps, svg, png.
|
||||||
* @return The image of the graph in .gif format.
|
* @return The image of the graph in .gif format.
|
||||||
*/
|
*/
|
||||||
private byte[] get_img_stream(File dot, String type)
|
private byte[] get_img_stream(File dot, String type) {
|
||||||
{
|
|
||||||
File img;
|
File img;
|
||||||
byte[] img_stream = null;
|
byte[] img_stream = null;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
img = File.createTempFile("graph_", "."+type, new File(GraphViz.TEMP_DIR));
|
img = File.createTempFile("graph_", "." + type, new File(GraphViz.TEMP_DIR));
|
||||||
Runtime rt = Runtime.getRuntime();
|
Runtime rt = Runtime.getRuntime();
|
||||||
|
|
||||||
// patch by Mike Chenault
|
// patch by Mike Chenault
|
||||||
String[] args = {DOT, "-T"+type, "-Gdpi="+dpiSizes[this.currentDpiPos], dot.getAbsolutePath(), "-o", img.getAbsolutePath()};
|
String[] args = {DOT, "-T" + type, "-Gdpi=" + dpiSizes[this.currentDpiPos], dot.getAbsolutePath(), "-o", img.getAbsolutePath()};
|
||||||
Process p = rt.exec(args);
|
Process p = rt.exec(args);
|
||||||
|
|
||||||
p.waitFor();
|
p.waitFor();
|
||||||
|
@ -262,13 +254,11 @@ private static String DOT = configFile.getProperty("dotFor" + osName);
|
||||||
|
|
||||||
if (!img.delete())
|
if (!img.delete())
|
||||||
System.err.println("Warning: " + img.getAbsolutePath() + " could not be deleted!");
|
System.err.println("Warning: " + img.getAbsolutePath() + " could not be deleted!");
|
||||||
}
|
} catch (java.io.IOException ioe) {
|
||||||
catch (java.io.IOException ioe) {
|
System.err.println("Error: in I/O processing of tempfile in dir " + GraphViz.TEMP_DIR + "\n");
|
||||||
System.err.println("Error: in I/O processing of tempfile in dir " + GraphViz.TEMP_DIR+"\n");
|
|
||||||
System.err.println(" or in calling external command");
|
System.err.println(" or in calling external command");
|
||||||
ioe.printStackTrace();
|
ioe.printStackTrace();
|
||||||
}
|
} catch (java.lang.InterruptedException ie) {
|
||||||
catch (java.lang.InterruptedException ie) {
|
|
||||||
System.err.println("Error: the execution of the external program was interrupted");
|
System.err.println("Error: the execution of the external program was interrupted");
|
||||||
ie.printStackTrace();
|
ie.printStackTrace();
|
||||||
}
|
}
|
||||||
|
@ -279,23 +269,22 @@ private static String DOT = configFile.getProperty("dotFor" + osName);
|
||||||
/**
|
/**
|
||||||
* Writes the source of the graph in a file, and returns the written file
|
* Writes the source of the graph in a file, and returns the written file
|
||||||
* as a File object.
|
* as a File object.
|
||||||
|
*
|
||||||
* @param str Source of the graph (in dot language).
|
* @param str Source of the graph (in dot language).
|
||||||
* @return The file (as a File object) that contains the source of the graph.
|
* @return The file (as a File object) that contains the source of the graph.
|
||||||
*/
|
*/
|
||||||
private File writeDotSourceToFile(String str) throws java.io.IOException
|
private File writeDotSourceToFile(String str) throws java.io.IOException {
|
||||||
{
|
|
||||||
File temp;
|
File temp;
|
||||||
try {
|
try {
|
||||||
temp = File.createTempFile("dorrr",".dot", new File(GraphViz.TEMP_DIR));
|
temp = File.createTempFile("dorrr", ".dot", new File(GraphViz.TEMP_DIR));
|
||||||
FileWriter fout = new FileWriter(temp);
|
FileWriter fout = new FileWriter(temp);
|
||||||
fout.write(str);
|
fout.write(str);
|
||||||
BufferedWriter br=new BufferedWriter(new FileWriter("/tmp/dotsource.dot"));
|
BufferedWriter br = new BufferedWriter(new FileWriter("/tmp/dotsource.dot"));
|
||||||
br.write(str);
|
br.write(str);
|
||||||
br.flush();
|
br.flush();
|
||||||
br.close();
|
br.close();
|
||||||
fout.close();
|
fout.close();
|
||||||
}
|
} catch (Exception e) {
|
||||||
catch (Exception e) {
|
|
||||||
System.err.println("Error: I/O error while writing the dot source to temp file!");
|
System.err.println("Error: I/O error while writing the dot source to temp file!");
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -304,6 +293,7 @@ private static String DOT = configFile.getProperty("dotFor" + osName);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a string that is used to start a graph.
|
* Returns a string that is used to start a graph.
|
||||||
|
*
|
||||||
* @return A string to open a graph.
|
* @return A string to open a graph.
|
||||||
*/
|
*/
|
||||||
public String start_graph() {
|
public String start_graph() {
|
||||||
|
@ -312,6 +302,7 @@ private static String DOT = configFile.getProperty("dotFor" + osName);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a string that is used to end a graph.
|
* Returns a string that is used to end a graph.
|
||||||
|
*
|
||||||
* @return A string to close a graph.
|
* @return A string to close a graph.
|
||||||
*/
|
*/
|
||||||
public String end_graph() {
|
public String end_graph() {
|
||||||
|
@ -321,6 +312,7 @@ private static String DOT = configFile.getProperty("dotFor" + osName);
|
||||||
/**
|
/**
|
||||||
* Takes the cluster or subgraph id as input parameter and returns a string
|
* Takes the cluster or subgraph id as input parameter and returns a string
|
||||||
* that is used to start a subgraph.
|
* that is used to start a subgraph.
|
||||||
|
*
|
||||||
* @return A string to open a subgraph.
|
* @return A string to open a subgraph.
|
||||||
*/
|
*/
|
||||||
public String start_subgraph(int clusterid) {
|
public String start_subgraph(int clusterid) {
|
||||||
|
@ -329,6 +321,7 @@ private static String DOT = configFile.getProperty("dotFor" + osName);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a string that is used to end a graph.
|
* Returns a string that is used to end a graph.
|
||||||
|
*
|
||||||
* @return A string to close a graph.
|
* @return A string to close a graph.
|
||||||
*/
|
*/
|
||||||
public String end_subgraph() {
|
public String end_subgraph() {
|
||||||
|
@ -341,12 +334,10 @@ private static String DOT = configFile.getProperty("dotFor" + osName);
|
||||||
* @param input Input text file containing the DOT graph
|
* @param input Input text file containing the DOT graph
|
||||||
* source.
|
* source.
|
||||||
*/
|
*/
|
||||||
public void readSource(String input)
|
public void readSource(String input) {
|
||||||
{
|
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
|
|
||||||
try
|
try {
|
||||||
{
|
|
||||||
FileInputStream fis = new FileInputStream(input);
|
FileInputStream fis = new FileInputStream(input);
|
||||||
DataInputStream dis = new DataInputStream(fis);
|
DataInputStream dis = new DataInputStream(fis);
|
||||||
BufferedReader br = new BufferedReader(new InputStreamReader(dis));
|
BufferedReader br = new BufferedReader(new InputStreamReader(dis));
|
||||||
|
@ -355,8 +346,7 @@ private static String DOT = configFile.getProperty("dotFor" + osName);
|
||||||
sb.append(line);
|
sb.append(line);
|
||||||
}
|
}
|
||||||
dis.close();
|
dis.close();
|
||||||
}
|
} catch (Exception e) {
|
||||||
catch (Exception e) {
|
|
||||||
System.err.println("Error: " + e.getMessage());
|
System.err.println("Error: " + e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,15 +1,15 @@
|
||||||
package grafos;
|
package grafos;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import com.github.javaparser.JavaParser;
|
import com.github.javaparser.JavaParser;
|
||||||
import com.github.javaparser.ast.CompilationUnit;
|
import com.github.javaparser.ast.CompilationUnit;
|
||||||
import com.github.javaparser.ast.Node;
|
import com.github.javaparser.ast.Node;
|
||||||
import com.github.javaparser.ast.comments.Comment;
|
import com.github.javaparser.ast.comments.Comment;
|
||||||
import com.github.javaparser.ast.visitor.VoidVisitor;
|
import com.github.javaparser.ast.visitor.VoidVisitor;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
public class Transformador {
|
public class Transformador {
|
||||||
|
|
||||||
public static void main(String[] args) throws Exception {
|
public static void main(String[] args) throws Exception {
|
||||||
|
@ -27,14 +27,14 @@ public class Transformador {
|
||||||
// Recorremos el AST
|
// Recorremos el AST
|
||||||
List<String> arcos = new ArrayList<String>();
|
List<String> arcos = new ArrayList<String>();
|
||||||
VoidVisitor<List<String>> visitador = new Visitador();
|
VoidVisitor<List<String>> visitador = new Visitador();
|
||||||
visitador.visit(cu,arcos);
|
visitador.visit(cu, arcos);
|
||||||
|
|
||||||
// Imprimimos el CFG del programa
|
// Imprimimos el CFG del programa
|
||||||
String dotInfo = imprimirGrafo(arcos);
|
String dotInfo = imprimirGrafo(arcos);
|
||||||
|
|
||||||
// Generamos un PDF con el CFG del programa
|
// Generamos un PDF con el CFG del programa
|
||||||
System.out.print("\nGenerando PDF...");
|
System.out.print("\nGenerando PDF...");
|
||||||
GraphViz gv=new GraphViz();
|
GraphViz gv = new GraphViz();
|
||||||
gv.addln(gv.start_graph());
|
gv.addln(gv.start_graph());
|
||||||
gv.add(dotInfo);
|
gv.add(dotInfo);
|
||||||
gv.addln(gv.end_graph());
|
gv.addln(gv.end_graph());
|
||||||
|
@ -44,18 +44,17 @@ public class Transformador {
|
||||||
gv.decreaseDpi();
|
gv.decreaseDpi();
|
||||||
gv.decreaseDpi();
|
gv.decreaseDpi();
|
||||||
gv.decreaseDpi();
|
gv.decreaseDpi();
|
||||||
File destino_CFG = new File(ruta + "_CFG."+ type);
|
File destino_CFG = new File(ruta + "_CFG." + type);
|
||||||
gv.writeGraphToFile( gv.getGraph( gv.getDotSource(), type ), destino_CFG);
|
gv.writeGraphToFile(gv.getGraph(gv.getDotSource(), type), destino_CFG);
|
||||||
System.out.println(" PDF generado!");
|
System.out.println(" PDF generado!");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Imprime el grafo en la pantalla
|
// Imprime el grafo en la pantalla
|
||||||
private static String imprimirGrafo(List<String> arcos)
|
private static String imprimirGrafo(List<String> arcos) {
|
||||||
{
|
StringBuilder dotInfo = new StringBuilder();
|
||||||
StringBuilder dotInfo= new StringBuilder();
|
for (String arco : arcos) {
|
||||||
for(String arco:arcos) {
|
|
||||||
dotInfo.append(arco);
|
dotInfo.append(arco);
|
||||||
System.out.println("ARCO: "+arco);
|
System.out.println("ARCO: " + arco);
|
||||||
}
|
}
|
||||||
System.out.println("\nCFG:");
|
System.out.println("\nCFG:");
|
||||||
System.out.println(dotInfo);
|
System.out.println(dotInfo);
|
||||||
|
@ -64,14 +63,13 @@ public class Transformador {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Elimina todos los comentarios de un nodo y sus hijos
|
// Elimina todos los comentarios de un nodo y sus hijos
|
||||||
private static void quitarComentarios(Node node){
|
private static void quitarComentarios(Node node) {
|
||||||
node.removeComment();
|
node.removeComment();
|
||||||
for (Comment comment : node.getOrphanComments())
|
for (Comment comment : node.getOrphanComments()) {
|
||||||
{
|
|
||||||
node.removeOrphanComment(comment);
|
node.removeOrphanComment(comment);
|
||||||
}
|
}
|
||||||
// Do something with the node
|
// Do something with the node
|
||||||
for (Node child : node.getChildNodes()){
|
for (Node child : node.getChildNodes()) {
|
||||||
quitarComentarios(child);
|
quitarComentarios(child);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,5 @@
|
||||||
package grafos;
|
package grafos;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import com.github.javaparser.ast.NodeList;
|
import com.github.javaparser.ast.NodeList;
|
||||||
import com.github.javaparser.ast.body.MethodDeclaration;
|
import com.github.javaparser.ast.body.MethodDeclaration;
|
||||||
import com.github.javaparser.ast.stmt.BlockStmt;
|
import com.github.javaparser.ast.stmt.BlockStmt;
|
||||||
|
@ -9,15 +7,16 @@ import com.github.javaparser.ast.stmt.ExpressionStmt;
|
||||||
import com.github.javaparser.ast.stmt.Statement;
|
import com.github.javaparser.ast.stmt.Statement;
|
||||||
import com.github.javaparser.ast.visitor.VoidVisitorAdapter;
|
import com.github.javaparser.ast.visitor.VoidVisitorAdapter;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
public class Visitador extends VoidVisitorAdapter<List<String>>
|
|
||||||
{
|
public class Visitador extends VoidVisitorAdapter<List<String>> {
|
||||||
//********************************************************/
|
//********************************************************/
|
||||||
//********************** Atributos ***********************/
|
//********************** Atributos ***********************/
|
||||||
//********************************************************/
|
//********************************************************/
|
||||||
|
|
||||||
// Usamos un contador para numerar las instrucciones
|
// Usamos un contador para numerar las instrucciones
|
||||||
private int contador=1;
|
private int contador = 1;
|
||||||
private String nodoAnterior = "Start";
|
private String nodoAnterior = "Start";
|
||||||
private String nodoActual = "";
|
private String nodoActual = "";
|
||||||
|
|
||||||
|
@ -28,20 +27,18 @@ public class Visitador extends VoidVisitorAdapter<List<String>>
|
||||||
// Visitador de métodos
|
// Visitador de métodos
|
||||||
// Este visitador añade el nodo final al CFG
|
// Este visitador añade el nodo final al CFG
|
||||||
@Override
|
@Override
|
||||||
public void visit(MethodDeclaration methodDeclaration, List<String>collector)
|
public void visit(MethodDeclaration methodDeclaration, List<String> collector) {
|
||||||
{
|
|
||||||
// Visitamos el método
|
// Visitamos el método
|
||||||
super.visit(methodDeclaration, collector);
|
super.visit(methodDeclaration, collector);
|
||||||
|
|
||||||
// Añadimos el nodo final al CFG
|
// Añadimos el nodo final al CFG
|
||||||
collector.add(nodoAnterior+"-> Stop;");
|
collector.add(nodoAnterior + "-> Stop;");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Visitador de expresiones
|
// Visitador de expresiones
|
||||||
// Cada expresión encontrada genera un nodo en el CFG
|
// Cada expresión encontrada genera un nodo en el CFG
|
||||||
@Override
|
@Override
|
||||||
public void visit(ExpressionStmt es, List<String>collector)
|
public void visit(ExpressionStmt es, List<String> collector) {
|
||||||
{
|
|
||||||
// Creamos el nodo actual
|
// Creamos el nodo actual
|
||||||
nodoActual = crearNodo(es);
|
nodoActual = crearNodo(es);
|
||||||
|
|
||||||
|
@ -54,8 +51,7 @@ public class Visitador extends VoidVisitorAdapter<List<String>>
|
||||||
}
|
}
|
||||||
|
|
||||||
// Añade un arco desde el último nodo hasta el nodo actual (se le pasa como parametro)
|
// Añade un arco desde el último nodo hasta el nodo actual (se le pasa como parametro)
|
||||||
private void añadirArcoSecuencialCFG(List<String>collector)
|
private void añadirArcoSecuencialCFG(List<String> collector) {
|
||||||
{
|
|
||||||
System.out.println("NODO: " + nodoActual);
|
System.out.println("NODO: " + nodoActual);
|
||||||
|
|
||||||
String arco = nodoAnterior + "->" + nodoActual + ";";
|
String arco = nodoAnterior + "->" + nodoActual + ";";
|
||||||
|
@ -63,29 +59,25 @@ public class Visitador extends VoidVisitorAdapter<List<String>>
|
||||||
}
|
}
|
||||||
|
|
||||||
// Crear arcos
|
// Crear arcos
|
||||||
private void crearArcos(List<String>collector)
|
private void crearArcos(List<String> collector) {
|
||||||
{
|
|
||||||
añadirArcoSecuencialCFG(collector);
|
añadirArcoSecuencialCFG(collector);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Crear nodo
|
// Crear nodo
|
||||||
// Añade un arco desde el nodo actual hasta el último control
|
// Añade un arco desde el nodo actual hasta el último control
|
||||||
private String crearNodo(Object objeto)
|
private String crearNodo(Object objeto) {
|
||||||
{
|
return "\"(" + contador++ + ") " + quitarComillas(objeto.toString()) + "\"";
|
||||||
return "\"("+ contador++ +") "+quitarComillas(objeto.toString())+"\"";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Sustituye " por \" en un string: Sirve para eliminar comillas.
|
// Sustituye " por \" en un string: Sirve para eliminar comillas.
|
||||||
private static String quitarComillas(String texto)
|
private static String quitarComillas(String texto) {
|
||||||
{
|
|
||||||
return texto.replace("\"", "\\\"");
|
return texto.replace("\"", "\\\"");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Dada una sentencia,
|
// Dada una sentencia,
|
||||||
// Si es una <EFBFBD>nica instrucci<EFBFBD>n, devuelve un bloque equivalente
|
// Si es una <EFBFBD>nica instrucci<EFBFBD>n, devuelve un bloque equivalente
|
||||||
// Si es un bloque, lo devuelve
|
// Si es un bloque, lo devuelve
|
||||||
private BlockStmt convertirEnBloque(Statement statement)
|
private BlockStmt convertirEnBloque(Statement statement) {
|
||||||
{
|
|
||||||
if (statement instanceof BlockStmt)
|
if (statement instanceof BlockStmt)
|
||||||
return (BlockStmt) statement;
|
return (BlockStmt) statement;
|
||||||
|
|
||||||
|
|
|
@ -2,12 +2,10 @@ package ejemplos;
|
||||||
|
|
||||||
public class Bucles_1 {
|
public class Bucles_1 {
|
||||||
|
|
||||||
public static void main(String[] args)
|
public static void main(String[] args) {
|
||||||
{
|
|
||||||
// BUCLE WHILE (sin anidamiento)
|
// BUCLE WHILE (sin anidamiento)
|
||||||
int x=1;
|
int x = 1;
|
||||||
while (x<=10)
|
while (x <= 10) {
|
||||||
{
|
|
||||||
System.out.print(x);
|
System.out.print(x);
|
||||||
x++;
|
x++;
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,19 +2,16 @@ package ejemplos;
|
||||||
|
|
||||||
public class Bucles_2 {
|
public class Bucles_2 {
|
||||||
|
|
||||||
public static void main(String[] args)
|
public static void main(String[] args) {
|
||||||
{
|
|
||||||
// BUCLE WHILE anidado a otro WHILE
|
// BUCLE WHILE anidado a otro WHILE
|
||||||
System.out.println("Empieza bucle WHILE anidado a otro WHILE:");
|
System.out.println("Empieza bucle WHILE anidado a otro WHILE:");
|
||||||
int x=1;
|
int x = 1;
|
||||||
char y='a';
|
char y = 'a';
|
||||||
while (x<=10)
|
while (x <= 10) {
|
||||||
{
|
System.out.print(" " + x);
|
||||||
System.out.print(" "+x);
|
y = 'a';
|
||||||
y='a';
|
while (y <= 'c') {
|
||||||
while (y<='c')
|
System.out.print(" " + y);
|
||||||
{
|
|
||||||
System.out.print(" "+y);
|
|
||||||
y++;
|
y++;
|
||||||
}
|
}
|
||||||
x++;
|
x++;
|
||||||
|
|
|
@ -7,30 +7,28 @@ public class Bucles_3 {
|
||||||
|
|
||||||
// BUCLE FOR (sin anidamiento)
|
// BUCLE FOR (sin anidamiento)
|
||||||
System.out.println("Empieza bucle FOR:");
|
System.out.println("Empieza bucle FOR:");
|
||||||
for (x=1;x<=10;x++)
|
for (x = 1; x <= 10; x++) {
|
||||||
{
|
System.out.print(" " + x);
|
||||||
System.out.print(" "+x);
|
|
||||||
}
|
}
|
||||||
System.out.println();
|
System.out.println();
|
||||||
|
|
||||||
// BUCLE WHILE (sin anidamiento)
|
// BUCLE WHILE (sin anidamiento)
|
||||||
System.out.println("Empieza bucle WHILE:");
|
System.out.println("Empieza bucle WHILE:");
|
||||||
x=1;
|
x = 1;
|
||||||
while (x<=10)
|
while (x <= 10) {
|
||||||
{
|
System.out.print(" " + x);
|
||||||
System.out.print(" "+x);
|
|
||||||
x++;
|
x++;
|
||||||
}
|
}
|
||||||
System.out.println();
|
System.out.println();
|
||||||
|
|
||||||
// BUCLE DO WHILE (sin anidamiento)
|
// BUCLE DO WHILE (sin anidamiento)
|
||||||
System.out.println("Empieza bucle DO WHILE:");
|
System.out.println("Empieza bucle DO WHILE:");
|
||||||
x=1;
|
x = 1;
|
||||||
do{
|
do {
|
||||||
System.out.print(" "+x);
|
System.out.print(" " + x);
|
||||||
x++;
|
x++;
|
||||||
}
|
}
|
||||||
while (x<=10);
|
while (x <= 10);
|
||||||
System.out.println();
|
System.out.println();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,22 +2,19 @@ package ejemplos;
|
||||||
|
|
||||||
public class Bucles_4 {
|
public class Bucles_4 {
|
||||||
|
|
||||||
public static void main(String[] args)
|
public static void main(String[] args) {
|
||||||
{
|
int x = 1;
|
||||||
int x=1;
|
|
||||||
|
|
||||||
//Bucle 1: Contador
|
//Bucle 1: Contador
|
||||||
while (x<10)
|
while (x < 10) {
|
||||||
{
|
|
||||||
System.out.println(x);
|
System.out.println(x);
|
||||||
x++;
|
x++;
|
||||||
}
|
}
|
||||||
|
|
||||||
//Bucle 2: Sumatorio
|
//Bucle 2: Sumatorio
|
||||||
int suma=0;
|
int suma = 0;
|
||||||
int y=1;
|
int y = 1;
|
||||||
while (y<10)
|
while (y < 10) {
|
||||||
{
|
|
||||||
suma += y;
|
suma += y;
|
||||||
y++;
|
y++;
|
||||||
}
|
}
|
||||||
|
@ -27,8 +24,7 @@ public class Bucles_4 {
|
||||||
int sumatorio = 0;
|
int sumatorio = 0;
|
||||||
int min = 10;
|
int min = 10;
|
||||||
int max = 100;
|
int max = 100;
|
||||||
for (int num = min; num <= max; num++)
|
for (int num = min; num <= max; num++) {
|
||||||
{
|
|
||||||
sumatorio += num;
|
sumatorio += num;
|
||||||
}
|
}
|
||||||
System.out.println(sumatorio);
|
System.out.println(sumatorio);
|
||||||
|
|
|
@ -8,26 +8,22 @@ public class Bucles_5 {
|
||||||
|
|
||||||
// BUCLE FOR anidado a otro FOR
|
// BUCLE FOR anidado a otro FOR
|
||||||
System.out.println("Empieza bucle FOR anidado a otro FOR:");
|
System.out.println("Empieza bucle FOR anidado a otro FOR:");
|
||||||
for (x=1;x<=10;x++)
|
for (x = 1; x <= 10; x++) {
|
||||||
{
|
System.out.print(" " + x);
|
||||||
System.out.print(" "+x);
|
for (y = 'a'; y <= 'c'; y++) {
|
||||||
for (y='a';y<='c';y++)
|
System.out.print(" " + y);
|
||||||
{
|
|
||||||
System.out.print(" "+y);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
System.out.println();
|
System.out.println();
|
||||||
|
|
||||||
// BUCLE WHILE anidado a otro WHILE
|
// BUCLE WHILE anidado a otro WHILE
|
||||||
System.out.println("Empieza bucle WHILE anidado a otro WHILE:");
|
System.out.println("Empieza bucle WHILE anidado a otro WHILE:");
|
||||||
x=1;
|
x = 1;
|
||||||
while (x<=10)
|
while (x <= 10) {
|
||||||
{
|
System.out.print(" " + x);
|
||||||
System.out.print(" "+x);
|
y = 'a';
|
||||||
y='a';
|
while (y <= 'c') {
|
||||||
while (y<='c')
|
System.out.print(" " + y);
|
||||||
{
|
|
||||||
System.out.print(" "+y);
|
|
||||||
y++;
|
y++;
|
||||||
}
|
}
|
||||||
x++;
|
x++;
|
||||||
|
@ -36,16 +32,15 @@ public class Bucles_5 {
|
||||||
|
|
||||||
// BUCLE FOR anidado a bucle DO WHILE
|
// BUCLE FOR anidado a bucle DO WHILE
|
||||||
System.out.println("Empieza bucle FOR anidado a bucle DO WHILE:");
|
System.out.println("Empieza bucle FOR anidado a bucle DO WHILE:");
|
||||||
x=1;
|
x = 1;
|
||||||
do{
|
do {
|
||||||
System.out.print(" "+x);
|
System.out.print(" " + x);
|
||||||
for (y='a';y<='c';y++)
|
for (y = 'a'; y <= 'c'; y++) {
|
||||||
{
|
System.out.print(" " + y);
|
||||||
System.out.print(" "+y);
|
|
||||||
}
|
}
|
||||||
x++;
|
x++;
|
||||||
}
|
}
|
||||||
while (x<=10);
|
while (x <= 10);
|
||||||
System.out.println();
|
System.out.println();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,24 +2,20 @@ package ejemplos;
|
||||||
|
|
||||||
public class Bucles_6 {
|
public class Bucles_6 {
|
||||||
|
|
||||||
public static void main(String[] args)
|
public static void main(String[] args) {
|
||||||
{
|
|
||||||
// BUCLE WHILE (sin anidamiento)
|
// BUCLE WHILE (sin anidamiento)
|
||||||
System.out.println("Empieza bucle WHILE:");
|
System.out.println("Empieza bucle WHILE:");
|
||||||
int x=1;
|
int x = 1;
|
||||||
while (x<=10)
|
while (x <= 10) {
|
||||||
{
|
System.out.print(" " + x);
|
||||||
System.out.print(" "+x);
|
|
||||||
x++;
|
x++;
|
||||||
while (x<=10)
|
while (x <= 10) {
|
||||||
{
|
System.out.print(" " + x);
|
||||||
System.out.print(" "+x);
|
|
||||||
x++;
|
x++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
while (x<=10)
|
while (x <= 10) {
|
||||||
{
|
System.out.print(" " + x);
|
||||||
System.out.print(" "+x);
|
|
||||||
x++;
|
x++;
|
||||||
}
|
}
|
||||||
System.out.println();
|
System.out.println();
|
||||||
|
|
|
@ -2,12 +2,11 @@ package ejemplos;
|
||||||
|
|
||||||
public class Test_1 {
|
public class Test_1 {
|
||||||
|
|
||||||
public static void main(String[] args)
|
public static void main(String[] args) {
|
||||||
{
|
|
||||||
System.out.println("HOLA mundo");
|
System.out.println("HOLA mundo");
|
||||||
int x=1;
|
int x = 1;
|
||||||
x=2;
|
x = 2;
|
||||||
x=3;
|
x = 3;
|
||||||
x=4;
|
x = 4;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,13 +2,12 @@ package ejemplos;
|
||||||
|
|
||||||
public class Test_2 {
|
public class Test_2 {
|
||||||
|
|
||||||
public static void main(String[] args)
|
public static void main(String[] args) {
|
||||||
{
|
int x = 1;
|
||||||
int x=1;
|
|
||||||
x++;
|
x++;
|
||||||
++x;
|
++x;
|
||||||
int y=0;
|
int y = 0;
|
||||||
x=x+y;
|
x = x + y;
|
||||||
System.out.println(x);
|
System.out.println(x);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,13 +2,12 @@ package ejemplos;
|
||||||
|
|
||||||
public class Test_3 {
|
public class Test_3 {
|
||||||
|
|
||||||
public static void main(String[] args)
|
public static void main(String[] args) {
|
||||||
{
|
int x = 1;
|
||||||
int x=1;
|
|
||||||
|
|
||||||
if (x==1)
|
if (x == 1)
|
||||||
x=2;
|
x = 2;
|
||||||
x=3;
|
x = 3;
|
||||||
x=4;
|
x = 4;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,20 +2,17 @@ package ejemplos;
|
||||||
|
|
||||||
public class Test_4 {
|
public class Test_4 {
|
||||||
|
|
||||||
public static void main(String[] args)
|
public static void main(String[] args) {
|
||||||
{
|
int x = 1;
|
||||||
int x=1;
|
|
||||||
|
|
||||||
if (x==1)
|
if (x == 1) {
|
||||||
{
|
x = 2;
|
||||||
x=2;
|
if (x >= 1) {
|
||||||
if (x>=1)
|
x = 3;
|
||||||
{
|
x = 4;
|
||||||
x=3;
|
|
||||||
x=4;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
x=5;
|
x = 5;
|
||||||
x=6;
|
x = 6;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,21 +2,18 @@ package ejemplos;
|
||||||
|
|
||||||
public class Test_5 {
|
public class Test_5 {
|
||||||
|
|
||||||
public static void main(String[] args)
|
public static void main(String[] args) {
|
||||||
{
|
int x = 1;
|
||||||
int x=1;
|
|
||||||
|
|
||||||
if (x==1)
|
if (x == 1) {
|
||||||
{
|
x = 2;
|
||||||
x=2;
|
if (x >= 1) {
|
||||||
if (x>=1)
|
x = 3;
|
||||||
{
|
x = 4;
|
||||||
x=3;
|
|
||||||
x=4;
|
|
||||||
}
|
}
|
||||||
x=5;
|
x = 5;
|
||||||
}
|
}
|
||||||
x=6;
|
x = 6;
|
||||||
x=7;
|
x = 7;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,20 +2,16 @@ package ejemplos;
|
||||||
|
|
||||||
public class Test_6 {
|
public class Test_6 {
|
||||||
|
|
||||||
public static void main(String[] args)
|
public static void main(String[] args) {
|
||||||
{
|
int x = 1;
|
||||||
int x=1;
|
|
||||||
|
|
||||||
if (x==1)
|
if (x == 1) {
|
||||||
{
|
x = 2;
|
||||||
x=2;
|
x = 3;
|
||||||
x=3;
|
} else {
|
||||||
|
x = 4;
|
||||||
|
x = 5;
|
||||||
}
|
}
|
||||||
else
|
x = 6;
|
||||||
{
|
|
||||||
x=4;
|
|
||||||
x=5;
|
|
||||||
}
|
|
||||||
x=6;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,21 +3,16 @@ package ejemplos;
|
||||||
|
|
||||||
public class Test_7 {
|
public class Test_7 {
|
||||||
|
|
||||||
public static void main(String[] args)
|
public static void main(String[] args) {
|
||||||
{
|
int x = 1;
|
||||||
int x=1;
|
|
||||||
|
|
||||||
if (x==1)
|
if (x == 1) {
|
||||||
{
|
x = 2;
|
||||||
x=2;
|
} else x = 3;
|
||||||
}
|
x = 4;
|
||||||
else x=3;
|
if (x == 2) {
|
||||||
x=4;
|
x = 5;
|
||||||
if (x==2)
|
} else if (x == 3) x = 6;
|
||||||
{
|
x = 7;
|
||||||
x=5;
|
|
||||||
}
|
|
||||||
else if (x==3) x=6;
|
|
||||||
x=7;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,21 +2,18 @@ package ejemplos;
|
||||||
|
|
||||||
public class Test_8 {
|
public class Test_8 {
|
||||||
|
|
||||||
public static void main(String[] args)
|
public static void main(String[] args) {
|
||||||
{
|
int x = 1;
|
||||||
int x=1;
|
|
||||||
|
|
||||||
if (x==1)
|
if (x == 1) {
|
||||||
{
|
x = 2;
|
||||||
x=2;
|
|
||||||
}
|
}
|
||||||
x=5;
|
x = 5;
|
||||||
x=6;
|
x = 6;
|
||||||
if (x==2)
|
if (x == 2) {
|
||||||
{
|
x = 7;
|
||||||
x=7;
|
|
||||||
}
|
}
|
||||||
if (x==3) x=8;
|
if (x == 3) x = 8;
|
||||||
x=9;
|
x = 9;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,28 +3,22 @@ package ejemplos;
|
||||||
public class Test_9 {
|
public class Test_9 {
|
||||||
|
|
||||||
|
|
||||||
public static void main(String[] args)
|
public static void main(String[] args) {
|
||||||
{
|
|
||||||
// ANIDAMIENTO de IF y WHILE
|
// ANIDAMIENTO de IF y WHILE
|
||||||
|
|
||||||
// ANIDAMIENTO de IF y WHILE 2
|
// ANIDAMIENTO de IF y WHILE 2
|
||||||
|
|
||||||
int x=0;
|
int x = 0;
|
||||||
if (x>1)
|
if (x > 1) {
|
||||||
{
|
x = 1;
|
||||||
x=1;
|
while (x > 2) {
|
||||||
while (x>2)
|
x = 2;
|
||||||
{
|
while (x > 3) {
|
||||||
x=2;
|
x = 3;
|
||||||
while (x>3)
|
if (x > 4) {
|
||||||
{
|
x = 4;
|
||||||
x=3;
|
if (x > 5) {
|
||||||
if (x>4)
|
x = 5;
|
||||||
{
|
|
||||||
x=4;
|
|
||||||
if (x>5)
|
|
||||||
{
|
|
||||||
x=5;
|
|
||||||
}
|
}
|
||||||
x--;
|
x--;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue