aboutsummaryrefslogtreecommitdiffstats
path: root/docs/progGuideDB/pitfalls.xml
diff options
context:
space:
mode:
Diffstat (limited to 'docs/progGuideDB/pitfalls.xml')
-rw-r--r--docs/progGuideDB/pitfalls.xml81
1 files changed, 45 insertions, 36 deletions
diff --git a/docs/progGuideDB/pitfalls.xml b/docs/progGuideDB/pitfalls.xml
index 5379d5daa..daf08f801 100644
--- a/docs/progGuideDB/pitfalls.xml
+++ b/docs/progGuideDB/pitfalls.xml
@@ -1,19 +1,22 @@
<chapter id="pitfalls" xreflabel="Pitfalls">
<title>Pitfalls</title>
- <sect1><!-- About this Chapter -->
- <title>About this Chapter</title>
+ <sect1 id="pitfalls-intro">
+ <title>Introduction</title>
- <para>This chapter consists of aspectj programs that may lead to surprising
- behaviour and how to understand them.
+ <para>
+ This chapter consists of a few AspectJ programs that may lead to
+ surprising behavior and how to understand them.
</para>
</sect1>
- <sect1>
+ <sect1 id="pitfalls-infiniteLoops">
<title>Infinite loops</title>
- <para>Here is a Java program with peculiar behavior </para>
+ <para>
+ Here is a Java program with peculiar behavior
+ </para>
<programlisting><![CDATA[
public class Main {
@@ -32,16 +35,21 @@ public class Main {
}
]]></programlisting>
- <para>This program will never reach the println call, but when it aborts
- will have no stack trace. </para>
+ <para>
+ This program will never reach the println call, but when it aborts
+ may have no stack trace.
+ </para>
- <para>This silence is caused by multiple StackOverflowExceptions. First
- the infinite loop in the body of the method generates one, which the
- finally clause tries to handle. But this finally clause also generates an
- infinite loop which the current JVMs can't handle gracefully leading to the
- completely silent abort. </para>
+ <para>
+ This silence is caused by multiple StackOverflowExceptions. First
+ the infinite loop in the body of the method generates one, which the
+ finally clause tries to handle. But this finally clause also
+ generates an infinite loop which the current JVMs can't handle
+ gracefully leading to the completely silent abort.
+ </para>
- <para> The following short aspect will also generate this behavior:
+ <para>
+ The following short aspect will also generate this behavior:
</para>
<programlisting><![CDATA[
@@ -51,9 +59,11 @@ aspect A {
}
]]></programlisting>
- <para>Why? Because the call to println is also a call matched by the
- pointcut <literal>call (* *(..))</literal>. We get no output because we
- used simple after() advice. If the aspect were changed to</para>
+ <para>
+ Why? Because the call to println is also a call matched by the
+ pointcut <literal>call (* *(..))</literal>. We get no output because
+ we used simple after() advice. If the aspect were changed to
+ </para>
<programlisting><![CDATA[
aspect A {
@@ -62,13 +72,17 @@ aspect A {
}
]]></programlisting>
- <para>Then at least a StackOverflowException with a stack trace would be
- seen. In both cases, though, the overall problem is advice applying within
- its own body. </para>
+ <para>
+ Then at least a StackOverflowException with a stack trace would be
+ seen. In both cases, though, the overall problem is advice applying
+ within its own body.
+ </para>
- <para>There's a simple idiom to use if you ever have a worry that your
- advice might apply in this way. Just restrict the advice from occurring in
- join points caused within the aspect. So: </para>
+ <para>
+ There's a simple idiom to use if you ever have a worry that your
+ advice might apply in this way. Just restrict the advice from occurring in
+ join points caused within the aspect. So:
+ </para>
<programlisting><![CDATA[
aspect A {
@@ -77,8 +91,10 @@ aspect A {
}
]]></programlisting>
- <para>Other solutions might be to more closely restrict the pointcut in
- other ways, for example: </para>
+ <para>
+ Other solutions might be to more closely restrict the pointcut in
+ other ways, for example:
+ </para>
<programlisting><![CDATA[
aspect A {
@@ -87,17 +103,10 @@ aspect A {
}
]]></programlisting>
- <para>The moral of the story is that unrestricted generic pointcuts can
- pick out more join points than intended. </para>
+ <para>
+ The moral of the story is that unrestricted generic pointcuts can
+ pick out more join points than intended.
+ </para>
</sect1>
</chapter>
-
-<!--
-Local variables:
-compile-command: "java sax.SAXCount -v progguide.xml && java com.icl.saxon.StyleSheet -w0 progguide.xml progguide.html.xsl"
-fill-column: 79
-sgml-local-ecat-files: "progguide.ced"
-sgml-parent-document:("progguide.xml" "book" "chapter")
-End:
--->