Sophie

Sophie

distrib > Fedora > 13 > x86_64 > by-pkgid > 1f68756f2311732dff7a7e2ea2a48123 > files > 27

elektra-devel-0.7.0-3.fc13.x86_64.rpm

<!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>Elektra Projekt: KDB Backends :: KDB access functions</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<link href="doxygen.css" rel="stylesheet" type="text/css"/>
</head>
<body>
<!-- Generated by Doxygen 1.6.1 -->
<div class="navigation" id="top">
  <div class="tabs">
    <ul>
      <li><a href="index.html"><span>Main&nbsp;Page</span></a></li>
      <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
      <li><a href="modules.html"><span>Modules</span></a></li>
    </ul>
  </div>
</div>
<div class="contents">
<h1>KDB Backends :: KDB access functions</h1>
<p>Methods to access the backend handle.  
<a href="#_details">More...</a></p>
<table border="0" cellpadding="0" cellspacing="0">
<tr><td colspan="2"><h2>Functions</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__backendhandle.html#ga97fab712e488c7ec3e198492106724ab">kdbhSetBackendData</a> (KDB *handle, void *data)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__backendhandle.html#gae463be8651422015fd12811ed66d20f3">kdbhGetBackendData</a> (const KDB *handle)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">KDBCap *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__backendhandle.html#gad077fae396d9be2b9d5e01b6f9f60318">kdbhSetCapability</a> (KDB *handle, KDBCap *cap)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">KDBCap *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__backendhandle.html#ga090cfa7483afbb159b75c975eb1d513c">kdbhGetCapability</a> (const KDB *handle)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">Trie *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__backendhandle.html#ga591d15bf10d8f4366ec7e1e9b8c6ddc7">kdbhGetTrie</a> (const KDB *handle)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__backendhandle.html#ga1c5c086715963f34f2a88fac89b62f82">kdbhSetTrie</a> (KDB *handle, Trie *trie)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">const Key *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__backendhandle.html#ga8b5612940fc9bc56e99c15ecc427cbb2">kdbhGetMountpoint</a> (KDB *handle)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__backendhandle.html#ga65c8878c24776c77716ac9e8abe1a29f">kdbhSetMountpoint</a> (KDB *handle, const Key *mountpoint)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">KeySet *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="group__backendhandle.html#gab14dc8708c2ae4ffcba6cfb130019115">kdbhGetConfig</a> (KDB *handle)</td></tr>
</table>
<hr/><a name="_details"></a><h2>Detailed Description</h2>
<p>Methods to access the backend handle. </p>
<p>To use them: </p>
<div class="fragment"><pre class="fragment"><span class="preprocessor"> #include &lt;kdb.h&gt;</span>
</pre></div><p>These functions provide access to the information stored in Backend Handles. </p>
<hr/><h2>Function Documentation</h2>
<a class="anchor" id="gae463be8651422015fd12811ed66d20f3"></a><!-- doxytag: member="kdbhandle.c::kdbhGetBackendData" ref="gae463be8651422015fd12811ed66d20f3" args="(const KDB *handle)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void* kdbhGetBackendData </td>
          <td>(</td>
          <td class="paramtype">const KDB *&nbsp;</td>
          <td class="paramname"> <em>handle</em></td>
          <td>&nbsp;)&nbsp;</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Get the previously set backend-specific <code>data</code> from the <code>handle</code>.</p>
<p>This is useful when your backend have a backend-global context or environment.</p>
<p>This method will probably be called everytime one of your kdb*() implementations is called. And if you change something inside the data, you don't have to <a class="el" href="group__backendhandle.html#ga97fab712e488c7ec3e198492106724ab">kdbhSetBackendData()</a> again, bacause you are manipulating your data, and not a copy of it.</p>
<dl class="user"><dt><b>Example:</b></dt><dd><div class="fragment"><pre class="fragment"><span class="keyword">struct </span>MyBackendData {
 <span class="keywordtype">int</span> context1;
 <span class="keywordtype">int</span> context2;
};

<span class="keywordtype">int</span> kdbOpen_mybackend(KDB *handle) {
        <span class="keyword">struct </span>MyBackendData *context;

        context=malloc(<span class="keyword">sizeof</span>(<span class="keyword">struct</span> MyBackendData));
 
        <span class="comment">// a random initialization...</span>
        context-&gt;context1=1;
        context-&gt;context2=2;

        <a class="code" href="group__backendhandle.html#ga97fab712e488c7ec3e198492106724ab">kdbhSetBackendData</a>(*handle,context);

        <span class="keywordflow">return</span> 0;
}

