aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--docs/adk15ProgGuideDB/adk15notebook.xml2
-rw-r--r--docs/adk15ProgGuideDB/annotations.xml412
-rw-r--r--docs/adk15ProgGuideDB/autoboxing.xml21
-rw-r--r--docs/adk15ProgGuideDB/covariance.xml174
-rw-r--r--docs/adk15ProgGuideDB/joinpointsignatures.xml131
-rw-r--r--docs/adk15ProgGuideDB/pertypewithin.xml14
-rw-r--r--docs/adk15ProgGuideDB/varargs.xml57
7 files changed, 669 insertions, 142 deletions
diff --git a/docs/adk15ProgGuideDB/adk15notebook.xml b/docs/adk15ProgGuideDB/adk15notebook.xml
index 62f6ca68a..c3ed62924 100644
--- a/docs/adk15ProgGuideDB/adk15notebook.xml
+++ b/docs/adk15ProgGuideDB/adk15notebook.xml
@@ -3,6 +3,7 @@
<!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"
"../../lib/docbook/docbook-dtd/docbookx.dtd"
[
+<!ENTITY jpsigs SYSTEM "joinpointsignatures.xml">
<!ENTITY annotations SYSTEM "annotations.xml">
<!ENTITY generics SYSTEM "generics.xml">
<!ENTITY enumeratedtypes SYSTEM "enumeratedtypes.xml">
@@ -55,6 +56,7 @@
</abstract>
</bookinfo>
+ &jpsigs;
&annotations;
&generics;
&enumeratedtypes;
diff --git a/docs/adk15ProgGuideDB/annotations.xml b/docs/adk15ProgGuideDB/annotations.xml
index 48773ac76..30e495c48 100644
--- a/docs/adk15ProgGuideDB/annotations.xml
+++ b/docs/adk15ProgGuideDB/annotations.xml
@@ -639,132 +639,19 @@
</sect2>
- <sect2>
- <title>Package and Parameter Annotations</title>
-
- <para>
- <emphasis>Note: A previous design allowed package annotation patterns to be specified
- directly in type patterns, and parameter annotation patterns to be
- specified directly in method and constructor signature patterns. Because
- this made some pointcut expressions hard to read and understand, we moved
- in favour of the design presented below, which also has its drawbacks.
- Matching on package and parameter annotations is one feature likely to be
- deferred until after the 1.5.0 release so that we can gain more understanding
- of the kinds of uses AspectJ users are making of annotations in pointcut
- expressions before commiting to any one approach.</emphasis>
- </para>
-
- <para>
- Java 5 allows both packages and parameters to be annotated. To allow matching on package and parameter annotations,
- AspectJ 1.5 introduces the <literal>@package</literal> and <literal>@parameters</literal> pointcut designators.
- <emphasis>Note: we could consider deferring implementation of these to a dot release after 1.5.0?</emphasis>
- </para>
-
- <programlisting><![CDATA[
- PackageAnnotationPointcut := '@package' '(' AnnotationPattern ')'
- ]]></programlisting>
-
- <para>The <literal>@package</literal> pointcut matches any join point
- occuring within the scope of a package with
- annotations matching the giving <literal>AnnotationPattern</literal>. For
- example:
- </para>
-
- <programlisting><![CDATA[
- @package(@Model)
- ]]></programlisting>
-
- <para>
- Matches any join point occuring within the scope of a package with the
- <literal>@Model</literal> annotation.
- </para>
-
- <para>
- <emphasis>
- Note: we added @package as a result of a conscious decision not to allow the
- specification of package annotation patterns within a general TypePattern. A
- consequence of this decision is that we lose the ability to say the following
- things: "a call to a method defined in a type in a package with annotations
- matching..." ; "the set of a field defined in a type in a package with annotations
- matching..." ; "the get of a field defined in a type in a package with annotations
- matching...". As well as the package of the target at these join points, there is
- also the package of the runtime type of the target (call/target difference). So
- there are at least three possible sets of package annotations you could theoretically
- want to match on at a call, get, or set join point. We have chosen to provide the
- means to express the simplest of these, and could consider extending the language
- to allow for the others in the future when we better understanding how users will
- really use both package annotations and these features.
- </emphasis>
- </para>
-
- <para>
- The <literal>@parameter</literal> pointcut designator acts in a similar manner to
- <literal>args</literal> in that it matches based on number and position of arguments
- at a join point (and supports the same wildcard options of <literal>*</literal> and
- <literal>..</literal>.
- </para>
-
- <programlisting><![CDATA[
- ParamsAnnotationPointcut := '@parameters' '(' ParamsAnnotationPattern ')'
-
- ParamsAnnotationPattern := AnnotationPattern (',' ParamsAnnotationPattern)? |
- '*' (',' ParamsAnnotationPattern)? |
- '..' (',' SingleParamsAnnotationPattern)*
-
- SingleParamsAnnotationPattern := AnnotationPattern (',' SingleParamsAnnotationPattern)? |
- '*' (',' SingleParamsAnnotationPattern)?
- ]]></programlisting>
-
- <para>The <literal>*</literal> wildcard matches a single parameter regardless of its annotations.
- The <literal>..</literal> wildcard matches zero or more parameters with any annotations. An
- annotation pattern in a given parameter position matches a parameter in that position with annotations
- matching the given annotation pattern. For example, the method signature</para>
-
- <programlisting><![CDATA[
- public void foo(@Immutable int i, String s, @Cached Object o);
- ]]></programlisting>
-
- <para>
- Is matched by:
- </para>
-
- <programlisting><![CDATA[
- @parameters(@Immutable, *, @Cached);
-
- and,
-
- @parameters(..,@Cached);
-
- and,
-
- @parameters(@Immutable, *, *);
- ]]></programlisting>
+ <sect2>
+ <title>Runtime type matching and context exposure</title>
- <para>
- It is not matched by:
+ <para>AspectJ 1.5 supports a set of "@" pointcut designators which
+ can be used both to match based on the presence of an annotation at
+ runtime, and to expose the annotation value as context in a pointcut or
+ advice definition. These designators are <literal>@args, @this, @target,
+ @within, @withincode, @call, @execution, @adviceexecution, @get, @set,
+ @staticinitialization, @initialization,</literal>, and <literal>@preinitialization</literal>
</para>
-
- <programlisting><![CDATA[
- @parameters(@Immutable, *);
-
- or,
-
- @parameters(*,@Immutable);
-
- or,
-
- @parameters(*, int, @Cached);
- ]]></programlisting>
- <para>
- This last example will result in a compilation error since <literal>int</literal> is not a
- valid annotation pattern.
- </para>
-
- </sect2>
-
- <sect2>
- <title>Runtime type matching and context exposure</title>
+ <para>It is a compilation error to attempt to match on an annotation type
+ that does not have runtime retention using one of these pointcut designators.</para>
<para>
The <literal>this()</literal>, <literal>target()</literal>, and
@@ -896,7 +783,154 @@
library to Java 5. A sub-interface and downcast solution could be used
if these helpers were felt to be sufficiently important.</emphasis>
</para>
+
+ <para>
+ The <literal>@within</literal> and <literal>@withincode</literal> pointcut designators
+ match any join point where the enclosing type (<literal>@within</literal>), or
+ method/constructor (<literal>@withincode</literal>) has an annotation of the specified
+ type. The form of these designators is:
+ </para>
+
+ <programlisting><![CDATA[
+ WithinAnnotation := '@within' '(' AnnotationNameOrVar ')'
+
+ WithinCodeAnnotation := '@withincode' '(' AnnotationNameOrVar ')'
+ ]]></programlisting>
+
+ <para>Some examples of using these designators follow:</para>
+
+ <variablelist>
+
+ <varlistentry>
+ <term>@within(@Foo)</term>
+ <listitem>
+ <para>
+ Matches any join point where the enclosing type
+ has an annotation of type <literal>Foo</literal>.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>pointcut insideCriticalMethod(Critical c) :
+ @withincode(c);</term>
+ <listitem>
+ <para>
+ Matches any join point whose shadow is lexically enclosed
+ in a method which has an annotation of type <literal>@Critical</literal>,
+ and exposes the value of the annotation in the parameter
+ <literal>c</literal>.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ </variablelist>
+ <para>The remaining annotation-based pointcut designators are defined in a
+ similar fashion:</para>
+
+ <programlisting><![CDATA[
+ CallAnnotation := '@call' '(' AnnotationNameOrVar ')'
+
+ ExecutionAnnotation := '@execution' '(' AnnotationNameOrVar ')'
+
+ AdviceExecution := '@adviceexecution' '(' AnnotationNameOrVar ')'
+
+ GetAnnotation := '@set' '(' AnnotationNameOrVar ')'
+
+ SetAnnotation := '@get' '(' AnnotationNameOrVar ')'
+
+ InitializationAnnotation := '@initialization' '(' AnnotationNameOrVar ')'
+
+ PreInitializationAnnotation := '@preinitialization' '(' AnnotationNameOrVar ')'
+
+ StaticInitializationAnnotation := '@staticinitialization' '(' AnnotationNameOrVar ')'
+ ]]></programlisting>
+
+ <variablelist>
+
+ <varlistentry>
+ <term>@call(@Foo)</term>
+ <listitem>
+ <para>
+ Matches any call join point where the most specific join point
+ signature has an annotation of type <literal>@Foo</literal>.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>@execution(@Foo)</term>
+ <listitem>
+ <para>
+ Matches any execution join point where the most specific join point
+ signature has an annotation of type <literal>@Foo</literal>.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>@adviceexecution(@Foo)</term>
+ <listitem>
+ <para>
+ Matches any advice execution join point where the advice
+ has an annotation of type <literal>@Foo</literal>.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>@get(@Foo)</term>
+ <listitem>
+ <para>
+ Matches any get join point where the target field
+ has an annotation of type <literal>@Foo</literal>.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>@set(@Foo)</term>
+ <listitem>
+ <para>
+ Matches any set join point where the target field
+ has an annotation of type <literal>@Foo</literal>.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>@initialization(@Foo)</term>
+ <listitem>
+ <para>
+ Matches any initialization join point where the initiating
+ constructor an annotation of type <literal>@Foo</literal>.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>@preinitialization(@Foo)</term>
+ <listitem>
+ <para>
+ Matches any preinitialization join point where the initiating
+ constructor an annotation of type <literal>@Foo</literal>.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>@staticinitialization(@Foo)</term>
+ <listitem>
+ <para>
+ Matches any staticinitialization join point where the type being
+ initialized has an annotation of type <literal>@Foo</literal>.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ </variablelist>
+
<para>
Access to annotation information on members at a matched join point is available
through the <literal>getSignature</literal> method of the <literal>JoinPoint</literal>
@@ -922,18 +956,134 @@
to Java 5.</emphasis>
</para>
+ </sect2>
+
+ <sect2>
+ <title>Package and Parameter Annotations</title>
+
+ <para>
+ <emphasis>Note: A previous design allowed package annotation patterns to be specified
+ directly in type patterns, and parameter annotation patterns to be
+ specified directly in method and constructor signature patterns. Because
+ this made some pointcut expressions hard to read and understand, we moved
+ in favour of the design presented below, which also has its drawbacks.
+ Matching on package and parameter annotations is one feature likely to be
+ deferred until after the 1.5.0 release so that we can gain more understanding
+ of the kinds of uses AspectJ users are making of annotations in pointcut
+ expressions before commiting to any one approach.</emphasis>
+ </para>
+
+ <para>
+ Java 5 allows both packages and parameters to be annotated. To allow matching on package and parameter annotations,
+ AspectJ 1.5 introduces the <literal>@package</literal> and <literal>@parameters</literal> pointcut designators.
+ <emphasis>Note: we could consider deferring implementation of these to a dot release after 1.5.0?</emphasis>
+ </para>
+
+ <programlisting><![CDATA[
+ PackageAnnotationPointcut := '@package' '(' AnnotationPattern ')'
+ ]]></programlisting>
+
+ <para>The <literal>@package</literal> pointcut matches any join point
+ occuring within the scope of a package with
+ annotations matching the giving <literal>AnnotationPattern</literal>. For
+ example:
+ </para>
+
+ <programlisting><![CDATA[
+ @package(@Model)
+ ]]></programlisting>
+
+ <para>
+ Matches any join point occuring within the scope of a package with the
+ <literal>@Model</literal> annotation.
+ </para>
+
+ <para>
+ <emphasis>
+ Note: we added @package as a result of a conscious decision not to allow the
+ specification of package annotation patterns within a general TypePattern. A
+ consequence of this decision is that we lose the ability to say the following
+ things: "a call to a method defined in a type in a package with annotations
+ matching..." ; "the set of a field defined in a type in a package with annotations
+ matching..." ; "the get of a field defined in a type in a package with annotations
+ matching...". As well as the package of the target at these join points, there is
+ also the package of the runtime type of the target (call/target difference). So
+ there are at least three possible sets of package annotations you could theoretically
+ want to match on at a call, get, or set join point. We have chosen to provide the
+ means to express the simplest of these, and could consider extending the language
+ to allow for the others in the future when we better understanding how users will
+ really use both package annotations and these features.
+ </emphasis>
+ </para>
+
+ <para>
+ The <literal>@parameter</literal> pointcut designator acts in a similar manner to
+ <literal>args</literal> in that it matches based on number and position of arguments
+ at a join point (and supports the same wildcard options of <literal>*</literal> and
+ <literal>..</literal>.
+ </para>
+
+ <programlisting><![CDATA[
+ ParamsAnnotationPointcut := '@parameters' '(' ParamsAnnotationPattern ')'
+
+ ParamsAnnotationPattern := AnnotationPattern (',' ParamsAnnotationPattern)? |
+ '*' (',' ParamsAnnotationPattern)? |
+ '..' (',' SingleParamsAnnotationPattern)*
+
+ SingleParamsAnnotationPattern := AnnotationPattern (',' SingleParamsAnnotationPattern)? |
+ '*' (',' SingleParamsAnnotationPattern)?
+ ]]></programlisting>
+
+ <para>The <literal>*</literal> wildcard matches a single parameter regardless of its annotations.
+ The <literal>..</literal> wildcard matches zero or more parameters with any annotations. An
+ annotation pattern in a given parameter position matches a parameter in that position with annotations
+ matching the given annotation pattern. For example, the method signature</para>
+
+ <programlisting><![CDATA[
+ public void foo(@Immutable int i, String s, @Cached Object o);
+ ]]></programlisting>
+
+ <para>
+ Is matched by:
+ </para>
+
+ <programlisting><![CDATA[
+ @parameters(@Immutable, *, @Cached);
+
+ and,
+
+ @parameters(..,@Cached);
+
+ and,
+
+ @parameters(@Immutable, *, *);
+ ]]></programlisting>
+
+ <para>
+ It is not matched by:
+ </para>
+
+ <programlisting><![CDATA[
+ @parameters(@Immutable, *);
+
+ or,
+
+ @parameters(*,@Immutable);
+
+ or,
+
+ @parameters(*, int, @Cached);
+ ]]></programlisting>
+
<para>
- <emphasis>Note: the use case of matching call/execution/get/set join points based
- on member annotations is expected to be a common one. If it is also common
- practice to want to access the annotation value in the advice body, then the
- route via thisJoinPointStaticPart and the Signature interface will be too
- cumbersome. In this case we need to find a form of context-exposing pcd
- that will allow the annotation value to be directly exposed as an advice
- parameter. What form should this take, and what join points should it match?
- </emphasis>
+ This last example will result in a compilation error since <literal>int</literal> is not a
+ valid annotation pattern.
</para>
+
</sect2>
+
+
<sect2>
<title>Annotation Inheritance and pointcut matching</title>
diff --git a/docs/adk15ProgGuideDB/autoboxing.xml b/docs/adk15ProgGuideDB/autoboxing.xml
index 5a3c454ad..ded805fb0 100644
--- a/docs/adk15ProgGuideDB/autoboxing.xml
+++ b/docs/adk15ProgGuideDB/autoboxing.xml
@@ -2,5 +2,26 @@
<title>Autoboxing and Unboxing</title>
+ <sect1 id="boxing-inJava5">
+ <title>Autoboxing and Unboxing in Java 5</title>
+
+ <para>
+ Java 5 (and hence AspectJ 1.5) ... . For example:
+ </para>
+
+ <programlisting><![CDATA[
+ ]]></programlisting>
+
+ </sect1>
+
+ <sect1>
+ <title>Autoboxing and Join Point matching in AspectJ 1.5</title>
+ </sect1>
+
+ <sect1>
+ <title>Inter-type method declarations and method dispatch</title>
+ </sect1>
+
+
</chapter>
diff --git a/docs/adk15ProgGuideDB/covariance.xml b/docs/adk15ProgGuideDB/covariance.xml
index d182e157e..4e1e2f8de 100644
--- a/docs/adk15ProgGuideDB/covariance.xml
+++ b/docs/adk15ProgGuideDB/covariance.xml
@@ -2,5 +2,179 @@
<title>Covariance</title>
+ <sect1 id="covariance-inJava5">
+ <title>Covariance in Java 5</title>
+
+ <para>
+ Java 5 (and hence AspectJ 1.5) allows you to narrow the return type
+ in an overriding method. For example:
+ </para>
+
+ <programlisting><![CDATA[
+ class A {
+ public A whoAreYou() {...}
+ }
+
+ class B extends A {
+ // override A.whoAreYou *and* narrow the return type.
+ public B whoAreYou() {...}
+ }
+ ]]></programlisting>
+
+ </sect1>
+
+ <sect1>
+ <title>Covariant methods and Join Point matching</title>
+
+ <para>The join point matching rules for <literal>call</literal>
+ and <literal>execution</literal> pointcut designators are extended
+ to match against covariant methods.</para>
+
+ <para>
+ Given the classes <literal>A</literal> and <literal>B</literal>
+ as defined in the previous section, and the program fragment
+ </para>
+
+ <programlisting><![CDATA[
+ A a = new A();
+ B b = new B();
+ a.whoAreYou();
+ b.whoAreYou();
+ ]]></programlisting>
+
+ <para>Then the call and execution join points for <literal>whoAreYou</literal>
+ are matched as follows:</para>
+
+ <variablelist>
+
+ <varlistentry>
+ <term>call(* whoAreYou())</term>
+ <listitem>
+ <para>Matches both calls, (since it places no constraint on the
+ return type of the join point signature).
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>call(* A.whoAreYou())</term>
+ <listitem>
+ <para>Matches both calls, (since the original declaring type
+ of <literal>whoAreYou</literal> is <literal>A</literal>).
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>call(A whoAreYou())</term>
+ <listitem>
+ <para>Matches both calls, (since the signature of
+ <literal>whoAreYou</literal>) in the original declaring type
+ has a return type of <literal>A</literal>).
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>call(A B.whoAreYou())</term>
+ <listitem>
+ <para>Does not match anything - the signature of <literal>whoAreYou</literal>
+ as overriden in <literal>B</literal> has a return type of
+ <literal>B</literal>, not <literal>A</literal>. A lint warning is
+ given for the call <literal>a.whoAreYou()</literal> ("does not match
+ because declaring type is A, if match required use target(B)").
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>call(A+ B.whoAreYou())</term>
+ <listitem>
+ <para>Matches the call to <literal>b.whoAreYou()</literal> since
+ the return type <literal>B</literal> in the method signature
+ is matched by the type pattern <literal>A+</literal>. A lint warning is
+ given for the call <literal>a.whoAreYou()</literal> ("does not match
+ because declaring type is A, if match required use target(B)").
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>call(B A.whoAreYou())</term>
+ <listitem>
+ <para>Does not match anything - there is no method declared in
+ <literal>A</literal> with a return type of <literal>B</literal>.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>call(B whoAreYou())</term>
+ <listitem>
+ <para>Matches the call to <literal>b.whoAreYou()</literal> only.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ <varlistentry>
+ <term>call(B B.whoAreYou())</term>
+ <listitem>
+ <para>Matches the call to <literal>b.whoAreYou()</literal> only.
+ </para>
+ </listitem>
+ </varlistentry>
+
+ </variablelist>
+
+ <para>The rule for signature matching at call and execution join points
+ is unchanged from AspectJ 1.2: a call or execution pointcut matches if
+ the signature pattern matches at least one of the signatures of the
+ join point, and if the most-specific matched signature is also matched
+ by any modifier pattern or annotation pattern that may be present.</para>
+
+ <para>For a call or execution join point, the signatures of a join point
+ for the call or execution of a method <literal>Rtype T.m(params)</literal>
+ are determined as follows:</para>
+ <itemizedlist>
+ <listitem>
+ If <literal>m(params)</literal> is defined in <literal>T</literal>,
+ then the signature of <literal>m(params)</literal> in <literal>T</literal> is
+ a signature of the join point: <literal>Rtype T.m(params)</literal>.
+ If <literal>T</literal> does not
+ provide its own definition of <literal>m</literal>, then the signature
+ <literal>Rtype' T.m(params)</literal>
+ is a signature of the join point, where <literal>Rtype'</literal> is the return type of
+ the definition of <literal>m</literal> inherited by <literal>T</literal>.
+ </listitem>
+ <listitem>
+ For each super-type <literal>S</literal> of <literal>T</literal> that is a valid receiver
+ for a call to <literal>m</literal>, then the signature of <literal>m(params)</literal> in
+ <literal>S</literal> is a signature
+ of the join point: <literal>Rtype S.m(params)</literal>.
+ If <literal>S</literal> does not provide its
+ own definition of <literal>m</literal>, then the signature
+ <literal>Rtype' S.m(params)</literal> is a
+ signature of the join point, where <literal>Rtype'</literal> is the return type of the
+ definition of <literal>m</literal> inherited by <literal>S</literal>.
+ </listitem>
+ </itemizedlist>
+
+ <para>A call to <literal>b.whoAreYou()</literal> has the join point signatures
+ </para>
+
+ <itemizedlist>
+ <listitem>B B.whoAreYou()</listitem>
+ <listitem>A A.whoAreYou()</listitem>
+ </itemizedlist>
+
+ <para>Following the rule given, it is easy to see why for example
+ <literal>call(B A.whoAreYou())</literal> does not match anything as
+ this pattern matches neither of the signatures at the join point. In
+ contrast, the pointcut expression <literal>call(A+ B.whoAreYou())</literal>
+ does match the call to <literal>b.whoAreYou()</literal> because it matches
+ the second of the signatures at the join point.</para>
+ </sect1>
+
+
</chapter>
diff --git a/docs/adk15ProgGuideDB/joinpointsignatures.xml b/docs/adk15ProgGuideDB/joinpointsignatures.xml
new file mode 100644
index 000000000..0c3473034
--- /dev/null
+++ b/docs/adk15ProgGuideDB/joinpointsignatures.xml
@@ -0,0 +1,131 @@
+<chapter id="jpsigs" xreflabel="Join Point Signatures">
+
+ <title>Join Point Signatures</title>
+
+ <para>To understand join point matching for annotations, generics, and
+ covariance, it is first necessary to understand the concepts of
+ join point signatures and join point signature matching, for call and
+ execution join points.</para>
+
+ <sect1>
+ <title>Join Point Signatures for Call Join Points</title>
+
+ <para>A call join point can have more than one signature. For a
+ call pointcut expression to match a given call join point, at
+ least one of the join point signatures must be matched by the
+ pointcut's signature pattern.</para>
+
+ <para>
+ For a call join point where a call is made to a method
+ <literal>m(args)</literal> on a target type <literal>T</literal> (where
+ <literal>T</literal> is the static type of the target):
+ </para>
+
+ <programlisting><![CDATA[
+ T t = new T();
+ t.m("hello"); <= call join point occurs when this line is executed
+ ]]></programlisting>
+
+ <para>
+ Then the signature <literal>R(T) T.m(args)</literal> is a signature
+ of the call join point, where <literal>R(T)</literal> is the return
+ type of <literal>m</literal> in <literal>T</literal>, and
+ <literal>args</literal> represents the types of the arguments to
+ <literal>m</literal>. If <literal>T</literal> itself does not
+ declare a definition of <literal>m(args)</literal>, then
+ <literal>R(T)</literal> is the return type in the definition of
+ <literal>m</literal> that <literal>T</literal> inherits. Given the
+ call above, and the definition of <literal>T.m</literal>:
+ </para>
+
+ <programlisting><![CDATA[
+ interface Q {
+ R m(String s);
+ }
+
+ class P implements Q {
+ R m(String s) {...}
+ }
+
+ class S extends P {
+ R' m(String s) {...}
+ }
+
+ class T extends S {
+
+ ]]></programlisting>
+
+ <para>Then <literal>R' T.m(String)</literal> is a signature of the
+ call join point for <literal>t.m("hello")</literal></para>.
+
+ <para>
+ For each ancestor (super-type) <literal>A</literal> of <literal>T</literal>,
+ if <literal>m(args)</literal> is defined for that super-type, then
+ <literal>R(A) A.m(args)</literal> is a signature of the call join
+ point, where <literal>R(A)</literal> is the return type of <literal>
+ m(args)</literal> as defined in <literal>A</literal>, or as inherited
+ by <literal>A</literal> if <literal>A</literal> itself does not
+ provide a definition of <literal>m(args)</literal>.
+ </para>
+
+ <para>
+ Continuing the example from above,we can deduce that
+ </para>
+
+ <programlisting><![CDATA[
+ R' S.m(String)
+ R P.m(String)
+ R Q.m(String)
+ ]]></programlisting>
+
+ <para>are all additional signatures for the call join point arising
+ from the call <literal>t.m("hello")</literal>. Thus the call
+ join point has four signatures in total. Amongst these signatures,
+ we say that the <emphasis>most-specific signature</emphasis> is the
+ signature with the most-specific declaring type - that is, the
+ signature of the static type of the target of the call
+ (<literal>R' T.m(String)</literal>) in this case.</para>
+
+ </sect1>
+
+ <sect1>
+ <title>Join Point Signatures for Execution Join Points</title>
+
+ <para>Join point signatures for execution join points are defined
+ in a similar manner to signatures for call join points. Given the
+ same hierarchy as in the call example in the previous section:
+ </para>
+
+
+ <programlisting><![CDATA[
+ interface Q {
+ R m(String s);
+ }
+
+ class P implements Q {
+ R m(String s) {...}
+ }
+
+ class S extends P {
+ R' m(String s) {...}
+ }
+
+ class T extends S {
+
+ ]]></programlisting>
+
+ <para>Then the execution join point signatures arising as a result
+ of the call to <literal>t.m("hello")</literal> are: </para>
+
+
+ </sect1>
+
+ <sect1>
+ <title>Pointcut matching based on Join Point Signatures</title>
+
+ <para>Explain signature + modifiers split, plus notion of "most-specific"
+ join point.</para>
+ </sect1>
+
+
+</chapter>
diff --git a/docs/adk15ProgGuideDB/pertypewithin.xml b/docs/adk15ProgGuideDB/pertypewithin.xml
index 5f5b8fd66..e870f10e5 100644
--- a/docs/adk15ProgGuideDB/pertypewithin.xml
+++ b/docs/adk15ProgGuideDB/pertypewithin.xml
@@ -2,5 +2,19 @@
<title>The pertypewithin Aspect Instantiation Model</title>
+ <para>This is a placeholder to stimulate discussion around a possible new
+ instantiation model : <literal>pertypewithin(OptionalParensTypePattern)</literal>.
+ The semantics of <literal>pertypewithin</literal> are that a new aspect
+ instance will be created at the <literal>staticinitialization</literal>
+ join point of each type matching the given type pattern.</para>
+
+ <para>Discussion must include motivating use cases. Raise the issue that
+ pertypewithin takes a type pattern, not a pointcut.</para>
+
+ <para>We will only do this if we believe we can generate an implementation
+ that is significantly more efficient than hand-coded alternatives.</para>
+
+ <para>Need to define aspectOf(Class), hasAspect(Class).</para>
+
</chapter>
diff --git a/docs/adk15ProgGuideDB/varargs.xml b/docs/adk15ProgGuideDB/varargs.xml
index 91a389b52..ceadfed05 100644
--- a/docs/adk15ProgGuideDB/varargs.xml
+++ b/docs/adk15ProgGuideDB/varargs.xml
@@ -2,7 +2,7 @@
<title>Varargs</title>
- <sect1 id="varargs-inJava5">
+ <sect1 id="varargs-inJava5" xreflabel="Varargs in Java 5">
<title>Variable-length Argument Lists in Java 5</title>
<para>
@@ -169,21 +169,56 @@
<literal>execution(* *.*(String[]))</literal> matches the execution join point
for <literal>bar</literal> but not <literal>foo</literal>.
</para>
-
- <para>
- The <literal>args</literal> pointcut designator can also now take a <literal>varargs</literal>
- pattern as the last argument in the list. For example, you can write:
- </para>
-
- <programlisting><![CDATA[
- args(int, String...)
- ]]></programlisting>
-
+
</sect2>
<sect2>
<title>Exposing variable-length arguments as context in pointcuts and advice</title>
+
+ <para>
+ When a varargs parameter is used within the body of a method, it has
+ an array type, as discussed in the introduction to this section. We follow the
+ same convention when binding a varargs parameter via the <literal>args</literal>
+ pointcut designator. Given a method
+ </para>
+
+ <programlisting><![CDATA[
+ public void foo(int i, String... strings) {
+ }
+ ]]></programlisting>
+
+ <para>
+ The call or execution join points for <literal>foo</literal> will be matched
+ by the pointcut <literal>args(int,String[])</literal>. It is not permitted
+ to use the varargs syntax within an args pointcut designator - so you
+ <emphasis>cannot</emphasis> write <literal>args(int,String...)</literal>.
+ </para>
+
+ <para>
+ Binding of a varargs parameter in an advice statement is straightforward:
+ </para>
+
+ <programlisting><![CDATA[
+ before(int i, String[] ss) : call(* foo(int,String...)) && args(i,ss) {
+ // varargs String... argument is accessible in advice body through ss
+ // ...
+ }
+ ]]></programlisting>
+
+ <para>Since you cannot use the varargs syntax in the <literal>args</literal>
+ pointcut designator, you also cannot use the varargs syntax to declare
+ advice parameters.</para>
+
+ <para>Note: the proposal in this section does not allow you to
+ distinguish between a join point with a signature (int, String...)
+ and a join point with a signature (int, String[]) based
+ <emphasis>solely</emphasis> on the use of the <literal>args</literal>
+ pointcut designator. If this distinction is required, <literal>args</literal>
+ can always be coupled with <literal>call</literal> or
+ <literal>execution</literal>.</para>
+
</sect2>
+
</sect1>
</chapter>