This library is in a very early stage where the developers try to become acquainted with the ZIO library along the way.
The library is heavily influenced by and mostly follows the ZIO service pattern, which uses a service tree (no cycles) structure where implementations only depend on interfaces of dependent services ("coding against the interface"). At deployment side, that is where the application is plugged together, implementations are chosen and the dependency tree is fulfilled.
The following picture shows this principle at two stacked services with the additions, that:
-
the factory interface of a service implementation is the sole public interface. This is the only handle to the service implementation.
-
the test implementation of lower level service is placed in the higher level service (test) package as a specific test implementation for testing the current service.
So far, this library consists of three stacked service layers:
-
Modbus Registers Service (/ Modbus Firmware Update Service)
-
Modbus Request Response Service
-
Serial Port Service
The following picture gives a visual overview about the services. They follow the previously explained service pattern.
The upper layer can be extended by a "Modbus Firmware Update Service"
just to demonstrate that here might be other modbus protocols (request/response types). This would look like this:
This service translates reads/writes of registers into modbus read/write requests of the service below.
There is a simple default implementation DefaultModbusRegistersService
, but also a sophisticated GroupingModbusRegisterService
implementation, that optimizes the translation of reads/writes by collecting reads/writes in a queue and applies a grouping of adjacent ones.
Note
|
There is the sibling "Modbus Firmware Update Service" package, which provides a firmware update procedure via modbus firmware requests/responses. The package is only depicted for demonstration purpose and not implemented. It shows that there might be more protocols than the read/write modbus protocol (RWModbusProtocol ) to be used at the ModbusRequestResponseService .
|
Given a protocol defining modbus requests and their responses, it writes requests to the serial port service and reads the respective response. The service is parameterized by a modbus protocol.
For now, we started with a read/write protocol for accessing registers in the modbus slave. There might be future protocols like firmware update, which the design is prepared for.