#include <user_info.h>
Public Member Functions | |
root * | new_instance () const |
A method returning a brand new instance of class T, this method is the reason why there have to be a parameterless construcotor in class T. | |
template<> | |
const ParticularUI < epdf_harness > & | factory (ParticularUI< epdf_harness >("epdf_harness")) |
template<> | |
const ParticularUI < mpdf_harness > & | factory (ParticularUI< mpdf_harness >("mpdf_harness")) |
Static Public Attributes | |
static const ParticularUI< T > & | factory |
The only instance of this class (each type T has its own instance) which is used as a factory for processing related UI. | |
Private Types | |
enum | SettingPresence { optional, compulsory } |
Enumerical type used to determine whether the data for concrete Settingis is compulsory or optional. | |
Static Private Member Functions | |
Initialization of classes | |
template<class T > | |
static T * | build (const Setting &element, const string &name, SettingPresence settingPresence=optional) |
template<class T > | |
static T * | build (const Setting &element, const int index, SettingPresence settingPresence=optional) |
template<class T > | |
static T * | build (const Setting &element) |
The new instance of type T* is constructed and initialized with values stored in the Setting element. | |
Initialization of structures | |
The type T has to be int, double, string, vec, ivec or mat. | |
template<class T > | |
static bool | get (T &instance, const Setting &element, const string &name, SettingPresence settingPresence=optional) |
template<class T > | |
static bool | get (T &instance, const Setting &element, const int index, SettingPresence settingPresence=optional) |
template<class T > | |
static bool | get (T &instance, const Setting &element) |
The existing instance of type T is initialized with values stored in the Setting element directly. | |
Initialization of arrays Array<T> | |
template<class T > | |
static bool | get (Array< T > &array_to_load, const Setting &element, const string &name, SettingPresence settingPresence=optional) |
template<class T > | |
static bool | get (Array< T > &array_to_load, const Setting &element, const int index, SettingPresence settingPresence=optional) |
template<class T > | |
static bool | get (Array< T > &array_to_load, const Setting &element) |
The existing array of type T is initialized with values stored in the Setting element. | |
Serialization of objects and structures into a new Setting | |
The new child Setting can be accessed either by its name - if some name is passed as a parameter - or by its integer index. In that case, the new element is added at the very end of the current list of child Settings. | |
template<class T > | |
static void | save (const T *const instance, Setting &element, const string &name="") |
A root descendant instance is stored in the new child Setting appended to the passed element. | |
template<class T > | |
static void | save (const Array< T > &array_to_save, Setting &element, const string &name="") |
An Array<T> instance is stored in the new child Setting appended to the passed element. | |
static void | save (const mat &matrix, Setting &element, const string &name="") |
A matrix(of type mat) is stored in the new child Setting appended to the passed element. | |
static void | save (const ivec &vec, Setting &element, const string &name="") |
An integer vector (of type ivec) is stored in the new child Setting appended to the passed element. | |
static void | save (const vec &vector, Setting &element, const string &name="") |
A double vector (of type vec) is stored in the new child Setting appended to the passed element. | |
static void | save (const string &str, Setting &element, const string &name="") |
A string is stored in the new child Setting appended to the passed element. | |
static void | save (const int &integer, Setting &element, const string &name="") |
An integer is stored in the new child Setting appended to the passed element. | |
static void | save (const double &real, Setting &element, const string &name="") |
A double is stored in the new child Setting appended to the passed element. |