diff options
Diffstat (limited to 'docs/progGuideDB/idioms.xml')
-rw-r--r-- | docs/progGuideDB/idioms.xml | 70 |
1 files changed, 20 insertions, 50 deletions
diff --git a/docs/progGuideDB/idioms.xml b/docs/progGuideDB/idioms.xml index 5898dbd9e..c6297c90b 100644 --- a/docs/progGuideDB/idioms.xml +++ b/docs/progGuideDB/idioms.xml @@ -1,17 +1,20 @@ <chapter id="idioms" xreflabel="Idioms"> <title>Idioms</title> - <sect1><!-- About this Chapter --> - <title>About this Chapter</title> + <sect1 id="idioms-intro"> + <title>Introduction</title> - <para>This chapter consists of very short snippets of AspectJ code, - typically pointcuts, that are particularly evocative or useful. - This section is a work in progress. + <para> + This chapter consists of very short snippets of AspectJ code, + typically pointcuts, that are particularly evocative or useful. + This section is a work in progress. </para> - <para> Here's an example of how to enfore a rule that code in the java.sql - package can only be used from one particular package in your system. This - doesn't require any access to code in the java.sql package. + <para> + Here's an example of how to enfore a rule that code in the + java.sql package can only be used from one particular package in + your system. This doesn't require any access to code in the + java.sql package. </para> <programlisting><![CDATA[ @@ -19,7 +22,7 @@ pointcut restrictedCall(): call(* java.sql.*.*(..)) || call(java.sql.*.new(..)); -/* Any code in my system not in the sqlAccess package */ +/* Any code in my system not in the sqlAccess package */ pointcut illegalSource(): within(com.foo..*) && !within(com.foo.sqlAccess.*); @@ -31,9 +34,9 @@ declare error: restrictedCall() && illegalSource(): not exactly equal to AbstractFacade:</para> <programlisting><![CDATA[ -pointcut nonAbstract(AbstractFacade af): - call(* *(..)) - && target(af) +pointcut nonAbstract(AbstractFacade af): + call(* *(..)) + && target(af) && !if(af.getClass() == AbstractFacade.class); ]]></programlisting> @@ -42,7 +45,7 @@ pointcut nonAbstract(AbstractFacade af): <programlisting><![CDATA[ pointcut nonAbstract(AbstractFacade af): - call(* *(..)) + call(* *(..)) && target(af); ]]></programlisting> @@ -51,8 +54,8 @@ pointcut nonAbstract(AbstractFacade af): </para> <programlisting><![CDATA[ -pointcut callToUndefinedMethod(): - call(* AbstractFacade+.*(..)) +pointcut callToUndefinedMethod(): + call(* AbstractFacade+.*(..)) && !call(* AbstractFacade.*(..)); ]]></programlisting> @@ -62,43 +65,10 @@ pointcut callToUndefinedMethod(): <programlisting><![CDATA[ pointcut executionOfUndefinedMethod(): - execution(* *(..)) - && within(AbstractFacade+) + execution(* *(..)) + && within(AbstractFacade+) && !within(AbstractFacade) ]]></programlisting> - <para>To use a per-class variable declared on many classes, - you can defer initialization until you are in a non-static instance context - so you can refer to the particular class member. If you want to use - it from advice (without knowing the particular class at compile-time), - you can declare a method on the type. - </para> - -<programlisting><![CDATA[ -aspect Logging { - - //... - - /** per-Loggable-class reference to per-class Logger */ - static private Logger Loggable+.staticLogger; - - /** instance getter for static logger (lazy construction) */ - public Logger Loggable+.getLogger() { // XXX make private to aspect? - if (null == staticLogger) { - staticLogger = Logger.getLoggerFor(getClass()); - } - return staticLogger; - } - - /** when logging and logger enabled, log the target and join point */ - before(Loggable loggable) : target(loggable) && logging() { - Logger logger = loggable.getLogger(); - if (logger.enabled()) { - logger.log(loggable + " at " + thisJoinPoint); - } - } -} -]]></programlisting> - </sect1> </chapter> |