ModbusAdapter.h
2.91 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/*****************************************************************************
* Copyright (c) 2022 Priva b.v.
*****************************************************************************/
#pragma once
#include "ConnectionConfig.h"
#include "IModbusAdapter.h"
#include "modbus.h"
// std
#include <memory>
#include <variant>
#include <vector>
/// @brief The ModbusAdapter class represents a single modbus context. Each context will
/// result in an instance of this class. It is not intended to be
/// created directly but through a factory. The factory will create
/// the object and return the pointer to its interface.
class ModbusAdapter : public IModbusAdapter
{
public:
/*!
* \brief ModbusAdapter
*/
explicit ModbusAdapter();
/*!
* \brief ~ModbusAdapter
*/
virtual ~ModbusAdapter();
/*!
* \brief ModbusConnect
* \param conncfg
*/
bool ModbusConnect( const ConnectionConfig &conncfg ) override;
/*!
* \brief ModbusDisconnect
*/
bool ModbusDisconnect() override;
/*!
* \brief ModbusReadData
* \param slaveId
* \param startAddress
* \param noOfItems
*/
modbusData ModbusReadData( int slaveId, int functionCode, int startAddress, int noOfItems ) override;
/*!
* \brief ModbusReadHoldReg
* \param slaveId
* \param startAddress
* \param noOfItems
* \return
*/
modbusData ModbusReadHoldReg( int slaveId, int startAddress, int noOfItems ) override;
/*!
* \brief ModBusWriteData
* \param slaveId
* \param funtionCode
* \param startAddress
* \param noOfItems
* \param values
*/
void ModBusWriteData( int slaveId, int functionCode, int startAddress, int noOfItems, std::vector<int>values ) override;
/*!
* \brief isConnected
* \return
*/
bool isConnected() const override;
/*!
* \brief ErrorString
* \param errnum
* \return
*/
std::string ErrorString( int errnum ) const override;
private: // Methods
bool ModbusConnectRTU( const std::string &serialport, int baud, char parity, int dataBits, int stopBits, int RTS, int timeOut );
bool ModbusConnectTCP( const std::string &ip, int port, int timeOut = -1 );
void InitBuffers();
void ClearBuffers();
private: // Members
ConnectionType m_connType { ConnectionType::CT_UNKNOWN }; ///> The type of connection this instance provides. Needed for administration
bool m_connected { false }; ///> Shows if the connection is still active.
modbus_t *m_modbus; ///> The actual low-level modbus instance as a raw-pointer. ( unique_pointer gives an error on this struct )
// Return value Buffers ( Room for improvement )
uint8_t *m_dest;
uint16_t *m_dest16;
};