aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--docs/sandbox/api-clients/org/aspectj/samples/AffectedFilesReporter.java124
-rw-r--r--docs/sandbox/sandbox-api-test.xml12
2 files changed, 135 insertions, 1 deletions
diff --git a/docs/sandbox/api-clients/org/aspectj/samples/AffectedFilesReporter.java b/docs/sandbox/api-clients/org/aspectj/samples/AffectedFilesReporter.java
new file mode 100644
index 000000000..0a0a0a4e6
--- /dev/null
+++ b/docs/sandbox/api-clients/org/aspectj/samples/AffectedFilesReporter.java
@@ -0,0 +1,124 @@
+/* @author Wes Isberg */
+
+// START-SAMPLE api-asm-listAffectedFiles Walk model to list affected files
+
+package org.aspectj.samples;
+
+import org.aspectj.tools.ajc.Main;
+import org.aspectj.asm.*;
+import org.aspectj.bridge.*;
+
+import java.io.*;
+import java.util.*;
+
+
+/**
+ * Run ajc and write "affected.lst" file listing those files
+ * affected by advice or inter-type declarations.
+ *
+ * WARNING: Does not emit info messages for uses-pointcut dependencies.
+ * @author Wes Isberg
+ */
+public class AffectedFilesReporter implements Runnable {
+
+ /**
+ * Wrapper for ajc that emits list of affected files.
+ * @param args the String[] of args for ajc,
+ * optionally prefixed with -to {file}
+ * @throws IOException if unable to write to {file}
+ */
+ public static void main(String[] args) throws IOException {
+ Main main = new Main();
+ PrintStream toConfig = System.out;
+ FileOutputStream fin = null;
+ if ((args.length > 1) && ("-to".equals(args[0]))) {
+ File config = new File(args[1]);
+ fin = new FileOutputStream(config);
+ toConfig = new PrintStream(fin, true);
+ String[] temp = new String[args.length-2];
+ System.arraycopy(args, 2, temp, 0, temp.length);
+ args = temp;
+ }
+ Runnable runner = new AffectedFilesReporter(toConfig);
+ main.setCompletionRunner(runner);
+ // should add -emacssym to args if not already there
+ main.runMain(args, false);
+ if (null != fin) {
+ fin.close();
+ }
+ }
+
+ final PrintStream sink;
+
+ public AffectedFilesReporter(PrintStream sink) {
+ this.sink = (null == sink ? System.out : sink);
+ }
+
+ public void run() {
+ IHierarchy hierarchy = AsmManager.getDefault().getHierarchy();
+ if (null == hierarchy) {
+ sink.println("# no structure model - use -emacssym option");
+ return;
+ }
+ List /*IProgramElement*/ nodes = new ArrayList();
+ List /*IProgramElement*/ newNodes = new ArrayList();
+ // root could be config file or blank root - either way, use kids
+ nodes.addAll(hierarchy.getRoot().getChildren());
+ while (0 < nodes.size()) {
+ for (ListIterator it = nodes.listIterator(); it.hasNext();) {
+ IProgramElement node = (IProgramElement) it.next();
+ if (node.getKind().isSourceFileKind()) {
+ if (isAffected(node)) {
+ ISourceLocation loc = node.getSourceLocation();
+ sink.println(loc.getSourceFile().getPath());
+ }
+ } else {
+ // XXX uncertain of structure - traverse all??
+ newNodes.addAll(node.getChildren());
+ }
+ it.remove();
+ }
+ nodes.addAll(newNodes);
+ newNodes.clear();
+ }
+ }
+
+ /**
+ * Return true if this file node is affected by any aspects.
+ * Recursively search children for any effect,
+ * and halt on first affect found.
+ * @param node the IProgramElementNode for a source file
+ * @return true if affected.
+ */
+ private boolean isAffected(final IProgramElement fileNode) {
+ final IRelationshipMap map =
+ AsmManager.getDefault().getRelationshipMap();
+ List /*IProgramElement*/ nodes = new ArrayList();
+ List /*IProgramElement*/ newNodes = new ArrayList();
+ nodes.add(fileNode);
+ while (0 < nodes.size()) {
+ for (ListIterator iter = nodes.listIterator();
+ iter.hasNext();) {
+ IProgramElement node = (IProgramElement) iter.next();
+ List relations = map.get(node);
+ if (null != relations) {
+ for (Iterator riter = relations.iterator();
+ riter.hasNext();) {
+ IRelationship.Kind kind =
+ ((IRelationship) riter.next()).getKind();
+ if ((kind == IRelationship.Kind.ADVICE)
+ || (kind == IRelationship.Kind.DECLARE_INTER_TYPE)) {
+ return true;
+ }
+ }
+ }
+ iter.remove();
+ newNodes.addAll(node.getChildren());
+ }
+ nodes.addAll(newNodes);
+ newNodes.clear();
+ }
+ return false;
+ }
+}
+// END-SAMPLE api-asm-listAffectedFiles Walk model to list affected files
diff --git a/docs/sandbox/sandbox-api-test.xml b/docs/sandbox/sandbox-api-test.xml
index 959272592..1c19e6e9c 100644
--- a/docs/sandbox/sandbox-api-test.xml
+++ b/docs/sandbox/sandbox-api-test.xml
@@ -14,13 +14,23 @@
<suite>
<ajc-test dir="api-clients" title="api-ajde-modelWalker"
- comment="function unvalidated, only that it compiles and runs">
+ comment="BROKEN - function unvalidated, only that it compiles and runs">
<compile files="org/aspectj/samples/JoinPointCollector.java"
classpath="../../../aj-build/dist/tools/lib/aspectjtools.jar"/>
<run class="org/aspectj/samples/JoinPointCollector"
options="-help"/>
</ajc-test>
+ <ajc-test dir="api-clients" title="api-asm-listAffectedFiles"
+ comment="function unvalidated; note run paths are relative to harness cwd">
+ <compile files="org/aspectj/samples/AffectedFilesReporter.java"
+ classpath="../../../aj-build/dist/tools/lib/aspectjtools.jar"/>
+ <run class="org/aspectj/samples/AffectedFilesReporter"
+ outStreamIsError="true"
+ options="-emacssym,@../aj-build/dist/docs/doc/examples/tracing/notrace.lst"/>
+ <run class="org/aspectj/samples/AffectedFilesReporter"
+ options="-emacssym,@../aj-build/dist/docs/doc/examples/tracing/tracev3.lst"/>
+ </ajc-test>
</suite>
\ No newline at end of file