|
@ -43,22 +43,22 @@ void GcodeSuite::M104() { |
|
|
if (DEBUGGING(DRYRUN)) return; |
|
|
if (DEBUGGING(DRYRUN)) return; |
|
|
|
|
|
|
|
|
#if ENABLED(MIXING_EXTRUDER) && MIXING_VIRTUAL_TOOLS > 1 |
|
|
#if ENABLED(MIXING_EXTRUDER) && MIXING_VIRTUAL_TOOLS > 1 |
|
|
constexpr int8_t e = 0; |
|
|
constexpr int8_t target_extruder = 0; |
|
|
#else |
|
|
#else |
|
|
const int8_t e = get_target_extruder_from_command(); |
|
|
const int8_t target_extruder = get_target_extruder_from_command(); |
|
|
if (e < 0) return; |
|
|
if (target_extruder < 0) return; |
|
|
#endif |
|
|
#endif |
|
|
|
|
|
|
|
|
if (parser.seenval('S')) { |
|
|
if (parser.seenval('S')) { |
|
|
const int16_t temp = parser.value_celsius(); |
|
|
const int16_t temp = parser.value_celsius(); |
|
|
#if ENABLED(SINGLENOZZLE) |
|
|
#if ENABLED(SINGLENOZZLE) |
|
|
singlenozzle_temp[e] = temp; |
|
|
singlenozzle_temp[target_extruder] = temp; |
|
|
if (e != active_extruder) return; |
|
|
if (target_extruder != active_extruder) return; |
|
|
#endif |
|
|
#endif |
|
|
thermalManager.setTargetHotend(temp, e); |
|
|
thermalManager.setTargetHotend(temp, target_extruder); |
|
|
|
|
|
|
|
|
#if ENABLED(DUAL_X_CARRIAGE) |
|
|
#if ENABLED(DUAL_X_CARRIAGE) |
|
|
if (dxc_is_duplicating() && e == 0) |
|
|
if (dxc_is_duplicating() && target_extruder == 0) |
|
|
thermalManager.setTargetHotend(temp ? temp + duplicate_extruder_temp_offset : 0, 1); |
|
|
thermalManager.setTargetHotend(temp ? temp + duplicate_extruder_temp_offset : 0, 1); |
|
|
#endif |
|
|
#endif |
|
|
|
|
|
|
|
|