1#ifndef Cpl_Dm_Mp_Enum_h_
2#define Cpl_Dm_Mp_Enum_h_
35template<
class BETTERENUM_TYPE,
class MPTYPE>
46 ,
m_data( BETTERENUM_TYPE::_from_index_unchecked( 0 ) )
53 ,
m_data( BETTERENUM_TYPE::_from_index_unchecked( 0 ) )
60 inline bool read( BETTERENUM_TYPE& dstData, uint16_t* seqNumPtr = 0 ) const noexcept
62 return readData( &dstData,
sizeof( BETTERENUM_TYPE ), seqNumPtr );
68 return writeData( &newValue,
sizeof( BETTERENUM_TYPE ), lockRequest );
99 doc[
"val"] = (
char*)
m_data._to_string();
107 const char* newValue = src;
108 if ( newValue ==
nullptr )
112 *errorMsg =
"Invalid syntax for the 'val' key/value pair";
118 auto maybeValue = BETTERENUM_TYPE::_from_string_nothrow( newValue );
123 errorMsg->format(
"Invalid enum value (%s)", newValue );
128 retSequenceNumber =
write( *maybeValue, lockRequest );
This concrete class implements a simple Model Database.
Definition ModelDatabase.h:56
This concrete class provide common infrastructure for a Model Point.
Definition ModelPointCommon_.h:32
void attachSubscriber(SubscriberApi &observer, uint16_t initialSeqNumber=SEQUENCE_NUMBER_UNKNOWN) noexcept
See Cpl::Dm::ModelPoint.
void detachSubscriber(SubscriberApi &observer) noexcept
See Cpl::Dm::ModelPoint.
bool readAndSync(void *dstData, size_t dstSize, SubscriberApi &observerToSync)
This method is used to read the MP contents and synchronize the observer with the current MP contents...
Definition ModelPointCommon_.h:93
virtual uint16_t copyDataAndStateFrom(const ModelPointCommon_ &src, LockRequest_T lockRequest) noexcept
Updates the MP with the valid-state/data from 'src'. Note: the src.lock state is NOT copied.
bool readData(void *dstData, size_t dstSize, uint16_t *seqNumPtr=0) const noexcept
See Cpl::Dm::ModelPoint.
uint16_t writeData(const void *srcData, size_t srcSize, LockRequest_T lockRequest=eNO_REQUEST) noexcept
See Cpl::Dm::ModelPoint.
LockRequest_T
Options related to the Model Point's locked state.
Definition ModelPoint.h:50
@ eNO_REQUEST
No change in the MP's lock state is requested.
Definition ModelPoint.h:51
static const uint16_t SEQUENCE_NUMBER_UNKNOWN
Magic value to use when registering for a change notification and application does not 'know' the cur...
Definition ModelPoint.h:62
This template class provides a mostly concrete implementation for a Model Point who's data is a BETTE...
Definition Enum_.h:37
Enum_(Cpl::Dm::ModelDatabase &myModelBase, const char *symbolicName)
Constructor: Invalid MP.
Definition Enum_.h:44
bool readAndSync(BETTERENUM_TYPE &dstData, SubscriberApi &observerToSync)
See Cpl::Dm::ModelPointCommon.
Definition Enum_.h:90
uint16_t copyFrom(const MPTYPE &src, LockRequest_T lockRequest=eNO_REQUEST) noexcept
Updates the MP with the valid-state/data from 'src'. Note: the src.lock state is NOT copied.
Definition Enum_.h:72
BETTERENUM_TYPE m_data
The element's value.
Definition Enum_.h:40
uint16_t write(BETTERENUM_TYPE newValue, Cpl::Dm::ModelPoint::LockRequest_T lockRequest=Cpl::Dm::ModelPoint::eNO_REQUEST) noexcept
Type safe write. See Cpl::Dm::ModelPoint.
Definition Enum_.h:66
void setJSONVal(JsonDocument &doc) noexcept
See Cpl::Dm::Point.
Definition Enum_.h:97
bool fromJSON_(JsonVariant &src, Cpl::Dm::ModelPoint::LockRequest_T lockRequest, uint16_t &retSequenceNumber, Cpl::Text::String *errorMsg) noexcept
See Cpl::Dm::Point.
Definition Enum_.h:104
void attach(Cpl::Dm::Subscriber< MPTYPE > &observer, uint16_t initialSeqNumber=SEQUENCE_NUMBER_UNKNOWN) noexcept
Type safe register observer.
Definition Enum_.h:78
void detach(Cpl::Dm::Subscriber< MPTYPE > &observer) noexcept
Type safe un-register observer.
Definition Enum_.h:84
Enum_(Cpl::Dm::ModelDatabase &myModelBase, const char *symbolicName, BETTERENUM_TYPE initialValue)
Constructor: Valid MP (requires initial value)
Definition Enum_.h:51
bool read(BETTERENUM_TYPE &dstData, uint16_t *seqNumPtr=0) const noexcept
Type safe read. See Cpl::Dm::ModelPoint.
Definition Enum_.h:60
This abstract class defines the Subscriber interface - for change notifications - to a Model Points d...
Definition SubscriberApi.h:34
This template class defines a type safe Subscriber.
Definition Subscriber.h:82
This abstract class defines the operations that can be before on a NULL terminated string.
Definition String.h:40
The 'Cpl' namespace is the root name space for the Colony.
Definition Api16.h:20