From 5e3dce85bbdc15c93f11a9cbe88c250352fbe739 Mon Sep 17 00:00:00 2001 From: supermerill Date: Wed, 7 Sep 2022 22:40:35 +0200 Subject: [PATCH] fix missing retraction when the lift is merged in start_gcode_manual & no layer_gcode supermerill/SuperSlicer#2916 --- src/libslic3r/GCode.cpp | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/libslic3r/GCode.cpp b/src/libslic3r/GCode.cpp index c2b6da7a4e4..22f6a518521 100644 --- a/src/libslic3r/GCode.cpp +++ b/src/libslic3r/GCode.cpp @@ -2736,7 +2736,7 @@ GCode::LayerResult GCode::process_layer( print.config().before_layer_gcode.value, m_writer.tool()->id(), &config) + "\n"; } - // print z move to next layer UNLESS + // print z move to next layer UNLESS (HACK for superslicer#1775) // if it's going to the first layer, then we may want to delay the move in these condition: // there is no "after layer change gcode" and it's the first move from the unknown if (print.config().layer_gcode.value.empty() && !m_last_pos_defined && m_config.start_gcode_manual && ( @@ -2745,6 +2745,9 @@ GCode::LayerResult GCode::process_layer( || // or lift_min is higher than the first layer height. m_config.lift_min.value > layer.print_z )) { + // still do the retraction + gcode += m_writer.retract(); + gcode += m_writer.reset_e(); m_delayed_layer_change = this->change_layer(print_z); //HACK for superslicer#1775 } else { //extra lift on layer change if multiple objects