这是我之前的问题的连续性:如何使用 Javaparser 解析 for 循环?. 我正在尝试将这个不正确的 for-loop: 解析为FOR(j, k, 15, >, -);
正确的形式:for (var j = k; j > 15; j--){}
。这意味着将Class.java解析为ClassAltered.java类。我的代码应该使用正确的循环创建新类 ClassAltered.java。现在我解析for循环的方法被注释了(我还没有完成),但无论如何我都有同样的错误。我确信 javaparser 可以解析不正确的语句,但我对“>”、“<=”、“+”、“-”的视线有问题。如果我删除这个景点,一切正常。我使用 javaparser-core-3.1.0.jar
这是我的错误:
这是我要解析的 Class.java:
public class Class {
public static void main(String[] args) {
method1();
method2();
}
public static void method1() {
FOR(j, k, 15, >, -);
System.out.println("FOR(j, k, 15, >, -) test");
}
public static void method2() {
FOR(j, 0, 10, <=, +);
System.out.println("FOR(j, 0, 10, <=, +) test");
}
}
这是我的 Main.class:
import com.github.javaparser.JavaParser;
import com.github.javaparser.ast.CompilationUnit;
import com.github.javaparser.ast.expr.*;
import com.github.javaparser.ast.stmt.ForStmt;
import javax.tools.*;
import java.io.*;
import java.util.*;
public class Main {
public static void main(String[] args) throws IOException {
final String fileName = "Class.java";
final String alteredFileName = "src\\ClassAltered.java";
CompilationUnit cu;
try(FileInputStream in = new FileInputStream(fileName)){
cu = JavaParser.parse(in);
}
//cu.getChildNodesByType(ForStmt.class)
//.forEach(Main::setForStatement);
cu.getClassByName("Class").get().setName("ClassAltered");
try(FileWriter output = new FileWriter(new File(alteredFileName), false)) {
output.write(cu.toString());
}
File[] files = {new File(alteredFileName)};
String[] options = { "-d", "out//production//Synthesis" };
JavaCompiler compiler = ToolProvider.getSystemJavaCompiler();
DiagnosticCollector<JavaFileObject> diagnostics = new DiagnosticCollector<>();
try (StandardJavaFileManager fileManager = compiler.getStandardFileManager(null, null, null)) {
Iterable<? extends JavaFileObject> compilationUnits =
fileManager.getJavaFileObjectsFromFiles(Arrays.asList(files));
compiler.getTask(
null,
fileManager,
diagnostics,
Arrays.asList(options),
null,
compilationUnits).call();
diagnostics.getDiagnostics().forEach(d -> System.out.println(d.getMessage(null)));
}
}
/*private static void setForStatement(ForStmt forStmt) {
MethodCallExpr initializer = (MethodCallExpr) forStmt.getInitialization().get(0);
if (initializer.getArguments().size() == 5
&& initializer.getArgument(1) instanceof IntegerLiteralExpr
&& initializer.getArgument(2) instanceof IntegerLiteralExpr) {
IntegerLiteralExpr a1 = (IntegerLiteralExpr) initializer.getArgument(1);
IntegerLiteralExpr a2 = (IntegerLiteralExpr) initializer.getArgument(2);
}
}*/
}