<span class="keywordtype">int</span> kdbGetKey_maybackend(KDB handle) {
        <span class="keyword">struct </span>MyBackendData *context;

        context=<a class="code" href="group__backendhandle.html#gae463be8651422015fd12811ed66d20f3">kdbhGetBackendData</a>(handle);

        <span class="comment">// No do something with the context</span>
        . . .

        <span class="keywordflow">return</span> 0;
}
</pre></div></dd></dl>
<p>On the <a class="el" href="group__kdb.html#gad9bb8bd3f1296bfa77cc9a1b41b7a859">kdbClose()</a> implementation of your backend, you must remember to free all resources associated to your data.</p>
<dl class="user"><dt><b>Example of kdbClose() implementation that correctly cleans the context:</b></dt><dd><div class="fragment"><pre class="fragment"><span class="keywordtype">int</span> kdbClose_mybackend(KDB &amp;handle) {
        <span class="keyword">struct </span>MyBackendData *context;

        context=<a class="code" href="group__backendhandle.html#gae463be8651422015fd12811ed66d20f3">kdbhGetBackendData</a>(handle);
        free(context);

        <span class="keywordflow">return</span> 0;
}
</pre></div> </dd></dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>a pointer to the data previously set be <a class="el" href="group__backendhandle.html#ga97fab712e488c7ec3e198492106724ab">kdbhSetBackendData()</a> </dd></dl>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>handle</em>&nbsp;</td><td>contains internal information of <a class="el" href="group__kdb.html#gab7be60c387892d2235907836c5060e1f">opened </a> key database </td></tr>
  </table>
  </dd>
</dl>

</div>
</div>
<a class="anchor" id="ga090cfa7483afbb159b75c975eb1d513c"></a><!-- doxytag: member="kdbhandle.c::kdbhGetCapability" ref="ga090cfa7483afbb159b75c975eb1d513c" args="(const KDB *handle)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">KDBCap* kdbhGetCapability </td>
          <td>(</td>
          <td class="paramtype">const KDB *&nbsp;</td>
          <td class="paramname"> <em>handle</em></td>
          <td>&nbsp;)&nbsp;</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Gets capability for handle.</p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>handle</em>&nbsp;</td><td>contains internal information of <a class="el" href="group__kdb.html#gab7be60c387892d2235907836c5060e1f">opened </a> key database </td></tr>
  </table>
  </dd>
</dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>The backend name set in <code>handle</code>. </dd></dl>

</div>
</div>
<a class="anchor" id="gab14dc8708c2ae4ffcba6cfb130019115"></a><!-- doxytag: member="kdbhandle.c::kdbhGetConfig" ref="gab14dc8708c2ae4ffcba6cfb130019115" args="(KDB *handle)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">KeySet* kdbhGetConfig </td>
          <td>(</td>
          <td class="paramtype">KDB *&nbsp;</td>
          <td class="paramname"> <em>handle</em></td>
          <td>&nbsp;)&nbsp;</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Returns configuration for handle.</p>
<p>Every backend may have its own configuration using a Keyset.</p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>handle</em>&nbsp;</td><td>contains internal information of <a class="el" href="group__kdb.html#gab7be60c387892d2235907836c5060e1f">opened </a> key database </td></tr>
  </table>
  </dd>
</dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>the keyset containing configuration for a backend </dd></dl>

</div>
</div>
<a class="anchor" id="ga8b5612940fc9bc56e99c15ecc427cbb2"></a><!-- doxytag: member="kdbhandle.c::kdbhGetMountpoint" ref="ga8b5612940fc9bc56e99c15ecc427cbb2" args="(KDB *handle)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">const Key* kdbhGetMountpoint </td>
          <td>(</td>
          <td class="paramtype">KDB *&nbsp;</td>
          <td class="paramname"> <em>handle</em></td>
          <td>&nbsp;)&nbsp;</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Gets mountpoint for handle.</p>
<p>Every mounted backend has a specific mountpoint where it is mounted. You may need to know where you were mounted inside a backend to calculate relative pathes.</p>
<p>The <a class="el" href="group__keyname.html#ga8e805c726a60da921d3736cda7813513">keyName()</a> is where the backend is mounted, keyString() gives the name of which backend is mounted.</p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>handle</em>&nbsp;</td><td>contains internal information of <a class="el" href="group__kdb.html#gab7be60c387892d2235907836c5060e1f">opened </a> key database </td></tr>
  </table>
  </dd>
</dl>
<dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="group__backendhandle.html#ga65c8878c24776c77716ac9e8abe1a29f">kdbhSetMountpoint()</a> </dd></dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>The Key containing the mountpoint. </dd></dl>

</div>
</div>
<a class="anchor" id="ga591d15bf10d8f4366ec7e1e9b8c6ddc7"></a><!-- doxytag: member="kdbhandle.c::kdbhGetTrie" ref="ga591d15bf10d8f4366ec7e1e9b8c6ddc7" args="(const KDB *handle)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">Trie* kdbhGetTrie </td>
          <td>(</td>
          <td class="paramtype">const KDB *&nbsp;</td>
          <td class="paramname"> <em>handle</em></td>
          <td>&nbsp;)&nbsp;</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Gets trie for handle.</p>
<p>The trie is a datastructure containing the mounted backends.</p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>handle</em>&nbsp;</td><td>contains internal information of <a class="el" href="group__kdb.html#gab7be60c387892d2235907836c5060e1f">opened </a> key database </td></tr>
  </table>
  </dd>
