About
The maxon::Factory template is used to create factory functions for a given interface. Such factory functions allow to safely create new, initialized instances of that interface.
Declaration
Based on the maxon::Factory template, a factory is typically declared as a published object using MAXON_DECLARATION.
using StringHashFactoryType = maxon::Factory<StringHashRef(
maxon::String)>;
MAXON_DECLARATION(StringHashFactoryType, StringHashFromStringFactory,
"net.maxonexample.factory.stringhashfromstring");
Definition: string.h:1226
#define MAXON_DECLARATION(T, Name, id,...)
Definition: module.h:812
Implementation
The published object containing the new factory must be defined in a source code file using MAXON_DECLARATION_REGISTER. The behaviour of the factory depends on a referenced function that is invoked by the factory:
- maxon::Factory::CreateFactory(): References a static function for creation of the desired object.
- maxon::Factory::CreateObjectFactory(): References a member function of a specific implementation. This function will create an instance and will call that member function.
Examples
This example shows a simple interface that just provides read-only access to its data.
{
public:
};
Definition: resultbase.h:766
#define MAXON_REFERENCE_NORMAL(FREEIMPL)
Definition: interfacebase.h:1090
#define MAXON_INTERFACE(Name, REFKIND, ID)
Definition: objectbase.h:1125
#define MAXON_METHOD
Definition: interfacebase.h:942
#define MAXON_INTERFACE_BASES(...)
Definition: objectbase.h:1054
The implementation can look like this:
class SecretStringHashImplementation :
public maxon::Component<SecretStringHashImplementation, StringHashInterface>
{
public:
{
}
{
if (_hash.IsPopulated())
if (hash.GetLength() != 64)
_hash = hash;
}
{
return InitFromHash(hash);
}
{
}
private:
};
Definition: c4d_string.h:39
Definition: objectbase.h:2632
Result< String > GetPasswordHash(const String &password, const StreamConversionFactory &hashClass, const DataDictionary &settings=DataDictionary())
return OK
Definition: apibase.h:2620
MAXON_ATTRIBUTE_FORCE_INLINE Bool IsEqual(PREDICATE &&predicate, const T1 &a, const T2 &b)
Definition: collection.h:102
#define MAXON_SOURCE_LOCATION
Definition: memoryallocationbase.h:67
#define MAXON_COMPONENT(KIND,...)
Definition: objectbase.h:2193
The maxon namespace contains all declarations of the MAXON API.
Definition: c4d_basedocument.h:16
#define iferr_scope
Definition: resultbase.h:1374
#define iferr_return
Definition: resultbase.h:1465
Since it should not be possible to change the internal data of an existing instance, the internal data must be set when the object is created. Within a header file a factory can be defined as a published object.
using StringHashFactoryType = maxon::Factory<StringHashRef(
maxon::String)>;
MAXON_DECLARATION(StringHashFactoryType, StringHashFromStringFactory,
"net.maxonexample.factory.stringhashfromstring");
A factory can call a static function that in return will create a new instance with the given arguments:
{
StringHashRef res = SecretStringHashImplementation::GetClass().Create()
iferr_return;
return res;
}
{
return StringHashFactoryType::CreateFactory(&MakeSecretStringFromHash);
}
#define MAXON_DECLARATION_REGISTER(...)
Definition: module.h:888
const Class< R > & Get(const Id &cls)
Definition: objectbase.h:2060
A different factory can invoke a member function of the implementation class. Then it will create an instance of that specific implementation automatically:
{
return StringHashFactoryType::CreateObjectFactory(&SecretStringHashImplementation::FactoryInit);
}
The factory is then used as any other published object:
const StringHashRef stringHash = StringHashFromStringFactory().Create(secretText)
iferr_return;
if (equal)
bool Bool
boolean type, possible values are only false/true, 8 bit
Definition: apibase.h:183
#define DiagnosticOutput(formatString,...)
Definition: debugdiagnostics.h:176
Further Reading