<message kind="error" line="85"/>
</compile>
</ajc-test>
+
+ <ajc-test dir="bugs" pr="34858"
+ title="cflow binding issues with ignoring state">
+ <compile files="CflowBinding.java"/>
+ <run class="CflowBinding"/>
+ </ajc-test>
+
+ <ajc-test dir="bugs" pr="34858"
+ title="cflow binding -- original weaver crash">
+ <compile files="CflowBindingOrig.java"/>
+ <run class="CflowBindingOrig"/>
+ </ajc-test>
</suite>
--- /dev/null
+// for Bugzilla Bug 34858
+// Weaver crash w/ coverage
+
+import org.aspectj.testing.Tester;
+
+public class CflowBinding {
+ public static void main(String[] args) {
+ new Bar().bar(10);
+ }
+
+
+ static aspect A {
+ pointcut flow(int i, Object o): cflow(execution(void bar(int)) && this(o) && args(i));
+
+ Object around() : call(void m()) && flow(int, Object) {
+ return proceed();
+ }
+
+ Object around(final int i) : call(void m()) && flow(i, Object) {
+ System.out.println("i: " + i);
+ return proceed(i);
+ }
+
+ Object around(final Object o) : call(void m()) && flow(int, o) {
+ System.out.println("o: " + o);
+ return proceed(o);
+ }
+
+ Object around(final Object o, final int i) : call(void m()) && flow(i, o) {
+ System.out.println("o: " + o + ", i: " + i);
+ return proceed(o, i);
+ }
+ }
+}
+
+class Bar {
+ void bar(int i) {
+ m();
+ }
+ void m() {
+ System.out.println("m");
+ }
+}
+
--- /dev/null
+// for Bugzilla Bug 34858
+// Weaver crash
+
+import org.aspectj.testing.Tester;
+
+/**
+ * Almost an exact duplicate of the reported issue
+ */
+public class CflowBindingOrig {
+ public static void main(String[] args) {
+ new Bar().foo();
+ }
+
+ static aspect MockProcessing {
+ pointcut testFlow(final Thread thread) :
+ cflow(execution(void run()) && this(thread) && within(Thread)); // the within is an optimization
+
+ Object around() :
+ call(* DummyConfiguration.createRootApplicationModule(..)) && testFlow(Thread)
+ {
+ return null;
+ }
+ }
+}
+
+class Bar {
+ void foo() {
+ DummyConfiguration.createRootApplicationModule();
+ }
+}
+
+class DummyConfiguration {
+ static Object createRootApplicationModule() {
+ return null;
+ }
+}
<!DOCTYPE suite SYSTEM "../tests/ajcTestSuite.dtd">
<suite>
+ <ajc-test dir="errors"
+ title="type not imported in around advice">
+ <compile files="TypeNotImportedInAroundCE.java">
+ <message kind="error" line="10"/>
+ </compile>
+ </ajc-test>
+ <ajc-test dir="errors"
+ title="type not imported in aspect">
+ <compile files="TypeInAspectNotImportedCE.java">
+ <message kind="error" line="6"/>
+ </compile>
+ </ajc-test>
<!--
List slots = new ArrayList();
for (int i=0, len=freeVars.length; i < len; i++) {
int freeVar = freeVars[i];
+
+ // we don't need to keep state that isn't actually exposed to advice
+ //??? this means that we will store some state that we won't actually use, optimize this later
+ if (!bindings.hasKey(freeVar)) continue;
+
int formalIndex = bindings.get(freeVar);
ResolvedTypeX formalType =
bindings.getAdviceSignature().getParameterTypes()[formalIndex].resolve(world);