Sophie

Sophie

distrib > Mandriva > 2008.1 > x86_64 > by-pkgid > 98d6b53e11e983e268c3e19f14e091a0 > files > 316

kdepim-devel-doc-3.5.9-9mdv2008.1.x86_64.rpm

<?xml version="1.0" encoding="UTF-8"?>
<!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" lang="en_US" xml:lang="en_US">

<head>
  <title>akregator/src/librss: RSS::Loader Class Reference (akregator/src/librss)</title>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

  <meta http-equiv="Content-Style-Type" content="text/css" />

  <meta http-equiv="pics-label" content='(pics-1.1 "http://www.icra.org/ratingsv02.html" comment "ICRAonline DE v2.0" l gen true for "http://www.kde.org"  r (nz 1 vz 1 lz 1 oz 1 cb 1) "http://www.rsac.org/ratingsv01.html" l gen true for "http://www.kde.org"  r (n 0 s 0 v 0 l 0))' />

  <meta name="trademark" content="KDE e.V." />
  <meta name="description" content="K Desktop Environment Homepage, KDE.org" />
  <meta name="MSSmartTagsPreventParsing" content="true" />
  <meta name="robots" content="all" />

  <link rel="shortcut icon" href="../../../../favicon.ico" />

<link rel="stylesheet" media="screen" type="text/css" title="APIDOX" href="doxygen.css" />



<style type="text/css">
<!--
hr { display: none; }
#content h2 { margin-left: 0px; }
table.mdTable { background-color: #f8f8f8; border: .2em solid #d7d7d7; }
td.mdRow { padding: 8px 20px; }
td.md { font-weight: bold; }
td.mdname1 { font-weight: bold; color: #602020; }
td.mdname { font-weight: bold; color: #602020;  }

-->
</style>

</head>

<body>

<div id="nav_header_top" align="right">
  <a href="#content" class="doNotDisplay" accesskey="2">Skip to main content ::</a>

  <a href="../../../.."><img id="nav_header_logo" alt="Home" align="left" src="../../../../kde_gear_64.png" border="0" /></a>
  <span class="doNotDisplay">::</span>
  <img id="nav_header_logo_right" alt="" align="right" src="../../../../pimlogo.png" border="0" />

  <div id="nav_header_title" align="left">KDE PIM API Reference</div>


</div>

<div id="nav_header_bottom" align="right">
  <span class="doNotDisplay">:: <a href="#navigation" accesskey="5">Skip to Link Menu</a><br/></span>
  <div id="nav_header_bottom_left" style="text-align: left;">
/ <a href="../../../../">API Reference</a>
 / <a href="../../../html/index.html">akregator</a> / <a href="../../html/index.html">src</a> / <a href=".">librss</a>
  </div>
</div>


<table id="main" border="0" cellpadding="0" cellspacing="0" width="100%">
<tr>
      <td valign="top" class="menuheader" height="0"></td>

  <td id="contentcolumn" valign="top" rowspan="2" >
    <div id="content" style="padding-top: 0px;"><div style="width:100%; margin: 0px; padding: 0px;">
    <h2><a name="content"></a>akregator/src/librss</h2>


<!-- Generated by Doxygen 1.5.5 -->
  <div class="navpath"><b>RSS</b>::<a class="el" href="classRSS_1_1Loader.html">Loader</a>
  </div>
<div class="contents">
<h1>RSS::Loader Class Reference</h1><!-- doxytag: class="RSS::Loader" --><!-- doxytag: inherits="QObject" --><code>#include &lt;<a class="el" href="loader_8h-source.html">loader.h</a>&gt;</code>
<p>
Inherits QObject.
<p>

<p>
<a href="classRSS_1_1Loader-members.html">List of all members.</a><hr><a name="_details"></a><h2>Detailed Description</h2>
This class is the preferred way of loading RSS files. 
<p>
Usage is very straightforward:<p>
<div class="fragment"><pre class="fragment"> Loader *loader = <a class="code" href="classRSS_1_1Loader.html#d52a90cf14d7544e27178db45d5b0684" title="Constructs a Loader instance.">Loader::create</a>();
 connect(loader, SIGNAL(<a class="code" href="classRSS_1_1Loader.html#31f6cee3ca8fbde8f7dc199cde9f41f9" title="This signal gets emitted when the loading process triggered by calling loadFrom()...">loadingComplete</a>(Loader *, Document, Status)),
         <span class="keyword">this</span>, SLOT(slotLoadingComplete(Loader *, Document, Status)));
 loader-&gt;loadFrom(<span class="stringliteral">"http://www.blah.org/foobar.rdf"</span>, <span class="keyword">new</span> FileRetriever);
</pre></div><p>
This creates a <a class="el" href="classRSS_1_1Loader.html" title="This class is the preferred way of loading RSS files.">Loader</a> object, connects it's <a class="el" href="classRSS_1_1Loader.html#31f6cee3ca8fbde8f7dc199cde9f41f9" title="This signal gets emitted when the loading process triggered by calling loadFrom()...">loadingComplete()</a> signal to your custom slot and then makes it load the file 'http://www.blah.org/foobar.rdf' using the <a class="el" href="classRSS_1_1FileRetriever.html" title="Implements a file retriever, to be used with Loader::loadFrom().">FileRetriever</a>. You could've done something like this as well:<p>
<div class="fragment"><pre class="fragment"> <span class="comment">// create the Loader, connect it's signal...</span>
 loader-&gt;loadFrom(<span class="stringliteral">"/home/myself/some-script.py"</span>, <span class="keyword">new</span> OutputRetriever);
</pre></div><p>
That'd make the <a class="el" href="classRSS_1_1Loader.html" title="This class is the preferred way of loading RSS files.">Loader</a> use another algorithm for retrieving the RSS data; 'OutputRetriever' will make it execute the script '/home/myself/some-script.py' and assume whatever that script prints to stdout is RSS markup. This is e.g. handy for conversion scripts, which download an HTML file and convert it's contents into RSS markup.<p>
No matter what kind of retrieval algorithm you employ, your 'slotLoadingComplete' method might look like this:<p>
<div class="fragment"><pre class="fragment"> <span class="keywordtype">void</span> MyClass::slotLoadingComplete(Loader *loader, Document doc, Status status)
 {
     <span class="comment">// Note that Loader::~Loader() is private, so you cannot delete Loader instances.</span>
     <span class="comment">// You don't need to do that anyway since Loader instances delete themselves.</span>

     <span class="keywordflow">if</span> (status != RSS::Success)
         <span class="keywordflow">return</span>;

     QString <a class="code" href="classRSS_1_1TextInput.html#7e79d1e69a37313962954dd188737823" title="RSS 0.90 and upwards.">title</a> = doc.title();
     <span class="comment">// do whatever you want with the information.</span>
 }
</pre></div><p>
<dl class="note" compact><dt><b>Note:</b></dt><dd>You have to create a copy of the passed <a class="el" href="classRSS_1_1Document.html" title="Represents a RSS document and provides all the features and properties as stored...">Document</a> instance in case you want/need to use it after the slot attached to the loadingComplete signal goes out of scope. This is e.g. the case if you intend to call getPixmap() on <a class="el" href="classRSS_1_1Document.html#0604f452097428aed1aa7fb0bfb5a01d" title="RSS 0.90 and upwards.">Document::image()</a>! </dd></dl>

<p>Definition at line <a class="el" href="loader_8h-source.html#l00254">254</a> of file <a class="el" href="loader_8h-source.html">loader.h</a>.</p>
<table border="0" cellpadding="0" cellspacing="0">
<tr><td></td></tr>
<tr><td colspan="2"><br><h2>Signals</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classRSS_1_1Loader.html#31f6cee3ca8fbde8f7dc199cde9f41f9">loadingComplete</a> (<a class="el" href="classRSS_1_1Loader.html">Loader</a> *loader, <a class="el" href="classRSS_1_1Document.html">Document</a> doc, Status status)</td></tr>

<tr><td colspan="2"><br><h2>Public Member Functions</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">void&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classRSS_1_1Loader.html#259a68def7c44a066a980c3e544ac0db">loadFrom</a> (const KURL &amp;url, <a class="el" href="classRSS_1_1DataRetriever.html">DataRetriever</a> *retriever)</td></tr>

<tr><td class="memItemLeft" nowrap align="right" valign="top">int&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classRSS_1_1Loader.html#266870efc4eba9eac454d305374cecd6">errorCode</a> () const </td></tr>

<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="b2ffe0d2f259fe5424efa5c3fbc96c69"></a><!-- doxytag: member="RSS::Loader::discoveredFeedURL" ref="b2ffe0d2f259fe5424efa5c3fbc96c69" args="() const " -->
const KURL &amp;&nbsp;</td><td class="memItemRight" valign="bottom"><b>discoveredFeedURL</b> () const </td></tr>

<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="49d81bc8c626c1143a7feba529854ef1"></a><!-- doxytag: member="RSS::Loader::abort" ref="49d81bc8c626c1143a7feba529854ef1" args="()" -->
void&nbsp;</td><td class="memItemRight" valign="bottom"><b>abort</b> ()</td></tr>

<tr><td colspan="2"><br><h2>Static Public Member Functions</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="classRSS_1_1Loader.html">Loader</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classRSS_1_1Loader.html#d52a90cf14d7544e27178db45d5b0684">create</a> ()</td></tr>

<tr><td class="memItemLeft" nowrap align="right" valign="top">static <a class="el" href="classRSS_1_1Loader.html">Loader</a> *&nbsp;</td><td class="memItemRight" valign="bottom"><a class="el" href="classRSS_1_1Loader.html#8823e12f29cc2e17e2f3c63854693f9a">create</a> (QObject *object, const char *slot)</td></tr>

<tr><td colspan="2"><br><h2>Friends</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="23455b5e6d5c24bfd2c202bdb8a9c889"></a><!-- doxytag: member="RSS::Loader::someClassWhichDoesNotExist" ref="23455b5e6d5c24bfd2c202bdb8a9c889" args="" -->
class&nbsp;</td><td class="memItemRight" valign="bottom"><b>someClassWhichDoesNotExist</b></td></tr>

</table>
<hr><h2>Member Function Documentation</h2>
<a class="anchor" name="d52a90cf14d7544e27178db45d5b0684"></a><!-- doxytag: member="RSS::Loader::create" ref="d52a90cf14d7544e27178db45d5b0684" args="()" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classRSS_1_1Loader.html">Loader</a> * Loader::create           </td>
          <td>(</td>
          <td class="paramname">          </td>
          <td>&nbsp;)&nbsp;</td>
          <td width="100%"><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Constructs a <a class="el" href="classRSS_1_1Loader.html" title="This class is the preferred way of loading RSS files.">Loader</a> instance. 
<p>
This is pretty much what the default constructor would do, except that it ensures that all <a class="el" href="classRSS_1_1Loader.html" title="This class is the preferred way of loading RSS files.">Loader</a> instances have been allocated on the heap (this is required so that Loader's can delete themselves safely after they emitted the <a class="el" href="classRSS_1_1Loader.html#31f6cee3ca8fbde8f7dc199cde9f41f9" title="This signal gets emitted when the loading process triggered by calling loadFrom()...">loadingComplete()</a> signal.). <dl class="return" compact><dt><b>Returns:</b></dt><dd>A pointer to a new <a class="el" href="classRSS_1_1Loader.html" title="This class is the preferred way of loading RSS files.">Loader</a> instance. </dd></dl>

<p>Definition at line <a class="el" href="loader_8cpp-source.html#l00263">263</a> of file <a class="el" href="loader_8cpp-source.html">loader.cpp</a>.</p>

</div>
</div><p>
<a class="anchor" name="8823e12f29cc2e17e2f3c63854693f9a"></a><!-- doxytag: member="RSS::Loader::create" ref="8823e12f29cc2e17e2f3c63854693f9a" args="(QObject *object, const char *slot)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="classRSS_1_1Loader.html">Loader</a> * Loader::create           </td>
          <td>(</td>
          <td class="paramtype">QObject *&nbsp;</td>
          <td class="paramname"> <em>object</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&nbsp;</td>
          <td class="paramname"> <em>slot</em></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td width="100%"><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Convenience method. 
<p>
Does the same as the above method except that it also does the job of connecting the <a class="el" href="classRSS_1_1Loader.html#31f6cee3ca8fbde8f7dc199cde9f41f9" title="This signal gets emitted when the loading process triggered by calling loadFrom()...">loadingComplete()</a> signal to the given slot for you. <dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>object</em>&nbsp;</td><td>A QObject which features the specified slot </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>slot</em>&nbsp;</td><td>Which slot to connect to. </td></tr>
  </table>
</dl>

<p>Definition at line <a class="el" href="loader_8cpp-source.html#l00268">268</a> of file <a class="el" href="loader_8cpp-source.html">loader.cpp</a>.</p>

</div>
</div><p>
<a class="anchor" name="259a68def7c44a066a980c3e544ac0db"></a><!-- doxytag: member="RSS::Loader::loadFrom" ref="259a68def7c44a066a980c3e544ac0db" args="(const KURL &amp;url, DataRetriever *retriever)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void Loader::loadFrom           </td>
          <td>(</td>
          <td class="paramtype">const KURL &amp;&nbsp;</td>
          <td class="paramname"> <em>url</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classRSS_1_1DataRetriever.html">DataRetriever</a> *&nbsp;</td>
          <td class="paramname"> <em>retriever</em></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td width="100%"></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Loads the RSS file referenced by the given URL using the specified retrieval algorithm. 
<p>
Make sure that you connected to the <a class="el" href="classRSS_1_1Loader.html#31f6cee3ca8fbde8f7dc199cde9f41f9" title="This signal gets emitted when the loading process triggered by calling loadFrom()...">loadingComplete()</a> signal before calling this method so that you're guaranteed to get notified when the loading finished. <dl class="note" compact><dt><b>Note:</b></dt><dd>A <a class="el" href="classRSS_1_1Loader.html" title="This class is the preferred way of loading RSS files.">Loader</a> object cannot load from multiple URLs simultaneously; consequently, subsequent calls to loadFrom will be discarded silently, only the first loadFrom request will be executed. </dd></dl>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>url</em>&nbsp;</td><td>An URL referencing the input file. </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>retriever</em>&nbsp;</td><td>A subclass of <a class="el" href="classRSS_1_1DataRetriever.html" title="Abstract baseclass for all data retriever classes.">DataRetriever</a> which implements a specialized retrieval behaviour. Note that the ownership of the retriever is transferred to the <a class="el" href="classRSS_1_1Loader.html" title="This class is the preferred way of loading RSS files.">Loader</a>, i.e. the <a class="el" href="classRSS_1_1Loader.html" title="This class is the preferred way of loading RSS files.">Loader</a> will delete it when it doesn't need it anymore. </td></tr>
  </table>
</dl>
<dl class="see" compact><dt><b>See also:</b></dt><dd><a class="el" href="classRSS_1_1DataRetriever.html" title="Abstract baseclass for all data retriever classes.">DataRetriever</a>, <a class="el" href="classRSS_1_1Loader.html#31f6cee3ca8fbde8f7dc199cde9f41f9" title="This signal gets emitted when the loading process triggered by calling loadFrom()...">Loader::loadingComplete()</a> </dd></dl>

<p>Definition at line <a class="el" href="loader_8cpp-source.html#l00285">285</a> of file <a class="el" href="loader_8cpp-source.html">loader.cpp</a>.</p>

</div>
</div><p>
<a class="anchor" name="266870efc4eba9eac454d305374cecd6"></a><!-- doxytag: member="RSS::Loader::errorCode" ref="266870efc4eba9eac454d305374cecd6" args="() const " -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">int Loader::errorCode           </td>
          <td>(</td>
          <td class="paramname">          </td>
          <td>&nbsp;)&nbsp;</td>
          <td width="100%"> const</td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
Retrieves the error code of the last loading process (if any), as reported by the employed data retrever. 
<p>

<p>Definition at line <a class="el" href="loader_8cpp-source.html#l00299">299</a> of file <a class="el" href="loader_8cpp-source.html">loader.cpp</a>.</p>

</div>
</div><p>
<a class="anchor" name="31f6cee3ca8fbde8f7dc199cde9f41f9"></a><!-- doxytag: member="RSS::Loader::loadingComplete" ref="31f6cee3ca8fbde8f7dc199cde9f41f9" args="(Loader *loader, Document doc, Status status)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void RSS::Loader::loadingComplete           </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="classRSS_1_1Loader.html">Loader</a> *&nbsp;</td>
          <td class="paramname"> <em>loader</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="el" href="classRSS_1_1Document.html">Document</a>&nbsp;</td>
          <td class="paramname"> <em>doc</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">Status&nbsp;</td>
          <td class="paramname"> <em>status</em></td><td>&nbsp;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td><td width="100%"><code> [signal]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>
This signal gets emitted when the loading process triggered by calling <a class="el" href="classRSS_1_1Loader.html#259a68def7c44a066a980c3e544ac0db" title="Loads the RSS file referenced by the given URL using the specified retrieval algorithm...">loadFrom()</a> finished. 
<p>
<dl compact><dt><b>Parameters:</b></dt><dd>
  <table border="0" cellspacing="2" cellpadding="0">
    <tr><td valign="top"></td><td valign="top"><em>loader</em>&nbsp;</td><td>A pointer pointing to the loader object which emitted this signal; this is handy in case you connect multiple loaders to a single slot. </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>doc</em>&nbsp;</td><td>In case status is Success, this parameter holds the parsed RSS file. In case it's RetrieveError, you should query loader-&gt;<a class="el" href="classRSS_1_1Loader.html#266870efc4eba9eac454d305374cecd6" title="Retrieves the error code of the last loading process (if any), as reported by the...">errorCode()</a> for the actual error code. Note that you have to create a copy of the passed <a class="el" href="classRSS_1_1Document.html" title="Represents a RSS document and provides all the features and properties as stored...">Document</a> instance in case you want/need to use it after the slot attached to the loadingComplete signal goes out of scope. This is e.g. the case if you intend to call getPixmap() on <a class="el" href="classRSS_1_1Document.html#0604f452097428aed1aa7fb0bfb5a01d" title="RSS 0.90 and upwards.">Document::image()</a>! </td></tr>
    <tr><td valign="top"></td><td valign="top"><em>status</em>&nbsp;</td><td>A status byte telling whether there were any problems while retrieving or parsing the data. </td></tr>
  </table>
</dl>
<dl class="see" compact><dt><b>See also:</b></dt><dd><a class="el" href="classRSS_1_1Document.html" title="Represents a RSS document and provides all the features and properties as stored...">Document</a>, Status </dd></dl>

</div>
</div><p>
<hr>The documentation for this class was generated from the following files:<ul>
<li><a class="el" href="loader_8h-source.html">loader.h</a><li><a class="el" href="loader_8cpp-source.html">loader.cpp</a></ul>
</div>
    </div></div>


      </td>
  </tr>
  <tr>
    <td valign="top" id="leftmenu" width="25%">
      <a name="navigation"></a>
      <div class="menu_box"><h2>akregator/src/librss</h2>
<div class="nav_list">
<ul><li><a href="index.html">Main Page</a></li><li><a href="hierarchy.html">Class Hierarchy</a></li><li><a href="classes.html">Alphabetical List</a></li><li><a href="annotated.html">Class List</a></li><li><a href="files.html">File List</a></li><li><a href="functions.html">Class Members</a></li></ul>
<!--
<h2>Class Picker</h2>
<div style="text-align: center;">
<form name="guideform">
<select name="guidelinks" style="width:100%;" onChange="window.location=document.guideform.guidelinks.options[document.guideform.guidelinks.selectedIndex].value">
<option value="annotated.html">-- Choose --</option>
  <option value="classRSS_1_1Article.html">rss::article</option>,  <option value="classRSS_1_1DataRetriever.html">rss::dataretriever</option>,  <option value="classRSS_1_1Document.html">rss::document</option>,  <option value="classRSS_1_1FeedDetector.html">rss::feeddetector</option>,  <option value="classRSS_1_1FileRetriever.html">rss::fileretriever</option>,  <option value="classRSS_1_1Image.html">rss::image</option>,  <option value="classRSS_1_1Loader.html">rss::loader</option>,  <option value="classRSS_1_1OutputRetriever.html">rss::outputretriever</option>,  <option value="classRSS_1_1TextInput.html">rss::textinput</option>,
</select>
</form>
</div>
-->
</div></div>
<div class="menu_box"><h2>API Dox</h2>
<div class="nav_list">
<ul>
<li><a href="../../../../akregator/html/index.html">akregator</a></li><li>&nbsp;&nbsp;<a href="../../../../akregator/src/html/index.html">src</a></li><li>&nbsp;&nbsp;&nbsp;&nbsp;<a href="../../../../akregator/src/librss/html/index.html">librss</a></li><li><a href="../../../../certmanager/html/index.html">certmanager</a></li><li>&nbsp;&nbsp;<a href="../../../../certmanager/lib/html/index.html">lib</a></li><li><a href="../../../../kaddressbook/html/index.html">kaddressbook</a></li><li><a href="../../../../kalarm/html/index.html">kalarm</a></li><li>&nbsp;&nbsp;<a href="../../../../kalarm/lib/html/index.html">lib</a></li><li><a href="../../../../kandy/html/index.html">kandy</a></li><li><a href="../../../../karm/html/index.html">karm</a></li><li><a href="../../../../kdgantt/html/index.html">kdgantt</a></li><li><a href="../../../../kgantt/html/index.html">kgantt</a></li><li><a href="../../../../kioslaves/html/index.html">kioslaves</a></li><li>&nbsp;&nbsp;<a href="../../../../kioslaves/imap4/html/index.html">imap4</a></li><li>&nbsp;&nbsp;<a href="../../../../kioslaves/mbox/html/index.html">mbox</a></li><li><a href="../../../../kitchensync/html/index.html">kitchensync</a></li><li><a href="../../../../kmail/html/index.html">kmail</a></li><li><a href="../../../../knotes/html/index.html">knotes</a></li><li><a href="../../../../konsolekalendar/html/index.html">konsolekalendar</a></li><li><a href="../../../../kontact/html/index.html">kontact</a></li><li><a href="../../../../korganizer/html/index.html">korganizer</a></li><li><a href="../../../../kpilot/html/index.html">kpilot</a></li><li>&nbsp;&nbsp;<a href="../../../../kpilot/kpilot/html/index.html">kpilot</a></li><li>&nbsp;&nbsp;<a href="../../../../kpilot/lib/html/index.html">lib</a></li><li><a href="../../../../libemailfunctions/html/index.html">libemailfunctions</a></li><li><a href="../../../../libkcal/html/index.html">libkcal</a></li><li><a href="../../../../libkdepim/html/index.html">libkdepim</a></li><li><a href="../../../../libkholidays/html/index.html">libkholidays</a></li><li><a href="../../../../libkmime/html/index.html">libkmime</a></li><li><a href="../../../../libkpgp/html/index.html">libkpgp</a></li><li><a href="../../../../libkpimidentities/html/index.html">libkpimidentities</a></li>
</ul></div></div>


        </td>
</tr>
</table>

<span class="doNotDisplay">
  <a href="http://www.kde.org/" accesskey="8">KDE Home</a> |
  <a href="http://accessibility.kde.org/" accesskey="9">KDE Accessibility Home</a> |
  <a href="http://www.kde.org/media/accesskeys.php" accesskey="0">Description of Access Keys</a>
</span>


<div style="height: 8px"></div>

<div id="footer">
  <div id="footer_left">
    Maintained by <a href="&#109;&#97;&#105;&#108;&#116;&#111;&#58;groo&#116;&#64;kde&#46;or&#x67;">Adriaan de Groot</a>
and
<a href="&#109;a&#105;&#108;&#116;&#111;&#58;w&#105;nter&#64;kde&#46;or&#x67">Allen Winter</a>.
<br/>
    KDE and K Desktop Environment are trademarks of <a href="http://www.kde.org/areas/kde-ev/" title="Homepage of the KDE non-profit Organization">KDE e.V.</a> |
    <a href="http://www.kde.org/contact/impressum.php">Legal</a>
  </div>
  <div id="footer_right"><img src="/media/images/footer_right.png" style="margin: 0px" alt="" /></div>
</div>

<!--
WARNING: DO NOT SEND MAIL TO THE FOLLOWING EMAIL ADDRESS! YOU WILL
BE BLOCKED INSTANTLY AND PERMANENTLY!
<a href="mailto:aaaatrap-425acc3b5374943f@kde.org">Block me</a>
WARNING END
-->

</body>
</html>