--- /dev/null
+package a.b.c;
+
+public class Code {
+ public static void main(String []argv) {
+ new Code().new PublicInner().run();
+ new Code().new DefaultInner().run();
+ new Code().new PrivateInner().run();
+ }
+
+ public class PublicInner implements Runnable {
+ public void run() {
+ System.out.println("PublicInner.run()");
+ }
+ }
+
+ class DefaultInner implements Runnable {
+ public void run() {
+ System.out.println("DefaultInner.run()");
+ }
+ }
+
+ private class PrivateInner implements Runnable {
+ public void run() {
+ System.out.println("PrivateInner.run()");
+ }
+ }
+
+ public void run() {
+ System.out.println("Code (outer public class).run()");
+ }
+}
--- /dev/null
+//package a.b.c;
+//
+//class Code2 implements Runnable {
+// public void run() {
+// System.out.println("Code2.run()");
+// }
+//}
--- /dev/null
+package a.b.c;
+
+aspect Foo pertypewithin(Runnable+) {
+ after() : staticinitialization(*) {
+ System.out.println(thisJoinPointStaticPart+" getWithinTypeName() = " + getWithinTypeName());
+ Class c = thisJoinPointStaticPart.getSourceLocation().getWithinType();
+ System.out.println(thisJoinPointStaticPart+" aspectOf("+c.getName()+") = "+Foo.aspectOf(c).getClass().getName());
+ }
+}
--- /dev/null
+package a.b.c;
+
+privileged aspect Foo pertypewithin(Runnable+) {
+ after() : staticinitialization(*) {
+ System.out.println(thisJoinPointStaticPart+" getWithinTypeName() = " + getWithinTypeName());
+ Class c = thisJoinPointStaticPart.getSourceLocation().getWithinType();
+ System.out.println(thisJoinPointStaticPart+" aspectOf("+c.getName()+") = "+Foo.aspectOf(c).getClass().getName());
+ }
+}
--- /dev/null
+package a.b.d;
+
+aspect Foo pertypewithin(Runnable+) {
+ after() : staticinitialization(*) {
+ System.out.println(thisJoinPointStaticPart+" getWithinTypeName() = " + getWithinTypeName());
+ Class c = thisJoinPointStaticPart.getSourceLocation().getWithinType();
+ System.out.println(thisJoinPointStaticPart+" aspectOf("+c.getName()+") = "+Foo.aspectOf(c).getClass().getName());
+ }
+}
--- /dev/null
+package a.b.d;
+
+privileged aspect Foo pertypewithin(Runnable+) {
+ after() : staticinitialization(*) {
+ System.out.println("getWithinTypeName() = " + getWithinTypeName());
+ Class c = thisJoinPointStaticPart.getSourceLocation().getWithinType();
+ System.out.println("Aspect instance = "+Foo.aspectOf(c).getClass().getName());
+ }
+}
--- /dev/null
+/*******************************************************************************
+ * Copyright (c) 2018 Contributors
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * Andy Clement - initial API and implementation
+ *******************************************************************************/
+package org.aspectj.systemtest.ajc192;
+
+import java.io.File;
+
+import org.aspectj.testing.XMLBasedAjcTestCase;
+
+import junit.framework.Test;
+
+/**
+ * @author Andy Clement
+ */
+public class Ajc192Tests extends XMLBasedAjcTestCase {
+
+ public void testPTW_nonPrivileged() {
+ runTest("ptw");
+ }
+
+ public void testPTW_nonPrivilegedSamePackage() {
+ runTest("ptw - same package");
+ }
+
+ public void testPTW_privileged() {
+ runTest("ptw - privileged");
+ }
+
+ public void testPTWW_privilegedSamePackage() {
+ runTest("ptw - privileged same package");
+ }
+
+ // ---
+
+ public static Test suite() {
+ return XMLBasedAjcTestCase.loadSuite(Ajc192Tests.class);
+ }
+
+ @Override
+ protected File getSpecFile() {
+ return getClassResource("ajc192.xml");
+ }
+
+}
--- /dev/null
+/*******************************************************************************
+ * Copyright (c) 2018 Contributors
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * Andy Clement - initial API and implementation
+ *******************************************************************************/
+package org.aspectj.systemtest.ajc192;
+
+import junit.framework.Test;
+import junit.framework.TestSuite;
+
+public class AllTestsAspectJ192 {
+
+ public static Test suite() {
+ TestSuite suite = new TestSuite("AspectJ 1.9.2 tests");
+ // $JUnit-BEGIN$
+ suite.addTest(Ajc192Tests.suite());
+ // $JUnit-END$
+ return suite;
+ }
+}
--- /dev/null
+<!DOCTYPE suite SYSTEM "../tests/ajcTestSuite.dtd"[]>
+
+<suite>
+
+ <ajc-test dir="bugs192/ptw" title="ptw">
+ <compile files="a/b/c/Code.java a/b/d/Foo.java" options="-8">
+ </compile>
+ <run class="a.b.c.Code">
+ <stdout>
+ <line text="staticinitialization(a.b.c.Code.PublicInner.<clinit>) getWithinTypeName() = a.b.c.Code$PublicInner"/>
+ <line text="staticinitialization(a.b.c.Code.PublicInner.<clinit>) aspectOf(a.b.c.Code$PublicInner) = a.b.d.Foo"/>
+ <line text="PublicInner.run()"/>
+ <line text="DefaultInner.run()"/>
+ <line text="PrivateInner.run()"/>
+ </stdout>
+ </run>
+ </ajc-test>
+
+ <ajc-test dir="bugs192/ptw" title="ptw - same package">
+ <compile files="a/b/c/Code.java a/b/c/Foo.java" options="-8">
+ </compile>
+ <run class="a.b.c.Code">
+ <stdout>
+ <line text="staticinitialization(a.b.c.Code.PublicInner.<clinit>) getWithinTypeName() = a.b.c.Code$PublicInner"/>
+ <line text="staticinitialization(a.b.c.Code.PublicInner.<clinit>) aspectOf(a.b.c.Code$PublicInner) = a.b.c.Foo"/>
+ <line text="PublicInner.run()"/>
+ <line text="staticinitialization(a.b.c.Code.DefaultInner.<clinit>) getWithinTypeName() = a.b.c.Code$DefaultInner"/>
+ <line text="staticinitialization(a.b.c.Code.DefaultInner.<clinit>) aspectOf(a.b.c.Code$DefaultInner) = a.b.c.Foo"/>
+ <line text="DefaultInner.run()"/>
+ <line text="staticinitialization(a.b.c.Code.PrivateInner.<clinit>) getWithinTypeName() = a.b.c.Code$PrivateInner"/>
+ <line text="staticinitialization(a.b.c.Code.PrivateInner.<clinit>) aspectOf(a.b.c.Code$PrivateInner) = a.b.c.Foo"/>
+ <line text="PrivateInner.run()"/>
+ </stdout>
+ </run>
+ </ajc-test>
+
+
+ <ajc-test dir="bugs192/ptw" title="ptw - privileged">
+ <compile files="a/b/c/Code.java a/b/d/FooPrivileged.java" options="-8">
+ </compile>
+ <run class="a.b.c.Code">
+ <stdout>
+ <line text="getWithinTypeName() = a.b.c.Code$PublicInner"/>
+ <line text="Aspect instance = a.b.d.Foo"/>
+ <line text="PublicInner.run()"/>
+ <line text="getWithinTypeName() = a.b.c.Code$DefaultInner"/>
+ <line text="Aspect instance = a.b.d.Foo"/>
+ <line text="DefaultInner.run()"/>
+ <line text="getWithinTypeName() = a.b.c.Code$PrivateInner"/>
+ <line text="Aspect instance = a.b.d.Foo"/>
+ <line text="PrivateInner.run()"/>
+ </stdout>
+ </run>
+ </ajc-test>
+
+ <ajc-test dir="bugs192/ptw" title="ptw - privileged same package">
+ <compile files="a/b/c/Code.java a/b/c/FooPrivileged.java" options="-8">
+ </compile>
+ <run class="a.b.c.Code">
+ <stdout>
+ <line text="staticinitialization(a.b.c.Code.PublicInner.<clinit>) getWithinTypeName() = a.b.c.Code$PublicInner"/>
+ <line text="staticinitialization(a.b.c.Code.PublicInner.<clinit>) aspectOf(a.b.c.Code$PublicInner) = a.b.c.Foo"/>
+ <line text="PublicInner.run()"/>
+ <line text="staticinitialization(a.b.c.Code.DefaultInner.<clinit>) getWithinTypeName() = a.b.c.Code$DefaultInner"/>
+ <line text="staticinitialization(a.b.c.Code.DefaultInner.<clinit>) aspectOf(a.b.c.Code$DefaultInner) = a.b.c.Foo"/>
+ <line text="DefaultInner.run()"/>
+ <line text="staticinitialization(a.b.c.Code.PrivateInner.<clinit>) getWithinTypeName() = a.b.c.Code$PrivateInner"/>
+ <line text="staticinitialization(a.b.c.Code.PrivateInner.<clinit>) aspectOf(a.b.c.Code$PrivateInner) = a.b.c.Foo"/>
+ <line text="PrivateInner.run()"/>
+ </stdout>
+ </run>
+ </ajc-test>
+
+</suite>