change parameter type from size_t to int for command functions
This commit is contained in:
parent
259c97f74a
commit
1e1ebbf711
|
|
@ -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;
|
||||
};
|
||||
}
|
||||
|
|
|
|||
|
|
@ -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
|
||||
|
|
|
|||
|
|
@ -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);
|
||||
|
|
|
|||
|
|
@ -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;
|
||||
|
|
|
|||
|
|
@ -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:
|
||||
|
|
|
|||
|
|
@ -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;
|
||||
};
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue