root/doc/html/classCompoundUserInfo.html @ 187

Revision 181, 15.5 kB (checked in by smidl, 16 years ago)

Regenerated doc

Line 
1<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
2<html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
3<title>mixpp: CompoundUserInfo&lt; T &gt; Class Template Reference</title>
4<link href="doxygen.css" rel="stylesheet" type="text/css">
5<link href="tabs.css" rel="stylesheet" type="text/css">
6</head><body>
7<!-- Generated by Doxygen 1.5.6 -->
8<div class="navigation" id="top">
9  <div class="tabs">
10    <ul>
11      <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
12      <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
13      <li class="current"><a href="annotated.html"><span>Classes</span></a></li>
14      <li><a href="files.html"><span>Files</span></a></li>
15    </ul>
16  </div>
17  <div class="tabs">
18    <ul>
19      <li><a href="annotated.html"><span>Class&nbsp;List</span></a></li>
20      <li><a href="hierarchy.html"><span>Class&nbsp;Hierarchy</span></a></li>
21      <li><a href="functions.html"><span>Class&nbsp;Members</span></a></li>
22    </ul>
23  </div>
24</div>
25<div class="contents">
26<h1>CompoundUserInfo&lt; T &gt; Class Template Reference</h1><!-- doxytag: class="CompoundUserInfo" --><!-- doxytag: inherits="TypedUserInfo" -->The main userinfo template class. You should derive this class whenever you need a new userinfo of a class which is compound from smaller elements (all having its own userinfo class prepared). 
27<a href="#_details">More...</a>
28<p>
29<code>#include &lt;<a class="el" href="userinfo_8h-source.html">userinfo.h</a>&gt;</code>
30<p>
31<div class="dynheader">
32Inheritance diagram for CompoundUserInfo&lt; T &gt;:</div>
33<div class="dynsection">
34<p><center><img src="classCompoundUserInfo__inherit__graph.png" border="0" usemap="#CompoundUserInfo_3_01T_01_4__inherit__map" alt="Inheritance graph"></center>
35<map name="CompoundUserInfo_3_01T_01_4__inherit__map">
36<area shape="rect" href="classCompoundUserInfo.html" title="CompoundUserInfo\&lt; Car \&gt;" alt="" coords="5,343,200,369"><area shape="rect" href="classCompoundUserInfo.html" title="CompoundUserInfo\&lt; Bike \&gt;" alt="" coords="224,343,424,369"><area shape="rect" href="classTypedUserInfo.html" title="TypeUserInfo is still an abstract class, but contrary to the UserInfo class it is..." alt="" coords="105,167,252,193"><area shape="rect" href="classUserInfo.html" title="UserInfo is an abstract is for internal purposes only. Use CompoundUserInfo&lt;T&gt;..." alt="" coords="141,87,216,113"><area shape="rect" href="classBindingFrame.html" title="Abstract class declaring general properties of a frame for data binding." alt="" coords="125,7,232,33"></map>
37<center><font size="2">[<a href="graph_legend.html">legend</a>]</font></center></div>
38<div class="dynheader">
39Collaboration diagram for CompoundUserInfo&lt; T &gt;:</div>
40<div class="dynsection">
41<p><center><img src="classCompoundUserInfo__coll__graph.png" border="0" usemap="#CompoundUserInfo_3_01T_01_4__coll__map" alt="Collaboration graph"></center>
42<map name="CompoundUserInfo_3_01T_01_4__coll__map">
43<area shape="rect" href="classTypedUserInfo.html" title="TypeUserInfo is still an abstract class, but contrary to the UserInfo class it is..." alt="" coords="83,295,229,321"><area shape="rect" href="classUserInfo.html" title="UserInfo is an abstract is for internal purposes only. Use CompoundUserInfo&lt;T&gt;..." alt="" coords="119,215,193,241"><area shape="rect" href="classBindingFrame.html" title="Abstract class declaring general properties of a frame for data binding." alt="" coords="24,103,131,129"><area shape="rect" href="classAssertXercesIsAlive.html" title="Class initializing Xerces library." alt="" coords="5,7,149,33"></map>
44<center><font size="2">[<a href="graph_legend.html">legend</a>]</font></center></div>
45
46<p>
47<a href="classCompoundUserInfo-members.html">List of all members.</a><table border="0" cellpadding="0" cellspacing="0">
48<tr><td></td></tr>
49<tr><td colspan="2"><br><h2>Static Public Member Functions</h2></td></tr>
50<tr><td class="memTemplParams" nowrap colspan="2">template&lt;class T&gt; </td></tr>
51<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">static T *&nbsp;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classUserInfo.html#0f090c6525a3e8fb11634a553f467ede">Assembly</a> (DOMElement &amp;element, const string tagName)</td></tr>
52
53<tr><td class="memTemplParams" nowrap colspan="2">template&lt;class T&gt; </td></tr>
54<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">static bool&nbsp;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classUserInfo.html#1d402661b82feccb5265a70f65c242e1">Disassembly</a> (T &amp;<a class="el" href="classTypedUserInfo.html#c7ad10a9ff002383518155c965ade85c">instance</a>, DOMElement &amp;element, const string tagName, const string help)</td></tr>
55
56<tr><td class="memTemplParams" nowrap colspan="2">template&lt;class T&gt; </td></tr>
57<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">static bool&nbsp;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classUserInfo.html#917b2257abc31b94c89ef3cd270e4a42">Disassembly</a> (T &amp;<a class="el" href="classTypedUserInfo.html#c7ad10a9ff002383518155c965ade85c">instance</a>, DOMElement &amp;element, const string tagName)</td></tr>
58
59<tr><td colspan="2"><br><h2>Protected Member Functions</h2></td></tr>
60<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="e2265e447e2f48550c5d8d479119bbb3"></a><!-- doxytag: member="CompoundUserInfo::CompoundUserInfo" ref="e2265e447e2f48550c5d8d479119bbb3" args="(string userFriendlyTypeName)" -->
61&nbsp;</td><td class="memItemRight" valign="bottom"><b>CompoundUserInfo</b> (string userFriendlyTypeName)</td></tr>
62
63<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="2244bd5181c3d1e70f3a6be2b72e9424"></a><!-- doxytag: member="CompoundUserInfo::XMLCh2str" ref="2244bd5181c3d1e70f3a6be2b72e9424" args="(const XMLCh *const XMLCh_str)" -->
64string&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classBindingFrame.html#2244bd5181c3d1e70f3a6be2b72e9424">XMLCh2str</a> (const XMLCh *const XMLCh_str)</td></tr>
65
66<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">function which transcodes Xerces' XMLCh-based strings into C++ strings <br></td></tr>
67<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="820e4df85c0dc545e3079e407fcdbbaa"></a><!-- doxytag: member="CompoundUserInfo::removeSpaces" ref="820e4df85c0dc545e3079e407fcdbbaa" args="(const string &amp;str)" -->
68string&nbsp;</td><td class="memItemRight" valign="bottom"><b>removeSpaces</b> (const string &amp;<a class="el" href="classstr.html">str</a>)</td></tr>
69
70<tr><td colspan="2"><br><h2>Static Protected Attributes</h2></td></tr>
71<tr><td class="memItemLeft" nowrap align="right" valign="top">static const <a class="el" href="classTypedUserInfo.html">TypedUserInfo</a>&lt; T &gt; &amp;&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classTypedUserInfo.html#c7ad10a9ff002383518155c965ade85c">instance</a></td></tr>
72
73<tr><td colspan="2"><br><h2>Classes</h2></td></tr>
74<tr><td class="memItemLeft" nowrap align="right" valign="top">class &nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classCompoundUserInfo_1_1BindedElement.html">BindedElement</a></td></tr>
75
76<tr><td class="mdescLeft">&nbsp;</td><td class="mdescRight">Templated class binding inner element with its XML tag and automating data transfers in both directions.  <a href="classCompoundUserInfo_1_1BindedElement.html#_details">More...</a><br></td></tr>
77</table>
78<hr><a name="_details"></a><h2>Detailed Description</h2>
79<h3>template&lt;typename T&gt;<br>
80 class CompoundUserInfo&lt; T &gt;</h3>
81
82The main userinfo template class. You should derive this class whenever you need a new userinfo of a class which is compound from smaller elements (all having its own userinfo class prepared).
83<p>
84To bind some inner element to its own userinfo class, and also to automate its assembling and disassembling, it is necessary to create a instance of an inner templated class BindedElement&lt;T&gt;. Those attributes have to be initialized in constructor of a new compound userinfo this way:<p>
85<div class="fragment"><pre class="fragment"><span class="keyword">class </span>BikeUI: <span class="keyword">public</span> <a class="code" href="classCompoundUserInfo.html" title="The main userinfo template class. You should derive this class whenever you need...">CompoundUserInfo</a>&lt;Bike&gt;
86{
87<span class="keyword">private</span>:
88        BindedElement&lt;int&gt; year;
89        BindedElement&lt;bool&gt; lights;
90        BindedElement&lt;string&gt; manufacturer;
91<span class="keyword">public</span>:
92        BikeUI()
93                :<a class="code" href="classCompoundUserInfo.html" title="The main userinfo template class. You should derive this class whenever you need...">CompoundUserInfo</a>&lt;Bike&gt;(<span class="stringliteral">"bike"</span>),
94                year( this, <span class="stringliteral">"year"</span>, 0 ),
95                lights( this, <span class="stringliteral">"electric lights"</span>, false ),
96                manufacturer( this, <span class="stringliteral">"manufacturer"</span>, <span class="stringliteral">"unknown"</span>)
97        {
98        }
99
100        ...
101}
102</pre></div> <hr><h2>Member Function Documentation</h2>
103<a class="anchor" name="0f090c6525a3e8fb11634a553f467ede"></a><!-- doxytag: member="CompoundUserInfo::Assembly" ref="0f090c6525a3e8fb11634a553f467ede" args="(DOMElement &amp;element, const string tagName)" -->
104<div class="memitem">
105<div class="memproto">
106<div class="memtemplate">
107template&lt;class T&gt; </div>
108      <table class="memname">
109        <tr>
110          <td class="memname">static T* UserInfo::Assembly           </td>
111          <td>(</td>
112          <td class="paramtype">DOMElement &amp;&nbsp;</td>
113          <td class="paramname"> <em>element</em>, </td>
114        </tr>
115        <tr>
116          <td class="paramkey"></td>
117          <td></td>
118          <td class="paramtype">const string&nbsp;</td>
119          <td class="paramname"> <em>tagName</em></td><td>&nbsp;</td>
120        </tr>
121        <tr>
122          <td></td>
123          <td>)</td>
124          <td></td><td></td><td><code> [inline, static, inherited]</code></td>
125        </tr>
126      </table>
127</div>
128<div class="memdoc">
129
130<p>
131This methods tries to assembly a new instance of type T (or some of its descendant types) according to a data stored in a DOMNode named tagName within a child nodes of the passed element. If an error occurs, it returns a NULL pointer.
132<p>References <a class="el" href="userinfo_8cpp-source.html#l00040">Attribute::Get()</a>, and <a class="el" href="userinfo_8h-source.html#l00152">Attribute::type</a>.</p>
133
134</div>
135</div><p>
136<a class="anchor" name="1d402661b82feccb5265a70f65c242e1"></a><!-- doxytag: member="CompoundUserInfo::Disassembly" ref="1d402661b82feccb5265a70f65c242e1" args="(T &amp;instance, DOMElement &amp;element, const string tagName, const string help)" -->
137<div class="memitem">
138<div class="memproto">
139<div class="memtemplate">
140template&lt;class T&gt; </div>
141      <table class="memname">
142        <tr>
143          <td class="memname">static bool UserInfo::Disassembly           </td>
144          <td>(</td>
145          <td class="paramtype">T &amp;&nbsp;</td>
146          <td class="paramname"> <em>instance</em>, </td>
147        </tr>
148        <tr>
149          <td class="paramkey"></td>
150          <td></td>
151          <td class="paramtype">DOMElement &amp;&nbsp;</td>
152          <td class="paramname"> <em>element</em>, </td>
153        </tr>
154        <tr>
155          <td class="paramkey"></td>
156          <td></td>
157          <td class="paramtype">const string&nbsp;</td>
158          <td class="paramname"> <em>tagName</em>, </td>
159        </tr>
160        <tr>
161          <td class="paramkey"></td>
162          <td></td>
163          <td class="paramtype">const string&nbsp;</td>
164          <td class="paramname"> <em>help</em></td><td>&nbsp;</td>
165        </tr>
166        <tr>
167          <td></td>
168          <td>)</td>
169          <td></td><td></td><td><code> [inline, static, inherited]</code></td>
170        </tr>
171      </table>
172</div>
173<div class="memdoc">
174
175<p>
176This methods tries to disassembly an instance of type T (or some of its descendant types) and build DOM tree accordingly. Then, it creates a new DOMNode named according tagName and connecti it to the passed DOMElement as a new child node (with a help attribute filled).
177<p>References <a class="el" href="userinfo_8h-source.html#l00149">Attribute::help</a>, <a class="el" href="userinfo_8cpp-source.html#l00046">Attribute::Set()</a>, and <a class="el" href="userinfo_8h-source.html#l00152">Attribute::type</a>.</p>
178
179<p>Referenced by <a class="el" href="userinfo_8h-source.html#l00327">UserInfo::Disassembly()</a>, and <a class="el" href="userinfo_8h-source.html#l00479">CompoundUserInfo&lt; T &gt;::BindedElement&lt; U &gt;::DisassemblyComponentsToXML()</a>.</p>
180
181</div>
182</div><p>
183<a class="anchor" name="917b2257abc31b94c89ef3cd270e4a42"></a><!-- doxytag: member="CompoundUserInfo::Disassembly" ref="917b2257abc31b94c89ef3cd270e4a42" args="(T &amp;instance, DOMElement &amp;element, const string tagName)" -->
184<div class="memitem">
185<div class="memproto">
186<div class="memtemplate">
187template&lt;class T&gt; </div>
188      <table class="memname">
189        <tr>
190          <td class="memname">static bool UserInfo::Disassembly           </td>
191          <td>(</td>
192          <td class="paramtype">T &amp;&nbsp;</td>
193          <td class="paramname"> <em>instance</em>, </td>
194        </tr>
195        <tr>
196          <td class="paramkey"></td>
197          <td></td>
198          <td class="paramtype">DOMElement &amp;&nbsp;</td>
199          <td class="paramname"> <em>element</em>, </td>
200        </tr>
201        <tr>
202          <td class="paramkey"></td>
203          <td></td>
204          <td class="paramtype">const string&nbsp;</td>
205          <td class="paramname"> <em>tagName</em></td><td>&nbsp;</td>
206        </tr>
207        <tr>
208          <td></td>
209          <td>)</td>
210          <td></td><td></td><td><code> [inline, static, inherited]</code></td>
211        </tr>
212      </table>
213</div>
214<div class="memdoc">
215
216<p>
217This methods tries to disassembly an instance of type T (or some of its descendant types) and build DOM tree accordingly. Then, it creates a new DOMNode named according tagName and connecti it to the passed DOMElement as a new child node.
218<p>References <a class="el" href="userinfo_8h-source.html#l00297">UserInfo::Disassembly()</a>.</p>
219
220</div>
221</div><p>
222<hr><h2>Member Data Documentation</h2>
223<a class="anchor" name="c7ad10a9ff002383518155c965ade85c"></a><!-- doxytag: member="CompoundUserInfo::instance" ref="c7ad10a9ff002383518155c965ade85c" args="" -->
224<div class="memitem">
225<div class="memproto">
226<div class="memtemplate">
227template&lt;typename T&gt; </div>
228      <table class="memname">
229        <tr>
230          <td class="memname">const <a class="el" href="classTypedUserInfo.html">TypedUserInfo</a>&lt;T&gt;&amp; <a class="el" href="classTypedUserInfo.html">TypedUserInfo</a>&lt; T &gt;::<a class="el" href="classTypedUserInfo.html#c7ad10a9ff002383518155c965ade85c">instance</a><code> [static, protected, inherited]</code>          </td>
231        </tr>
232      </table>
233</div>
234<div class="memdoc">
235
236<p>
237the only instance of this class (each type T has its own instance) which is used as a factory for processing related userinfos
238</div>
239</div><p>
240<hr>The documentation for this class was generated from the following file:<ul>
241<li>work/git/mixpp/bdm/<a class="el" href="userinfo_8h-source.html">userinfo.h</a></ul>
242</div>
243<hr size="1"><address style="text-align: right;"><small>Generated on Wed Oct 15 15:57:13 2008 for mixpp by&nbsp;
244<a href="http://www.doxygen.org/index.html">
245<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.6 </small></address>
246</body>
247</html>
Note: See TracBrowser for help on using the browser.