DynExp
Highly flexible laboratory automation for dynamically changing experiments.
DynExp::ParamsBase::TypedParamBase< ParamType > Class Template Reference

Base class of parameters containing a single value. More...

+ Inheritance diagram for DynExp::ParamsBase::TypedParamBase< ParamType >:

Public Types

using UnderlyingType = ParamType
 

Public Member Functions

ParamType GetDefaultValue () const noexcept
 Returns this parameter's default value. Thread-safe since a const member variable is returned. More...
 
 operator ParamType () const noexcept
 Converts the parameter implicitly to its underlying type returning its current value. More...
 
const ParamType & Get () const noexcept
 Returns the parameter's value. More...
 
const ParamType & operator= (const ParamType &NewValue)
 Assigns a new value to this parameter. The operator cannot be accessed by Object because this function is not const. More...
 
- Public Member Functions inherited from DynExp::ParamsBase::ParamBase
 ParamBase (const ParamBase &)=delete
 
ParamBaseoperator= (const ParamBase &)=delete
 
QDomElement ToXMLNode (QDomDocument &Document) const
 Converts this parameter to a Qt dom element (describing an XML node containing this parameter's name and value). More...
 
void FromXMLNode (const QDomElement &XMLElement)
 Restores this parameter's value from the given Qt dom element (describing an XML node) More...
 
bool Validate ()
 Checks whether a valid value is assigned to this parameter. This function is not const since it is also intended to reset the parameter if it is invalid. More...
 
void Reset ()
 Resets this parameter to its default value. More...
 
bool IsUserEditable () const noexcept
 Returns ParamBase::UserEditable. More...
 
std::string_view GetParamName () const noexcept
 Returns ParamBase::ParamName. More...
 
std::string_view GetParamTitle () const noexcept
 Returns ParamBase::ParamTitle. More...
 
std::string_view GetParamDescription () const noexcept
 Returns ParamBase::ParamDescription. More...
 
bool GetNeedsResetToApplyChange () const noexcept
 Returns ParamBase::NeedsResetToApplyChange. More...
 

Protected Member Functions

 TypedParamBase (ParamsBase &Owner, std::string ParamName, std::string_view ParamTitle, std::string_view ParamDescription, bool NeedsResetToApplyChange=true, ParamType DefaultValue=ParamType())
 Base constructor of any parameter to be used if a parameter should be displayed in a settings dialog (UserEditable is set to true). More...
 
 TypedParamBase (ParamsBase &Owner, std::string ParamName, ParamType DefaultValue=ParamType())
 Base constructor of any parameter to be used if a parameter should not be displayed in a settings dialog (UserEditable is set to false). More...
 
virtual void ToXMLNodeChild (QDomDocument &Document, QDomElement &XMLElement) const override
 Converts this parameter to a Qt dom element (describing an XML node containing this parameter's name and value). More...
 
virtual void FromXMLNodeChild (const QDomElement &XMLElement) override
 Restores this parameter's value from the given Qt dom element (describing an XML node) More...
 
- Protected Member Functions inherited from DynExp::ParamsBase::ParamBase
 ParamBase (ParamsBase &Owner, std::string ParamName, std::string_view ParamTitle, std::string_view ParamDescription, bool NeedsResetToApplyChange)
 Base constructor of any parameter to be used if a parameter should be displayed in a settings dialog (UserEditable is set to true). More...
 
 ParamBase (ParamsBase &Owner, std::string ParamName)
 Base constructor of any parameter to be used if a parameter should not be displayed in a settings dialog (UserEditable is set to false). More...
 
virtual ~ParamBase ()=0
 
const auto & GetOwner () const noexcept
 Returns the ParamsBase instance owning this ParamBase instance. More...
 
auto & GetOwner () noexcept
 Returns the ParamsBase instance owning this ParamBase instance. More...
 

Private Member Functions

virtual bool ValidateChild () const override final
 Checks whether a valid value is assigned to this parameter. This function is not const since it is also intended to reset the parameter if it is invalid. Returns true by default. More...
 
virtual bool ValidateValue (const ParamType &NewValue) const
 Called by ValidateChild(). Validates a single value. Override to validate the value which is about to be assigned to the parameter. Returns true by default. More...
 
virtual void ResetChild () override
 Resets this parameter to its default value. More...
 

Private Attributes

const ParamType DefaultValue
 Value to assign to the parameter upon construction and reset. More...
 
ParamType Value
 Current parameter value. More...
 

Additional Inherited Members

- Public Attributes inherited from DynExp::ParamsBase::ParamBase
ParamsBaseOnlyType ParamsBaseOnly
 Provides the class ParamsBase access to some private members of class ParamBase. More...
 

Detailed Description

template<typename ParamType>
class DynExp::ParamsBase::TypedParamBase< ParamType >

Base class of parameters containing a single value.

Template Parameters
ParamTypeUnderlying parameter value type

Definition at line 538 of file Object.h.

Member Typedef Documentation

◆ UnderlyingType

template<typename ParamType >
using DynExp::ParamsBase::TypedParamBase< ParamType >::UnderlyingType = ParamType

Definition at line 541 of file Object.h.

Constructor & Destructor Documentation

◆ TypedParamBase() [1/2]

template<typename ParamType >
DynExp::ParamsBase::TypedParamBase< ParamType >::TypedParamBase ( ParamsBase Owner,
std::string  ParamName,
std::string_view  ParamTitle,
std::string_view  ParamDescription,
bool  NeedsResetToApplyChange = true,
ParamType  DefaultValue = ParamType() 
)
inlineprotected

Base constructor of any parameter to be used if a parameter should be displayed in a settings dialog (UserEditable is set to true).

Parameters
OwnerParamsBase instance owning this parameter.
ParamNameName of the parameter to be used in the XML config file. std::string to allow for auto-generated names.
ParamTitleTitle of the parameter to be displayed in settings dialogs. A static string literal with a constant address is expected.
ParamDescriptionDetailed description of the parameter to be displayed in settings dialogs. A static string literal with a constant address is expected.
NeedsResetToApplyChangeIndicated whether the object this parameter belongs to needs to be reset to apply changes if this parameter's value has changed.
DefaultValueDefault value to assign to the constructed parameter

Definition at line 548 of file Object.h.

◆ TypedParamBase() [2/2]

template<typename ParamType >
DynExp::ParamsBase::TypedParamBase< ParamType >::TypedParamBase ( ParamsBase Owner,
std::string  ParamName,
ParamType  DefaultValue = ParamType() 
)
inlineprotected

Base constructor of any parameter to be used if a parameter should not be displayed in a settings dialog (UserEditable is set to false).

Parameters
OwnerParamsBase instance owning this parameter.
ParamNameName of the parameter to be used in the XML config file. std::string to allow for auto-generated names.
DefaultValueDefault value to assign to the constructed parameter

Definition at line 557 of file Object.h.

Member Function Documentation

◆ FromXMLNodeChild()

template<typename ParamType >
virtual void DynExp::ParamsBase::TypedParamBase< ParamType >::FromXMLNodeChild ( const QDomElement &  XMLElement)
inlineoverrideprotectedvirtual

Restores this parameter's value from the given Qt dom element (describing an XML node)

Parameters
XMLElementQt dom element containing information about this parameter.

Implements DynExp::ParamsBase::ParamBase.

Reimplemented in DynExp::ParamsBase::Param< LinkType, std::enable_if_t< std::is_base_of_v< ObjectLinkBase, LinkType > > >.

Definition at line 604 of file Object.h.

◆ Get()

template<typename ParamType >
const ParamType& DynExp::ParamsBase::TypedParamBase< ParamType >::Get ( ) const
inlinenoexcept

Returns the parameter's value.

Returns
Current parameter value

Definition at line 577 of file Object.h.

◆ GetDefaultValue()

template<typename ParamType >
ParamType DynExp::ParamsBase::TypedParamBase< ParamType >::GetDefaultValue ( ) const
inlinenoexcept

Returns this parameter's default value. Thread-safe since a const member variable is returned.

Returns
Parameter's default value

Definition at line 566 of file Object.h.

◆ operator ParamType()

template<typename ParamType >
DynExp::ParamsBase::TypedParamBase< ParamType >::operator ParamType ( ) const
inlinenoexcept

Converts the parameter implicitly to its underlying type returning its current value.

Definition at line 571 of file Object.h.

◆ operator=()

template<typename ParamType >
const ParamType& DynExp::ParamsBase::TypedParamBase< ParamType >::operator= ( const ParamType &  NewValue)
inline

Assigns a new value to this parameter. The operator cannot be accessed by Object because this function is not const.

Parameters
NewValueNew value to assign
Returns
Reference to this parameter
Exceptions
Util::InvalidArgExceptionis thrown if the value to assign to the parameter is not considered valid as determined by a call to ParamBase::Validate().

Definition at line 587 of file Object.h.

◆ ResetChild()

template<typename ParamType >
virtual void DynExp::ParamsBase::TypedParamBase< ParamType >::ResetChild ( )
inlineoverrideprivatevirtual

Resets this parameter to its default value.

Implements DynExp::ParamsBase::ParamBase.

Definition at line 620 of file Object.h.

◆ ToXMLNodeChild()

template<typename ParamType >
virtual void DynExp::ParamsBase::TypedParamBase< ParamType >::ToXMLNodeChild ( QDomDocument &  Document,
QDomElement &  XMLElement 
) const
inlineoverrideprotectedvirtual

Converts this parameter to a Qt dom element (describing an XML node containing this parameter's name and value).

Parameters
DocumentQt dom document within to create the dom element.
XMLElementQt dom element to save information about this parameter to.

Implements DynExp::ParamsBase::ParamBase.

Definition at line 598 of file Object.h.

◆ ValidateChild()

template<typename ParamType >
virtual bool DynExp::ParamsBase::TypedParamBase< ParamType >::ValidateChild ( ) const
inlinefinaloverrideprivatevirtual

Checks whether a valid value is assigned to this parameter. This function is not const since it is also intended to reset the parameter if it is invalid. Returns true by default.

Returns
Returns true if the parameter is valid. Returns false if it was invalid and has been reset. Returns true by default.

Reimplemented from DynExp::ParamsBase::ParamBase.

Definition at line 610 of file Object.h.

◆ ValidateValue()

template<typename ParamType >
virtual bool DynExp::ParamsBase::TypedParamBase< ParamType >::ValidateValue ( const ParamType &  NewValue) const
inlineprivatevirtual

Called by ValidateChild(). Validates a single value. Override to validate the value which is about to be assigned to the parameter. Returns true by default.

Parameters
NewValueValue to be validated before the assignment
Returns
Returns true if NewValue is considered valid, false otherwise.

Reimplemented in DynExp::ParamsBase::Param< ParamType, std::enable_if_t< std::is_base_of_v< IndexedTextList, ParamType > > >.

Definition at line 618 of file Object.h.

Member Data Documentation

◆ DefaultValue

template<typename ParamType >
const ParamType DynExp::ParamsBase::TypedParamBase< ParamType >::DefaultValue
private

Value to assign to the parameter upon construction and reset.

Definition at line 622 of file Object.h.

◆ Value

template<typename ParamType >
ParamType DynExp::ParamsBase::TypedParamBase< ParamType >::Value
private

Current parameter value.

Definition at line 623 of file Object.h.


The documentation for this class was generated from the following file: