Sophie

Sophie

distrib > Fedora > 14 > x86_64 > by-pkgid > 5b6c31d6428e1f6ea754ea6f7b1aed6e > files > 142

soprano-apidocs-2.6.0-2.fc14.noarch.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>Soprano: Soprano::Iterator&lt; T &gt; Class Template Reference</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.7.3 -->
<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 style="padding-left: 0.5em;">
   <div id="projectname">Soprano&#160;<span id="projectnumber">2.6.0</span></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>
    </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="inherits.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="namespaceSoprano.html">Soprano</a>      </li>
      <li class="navelem"><a class="el" href="classSoprano_1_1Iterator.html">Iterator</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>  </div>
  <div class="headertitle">
<h1>Soprano::Iterator&lt; T &gt; Class Template Reference</h1>  </div>
</div>
<div class="contents">
<!-- doxytag: class="Soprano::Iterator" --><!-- doxytag: inherits="Soprano::Error::ErrorCache" -->
<p>The basic Soprano iterator class.  
<a href="#_details">More...</a></p>

<p><code>#include &lt;<a class="el" href="iterator_8h_source.html">Soprano/Iterator</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 Soprano::Iterator&lt; T &gt;:</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="classSoprano_1_1Iterator__inherit__graph.png" border="0" usemap="#Soprano_1_1Iterator_3_01T_01_4_inherit__map" alt="Inheritance graph"/></div>
<map name="Soprano_1_1Iterator_3_01T_01_4_inherit__map" id="Soprano_1_1Iterator_3_01T_01_4_inherit__map">
<area shape="rect" id="node5" href="classSoprano_1_1Iterator.html" title="Soprano::Iterator\&lt; Node \&gt;" alt="" coords="543,76,716,105"/><area shape="rect" id="node13" href="classSoprano_1_1Iterator.html" title="Soprano::Iterator\&lt; Statement \&gt;" alt="" coords="528,156,731,185"/><area shape="rect" id="node21" href="classSoprano_1_1Iterator.html" title="Soprano::Iterator\&lt; BindingSet \&gt;" alt="" coords="527,216,732,245"/><area shape="rect" id="node2" href="classSoprano_1_1Error_1_1ErrorCache.html" title="Core class of Soprano&#39;s exception system." alt="" coords="7,156,185,185"/><area shape="rect" id="node7" href="classSoprano_1_1NodeIterator.html" title="An iterator that provides a stream of Nodes." alt="" coords="805,59,955,88"/><area shape="rect" id="node9" href="classSoprano_1_1Client_1_1DBusNodeIterator.html" title="Interface to a DBus server node iterator." alt="" coords="1048,5,1272,35"/><area shape="rect" id="node11" href="classSoprano_1_1Util_1_1SimpleNodeIterator.html" title="The most simple version of a NodeIterator simply iterates over a list of Nodes." alt="" coords="1051,59,1269,88"/><area shape="rect" id="node15" href="classSoprano_1_1StatementIterator.html" title="An iterator that provides a stream of Statements." alt="" coords="791,156,969,185"/><area shape="rect" id="node17" href="classSoprano_1_1Client_1_1DBusStatementIterator.html" title="Interface to a DBus server statement iterator." alt="" coords="1033,112,1287,141"/><area shape="rect" id="node19" href="classSoprano_1_1Util_1_1SimpleStatementIterator.html" title="The most simple version of a StatementIterator simply iterates over a list of Statements." alt="" coords="1037,165,1283,195"/><area shape="rect" id="node23" href="classSoprano_1_1QueryResultIterator.html" title="An iterator for query results." alt="" coords="784,216,976,245"/><area shape="rect" id="node25" href="classSoprano_1_1Client_1_1DBusQueryResultIterator.html" title="Interface to a DBus server query result iterator." alt="" coords="1027,219,1293,248"/></map>
<center><span class="legend">[<a href="graph_legend.html">legend</a>]</span></center></div>

