|
@@ -1298,19 +1298,30 @@ inline bool code_value_bool() { return !code_has_value() || code_value_byte() >
|
1298
|
1298
|
#if ENABLED(TEMPERATURE_UNITS_SUPPORT)
|
1299
|
1299
|
inline void set_input_temp_units(TempUnit units) { input_temp_units = units; }
|
1300
|
1300
|
|
1301
|
|
- float temp_abs(const float &c) {
|
|
1301
|
+ float to_temp_units(const float &c) {
|
1302
|
1302
|
switch (input_temp_units) {
|
1303
|
1303
|
case TEMPUNIT_F:
|
1304
|
|
- return (c - 32.0) * 0.5555555556;
|
|
1304
|
+ return c * 0.5555555556 + 32.0;
|
1305
|
1305
|
case TEMPUNIT_K:
|
1306
|
|
- return c - 273.15;
|
|
1306
|
+ return c + 273.15;
|
1307
|
1307
|
case TEMPUNIT_C:
|
1308
|
1308
|
default:
|
1309
|
1309
|
return c;
|
1310
|
1310
|
}
|
1311
|
1311
|
}
|
1312
|
1312
|
|
1313
|
|
- int16_t code_value_temp_abs() { return temp_abs(code_value_float()); }
|
|
1313
|
+ int16_t code_value_temp_abs() {
|
|
1314
|
+ const float c = code_value_float();
|
|
1315
|
+ switch (input_temp_units) {
|
|
1316
|
+ case TEMPUNIT_F:
|
|
1317
|
+ return (int16_t)((c - 32.0) * 0.5555555556);
|
|
1318
|
+ case TEMPUNIT_K:
|
|
1319
|
+ return (int16_t)(c - 273.15);
|
|
1320
|
+ case TEMPUNIT_C:
|
|
1321
|
+ default:
|
|
1322
|
+ return (int16_t)(c);
|
|
1323
|
+ }
|
|
1324
|
+ }
|
1314
|
1325
|
|
1315
|
1326
|
int16_t code_value_temp_diff() {
|
1316
|
1327
|
switch (input_temp_units) {
|