![]() |
GM6000 Digital Heater Controller Branch: main
SDX-1330
|
This concrete template class provides the storage for a Point who's data is a null terminated string. More...
This concrete template class provides the storage for a Point who's data is a null terminated string.
Template Args: S:= Max Size of the String WITHOUT the null terminator!
#include <String.h>
Public Types | |
typedef Cpl::Dm::Subscriber< String > | Observer |
Type safe subscriber. | |
![]() | |
enum | LockRequest_T { eNO_REQUEST , eLOCK , eUNLOCK } |
Options related to the Model Point's locked state. More... | |
enum | Event_T { eATTACH , eDETACH , eDATA_CHANGED , eNOTIFYING , eNOTIFY_COMPLETE } |
Subscriber events. More... | |
Public Member Functions | |
String (Cpl::Dm::ModelDatabase &myModelBase, const char *symbolicName) | |
Constructor. | |
String (Cpl::Dm::ModelDatabase &myModelBase, const char *symbolicName, const char *initialValue) | |
Constructor. Valid Point. Requires an initial value. | |
void | attach (Observer &observer, uint16_t initialSeqNumber=SEQUENCE_NUMBER_UNKNOWN) noexcept |
Type safe register observer. | |
void | detach (Observer &observer) noexcept |
Type safe un-register observer. | |
bool | readAndSync (Cpl::Text::String &dstData, SubscriberApi &observerToSync) |
This method is used to read the MP contents and synchronize the observer with the current MP contents. | |
bool | readAndSync (char *dstData, size_t dataSizeInBytesIncludingNullTerminator, SubscriberApi &observerToSync) |
Same as readAndSync() above, except using a raw char array. | |
![]() | |
bool | read (Cpl::Text::String &dstData, uint16_t *seqNumPtr=0) const noexcept |
Type safe read. See Cpl::Dm::ModelPoint. | |
bool | read (char *dstData, size_t dataSizeInBytesIncludingNullTerminator, uint16_t *seqNumPtr=0) const noexcept |
Type safe read. See Cpl::Dm::ModelPoint. | |
uint16_t | write (const char *srcNullTerminatedString, LockRequest_T lockRequest=eNO_REQUEST) noexcept |
Type safe write of a null terminated string. See Cpl::Dm::ModelPoint. | |
uint16_t | write (const char *srcData, size_t dataSizeInBytesIncludingNullTerminator, LockRequest_T lockRequest=eNO_REQUEST) noexcept |
Same as write(), except only writes at most 'srcLen' bytes. | |
size_t | getMaxLength () const noexcept |
Returns the maximum size WITHOUT the null terminator of the string storage. | |
uint16_t | copyFrom (const StringBase_ &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. | |
const char * | getTypeAsText () const noexcept |
See Cpl::Dm::ModelPoint. | |
bool | fromJSON_ (JsonVariant &src, LockRequest_T lockRequest, uint16_t &retSequenceNumber, Cpl::Text::String *errorMsg) noexcept |
See Cpl::Dm::Point. | |
bool | isDataEqual_ (const void *otherData) const noexcept |
See Cpl::Dm::Point. | |
![]() | |
const char * | getName () const noexcept |
See Cpl::Dm::ModelPoint. | |
size_t | getSize () const noexcept |
See Cpl::Dm::ModelPoint. This method IS thread safe. | |
uint16_t | getSequenceNumber () const noexcept |
See Cpl::Dm::ModelPoint. | |
uint16_t | touch () noexcept |
See Cpl::Dm::ModelPoint. | |
uint16_t | setInvalid (LockRequest_T lockRequest=eNO_REQUEST) noexcept |
See Cpl::Dm::ModelPoint. | |
bool | isNotValid (uint16_t *seqNumPtr=0) const noexcept |
See Cpl::Dm::ModelPoint. | |
bool | isLocked () const noexcept |
See Cpl::Dm::ModelPoint. | |
uint16_t | setLockState (LockRequest_T lockRequest) noexcept |
See Cpl::Dm::ModelPoint. | |
size_t | getExternalSize (bool includeLockedState=false) const noexcept |
See Cpl::Dm::ModelPoint. | |
size_t | exportData (void *dstDataStream, size_t maxDstLength, uint16_t *retSequenceNumber=0, bool includeLockedState=false) const noexcept |
See Cpl::Dm::ModelPoint. Note: The implementation does NOT account for Endianess, i.e. assumes the 'platform' is the same for export/import. | |
size_t | importData (const void *srcDataStream, size_t srcLength, uint16_t *retSequenceNumber=0, bool includeLockedState=false) noexcept |
See Cpl::Dm::ModelPoint. Note: The implementation does NOT account for Endianess, i.e. assumes the 'platform' is the same for export/import. | |
void | genericAttach (SubscriberApi &observer, uint16_t initialSeqNumber=SEQUENCE_NUMBER_UNKNOWN) noexcept |
See Cpl::Dm::ModelPoint. | |
void | genericDetach (SubscriberApi &observer) noexcept |
See Cpl::Dm::ModelPoint. | |
bool | toJSON (char *dst, size_t dstSize, bool &truncated, bool verbose=true, bool pretty=false) noexcept |
See Cpl::Dm::ModelPoint. | |
bool | isNotValidAndSync (SubscriberApi &observerToSync) |
This method is used to test the validate state of the MP and synchronize the observer with the current MP contents. | |
void | processSubscriptionEvent_ (SubscriberApi &subscriber, Event_T event) noexcept |
See Cpl::Dm::ModelPoint. | |
![]() | |
uint16_t | removeLock () noexcept |
Short hand for unconditionally removing the lock from the MP. | |
uint16_t | applyLock () noexcept |
Short hand for putting the MP into the locked state. | |
virtual bool | exportMetadata_ (void *dstDataStream, size_t &bytesAdded) const noexcept |
This method has PACKAGE Scope, i.e. | |
virtual bool | importMetadata_ (const void *srcDataStream, size_t &bytesConsumed) noexcept |
This method has PACKAGE Scope, i.e. | |
virtual | ~ModelPoint () |
Virtual destructor to make the compiler happy. | |
![]() | |
bool | insert_ (void *newContainerPtr) |
Helper method to trap when inserting an item in multiple containers. | |
bool | isInContainer_ (const void *containerPtr) const noexcept |
Returns 'true' if the instance is in the specified container. | |
Protected Attributes | |
char | m_data [S+1] |
The MP's raw storage. | |
![]() | |
Cpl::Container::DList< SubscriberApi > | m_subscribers |
List of Active Subscribers. | |
const char * | m_name |
The model point's symbolic name. | |
ModelDatabase & | m_modelDatabase |
Reference to the containing Model Base. | |
void * | m_dataPtr |
Reference to my Data. | |
size_t | m_dataSize |
Size of my data. | |
uint16_t | m_seqNum |
Sequence number used for tracking changes in the Point data. | |
bool | m_locked |
Locked state. | |
bool | m_valid |
valid/invalid state | |
Additional Inherited Members | |
![]() | |
static void | remove_ (Item *itemPtr) noexcept |
Helper method to do the proper 'clean-up' for the multiple-containers-error-trap when removing an item from a container. | |
![]() | |
void * | m_nextPtr_ |
The link field. | |
void * | m_inListPtr_ |
Debug field. | |
![]() | |
static const uint16_t | SEQUENCE_NUMBER_UNKNOWN |
Magic value to use when registering for a change notification and application does not 'know' the current sequence number value of the Model Point. | |
![]() | |
StringBase_ (Cpl::Dm::ModelDatabase &myModelBase, const char *symbolicName, char *myDataPtr, size_t dataSizeInBytesIncludingNullTerminator) | |
Constructor. | |
StringBase_ (Cpl::Dm::ModelDatabase &myModelBase, const char *symbolicName, char *myDataPtr, size_t dataSizeInBytesIncludingNullTerminator, const char *initialValue) | |
Constructor. Valid MP. Requires an initial value. | |
void | setJSONVal (JsonDocument &doc) noexcept |
See Cpl::Dm::Point. | |
![]() | |
ModelPointCommon_ (ModelDatabase &myModelBase, const char *symbolicName, void *myDataPtr, size_t dataSizeInBytes, bool isValid=false) | |
Constructor. | |
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. | |
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. | |
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. | |
void | attachSubscriber (SubscriberApi &observer, uint16_t initialSeqNumber=SEQUENCE_NUMBER_UNKNOWN) noexcept |
See Cpl::Dm::ModelPoint. | |
void | detachSubscriber (SubscriberApi &observer) noexcept |
See Cpl::Dm::ModelPoint. | |
void | copyDataTo_ (void *dstData, size_t dstSize) const noexcept |
See Cpl::Dm::ModelPoint. | |
void | copyDataFrom_ (const void *srcData, size_t srcSize) noexcept |
See Cpl::Dm::ModelPoint. | |
const void * | getImportExportDataPointer_ () const noexcept |
See Cpl::Dm::ModelPoint. | |
size_t | getInternalDataSize_ () const noexcept |
See Cpl::Dm::ModelPoint. | |
virtual void | processDataUpdated () noexcept |
Internal helper method that completes the data update process as well as ensuring any change notifications get generated. | |
virtual void | processChangeNotifications () noexcept |
Internal helper method that handles generating change notifications when the Model Point's data/state has changed. | |
virtual void | advanceSequenceNumber () noexcept |
Internal helper method that advances/updates the Model Point's sequence number. | |
virtual bool | testAndUpdateLock (LockRequest_T lockRequest) noexcept |
Internal helper method that manages testing and updating the locked state. | |
virtual void | transitionToNotifyPending (SubscriberApi &subscriber) noexcept |
Helper FSM method. | |
virtual void | transitionToSubscribed (SubscriberApi &subscriber) noexcept |
Helper FSM method. | |
virtual JsonDocument & | beginJSON (bool isValid, bool locked, uint16_t seqnum, bool verbose=true) noexcept |
Helper method when converting MP to a JSON string. | |
virtual void | endJSON (char *dst, size_t dstSize, bool &truncated, bool verbose=true, bool pretty=false) noexcept |
Helper method when converting MP to a JSON string. | |
virtual void | hookSetInvalid () noexcept |
Helper method that a child a class can override to change behavior when an MP is set to the invalid state. | |
![]() | |
Item () | |
Constructor. | |
Item (const char *) | |
Constructor used ONLY with the child class MapItem: -->special constructor to allow a Map to be statically allocated. | |
typedef Cpl::Dm::Subscriber<String> Cpl::Dm::Mp::String< S >::Observer |
Type safe subscriber.
|
inline |
Constructor.
Invalid Point.
|
inline |
Constructor. Valid Point. Requires an initial value.
|
inlinenoexcept |
Type safe register observer.
|
inlinenoexcept |
Type safe un-register observer.
|
inline |
Same as readAndSync() above, except using a raw char array.
|
inline |
This method is used to read the MP contents and synchronize the observer with the current MP contents.
This method should ONLY be used in the notification callback method and the 'observerToSync' argument MUST be the argument provided by the callback method
Note: The observer will be subscribed for change notifications after this call.
|
protected |
The MP's raw storage.