Sophie

Sophie

distrib > Fedora > 15 > i386 > by-pkgid > 1f9eb832ba1e4b88d9a5c2b384813bb4 > files > 6434

kdelibs3-apidocs-3.5.10-31.fc15.noarch.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>kparts: KParts::ComponentFactory Namespace Reference (kparts)</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" />



</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>

  <div id="nav_header_title" align="left">KDE 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_right" style="text-align: left;">
/ <a href="../..">API Reference</a>
 / <a href=".">kparts</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;">
    <a name="content"></a>


<!-- Generated by Doxygen 1.7.4 -->
  <div id="nav-path" class="navpath">
    <ul>
      <li class="navelem"><b>KParts</b>      </li>
      <li class="navelem"><a class="el" href="namespaceKParts_1_1ComponentFactory.html">ComponentFactory</a>      </li>
    </ul>
  </div>
</div>
<div class="header">
  <div class="summary">
<a href="#enum-members">Enumerations</a> &#124;
<a href="#func-members">Functions</a>  </div>
  <div class="headertitle">
<div class="title">KParts::ComponentFactory Namespace Reference</div>  </div>
</div>
<div class="contents">

<p>Namespace for KParts components.  
<a href="#details">More...</a></p>
<table class="memberdecls">
<tr><td colspan="2"><h2><a name="enum-members"></a>
Enumerations</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceKParts_1_1ComponentFactory.html#aa0f34004323782d3721aea693a7e9bfb">ComponentLoadingError</a> { <br/>
&#160;&#160;<b>ErrNoServiceFound</b> =  1, 
<b>ErrServiceProvidesNoLibrary</b>, 
<b>ErrNoLibrary</b>, 
<b>ErrNoFactory</b>, 
<br/>
&#160;&#160;<b>ErrNoComponent</b>
<br/>
 }</td></tr>
<tr><td colspan="2"><h2><a name="func-members"></a>
Functions</h2></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;class T &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">static T *&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="namespaceKParts_1_1ComponentFactory.html#aea3f2ee59e87ce6476f0a9bd656807ea">createInstanceFromFactory</a> (<a class="elRef" doxygen="kdecore.tag:../../kdecore/html/" href="../../kdecore/html/classKLibFactory.html">KLibFactory</a> *factory, <a class="elRef" href="qobject.html">QObject</a> *parent=0, const char *name=0, const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;args=<a class="elRef" href="qstringlist.html">QStringList</a>())</td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;class T &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">static T *&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="namespaceKParts_1_1ComponentFactory.html#a51396dbf12d4fec7a6d23649e089161e">createPartInstanceFromFactory</a> (<a class="el" href="classKParts_1_1Factory.html">KParts::Factory</a> *factory, <a class="elRef" href="qwidget.html">QWidget</a> *parentWidget=0, const char *widgetName=0, <a class="elRef" href="qobject.html">QObject</a> *parent=0, const char *name=0, const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;args=<a class="elRef" href="qstringlist.html">QStringList</a>())</td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;class T &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">static T *&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="namespaceKParts_1_1ComponentFactory.html#a9fe4287abe37f168857ef6e1fb7621f4">createInstanceFromLibrary</a> (const char *libraryName, <a class="elRef" href="qobject.html">QObject</a> *parent=0, const char *name=0, const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;args=<a class="elRef" href="qstringlist.html">QStringList</a>(), int *error=0)</td></tr>
<tr><td class="memTemplParams" colspan="2"><a class="anchor" id="ae055044d664b5e18c8d3215a2601c9f6"></a><!-- doxytag: member="KParts::ComponentFactory::createPartInstanceFromLibrary" ref="ae055044d664b5e18c8d3215a2601c9f6" args="(const char *libraryName, QWidget *parentWidget=0, const char *widgetName=0, QObject *parent=0, const char *name=0, const QStringList &amp;args=QStringList(), int *error=0)" -->
template&lt;class T &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">static T *&#160;</td><td class="memTemplItemRight" valign="bottom"><b>createPartInstanceFromLibrary</b> (const char *libraryName, <a class="elRef" href="qwidget.html">QWidget</a> *parentWidget=0, const char *widgetName=0, <a class="elRef" href="qobject.html">QObject</a> *parent=0, const char *name=0, const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;args=<a class="elRef" href="qstringlist.html">QStringList</a>(), int *error=0)</td></tr>
<tr><td class="memTemplParams" colspan="2"><a class="anchor" id="a97853cd4de3b0451fced5278049db71f"></a><!-- doxytag: member="KParts::ComponentFactory::createInstanceFromService" ref="a97853cd4de3b0451fced5278049db71f" args="(const KService::Ptr &amp;service, QObject *parent=0, const char *name=0, const QStringList &amp;args=QStringList(), int *error=0)" -->
template&lt;class T &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">static T *&#160;</td><td class="memTemplItemRight" valign="bottom"><b>createInstanceFromService</b> (const KService::Ptr &amp;service, <a class="elRef" href="qobject.html">QObject</a> *parent=0, const char *name=0, const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;args=<a class="elRef" href="qstringlist.html">QStringList</a>(), int *error=0)</td></tr>
<tr><td class="memTemplParams" colspan="2"><a class="anchor" id="ab3a009f028368e3507e6ffef7b0bff8d"></a><!-- doxytag: member="KParts::ComponentFactory::createPartInstanceFromService" ref="ab3a009f028368e3507e6ffef7b0bff8d" args="(const KService::Ptr &amp;service, QWidget *parentWidget=0, const char *widgetName=0, QObject *parent=0, const char *name=0, const QStringList &amp;args=QStringList(), int *error=0)" -->
template&lt;class T &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">static T *&#160;</td><td class="memTemplItemRight" valign="bottom"><b>createPartInstanceFromService</b> (const KService::Ptr &amp;service, <a class="elRef" href="qwidget.html">QWidget</a> *parentWidget=0, const char *widgetName=0, <a class="elRef" href="qobject.html">QObject</a> *parent=0, const char *name=0, const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;args=<a class="elRef" href="qstringlist.html">QStringList</a>(), int *error=0)</td></tr>
<tr><td class="memTemplParams" colspan="2"><a class="anchor" id="a3ad061bac7167ab749094c9534dee6bd"></a><!-- doxytag: member="KParts::ComponentFactory::createInstanceFromServices" ref="a3ad061bac7167ab749094c9534dee6bd" args="(ServiceIterator begin, ServiceIterator end, QObject *parent=0, const char *name=0, const QStringList &amp;args=QStringList(), int *error=0)" -->
template&lt;class T , class ServiceIterator &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">static T *&#160;</td><td class="memTemplItemRight" valign="bottom"><b>createInstanceFromServices</b> (ServiceIterator begin, ServiceIterator end, <a class="elRef" href="qobject.html">QObject</a> *parent=0, const char *name=0, const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;args=<a class="elRef" href="qstringlist.html">QStringList</a>(), int *error=0)</td></tr>
<tr><td class="memTemplParams" colspan="2"><a class="anchor" id="af44ec954d45ff06c66db833d9e64a0a7"></a><!-- doxytag: member="KParts::ComponentFactory::createPartInstanceFromServices" ref="af44ec954d45ff06c66db833d9e64a0a7" args="(ServiceIterator begin, ServiceIterator end, QWidget *parentWidget=0, const char *widgetName=0, QObject *parent=0, const char *name=0, const QStringList &amp;args=QStringList(), int *error=0)" -->
template&lt;class T , class ServiceIterator &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">static T *&#160;</td><td class="memTemplItemRight" valign="bottom"><b>createPartInstanceFromServices</b> (ServiceIterator begin, ServiceIterator end, <a class="elRef" href="qwidget.html">QWidget</a> *parentWidget=0, const char *widgetName=0, <a class="elRef" href="qobject.html">QObject</a> *parent=0, const char *name=0, const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;args=<a class="elRef" href="qstringlist.html">QStringList</a>(), int *error=0)</td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;class T &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">static T *&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="namespaceKParts_1_1ComponentFactory.html#a66a8538016585af5338d9578b116a918">createInstanceFromQuery</a> (const <a class="elRef" href="qstring.html">QString</a> &amp;serviceType, const <a class="elRef" href="qstring.html">QString</a> &amp;constraint=QString::null, <a class="elRef" href="qobject.html">QObject</a> *parent=0, const char *name=0, const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;args=<a class="elRef" href="qstringlist.html">QStringList</a>(), int *error=0)</td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;class T &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">static T *&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="namespaceKParts_1_1ComponentFactory.html#a0af2316c53e9d4dedfedecd1badc5e72">createPartInstanceFromQuery</a> (const <a class="elRef" href="qstring.html">QString</a> &amp;serviceType, const <a class="elRef" href="qstring.html">QString</a> &amp;constraint, <a class="elRef" href="qwidget.html">QWidget</a> *parentWidget=0, const char *widgetName=0, <a class="elRef" href="qobject.html">QObject</a> *parent=0, const char *name=0, const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;args=<a class="elRef" href="qstringlist.html">QStringList</a>(), int *error=0)</td></tr>
</table>
<hr/><a name="details" id="details"></a><h2>Detailed Description</h2>
<div class="textblock"><p>Namespace for KParts components. </p>
</div><hr/><h2>Enumeration Type Documentation</h2>
<a class="anchor" id="aa0f34004323782d3721aea693a7e9bfb"></a><!-- doxytag: member="KParts::ComponentFactory::ComponentLoadingError" ref="aa0f34004323782d3721aea693a7e9bfb" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">enum <a class="el" href="namespaceKParts_1_1ComponentFactory.html#aa0f34004323782d3721aea693a7e9bfb">KParts::ComponentFactory::ComponentLoadingError</a></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>This enum type defines the possible error cases that can happen when loading a component. </p>
<ul>
<li>
<code>ErrNoServiceFound</code> - no service implementing the given mimetype and fullfilling the given constraint expression can be found. </li>
<li>
<code>ErrServiceProvidesNoLibrary</code> - the specified service provides no shared library </li>
<li>
<code>ErrNoLibrary</code> - the specified library could not be loaded. Use <a class="elRef" doxygen="kdecore.tag:../../kdecore/html/" href="../../kdecore/html/classKLibLoader.html#a6b463bb7c1412ad12201b72944d4f85d">KLibLoader::lastErrorMessage</a> for details. </li>
<li>
<code>ErrNoFactory</code> - the library does not export a factory for creating components </li>
<li>
<code>ErrNoComponent</code> - the factory does not support creating components of the specified type </li>
</ul>

