mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-24 01:01:15 -06:00
gcc & clang do not like taking reference of const temporaries.
This commit is contained in:
parent
98e49772ed
commit
c96fc5eb51
2 changed files with 9 additions and 12 deletions
|
@ -89,7 +89,7 @@ ToolOrdering::ToolOrdering(const PrintObject &object, unsigned int first_extrude
|
||||||
}
|
}
|
||||||
|
|
||||||
// Collect extruders reuqired to print the layers.
|
// Collect extruders reuqired to print the layers.
|
||||||
this->collect_extruders(object, nullptr);
|
this->collect_extruders(object, std::vector<std::pair<double, unsigned int>>());
|
||||||
|
|
||||||
// Reorder the extruders to minimize tool switches.
|
// Reorder the extruders to minimize tool switches.
|
||||||
this->reorder_extruders(first_extruder);
|
this->reorder_extruders(first_extruder);
|
||||||
|
@ -128,10 +128,9 @@ ToolOrdering::ToolOrdering(const Print &print, unsigned int first_extruder, bool
|
||||||
|
|
||||||
// Use the extruder switches from Model::custom_gcode_per_print_z to override the extruder to print the object.
|
// Use the extruder switches from Model::custom_gcode_per_print_z to override the extruder to print the object.
|
||||||
// Do it only if all the objects were configured to be printed with a single extruder.
|
// Do it only if all the objects were configured to be printed with a single extruder.
|
||||||
const std::vector<std::pair<double, unsigned int>> *per_layer_extruder_switches = (print.object_extruders().size() == 1) ?
|
std::vector<std::pair<double, unsigned int>> per_layer_extruder_switches;
|
||||||
&custom_tool_changes(print.model(), (unsigned int)print.config().nozzle_diameter.size()) : nullptr;
|
if (print.object_extruders().size() == 1)
|
||||||
if (per_layer_extruder_switches != nullptr && per_layer_extruder_switches->empty())
|
per_layer_extruder_switches = custom_tool_changes(print.model(), (unsigned int)print.config().nozzle_diameter.size());
|
||||||
per_layer_extruder_switches = nullptr;
|
|
||||||
|
|
||||||
// Collect extruders reuqired to print the layers.
|
// Collect extruders reuqired to print the layers.
|
||||||
for (auto object : print.objects())
|
for (auto object : print.objects())
|
||||||
|
@ -166,7 +165,7 @@ void ToolOrdering::initialize_layers(std::vector<coordf_t> &zs)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Collect extruders reuqired to print layers.
|
// Collect extruders reuqired to print layers.
|
||||||
void ToolOrdering::collect_extruders(const PrintObject &object, const std::vector<std::pair<double, unsigned int>> *per_layer_extruder_switches)
|
void ToolOrdering::collect_extruders(const PrintObject &object, const std::vector<std::pair<double, unsigned int>> &per_layer_extruder_switches)
|
||||||
{
|
{
|
||||||
// Collect the support extruders.
|
// Collect the support extruders.
|
||||||
for (auto support_layer : object.support_layers()) {
|
for (auto support_layer : object.support_layers()) {
|
||||||
|
@ -186,8 +185,7 @@ void ToolOrdering::collect_extruders(const PrintObject &object, const std::vecto
|
||||||
|
|
||||||
// Extruder overrides are ordered by print_z.
|
// Extruder overrides are ordered by print_z.
|
||||||
std::vector<std::pair<double, unsigned int>>::const_iterator it_per_layer_extruder_override;
|
std::vector<std::pair<double, unsigned int>>::const_iterator it_per_layer_extruder_override;
|
||||||
if (per_layer_extruder_switches != nullptr)
|
it_per_layer_extruder_override = per_layer_extruder_switches.begin();
|
||||||
it_per_layer_extruder_override = per_layer_extruder_switches->begin();
|
|
||||||
unsigned int extruder_override = 0;
|
unsigned int extruder_override = 0;
|
||||||
|
|
||||||
// Collect the object extruders.
|
// Collect the object extruders.
|
||||||
|
@ -195,8 +193,7 @@ void ToolOrdering::collect_extruders(const PrintObject &object, const std::vecto
|
||||||
LayerTools &layer_tools = this->tools_for_layer(layer->print_z);
|
LayerTools &layer_tools = this->tools_for_layer(layer->print_z);
|
||||||
|
|
||||||
// Override extruder with the next
|
// Override extruder with the next
|
||||||
if (per_layer_extruder_switches != nullptr)
|
for (; it_per_layer_extruder_override != per_layer_extruder_switches.end() && it_per_layer_extruder_override->first < layer->print_z + EPSILON; ++ it_per_layer_extruder_override)
|
||||||
for (; it_per_layer_extruder_override != per_layer_extruder_switches->end() && it_per_layer_extruder_override->first < layer->print_z + EPSILON; ++ it_per_layer_extruder_override)
|
|
||||||
extruder_override = (int)it_per_layer_extruder_override->second;
|
extruder_override = (int)it_per_layer_extruder_override->second;
|
||||||
|
|
||||||
// Store the current extruder override (set to zero if no overriden), so that layer_tools.wiping_extrusions().is_overridable_and_mark() will use it.
|
// Store the current extruder override (set to zero if no overriden), so that layer_tools.wiping_extrusions().is_overridable_and_mark() will use it.
|
||||||
|
|
|
@ -166,7 +166,7 @@ public:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void initialize_layers(std::vector<coordf_t> &zs);
|
void initialize_layers(std::vector<coordf_t> &zs);
|
||||||
void collect_extruders(const PrintObject &object, const std::vector<std::pair<double, unsigned int>> *per_layer_extruder_switches);
|
void collect_extruders(const PrintObject &object, const std::vector<std::pair<double, unsigned int>> &per_layer_extruder_switches);
|
||||||
void reorder_extruders(unsigned int last_extruder_id);
|
void reorder_extruders(unsigned int last_extruder_id);
|
||||||
void fill_wipe_tower_partitions(const PrintConfig &config, coordf_t object_bottom_z);
|
void fill_wipe_tower_partitions(const PrintConfig &config, coordf_t object_bottom_z);
|
||||||
void collect_extruder_statistics(bool prime_multi_material);
|
void collect_extruder_statistics(bool prime_multi_material);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue