OpendTect-6_4  6.4
Public Types | Public Member Functions | Protected Attributes | Static Private Member Functions | List of all members
Factory< T > Class Template Reference

Generalized static factory that can deliver instances of T, when no variable is needed in the creation. More...

Inheritance diagram for Factory< T >:
[legend]

Public Types

typedef T *(* Creator) ()
 

Public Member Functions

void addCreator (Creator, const char *nm, const uiString &username=uiString::emptyString())
 
T * create (const char *nm) const
 Name may be not be null. More...
 
- Public Member Functions inherited from FactoryBase
virtual ~FactoryBase ()
 
int size () const
 
bool isEmpty () const
 
bool hasName (const char *n)
 
const BufferStringSetgetNames () const
 
const uiStringSetgetUserNames () const
 
void setDefaultName (int idx)
 
const char * getDefaultName () const
 
BufferStringerrMsg () const
 
const char * currentName () const
 

Protected Attributes

TypeSet< Creatorcreators_
 
- Protected Attributes inherited from FactoryBase
StaticStringManager errmsgs_
 
StaticStringManager currentname_
 

Static Private Member Functions

static uiString tr (const char *text, const char *disambiguation=0, int pluralnr=-1)
 
static uiString legacyTr (const char *text, const char *disambiguation=0, int pluralnr=-1)
 

Additional Inherited Members

- Static Public Member Functions inherited from FactoryBase
static char cSeparator ()
 
- Protected Member Functions inherited from FactoryBase
int indexOf (const char *) const
 
void addNames (const char *, const uiString &)
 
void setNames (int, const char *, const uiString &)
 

Detailed Description

template<class T>
class Factory< T >

Generalized static factory that can deliver instances of T, when no variable is needed in the creation.

Usage. Each implementation of the base class T must add themselves to the factory when application starts up, e.g. in an initClass() function:

class A
{
public:
virtual int myFunc() = 0;
};
class B : public A
{
public:
static A* createFunc() { return new B; }
static void initClass()
{ thefactory.addCreator(createFunc,"MyKeyword",
"My Name"); }
int myFunc();
};

Two macros are available to make a static accessfuncion for the factory:

mDefineFactory( Module, ClassName, FunctionName );

that will create a static function that returns an instance to Factory<ClassName>. If the function is a static member of a class, it has to be defined with the mDefineFactoryInClass macro.

The static function must be implemented in a src-file with the macro

mImplFactory( ClassName, FunctionName );

Member Typedef Documentation

template<class T >
typedef T*(* Factory< T >::Creator) ()

Member Function Documentation

template<class T >
void Factory< T >::addCreator ( Creator  cr,
const char *  nm,
const uiString username = uiString::emptyString() 
)
inline

Name may be not be null If nm is found, old creator is replaced. nm can be a SeparString, separated by cSeparator(), allowing multiple names, where the first name will be the main name that is returned in getNames.

template<class T >
T * Factory< T >::create ( const char *  nm) const
inline

Name may be not be null.

template<class T >
static uiString Factory< T >::legacyTr ( const char *  text,
const char *  disambiguation = 0,
int  pluralnr = -1 
)
inlinestaticprivate
template<class T >
static uiString Factory< T >::tr ( const char *  text,
const char *  disambiguation = 0,
int  pluralnr = -1 
)
inlinestaticprivate

Member Data Documentation

template<class T >
TypeSet<Creator> Factory< T >::creators_
protected

Generated at for the OpendTect seismic interpretation project. Copyright (C): dGB Beheer B. V. 2019