<p>Definition at line <a class="el" href="componentfactory_8h_source.html#l00037">37</a> of file <a class="el" href="componentfactory_8h_source.html">componentfactory.h</a>.</p>

</div>
</div>
<hr/><h2>Function Documentation</h2>
<a class="anchor" id="aea3f2ee59e87ce6476f0a9bd656807ea"></a><!-- doxytag: member="KParts::ComponentFactory::createInstanceFromFactory" ref="aea3f2ee59e87ce6476f0a9bd656807ea" args="(KLibFactory *factory, QObject *parent=0, const char *name=0, const QStringList &amp;args=QStringList())" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T &gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">static T* KParts::ComponentFactory::createInstanceFromFactory </td>
          <td>(</td>
          <td class="paramtype"><a class="elRef" doxygen="kdecore.tag:../../kdecore/html/" href="../../kdecore/html/classKLibFactory.html">KLibFactory</a> *&#160;</td>
          <td class="paramname"><em>factory</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="elRef" href="qobject.html">QObject</a> *&#160;</td>
          <td class="paramname"><em>parent</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>name</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;&#160;</td>
          <td class="paramname"><em>args</em> = <code><a class="elRef" href="qstringlist.html">QStringList</a>()</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>This template function allows to ask the given factory to create an instance of the given template type. </p>
<p>Example of usage: </p>
<div class="fragment"><pre class="fragment">     MyPlugin *plugin = KParts::ComponentFactory::createInstanceFromFactory&lt;MyPlugin&gt;( factory, parent );
</pre></div><dl><dt><b>Parameters:</b></dt><dd>
  <table class="params">
    <tr><td class="paramname">factory</td><td>The factory to ask for the creation of the component </td></tr>
    <tr><td class="paramname">parent</td><td>The parent object (see <a class="elRef" href="qobject.html">QObject</a> constructor) </td></tr>
    <tr><td class="paramname">name</td><td>The name of the object to create (see <a class="elRef" href="qobject.html">QObject</a> constructor) </td></tr>
    <tr><td class="paramname">args</td><td>A list of string arguments, passed to the factory and possibly to the component (see <a class="elRef" doxygen="kdecore.tag:../../kdecore/html/" href="../../kdecore/html/classKLibFactory.html">KLibFactory</a>) </td></tr>
  </table>
  </dd>
</dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>A pointer to the newly created object or a null pointer if the factory was unable to create an object of the given type. </dd></dl>

<p>Definition at line <a class="el" href="componentfactory_8h_source.html#l00061">61</a> of file <a class="el" href="componentfactory_8h_source.html">componentfactory.h</a>.</p>

</div>
</div>
<a class="anchor" id="a9fe4287abe37f168857ef6e1fb7621f4"></a><!-- doxytag: member="KParts::ComponentFactory::createInstanceFromLibrary" ref="a9fe4287abe37f168857ef6e1fb7621f4" args="(const char *libraryName, QObject *parent=0, const char *name=0, const QStringList &amp;args=QStringList(), int *error=0)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T &gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">static T* KParts::ComponentFactory::createInstanceFromLibrary </td>
          <td>(</td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>libraryName</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="elRef" href="qobject.html">QObject</a> *&#160;</td>
          <td class="paramname"><em>parent</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>name</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;&#160;</td>
          <td class="paramname"><em>args</em> = <code><a class="elRef" href="qstringlist.html">QStringList</a>()</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">int *&#160;</td>
          <td class="paramname"><em>error</em> = <code>0</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>This template allows to load the specified library and ask the factory to create an instance of the given template type. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table class="params">
    <tr><td class="paramname">libraryName</td><td>The library to open </td></tr>
    <tr><td class="paramname">parent</td><td>The parent object (see <a class="elRef" href="qobject.html">QObject</a> constructor) </td></tr>
    <tr><td class="paramname">name</td><td>The name of the object to create (see <a class="elRef" href="qobject.html">QObject</a> constructor) </td></tr>
    <tr><td class="paramname">args</td><td>A list of string arguments, passed to the factory and possibly to the component (see <a class="elRef" doxygen="kdecore.tag:../../kdecore/html/" href="../../kdecore/html/classKLibFactory.html">KLibFactory</a>) </td></tr>
    <tr><td class="paramname">error</td><td></td></tr>
  </table>
  </dd>
</dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>A pointer to the newly created object or a null pointer if the factory was unable to create an object of the given type. </dd></dl>

<p>Definition at line <a class="el" href="componentfactory_8h_source.html#l00127">127</a> of file <a class="el" href="componentfactory_8h_source.html">componentfactory.h</a>.</p>

</div>
</div>
<a class="anchor" id="a66a8538016585af5338d9578b116a918"></a><!-- doxytag: member="KParts::ComponentFactory::createInstanceFromQuery" ref="a66a8538016585af5338d9578b116a918" args="(const QString &amp;serviceType, const QString &amp;constraint=QString::null, QObject *parent=0, const char *name=0, const QStringList &amp;args=QStringList(), int *error=0)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T &gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">static T* KParts::ComponentFactory::createInstanceFromQuery </td>
          <td>(</td>
          <td class="paramtype">const <a class="elRef" href="qstring.html">QString</a> &amp;&#160;</td>
          <td class="paramname"><em>serviceType</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="elRef" href="qstring.html">QString</a> &amp;&#160;</td>
          <td class="paramname"><em>constraint</em> = <code>QString::null</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="elRef" href="qobject.html">QObject</a> *&#160;</td>
          <td class="paramname"><em>parent</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>name</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;&#160;</td>
          <td class="paramname"><em>args</em> = <code><a class="elRef" href="qstringlist.html">QStringList</a>()</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">int *&#160;</td>
          <td class="paramname"><em>error</em> = <code>0</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>This method creates and returns a plugin, from the trader query for a given serviceType. </p>
<p>Example: </p>
<div class="fragment"><pre class="fragment"> KMyAppPlugin* plugin = KParts::ComponentFactory::createInstanceFromQuery&lt;KMyAppPlugin&gt;( serviceType, QString::null, parentObject );
 <span class="keywordflow">if</span> ( plugin ) {
     ....
 }
</pre></div><dl><dt><b>Parameters:</b></dt><dd>
  <table class="params">
    <tr><td class="paramname">serviceType</td><td>the type of service for which to find a plugin </td></tr>
    <tr><td class="paramname">constraint</td><td>an optional constraint to pass to the trader (see KIO::KTrader) </td></tr>
    <tr><td class="paramname">parent</td><td>the parent object for the part itself </td></tr>
    <tr><td class="paramname">name</td><td>the name that will be given to the part </td></tr>
    <tr><td class="paramname">args</td><td>A list of string arguments, passed to the factory and possibly to the component (see <a class="elRef" doxygen="kdecore.tag:../../kdecore/html/" href="../../kdecore/html/classKLibFactory.html">KLibFactory</a>) </td></tr>
    <tr><td class="paramname">error</td><td>The int passed here will receive an error code in case of errors. (See enum <a class="el" href="namespaceKParts_1_1ComponentFactory.html#aa0f34004323782d3721aea693a7e9bfb" title="This enum type defines the possible error cases that can happen when loading a component.">ComponentLoadingError</a>) </td></tr>
  </table>
  </dd>
</dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>A pointer to the newly created object or a null pointer if the factory was unable to create an object of the given type. </dd></dl>

<p>Definition at line <a class="el" href="componentfactory_8h_source.html#l00321">321</a> of file <a class="el" href="componentfactory_8h_source.html">componentfactory.h</a>.</p>

</div>
</div>
<a class="anchor" id="a51396dbf12d4fec7a6d23649e089161e"></a><!-- doxytag: member="KParts::ComponentFactory::createPartInstanceFromFactory" ref="a51396dbf12d4fec7a6d23649e089161e" args="(KParts::Factory *factory, QWidget *parentWidget=0, const char *widgetName=0, QObject *parent=0, const char *name=0, const QStringList &amp;args=QStringList())" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T &gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">static T* KParts::ComponentFactory::createPartInstanceFromFactory </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="classKParts_1_1Factory.html">KParts::Factory</a> *&#160;</td>
          <td class="paramname"><em>factory</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="elRef" href="qwidget.html">QWidget</a> *&#160;</td>
          <td class="paramname"><em>parentWidget</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>widgetName</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="elRef" href="qobject.html">QObject</a> *&#160;</td>
          <td class="paramname"><em>parent</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>name</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;&#160;</td>
          <td class="paramname"><em>args</em> = <code><a class="elRef" href="qstringlist.html">QStringList</a>()</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>This template function allows to ask the given kparts factory to create an instance of the given template type. </p>
<p>Example of usage: </p>
<div class="fragment"><pre class="fragment">     KViewPart *doc = KParts::ComponentFactory::createPartInstanceFromFactory&lt;KViewPart&gt;( factory, parent );
</pre></div><dl><dt><b>Parameters:</b></dt><dd>
  <table class="params">
    <tr><td class="paramname">factory</td><td>The factory to ask for the creation of the component </td></tr>
    <tr><td class="paramname">parentWidget</td><td>the parent widget for the part </td></tr>
    <tr><td class="paramname">widgetName</td><td>the name of the part's widget </td></tr>
    <tr><td class="paramname">parent</td><td>The parent object (see <a class="elRef" href="qobject.html">QObject</a> constructor) </td></tr>
    <tr><td class="paramname">name</td><td>The name of the object to create (see <a class="elRef" href="qobject.html">QObject</a> constructor) </td></tr>
    <tr><td class="paramname">args</td><td>A list of string arguments, passed to the factory and possibly to the component (see <a class="elRef" doxygen="kdecore.tag:../../kdecore/html/" href="../../kdecore/html/classKLibFactory.html">KLibFactory</a>) </td></tr>
  </table>
  </dd>
</dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>A pointer to the newly created object or a null pointer if the factory was unable to create an object of the given type. </dd></dl>

<p>Definition at line <a class="el" href="componentfactory_8h_source.html#l00095">95</a> of file <a class="el" href="componentfactory_8h_source.html">componentfactory.h</a>.</p>

</div>
</div>
<a class="anchor" id="a0af2316c53e9d4dedfedecd1badc5e72"></a><!-- doxytag: member="KParts::ComponentFactory::createPartInstanceFromQuery" ref="a0af2316c53e9d4dedfedecd1badc5e72" args="(const QString &amp;serviceType, const QString &amp;constraint, QWidget *parentWidget=0, const char *widgetName=0, QObject *parent=0, const char *name=0, const QStringList &amp;args=QStringList(), int *error=0)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class T &gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">static T* KParts::ComponentFactory::createPartInstanceFromQuery </td>
          <td>(</td>
          <td class="paramtype">const <a class="elRef" href="qstring.html">QString</a> &amp;&#160;</td>
          <td class="paramname"><em>serviceType</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="elRef" href="qstring.html">QString</a> &amp;&#160;</td>
          <td class="paramname"><em>constraint</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="elRef" href="qwidget.html">QWidget</a> *&#160;</td>
          <td class="paramname"><em>parentWidget</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>widgetName</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype"><a class="elRef" href="qobject.html">QObject</a> *&#160;</td>
          <td class="paramname"><em>parent</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const char *&#160;</td>
          <td class="paramname"><em>name</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="elRef" href="qstringlist.html">QStringList</a> &amp;&#160;</td>
          <td class="paramname"><em>args</em> = <code><a class="elRef" href="qstringlist.html">QStringList</a>()</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">int *&#160;</td>
          <td class="paramname"><em>error</em> = <code>0</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td><code> [static]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>This method creates and returns a KParts part from a serviceType (e.g. </p>
<p>a mimetype).</p>
<p>You can use this method to create a generic viewer - that can display any kind of file, provided that there is a <a class="el" href="classKParts_1_1ReadOnlyPart.html" title="Base class for any &quot;viewer&quot; part.">ReadOnlyPart</a> installed for it - in 5 lines: </p>
<div class="fragment"><pre class="fragment"> <span class="comment">// Given the following: KURL url, QWidget* parentWidget and QObject* parentObject.</span>
 <a class="codeRef" href="qstring.html">QString</a> mimetype = KMimeType::findByURL( url )-&gt;name();
 <a class="code" href="classKParts_1_1ReadOnlyPart.html" title="Base class for any &quot;viewer&quot; part.">KParts::ReadOnlyPart</a>* part = KParts::ComponentFactory::createPartInstanceFromQuery&lt;KParts::ReadOnlyPart&gt;( mimetype, QString::null, parentWidget, 0, parentObject, 0 );
 <span class="keywordflow">if</span> ( part ) {
     part-&gt;<a class="code" href="classKParts_1_1ReadOnlyPart.html#a1717bbae9cbdfd38c6d9130914c29cd9" title="Only reimplement openURL if you don&#39;t want the network transparency support to download from the url ...">openURL</a>( url );
     part-&gt;<a class="code" href="classKParts_1_1Part.html#a2d2efd56fe23904104c48dc56371c03d">widget</a>()-&gt;<a class="codeRef" href="qwidget.html#show">show</a>();  <span class="comment">// also insert the widget into a layout, or simply use a QVBox as parentWidget</span>
 }
</pre></div><dl><dt><b>Parameters:</b></dt><dd>
  <table class="params">
    <tr><td class="paramname">serviceType</td><td>the type of service for which to find a part, e.g. a mimetype </td></tr>
    <tr><td class="paramname">constraint</td><td>an optional constraint to pass to the trader (see KTrader) </td></tr>
    <tr><td class="paramname">parentWidget</td><td>the parent widget, will be set as the parent of the part's widget </td></tr>
    <tr><td class="paramname">widgetName</td><td>the name that will be given to the part's widget </td></tr>
    <tr><td class="paramname">parent</td><td>the parent object for the part itself </td></tr>
    <tr><td class="paramname">name</td><td>the name that will be given to the part </td></tr>
    <tr><td class="paramname">args</td><td>A list of string arguments, passed to the factory and possibly to the component (see <a class="elRef" doxygen="kdecore.tag:../../kdecore/html/" href="../../kdecore/html/classKLibFactory.html">KLibFactory</a>) </td></tr>
    <tr><td class="paramname">error</td><td>The int passed here will receive an error code in case of errors. (See enum <a class="el" href="namespaceKParts_1_1ComponentFactory.html#aa0f34004323782d3721aea693a7e9bfb" title="This enum type defines the possible error cases that can happen when loading a component.">ComponentLoadingError</a>) </td></tr>
  </table>
  </dd>
</dl>
<dl class="return"><dt><b>Returns:</b></dt><dd>A pointer to the newly created object or a null pointer if the factory was unable to create an object of the given type. </dd></dl>

<p>Definition at line <a class="el" href="componentfactory_8h_source.html#l00370">370</a> of file <a class="el" href="componentfactory_8h_source.html">componentfactory.h</a>.</p>

</div>
</div>
</div>
    </div></div>


      </td>
  </tr>
  <tr>
    <td valign="top" id="leftmenu" width="25%">
      <a name="navigation"></a>
      <div class="menu_box"><h2>kparts</h2>
<div class="nav_list">
<ul><li><a href="index.html">Main Page</a></li><li><a href="namespaces.html">Namespace List</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="namespacemembers.html">Namespace Members</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="classKParts_1_1BrowserExtension.html">kparts::browserextension</option>,  <option value="classKParts_1_1BrowserHostExtension.html">kparts::browserhostextension</option>,  <option value="classKParts_1_1BrowserInterface.html">kparts::browserinterface</option>,  <option value="classKParts_1_1BrowserRun.html">kparts::browserrun</option>,  <option value="classKParts_1_1DockMainWindow.html">kparts::dockmainwindow</option>,  <option value="classKParts_1_1Event.html">kparts::event</option>,  <option value="classKParts_1_1Factory.html">kparts::factory</option>,  <option value="classKParts_1_1GenericFactory.html">kparts::genericfactory</option>,  <option value="classKParts_1_1GUIActivateEvent.html">kparts::guiactivateevent</option>,  <option value="classKParts_1_1HistoryProvider.html">kparts::historyprovider</option>,  <option value="classKParts_1_1LiveConnectExtension.html">kparts::liveconnectextension</option>,  <option value="classKParts_1_1MainWindow.html">kparts::mainwindow</option>,  <option value="classKParts_1_1OpenURLEvent.html">kparts::openurlevent</option>,  <option value="classKParts_1_1Part.html">kparts::part</option>,  <option value="classKParts_1_1PartActivateEvent.html">kparts::partactivateevent</option>,  <option value="classKParts_1_1PartBase.html">kparts::partbase</option>,  <option value="classKParts_1_1PartManager.html">kparts::partmanager</option>,  <option value="classKParts_1_1PartSelectEvent.html">kparts::partselectevent</option>,  <option value="classKParts_1_1Plugin.html">kparts::plugin</option>,  <option value="classKParts_1_1ReadOnlyPart.html">kparts::readonlypart</option>,  <option value="classKParts_1_1ReadWritePart.html">kparts::readwritepart</option>,  <option value="classKParts_1_1StatusBarExtension.html">kparts::statusbarextension</option>,
</select>
</form>
</div>
-->
</div></div>
<div class="menu_box"><h2>API Dox</h2>
<div class="nav_list">
<ul>
<li><a href="../../arts/html/index.html">arts</a></li><li><a href="../../dcop/html/index.html">dcop</a></li><li><a href="../../dnssd/html/index.html">dnssd</a></li><li><a href="../../interfaces/html/index.html">interfaces</a></li><li>&nbsp;&nbsp;&nbsp;&nbsp;<a href="../../interfaces/kimproxy/interface/html/index.html">interface</a></li><li>&nbsp;&nbsp;&nbsp;&nbsp;<a href="../../interfaces/kimproxy/library/html/index.html">library</a></li><li>&nbsp;&nbsp;<a href="../../interfaces/kspeech/html/index.html">kspeech</a></li><li>&nbsp;&nbsp;<a href="../../interfaces/ktexteditor/html/index.html">ktexteditor</a></li><li><a href="../../kabc/html/index.html">kabc</a></li><li><a href="../../kate/html/index.html">kate</a></li><li><a href="../../kcmshell/html/index.html">kcmshell</a></li><li><a href="../../kdecore/html/index.html">kdecore</a></li><li><a href="../../kded/html/index.html">kded</a></li><li><a href="../../kdefx/html/index.html">kdefx</a></li><li><a href="../../kdeprint/html/index.html">kdeprint</a></li><li><a href="../../kdesu/html/index.html">kdesu</a></li><li><a href="../../kdeui/html/index.html">kdeui</a></li><li><a href="../../kdoctools/html/index.html">kdoctools</a></li><li><a href="../../khtml/html/index.html">khtml</a></li><li><a href="../../kimgio/html/index.html">kimgio</a></li><li><a href="../../kinit/html/index.html">kinit</a></li><li><a href="../../kio/html/index.html">kio</a></li><li>&nbsp;&nbsp;<a href="../../kio/bookmarks/html/index.html">bookmarks</a></li><li>&nbsp;&nbsp;<a href="../../kio/httpfilter/html/index.html">httpfilter</a></li><li>&nbsp;&nbsp;<a href="../../kio/kfile/html/index.html">kfile</a></li><li>&nbsp;&nbsp;<a href="../../kio/kio/html/index.html">kio</a></li><li>&nbsp;&nbsp;<a href="../../kio/kioexec/html/index.html">kioexec</a></li><li>&nbsp;&nbsp;<a href="../../kio/kpasswdserver/html/index.html">kpasswdserver</a></li><li>&nbsp;&nbsp;<a href="../../kio/kssl/html/index.html">kssl</a></li><li><a href="../../kioslave/html/index.html">kioslave</a></li><li>&nbsp;&nbsp;<a href="../../kioslave/http/html/index.html">http</a></li><li><a href="../../kjs/html/index.html">kjs</a></li><li><a href="../../kmdi/html/index.html">kmdi</a></li><li>&nbsp;&nbsp;<a href="../../kmdi/kmdi/html/index.html">kmdi</a></li><li><a href="../../knewstuff/html/index.html">knewstuff</a></li><li><a href="../../kparts/html/index.html">kparts</a></li><li><a href="../../kresources/html/index.html">kresources</a></li><li><a href="../../kspell2/html/index.html">kspell2</a></li><li><a href="../../kunittest/html/index.html">kunittest</a></li><li><a href="../../kutils/html/index.html">kutils</a></li><li><a href="../../kwallet/html/index.html">kwallet</a></li><li><a href="../../libkmid/html/index.html">libkmid</a></li><li><a href="../../libkscreensaver/html/index.html">libkscreensaver</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>