<p><a href="classSoprano_1_1Iterator-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="classSoprano_1_1Iterator.html#af0cc2606052285dcd4ab3bd2f93377a2">Iterator</a> ()</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classSoprano_1_1Iterator.html#a8603764eaec13eb7670b8c0229cdab00">Iterator</a> (<a class="el" href="classSoprano_1_1IteratorBackend.html">IteratorBackend</a>&lt; T &gt; *sti)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classSoprano_1_1Iterator.html#a6660a517b9bdb993a61df8ff41fa2c75">Iterator</a> (const <a class="el" href="classSoprano_1_1Iterator.html">Iterator</a> &amp;sti)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">virtual&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classSoprano_1_1Iterator.html#a1b46cffbe390bd0e23cdda417c6ad845">~Iterator</a> ()</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="classSoprano_1_1Iterator.html">Iterator</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classSoprano_1_1Iterator.html#a1c83515d4e73f9603d3b84a647fee5de">operator=</a> (const <a class="el" href="classSoprano_1_1Iterator.html">Iterator</a> &amp;)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classSoprano_1_1Iterator.html#a623fb6440a6cfadbb560bd7738c01871">close</a> ()</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classSoprano_1_1Iterator.html#a1ba632f6f015242ab9441da77d48415b">next</a> ()</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">T&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classSoprano_1_1Iterator.html#a7060834a96aced1bba25e760474ac22e">current</a> () const </td></tr>
<tr><td class="memItemLeft" align="right" valign="top">T&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classSoprano_1_1Iterator.html#a5b6240c9f5f7686ce76e4eb2a39f6f9f">operator*</a> () const </td></tr>
<tr><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classSoprano_1_1Iterator.html#a03d741ebdc499352fa85b38835825f6a">isValid</a> () const </td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="elRef" href="qlist.html">QList</a>&lt; T &gt;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classSoprano_1_1Iterator.html#ab8f53c8b02072c3e688ee62e5f318b46">allElements</a> ()</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">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classSoprano_1_1Iterator.html#a27a5362ea770284c1a83d5b432f8a59b">setBackend</a> (<a class="el" href="classSoprano_1_1IteratorBackend.html">IteratorBackend</a>&lt; T &gt; *b)</td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="classSoprano_1_1IteratorBackend.html">IteratorBackend</a>&lt; T &gt; *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classSoprano_1_1Iterator.html#aff7df72a54da0b2dee48f1a1b59e0ac8">backend</a> () const </td></tr>
</table>
<hr/><a name="_details"></a><h2>Detailed Description</h2>
<div class="textblock"><h3>template&lt;typename T&gt;<br/>
 class Soprano::Iterator&lt; T &gt;</h3>

<p>The basic Soprano iterator class. </p>
<p>Iterators in Soprano are very easy to use through two methods <a class="el" href="classSoprano_1_1Iterator.html#a1ba632f6f015242ab9441da77d48415b">next()</a> and <a class="el" href="classSoprano_1_1Iterator.html#a7060834a96aced1bba25e760474ac22e">current()</a>. Instead of the latter <a class="el" href="classSoprano_1_1Iterator.html#a5b6240c9f5f7686ce76e4eb2a39f6f9f">operator*()</a> can also be used. Both can be called subsequetially to retrieve the current element until <a class="el" href="classSoprano_1_1Iterator.html#a1ba632f6f015242ab9441da77d48415b">next()</a> has been called again.</p>
<div class="fragment"><pre class="fragment"> <a class="code" href="classSoprano_1_1Iterator.html" title="The basic Soprano iterator class.">Soprano::Iterator&lt;X&gt;</a> it;
 <span class="keywordflow">while</span>( it.<a class="code" href="classSoprano_1_1Iterator.html#a1ba632f6f015242ab9441da77d48415b">next</a>() ) {
    doSomething( *it );
    doSomethingElse( it.<a class="code" href="classSoprano_1_1Iterator.html#a7060834a96aced1bba25e760474ac22e">current</a>() );
 }
