change parameter type from size_t to int for command functions

This commit is contained in:
ElVit 2026-03-19 09:01:53 +01:00
parent 259c97f74a
commit 1e1ebbf711
6 changed files with 72 additions and 67 deletions

View File

@ -41,39 +41,42 @@ void PanasonicHeatpumpClimate::control(const climate::ClimateCall& call) {
if (call.get_target_temperature().has_value()) {
float new_temp = *call.get_target_temperature();
int new_temp_int = static_cast<int>(round(new_temp));
switch (this->id_) {
case ClimateIds::CONF_CLIMATE_TANK:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp), 42); // set11
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp_int), 42); // set11
break;
case ClimateIds::CONF_CLIMATE_ZONE1:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp), 38); // set5
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp_int), 38); // set5
break;
case ClimateIds::CONF_CLIMATE_ZONE2:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp), 40); // set7
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp_int), 40); // set7
break;
};
}
if (call.get_target_temperature_high().has_value()) {
float new_temp = *call.get_target_temperature_high();
int new_temp_int = static_cast<int>(round(new_temp));
switch (this->id_) {
case ClimateIds::CONF_CLIMATE_ZONE1:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp), 38); // set5
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp_int), 38); // set5
break;
case ClimateIds::CONF_CLIMATE_ZONE2:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp), 40); // set7
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp_int), 40); // set7
break;
};
}
if (call.get_target_temperature_low().has_value()) {
float new_temp = *call.get_target_temperature_low();
int new_temp_int = static_cast<int>(round(new_temp));
switch (this->id_) {
case ClimateIds::CONF_CLIMATE_ZONE1:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp), 39); // set6
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp_int), 39); // set6
break;
case ClimateIds::CONF_CLIMATE_ZONE2:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp), 41); // set8
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp_int), 41); // set8
break;
};
}

View File

