Skip to content

Commit

Permalink
Add symbolic links to latest csv
Browse files Browse the repository at this point in the history
  • Loading branch information
galderz committed Jun 29, 2021
1 parent 956a9bb commit 95e5ae3
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 21 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,12 @@
import static com.oracle.graal.pointsto.reports.ReportUtils.methodComparator;

import java.io.File;
import java.io.IOException;
import java.io.PrintWriter;
import java.nio.file.Files;
import java.nio.file.LinkOption;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.ArrayDeque;
import java.util.ArrayList;
import java.util.Arrays;
Expand All @@ -47,6 +52,7 @@
import java.util.Objects;
import java.util.Set;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.function.Consumer;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import java.util.stream.Collectors;
Expand Down Expand Up @@ -334,26 +340,34 @@ private static void printCsvFiles(Map<AnalysisMethod, MethodNode> methodToNode,
walkNodes(node, directEdges, virtualEdges, overridenByEdges, virtualNodes, nonVirtualNodes, virtualNodeId);
}

ReportUtils.report("call tree for vm entry point", path + File.separatorChar + "reports", "csv_call_tree_vm_" + reportName, "csv",
CallTreePrinter::printVMEntryPoint);

ReportUtils.report("call tree for methods", path + File.separatorChar + "reports", "csv_call_tree_methods_" + reportName, "csv",
writer -> printMethodNodes(methodToNode.values(), writer));

ReportUtils.report("call tree for virtual methods", path + File.separatorChar + "reports", "csv_call_tree_virtual_methods_" + reportName, "csv",
writer -> printVirtualNodes(virtualNodes, writer));

ReportUtils.report("call tree for entry points", path + File.separatorChar + "reports", "csv_call_tree_entry_points_" + reportName, "csv",
writer -> printEntryPointIds(entryPointIds, writer));

ReportUtils.report("call tree for direct edges", path + File.separatorChar + "reports", "csv_call_tree_direct_edges_" + reportName, "csv",
writer -> printBciEdges(directEdges, writer));

ReportUtils.report("call tree for overriden by edges", path + File.separatorChar + "reports", "csv_call_tree_override_by_edges_" + reportName, "csv",
writer -> printNonBciEdges(overridenByEdges, writer));
toCsvFile("call tree for vm entry point", path, "csv_call_tree_vm", reportName, CallTreePrinter::printVMEntryPoint);
toCsvFile("call tree for methods", path, "csv_call_tree_methods", reportName, writer -> printMethodNodes(methodToNode.values(), writer));
toCsvFile("call tree for virtual methods", path, "csv_call_tree_virtual_methods", reportName, writer -> printVirtualNodes(virtualNodes, writer));
toCsvFile("call tree for entry points", path, "csv_call_tree_entry_points", reportName, writer -> printEntryPointIds(entryPointIds, writer));
toCsvFile("call tree for direct edges", path, "csv_call_tree_direct_edges", reportName, writer -> printBciEdges(directEdges, writer));
toCsvFile("call tree for overriden by edges", path, "csv_call_tree_override_by_edges", reportName, writer -> printNonBciEdges(overridenByEdges, writer));
toCsvFile("call tree for virtual edges", path, "csv_call_tree_virtual_edges", reportName, writer -> printBciEdges(virtualEdges, writer));
}

private static void toCsvFile(String description, String path, String prefix, String reportName, Consumer<PrintWriter> reporter) {
final Path reportsPath = Paths.get(path, "reports");
final String name = prefix + "_" + reportName;
final String csvFile = ReportUtils.report(description, reportsPath.toString(), name, "csv", reporter);
final Path csvLink = reportsPath.resolve(prefix + ".csv");

if (Files.exists(csvLink, LinkOption.NOFOLLOW_LINKS)) {
try {
Files.delete(csvLink);
} catch (IOException e) {
// Ignore
}
}

ReportUtils.report("call tree for virtual edges", path + File.separatorChar + "reports", "csv_call_tree_virtual_edges_" + reportName, "csv",
writer -> printBciEdges(virtualEdges, writer));
try {
Files.createSymbolicLink(csvLink, Paths.get(csvFile));
} catch (IOException e) {
throw new RuntimeException(e);
}
}

private static void printVMEntryPoint(PrintWriter writer) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -62,18 +62,20 @@ public class ReportUtils {
/**
* Print a report in the format: path/name_timeStamp.extension. The path is relative to the
* working directory.
*
*
* @param description the description of the report
* @param path the path (relative to the working directory if the argument represents a relative
* path)
* @param name the name of the report
* @param extension the extension of the report
* @param reporter a consumer that writes to a PrintWriter
* @return path to the created report
*/
public static void report(String description, String path, String name, String extension, Consumer<PrintWriter> reporter) {
public static String report(String description, String path, String name, String extension, Consumer<PrintWriter> reporter) {
String fileName = timeStampedFileName(name, extension);
Path reportDir = Paths.get(path);
reportImpl(description, reportDir, fileName, reporter);
return fileName;
}

public static String timeStampedFileName(String name, String extension) {
Expand Down

0 comments on commit 95e5ae3

Please sign in to comment.