• Skip to content
  • Skip to link menu
Trinity API Reference
  • Trinity API Reference
  • tdeparts
 

tdeparts

  • KParts
  • GenericFactory
Public Member Functions | List of all members
KParts::GenericFactory< T > Class Template Reference

#include <genericfactory.h>

Inherits KParts::GenericFactoryBase< T >.

Public Member Functions

virtual KParts::Part * createPartObject (TQWidget *parentWidget, const char *widgetName, TQObject *parent, const char *name, const char *className, const TQStringList &args)
 

Detailed Description

template<class T>
class KParts::GenericFactory< T >

A template for a KParts::Factory implementation.

It implements the pure virtual createPartObject method by instantiating the template argument when requested through the className field. In addition it is a container for a part's TDEInstance object, by providing a static TDEInstance *instance() method.

The template argument has to inherit from KParts::Part and has to implement two methods: 1) There needs to be a public constructor with the following signature: MyPart( TQWidget *parentWidget, const char *widgetName, TQObject *parent, const char *name, const TQStringList& args )

2) It needs to provide one static method to create a TDEAboutData object per request, holding information about the component's name, its authors, license, etc. The signature of that static method has to be TDEAboutData *createAboutData()

The template will take care of memory management of the TDEInstance and the TDEAboutData object, meaning ownership of what createAboutData returns is passed to the caller (this template) .

For advanced use you can also inherit from the template and re-implement additionally the virtual TDEInstance *createInstance() method, for example in case you want to extend the paths of your instance's TDEStandardDirs object.

If a KParts::ReadOnlyPart is requested through this factory and the template argument implements a KParts::ReadWritePart then setReadWrite( false ) will automatically be called in createPartObject.

Use the factory through the K_EXPORT_COMPONENT_FACTORY macro, like that:

typedef KParts::GenericFactory&lt;YourKPart&gt; YourKPartFactory;
K_EXPORT_COMPONENT_FACTORY( yourlibrary, YourKPartFactory )
KParts::GenericFactory
A template for a KParts::Factory implementation.
Definition: genericfactory.h:96

yourlibrary is the library name that you compiled your KPart into.

Definition at line 95 of file genericfactory.h.

Constructor & Destructor Documentation

◆ GenericFactory()

template<class T >
KParts::GenericFactory< T >::GenericFactory ( )
inline

Definition at line 98 of file genericfactory.h.

Member Function Documentation

◆ createPartObject()

template<class T >
virtual KParts::Part * KParts::GenericFactory< T >::createPartObject ( TQWidget *  parentWidget,
const char *  widgetName,
TQObject *  parent,
const char *  name,
const char *  classname,
const TQStringList &  args 
)
inlinevirtual

Reimplement this method in your implementation to create the Part.

The TQStringList can be used to pass additional arguments to the part. If the part needs additional arguments, it should take them as name="value" pairs. This is the way additional arguments will get passed to the part from eg. tdehtml. You can for example emebed the part into HTML by using the following code:

<object type="my_mimetype" data="url_to_my_data">
<param name="name1" value="value1">
<param name="name2" value="value2">
</object>

This could result in a call to

createPart( parentWidget, name, parentObject, parentName, "Kparts::Part",
TQStringList("name1="value1"", "name2="value2") );
KParts::Factory::createPart
Part * createPart(TQWidget *parentWidget=0, const char *widgetName=0, TQObject *parent=0, const char *name=0, const char *classname="KParts::Part", const TQStringList &args=TQStringList())
Creates a part.
Definition: factory.cpp:42
Returns
the newly created part.

Implements KParts::Factory.

Definition at line 100 of file genericfactory.h.


The documentation for this class was generated from the following file:
  • genericfactory.h

tdeparts

Skip menu "tdeparts"
  • Main Page
  • Namespace List
  • Class Hierarchy
  • Alphabetical List
  • Class List
  • File List
  • Namespace Members
  • Class Members
  • Related Pages

tdeparts

Skip menu "tdeparts"
  • arts
  • dcop
  • dnssd
  • interfaces
  •   kspeech
  •     interface
  •     library
  •   tdetexteditor
  • kate
  • kded
  • kdoctools
  • kimgio
  • kjs
  • libtdemid
  • libtdescreensaver
  • tdeabc
  • tdecmshell
  • tdecore
  • tdefx
  • tdehtml
  • tdeinit
  • tdeio
  •   bookmarks
  •   httpfilter
  •   kpasswdserver
  •   kssl
  •   tdefile
  •   tdeio
  •   tdeioexec
  • tdeioslave
  •   http
  • tdemdi
  •   tdemdi
  • tdenewstuff
  • tdeparts
  • tdeprint
  • tderandr
  • tderesources
  • tdespell2
  • tdesu
  • tdeui
  • tdeunittest
  • tdeutils
  • tdewallet
Generated for tdeparts by doxygen 1.9.4
This website is maintained by Timothy Pearson.