@ -38,39 +38,39 @@ uint8_t PanasonicCommand::calcChecksum(std::vector<uint8_t>& data, int length) {
return checksum;
}
uint8_t PanasonicCommand::setMultiply2(size_t input) {
return input * 0b10;
uint8_t PanasonicCommand::setMultiply2(int input) {
return input * 2;
}
uint8_t PanasonicCommand::setMultiply4(size_t input) {
return input * 0b100;
uint8_t PanasonicCommand::setMultiply4(int input) {
return input * 4;
}
uint8_t PanasonicCommand::setPlus1Multiply4(size_t input) {
return (input + 1) * 0b100;
uint8_t PanasonicCommand::setPlus1Multiply4(int input) {
return (input + 1) * 4;
}
uint8_t PanasonicCommand::setPlus1Multiply8(size_t input) {
return (input + 1) * 0b1000;
uint8_t PanasonicCommand::setPlus1Multiply8(int input) {
return (input + 1) * 8;
}
uint8_t PanasonicCommand::setPlus1Multiply16(size_t input) {
return (input + 1) * 0b10000;
uint8_t PanasonicCommand::setPlus1Multiply16(int input) {
return (input + 1) * 16;
}
uint8_t PanasonicCommand::setPlus1Multiply64(size_t input) {
return (input + 1) * 0b1000000;
uint8_t PanasonicCommand::setPlus1Multiply64(int input) {
return (input + 1) * 64;
}
uint8_t PanasonicCommand::setPlus1(size_t input) {
uint8_t PanasonicCommand::setPlus1(int input) {
return input + 1;
}
uint8_t PanasonicCommand::setPlus128(size_t input) {
return input + 0b10000000;
uint8_t PanasonicCommand::setPlus128(int input) {
return input + 128;
}
uint8_t PanasonicCommand::setOperationMode(size_t input) {
uint8_t PanasonicCommand::setOperationMode(int input) {
switch (input) {
case 0:
return 0b100001; // 0x21 = tank

View File

@ -22,15 +22,15 @@ class PanasonicCommand {
PanasonicCommand() = delete;
static uint8_t calcChecksum(std::vector<uint8_t>& data, int length);
static uint8_t setMultiply2(size_t input);
static uint8_t setMultiply4(size_t input);
static uint8_t setPlus1Multiply4(size_t input);
static uint8_t setPlus1Multiply8(size_t input);
static uint8_t setPlus1Multiply16(size_t input);
static uint8_t setPlus1Multiply64(size_t input);
static uint8_t setPlus1(size_t input);
static uint8_t setPlus128(size_t input);
static uint8_t setOperationMode(size_t input);
static uint8_t setMultiply2(int input);
static uint8_t setMultiply4(int input);
static uint8_t setPlus1Multiply4(int input);
static uint8_t setPlus1Multiply8(int input);
static uint8_t setPlus1Multiply16(int input);
static uint8_t setPlus1Multiply64(int input);
static uint8_t setPlus1(int input);
static uint8_t setPlus128(int input);
static uint8_t setOperationMode(int input);
static uint8_t temp2hex(float temp);
static uint8_t setByte6(uint8_t byte6, int val, int base, int bit);
static uint8_t setDemandControl(size_t input);

View File

@ -10,105 +10,106 @@ void PanasonicHeatpumpNumber::dump_config() {
}
void PanasonicHeatpumpNumber::control(float value) {
int value_int = static_cast<int>(round(value));
switch (this->id_) {
case NumberIds::CONF_SET5:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 38);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 38);
break;
case NumberIds::CONF_SET6:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 39);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 39);
break;
case NumberIds::CONF_SET7:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 40);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 40);
break;
case NumberIds::CONF_SET8:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 41);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 41);
break;
case NumberIds::CONF_SET11:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 42);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 42);
break;
case NumberIds::CONF_SET15:
this->parent_->set_command_byte(PanasonicCommand::setPlus1(value), 45);
this->parent_->set_command_byte(PanasonicCommand::setPlus1(value_int), 45);
break;
case NumberIds::CONF_SET16_01:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 75);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 75);
break;
case NumberIds::CONF_SET16_02:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 76);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 76);
break;
case NumberIds::CONF_SET16_03:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 77);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 77);
break;
case NumberIds::CONF_SET16_04:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 78);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 78);
break;
case NumberIds::CONF_SET16_05:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 79);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 79);
break;
case NumberIds::CONF_SET16_06:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 80);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 80);
break;
case NumberIds::CONF_SET16_07:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 81);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 81);
break;
case NumberIds::CONF_SET16_08:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 82);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 82);
break;
case NumberIds::CONF_SET16_09:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 86);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 86);
break;
case NumberIds::CONF_SET16_10:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 87);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 87);
break;
case NumberIds::CONF_SET16_11:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 88);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 88);
break;
case NumberIds::CONF_SET16_12:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 89);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 89);
break;
case NumberIds::CONF_SET16_13:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 90);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 90);
break;
case NumberIds::CONF_SET16_14:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 91);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 91);
break;
case NumberIds::CONF_SET16_15:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 92);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 92);
break;
case NumberIds::CONF_SET16_16:
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value), 93);
this->parent_->set_command_curve(PanasonicCommand::setPlus128(value_int), 93);
break;
case NumberIds::CONF_SET18:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 84);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 84);
break;
case NumberIds::CONF_SET19:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 94);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 94);
break;
case NumberIds::CONF_SET20:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 99);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 99);
break;
case NumberIds::CONF_SET21:
this->parent_->set_command_byte(PanasonicCommand::setPlus1(value), 104);
this->parent_->set_command_byte(PanasonicCommand::setPlus1(value_int), 104);
break;
case NumberIds::CONF_SET22:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 105);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 105);
break;
case NumberIds::CONF_SET23:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 106);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 106);
break;
case NumberIds::CONF_SET27:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 59);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 59);
break;
case NumberIds::CONF_SET29:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 83);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 83);
break;
case NumberIds::CONF_SET36:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 65);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 65);
break;
case NumberIds::CONF_SET37:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 66);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 66);
break;
case NumberIds::CONF_SET38:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value), 68);
this->parent_->set_command_byte(PanasonicCommand::setPlus128(value_int), 68);
break;
default:
return;

View File

@ -10,7 +10,7 @@ void PanasonicHeatpumpSwitch::dump_config() {
}
void PanasonicHeatpumpSwitch::write_state(bool state) {
size_t value = state ? 1 : 0;
int value = state ? 1 : 0;
switch (this->id_) {
case SwitchIds::CONF_SET1:

View File

@ -32,9 +32,10 @@ void PanasonicHeatpumpWaterHeater::control(const water_heater::WaterHeaterCall&
}
float new_temp = call.get_target_temperature();
int new_temp_int = static_cast<int>(round(new_temp));
switch (this->id_) {
case WaterHeaterIds::CONF_HEATER_TANK:
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp), 42); // set11
this->parent_->set_command_byte(PanasonicCommand::setPlus128(new_temp_int), 42); // set11
break;
};