</dl>
<dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="group__backendhandle.html#ga1c5c086715963f34f2a88fac89b62f82">kdbhSetTrie()</a> </dd></dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>The backend name set in <code>handle</code>. </dd></dl>

</div>
</div>
<a class="anchor" id="ga97fab712e488c7ec3e198492106724ab"></a><!-- doxytag: member="kdbhandle.c::kdbhSetBackendData" ref="ga97fab712e488c7ec3e198492106724ab" args="(KDB *handle, void *data)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void* kdbhSetBackendData </td>
          <td>(</td>
          <td class="paramtype">KDB *&nbsp;</td>
          <td class="paramname"> <em>handle</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">void *&nbsp;</td>
          <td class="paramname"> <em>data</em></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Set some backend-specific <code>data</code> in the <code>handle</code>.</p>
<p>This is useful when your backend have a backend-global context or environment.</p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>handle</em>&nbsp;</td><td>contains internal information of <a class="el" href="group__kdb.html#gab7be60c387892d2235907836c5060e1f">opened </a> key database </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>data</em>&nbsp;</td><td>a pointer to general data specific to a backend implementation. </td></tr>
  </table>
  </dd>
</dl>
<dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="group__backendhandle.html#gae463be8651422015fd12811ed66d20f3">kdbhGetBackendData()</a> </dd></dl>

</div>
</div>
<a class="anchor" id="gad077fae396d9be2b9d5e01b6f9f60318"></a><!-- doxytag: member="kdbhandle.c::kdbhSetCapability" ref="gad077fae396d9be2b9d5e01b6f9f60318" args="(KDB *handle, KDBCap *cap)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">KDBCap* kdbhSetCapability </td>
          <td>(</td>
          <td class="paramtype">KDB *&nbsp;</td>
          <td class="paramname"> <em>handle</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">KDBCap *&nbsp;</td>
          <td class="paramname"> <em>cap</em></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Sets capabilty for handle.</p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>cap</em>&nbsp;</td><td>a pointer to capability structure </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>handle</em>&nbsp;</td><td>contains internal information of <a class="el" href="group__kdb.html#gab7be60c387892d2235907836c5060e1f">opened </a> key database </td></tr>
  </table>
  </dd>
</dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>The backend name set in <code>handle</code>. </dd></dl>

</div>
</div>
<a class="anchor" id="ga65c8878c24776c77716ac9e8abe1a29f"></a><!-- doxytag: member="kdbhandle.c::kdbhSetMountpoint" ref="ga65c8878c24776c77716ac9e8abe1a29f" args="(KDB *handle, const Key *mountpoint)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void kdbhSetMountpoint </td>
          <td>(</td>
          <td class="paramtype">KDB *&nbsp;</td>
          <td class="paramname"> <em>handle</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const Key *&nbsp;</td>
          <td class="paramname"> <em>mountpoint</em></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Sets mountpoint for handle.</p>
<p>You must not change the mountpoint inside your backend, it was set correctly already for you.</p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>handle</em>&nbsp;</td><td>contains internal information of <a class="el" href="group__kdb.html#gab7be60c387892d2235907836c5060e1f">opened </a> key database </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>mountpoint</em>&nbsp;</td><td>the key containing as name where backend is mounted and as value the backendname </td></tr>
  </table>
  </dd>
</dl>
<dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="group__backendhandle.html#ga8b5612940fc9bc56e99c15ecc427cbb2">kdbhGetMountpoint()</a> </dd></dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>nothing </dd></dl>

</div>
</div>
<a class="anchor" id="ga1c5c086715963f34f2a88fac89b62f82"></a><!-- doxytag: member="kdbhandle.c::kdbhSetTrie" ref="ga1c5c086715963f34f2a88fac89b62f82" args="(KDB *handle, Trie *trie)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void kdbhSetTrie </td>
          <td>(</td>
          <td class="paramtype">KDB *&nbsp;</td>
          <td class="paramname"> <em>handle</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">Trie *&nbsp;</td>
          <td class="paramname"> <em>trie</em></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Sets trie for handle.</p>
<p>The trie is a datastructure containing the mounted backends. This must not done inside backends, it was set correctly already for you.</p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>handle</em>&nbsp;</td><td>contains internal information of <a class="el" href="group__kdb.html#gab7be60c387892d2235907836c5060e1f">opened </a> key database </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>trie</em>&nbsp;</td><td>the datastructure referencing to the other handles of backends </td></tr>
  </table>
  </dd>
</dl>
<dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="group__backendhandle.html#ga591d15bf10d8f4366ec7e1e9b8c6ddc7">kdbhGetTrie()</a> </dd></dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>nothing </dd></dl>

</div>
</div>
</div>
<hr size="1"/><address style="text-align: right;"><small>Generated on 8 Nov 2009 for Elektra Projekt by&nbsp;
<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.6.1 </small></address>
</body>
</html>