• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1<html>
2<head>
3<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
4<title>BOOST_TEST: details on expressions</title>
5<link rel="stylesheet" href="../../boostbook.css" type="text/css">
6<meta name="generator" content="DocBook XSL Stylesheets V1.79.1">
7<link rel="home" href="../../index.html" title="Boost.Test">
8<link rel="up" href="../testing_tools.html" title="Writing unit tests">
9<link rel="prev" href="output_stream_testing.html" title="Output streams testing tool">
10<link rel="next" href="debugging.html" title="Debugging the assertions">
11</head>
12<body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
13<table cellpadding="2" width="100%"><tr>
14<td valign="top"><img alt="Boost C++ Libraries" width="277" height="86" src="../../../../../../boost.png"></td>
15<td align="center"><a href="../../../../../../index.html">Home</a></td>
16<td align="center"><a href="../../../../../../libs/libraries.htm">Libraries</a></td>
17<td align="center"><a href="http://www.boost.org/users/people.html">People</a></td>
18<td align="center"><a href="http://www.boost.org/users/faq.html">FAQ</a></td>
19<td align="center"><a href="../../../../../../more/index.htm">More</a></td>
20</tr></table>
21<hr>
22<div class="spirit-nav">
23<a accesskey="p" href="output_stream_testing.html"><img src="../../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../testing_tools.html"><img src="../../../../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../../index.html"><img src="../../../../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="debugging.html"><img src="../../../../../../doc/src/images/next.png" alt="Next"></a>
24</div>
25<div class="section">
26<div class="titlepage"><div><div><h3 class="title">
27<a name="boost_test.testing_tools.internal_details"></a><a class="link" href="internal_details.html" title="BOOST_TEST: details on expressions"><code class="computeroutput"><span class="identifier">BOOST_TEST</span></code>: details on expressions</a>
28</h3></div></div></div>
29<p>
30        Let's consider the following example:
31      </p>
32<h6>
33<a name="boost_test.testing_tools.internal_details.h0"></a>
34        <span class="phrase"><a name="boost_test.testing_tools.internal_details.example_descr"></a></span><a class="link" href="internal_details.html#boost_test.testing_tools.internal_details.example_descr">Example:
35        BOOST_TEST reporting</a>
36      </h6>
37<div class="informaltable"><table class="table">
38<colgroup><col></colgroup>
39<thead><tr><th>
40                <p>
41                  Code
42                </p>
43              </th></tr></thead>
44<tbody><tr><td>
45<pre xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" class="table-programlisting"><span class="preprocessor">#define</span> <span class="identifier">BOOST_TEST_MODULE</span> <span class="identifier">boost_test_macro3</span>
46<span class="preprocessor">#include</span> <span class="special">&lt;</span><span class="identifier">boost</span><span class="special">/</span><span class="identifier">test</span><span class="special">/</span><span class="identifier">included</span><span class="special">/</span><span class="identifier">unit_test</span><span class="special">.</span><span class="identifier">hpp</span><span class="special">&gt;</span>
47
48<span class="identifier">BOOST_AUTO_TEST_CASE</span><span class="special">(</span> <span class="identifier">test_op_reportings</span> <span class="special">)</span>
49<span class="special">{</span>
50  <span class="keyword">int</span> <span class="identifier">a</span> <span class="special">=</span> <span class="number">13</span><span class="special">,</span> <span class="identifier">b</span> <span class="special">=</span> <span class="number">12</span><span class="special">;</span>
51  <span class="identifier">BOOST_TEST</span><span class="special">(</span><span class="identifier">a</span> <span class="special">==</span> <span class="identifier">b</span><span class="special">);</span>
52  <span class="identifier">BOOST_TEST</span><span class="special">(</span><span class="identifier">a</span> <span class="special">&lt;</span> <span class="identifier">b</span><span class="special">);</span>
53  <span class="identifier">BOOST_TEST</span><span class="special">(</span><span class="identifier">a</span> <span class="special">-</span> <span class="number">1</span> <span class="special">&lt;</span> <span class="identifier">b</span><span class="special">);</span>
54  <span class="identifier">BOOST_TEST</span><span class="special">(</span><span class="identifier">b</span> <span class="special">&gt;</span> <span class="identifier">a</span> <span class="special">-</span> <span class="number">1</span><span class="special">);</span>
55<span class="special">}</span>
56</pre>
57              </td></tr></tbody>
58</table></div>
59<div class="informaltable"><table class="table">
60<colgroup><col></colgroup>
61<thead><tr><th>
62                <p>
63                  Output
64                </p>
65              </th></tr></thead>
66<tbody><tr><td>
67<pre xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" class="table-programlisting"><span class="special">&gt;</span> <span class="special">./</span><span class="identifier">boost_test_macro3</span> <span class="special">--</span><span class="identifier">log_level</span><span class="special">=</span><span class="identifier">all</span>
68<span class="identifier">Running</span> <span class="number">1</span> <span class="identifier">test</span> <span class="keyword">case</span><span class="special">...</span>
69<span class="identifier">Entering</span> <span class="identifier">test</span> <span class="identifier">module</span> <span class="string">"boost_test_macro3"</span>
70<span class="identifier">test</span><span class="special">.</span><span class="identifier">cpp</span><span class="special">(</span><span class="number">12</span><span class="special">):</span> <span class="identifier">Entering</span> <span class="identifier">test</span> <span class="keyword">case</span> <span class="string">"test_op_reportings"</span>
71<span class="identifier">test</span><span class="special">.</span><span class="identifier">cpp</span><span class="special">(</span><span class="number">15</span><span class="special">):</span> <span class="identifier">error</span><span class="special">:</span> <span class="identifier">in</span> <span class="string">"test_op_reportings"</span><span class="special">:</span> <span class="identifier">check</span> <span class="identifier">a</span> <span class="special">==</span> <span class="identifier">b</span> <span class="identifier">has</span> <span class="identifier">failed</span> <span class="special">[</span><span class="number">13</span> <span class="special">!=</span> <span class="number">12</span><span class="special">]</span>
72<span class="identifier">test</span><span class="special">.</span><span class="identifier">cpp</span><span class="special">(</span><span class="number">16</span><span class="special">):</span> <span class="identifier">error</span><span class="special">:</span> <span class="identifier">in</span> <span class="string">"test_op_reportings"</span><span class="special">:</span> <span class="identifier">check</span> <span class="identifier">a</span> <span class="special">&lt;</span> <span class="identifier">b</span> <span class="identifier">has</span> <span class="identifier">failed</span> <span class="special">[</span><span class="number">13</span> <span class="special">&gt;=</span> <span class="number">12</span><span class="special">]</span>
73<span class="identifier">test</span><span class="special">.</span><span class="identifier">cpp</span><span class="special">(</span><span class="number">17</span><span class="special">):</span> <span class="identifier">error</span><span class="special">:</span> <span class="identifier">in</span> <span class="string">"test_op_reportings"</span><span class="special">:</span> <span class="identifier">check</span> <span class="identifier">a</span> <span class="special">-</span> <span class="number">1</span> <span class="special">&lt;</span> <span class="identifier">b</span> <span class="identifier">has</span> <span class="identifier">failed</span> <span class="special">[</span><span class="number">13</span> <span class="special">-</span> <span class="number">1</span> <span class="special">&gt;=</span> <span class="number">12</span><span class="special">]</span>
74<span class="identifier">test</span><span class="special">.</span><span class="identifier">cpp</span><span class="special">(</span><span class="number">18</span><span class="special">):</span> <span class="identifier">error</span><span class="special">:</span> <span class="identifier">in</span> <span class="string">"test_op_reportings"</span><span class="special">:</span> <span class="identifier">check</span> <span class="identifier">b</span> <span class="special">&gt;</span> <span class="identifier">a</span> <span class="special">-</span> <span class="number">1</span> <span class="identifier">has</span> <span class="identifier">failed</span> <span class="special">[</span><span class="number">12</span> <span class="special">&lt;=</span> <span class="number">12</span><span class="special">]</span>
75<span class="identifier">test</span><span class="special">.</span><span class="identifier">cpp</span><span class="special">(</span><span class="number">12</span><span class="special">):</span> <span class="identifier">Leaving</span> <span class="identifier">test</span> <span class="keyword">case</span> <span class="string">"test_op_reportings"</span><span class="special">;</span> <span class="identifier">testing</span> <span class="identifier">time</span><span class="special">:</span> <span class="number">484u</span><span class="identifier">s</span>
76<span class="identifier">Leaving</span> <span class="identifier">test</span> <span class="identifier">module</span> <span class="string">"boost_test_macro3"</span><span class="special">;</span> <span class="identifier">testing</span> <span class="identifier">time</span><span class="special">:</span> <span class="number">588u</span><span class="identifier">s</span>
77
78<span class="special">***</span> <span class="number">2</span> <span class="identifier">failures</span> <span class="identifier">are</span> <span class="identifier">detected</span> <span class="identifier">in</span> <span class="identifier">the</span> <span class="identifier">test</span> <span class="identifier">module</span> <span class="string">"boost_test_macro3"</span>
79</pre>
80              </td></tr></tbody>
81</table></div>
82<p>
83        It was already mentioned that the reporting is not symmetrical (see <a class="link" href="reports.html" title="Reported information">here</a>). An expression is
84        constructed from the <code class="computeroutput"><span class="identifier">statement</span></code>
85        appearing in the <code class="computeroutput"><span class="identifier">BOOST_TEST</span></code>
86        macro. This expression allows evaluation and reporting such as <code class="computeroutput"><span class="string">"13 - 1 &gt;= 12"</span> <span class="identifier">failed</span></code>
87        along with a copy of the <code class="computeroutput"><span class="identifier">statement</span></code>,
88        which contains more details than <code class="computeroutput"><span class="string">"a - 1
89        &lt; b"</span> <span class="identifier">failed</span></code>. In
90        details, what happens is the following:
91      </p>
92<div class="orderedlist"><ol class="orderedlist" type="1">
93<li class="listitem">
94<p class="simpara">
95            a special object, the <code class="computeroutput"><span class="identifier">seed</span></code>
96            of the expression, is composed from the left side of <code class="computeroutput"><span class="identifier">statement</span></code>.
97            This initial composition has highest precedence over the supported operations.
98            The expression below:
99          </p>
100<pre class="programlisting"><span class="identifier">a</span> <span class="identifier">op1</span> <span class="identifier">b</span> <span class="identifier">op2</span> <span class="identifier">c</span> <span class="identifier">op3</span> <span class="identifier">d</span>
101</pre>
102<p class="simpara">
103            is actually seen as
104          </p>
105<pre class="programlisting"><span class="special">(</span> <span class="identifier">seed</span> <span class="identifier">a</span> <span class="special">)</span> <span class="identifier">op1</span> <span class="identifier">b</span> <span class="identifier">op2</span> <span class="identifier">c</span> <span class="identifier">op3</span> <span class="identifier">d</span>
106</pre>
107</li>
108<li class="listitem">
109<p class="simpara">
110            The "<code class="computeroutput"><span class="identifier">seed</span> <span class="identifier">a</span></code>"
111            returns an <code class="computeroutput"><span class="identifier">expression</span></code>
112            object that keep tracks of the type of <code class="computeroutput"><span class="identifier">a</span></code>.
113            This expression has overloads for left-to-right associativity, and the
114            operations <code class="computeroutput"><span class="identifier">op1</span></code>, <code class="computeroutput"><span class="identifier">op2</span></code> ... are <span class="emphasis"><em>chained</em></span>
115            to the right of this expression object:
116          </p>
117<pre class="programlisting"><span class="identifier">a</span> <span class="identifier">op1</span> <span class="identifier">b</span>
118</pre>
119<p class="simpara">
120            yields to the pseudo-code
121          </p>
122<pre class="programlisting"><span class="identifier">expression1</span> <span class="special">=</span> <span class="identifier">create</span><span class="special">-</span><span class="identifier">expression</span><span class="special">(</span><span class="identifier">a</span><span class="special">)</span>
123<span class="identifier">expression2</span> <span class="special">=</span> <span class="identifier">create</span><span class="special">-</span><span class="identifier">expression</span><span class="special">(</span><span class="identifier">expression1</span><span class="special">,</span> <span class="identifier">op1</span><span class="special">,</span> <span class="identifier">b</span><span class="special">)</span>
124</pre>
125<p class="simpara">
126            <code class="computeroutput"><span class="identifier">expression1</span></code> and <code class="computeroutput"><span class="identifier">expression2</span></code> keep track of their left
127            and right operands, and the operation on those operands. The expressions
128            keep also track of the result type of the associated sub-expression.
129            In the above example, <code class="computeroutput"><span class="identifier">expression1</span></code>
130            and <code class="computeroutput"><span class="identifier">expression2</span></code> have
131            result type <code class="computeroutput"><span class="keyword">decltype</span><span class="special">(</span><span class="identifier">a</span><span class="special">)</span></code>
132            and <code class="computeroutput"><span class="keyword">decltype</span><span class="special">(</span><span class="identifier">a</span> <span class="identifier">op1</span>
133            <span class="identifier">b</span><span class="special">)</span></code>
134            respectively. The result type allows for chaining sub-expressions.
135          </p>
136</li>
137<li class="listitem">
138<p class="simpara">
139            The C++ operators precedence rules apply in any case. What is seen by
140            the expression is what is reachable with left-to-right composition. Any
141            other operation that happens before it reaches the expression's right
142            operand is not parsed as a sub-expression and is seen as a single operand:
143            the right operand is not developed further by the framework. Let's suppose
144            <code class="computeroutput"><span class="identifier">op2</span></code> below has higher
145            precedence than <code class="computeroutput"><span class="identifier">op1</span></code>,
146            then
147          </p>
148<pre class="programlisting"><span class="identifier">a</span> <span class="identifier">op1</span> <span class="identifier">b</span> <span class="identifier">op2</span> <span class="identifier">c</span>
149</pre>
150<p class="simpara">
151            is equivalent to:
152          </p>
153<pre class="programlisting"><span class="identifier">create</span><span class="special">-</span><span class="identifier">expression</span><span class="special">(</span><span class="identifier">create</span><span class="special">-</span><span class="identifier">expression</span><span class="special">(</span><span class="identifier">a</span><span class="special">),</span> <span class="identifier">op1</span><span class="special">,</span> <span class="special">(</span><span class="identifier">b</span> <span class="identifier">op2</span> <span class="identifier">c</span><span class="special">))</span>
154</pre>
155<p class="simpara">
156            In the above statement, the final expression can only see the result
157            of <code class="computeroutput"><span class="special">(</span><span class="identifier">b</span>
158            <span class="identifier">op2</span> <span class="identifier">c</span><span class="special">)</span></code> to its right, for which no further detail
159            can be provided in the logs. This is also the case for <span class="emphasis"><em>right-to-left</em></span>
160            associative operators, such as <code class="computeroutput"><span class="special">!</span></code>,
161            <code class="computeroutput"><span class="special">~</span></code>, <code class="computeroutput"><span class="special">-</span></code>
162            (unary negation) etc.
163          </p>
164<div class="caution"><table border="0" summary="Caution">
165<tr>
166<td rowspan="2" align="center" valign="top" width="25"><img alt="[Caution]" src="../../../../../../doc/src/images/caution.png"></td>
167<th align="left">Caution</th>
168</tr>
169<tr><td align="left" valign="top"><p>
170              Since the <code class="computeroutput"><span class="identifier">expression</span></code>
171              object is composed from left-to-right, it actually observes a chain
172              of operations and not the full expression tree.
173            </p></td></tr>
174</table></div>
175</li>
176<li class="listitem">
177<p class="simpara">
178            Once the full expression chain is built, it is evaluated as a chain of
179            sub-expressions from left-to-right, exactly as the composition rule above.
180            The evaluated elements are the ones of the expression itself. The expression
181          </p>
182<pre class="programlisting"><span class="identifier">a</span> <span class="identifier">op1</span> <span class="identifier">b</span>
183</pre>
184<p class="simpara">
185            yields to the following evaluation chain:
186          </p>
187<pre class="programlisting"><span class="identifier">expression2</span><span class="special">.</span><span class="identifier">result</span> <span class="special">=</span> <span class="identifier">expression1</span><span class="special">.</span><span class="identifier">result</span> <span class="identifier">op1</span> <span class="identifier">b</span>
188<span class="identifier">expression1</span><span class="special">.</span><span class="identifier">result</span> <span class="special">=</span> <span class="identifier">a</span>
189</pre>
190<p class="simpara">
191            The final expression of the statement is cast to a boolean, which is
192            in turn evaluated by the <span class="emphasis"><em>Unit Test Framework</em></span>.
193          </p>
194</li>
195</ol></div>
196<p>
197        The example below illustrates the construction of the left-to-right <span class="emphasis"><em>chained</em></span>
198        expression.
199      </p>
200<h6>
201<a name="boost_test.testing_tools.internal_details.h1"></a>
202        <span class="phrase"><a name="boost_test.testing_tools.internal_details.example_descr0"></a></span><a class="link" href="internal_details.html#boost_test.testing_tools.internal_details.example_descr0">Example:
203        BOOST_TEST compound statements</a>
204      </h6>
205<div class="informaltable"><table class="table">
206<colgroup><col></colgroup>
207<thead><tr><th>
208                <p>
209                  Code
210                </p>
211              </th></tr></thead>
212<tbody><tr><td>
213<pre xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" class="table-programlisting"><span class="preprocessor">#define</span> <span class="identifier">BOOST_TEST_MODULE</span> <span class="identifier">boost_test_macro2</span>
214<span class="preprocessor">#include</span> <span class="special">&lt;</span><span class="identifier">boost</span><span class="special">/</span><span class="identifier">test</span><span class="special">/</span><span class="identifier">included</span><span class="special">/</span><span class="identifier">unit_test</span><span class="special">.</span><span class="identifier">hpp</span><span class="special">&gt;</span>
215
216<span class="identifier">BOOST_AUTO_TEST_CASE</span><span class="special">(</span> <span class="identifier">test_op_precedence</span> <span class="special">)</span>
217<span class="special">{</span>
218  <span class="keyword">int</span> <span class="identifier">a</span> <span class="special">=</span> <span class="number">13</span><span class="special">,</span> <span class="identifier">b</span> <span class="special">=</span> <span class="number">2</span><span class="special">,</span> <span class="identifier">c</span> <span class="special">=</span> <span class="number">12</span><span class="special">;</span>
219  <span class="comment">// left term of == is expanded in the logs</span>
220  <span class="identifier">BOOST_TEST</span><span class="special">(</span><span class="identifier">a</span> <span class="special">%</span> <span class="identifier">b</span> <span class="special">==</span> <span class="identifier">c</span><span class="special">);</span>
221  <span class="comment">// right term of == is not expanded in the logs</span>
222  <span class="identifier">BOOST_TEST</span><span class="special">(</span><span class="identifier">a</span> <span class="special">==</span> <span class="identifier">c</span> <span class="special">%</span> <span class="identifier">b</span><span class="special">);</span>
223<span class="special">}</span>
224
225<span class="identifier">BOOST_AUTO_TEST_CASE</span><span class="special">(</span> <span class="identifier">test_op_right_associative</span> <span class="special">)</span>
226<span class="special">{</span>
227  <span class="keyword">int</span> <span class="identifier">a</span> <span class="special">=</span> <span class="number">1</span><span class="special">;</span>
228  <span class="identifier">BOOST_TEST</span><span class="special">(</span><span class="identifier">a</span><span class="special">);</span>
229  <span class="identifier">BOOST_TEST</span><span class="special">(!</span><span class="identifier">a</span><span class="special">);</span>
230  <span class="identifier">BOOST_TEST</span><span class="special">(--</span><span class="identifier">a</span><span class="special">);</span>
231<span class="special">}</span>
232</pre>
233              </td></tr></tbody>
234</table></div>
235<div class="informaltable"><table class="table">
236<colgroup><col></colgroup>
237<thead><tr><th>
238                <p>
239                  Output
240                </p>
241              </th></tr></thead>
242<tbody><tr><td>
243<pre xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" class="table-programlisting"><span class="special">&gt;</span> <span class="special">./</span><span class="identifier">boost_test_macro2</span> <span class="special">--</span><span class="identifier">log_level</span><span class="special">=</span><span class="identifier">all</span>
244<span class="identifier">Running</span> <span class="number">2</span> <span class="identifier">test</span> <span class="identifier">cases</span><span class="special">...</span>
245<span class="identifier">test</span><span class="special">.</span><span class="identifier">cpp</span><span class="special">(</span><span class="number">16</span><span class="special">):</span> <span class="identifier">error</span><span class="special">:</span> <span class="identifier">in</span> <span class="string">"test_op_precedence"</span><span class="special">:</span> <span class="identifier">check</span> <span class="identifier">a</span> <span class="special">%</span> <span class="identifier">b</span> <span class="special">==</span> <span class="identifier">c</span> <span class="identifier">has</span> <span class="identifier">failed</span> <span class="special">[</span><span class="number">13</span> <span class="special">%</span> <span class="number">2</span> <span class="special">!=</span> <span class="number">12</span><span class="special">]</span>
246<span class="identifier">test</span><span class="special">.</span><span class="identifier">cpp</span><span class="special">(</span><span class="number">18</span><span class="special">):</span> <span class="identifier">error</span><span class="special">:</span> <span class="identifier">in</span> <span class="string">"test_op_precedence"</span><span class="special">:</span> <span class="identifier">check</span> <span class="identifier">a</span> <span class="special">==</span> <span class="identifier">c</span> <span class="special">%</span> <span class="identifier">b</span> <span class="identifier">has</span> <span class="identifier">failed</span> <span class="special">[</span><span class="number">13</span> <span class="special">!=</span> <span class="number">0</span><span class="special">]</span>
247<span class="identifier">test</span><span class="special">.</span><span class="identifier">cpp</span><span class="special">(</span><span class="number">25</span><span class="special">):</span> <span class="identifier">error</span><span class="special">:</span> <span class="identifier">in</span> <span class="string">"test_op_right_associative"</span><span class="special">:</span> <span class="identifier">check</span> <span class="special">!</span><span class="identifier">a</span> <span class="identifier">has</span> <span class="identifier">failed</span>
248<span class="identifier">test</span><span class="special">.</span><span class="identifier">cpp</span><span class="special">(</span><span class="number">26</span><span class="special">):</span> <span class="identifier">error</span><span class="special">:</span> <span class="identifier">in</span> <span class="string">"test_op_right_associative"</span><span class="special">:</span> <span class="identifier">check</span> <span class="special">--</span><span class="identifier">a</span> <span class="identifier">has</span> <span class="identifier">failed</span> <span class="special">[(</span><span class="keyword">bool</span><span class="special">)</span><span class="number">0</span> <span class="identifier">is</span> <span class="keyword">false</span><span class="special">]</span>
249
250<span class="special">***</span> <span class="number">4</span> <span class="identifier">failures</span> <span class="identifier">are</span> <span class="identifier">detected</span> <span class="identifier">in</span> <span class="identifier">the</span> <span class="identifier">test</span> <span class="identifier">module</span> <span class="string">"boost_test_macro2"</span>
251</pre>
252              </td></tr></tbody>
253</table></div>
254</div>
255<table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr>
256<td align="left"></td>
257<td align="right"><div class="copyright-footer">Copyright © 2001-2020 Boost.Test contributors<p>
258        Distributed under the Boost Software License, Version 1.0. (See accompanying
259        file LICENSE_1_0.txt or copy at <a href="http://www.boost.org/LICENSE_1_0.txt" target="_top">http://www.boost.org/LICENSE_1_0.txt</a>)
260      </p>
261</div></td>
262</tr></table>
263<hr>
264<div class="spirit-nav">
265<a accesskey="p" href="output_stream_testing.html"><img src="../../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../testing_tools.html"><img src="../../../../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../../index.html"><img src="../../../../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="debugging.html"><img src="../../../../../../doc/src/images/next.png" alt="Next"></a>
266</div>
267</body>
268</html>
269