aboutsummaryrefslogtreecommitdiffstats
path: root/tests/features152
diff options
context:
space:
mode:
authoracolyer <acolyer>2006-06-23 07:00:38 +0000
committeracolyer <acolyer>2006-06-23 07:00:38 +0000
commit4dafe048cb1f5bf9a30fcfac58011fe425141b91 (patch)
tree090ed647a16053e286947a56240520265112098d /tests/features152
parent76d1bc7bdfe7665c6d4fd04c852b92f17d255ddb (diff)
downloadaspectj-4dafe048cb1f5bf9a30fcfac58011fe425141b91.tar.gz
aspectj-4dafe048cb1f5bf9a30fcfac58011fe425141b91.zip
design notes and initial test for "truly synthetic" members
Diffstat (limited to 'tests/features152')
-rw-r--r--tests/features152/synthetic/PerThisFieldsAreSynthetic.aj24
-rw-r--r--tests/features152/synthetic/design.txt63
2 files changed, 87 insertions, 0 deletions
diff --git a/tests/features152/synthetic/PerThisFieldsAreSynthetic.aj b/tests/features152/synthetic/PerThisFieldsAreSynthetic.aj
new file mode 100644
index 000000000..33c2ca1c1
--- /dev/null
+++ b/tests/features152/synthetic/PerThisFieldsAreSynthetic.aj
@@ -0,0 +1,24 @@
+import java.lang.reflect.*;
+
+public class PerThisFieldsAreSynthetic {
+
+ public static void main(String[] args) throws Exception {
+ new PerThisFieldsAreSynthetic().foo();
+ Field[] fields = PerThisFieldsAreSynthetic.class.getDeclaredFields();
+ for (Field f : fields) {
+ if (!f.isSynthetic()) {
+ System.out.println("Found unexpected non-synthetic field: " + f.getName());
+ throw new IllegalStateException("non-synthetic field " + f.getName());
+ }
+ }
+ }
+
+ public void foo() {}
+
+}
+
+aspect PerThis perthis(execution(* PerThisFieldsAreSynthetic.*(..))) {
+
+ before() : execution(* *(..)) { System.out.println("before"); }
+
+} \ No newline at end of file
diff --git a/tests/features152/synthetic/design.txt b/tests/features152/synthetic/design.txt
new file mode 100644
index 000000000..bfc7909ff
--- /dev/null
+++ b/tests/features152/synthetic/design.txt
@@ -0,0 +1,63 @@
+This table shows the members we create as a result of aspect declarations and weaving,
+and whether they should be marked synthetic or not.
+
+Inside aspects:
+==================
+
+name type description synthetic
+-----------------------------------------------------------------------------------------
+ajc$preClinit method start of static initialization yes
+ajc$postClinit method end of static initialization yes
+ajc$perCflowPush method start a cflow yes
+ajc$perCflowStack field cflow stack yes
+ajc$perSingletonInstance field singleton instance yes
+ajc$initFailureCause field exception during init yes
+ajc$withinType field type for perwithin aspects yes
+ajc$perObjectBind method creation of perobject aspects yes
+ajc$getInstance method perwithin instance accessor yes
+ajc$createAspectInstance method creates ptw aspect yes
+aspectOf method generated aspectOf method yes?* (it has no matching source code)
+hasAspect method generated hasAspect method yes?* (it has no matching source code)
+ajc$superDispatch$<STname>$name super method accessor (for around advice) yes
+ajc$inlineAccessMethod$<AName>$<TName>$<mname> accessor for around advice yes
+ajc$inlineAccessFieldGet$... method for around advice yes
+ajc$inlineAccessFieldSet$... method for around advice yes
+ajc$preInterConstructor$<AName>$<TName> method ITD cons yes
+ajc$postInterConstructor$<AName>$<TName> method ITD cons yes
+ajc$interFieldInit$... method initializer for ITD field yes
+ajc$interFieldSetDispatch$... method set of ITD field yes
+ajc$interFieldGetDispatch$... method get of ITD field yes
+ajc$interMethodDispatch1$... method dispatch for ITD method yes
+ajc$interMethod$<AName>$<TName>$<name> method body of ITD method no
+ajc$before$... method before advice no
+ajc$after$... method after advice no
+ajc$around$... method around advice no
+ajc$afterReturning$... method after returning advice no
+ajc$afterThrowing$... method after throwing advice no
+ajc$declare... method declare statement yes
+ajc$if_... method if statement inside pointcut yes
+ajc$pointcut$... method pointcut declaration yes
+ajc$around$.....proceed method proceed method for around advice yes
+
+Inside classes:
+===================
+ajc$pointcut$... method pointcut declaration yes
+
+
+Inside woven types:
+===================
+
+ajc$<TName>$perObjectField field holds per-object aspect instance yes
+ajc$<TName>$ptwAspectInstance field holds per-type-within aspect yes
+<AName>$ajcMightHaveAspect interface added to per-xxx aspects n/a
+ajc$<AName>$perObjectGet method on types with ajcMightHaveAspect yes
+ajc$<AName>$perObjectSet method on types with ajcMightHaveAspect yes
+ajc$<AName>$localAspectOf method get ptw aspect instance yes
+ajc$privMethod$<Tname>$<AName>$<mname> method privileged accessor yes
+ajc$privFieldGet$<Tname>$<AName>$<fname> method privileged accessor yes
+ajc$privFieldSet$<Tname>$<AName>$<fname> method privileged mutator yes
+ajc$<AName>$<DPType> field @DeclareParents delegate yes
+ajc$interField$... field ITD-field yes
+ajc$interFieldGet$... method on target of ITD-field yes
+ajc$interFieldSet$... method on target of ITD-field yes
+ajc$interMethodDispatch2$... method on target of ITD-method yes