GM6000 Digital Heater Controller Branch: main
SDX-1330
Bool.h
Go to the documentation of this file.
1#ifndef Cpl_Dm_Mp_Bool_h_
2#define Cpl_Dm_Mp_Bool_h_
3/*-----------------------------------------------------------------------------
4* This file is part of the Colony.Core Project. The Colony.Core Project is an
5* open source project with a BSD type of licensing agreement. See the license
6* agreement (license.txt) in the top/ directory or on the Internet at
7* http://integerfox.com/colony.core/license.txt
8*
9* Copyright (c) 2014-2022 John T. Taylor
10*
11* Redistributions of the source code must retain the above copyright notice.
12*----------------------------------------------------------------------------*/
13/** @file */
14
15
17
18///
19namespace Cpl {
20///
21namespace Dm {
22///
23namespace Mp {
24
25
26/** This class provides a concrete implementation for a Point who's data is a
27 bool.
28
29 The toJSON()/fromJSON format is:
30 \code
31
32 { name:"<mpname>", type:"<mptypestring>", valid:true|false, seqnum:nnnn, locked:true|false, val:true|false }
33
34 \endcode
35
36 NOTE: All methods in this class ARE thread Safe unless explicitly
37 documented otherwise.
38 */
39class Bool : public ModelPointCommon_
40{
41public:
42 /// Constructor. Invalid MP.
43 Bool( Cpl::Dm::ModelDatabase& myModelBase, const char* symbolicName )
44 :Cpl::Dm::ModelPointCommon_( myModelBase, symbolicName, &m_data, sizeof( m_data ), false )
45 {
46 }
47
48 /// Constructor. Valid MP. Requires an initial value
49 Bool( Cpl::Dm::ModelDatabase& myModelBase, const char* symbolicName, bool initialValue )
50 :Cpl::Dm::ModelPointCommon_( myModelBase, symbolicName, &m_data, sizeof( m_data ), true )
51 {
52 m_data = initialValue;
53 }
54
55public:
56 /// Type safe read. See Cpl::Dm::ModelPoint
57 inline bool read( bool& dstData, uint16_t* seqNumPtr=0 ) const noexcept
58 {
59 return readData( &dstData, sizeof( m_data ), seqNumPtr );
60 }
61
62 /// Type safe write. See Cpl::Dm::ModelPoint
63 inline uint16_t write( bool newValue, LockRequest_T lockRequest = eNO_REQUEST ) noexcept
64 {
65 return writeData( &newValue, sizeof( m_data ), lockRequest );
66 }
67
68 /// Updates the MP with the valid-state/data from 'src'. Note: the src.lock state is NOT copied
69 inline uint16_t copyFrom( const Bool& src, LockRequest_T lockRequest = eNO_REQUEST ) noexcept
70 {
71 return copyDataAndStateFrom( src, lockRequest );
72 }
73
74 /// See Cpl::Dm::ModelPoint.
75 const char* getTypeAsText() const noexcept;
76
77public:
78 /// Type safe subscriber
79 typedef Cpl::Dm::Subscriber<Bool> Observer;
80
81 /// Type safe register observer
82 void attach( Observer& observer, uint16_t initialSeqNumber=SEQUENCE_NUMBER_UNKNOWN ) noexcept;
83
84 /// Type safe un-register observer
85 void detach( Observer& observer ) noexcept;
86
87 /// See Cpl::Dm::Point.
88 bool fromJSON_( JsonVariant& src, LockRequest_T lockRequest, uint16_t& retSequenceNumber, Cpl::Text::String* errorMsg ) noexcept;
89
90 /// See Cpl::Dm::ModelPointCommon
91 inline bool readAndSync( bool& dstData, SubscriberApi& observerToSync )
92 {
93 return ModelPointCommon_::readAndSync( &dstData, sizeof( m_data ), observerToSync );
94 }
95
96
97protected:
98 /// See Cpl::Dm::Point.
99 void setJSONVal( JsonDocument& doc ) noexcept;
100
101
102protected:
103 /// My data
104 bool m_data;
105};
106
107
108
109}; // end namespaces
110};
111};
112#endif // end header latch
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
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 class provides a concrete implementation for a Point who's data is a bool.
Definition Bool.h:40
Bool(Cpl::Dm::ModelDatabase &myModelBase, const char *symbolicName, bool initialValue)
Constructor. Valid MP. Requires an initial value.
Definition Bool.h:49
uint16_t write(bool newValue, LockRequest_T lockRequest=eNO_REQUEST) noexcept
Type safe write. See Cpl::Dm::ModelPoint.
Definition Bool.h:63
void setJSONVal(JsonDocument &doc) noexcept
See Cpl::Dm::Point.
bool m_data
My data.
Definition Bool.h:104
bool fromJSON_(JsonVariant &src, LockRequest_T lockRequest, uint16_t &retSequenceNumber, Cpl::Text::String *errorMsg) noexcept
See Cpl::Dm::Point.
bool read(bool &dstData, uint16_t *seqNumPtr=0) const noexcept
Type safe read. See Cpl::Dm::ModelPoint.
Definition Bool.h:57
const char * getTypeAsText() const noexcept
See Cpl::Dm::ModelPoint.
void attach(Observer &observer, uint16_t initialSeqNumber=SEQUENCE_NUMBER_UNKNOWN) noexcept
Type safe register observer.
Bool(Cpl::Dm::ModelDatabase &myModelBase, const char *symbolicName)
Constructor. Invalid MP.
Definition Bool.h:43
bool readAndSync(bool &dstData, SubscriberApi &observerToSync)
See Cpl::Dm::ModelPointCommon.
Definition Bool.h:91
uint16_t copyFrom(const Bool &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 Bool.h:69
void detach(Observer &observer) noexcept
Type safe un-register observer.
This concrete template class provides the storage for a Point who's data is a null terminated string.
Definition String.h:114
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
The 'Cpl' namespace is the root name space for the Colony.
Definition Api16.h:20