C12Adapter Opensource C++ Interface
|
Optical probe is a channel based on serial port that is able to control the batteries of the probe (if it exists). More...
Public Member Functions | |
MChannelOpticalProbe () | |
Object constructor. | |
virtual | ~MChannelOpticalProbe () |
Object destructor. | |
virtual void | Connect () |
Establishes the connection to the meter using the optical probe. More... | |
virtual void | Disconnect () |
Disconnect brings down the connection and releases the serial port resource. More... | |
bool | GetBatteryState () const |
void | SetBatteryState (bool power) |
bool | GetBatteryControlDtrHigh () const |
void | SetBatteryControlDtrHigh (bool yes) |
bool | GetBatteryControlRtsHigh () const |
void | SetBatteryControlRtsHigh (bool yes) |
![]() | |
MChannelSerialPort () | |
Construct serial port channel. | |
virtual | ~MChannelSerialPort () |
Destructor. | |
virtual void | FlushOutputBuffer (unsigned numberOfCharsInBuffer=UINT_MAX) |
Ensure that the characters from the output buffer are sent. More... | |
virtual bool | IsConnected () const |
Returns the current connection state of the serial port channel. | |
virtual void | WaitForNextIncomingConnection (bool reinitialize=true) |
When GetAutoAnswer true, wait for the incoming connection without disconnecting the channel. More... | |
void | SetParameters (unsigned baud, int dataBits, char parity, int stopBits) |
SetParameters is a convenience function for setting the properties baud rate, number of data bits, parity, and number of stop bits in a single call. | |
bool | GetDCD () const |
The current state of the DCD signal of the port. More... | |
virtual MStdString | GetMediaIdentification () const |
Return a string that will identify the media through which this channel is talking to. More... | |
const MStdString & | GetPortName () const |
void | SetPortName (const MStdString &portName) |
unsigned | GetBaud () const |
void | SetBaud (unsigned baud) |
char | GetParity () const |
void | SetParity (char p) |
int | GetStopBits () const |
void | SetStopBits (int stopBits) |
int | GetDataBits () const |
void | SetDataBits (int dataBits) |
bool | GetCtsFlow () const |
void | SetCtsFlow (bool isCtsFlow) |
bool | GetDsrFlow () const |
void | SetDsrFlow (bool isDsrFlow) |
bool | GetDsrSensitivity () const |
void | SetDsrSensitivity (bool isDsrSens) |
char | GetDtrControl () const |
void | SetDtrControl (char dtrControl) |
char | GetRtsControl () const |
void | SetRtsControl (char rtsControl) |
MSerialPort & | GetPort () |
const MSerialPort & | GetPort () const |
![]() | |
virtual MChannel * | CreateClone () const |
Virtual copy constructor, creates the channel, which is a clone of current. More... | |
virtual | ~MChannel () |
The destructor is public, and virtual. More... | |
void | WriteBytes (const MByteString &buffer) |
Writes the data to the channel, and returns when the last byte has been sent by the software. More... | |
void | WriteByte (Muint8 b) |
Writes a byte to the channel, and returns when it has been sent. More... | |
void | WriteBuffer (const char *buf, unsigned len) |
Writes the data buffer to the channel, and returns when the last character has been sent by the software (but hardware might still need to do some work). More... | |
Muint8 | ReadByte () |
Read a single byte from the channel. More... | |
void | ReadBuffer (char *buf, unsigned numberToRead) |
Read an exact number of characters from the channel. More... | |
void | Unread (const MVariant &byteOrBytes) |
Return the given byte or bytes to the stream buffer so they get read at the next read operation. More... | |
void | UnreadBuffer (const char *buff, unsigned size) |
Return the given bytes to the stream buffer so they get read at the next read operation. More... | |
MByteString | ReadBytes (unsigned numberToRead) |
Read bytes directly from the communication channel. More... | |
MByteString | ReadBytesUntil (const MByteString &terminatingString) |
Read bytes from the channel until a specified sequence is read. More... | |
MByteString | ReadBytesUntilAnyByte (const char *finisher, unsigned finisherSize, unsigned headerSize, unsigned footerSize) |
Read bytes from the channel until a specified sequence is read. More... | |
MByteString | ReadAllBytes () |
Read an arbitrary number of characters from the channel, as much as available. More... | |
void | ClearInputBuffer () |
Immediately discards all the pending characters from the channel. More... | |
void | ClearInputUntilSilence (unsigned milliseconds) |
Keep reading and ignoring input until there is silence. More... | |
virtual void | CheckIfConnected () |
Throw an appropriate exception if the channel is not connected. More... | |
void | CheckIfConnectedConst () const |
Throw an appropriate exception if the channel is not connected, constant version. More... | |
unsigned | GetCountBytesSent () const |
Number of bytes sent through the channel since its creation or since the last ResetCounts(). More... | |
unsigned | GetCountBytesReceived () const |
The number of bytes received through the channel since creation or since the last ResetCounts(). More... | |
void | ResetCounts () |
Reset channel statistical data, so the counters become zeros. More... | |
virtual void | WriteToMonitor (const MStdString &message) |
Synchronously write a message to the monitor, if it is connected. More... | |
virtual void | CancelCommunication (bool callDisconnect=false) |
Request canceling of the communication. More... | |
void | EnterUninterruptibleCommunication (bool notify=true) |
Enter a communication sequence that shall not be be interrupted with CancelCommunication call. More... | |
void | LeaveUninterruptibleCommunication (bool notify=true) |
Leave a communication sequence that shall not be be interrupted with CancelCommunication call. More... | |
void | CheckIfOperationIsCancelled () |
Check if the user has requested the termination of the communication, and whether the cancel operation lock is zero. More... | |
void | Sleep (unsigned milliseconds) |
Channel version of Sleep, a delay function that is aware of cancel communication event. More... | |
unsigned | ReadWithTimeout (char *buf, unsigned size, unsigned timeout) |
Read up to size bytes into buffer using the given timeout. More... | |
bool | GetAutoAnswer () const |
void | SetAutoAnswer (bool isAutoAnswer) |
unsigned | GetAutoAnswerTimeout () const |
void | SetAutoAnswerTimeout (unsigned timeout) |
void | SetMonitor (MMonitor::Pointer monitor) |
MMonitor::Pointer | GetMonitor () const |
SHOW_INTERNAL bool | GetEcho () const |
void | SetEcho (bool echo) |
bool | GetSendEchoBytesToMonitor () const |
void | SetSendEchoBytesToMonitor (bool doSend) |
unsigned | GetIntercharacterTimeout () const |
void | SetIntercharacterTimeout (unsigned timeout) |
unsigned | GetReadTimeout () const |
void | SetReadTimeout (unsigned timeout) |
unsigned | GetWriteTimeout () const |
void | SetWriteTimeout (unsigned timeout) |
![]() | |
virtual | ~MCOMObject () |
Object destructor. | |
virtual MStdStringVector | GetAllPropertyNames () const |
Return the list of publicly available properties in MCOM syntax. More... | |
virtual MStdStringVector | GetAllPersistentPropertyNames () const |
Return the list of publicly available persistent properties in MCOM syntax. More... | |
MStdString | GetPersistentPropertyValues (bool onlyNondefaults=false, bool excludeSecurityRelated=false) const |
Get the string with the list of persistent property names and their values. More... | |
void | SetPersistentPropertyValues (const MStdString &values) |
Set the persistent properties for the object using the string with the following format: More... | |
void | SetPropertyValues (const MDictionary &values) |
Set the properties for the object using the property list object. More... | |
void | WritePropertiesToMonitor () |
Write all non-default values of protocol properties into monitor. More... | |
MStdString | DoGetPersistentPropertyValues0 () const |
Get the string with the whole list of persistent property names and their values. More... | |
MStdString | DoGetPersistentPropertyValues1 (bool onlyNondefaults) const |
Get the string with the list of persistent property names and their values. More... | |
![]() | |
virtual | ~MObject () |
Object destructor. | |
virtual const MClass * | GetClass () const =0 |
Get the final class of the object. More... | |
virtual unsigned | GetEmbeddedSizeof () const |
For embedded object types, return the size of the class. More... | |
bool | IsEmbeddedObject () const |
Tell if the object is of embedded kind. More... | |
SHOW_INTERNAL MVariant | Call (const MStdString &name, const MVariant ¶ms) |
Call the object service with parameters, given as variant. More... | |
MVariant | Call0 (const MStdString &name) |
Call the object service with no parameters. More... | |
MVariant | Call1 (const MStdString &name, const MVariant &p1) |
Call the object service with one parameter. More... | |
MVariant | Call2 (const MStdString &name, const MVariant &p1, const MVariant &p2) |
Call the object service with two parameter. More... | |
MVariant | Call3 (const MStdString &name, const MVariant &p1, const MVariant &p2, const MVariant &p3) |
Call the object service with three parameter. More... | |
MVariant | Call4 (const MStdString &name, const MVariant &p1, const MVariant &p2, const MVariant &p3, const MVariant &p4) |
Call the object service with four parameter. More... | |
MVariant | Call5 (const MStdString &name, const MVariant &p1, const MVariant &p2, const MVariant &p3, const MVariant &p4, const MVariant &p5) |
Call the object service with five parameter. More... | |
MVariant | Call6 (const MStdString &name, const MVariant &p1, const MVariant &p2, const MVariant &p3, const MVariant &p4, const MVariant &p5, const MVariant &p6) |
Call the object service with six parameter. More... | |
virtual MVariant | CallV (const MStdString &name, const MVariant::VariantVector ¶ms) |
Call the object service with parameters, given as variant vector. More... | |
virtual bool | IsPropertyPresent (const MStdString &name) const |
Tell if the property with the given name exists. | |
virtual bool | IsServicePresent (const MStdString &name) const |
Tell if the service with the given name exists. | |
virtual MVariant | GetProperty (const MStdString &name) const |
Get the property value using name of the property. More... | |
virtual void | SetProperty (const MStdString &name, const MVariant &value) |
Set the property using name of the property, and value. More... | |
virtual void | SetPersistentPropertiesToDefault () |
Set the persistent properties of the object to their default values. More... | |
virtual MVariant | GetPersistentPropertyDefaultValue (const MStdString &name) const |
Get the default value of persistent property with the name given. More... | |
virtual void | SetPersistentPropertyToDefault (const MStdString &name) |
Set the persistent property with the name given to default value. More... | |
virtual const char * | GetType () const |
Get the name of the type for the object (could be the same as class name). | |
virtual void | SetType (const MStdString &) |
Intentionally, it will set the name of the type for the object, but the service will not allow setting the name to anything other than the current name. More... | |
virtual void | Validate () |
Validate internal structures of the object. More... | |
Additional Inherited Members | |
![]() | |
enum | { CANCEL_COMMUNICATION_CHECK_OPTIMUM_INTERVAL = 1000 } |
![]() | |
static MStdStringVector | GetAvailablePortNames (bool addExtraInfo=false) |
Return a collection of serial port names available at this computer. More... | |
static MStdString | GetPortType (const MStdString &portName) |
Get type based on the port name. More... | |
![]() | |
static const MClass * | GetStaticClass () |
Get the declared class of this particular object. More... | |
static bool | IsClassPresent (const MStdString &name) |
Tells if the given class name is available. More... | |
![]() | |
static const MClass | s_class |
Class of MObject. | |
![]() | |
MChannel () | |
Construct the channel object from parent class. More... | |
![]() | |
MCOMObject () | |
Object constructor, protected as the class is abstract. | |
![]() | |
MObject () | |
Object constructor, protected as the class is abstract. | |
void | DoSetPersistentPropertiesToDefault (const MClass *staticClass) |
Set the persistent properties to their default values for one object provided the class for that object. More... | |
Optical probe is a channel based on serial port that is able to control the batteries of the probe (if it exists).
The optical probe channel exports all properties of its parent class, plus the following properties through the property dispatch mechanism:
More information on property handling and error treatment is given within descriptions for property accessors and modifiers.
MChannelOpticalProbe inherits its properties from MChannelSerialPort. Several serial control lines are re-assigned to operate probe features such as battery control and RTS sense. For this channel type, Connect acquires the communication port from the Operating System, sets IsConnected to True, and returns.
|
virtual |
Establishes the connection to the meter using the optical probe.
In addition to serial port connection, this particular service turns on probe batteries (if they are present).
Reimplemented from MChannelSerialPort.
|
virtual |
Disconnect brings down the connection and releases the serial port resource.
In additional to the parent implementation, the optical probe switches the batteries off.
Reimplemented from MChannelSerialPort.
|
inline |
Whether the DTR signal has to be high in order to switch the battery on.
The Data Terminal Ready (DTR) line is used with the Request To Send (RTS) line to turn the optical probe battery power On / Off. Refer to the technical specifications for the probe being used to determine the correct state for each line. Typically, the DTR and RTS signals are mutually exclusive (one true, one false).
BatteryControlDtrHigh must be set prior to a call to Connect because the optical probe batteries have to be turned on when the connection is established (this is just a convention if there are no batteries). This property overrides the DtrControl property.
|
inline |
Whether the RTS signal has to be high in order to switch the battery on.
The Request To Send (RTS) line is used with the Data Terminal Ready (DTR) line to turn the optical probe battery power On / Off. Refer to the technical specifications for the probe being used to determine the correct state for each line. Typically, the RTS and DTR signals are mutually exclusive (one true, one false).
BatteryControlRtsHigh must be set prior to a call to Connect because the optical probe batteries have to be turned on when the connection is established (this is just a convention if there are no batteries). This property overrides the RtsControl property.
bool MChannelOpticalProbe::GetBatteryState | ( | ) | const |
The state of the probe's batteries.
This dynamic non-persistent property is used to get or set the battery power state explicitly. If the optical probe does not use the batteries, this property is still handled to enable or disable the communication.
This property is controlled by Connect and Disconnect services, when the optical probe communication is established or severed. It may be necessary to set it if the connection stays for a long time, but the communication is inactive.
The logic sense of the battery control lines is set by BatteryControlDtrHigh and BatteryControlRtsHigh
|
inline |
Whether the DTR signal has to be high in order to switch the battery on.
The Data Terminal Ready (DTR) line is used with the Request To Send (RTS) line to turn the optical probe battery power On / Off. Refer to the technical specifications for the probe being used to determine the correct state for each line. Typically, the DTR and RTS signals are mutually exclusive (one true, one false).
BatteryControlDtrHigh must be set prior to a call to Connect because the optical probe batteries have to be turned on when the connection is established (this is just a convention if there are no batteries). This property overrides the DtrControl property.
|
inline |
Whether the RTS signal has to be high in order to switch the battery on.
The Request To Send (RTS) line is used with the Data Terminal Ready (DTR) line to turn the optical probe battery power On / Off. Refer to the technical specifications for the probe being used to determine the correct state for each line. Typically, the RTS and DTR signals are mutually exclusive (one true, one false).
BatteryControlRtsHigh must be set prior to a call to Connect because the optical probe batteries have to be turned on when the connection is established (this is just a convention if there are no batteries). This property overrides the RtsControl property.
void MChannelOpticalProbe::SetBatteryState | ( | bool | power | ) |
The state of the probe's batteries.
This dynamic non-persistent property is used to get or set the battery power state explicitly. If the optical probe does not use the batteries, this property is still handled to enable or disable the communication.
This property is controlled by Connect and Disconnect services, when the optical probe communication is established or severed. It may be necessary to set it if the connection stays for a long time, but the communication is inactive.
The logic sense of the battery control lines is set by BatteryControlDtrHigh and BatteryControlRtsHigh