<?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 <<a class="el" href="loader_8h-source.html">loader.h</a>></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->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->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 </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 </td><td class="memItemRight" valign="bottom"><a class="el" href="classRSS_1_1Loader.html#259a68def7c44a066a980c3e544ac0db">loadFrom</a> (const KURL &url, <a class="el" href="classRSS_1_1DataRetriever.html">DataRetriever</a> *retriever)</td></tr> <tr><td class="memItemLeft" nowrap align="right" valign="top">int </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 & </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 </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> * </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> * </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 </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> ) </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 * </td> <td class="paramname"> <em>object</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">const char * </td> <td class="paramname"> <em>slot</em></td><td> </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> </td><td>A QObject which features the specified slot </td></tr> <tr><td valign="top"></td><td valign="top"><em>slot</em> </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 &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 & </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> * </td> <td class="paramname"> <em>retriever</em></td><td> </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> </td><td>An URL referencing the input file. </td></tr> <tr><td valign="top"></td><td valign="top"><em>retriever</em> </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> ) </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> * </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> </td> <td class="paramname"> <em>doc</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">Status </td> <td class="paramname"> <em>status</em></td><td> </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> </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> </td><td>In case status is Success, this parameter holds the parsed RSS file. In case it's RetrieveError, you should query loader-><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> </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> <a href="../../../../akregator/src/html/index.html">src</a></li><li> <a href="../../../../akregator/src/librss/html/index.html">librss</a></li><li><a href="../../../../certmanager/html/index.html">certmanager</a></li><li> <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> <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> <a href="../../../../kioslaves/imap4/html/index.html">imap4</a></li><li> <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> <a href="../../../../kpilot/kpilot/html/index.html">kpilot</a></li><li> <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="mailto:groot@kde.org">Adriaan de Groot</a> and <a href="mailto:winter@kde.org">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>