Cantera
2.5.1
|
Factory class for creating new instances of classes derived from Transport. More...
#include <TransportFactory.h>
Public Member Functions | |
virtual void | deleteFactory () |
Deletes the statically allocated factory instance. More... | |
virtual Transport * | newTransport (const std::string &model, thermo_t *thermo, int log_level=0, int ndim=-99) |
Build a new transport manager using a transport manager that may not be the same as in the phase description and return a base class pointer to it. More... | |
virtual Transport * | newTransport (thermo_t *thermo, int log_level=0) |
Build a new transport manager using the default transport manager in the phase description and return a base class pointer to it. More... | |
Public Member Functions inherited from Factory< Transport > | |
Transport * | create (const std::string &name, Args... args) |
Create an object using the object construction function corresponding to "name" and the provided constructor arguments. More... | |
void | reg (const std::string &name, std::function< Transport *(Args...)> f) |
Register a new object construction function. More... | |
void | addAlias (const std::string &original, const std::string &alias) |
Add an alias for an existing registered type. More... | |
std::string | canonicalize (const std::string &name) |
Get the canonical name registered for a type. More... | |
bool | exists (const std::string &name) const |
Returns true if name is registered with this factory. More... | |
Public Member Functions inherited from FactoryBase | |
virtual | ~FactoryBase () |
destructor More... | |
Static Public Member Functions | |
static TransportFactory * | factory () |
Return a pointer to a TransportFactory instance. More... | |
Static Public Member Functions inherited from FactoryBase | |
static void | deleteFactories () |
static function that deletes all factories in the internal registry maintained in a static variable More... | |
Private Member Functions | |
TransportFactory () | |
The constructor is private; use static method factory() to get a pointer to a factory instance. More... | |
Private Attributes | |
std::map< std::string, bool > | m_CK_mode |
Models included in this map are initialized in CK compatibility mode. More... | |
Static Private Attributes | |
static TransportFactory * | s_factory = 0 |
Static instance of the factor -> This is the only instance of this object allowed. More... | |
static std::mutex | transport_mutex |
Static instance of the mutex used to ensure the proper reading of the transport database. More... | |
Additional Inherited Members | |
Protected Member Functions inherited from Factory< Transport > | |
void | addDeprecatedAlias (const std::string &original, const std::string &alias) |
Add a deprecated alias for an existing registered type. More... | |
Protected Member Functions inherited from FactoryBase | |
FactoryBase () | |
Constructor. More... | |
Factory class for creating new instances of classes derived from Transport.
Creates 'transport managers', which are classes derived from class Transport that provide transport properties. TransportFactory handles all initialization required, including evaluation of collision integrals and generating polynomial fits. Transport managers can also be created in other ways.
Definition at line 30 of file TransportFactory.h.
|
private |
The constructor is private; use static method factory() to get a pointer to a factory instance.
The default constructor for this class sets up m_models[], a mapping between the string name for a transport model and the integer name.
Definition at line 47 of file TransportFactory.cpp.
Referenced by TransportFactory::factory().
|
inlinestatic |
Return a pointer to a TransportFactory instance.
TransportFactory is implemented as a 'singleton', which means that at most one instance may be created. The constructor is private. When a TransportFactory instance is required, call static method factory() to return a pointer to the TransportFactory instance.
Definition at line 45 of file TransportFactory.h.
References TransportFactory::s_factory, TransportFactory::transport_mutex, and TransportFactory::TransportFactory().
|
virtual |
Deletes the statically allocated factory instance.
Implements FactoryBase.
Definition at line 71 of file TransportFactory.cpp.
|
virtual |
Build a new transport manager using a transport manager that may not be the same as in the phase description and return a base class pointer to it.
model | String name for the transport manager |
thermo | ThermoPhase object |
log_level | log level |
ndim | Number of dimensions for fluxes |
ndim
parameter is unused and will be removed after Cantera 2.5. Definition at line 78 of file TransportFactory.cpp.
References Transport::init(), DustyGasTransport::initialize(), Phase::restoreState(), Phase::saveState(), and Cantera::warn_deprecated().
Referenced by Cantera::newTransportMgr().
Build a new transport manager using the default transport manager in the phase description and return a base class pointer to it.
thermo | ThermoPhase object |
log_level | log level |
Definition at line 104 of file TransportFactory.cpp.
References XML_Node::attrib(), XML_Node::child(), XML_Node::hasChild(), AnyMap::hasKey(), ThermoPhase::input(), and Phase::xml().
|
staticprivate |
Static instance of the factor -> This is the only instance of this object allowed.
Definition at line 81 of file TransportFactory.h.
Referenced by TransportFactory::factory().
|
staticprivate |
Static instance of the mutex used to ensure the proper reading of the transport database.
Definition at line 85 of file TransportFactory.h.
Referenced by TransportFactory::factory().
|
private |
Models included in this map are initialized in CK compatibility mode.
Definition at line 96 of file TransportFactory.h.