A C++ DAL / ORM code generation framework
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

779 lines
44 KiB

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<title>WORM: WSql::WSqlDriver Class Reference</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/search.js"></script>
<link href="doxygen.css" rel="stylesheet" type="text/css"/>
</head>
<body onload='searchBox.OnSelectItem(0);'>
<!-- Generated by Doxygen 1.7.3 -->
<script type="text/javascript"><!--
var searchBox = new SearchBox("searchBox", "search",false,'Search');
--></script>
<script type="text/javascript">
function hasClass(ele,cls) {
return ele.className.match(new RegExp('(\\s|^)'+cls+'(\\s|$)'));
}
function addClass(ele,cls) {
if (!this.hasClass(ele,cls)) ele.className += " "+cls;
}
function removeClass(ele,cls) {
if (hasClass(ele,cls)) {
var reg = new RegExp('(\\s|^)'+cls+'(\\s|$)');
ele.className=ele.className.replace(reg,' ');
}
}
function toggleVisibility(linkObj) {
var base = linkObj.getAttribute('id');
var summary = document.getElementById(base + '-summary');
var content = document.getElementById(base + '-content');
var trigger = document.getElementById(base + '-trigger');
if ( hasClass(linkObj,'closed') ) {
summary.style.display = 'none';
content.style.display = 'block';
trigger.src = 'open.png';
removeClass(linkObj,'closed');
addClass(linkObj,'opened');
} else if ( hasClass(linkObj,'opened') ) {
summary.style.display = 'block';
content.style.display = 'none';
trigger.src = 'closed.png';
removeClass(linkObj,'opened');
addClass(linkObj,'closed');
}
return false;
}
</script>
<div id="top">
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
<tbody>
<tr style="height: 56px;">
<td id="projectlogo"><img alt="Logo" src="worm_sm.png"></td>
<td style="padding-left: 0.5em;">
<div id="projectname">WORM&#160;<span id="projectnumber">0.2</span></div>
<div id="projectbrief">A C++ DAL/ORM code generation framework</div>
</td>
</tr>
</tbody>
</table>
</div>
<div id="navrow1" class="tabs">
<ul class="tablist">
<li><a href="index.html"><span>Main&#160;Page</span></a></li>
<li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
<li><a href="namespaces.html"><span>Namespaces</span></a></li>
<li class="current"><a href="annotated.html"><span>Classes</span></a></li>
<li><a href="files.html"><span>Files</span></a></li>
<li id="searchli">
<div id="MSearchBox" class="MSearchBoxInactive">
<span class="left">
<img id="MSearchSelect" src="search/mag_sel.png"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
alt=""/>
<input type="text" id="MSearchField" value="Search" accesskey="S"
onfocus="searchBox.OnSearchFieldFocus(true)"
onblur="searchBox.OnSearchFieldFocus(false)"
onkeyup="searchBox.OnSearchFieldChange(event)"/>
</span><span class="right">
<a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
</span>
</div>
</li>
</ul>
</div>
<div id="navrow2" class="tabs2">
<ul class="tablist">
<li><a href="annotated.html"><span>Class&#160;List</span></a></li>
<li><a href="classes.html"><span>Class&#160;Index</span></a></li>
<li><a href="hierarchy.html"><span>Class&#160;Hierarchy</span></a></li>
<li><a href="functions.html"><span>Class&#160;Members</span></a></li>
</ul>
</div>
<div id="nav-path" class="navpath">
<ul>
<li class="navelem"><a class="el" href="namespace_w_sql.html">WSql</a> </li>
<li class="navelem"><a class="el" href="class_w_sql_1_1_w_sql_driver.html">WSqlDriver</a> </li>
</ul>
</div>
</div>
<div class="header">
<div class="summary">
<a href="#pub-methods">Public Member Functions</a> &#124;
<a href="#pro-methods">Protected Member Functions</a> &#124;
<a href="#pro-attribs">Protected Attributes</a> &#124;
<a href="#friends">Friends</a> </div>
<div class="headertitle">
<h1>WSql::WSqlDriver Class Reference</h1> </div>
</div>
<div class="contents">
<!-- doxytag: class="WSql::WSqlDriver" -->
<p>The <a class="el" href="class_w_sql_1_1_w_sql_driver.html" title="The WSqlDriver class is an abstract base class for database drivers.">WSqlDriver</a> class is an abstract base class for database drivers.
<a href="#_details">More...</a></p>
<p><code>#include &lt;<a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>&gt;</code></p>
<div id="dynsection-0" onclick="return toggleVisibility(this)" class="dynheader closed" style="cursor:pointer;">
<img id="dynsection-0-trigger" src="closed.png"/> Inheritance diagram for WSql::WSqlDriver:</div>
<div id="dynsection-0-summary" class="dynsummary" style="display:block;">
</div>
<div id="dynsection-0-content" class="dyncontent" style="display:none;">
<div class="center">
<img src="class_w_sql_1_1_w_sql_driver.png" usemap="#WSql::WSqlDriver_map" alt=""/>
<map id="WSql::WSqlDriver_map" name="WSql::WSqlDriver_map">
<area href="class_w_sql_1_1_w_mysql_driver.html" alt="WSql::WMysqlDriver" shape="rect" coords="0,56,126,80"/>
<area href="class_w_sql_1_1_w_sqlite_driver.html" alt="WSql::WSqliteDriver" shape="rect" coords="136,56,262,80"/>
</map>
</div></div>
<p><a href="class_w_sql_1_1_w_sql_driver-members.html">List of all members.</a></p>
<table class="memberdecls">
<tr><td colspan="2"><h2><a name="pub-methods"></a>
Public Member Functions</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#aafd8e66401bcbf3abe1abfa809979375">WSqlDriver</a> (<a class="el" href="class_w_sql_1_1_w_sql_database.html">WSqlDatabase</a> *db)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Construct a driver with the given database <em>db</em>. <a href="#aafd8e66401bcbf3abe1abfa809979375"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">virtual&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#ad8c75e82dbe10f41eb7bd4e6a777e4d7">~WSqlDriver</a> ()</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Destroys the driver and created resources. <a href="#ad8c75e82dbe10f41eb7bd4e6a777e4d7"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">virtual bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#a2a1f251900715cd1e45aa7a565a57253">open</a> ()=0</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">virtual void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#a17afc1e43627a2a952e76d04420dead0">close</a> ()=0</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">virtual bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#ad15803a5c5d4e8e1d80fec885ed13203">query</a> (std::string sql)=0</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">virtual std::vector&lt; std::string &gt;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#adc7f0845587544ad92e3079542e844db">tableNames</a> ()=0</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="class_w_sql_1_1_w_sql_table.html">WSqlTable</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#a2574f1f0d2083f1b0e05f4721f870a74">tableMetaData</a> (const std::string &amp;tableName)=0</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="class_w_sql_1_1_w_sql_result.html">WSqlResult</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#ae5670416af2dc36911bc29478e5ad0e3">result</a> (bool iscached=true)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="class_w_sql_1_1_w_sql_error.html">WSqlError</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#aabd54e13ac3769bfd283cc8e7e937e6f">error</a> () const </td></tr>
<tr><td class="memItemLeft" align="right" valign="top">virtual bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#aa81bf0a003e897f38574a8ee23348b8d">isValid</a> () const </td></tr>
<tr><td class="memItemLeft" align="right" valign="top">virtual bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#a6c4bf314bfa0d19e476377891a949253">isOpen</a> () const </td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_w_sql_1_1_w_sql_table.html">WSqlTable</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#a26154ae9b11b139482be58c0b2ed4917">findTable</a> (std::string tablename) const </td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Locate the metadata table for <em>tablename</em> in the cache. <a href="#a26154ae9b11b139482be58c0b2ed4917"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#aee4657eb1bf5d7d5b8a68dc51da1572f">hasError</a> () const </td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#ae8e1c1685325f8c3fbab81992a0ff3de">setDatabase</a> (<a class="el" href="class_w_sql_1_1_w_sql_database.html">WSqlDatabase</a> *dp)</td></tr>
<tr><td colspan="2"><h2><a name="pro-methods"></a>
Protected Member Functions</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_w_sql_1_1_w_sql_table.html">WSqlTable</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#ac8280245a9ab0d63d09c9b7b03c0b3b9">getTable</a> (const std::string &amp;tablename)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Return a reference to the metadata table for <em>tablename</em> in the cache. <a href="#ac8280245a9ab0d63d09c9b7b03c0b3b9"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#a18022bccc41d920564c83b02339aa4f8">setIsValid</a> (bool b)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#adb8b4302e38822dbc2fbe71889ab7724">setIsOpen</a> (bool o)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#a76938d8fa49e562f015d7e6eb7b6ed42">setHasError</a> (bool e)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#aa5e7841c760ffc5c7dbc7c2593f8ecb3">setError</a> (const <a class="el" href="class_w_sql_1_1_w_sql_error.html">WSqlError</a> &amp;e)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Sets the the current error to <em>error</em>. <a href="#aa5e7841c760ffc5c7dbc7c2593f8ecb3"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#ad19e63bfa9c1101b314c168642d80938">setError</a> (const std::string &amp;text, <a class="el" href="class_w_sql_1_1_w_sql_error.html#a8bcabd8bf1016ca27304a717ef3d78db">WSqlError::ErrorType</a> type, <a class="el" href="class_w_sql_1_1_w_sql_error.html#a63b2672eb5c68164c4ff43443037f6d9">WSqlError::ErrorSeverity</a> severity, bool isvalid=true)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Set an error with <em>text</em> and types and also set isValid. <a href="#ad19e63bfa9c1101b314c168642d80938"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#ab1e89214bd9e0d8c9c0caaae52036287">setError</a> (const std::string &amp;text)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#a334d7b76b1bf64c4d779b0196510faac">setError</a> (const char *text)</td></tr>
<tr><td colspan="2"><h2><a name="pro-attribs"></a>
Protected Attributes</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_w_sql_1_1_w_sql_database.html">WSqlDatabase</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#a6aac5abed866e56bd56ed20b7eef06f0">_database</a></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_w_sql_1_1_w_sql_result.html">WSqlResult</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#a0fcc770ae53104549e68703eab08cab9">_result</a></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">std::vector&lt; <a class="el" href="class_w_sql_1_1_w_sql_table.html">WSqlTable</a> &gt;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#a4eae8e8af5b50b1bc3a10bf528073724">_tables</a></td></tr>
<tr><td colspan="2"><h2><a name="friends"></a>
Friends</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">class&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sql_driver.html#aec208bf350d9750fc15c0c908d7b989a">WSqlDatabase</a></td></tr>
</table>
<hr/><a name="_details"></a><h2>Detailed Description</h2>
<div class="textblock"><p>The <a class="el" href="class_w_sql_1_1_w_sql_driver.html" title="The WSqlDriver class is an abstract base class for database drivers.">WSqlDriver</a> class is an abstract base class for database drivers. </p>
<p>This class can not be used directly. This must be implemented for a specific database server (eg. SQLite or MySQL ).Also, prefer not to use a driver directly but rather an instance of <a class="el" href="class_w_sql_1_1_w_sql_database.html" title="The WSqlDatabase class represents a single database.">WSqlDatabase</a> to access the database (recommended).</p>
<dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="class_w_sql_1_1_w_sql_database.html" title="The WSqlDatabase class represents a single database.">WSqlDatabase</a> <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html">WSqliteDriver</a> <a class="el" href="class_w_sql_1_1_w_mysql_driver.html" title="A driver for MySQL databases.">WMysqlDriver</a> </dd></dl>
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00033">33</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div><hr/><h2>Constructor &amp; Destructor Documentation</h2>
<a class="anchor" id="aafd8e66401bcbf3abe1abfa809979375"></a><!-- doxytag: member="WSql::WSqlDriver::WSqlDriver" ref="aafd8e66401bcbf3abe1abfa809979375" args="(WSqlDatabase *db)" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">WSql::WSqlDriver::WSqlDriver </td>
<td>(</td>
<td class="paramtype"><a class="el" href="class_w_sql_1_1_w_sql_database.html">WSqlDatabase</a> *&#160;</td>
<td class="paramname"><em>db</em></td><td>)</td>
<td></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Construct a driver with the given database <em>db</em>. </p>
<p>Constructs a driver with a pointer to the database - note that this is the only way to create a driver; all connection information (eg. database name, user name, etc. ) is set in and managed by <a class="el" href="class_w_sql_1_1_w_sql_database.html" title="The WSqlDatabase class represents a single database.">WSqlDatabase</a> - the driver will obtain what it needs to know from there.</p>
<dl><dt><b>Parameters:</b></dt><dd>
<table class="params">
<tr><td class="paramname">WSqlDatabase*</td><td>db - the database using this driver. </td></tr>
</table>
</dd>
</dl>
<p>Definition at line <a class="el" href="wsqldriver_8cpp_source.html#l00045">45</a> of file <a class="el" href="wsqldriver_8cpp_source.html">wsqldriver.cpp</a>.</p>
</div>
</div>
<a class="anchor" id="ad8c75e82dbe10f41eb7bd4e6a777e4d7"></a><!-- doxytag: member="WSql::WSqlDriver::~WSqlDriver" ref="ad8c75e82dbe10f41eb7bd4e6a777e4d7" args="()" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">WSql::WSqlDriver::~WSqlDriver </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td><code> [virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Destroys the driver and created resources. </p>
<p>Note that the result pointer obtained from <a class="el" href="class_w_sql_1_1_w_sql_driver.html#ae5670416af2dc36911bc29478e5ad0e3">getResult()</a> is <em>invalid</em> after the object is destroyed! This means you do not need to (and should not) delete a result from the driver and that you also must be careful not to use it after a <a class="el" href="class_w_sql_1_1_w_sql_driver.html" title="The WSqlDriver class is an abstract base class for database drivers.">WSqlDriver</a> object has been destroyed. </p>
<p>Definition at line <a class="el" href="wsqldriver_8cpp_source.html#l00061">61</a> of file <a class="el" href="wsqldriver_8cpp_source.html">wsqldriver.cpp</a>.</p>
</div>
</div>
<hr/><h2>Member Function Documentation</h2>
<a class="anchor" id="a17afc1e43627a2a952e76d04420dead0"></a><!-- doxytag: member="WSql::WSqlDriver::close" ref="a17afc1e43627a2a952e76d04420dead0" args="()=0" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool WSql::WSqlDriver::close </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td><code> [pure virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Derived classes must reimplement this pure virtual function in order to close the database connection. Return true on success, false on failure.</p>
<dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="class_w_sql_1_1_w_sql_driver.html#a2a1f251900715cd1e45aa7a565a57253">open()</a>, setOpen() </dd></dl>
<p>Implemented in <a class="el" href="class_w_sql_1_1_w_mysql_driver.html#a347c2c1642d3046292688980dfc5c96b">WSql::WMysqlDriver</a>, and <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#ac80543216d537dab91b382488042c416">WSql::WSqliteDriver</a>.</p>
</div>
</div>
<a class="anchor" id="aabd54e13ac3769bfd283cc8e7e937e6f"></a><!-- doxytag: member="WSql::WSqlDriver::error" ref="aabd54e13ac3769bfd283cc8e7e937e6f" args="() const " -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="class_w_sql_1_1_w_sql_error.html">WSqlError</a> WSql::WSqlDriver::error </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td> const<code> [inline, virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Returns a <a class="el" href="class_w_sql_1_1_w_sql_error.html" title="The WSqlError class provides SQL database and driver error information.">WSqlError</a> object which contains information about the last error that occurred on the database. </p>
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00049">49</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<a class="anchor" id="a26154ae9b11b139482be58c0b2ed4917"></a><!-- doxytag: member="WSql::WSqlDriver::findTable" ref="a26154ae9b11b139482be58c0b2ed4917" args="(std::string tablename) const " -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="class_w_sql_1_1_w_sql_table.html">WSqlTable</a> WSql::WSqlDriver::findTable </td>
<td>(</td>
<td class="paramtype">std::string&#160;</td>
<td class="paramname"><em>tablename</em></td><td>)</td>
<td> const</td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Locate the metadata table for <em>tablename</em> in the cache. </p>
<p>This returns a <a class="el" href="class_w_sql_1_1_w_sql_table.html" title="WSqlTable is an abstraction for a single table, collection or view in a database.">WSqlTable</a> of metadata for a given table by looking it up in the local cache. If the table has been initialized it will be returned if not an invalid (ie. empty) <a class="el" href="class_w_sql_1_1_w_sql_table.html" title="WSqlTable is an abstraction for a single table, collection or view in a database.">WSqlTable</a> object will be returned. </p>
<dl><dt><b>Parameters:</b></dt><dd>
<table class="params">
<tr><td class="paramname">std::string</td><td>tablename - the name of the table to find </td></tr>
</table>
</dd>
</dl>
<dl><dt><b>Return values:</b></dt><dd>
<table class="retval">
<tr><td class="paramname"><a class="el" href="class_w_sql_1_1_w_sql_table.html" title="WSqlTable is an abstraction for a single table, collection or view in a database.">WSqlTable</a></td><td>valid if found in cache </td></tr>
</table>
</dd>
</dl>
<p>Definition at line <a class="el" href="wsqldriver_8cpp_source.html#l00109">109</a> of file <a class="el" href="wsqldriver_8cpp_source.html">wsqldriver.cpp</a>.</p>
</div>
</div>
<a class="anchor" id="ac8280245a9ab0d63d09c9b7b03c0b3b9"></a><!-- doxytag: member="WSql::WSqlDriver::getTable" ref="ac8280245a9ab0d63d09c9b7b03c0b3b9" args="(const std::string &amp;tablename)" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="class_w_sql_1_1_w_sql_table.html">WSqlTable</a> * WSql::WSqlDriver::getTable </td>
<td>(</td>
<td class="paramtype">const std::string &amp;&#160;</td>
<td class="paramname"><em>tablename</em></td><td>)</td>
<td><code> [protected]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Return a reference to the metadata table for <em>tablename</em> in the cache. </p>
<p>This returns a reference to the <a class="el" href="class_w_sql_1_1_w_sql_table.html" title="WSqlTable is an abstraction for a single table, collection or view in a database.">WSqlTable</a> of metadata for a given table by looking it up in the local cache. If the table has been initialized it will be returned if not a null (0) pointer will be returned. This function is used internally to modify tables - it is not recommended for use otherwise.</p>
<dl><dt><b>Parameters:</b></dt><dd>
<table class="params">
<tr><td class="paramname">std::string</td><td>tablename - the name of the table to find </td></tr>
</table>
</dd>
</dl>
<dl><dt><b>Return values:</b></dt><dd>
<table class="retval">
<tr><td class="paramname">WSqlTable*</td><td>valid if found in cache </td></tr>
</table>
</dd>
</dl>
<p>Definition at line <a class="el" href="wsqldriver_8cpp_source.html#l00130">130</a> of file <a class="el" href="wsqldriver_8cpp_source.html">wsqldriver.cpp</a>.</p>
</div>
</div>
<a class="anchor" id="aee4657eb1bf5d7d5b8a68dc51da1572f"></a><!-- doxytag: member="WSql::WSqlDriver::hasError" ref="aee4657eb1bf5d7d5b8a68dc51da1572f" args="() const " -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool WSql::WSqlDriver::hasError </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td> const<code> [inline]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Returns true if the there was an error during the last action, otherwise returns false. </p>
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00055">55</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<a class="anchor" id="a6c4bf314bfa0d19e476377891a949253"></a><!-- doxytag: member="WSql::WSqlDriver::isOpen" ref="a6c4bf314bfa0d19e476377891a949253" args="() const " -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool WSql::WSqlDriver::isOpen </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td> const<code> [inline, virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Returns true if the database connection is open; otherwise returns false. </p>
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00051">51</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<a class="anchor" id="aa81bf0a003e897f38574a8ee23348b8d"></a><!-- doxytag: member="WSql::WSqlDriver::isValid" ref="aa81bf0a003e897f38574a8ee23348b8d" args="() const " -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">virtual bool WSql::WSqlDriver::isValid </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td> const<code> [inline, virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00050">50</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<a class="anchor" id="a2a1f251900715cd1e45aa7a565a57253"></a><!-- doxytag: member="WSql::WSqlDriver::open" ref="a2a1f251900715cd1e45aa7a565a57253" args="()=0" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">bool WSql::WSqlDriver::open </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td><code> [pure virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Derived classes must reimplement this pure virtual function to open a database connection on the database</p>
<p>The function must return true on success and false on failure.</p>
<dl class="see"><dt><b>See also:</b></dt><dd>setOpen() </dd></dl>
<p>Implemented in <a class="el" href="class_w_sql_1_1_w_mysql_driver.html#ae53e50ad703fd76da1d34a52b5a844b8">WSql::WMysqlDriver</a>, and <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#a401f5a03ca5d1e288ade6598c5379a20">WSql::WSqliteDriver</a>.</p>
</div>
</div>
<a class="anchor" id="ad15803a5c5d4e8e1d80fec885ed13203"></a><!-- doxytag: member="WSql::WSqlDriver::query" ref="ad15803a5c5d4e8e1d80fec885ed13203" args="(std::string sql)=0" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">virtual bool WSql::WSqlDriver::query </td>
<td>(</td>
<td class="paramtype">std::string&#160;</td>
<td class="paramname"><em>sql</em></td><td>)</td>
<td><code> [pure virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Implemented in <a class="el" href="class_w_sql_1_1_w_mysql_driver.html#a16cbd55969cbe2421bcc5ebe2dd0d677">WSql::WMysqlDriver</a>, and <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#a4ba7ea260dd263e74d9c16c58e655434">WSql::WSqliteDriver</a>.</p>
</div>
</div>
<a class="anchor" id="ae5670416af2dc36911bc29478e5ad0e3"></a><!-- doxytag: member="WSql::WSqlDriver::result" ref="ae5670416af2dc36911bc29478e5ad0e3" args="(bool iscached=true)" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">virtual <a class="el" href="class_w_sql_1_1_w_sql_result.html">WSqlResult</a>* WSql::WSqlDriver::result </td>
<td>(</td>
<td class="paramtype">bool&#160;</td>
<td class="paramname"><em>iscached</em> = <code>true</code></td><td>)</td>
<td><code> [inline, virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Reimplemented in <a class="el" href="class_w_sql_1_1_w_mysql_driver.html#a064edf98eaa9453d358818d76627ef6b">WSql::WMysqlDriver</a>, and <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#a1cf0f135668cdd8299995c1ffff72724">WSql::WSqliteDriver</a>.</p>
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00048">48</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<a class="anchor" id="ae8e1c1685325f8c3fbab81992a0ff3de"></a><!-- doxytag: member="WSql::WSqlDriver::setDatabase" ref="ae8e1c1685325f8c3fbab81992a0ff3de" args="(WSqlDatabase *dp)" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void WSql::WSqlDriver::setDatabase </td>
<td>(</td>
<td class="paramtype"><a class="el" href="class_w_sql_1_1_w_sql_database.html">WSqlDatabase</a> *&#160;</td>
<td class="paramname"><em>dp</em></td><td>)</td>
<td><code> [inline]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00058">58</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<a class="anchor" id="aa5e7841c760ffc5c7dbc7c2593f8ecb3"></a><!-- doxytag: member="WSql::WSqlDriver::setError" ref="aa5e7841c760ffc5c7dbc7c2593f8ecb3" args="(const WSqlError &amp;e)" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void WSql::WSqlDriver::setError </td>
<td>(</td>
<td class="paramtype">const <a class="el" href="class_w_sql_1_1_w_sql_error.html">WSqlError</a> &amp;&#160;</td>
<td class="paramname"><em>error</em></td><td>)</td>
<td><code> [protected]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Sets the the current error to <em>error</em>. </p>
<p>This method sets the current error and pushes any previous error onto the error stack. </p>
<dl><dt><b>Parameters:</b></dt><dd>
<table class="params">
<tr><td class="paramname"><a class="el" href="class_w_sql_1_1_w_sql_error.html" title="The WSqlError class provides SQL database and driver error information.">WSqlError</a></td><td>error - the error to set </td></tr>
</table>
</dd>
</dl>
<p>Definition at line <a class="el" href="wsqldriver_8cpp_source.html#l00093">93</a> of file <a class="el" href="wsqldriver_8cpp_source.html">wsqldriver.cpp</a>.</p>
</div>
</div>
<a class="anchor" id="a334d7b76b1bf64c4d779b0196510faac"></a><!-- doxytag: member="WSql::WSqlDriver::setError" ref="a334d7b76b1bf64c4d779b0196510faac" args="(const char *text)" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void WSql::WSqlDriver::setError </td>
<td>(</td>
<td class="paramtype">const char *&#160;</td>
<td class="paramname"><em>text</em></td><td>)</td>
<td><code> [inline, protected]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00077">77</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<a class="anchor" id="ab1e89214bd9e0d8c9c0caaae52036287"></a><!-- doxytag: member="WSql::WSqlDriver::setError" ref="ab1e89214bd9e0d8c9c0caaae52036287" args="(const std::string &amp;text)" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void WSql::WSqlDriver::setError </td>
<td>(</td>
<td class="paramtype">const std::string &amp;&#160;</td>
<td class="paramname"><em>text</em></td><td>)</td>
<td><code> [inline, protected]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00074">74</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<a class="anchor" id="ad19e63bfa9c1101b314c168642d80938"></a><!-- doxytag: member="WSql::WSqlDriver::setError" ref="ad19e63bfa9c1101b314c168642d80938" args="(const std::string &amp;text, WSqlError::ErrorType type, WSqlError::ErrorSeverity severity, bool isvalid=true)" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void WSql::WSqlDriver::setError </td>
<td>(</td>
<td class="paramtype">const std::string &amp;&#160;</td>
<td class="paramname"><em>text</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="class_w_sql_1_1_w_sql_error.html#a8bcabd8bf1016ca27304a717ef3d78db">WSqlError::ErrorType</a>&#160;</td>
<td class="paramname"><em>type</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="class_w_sql_1_1_w_sql_error.html#a63b2672eb5c68164c4ff43443037f6d9">WSqlError::ErrorSeverity</a>&#160;</td>
<td class="paramname"><em>severity</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">bool&#160;</td>
<td class="paramname"><em>isvalid</em> = <code>true</code>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td><code> [protected]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Set an error with <em>text</em> and types and also set isValid. </p>
<p>A convenience function for creating and setting the error to an error with the message in <em>text</em> of ErrorType <em>type</em> and ErrorSeverity <em>severity</em>. Also sets hasError to be true and isValid to be <em>isvalid</em> - Note: the default for isvalid is "true". </p>
<dl><dt><b>Parameters:</b></dt><dd>
<table class="params">
<tr><td class="paramname">std::string</td><td>text - the message </td></tr>
<tr><td class="paramname"><a class="el" href="class_w_sql_1_1_w_sql_error.html#a8bcabd8bf1016ca27304a717ef3d78db">WSqlError::ErrorType</a></td><td>type - what kind of error </td></tr>
<tr><td class="paramname"><a class="el" href="class_w_sql_1_1_w_sql_error.html#a63b2672eb5c68164c4ff43443037f6d9">WSqlError::ErrorSeverity</a></td><td>severity - how severe the error is </td></tr>
<tr><td class="paramname">bool</td><td>isvalid - set the isValid flag of the driver to isvalid (default true). </td></tr>
</table>
</dd>
</dl>
<p>Definition at line <a class="el" href="wsqldriver_8cpp_source.html#l00080">80</a> of file <a class="el" href="wsqldriver_8cpp_source.html">wsqldriver.cpp</a>.</p>
</div>
</div>
<a class="anchor" id="a76938d8fa49e562f015d7e6eb7b6ed42"></a><!-- doxytag: member="WSql::WSqlDriver::setHasError" ref="a76938d8fa49e562f015d7e6eb7b6ed42" args="(bool e)" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void WSql::WSqlDriver::setHasError </td>
<td>(</td>
<td class="paramtype">bool&#160;</td>
<td class="paramname"><em>e</em></td><td>)</td>
<td><code> [inline, protected]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00067">67</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<a class="anchor" id="adb8b4302e38822dbc2fbe71889ab7724"></a><!-- doxytag: member="WSql::WSqlDriver::setIsOpen" ref="adb8b4302e38822dbc2fbe71889ab7724" args="(bool o)" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void WSql::WSqlDriver::setIsOpen </td>
<td>(</td>
<td class="paramtype">bool&#160;</td>
<td class="paramname"><em>o</em></td><td>)</td>
<td><code> [inline, protected]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00066">66</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<a class="anchor" id="a18022bccc41d920564c83b02339aa4f8"></a><!-- doxytag: member="WSql::WSqlDriver::setIsValid" ref="a18022bccc41d920564c83b02339aa4f8" args="(bool b)" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void WSql::WSqlDriver::setIsValid </td>
<td>(</td>
<td class="paramtype">bool&#160;</td>
<td class="paramname"><em>b</em></td><td>)</td>
<td><code> [inline, protected]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00065">65</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<a class="anchor" id="a2574f1f0d2083f1b0e05f4721f870a74"></a><!-- doxytag: member="WSql::WSqlDriver::tableMetaData" ref="a2574f1f0d2083f1b0e05f4721f870a74" args="(const std::string &amp;tableName)=0" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">virtual <a class="el" href="class_w_sql_1_1_w_sql_table.html">WSqlTable</a> WSql::WSqlDriver::tableMetaData </td>
<td>(</td>
<td class="paramtype">const std::string &amp;&#160;</td>
<td class="paramname"><em>tableName</em></td><td>)</td>
<td><code> [pure virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Implemented in <a class="el" href="class_w_sql_1_1_w_mysql_driver.html#aa770c3b864ee481dc6d83a1d4d49a164">WSql::WMysqlDriver</a>, and <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#aa74cc6840682c0ae5fe9bb2e4aa76a4d">WSql::WSqliteDriver</a>.</p>
</div>
</div>
<a class="anchor" id="adc7f0845587544ad92e3079542e844db"></a><!-- doxytag: member="WSql::WSqlDriver::tableNames" ref="adc7f0845587544ad92e3079542e844db" args="()=0" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::vector&lt; std::string &gt; WSql::WSqlDriver::tableNames </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td><code> [pure virtual]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Returns a list of the names of the tables in the database.</p>
<p><em>tableType</em> defines what types of tables to return in the list, meaning: normal tables, views, system tables or all of the above.</p>
<dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="namespace_w_sql.html#a2860958b4a0664bf26cd4959a7aaace8">WSql::TableType</a> </dd></dl>
<p>Implemented in <a class="el" href="class_w_sql_1_1_w_mysql_driver.html#aa55eb7fb3c030f4d47aae5fe18435cb6">WSql::WMysqlDriver</a>, and <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#aa7796f2d18f519f24016a9fa1f9e2f0b">WSql::WSqliteDriver</a>.</p>
</div>
</div>
<hr/><h2>Friends And Related Function Documentation</h2>
<a class="anchor" id="aec208bf350d9750fc15c0c908d7b989a"></a><!-- doxytag: member="WSql::WSqlDriver::WSqlDatabase" ref="aec208bf350d9750fc15c0c908d7b989a" args="" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">friend class <a class="el" href="class_w_sql_1_1_w_sql_database.html">WSqlDatabase</a><code> [friend]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00061">61</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<hr/><h2>Member Data Documentation</h2>
<a class="anchor" id="a6aac5abed866e56bd56ed20b7eef06f0"></a><!-- doxytag: member="WSql::WSqlDriver::_database" ref="a6aac5abed866e56bd56ed20b7eef06f0" args="" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="class_w_sql_1_1_w_sql_database.html">WSqlDatabase</a>* <a class="el" href="class_w_sql_1_1_w_sql_driver.html#a6aac5abed866e56bd56ed20b7eef06f0">WSql::WSqlDriver::_database</a><code> [protected]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00079">79</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<a class="anchor" id="a0fcc770ae53104549e68703eab08cab9"></a><!-- doxytag: member="WSql::WSqlDriver::_result" ref="a0fcc770ae53104549e68703eab08cab9" args="" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="class_w_sql_1_1_w_sql_result.html">WSqlResult</a>* <a class="el" href="class_w_sql_1_1_w_sql_driver.html#a0fcc770ae53104549e68703eab08cab9">WSql::WSqlDriver::_result</a><code> [protected]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00080">80</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<a class="anchor" id="a4eae8e8af5b50b1bc3a10bf528073724"></a><!-- doxytag: member="WSql::WSqlDriver::_tables" ref="a4eae8e8af5b50b1bc3a10bf528073724" args="" -->
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::vector&lt;<a class="el" href="class_w_sql_1_1_w_sql_table.html">WSqlTable</a>&gt; <a class="el" href="class_w_sql_1_1_w_sql_driver.html#a4eae8e8af5b50b1bc3a10bf528073724">WSql::WSqlDriver::_tables</a><code> [protected]</code></td>
</tr>
</table>
</div>
<div class="memdoc">
<p>Definition at line <a class="el" href="wsqldriver_8h_source.html#l00081">81</a> of file <a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a>.</p>
</div>
</div>
<hr/>The documentation for this class was generated from the following files:<ul>
<li>src/sql/<a class="el" href="wsqldriver_8h_source.html">wsqldriver.h</a></li>
<li>src/sql/<a class="el" href="wsqldriver_8cpp_source.html">wsqldriver.cpp</a></li>
</ul>
</div>
<!--- window showing the filter options -->
<div id="MSearchSelectWindow"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
onkeydown="return searchBox.OnSearchSelectKey(event)">
<a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(0)"><span class="SelectionMark">&#160;</span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark">&#160;</span>Classes</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark">&#160;</span>Namespaces</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark">&#160;</span>Files</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark">&#160;</span>Functions</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(5)"><span class="SelectionMark">&#160;</span>Variables</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(6)"><span class="SelectionMark">&#160;</span>Enumerations</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(7)"><span class="SelectionMark">&#160;</span>Enumerator</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(8)"><span class="SelectionMark">&#160;</span>Friends</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(9)"><span class="SelectionMark">&#160;</span>Defines</a></div>
<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="" frameborder="0"
name="MSearchResults" id="MSearchResults">
</iframe>
</div>
<hr class="footer"/><address class="footer"><small>Generated on Fri Nov 18 2011 21:01:46 for WORM by&#160;
<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.7.3 </small></address>
</body>
</html>