使用 javaparse 解析 for 循环时出错
Error while parsing for-loop using javaparse
它是我之前问题的延续:How to parse a for-loop using Javaparser?。我试图将这个不正确的 for 循环:FOR(j, k, 15, >, -);
解析为正确的形式:for (var j = k; j > 15; j--){}
。意思是把Class.java解析成classClassAltered.java。我的代码应该使用正确的循环创建新的 class ClassAltered.java。现在我解析 for-loop 的方法被注释了(我还没有完成),但无论如何我有同样的错误。
我确信 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);
}
}*/
}
我认为你不应该在中转Java解析器处理不正确的语句。解析不正确的陈述是一件复杂而脆弱的事情。没有 "right" 方法来解析 Java 文件中不属于 Java 的内容。
我想知道该代码是如何在 Java解析器文件中结束的:它是由某个错误的代码生成器生成的吗?您是否有机会修复该生成器而不是对不正确的文件进行逆向工程?
免责声明:我是 Java解析器贡献者
它是我之前问题的延续:How to parse a for-loop using Javaparser?。我试图将这个不正确的 for 循环:FOR(j, k, 15, >, -);
解析为正确的形式:for (var j = k; j > 15; j--){}
。意思是把Class.java解析成classClassAltered.java。我的代码应该使用正确的循环创建新的 class ClassAltered.java。现在我解析 for-loop 的方法被注释了(我还没有完成),但无论如何我有同样的错误。
我确信 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);
}
}*/
}
我认为你不应该在中转Java解析器处理不正确的语句。解析不正确的陈述是一件复杂而脆弱的事情。没有 "right" 方法来解析 Java 文件中不属于 Java 的内容。
我想知道该代码是如何在 Java解析器文件中结束的:它是由某个错误的代码生成器生成的吗?您是否有机会修复该生成器而不是对不正确的文件进行逆向工程?
免责声明:我是 Java解析器贡献者