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.

366 lines
22 KiB

  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>WORM: WSql::WSqliteDriver Class Reference</title>
  6. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  7. <link href="search/search.css" rel="stylesheet" type="text/css"/>
  8. <script type="text/javascript" src="search/search.js"></script>
  9. <link href="doxygen.css" rel="stylesheet" type="text/css"/>
  10. </head>
  11. <body onload='searchBox.OnSelectItem(0);'>
  12. <!-- Generated by Doxygen 1.7.3 -->
  13. <script type="text/javascript"><!--
  14. var searchBox = new SearchBox("searchBox", "search",false,'Search');
  15. --></script>
  16. <script type="text/javascript">
  17. function hasClass(ele,cls) {
  18. return ele.className.match(new RegExp('(\\s|^)'+cls+'(\\s|$)'));
  19. }
  20. function addClass(ele,cls) {
  21. if (!this.hasClass(ele,cls)) ele.className += " "+cls;
  22. }
  23. function removeClass(ele,cls) {
  24. if (hasClass(ele,cls)) {
  25. var reg = new RegExp('(\\s|^)'+cls+'(\\s|$)');
  26. ele.className=ele.className.replace(reg,' ');
  27. }
  28. }
  29. function toggleVisibility(linkObj) {
  30. var base = linkObj.getAttribute('id');
  31. var summary = document.getElementById(base + '-summary');
  32. var content = document.getElementById(base + '-content');
  33. var trigger = document.getElementById(base + '-trigger');
  34. if ( hasClass(linkObj,'closed') ) {
  35. summary.style.display = 'none';
  36. content.style.display = 'block';
  37. trigger.src = 'open.png';
  38. removeClass(linkObj,'closed');
  39. addClass(linkObj,'opened');
  40. } else if ( hasClass(linkObj,'opened') ) {
  41. summary.style.display = 'block';
  42. content.style.display = 'none';
  43. trigger.src = 'closed.png';
  44. removeClass(linkObj,'opened');
  45. addClass(linkObj,'closed');
  46. }
  47. return false;
  48. }
  49. </script>
  50. <div id="top">
  51. <div id="titlearea">
  52. <table cellspacing="0" cellpadding="0">
  53. <tbody>
  54. <tr style="height: 56px;">
  55. <td id="projectlogo"><img alt="Logo" src="worm_sm.png"></td>
  56. <td style="padding-left: 0.5em;">
  57. <div id="projectname">WORM&#160;<span id="projectnumber">0.2</span></div>
  58. <div id="projectbrief">A C++ DAL/ORM code generation framework</div>
  59. </td>
  60. </tr>
  61. </tbody>
  62. </table>
  63. </div>
  64. <div id="navrow1" class="tabs">
  65. <ul class="tablist">
  66. <li><a href="index.html"><span>Main&#160;Page</span></a></li>
  67. <li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
  68. <li><a href="namespaces.html"><span>Namespaces</span></a></li>
  69. <li class="current"><a href="annotated.html"><span>Classes</span></a></li>
  70. <li><a href="files.html"><span>Files</span></a></li>
  71. <li id="searchli">
  72. <div id="MSearchBox" class="MSearchBoxInactive">
  73. <span class="left">
  74. <img id="MSearchSelect" src="search/mag_sel.png"
  75. onmouseover="return searchBox.OnSearchSelectShow()"
  76. onmouseout="return searchBox.OnSearchSelectHide()"
  77. alt=""/>
  78. <input type="text" id="MSearchField" value="Search" accesskey="S"
  79. onfocus="searchBox.OnSearchFieldFocus(true)"
  80. onblur="searchBox.OnSearchFieldFocus(false)"
  81. onkeyup="searchBox.OnSearchFieldChange(event)"/>
  82. </span><span class="right">
  83. <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
  84. </span>
  85. </div>
  86. </li>
  87. </ul>
  88. </div>
  89. <div id="navrow2" class="tabs2">
  90. <ul class="tablist">
  91. <li><a href="annotated.html"><span>Class&#160;List</span></a></li>
  92. <li><a href="classes.html"><span>Class&#160;Index</span></a></li>
  93. <li><a href="hierarchy.html"><span>Class&#160;Hierarchy</span></a></li>
  94. <li><a href="functions.html"><span>Class&#160;Members</span></a></li>
  95. </ul>
  96. </div>
  97. <div id="nav-path" class="navpath">
  98. <ul>
  99. <li class="navelem"><a class="el" href="namespace_w_sql.html">WSql</a> </li>
  100. <li class="navelem"><a class="el" href="class_w_sql_1_1_w_sqlite_driver.html">WSqliteDriver</a> </li>
  101. </ul>
  102. </div>
  103. </div>
  104. <div class="header">
  105. <div class="summary">
  106. <a href="#pub-methods">Public Member Functions</a> </div>
  107. <div class="headertitle">
  108. <h1>WSql::WSqliteDriver Class Reference</h1> </div>
  109. </div>
  110. <div class="contents">
  111. <!-- doxytag: class="WSql::WSqliteDriver" --><!-- doxytag: inherits="WSql::WSqlDriver" -->
  112. <p><code>#include &lt;<a class="el" href="wsqlitedriver_8h_source.html">wsqlitedriver.h</a>&gt;</code></p>
  113. <div id="dynsection-0" onclick="return toggleVisibility(this)" class="dynheader closed" style="cursor:pointer;">
  114. <img id="dynsection-0-trigger" src="closed.png"/> Inheritance diagram for WSql::WSqliteDriver:</div>
  115. <div id="dynsection-0-summary" class="dynsummary" style="display:block;">
  116. </div>
  117. <div id="dynsection-0-content" class="dyncontent" style="display:none;">
  118. <div class="center">
  119. <img src="class_w_sql_1_1_w_sqlite_driver.png" usemap="#WSql::WSqliteDriver_map" alt=""/>
  120. <map id="WSql::WSqliteDriver_map" name="WSql::WSqliteDriver_map">
  121. <area href="class_w_sql_1_1_w_sql_driver.html" alt="WSql::WSqlDriver" shape="rect" coords="0,0,123,24"/>
  122. </map>
  123. </div></div>
  124. <p><a href="class_w_sql_1_1_w_sqlite_driver-members.html">List of all members.</a></p>
  125. <table class="memberdecls">
  126. <tr><td colspan="2"><h2><a name="pub-methods"></a>
  127. Public Member Functions</h2></td></tr>
  128. <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_sqlite_driver.html#a9c3c650f052fe64490b0c0607c75a379">WSqliteDriver</a> (<a class="el" href="class_w_sql_1_1_w_sql_database.html">WSqlDatabase</a> *db)</td></tr>
  129. <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_sqlite_driver.html#aedc78f4e6972c7df4388f8e960424d53">~WSqliteDriver</a> ()</td></tr>
  130. <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_sqlite_driver.html#a401f5a03ca5d1e288ade6598c5379a20">open</a> ()</td></tr>
  131. <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_sqlite_driver.html#ac80543216d537dab91b382488042c416">close</a> ()</td></tr>
  132. <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_sqlite_driver.html#a4ba7ea260dd263e74d9c16c58e655434">query</a> (std::string sql)</td></tr>
  133. <tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Send the query <em>sql</em> to the database. <a href="#a4ba7ea260dd263e74d9c16c58e655434"></a><br/></td></tr>
  134. <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_sqlite_driver.html#a1cf0f135668cdd8299995c1ffff72724">result</a> (bool iscached=true)</td></tr>
  135. <tr><td class="memItemLeft" align="right" valign="top">std::vector&lt; std::string &gt;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#aa7796f2d18f519f24016a9fa1f9e2f0b">tableNames</a> ()</td></tr>
  136. <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_sqlite_driver.html#aa74cc6840682c0ae5fe9bb2e4aa76a4d">tableMetaData</a> (const std::string &amp;tableName)</td></tr>
  137. </table>
  138. <hr/><a name="_details"></a><h2>Detailed Description</h2>
  139. <div class="textblock"><p>driver for SQlite3 databases This class provides a driver for SQlite3 databases.</p>
  140. <p>DANGER: USE AT YOUR OWN RISK!! NOT RECOMMENDED.</p>
  141. <dl class="todo"><dt><b><a class="el" href="todo.html#_todo000014">Todo:</a></b></dt><dd>This driver is unfinished. Basic functionality is there but it is not, ah, elegant. Metadata is incomplete, all results are cached locally and there may be strange behavior. Basically I have done enough to get sufficient metadata for the ORM generator (except indices still) and <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#a4ba7ea260dd263e74d9c16c58e655434" title="Send the query sql to the database.">query()</a> will perform the query and return a result via <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#a1cf0f135668cdd8299995c1ffff72724">getResult()</a>. <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#aa7796f2d18f519f24016a9fa1f9e2f0b">tableNames()</a> works and <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#aa74cc6840682c0ae5fe9bb2e4aa76a4d">tableMetaData()</a> works as well (with the above caveats). Transactions are not supported and I seriously doubt that this is thread safe. It quite is crude at the moment - your milage may vary. It _might_ work for you but at this point I don't recommend it for production (10/10/2011)</dd></dl>
  142. <p>(at a minimum) : </p>
  143. <ul>
  144. <li>finish initializing the indices and fully initialize 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>. </li>
  145. <li>clean up some of the logic and make use of <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#a4ba7ea260dd263e74d9c16c58e655434" title="Send the query sql to the database.">query()</a> rather than reproducing code for queries. </li>
  146. <li>break up <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#a4ba7ea260dd263e74d9c16c58e655434" title="Send the query sql to the database.">query()</a> and handle errors properly </li>
  147. <li>see the note by <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#a4ba7ea260dd263e74d9c16c58e655434" title="Send the query sql to the database.">query()</a> about creating a result set so that fields exist and have names even if the value is empty (ie. NULL). This is a valid return in SQL and should be there! </li>
  148. <li>implement transactions </li>
  149. <li>if we _must_ parse the create statements .. this needs redone correctly - it is a bit buggy, awkward and very inefficient (a quick fix). Alternately, figure out some way to get sqlite to provide the metadata correctly and reliably at _any_ time (meaning, even if a table happens to be empty ..). </li>
  150. <li>redo the columns mapping mess .. std::map is overkill, a quick fix.. </li>
  151. <li>general safety checks, eliminate code duplication, memory checks, testing .. etc.</li>
  152. </ul>
  153. <dl class="see"><dt><b>See also:</b></dt><dd><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> WSqlMysqlDriver </dd></dl>
  154. <p>Definition at line <a class="el" href="wsqlitedriver_8h_source.html#l00033">33</a> of file <a class="el" href="wsqlitedriver_8h_source.html">wsqlitedriver.h</a>.</p>
  155. </div><hr/><h2>Constructor &amp; Destructor Documentation</h2>
  156. <a class="anchor" id="a9c3c650f052fe64490b0c0607c75a379"></a><!-- doxytag: member="WSql::WSqliteDriver::WSqliteDriver" ref="a9c3c650f052fe64490b0c0607c75a379" args="(WSqlDatabase *db)" -->
  157. <div class="memitem">
  158. <div class="memproto">
  159. <table class="memname">
  160. <tr>
  161. <td class="memname">WSql::WSqliteDriver::WSqliteDriver </td>
  162. <td>(</td>
  163. <td class="paramtype"><a class="el" href="class_w_sql_1_1_w_sql_database.html">WSqlDatabase</a> *&#160;</td>
  164. <td class="paramname"><em>db</em></td><td>)</td>
  165. <td></td>
  166. </tr>
  167. </table>
  168. </div>
  169. <div class="memdoc">
  170. <p>Definition at line <a class="el" href="wsqlitedriver_8cpp_source.html#l00212">212</a> of file <a class="el" href="wsqlitedriver_8cpp_source.html">wsqlitedriver.cpp</a>.</p>
  171. </div>
  172. </div>
  173. <a class="anchor" id="aedc78f4e6972c7df4388f8e960424d53"></a><!-- doxytag: member="WSql::WSqliteDriver::~WSqliteDriver" ref="aedc78f4e6972c7df4388f8e960424d53" args="()" -->
  174. <div class="memitem">
  175. <div class="memproto">
  176. <table class="memname">
  177. <tr>
  178. <td class="memname">WSql::WSqliteDriver::~WSqliteDriver </td>
  179. <td>(</td>
  180. <td class="paramname"></td><td>)</td>
  181. <td></td>
  182. </tr>
  183. </table>
  184. </div>
  185. <div class="memdoc">
  186. <p>Definition at line <a class="el" href="wsqlitedriver_8cpp_source.html#l00217">217</a> of file <a class="el" href="wsqlitedriver_8cpp_source.html">wsqlitedriver.cpp</a>.</p>
  187. </div>
  188. </div>
  189. <hr/><h2>Member Function Documentation</h2>
  190. <a class="anchor" id="ac80543216d537dab91b382488042c416"></a><!-- doxytag: member="WSql::WSqliteDriver::close" ref="ac80543216d537dab91b382488042c416" args="()" -->
  191. <div class="memitem">
  192. <div class="memproto">
  193. <table class="memname">
  194. <tr>
  195. <td class="memname">void WSql::WSqliteDriver::close </td>
  196. <td>(</td>
  197. <td class="paramname"></td><td>)</td>
  198. <td><code> [virtual]</code></td>
  199. </tr>
  200. </table>
  201. </div>
  202. <div class="memdoc">
  203. <p>Derived classes must reimplement this pure virtual function in order to close the database connection. Return true on success, false on failure.</p>
  204. <dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#a401f5a03ca5d1e288ade6598c5379a20">open()</a>, setOpen() </dd></dl>
  205. <p>Implements <a class="el" href="class_w_sql_1_1_w_sql_driver.html#a17afc1e43627a2a952e76d04420dead0">WSql::WSqlDriver</a>.</p>
  206. <p>Definition at line <a class="el" href="wsqlitedriver_8cpp_source.html#l00262">262</a> of file <a class="el" href="wsqlitedriver_8cpp_source.html">wsqlitedriver.cpp</a>.</p>
  207. </div>
  208. </div>
  209. <a class="anchor" id="a401f5a03ca5d1e288ade6598c5379a20"></a><!-- doxytag: member="WSql::WSqliteDriver::open" ref="a401f5a03ca5d1e288ade6598c5379a20" args="()" -->
  210. <div class="memitem">
  211. <div class="memproto">
  212. <table class="memname">
  213. <tr>
  214. <td class="memname">bool WSql::WSqliteDriver::open </td>
  215. <td>(</td>
  216. <td class="paramname"></td><td>)</td>
  217. <td><code> [virtual]</code></td>
  218. </tr>
  219. </table>
  220. </div>
  221. <div class="memdoc">
  222. <p>Derived classes must reimplement this pure virtual function to open a database connection on the database</p>
  223. <p>The function must return true on success and false on failure.</p>
  224. <dl class="see"><dt><b>See also:</b></dt><dd>setOpen() </dd></dl>
  225. <p>Implements <a class="el" href="class_w_sql_1_1_w_sql_driver.html#a2a1f251900715cd1e45aa7a565a57253">WSql::WSqlDriver</a>.</p>
  226. <p>Definition at line <a class="el" href="wsqlitedriver_8cpp_source.html#l00241">241</a> of file <a class="el" href="wsqlitedriver_8cpp_source.html">wsqlitedriver.cpp</a>.</p>
  227. </div>
  228. </div>
  229. <a class="anchor" id="a4ba7ea260dd263e74d9c16c58e655434"></a><!-- doxytag: member="WSql::WSqliteDriver::query" ref="a4ba7ea260dd263e74d9c16c58e655434" args="(std::string sql)" -->
  230. <div class="memitem">
  231. <div class="memproto">
  232. <table class="memname">
  233. <tr>
  234. <td class="memname">bool WSql::WSqliteDriver::query </td>
  235. <td>(</td>
  236. <td class="paramtype">std::string&#160;</td>
  237. <td class="paramname"><em>sql</em></td><td>)</td>
  238. <td><code> [virtual]</code></td>
  239. </tr>
  240. </table>
  241. </div>
  242. <div class="memdoc">
  243. <p>Send the query <em>sql</em> to the database. </p>
  244. <dl class="todo"><dt><b><a class="el" href="todo.html#_todo000016">Todo:</a></b></dt><dd>refactor this using metadata to construct a proper result set .. sqlite doesn't return things in orderly fashion - if a field is empty (i.e. NULL) it just doesn't include it in the results (ARG!), i _think_ and other strange random behavior is observed ..- so, we need to construct a skeleton result set from metadata and then fill it leaving the appropriate gaps such that the field name will _always_ be there. We can't simply refer to tableMetaData as it may be a join or such - which would mean parsing the query, etc..ugly The problem is that we cannot rely on sqlite to return metadata if, for instance, the query returns no results.. Consider using sqlite3_column_metadata. Also, some of this might be better moved to <a class="el" href="class_w_sql_1_1_w_sqlite_driver.html#a1cf0f135668cdd8299995c1ffff72724">getResult()</a></dd></dl>
  245. <dl><dt><b>Parameters:</b></dt><dd>
  246. <table class="params">
  247. <tr><td class="paramname">std::string</td><td>sql containing the query string </td></tr>
  248. </table>
  249. </dd>
  250. </dl>
  251. <dl><dt><b>Return values:</b></dt><dd>
  252. <table class="retval">
  253. <tr><td class="paramname">bool</td><td></td></tr>
  254. </table>
  255. </dd>
  256. </dl>
  257. <p>Implements <a class="el" href="class_w_sql_1_1_w_sql_driver.html#ad15803a5c5d4e8e1d80fec885ed13203">WSql::WSqlDriver</a>.</p>
  258. <p>Definition at line <a class="el" href="wsqlitedriver_8cpp_source.html#l00292">292</a> of file <a class="el" href="wsqlitedriver_8cpp_source.html">wsqlitedriver.cpp</a>.</p>
  259. </div>
  260. </div>
  261. <a class="anchor" id="a1cf0f135668cdd8299995c1ffff72724"></a><!-- doxytag: member="WSql::WSqliteDriver::result" ref="a1cf0f135668cdd8299995c1ffff72724" args="(bool iscached=true)" -->
  262. <div class="memitem">
  263. <div class="memproto">
  264. <table class="memname">
  265. <tr>
  266. <td class="memname"><a class="el" href="class_w_sql_1_1_w_sql_result.html">WSqlResult</a> * WSql::WSqliteDriver::result </td>
  267. <td>(</td>
  268. <td class="paramtype">bool&#160;</td>
  269. <td class="paramname"><em>iscached</em> = <code>true</code></td><td>)</td>
  270. <td><code> [virtual]</code></td>
  271. </tr>
  272. </table>
  273. </div>
  274. <div class="memdoc">
  275. <p>Reimplemented from <a class="el" href="class_w_sql_1_1_w_sql_driver.html#ae5670416af2dc36911bc29478e5ad0e3">WSql::WSqlDriver</a>.</p>
  276. <p>Definition at line <a class="el" href="wsqlitedriver_8cpp_source.html#l00352">352</a> of file <a class="el" href="wsqlitedriver_8cpp_source.html">wsqlitedriver.cpp</a>.</p>
  277. </div>
  278. </div>
  279. <a class="anchor" id="aa74cc6840682c0ae5fe9bb2e4aa76a4d"></a><!-- doxytag: member="WSql::WSqliteDriver::tableMetaData" ref="aa74cc6840682c0ae5fe9bb2e4aa76a4d" args="(const std::string &amp;tableName)" -->
  280. <div class="memitem">
  281. <div class="memproto">
  282. <table class="memname">
  283. <tr>
  284. <td class="memname"><a class="el" href="class_w_sql_1_1_w_sql_table.html">WSqlTable</a> WSql::WSqliteDriver::tableMetaData </td>
  285. <td>(</td>
  286. <td class="paramtype">const std::string &amp;&#160;</td>
  287. <td class="paramname"><em>tableName</em></td><td>)</td>
  288. <td><code> [virtual]</code></td>
  289. </tr>
  290. </table>
  291. </div>
  292. <div class="memdoc">
  293. <p>Implements <a class="el" href="class_w_sql_1_1_w_sql_driver.html#a2574f1f0d2083f1b0e05f4721f870a74">WSql::WSqlDriver</a>.</p>
  294. <p>Definition at line <a class="el" href="wsqlitedriver_8cpp_source.html#l00384">384</a> of file <a class="el" href="wsqlitedriver_8cpp_source.html">wsqlitedriver.cpp</a>.</p>
  295. </div>
  296. </div>
  297. <a class="anchor" id="aa7796f2d18f519f24016a9fa1f9e2f0b"></a><!-- doxytag: member="WSql::WSqliteDriver::tableNames" ref="aa7796f2d18f519f24016a9fa1f9e2f0b" args="()" -->
  298. <div class="memitem">
  299. <div class="memproto">
  300. <table class="memname">
  301. <tr>
  302. <td class="memname">std::vector&lt; std::string &gt; WSql::WSqliteDriver::tableNames </td>
  303. <td>(</td>
  304. <td class="paramname"></td><td>)</td>
  305. <td><code> [virtual]</code></td>
  306. </tr>
  307. </table>
  308. </div>
  309. <div class="memdoc">
  310. <dl class="todo"><dt><b><a class="el" href="todo.html#_todo000017">Todo:</a></b></dt><dd>support table type flag .. views, information schema </dd></dl>
  311. <p>Implements <a class="el" href="class_w_sql_1_1_w_sql_driver.html#adc7f0845587544ad92e3079542e844db">WSql::WSqlDriver</a>.</p>
  312. <p>Definition at line <a class="el" href="wsqlitedriver_8cpp_source.html#l00360">360</a> of file <a class="el" href="wsqlitedriver_8cpp_source.html">wsqlitedriver.cpp</a>.</p>
  313. </div>
  314. </div>
  315. <hr/>The documentation for this class was generated from the following files:<ul>
  316. <li>src/sql/drivers/<a class="el" href="wsqlitedriver_8h_source.html">wsqlitedriver.h</a></li>
  317. <li>src/sql/drivers/<a class="el" href="wsqlitedriver_8cpp_source.html">wsqlitedriver.cpp</a></li>
  318. </ul>
  319. </div>
  320. <!--- window showing the filter options -->
  321. <div id="MSearchSelectWindow"
  322. onmouseover="return searchBox.OnSearchSelectShow()"
  323. onmouseout="return searchBox.OnSearchSelectHide()"
  324. onkeydown="return searchBox.OnSearchSelectKey(event)">
  325. <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>
  326. <!-- iframe showing the search results (closed by default) -->
  327. <div id="MSearchResultsWindow">
  328. <iframe src="" frameborder="0"
  329. name="MSearchResults" id="MSearchResults">
  330. </iframe>
  331. </div>
  332. <hr class="footer"/><address class="footer"><small>Generated on Fri Nov 18 2011 21:01:46 for WORM by&#160;
  333. <a href="http://www.doxygen.org/index.html">
  334. <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.7.3 </small></address>
  335. </body>
  336. </html>