0

这是我之前的问题的连续性:如何使用 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);
    }
}*/
}
4

1 回答 1

2

我认为您不应该转述 JavaParser 处理错误语句的方式。解析不正确的陈述是一件复杂而脆弱的事情。没有“正确”的方法来解析 Java 文件中非 Java 的内容。

我想知道该代码是如何在 JavaParser 文件中结束的:它是由一些错误的代码生成器生成的吗?您是否有机会修复该生成器而不是对不正确的文件进行逆向工程?

免责声明:我是 JavaParser 贡献者

于 2017-12-31T10:56:30.807 回答