| 1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> | 
|---|
| 2 | <html xmlns="http://www.w3.org/1999/xhtml"> | 
|---|
| 3 | <head> | 
|---|
| 4 | <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> | 
|---|
| 5 | <title>mixpp: bdm::shared_ptr< T > Class Template Reference</title> | 
|---|
| 6 | <link href="tabs.css" rel="stylesheet" type="text/css"/> | 
|---|
| 7 | <link href="doxygen.css" rel="stylesheet" type="text/css"/> | 
|---|
| 8 | </head> | 
|---|
| 9 | <body> | 
|---|
| 10 | <!-- Generated by Doxygen 1.6.1 --> | 
|---|
| 11 | <script type="text/javascript"> | 
|---|
| 12 | <!-- | 
|---|
| 13 | function changeDisplayState (e){ | 
|---|
| 14 | var num=this.id.replace(/[^[0-9]/g,''); | 
|---|
| 15 | var button=this.firstChild; | 
|---|
| 16 | var sectionDiv=document.getElementById('dynsection'+num); | 
|---|
| 17 | if (sectionDiv.style.display=='none'||sectionDiv.style.display==''){ | 
|---|
| 18 | sectionDiv.style.display='block'; | 
|---|
| 19 | button.src='open.gif'; | 
|---|
| 20 | }else{ | 
|---|
| 21 | sectionDiv.style.display='none'; | 
|---|
| 22 | button.src='closed.gif'; | 
|---|
| 23 | } | 
|---|
| 24 | } | 
|---|
| 25 | function initDynSections(){ | 
|---|
| 26 | var divs=document.getElementsByTagName('div'); | 
|---|
| 27 | var sectionCounter=1; | 
|---|
| 28 | for(var i=0;i<divs.length-1;i++){ | 
|---|
| 29 | if(divs[i].className=='dynheader'&&divs[i+1].className=='dynsection'){ | 
|---|
| 30 | var header=divs[i]; | 
|---|
| 31 | var section=divs[i+1]; | 
|---|
| 32 | var button=header.firstChild; | 
|---|
| 33 | if (button!='IMG'){ | 
|---|
| 34 | divs[i].insertBefore(document.createTextNode(' '),divs[i].firstChild); | 
|---|
| 35 | button=document.createElement('img'); | 
|---|
| 36 | divs[i].insertBefore(button,divs[i].firstChild); | 
|---|
| 37 | } | 
|---|
| 38 | header.style.cursor='pointer'; | 
|---|
| 39 | header.onclick=changeDisplayState; | 
|---|
| 40 | header.id='dynheader'+sectionCounter; | 
|---|
| 41 | button.src='closed.gif'; | 
|---|
| 42 | section.id='dynsection'+sectionCounter; | 
|---|
| 43 | section.style.display='none'; | 
|---|
| 44 | section.style.marginLeft='14px'; | 
|---|
| 45 | sectionCounter++; | 
|---|
| 46 | } | 
|---|
| 47 | } | 
|---|
| 48 | } | 
|---|
| 49 | window.onload = initDynSections; | 
|---|
| 50 | --> | 
|---|
| 51 | </script> | 
|---|
| 52 | <div class="navigation" id="top"> | 
|---|
| 53 | <div class="tabs"> | 
|---|
| 54 | <ul> | 
|---|
| 55 | <li><a href="main.html"><span>Main Page</span></a></li> | 
|---|
| 56 | <li><a href="pages.html"><span>Related Pages</span></a></li> | 
|---|
| 57 | <li class="current"><a href="annotated.html"><span>Classes</span></a></li> | 
|---|
| 58 | <li><a href="files.html"><span>Files</span></a></li> | 
|---|
| 59 | </ul> | 
|---|
| 60 | </div> | 
|---|
| 61 | <div class="tabs"> | 
|---|
| 62 | <ul> | 
|---|
| 63 | <li><a href="annotated.html"><span>Class List</span></a></li> | 
|---|
| 64 | <li><a href="classes.html"><span>Class Index</span></a></li> | 
|---|
| 65 | <li><a href="hierarchy.html"><span>Class Hierarchy</span></a></li> | 
|---|
| 66 | <li><a href="functions.html"><span>Class Members</span></a></li> | 
|---|
| 67 | </ul> | 
|---|
| 68 | </div> | 
|---|
| 69 | <div class="navpath"><b>bdm</b>::<a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a> | 
|---|
| 70 | </div> | 
|---|
| 71 | </div> | 
|---|
| 72 | <div class="contents"> | 
|---|
| 73 | <h1>bdm::shared_ptr< T > Class Template Reference</h1><!-- doxytag: class="bdm::shared_ptr" --> | 
|---|
| 74 | <p>A naive implementation of roughly a subset of the std::tr1::shared_ptr spec. | 
|---|
| 75 | <a href="#_details">More...</a></p> | 
|---|
| 76 | <hr/><a name="_details"></a><h2>Detailed Description</h2> | 
|---|
| 77 | <h3>template<typename T><br/> | 
|---|
| 78 | class bdm::shared_ptr< T ></h3> | 
|---|
| 79 |  | 
|---|
| 80 | <p>A naive implementation of roughly a subset of the std::tr1::shared_ptr spec. </p> | 
|---|
| 81 | <p>Really just roughly - it ignores memory exceptions, for example; also note I didn't read the spec.</p> | 
|---|
| 82 | <p>The standard template would naturally be preferable, <b>if</b> it was included in the standard libraries of all supported compilers - but as of 2009, that's still a problem... </p> | 
|---|
| 83 |  | 
|---|
| 84 | <p><code>#include <<a class="el" href="shared__ptr_8h_source.html">shared_ptr.h</a>></code></p> | 
|---|
| 85 |  | 
|---|
| 86 | <p><a href="classbdm_1_1shared__ptr-members.html">List of all members.</a></p> | 
|---|
| 87 | <table border="0" cellpadding="0" cellspacing="0"> | 
|---|
| 88 | <tr><td colspan="2"><h2>Public Member Functions</h2></td></tr> | 
|---|
| 89 | <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#a66a4d41031e37618f1a9bb3c81814c11">shared_ptr</a> ()</td></tr> | 
|---|
| 90 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Default constructor.  <a href="#a66a4d41031e37618f1a9bb3c81814c11"></a><br/></td></tr> | 
|---|
| 91 | <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#ac8b7f0a813173581530c80d7ac4fc7c2">shared_ptr</a> (T *p)</td></tr> | 
|---|
| 92 | <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#a357702d12bfd608a08b46e4a194aa4b5">shared_ptr</a> (const <a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a>< T > &other)</td></tr> | 
|---|
| 93 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Copy constructor.  <a href="#a357702d12bfd608a08b46e4a194aa4b5"></a><br/></td></tr> | 
|---|
| 94 | <tr><td class="memTemplParams" colspan="2">template<typename U > </td></tr> | 
|---|
| 95 | <tr><td class="memTemplItemLeft" align="right" valign="top"> </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#aaffa5b17385493f4102c52cf75d3b509">shared_ptr</a> (const <a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a>< U > &other)</td></tr> | 
|---|
| 96 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Generalized copy.  <a href="#aaffa5b17385493f4102c52cf75d3b509"></a><br/></td></tr> | 
|---|
| 97 | <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#a79374842e417d2f64e449e374be4cfc1">~shared_ptr</a> ()</td></tr> | 
|---|
| 98 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a55263b1c8efbd3f8fddf703e2c457f6c"></a><!-- doxytag: member="bdm::shared_ptr::operator=" ref="a55263b1c8efbd3f8fddf703e2c457f6c" args="(const shared_ptr< T > &other)" --> | 
|---|
| 99 | <a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a>< T > & </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#a55263b1c8efbd3f8fddf703e2c457f6c">operator=</a> (const <a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a>< T > &other)</td></tr> | 
|---|
| 100 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Assignment operator. <br/></td></tr> | 
|---|
| 101 | <tr><td class="memItemLeft" align="right" valign="top">T * </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#a37ebcfb6750dd7b5630f1d2354c07a96">get</a> ()</td></tr> | 
|---|
| 102 | <tr><td class="memItemLeft" align="right" valign="top">T * </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#abcaae812868eacbad050beda465d2327">operator-></a> ()</td></tr> | 
|---|
| 103 | <tr><td class="memItemLeft" align="right" valign="top">T & </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#ade38de837267becf5eed2839fea42c45">operator*</a> ()</td></tr> | 
|---|
| 104 | <tr><td class="memItemLeft" align="right" valign="top">const T * </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#afff45e4841b2921cd42ce0691f8c1196">get</a> () const </td></tr> | 
|---|
| 105 | <tr><td class="memItemLeft" align="right" valign="top">const T * </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#ad89ec7ceb318241d833c7d278444396d">operator-></a> () const </td></tr> | 
|---|
| 106 | <tr><td class="memItemLeft" align="right" valign="top">const T & </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#ade000a72fe73804aa26962432f264800">operator*</a> () const </td></tr> | 
|---|
| 107 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a338dbc6aa9fd95175abdc2df3ae2c284"></a><!-- doxytag: member="bdm::shared_ptr::unique" ref="a338dbc6aa9fd95175abdc2df3ae2c284" args="() const " --> | 
|---|
| 108 | bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#a338dbc6aa9fd95175abdc2df3ae2c284">unique</a> () const </td></tr> | 
|---|
| 109 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Returns <a class="el" href="classbdm_1_1shared__ptr.html#a8e52b8887a4408c52b5263a5717343f2">use_count()</a> == 1. <br/></td></tr> | 
|---|
| 110 | <tr><td class="memItemLeft" align="right" valign="top">long </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#a8e52b8887a4408c52b5263a5717343f2">use_count</a> () const </td></tr> | 
|---|
| 111 | <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#a6cac71bb600f9f7c6fbed9335fd22d37">operator bool</a> () const </td></tr> | 
|---|
| 112 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Boolean cast.  <a href="#a6cac71bb600f9f7c6fbed9335fd22d37"></a><br/></td></tr> | 
|---|
| 113 | <tr><td class="memTemplParams" colspan="2">template<typename U > </td></tr> | 
|---|
| 114 | <tr><td class="memTemplItemLeft" align="right" valign="top"> </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#ab3cd369b00369ab92456aa0645e8d560">operator shared_ptr< const U ></a> () const </td></tr> | 
|---|
| 115 | <tr><td class="mdescLeft"> </td><td class="mdescRight">const cast  <a href="#ab3cd369b00369ab92456aa0645e8d560"></a><br/></td></tr> | 
|---|
| 116 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="afca7fd588f8de50e7590357305b00984"></a><!-- doxytag: member="bdm::shared_ptr::swap" ref="afca7fd588f8de50e7590357305b00984" args="(shared_ptr &other)" --> | 
|---|
| 117 | void </td><td class="memItemRight" valign="bottom"><a class="el" href="classbdm_1_1shared__ptr.html#afca7fd588f8de50e7590357305b00984">swap</a> (<a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a> &other)</td></tr> | 
|---|
| 118 | <tr><td class="mdescLeft"> </td><td class="mdescRight">Efficient swap for <a class="el" href="classbdm_1_1shared__ptr.html" title="A naive implementation of roughly a subset of the std::tr1::shared_ptr spec.">shared_ptr</a>. <br/></td></tr> | 
|---|
| 119 | <tr><td colspan="2"><h2>Friends</h2></td></tr> | 
|---|
| 120 | <tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a9a4da829475f0cf1809fc6ef555ffe06"></a><!-- doxytag: member="bdm::shared_ptr::shared_ptr" ref="a9a4da829475f0cf1809fc6ef555ffe06" args="" --> | 
|---|
| 121 | class </td><td class="memItemRight" valign="bottom"><b>shared_ptr</b></td></tr> | 
|---|
| 122 | </table> | 
|---|
| 123 | <hr/><h2>Constructor & Destructor Documentation</h2> | 
|---|
| 124 | <a class="anchor" id="a66a4d41031e37618f1a9bb3c81814c11"></a><!-- doxytag: member="bdm::shared_ptr::shared_ptr" ref="a66a4d41031e37618f1a9bb3c81814c11" args="()" --> | 
|---|
| 125 | <div class="memitem"> | 
|---|
| 126 | <div class="memproto"> | 
|---|
| 127 | <div class="memtemplate"> | 
|---|
| 128 | template<typename T> </div> | 
|---|
| 129 | <table class="memname"> | 
|---|
| 130 | <tr> | 
|---|
| 131 | <td class="memname"><a class="el" href="classbdm_1_1shared__ptr.html">bdm::shared_ptr</a>< T >::<a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a> </td> | 
|---|
| 132 | <td>(</td> | 
|---|
| 133 | <td class="paramname"></td> | 
|---|
| 134 | <td> ) </td> | 
|---|
| 135 | <td><code> [inline]</code></td> | 
|---|
| 136 | </tr> | 
|---|
| 137 | </table> | 
|---|
| 138 | </div> | 
|---|
| 139 | <div class="memdoc"> | 
|---|
| 140 |  | 
|---|
| 141 | <p>Default constructor. </p> | 
|---|
| 142 | <p>Creates an empty <a class="el" href="classbdm_1_1shared__ptr.html" title="A naive implementation of roughly a subset of the std::tr1::shared_ptr spec.">shared_ptr</a> - one that doesn't point anywhere. </p> | 
|---|
| 143 |  | 
|---|
| 144 | </div> | 
|---|
| 145 | </div> | 
|---|
| 146 | <a class="anchor" id="ac8b7f0a813173581530c80d7ac4fc7c2"></a><!-- doxytag: member="bdm::shared_ptr::shared_ptr" ref="ac8b7f0a813173581530c80d7ac4fc7c2" args="(T *p)" --> | 
|---|
| 147 | <div class="memitem"> | 
|---|
| 148 | <div class="memproto"> | 
|---|
| 149 | <div class="memtemplate"> | 
|---|
| 150 | template<typename T> </div> | 
|---|
| 151 | <table class="memname"> | 
|---|
| 152 | <tr> | 
|---|
| 153 | <td class="memname"><a class="el" href="classbdm_1_1shared__ptr.html">bdm::shared_ptr</a>< T >::<a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a> </td> | 
|---|
| 154 | <td>(</td> | 
|---|
| 155 | <td class="paramtype">T * </td> | 
|---|
| 156 | <td class="paramname"> <em>p</em></td> | 
|---|
| 157 | <td> ) </td> | 
|---|
| 158 | <td><code> [inline]</code></td> | 
|---|
| 159 | </tr> | 
|---|
| 160 | </table> | 
|---|
| 161 | </div> | 
|---|
| 162 | <div class="memdoc"> | 
|---|
| 163 | <p>Constructs a <a class="el" href="classbdm_1_1shared__ptr.html" title="A naive implementation of roughly a subset of the std::tr1::shared_ptr spec.">shared_ptr</a> that owns the pointer p (unless p is NULL, in which case this constructor creates an empty <a class="el" href="classbdm_1_1shared__ptr.html" title="A naive implementation of roughly a subset of the std::tr1::shared_ptr spec.">shared_ptr</a>). When p isn't null, it must have been alllocated by new! </p> | 
|---|
| 164 |  | 
|---|
| 165 | </div> | 
|---|
| 166 | </div> | 
|---|
| 167 | <a class="anchor" id="a357702d12bfd608a08b46e4a194aa4b5"></a><!-- doxytag: member="bdm::shared_ptr::shared_ptr" ref="a357702d12bfd608a08b46e4a194aa4b5" args="(const shared_ptr< T > &other)" --> | 
|---|
| 168 | <div class="memitem"> | 
|---|
| 169 | <div class="memproto"> | 
|---|
| 170 | <div class="memtemplate"> | 
|---|
| 171 | template<typename T> </div> | 
|---|
| 172 | <table class="memname"> | 
|---|
| 173 | <tr> | 
|---|
| 174 | <td class="memname"><a class="el" href="classbdm_1_1shared__ptr.html">bdm::shared_ptr</a>< T >::<a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a> </td> | 
|---|
| 175 | <td>(</td> | 
|---|
| 176 | <td class="paramtype">const <a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a>< T > & </td> | 
|---|
| 177 | <td class="paramname"> <em>other</em></td> | 
|---|
| 178 | <td> ) </td> | 
|---|
| 179 | <td><code> [inline]</code></td> | 
|---|
| 180 | </tr> | 
|---|
| 181 | </table> | 
|---|
| 182 | </div> | 
|---|
| 183 | <div class="memdoc"> | 
|---|
| 184 |  | 
|---|
| 185 | <p>Copy constructor. </p> | 
|---|
| 186 | <p>If other is empty, constructs an empty <a class="el" href="classbdm_1_1shared__ptr.html" title="A naive implementation of roughly a subset of the std::tr1::shared_ptr spec.">shared_ptr</a>; otherwise, constructs a <a class="el" href="classbdm_1_1shared__ptr.html" title="A naive implementation of roughly a subset of the std::tr1::shared_ptr spec.">shared_ptr</a> that shares ownership with other. </p> | 
|---|
| 187 |  | 
|---|
| 188 | </div> | 
|---|
| 189 | </div> | 
|---|
| 190 | <a class="anchor" id="aaffa5b17385493f4102c52cf75d3b509"></a><!-- doxytag: member="bdm::shared_ptr::shared_ptr" ref="aaffa5b17385493f4102c52cf75d3b509" args="(const shared_ptr< U > &other)" --> | 
|---|
| 191 | <div class="memitem"> | 
|---|
| 192 | <div class="memproto"> | 
|---|
| 193 | <div class="memtemplate"> | 
|---|
| 194 | template<typename T> </div> | 
|---|
| 195 | <div class="memtemplate"> | 
|---|
| 196 | template<typename U > </div> | 
|---|
| 197 | <table class="memname"> | 
|---|
| 198 | <tr> | 
|---|
| 199 | <td class="memname"><a class="el" href="classbdm_1_1shared__ptr.html">bdm::shared_ptr</a>< T >::<a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a> </td> | 
|---|
| 200 | <td>(</td> | 
|---|
| 201 | <td class="paramtype">const <a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a>< U > & </td> | 
|---|
| 202 | <td class="paramname"> <em>other</em></td> | 
|---|
| 203 | <td> ) </td> | 
|---|
| 204 | <td><code> [inline]</code></td> | 
|---|
| 205 | </tr> | 
|---|
| 206 | </table> | 
|---|
| 207 | </div> | 
|---|
| 208 | <div class="memdoc"> | 
|---|
| 209 |  | 
|---|
| 210 | <p>Generalized copy. </p> | 
|---|
| 211 | <p>Allows initialization of shared pointer of a base type from raw pointer to a derived type.</p> | 
|---|
| 212 | <p>If other is empty, constructs an empty <a class="el" href="classbdm_1_1shared__ptr.html" title="A naive implementation of roughly a subset of the std::tr1::shared_ptr spec.">shared_ptr</a>; otherwise, constructs a <a class="el" href="classbdm_1_1shared__ptr.html" title="A naive implementation of roughly a subset of the std::tr1::shared_ptr spec.">shared_ptr</a> that shares ownership with other. </p> | 
|---|
| 213 |  | 
|---|
| 214 | </div> | 
|---|
| 215 | </div> | 
|---|
| 216 | <a class="anchor" id="a79374842e417d2f64e449e374be4cfc1"></a><!-- doxytag: member="bdm::shared_ptr::~shared_ptr" ref="a79374842e417d2f64e449e374be4cfc1" args="()" --> | 
|---|
| 217 | <div class="memitem"> | 
|---|
| 218 | <div class="memproto"> | 
|---|
| 219 | <div class="memtemplate"> | 
|---|
| 220 | template<typename T> </div> | 
|---|
| 221 | <table class="memname"> | 
|---|
| 222 | <tr> | 
|---|
| 223 | <td class="memname"><a class="el" href="classbdm_1_1shared__ptr.html">bdm::shared_ptr</a>< T >::~<a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a> </td> | 
|---|
| 224 | <td>(</td> | 
|---|
| 225 | <td class="paramname"></td> | 
|---|
| 226 | <td> ) </td> | 
|---|
| 227 | <td><code> [inline]</code></td> | 
|---|
| 228 | </tr> | 
|---|
| 229 | </table> | 
|---|
| 230 | </div> | 
|---|
| 231 | <div class="memdoc"> | 
|---|
| 232 | <p>Destructor. </p> | 
|---|
| 233 |  | 
|---|
| 234 | </div> | 
|---|
| 235 | </div> | 
|---|
| 236 | <hr/><h2>Member Function Documentation</h2> | 
|---|
| 237 | <a class="anchor" id="afff45e4841b2921cd42ce0691f8c1196"></a><!-- doxytag: member="bdm::shared_ptr::get" ref="afff45e4841b2921cd42ce0691f8c1196" args="() const " --> | 
|---|
| 238 | <div class="memitem"> | 
|---|
| 239 | <div class="memproto"> | 
|---|
| 240 | <div class="memtemplate"> | 
|---|
| 241 | template<typename T> </div> | 
|---|
| 242 | <table class="memname"> | 
|---|
| 243 | <tr> | 
|---|
| 244 | <td class="memname">const T* <a class="el" href="classbdm_1_1shared__ptr.html">bdm::shared_ptr</a>< T >::get </td> | 
|---|
| 245 | <td>(</td> | 
|---|
| 246 | <td class="paramname"></td> | 
|---|
| 247 | <td> ) </td> | 
|---|
| 248 | <td> const<code> [inline]</code></td> | 
|---|
| 249 | </tr> | 
|---|
| 250 | </table> | 
|---|
| 251 | </div> | 
|---|
| 252 | <div class="memdoc"> | 
|---|
| 253 | <p>Returns the stored pointer (which remains owned by this instance). For empty instances, this method returns NULL. </p> | 
|---|
| 254 |  | 
|---|
| 255 | </div> | 
|---|
| 256 | </div> | 
|---|
| 257 | <a class="anchor" id="a37ebcfb6750dd7b5630f1d2354c07a96"></a><!-- doxytag: member="bdm::shared_ptr::get" ref="a37ebcfb6750dd7b5630f1d2354c07a96" args="()" --> | 
|---|
| 258 | <div class="memitem"> | 
|---|
| 259 | <div class="memproto"> | 
|---|
| 260 | <div class="memtemplate"> | 
|---|
| 261 | template<typename T> </div> | 
|---|
| 262 | <table class="memname"> | 
|---|
| 263 | <tr> | 
|---|
| 264 | <td class="memname">T* <a class="el" href="classbdm_1_1shared__ptr.html">bdm::shared_ptr</a>< T >::get </td> | 
|---|
| 265 | <td>(</td> | 
|---|
| 266 | <td class="paramname"></td> | 
|---|
| 267 | <td> ) </td> | 
|---|
| 268 | <td><code> [inline]</code></td> | 
|---|
| 269 | </tr> | 
|---|
| 270 | </table> | 
|---|
| 271 | </div> | 
|---|
| 272 | <div class="memdoc"> | 
|---|
| 273 | <p>Returns the stored pointer (which remains owned by this instance). For empty instances, this method returns NULL. </p> | 
|---|
| 274 |  | 
|---|
| 275 | <p>Referenced by <a class="el" href="bdmbase_8cpp_source.html#l00372">bdm::mepdf::from_setting()</a>, <a class="el" href="bdmbase_8h_source.html#l00904">bdm::mepdf::mepdf()</a>, and <a class="el" href="kalman_8h_source.html#l00120">bdm::Kalman< fsqmat >::posterior()</a>.</p> | 
|---|
| 276 |  | 
|---|
| 277 | </div> | 
|---|
| 278 | </div> | 
|---|
| 279 | <a class="anchor" id="a6cac71bb600f9f7c6fbed9335fd22d37"></a><!-- doxytag: member="bdm::shared_ptr::operator bool" ref="a6cac71bb600f9f7c6fbed9335fd22d37" args="() const " --> | 
|---|
| 280 | <div class="memitem"> | 
|---|
| 281 | <div class="memproto"> | 
|---|
| 282 | <div class="memtemplate"> | 
|---|
| 283 | template<typename T> </div> | 
|---|
| 284 | <table class="memname"> | 
|---|
| 285 | <tr> | 
|---|
| 286 | <td class="memname"><a class="el" href="classbdm_1_1shared__ptr.html">bdm::shared_ptr</a>< T >::operator bool </td> | 
|---|
| 287 | <td>(</td> | 
|---|
| 288 | <td class="paramname"></td> | 
|---|
| 289 | <td> ) </td> | 
|---|
| 290 | <td> const<code> [inline]</code></td> | 
|---|
| 291 | </tr> | 
|---|
| 292 | </table> | 
|---|
| 293 | </div> | 
|---|
| 294 | <div class="memdoc"> | 
|---|
| 295 |  | 
|---|
| 296 | <p>Boolean cast. </p> | 
|---|
| 297 | <p>This operator returns true if and only if the instance isn't empty. </p> | 
|---|
| 298 |  | 
|---|
| 299 | </div> | 
|---|
| 300 | </div> | 
|---|
| 301 | <a class="anchor" id="ab3cd369b00369ab92456aa0645e8d560"></a><!-- doxytag: member="bdm::shared_ptr::operator shared_ptr< const U >" ref="ab3cd369b00369ab92456aa0645e8d560" args="() const " --> | 
|---|
| 302 | <div class="memitem"> | 
|---|
| 303 | <div class="memproto"> | 
|---|
| 304 | <div class="memtemplate"> | 
|---|
| 305 | template<typename T> </div> | 
|---|
| 306 | <div class="memtemplate"> | 
|---|
| 307 | template<typename U > </div> | 
|---|
| 308 | <table class="memname"> | 
|---|
| 309 | <tr> | 
|---|
| 310 | <td class="memname"><a class="el" href="classbdm_1_1shared__ptr.html">bdm::shared_ptr</a>< T >::operator <a class="el" href="classbdm_1_1shared__ptr.html">shared_ptr</a>< const U > </td> | 
|---|
| 311 | <td>(</td> | 
|---|
| 312 | <td class="paramname"></td> | 
|---|
| 313 | <td> ) </td> | 
|---|
| 314 | <td> const<code> [inline]</code></td> | 
|---|
| 315 | </tr> | 
|---|
| 316 | </table> | 
|---|
| 317 | </div> | 
|---|
| 318 | <div class="memdoc"> | 
|---|
| 319 |  | 
|---|
| 320 | <p>const cast </p> | 
|---|
| 321 | <p>Shared pointer to T can be converted to shared pointer to const T, just like T * can be converted to T const *. </p> | 
|---|
| 322 |  | 
|---|
| 323 | </div> | 
|---|
| 324 | </div> | 
|---|
| 325 | <a class="anchor" id="ade000a72fe73804aa26962432f264800"></a><!-- doxytag: member="bdm::shared_ptr::operator*" ref="ade000a72fe73804aa26962432f264800" args="() const " --> | 
|---|
| 326 | <div class="memitem"> | 
|---|
| 327 | <div class="memproto"> | 
|---|
| 328 | <div class="memtemplate"> | 
|---|
| 329 | template<typename T> </div> | 
|---|
| 330 | <table class="memname"> | 
|---|
| 331 | <tr> | 
|---|
| 332 | <td class="memname">const T& <a class="el" href="classbdm_1_1shared__ptr.html">bdm::shared_ptr</a>< T >::operator* </td> | 
|---|
| 333 | <td>(</td> | 
|---|
| 334 | <td class="paramname"></td> | 
|---|
| 335 | <td> ) </td> | 
|---|
| 336 | <td> const<code> [inline]</code></td> | 
|---|
| 337 | </tr> | 
|---|
| 338 | </table> | 
|---|
| 339 | </div> | 
|---|
| 340 | <div class="memdoc"> | 
|---|
| 341 | <p>Returns a reference to the object pointed to by the stored pointer. This method may only be called when the stored pointer isn't NULL. </p> | 
|---|
| 342 |  | 
|---|
| 343 | </div> | 
|---|
| 344 | </div> | 
|---|
| 345 | <a class="anchor" id="ade38de837267becf5eed2839fea42c45"></a><!-- doxytag: member="bdm::shared_ptr::operator*" ref="ade38de837267becf5eed2839fea42c45" args="()" --> | 
|---|
| 346 | <div class="memitem"> | 
|---|
| 347 | <div class="memproto"> | 
|---|
| 348 | <div class="memtemplate"> | 
|---|
| 349 | template<typename T> </div> | 
|---|
| 350 | <table class="memname"> | 
|---|
| 351 | <tr> | 
|---|
| 352 | <td class="memname">T& <a class="el" href="classbdm_1_1shared__ptr.html">bdm::shared_ptr</a>< T >::operator* </td> | 
|---|
| 353 | <td>(</td> | 
|---|
| 354 | <td class="paramname"></td> | 
|---|
| 355 | <td> ) </td> | 
|---|
| 356 | <td><code> [inline]</code></td> | 
|---|
| 357 | </tr> | 
|---|
| 358 | </table> | 
|---|
| 359 | </div> | 
|---|
| 360 | <div class="memdoc"> | 
|---|
| 361 | <p>Returns a reference to the object pointed to by the stored pointer. This method may only be called when the stored pointer isn't NULL. </p> | 
|---|
| 362 |  | 
|---|
| 363 | </div> | 
|---|
| 364 | </div> | 
|---|
| 365 | <a class="anchor" id="ad89ec7ceb318241d833c7d278444396d"></a><!-- doxytag: member="bdm::shared_ptr::operator->" ref="ad89ec7ceb318241d833c7d278444396d" args="() const " --> | 
|---|
| 366 | <div class="memitem"> | 
|---|
| 367 | <div class="memproto"> | 
|---|
| 368 | <div class="memtemplate"> | 
|---|
| 369 | template<typename T> </div> | 
|---|
| 370 | <table class="memname"> | 
|---|
| 371 | <tr> | 
|---|
| 372 | <td class="memname">const T* <a class="el" href="classbdm_1_1shared__ptr.html">bdm::shared_ptr</a>< T >::operator-> </td> | 
|---|
| 373 | <td>(</td> | 
|---|
| 374 | <td class="paramname"></td> | 
|---|
| 375 | <td> ) </td> | 
|---|
| 376 | <td> const<code> [inline]</code></td> | 
|---|
| 377 | </tr> | 
|---|
| 378 | </table> | 
|---|
| 379 | </div> | 
|---|
| 380 | <div class="memdoc"> | 
|---|
| 381 | <p>Returns the stored pointer (which remains owned by this instance). This method may only be called when the stored pointer isn't NULL. </p> | 
|---|
| 382 |  | 
|---|
| 383 | </div> | 
|---|
| 384 | </div> | 
|---|
| 385 | <a class="anchor" id="abcaae812868eacbad050beda465d2327"></a><!-- doxytag: member="bdm::shared_ptr::operator->" ref="abcaae812868eacbad050beda465d2327" args="()" --> | 
|---|
| 386 | <div class="memitem"> | 
|---|
| 387 | <div class="memproto"> | 
|---|
| 388 | <div class="memtemplate"> | 
|---|
| 389 | template<typename T> </div> | 
|---|
| 390 | <table class="memname"> | 
|---|
| 391 | <tr> | 
|---|
| 392 | <td class="memname">T* <a class="el" href="classbdm_1_1shared__ptr.html">bdm::shared_ptr</a>< T >::operator-> </td> | 
|---|
| 393 | <td>(</td> | 
|---|
| 394 | <td class="paramname"></td> | 
|---|
| 395 | <td> ) </td> | 
|---|
| 396 | <td><code> [inline]</code></td> | 
|---|
| 397 | </tr> | 
|---|
| 398 | </table> | 
|---|
| 399 | </div> | 
|---|
| 400 | <div class="memdoc"> | 
|---|
| 401 | <p>Dereferences the stored pointer (which remains owned by this instance). This method may only be called when the stored pointer isn't NULL. </p> | 
|---|
| 402 |  | 
|---|
| 403 | </div> | 
|---|
| 404 | </div> | 
|---|
| 405 | <a class="anchor" id="a8e52b8887a4408c52b5263a5717343f2"></a><!-- doxytag: member="bdm::shared_ptr::use_count" ref="a8e52b8887a4408c52b5263a5717343f2" args="() const " --> | 
|---|
| 406 | <div class="memitem"> | 
|---|
| 407 | <div class="memproto"> | 
|---|
| 408 | <div class="memtemplate"> | 
|---|
| 409 | template<typename T> </div> | 
|---|
| 410 | <table class="memname"> | 
|---|
| 411 | <tr> | 
|---|
| 412 | <td class="memname">long <a class="el" href="classbdm_1_1shared__ptr.html">bdm::shared_ptr</a>< T >::use_count </td> | 
|---|
| 413 | <td>(</td> | 
|---|
| 414 | <td class="paramname"></td> | 
|---|
| 415 | <td> ) </td> | 
|---|
| 416 | <td> const<code> [inline]</code></td> | 
|---|
| 417 | </tr> | 
|---|
| 418 | </table> | 
|---|
| 419 | </div> | 
|---|
| 420 | <div class="memdoc"> | 
|---|
| 421 | <p>Returns the number of <a class="el" href="classbdm_1_1shared__ptr.html" title="A naive implementation of roughly a subset of the std::tr1::shared_ptr spec.">shared_ptr</a> instances (including this instance) that share ownership with this instance. For empty instances, this method returns 0. </p> | 
|---|
| 422 |  | 
|---|
| 423 | </div> | 
|---|
| 424 | </div> | 
|---|
| 425 | <hr/>The documentation for this class was generated from the following file:<ul> | 
|---|
| 426 | <li><a class="el" href="shared__ptr_8h_source.html">shared_ptr.h</a></li> | 
|---|
| 427 | </ul> | 
|---|
| 428 | </div> | 
|---|
| 429 | <hr size="1"/><address style="text-align: right;"><small>Generated on Sun Sep 13 23:08:56 2009 for mixpp by  | 
|---|
| 430 | <a href="http://www.doxygen.org/index.html"> | 
|---|
| 431 | <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.6.1 </small></address> | 
|---|
| 432 | </body> | 
|---|
| 433 | </html> | 
|---|