Imported Upstream version 1.72.0
[platform/upstream/boost.git] / libs / contract / doc / html / boost / contract / virtual_.html
1 <html>
2 <head>
3 <meta http-equiv="Content-Type" content="text/html; charset=US-ASCII">
4 <title>Class virtual_</title>
5 <link rel="stylesheet" href="../../../../../../doc/src/boostbook.css" type="text/css">
6 <meta name="generator" content="DocBook XSL Stylesheets V1.79.1">
7 <link rel="home" href="../../index.html" title="Chapter&#160;1.&#160;Boost.Contract 1.0.0">
8 <link rel="up" href="../../reference.html#header.boost.contract.core.virtual_hpp" title="Header &lt;boost/contract/core/virtual.hpp&gt;">
9 <link rel="prev" href="specify__idm45394999179040.html" title="Class template specify_precondition_old_postcondition_except">
10 <link rel="next" href="destructor.html" title="Function template destructor">
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="specify__idm45394999179040.html"><img src="../../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../../reference.html#header.boost.contract.core.virtual_hpp"><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="destructor.html"><img src="../../../../../../doc/src/images/next.png" alt="Next"></a>
24 </div>
25 <div class="refentry">
26 <a name="boost.contract.virtual_"></a><div class="titlepage"></div>
27 <div class="refnamediv">
28 <h2><span class="refentrytitle">Class virtual_</span></h2>
29 <p>boost::contract::virtual_ &#8212; Type of extra function parameter to handle contracts for virtual public functions (for subcontracting). </p>
30 </div>
31 <h2 xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" class="refsynopsisdiv-title">Synopsis</h2>
32 <div xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" class="refsynopsisdiv"><pre class="synopsis"><span class="comment">// In header: &lt;<a class="link" href="../../reference.html#header.boost.contract.core.virtual_hpp" title="Header &lt;boost/contract/core/virtual.hpp&gt;">boost/contract/core/virtual.hpp</a>&gt;
33
34 </span>
35 <span class="keyword">class</span> <a class="link" href="virtual_.html" title="Class virtual_">virtual_</a> <span class="special">{</span>
36 <span class="special">}</span><span class="special">;</span></pre></div>
37 <div class="refsect1">
38 <a name="idm45707995083200"></a><h2>Description</h2>
39 <p>Virtual public functions (and therefore also public function overrides) declaring contracts using this library must specify an extra function parameter at the very end of their parameter list. This parameter must be a pointer to this class and it must have default value <code class="computeroutput">0</code> or <code class="computeroutput">nullptr</code> (this extra parameter is often named <code class="computeroutput">v</code> in this documentation, but any name can be used):</p>
40 <pre class="programlisting"><span class="keyword">class</span> <span class="identifier">u</span> <span class="special">{</span>
41 <span class="keyword">public</span><span class="special">:</span>
42     <span class="keyword">virtual</span> <span class="keyword">void</span> <span class="identifier">f</span><span class="special">(</span><span class="keyword">int</span> <span class="identifier">x</span><span class="special">,</span> <span class="identifier">boost</span><span class="special">::</span><span class="identifier">contract</span><span class="special">::</span><span class="identifier">virtual_</span><span class="special">*</span> <span class="identifier">v</span> <span class="special">=</span> <span class="number">0</span><span class="special">)</span> <span class="special">{</span> <span class="comment">// Declare `v`.</span>
43         <span class="special">...</span> <span class="comment">// Contract declaration (which will use `v`) and function body.</span>
44     <span class="special">}</span>
45
46     <span class="special">...</span>
47 <span class="special">}</span><span class="special">;</span>
48 </pre>
49 <p>In practice this extra parameter does not alter the calling interface of the enclosing function declaring the contract because it is always the very last parameter and it has a default value (so it can always be omitted when users call the function). This extra parameter must be passed to  <code class="computeroutput"><a class="link" href="public_f_idm45394998885120.html" title="Function template public_function">boost::contract::public_function</a></code>, <code class="computeroutput"><a class="link" href="../../BOOST_CONTRACT_OLDOF.html" title="Macro BOOST_CONTRACT_OLDOF">BOOST_CONTRACT_OLDOF</a></code>, and all other operations of this library that accept a pointer to  <code class="computeroutput"><a class="link" href="virtual_.html" title="Class virtual_">boost::contract::virtual_</a></code>. A part from that, this class is not intended to be directly used by programmers (and that is why this class does not have any public member and it is not copyable).</p>
50 <p><span class="bold"><strong>See Also:</strong></span></p>
51 <p> <a class="link" href="../../boost_contract/tutorial.html#boost_contract.tutorial.virtual_public_functions" title="Virtual Public Functions"> Virtual Public Functions</a>,  <a class="link" href="../../boost_contract/tutorial.html#boost_contract.tutorial.public_function_overrides__subcontracting_" title="Public Function Overrides (Subcontracting)">
52         Public Function Overrides</a> </p>
53 <p>
54 </p>
55 <p>
56 </p>
57 </div>
58 </div>
59 <table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr>
60 <td align="left"></td>
61 <td align="right"><div class="copyright-footer">Copyright &#169; 2008-2019 Lorenzo Caminiti<p>
62         Distributed under the Boost Software License, Version 1.0 (see accompanying
63         file LICENSE_1_0.txt or a copy at <a href="http://www.boost.org/LICENSE_1_0.txt" target="_top">http://www.boost.org/LICENSE_1_0.txt</a>)
64       </p>
65 </div></td>
66 </tr></table>
67 <hr>
68 <div class="spirit-nav">
69 <a accesskey="p" href="specify__idm45394999179040.html"><img src="../../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../../reference.html#header.boost.contract.core.virtual_hpp"><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="destructor.html"><img src="../../../../../../doc/src/images/next.png" alt="Next"></a>
70 </div>
71 </body>
72 </html>