This concrete class provide common infrastructure for a Model 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.
|
|
virtual const char * | getTypeAsText () const noexcept=0 |
| This method returns a string identifier for the Model Point's data type.
|
|
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 bool | fromJSON_ (JsonVariant &src, LockRequest_T lockRequest, uint16_t &retSequenceNumber, Cpl::Text::String *errorMsg) noexcept=0 |
| 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.
|
|
|
| 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.
|
|
bool | isDataEqual_ (const void *otherData) const noexcept |
| See Cpl::Dm::ModelPoint. Note: This implementation does NOT work if the any of the data content are floats/double data types.
|
|
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.
|
|
virtual void | setJSONVal (JsonDocument &doc) noexcept=0 |
| This method converts the MP data to a JSON key/value pair.
|
|
| Item () |
| Constructor.
|
|
| Item (const char *) |
| Constructor used ONLY with the child class MapItem: -->special constructor to allow a Map to be statically allocated.
|
|
virtual bool Cpl::Dm::ModelPointCommon_::testAndUpdateLock |
( |
LockRequest_T |
lockRequest | ) |
|
|
protectedvirtualnoexcept |
Internal helper method that manages testing and updating the locked state.
Rules: 1) If 'lockRequest' is eNO_REQUEST, the method only returns true if the MP is in the unlocked state 2) If 'lockRequest' is eLOCK, the method only returns if the MP is in the unlocked state. In addition, when true is returned the MP is put into the locked state. 3) If 'lockRequest' is eUNLOCK, the method always returns true and the MP is left in the unlocked state.
This method is NOT thread safe.