</pre></div><p>Many backends do lock the underlying <a class="el" href="classSoprano_1_1Model.html" title="A Model is the central class in Soprano. It is a queryable collection of RDF quadruples, i.e statements.">Model</a> during iteration. Thus, it is always a good idea to cache the results if they are to be used to modify the model to prevent a deadlock:</p>
<div class="fragment"><pre class="fragment"> <a class="code" href="classSoprano_1_1StatementIterator.html" title="An iterator that provides a stream of Statements.">Soprano::StatementIterator</a> it = model-&gt;<a class="code" href="classSoprano_1_1Model.html#a7f50dc6483e0bed7830877182c7906ac">listStatements</a>();
 <a class="codeRef" href="qlist.html">QList&lt;Statement&gt;</a> allStatements = it.<a class="code" href="classSoprano_1_1Iterator.html#ab8f53c8b02072c3e688ee62e5f318b46">allElements</a>();
 Q_FOREACH( <a class="code" href="classSoprano_1_1Statement.html" title="A Statement instance represents one RDF quadruple.">Soprano::Statement</a> s, allStatements ) {
    modifyTheModel( model, s );
 }
</pre></div><p>Iterators have to be closed. This can either be achieved by deleting the iterator, finishing it (<a class="el" href="classSoprano_1_1Iterator.html#a1ba632f6f015242ab9441da77d48415b">next()</a> does return <code>false</code>), or calling <a class="el" href="classSoprano_1_1Iterator.html#a623fb6440a6cfadbb560bd7738c01871">close()</a>. Before that other operations on the <a class="el" href="classSoprano_1_1Model.html" title="A Model is the central class in Soprano. It is a queryable collection of RDF quadruples, i.e statements.">Model</a> may block.</p>
<p>Iterators are not thread-safe. Two threads using the same iterator may result in undefined behaviour and even crashes. An iterator needs to be closed by the same thread that opened it (except if the iterator contains special code to handle such a situation.)</p>
<dl class="warning"><dt><b>Warning:</b></dt><dd>Be aware that iterators in <a class="el" href="namespaceSoprano.html">Soprano</a> are shared objects which means that copies of one iterator object work on the same data.</dd></dl>
<dl class="author"><dt><b>Author:</b></dt><dd>Daniele Galdi &lt;<a href="mailto:daniele.galdi@gmail.com">daniele.galdi@gmail.com</a>&gt;<br/>
Sebastian Trueg &lt;<a href="mailto:trueg@kde.org">trueg@kde.org</a>&gt; </dd></dl>

<p>Definition at line <a class="el" href="iterator_8h_source.html#l00079">79</a> of file <a class="el" href="iterator_8h_source.html">iterator.h</a>.</p>
</div><hr/><h2>Constructor &amp; Destructor Documentation</h2>
<a class="anchor" id="af0cc2606052285dcd4ab3bd2f93377a2"></a><!-- doxytag: member="Soprano::Iterator::Iterator" ref="af0cc2606052285dcd4ab3bd2f93377a2" args="()" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classSoprano_1_1Iterator.html">Soprano::Iterator</a>&lt; T &gt;::<a class="el" href="classSoprano_1_1Iterator.html">Iterator</a> </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Creates and empty, invalid iterator. </p>

</div>
</div>
<a class="anchor" id="a8603764eaec13eb7670b8c0229cdab00"></a><!-- doxytag: member="Soprano::Iterator::Iterator" ref="a8603764eaec13eb7670b8c0229cdab00" args="(IteratorBackend&lt; T &gt; *sti)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classSoprano_1_1Iterator.html">Soprano::Iterator</a>&lt; T &gt;::<a class="el" href="classSoprano_1_1Iterator.html">Iterator</a> </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="classSoprano_1_1IteratorBackend.html">IteratorBackend</a>&lt; T &gt; *&#160;</td>
          <td class="paramname"><em>sti</em></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Create a new <a class="el" href="classSoprano_1_1Iterator.html" title="The basic Soprano iterator class.">Iterator</a> instance that uses sti as backend. <a class="el" href="classSoprano_1_1Iterator.html" title="The basic Soprano iterator class.">Iterator</a> will take ownership of the backend. </p>

</div>
</div>
<a class="anchor" id="a6660a517b9bdb993a61df8ff41fa2c75"></a><!-- doxytag: member="Soprano::Iterator::Iterator" ref="a6660a517b9bdb993a61df8ff41fa2c75" args="(const Iterator &amp;sti)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classSoprano_1_1Iterator.html">Soprano::Iterator</a>&lt; T &gt;::<a class="el" href="classSoprano_1_1Iterator.html">Iterator</a> </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="classSoprano_1_1Iterator.html">Iterator</a>&lt; T &gt; &amp;&#160;</td>
          <td class="paramname"><em>sti</em></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">

</div>
</div>
<a class="anchor" id="a1b46cffbe390bd0e23cdda417c6ad845"></a><!-- doxytag: member="Soprano::Iterator::~Iterator" ref="a1b46cffbe390bd0e23cdda417c6ad845" args="()" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">virtual <a class="el" href="classSoprano_1_1Iterator.html">Soprano::Iterator</a>&lt; T &gt;::~<a class="el" href="classSoprano_1_1Iterator.html">Iterator</a> </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td><code> [virtual]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

</div>
</div>
<hr/><h2>Member Function Documentation</h2>
<a class="anchor" id="a1c83515d4e73f9603d3b84a647fee5de"></a><!-- doxytag: member="Soprano::Iterator::operator=" ref="a1c83515d4e73f9603d3b84a647fee5de" args="(const Iterator &amp;)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classSoprano_1_1Iterator.html">Iterator</a>&amp; <a class="el" href="classSoprano_1_1Iterator.html">Soprano::Iterator</a>&lt; T &gt;::operator= </td>
          <td>(</td>
          <td class="paramtype">const <a class="el" href="classSoprano_1_1Iterator.html">Iterator</a>&lt; T &gt; &amp;&#160;</td>
          <td class="paramname"></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">

</div>
</div>
<a class="anchor" id="a623fb6440a6cfadbb560bd7738c01871"></a><!-- doxytag: member="Soprano::Iterator::close" ref="a623fb6440a6cfadbb560bd7738c01871" args="()" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="classSoprano_1_1Iterator.html">Soprano::Iterator</a>&lt; T &gt;::close </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Close the iterator and release any locks on the underlying <a class="el" href="classSoprano_1_1Model.html" title="A Model is the central class in Soprano. It is a queryable collection of RDF quadruples, i.e statements.">Model</a>. </p>

</div>
</div>
<a class="anchor" id="a1ba632f6f015242ab9441da77d48415b"></a><!-- doxytag: member="Soprano::Iterator::next" ref="a1ba632f6f015242ab9441da77d48415b" args="()" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">bool <a class="el" href="classSoprano_1_1Iterator.html">Soprano::Iterator</a>&lt; T &gt;::next </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Advances to the next element in the iterator. </p>
<dl class="return"><dt><b>Returns:</b></dt><dd>true if another element can be read from the iterator, false if the end has been reached. </dd></dl>

</div>
</div>
<a class="anchor" id="a7060834a96aced1bba25e760474ac22e"></a><!-- doxytag: member="Soprano::Iterator::current" ref="a7060834a96aced1bba25e760474ac22e" args="() const " -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">T <a class="el" href="classSoprano_1_1Iterator.html">Soprano::Iterator</a>&lt; T &gt;::current </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Get the element the iterator currently points to. Be aware that a valid current element is only available if <a class="el" href="classSoprano_1_1Iterator.html#a1ba632f6f015242ab9441da77d48415b">next()</a> returned <code>true</code>.</p>
<dl class="return"><dt><b>Returns:</b></dt><dd>the current element. </dd></dl>

</div>
</div>
<a class="anchor" id="a5b6240c9f5f7686ce76e4eb2a39f6f9f"></a><!-- doxytag: member="Soprano::Iterator::operator*" ref="a5b6240c9f5f7686ce76e4eb2a39f6f9f" args="() const " -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">T <a class="el" href="classSoprano_1_1Iterator.html">Soprano::Iterator</a>&lt; T &gt;::operator* </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Retrieve the current element in the iterator.</p>
<p>This is equivalent to <a class="el" href="classSoprano_1_1Iterator.html#a7060834a96aced1bba25e760474ac22e">current()</a>.</p>
<dl class="return"><dt><b>Returns:</b></dt><dd>The element the iterator currently points to or an invalid one if next has never been called. </dd></dl>

</div>
</div>
<a class="anchor" id="a03d741ebdc499352fa85b38835825f6a"></a><!-- doxytag: member="Soprano::Iterator::isValid" ref="a03d741ebdc499352fa85b38835825f6a" args="() const " -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">bool <a class="el" href="classSoprano_1_1Iterator.html">Soprano::Iterator</a>&lt; T &gt;::isValid </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td> const</td>
        </tr>
      </table>
</div>
<div class="memdoc">
<dl class="return"><dt><b>Returns:</b></dt><dd><code>true</code> if the <a class="el" href="classSoprano_1_1Iterator.html" title="The basic Soprano iterator class.">Iterator</a> is valid, <code>false</code> otherwise. (An invalid iterator has no backend.) </dd></dl>

</div>
</div>
<a class="anchor" id="ab8f53c8b02072c3e688ee62e5f318b46"></a><!-- doxytag: member="Soprano::Iterator::allElements" ref="ab8f53c8b02072c3e688ee62e5f318b46" args="()" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="elRef" href="qlist.html">QList</a>&lt;T&gt; <a class="el" href="classSoprano_1_1Iterator.html">Soprano::Iterator</a>&lt; T &gt;::allElements </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Convenience method which extracts all elements (this does not include the elements that have already been read from the iterator) from the iterator and returns them in a list.</p>
<p>Be aware that after calling this method the iterator will be invalid.</p>
<dl class="return"><dt><b>Returns:</b></dt><dd>A list of all elements that rest in the iterator. </dd></dl>

</div>
</div>
<a class="anchor" id="a27a5362ea770284c1a83d5b432f8a59b"></a><!-- doxytag: member="Soprano::Iterator::setBackend" ref="a27a5362ea770284c1a83d5b432f8a59b" args="(IteratorBackend&lt; T &gt; *b)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void <a class="el" href="classSoprano_1_1Iterator.html">Soprano::Iterator</a>&lt; T &gt;::setBackend </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="classSoprano_1_1IteratorBackend.html">IteratorBackend</a>&lt; T &gt; *&#160;</td>
          <td class="paramname"><em>b</em></td><td>)</td>
          <td><code> [protected]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">
<p>Set the backend to read the actual data from. A previous backend will be deleted if there are no other <a class="el" href="classSoprano_1_1Iterator.html" title="The basic Soprano iterator class.">Iterator</a> instances using it. </p>

</div>
</div>
<a class="anchor" id="aff7df72a54da0b2dee48f1a1b59e0ac8"></a><!-- doxytag: member="Soprano::Iterator::backend" ref="aff7df72a54da0b2dee48f1a1b59e0ac8" args="() const " -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T&gt; </div>
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classSoprano_1_1IteratorBackend.html">IteratorBackend</a>&lt;T&gt;* <a class="el" href="classSoprano_1_1Iterator.html">Soprano::Iterator</a>&lt; T &gt;::backend </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td> const<code> [protected]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

</div>
</div>
<hr/>The documentation for this class was generated from the following file:<ul>
<li>/builddir/build/BUILD/soprano-2.6.0/soprano/<a class="el" href="iterator_8h_source.html">iterator.h</a></li>
</ul>
</div>
<hr class="footer"/><address class="footer"><small>Generated on Fri Mar 11 2011 for Soprano 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>