mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-24 09:11:23 -06:00
Merge remote-tracking branch 'remotes/origin/master' into dev
This commit is contained in:
commit
9bdc5b7939
1 changed files with 15 additions and 5 deletions
|
@ -2,6 +2,7 @@
|
||||||
#include "CoolingBuffer.hpp"
|
#include "CoolingBuffer.hpp"
|
||||||
#include <boost/algorithm/string/predicate.hpp>
|
#include <boost/algorithm/string/predicate.hpp>
|
||||||
#include <boost/algorithm/string/replace.hpp>
|
#include <boost/algorithm/string/replace.hpp>
|
||||||
|
#include <boost/log/trivial.hpp>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <float.h>
|
#include <float.h>
|
||||||
|
|
||||||
|
@ -415,13 +416,22 @@ std::vector<PerExtruderAdjustments> CoolingBuffer::parse_layer_gcode(const std::
|
||||||
line.type = CoolingLine::TYPE_EXTRUDE_END;
|
line.type = CoolingLine::TYPE_EXTRUDE_END;
|
||||||
active_speed_modifier = size_t(-1);
|
active_speed_modifier = size_t(-1);
|
||||||
} else if (boost::starts_with(sline, toolchange_prefix)) {
|
} else if (boost::starts_with(sline, toolchange_prefix)) {
|
||||||
|
unsigned int new_extruder = (unsigned int)atoi(sline.c_str() + toolchange_prefix.size());
|
||||||
|
// Only change extruder in case the number is meaningful. User could provide an out-of-range index through custom gcodes - those shall be ignored.
|
||||||
|
if (new_extruder < map_extruder_to_per_extruder_adjustment.size()) {
|
||||||
|
if (new_extruder != current_extruder) {
|
||||||
// Switch the tool.
|
// Switch the tool.
|
||||||
line.type = CoolingLine::TYPE_SET_TOOL;
|
line.type = CoolingLine::TYPE_SET_TOOL;
|
||||||
unsigned int new_extruder = (unsigned int)atoi(sline.c_str() + toolchange_prefix.size());
|
|
||||||
if (new_extruder != current_extruder) {
|
|
||||||
current_extruder = new_extruder;
|
current_extruder = new_extruder;
|
||||||
adjustment = &per_extruder_adjustments[map_extruder_to_per_extruder_adjustment[current_extruder]];
|
adjustment = &per_extruder_adjustments[map_extruder_to_per_extruder_adjustment[current_extruder]];
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// Only log the error in case of MM printer. Single extruder printers likely ignore any T anyway.
|
||||||
|
if (map_extruder_to_per_extruder_adjustment.size() > 1)
|
||||||
|
BOOST_LOG_TRIVIAL(error) << "CoolingBuffer encountered an invalid toolchange, maybe from a custom gcode: " << sline;
|
||||||
|
}
|
||||||
|
|
||||||
} else if (boost::starts_with(sline, ";_BRIDGE_FAN_START")) {
|
} else if (boost::starts_with(sline, ";_BRIDGE_FAN_START")) {
|
||||||
line.type = CoolingLine::TYPE_BRIDGE_FAN_START;
|
line.type = CoolingLine::TYPE_BRIDGE_FAN_START;
|
||||||
} else if (boost::starts_with(sline, ";_BRIDGE_FAN_END")) {
|
} else if (boost::starts_with(sline, ";_BRIDGE_FAN_END")) {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue