Made a beta release #15

Merged
trabus322 merged 5 commits from master into release 2024-03-28 19:46:26 +01:00
5 changed files with 21 additions and 15 deletions
Showing only changes of commit 4209d2767e - Show all commits

View file

@ -14,8 +14,6 @@ class Dtu {
std::vector<Microinverter> microinverters;
bool connected;
void populateMicroinverters();
std::pair<Microinverter *, bool> getMicroinverterBySerialNumber(long long serialNumber);
@ -25,6 +23,10 @@ class Dtu {
bool isConnected();
bool modbusError();
std::string modbusErrorMessage();
// void updateMicroinverters();
void updateMicroinverters(std::vector<std::string> &parametersToGet, bool allParameters, std::vector<long long> &microinvertersToGet);

View file

@ -20,9 +20,9 @@ class Port {
void increaseParametersAge();
public:
Port(std::shared_ptr<class modbus> modbus, uint16_t portStartAddress);
Port(std::shared_ptr<class modbus> modbus, int portStartAddress);
uint16_t portStartAddress;
int portStartAddress;
std::vector<std::shared_ptr<PortParameter>> parameters;

View file

@ -16,27 +16,28 @@ Dtu::Dtu(const char *ip_address, int port) {
this->modbus = std::make_shared<class modbus>(modbus);
if (!this->modbus.get()->modbus_connect()) {
std::cerr << "conn_error" << std::endl;
this->connected = false;
} else {
this->connected = true;
std::cerr << "NOT CONNECTED" << std::endl;
}
if (this->connected) {
if (this->modbus.get()->is_connected()) {
this->populateMicroinverters();
}
}
bool Dtu::isConnected() { return this->connected; }
bool Dtu::isConnected() { return this->modbus.get()->is_connected(); }
bool Dtu::modbusError() { return this->modbus.get()->err; }
std::string Dtu::modbusErrorMessage() { return this->modbus.get()->error_msg; }
Dtu::~Dtu() { this->modbus.get()->modbus_close(); }
void Dtu::populateMicroinverters() {
uint16_t portStartAddress = 0x1000;
uint16_t readArray[1];
int portStartAddress = 0x1000;
uint16_t readArray[20];
int registerCount;
registerCount = this->modbus.get()->modbus_read_holding_registers(portStartAddress + 0x0021, 1, readArray);
registerCount = this->modbus.get()->modbus_read_holding_registers(portStartAddress + 0x0001, 1, readArray);
while (registerCount != -1 && readArray[0] == 0x700) {
Port port{this->modbus, portStartAddress};

View file

@ -9,7 +9,7 @@
#include "port.h"
#include "portParameters.h"
Port::Port(std::shared_ptr<class modbus> modbus, uint16_t portStartAddress) {
Port::Port(std::shared_ptr<class modbus> modbus, int portStartAddress) {
this->modbus = modbus;
this->portStartAddress = portStartAddress;

View file

@ -73,7 +73,7 @@ int main(int argc, char **argv) {
auto endTime = std::chrono::high_resolution_clock::now();
std::cout << "DTU construction time: " << std::chrono::duration_cast<std::chrono::milliseconds>(endTime - startTime).count() << "ms" << std::endl;
while ((dtu.isConnected() || ignoreNotConnected) && (!parametersToGet.empty() || allParameters)) {
while (!dtu.modbusError() && (dtu.isConnected() || ignoreNotConnected) && (!parametersToGet.empty() || allParameters)) {
startTime = std::chrono::high_resolution_clock::now();
dtu.updateMicroinverters(parametersToGet, allParameters, microinvertersToGet);
endTime = std::chrono::high_resolution_clock::now();
@ -82,6 +82,9 @@ int main(int argc, char **argv) {
dtu.printMicroinverters(parametersToGet, allParameters, microinvertersToGet, shortNames, microinvertersGetTodayProduction, microinvertersGetTotalProduction);
std::cout << std::endl;
}
if(dtu.modbusError()) {
std::cerr << dtu.modbusErrorMessage() << std::endl;
}
return 0;
}