mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Reworked the FFF Print::update() to process the filament retract
override values and to store them into the output G-code.
This commit is contained in:
		
							parent
							
								
									42c8940795
								
							
						
					
					
						commit
						f8218eb903
					
				
					 11 changed files with 210 additions and 66 deletions
				
			
		|  | @ -129,6 +129,19 @@ public: | ||||||
|     virtual bool 				nullable()		const { return false; } |     virtual bool 				nullable()		const { return false; } | ||||||
|     // A scalar is nil, or all values of a vector are nil.
 |     // A scalar is nil, or all values of a vector are nil.
 | ||||||
|     virtual bool 				is_nil() 		const { return false; } |     virtual bool 				is_nil() 		const { return false; } | ||||||
|  |     // Is this option overridden by another option?
 | ||||||
|  |     // An option overrides another option if it is not nil and not equal.
 | ||||||
|  |     virtual bool 				overriden_by(const ConfigOption *rhs) const { | ||||||
|  |     	assert(! this->nullable() && ! rhs->nullable()); | ||||||
|  |     	return *this != *rhs; | ||||||
|  |     } | ||||||
|  |     // Apply an override option, possibly a nullable one.
 | ||||||
|  |     virtual bool 				apply_override(const ConfigOption *rhs) {  | ||||||
|  |     	if (*this == *rhs)  | ||||||
|  |     		return false;  | ||||||
|  |     	*this = *rhs;  | ||||||
|  |     	return true; | ||||||
|  |     } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| typedef ConfigOption*       ConfigOptionPtr; | typedef ConfigOption*       ConfigOptionPtr; | ||||||
|  | @ -309,6 +322,62 @@ public: | ||||||
|     bool operator==(const std::vector<T> &rhs) const { return this->values == rhs; } |     bool operator==(const std::vector<T> &rhs) const { return this->values == rhs; } | ||||||
|     bool operator!=(const std::vector<T> &rhs) const { return this->values != rhs; } |     bool operator!=(const std::vector<T> &rhs) const { return this->values != rhs; } | ||||||
| 
 | 
 | ||||||
|  |     // Is this option overridden by another option?
 | ||||||
|  |     // An option overrides another option if it is not nil and not equal.
 | ||||||
|  |     bool overriden_by(const ConfigOption *rhs) const override { | ||||||
|  |         if (this->nullable()) | ||||||
|  |         	throw std::runtime_error("Cannot override a nullable ConfigOption."); | ||||||
|  |         if (rhs->type() != this->type()) | ||||||
|  |             throw std::runtime_error("ConfigOptionVector.overriden_by() applied to different types."); | ||||||
|  |     	auto rhs_vec = static_cast<const ConfigOptionVector<T>*>(rhs); | ||||||
|  |     	if (! rhs->nullable()) | ||||||
|  |     		// Overridding a non-nullable object with another non-nullable object.
 | ||||||
|  |     		return this->values != rhs_vec->values; | ||||||
|  |     	size_t i = 0; | ||||||
|  |     	size_t cnt = std::min(this->size(), rhs_vec->size()); | ||||||
|  |     	for (; i < cnt; ++ i) | ||||||
|  |     		if (! rhs_vec->is_nil(i) && this->values[i] != rhs_vec->values[i]) | ||||||
|  |     			return true; | ||||||
|  |     	for (; i < rhs_vec->size(); ++ i) | ||||||
|  |     		if (! rhs_vec->is_nil(i)) | ||||||
|  |     			return true; | ||||||
|  |     	return false; | ||||||
|  |     } | ||||||
|  |     // Apply an override option, possibly a nullable one.
 | ||||||
|  |     bool apply_override(const ConfigOption *rhs) override { | ||||||
|  |         if (this->nullable()) | ||||||
|  |         	throw std::runtime_error("Cannot override a nullable ConfigOption."); | ||||||
|  | 		if (rhs->type() != this->type()) | ||||||
|  | 			throw std::runtime_error("ConfigOptionVector.apply_override() applied to different types."); | ||||||
|  | 		auto rhs_vec = static_cast<const ConfigOptionVector<T>*>(rhs); | ||||||
|  | 		if (! rhs->nullable()) { | ||||||
|  |     		// Overridding a non-nullable object with another non-nullable object.
 | ||||||
|  |     		if (this->values != rhs_vec->values) { | ||||||
|  |     			this->values = rhs_vec->values; | ||||||
|  |     			return true; | ||||||
|  |     		} | ||||||
|  |     		return false; | ||||||
|  |     	} | ||||||
|  |     	size_t i = 0; | ||||||
|  |     	size_t cnt = std::min(this->size(), rhs_vec->size()); | ||||||
|  |     	bool   modified = false; | ||||||
|  |     	for (; i < cnt; ++ i) | ||||||
|  |     		if (! rhs_vec->is_nil(i) && this->values[i] != rhs_vec->values[i]) { | ||||||
|  |     			this->values[i] = rhs_vec->values[i]; | ||||||
|  |     			modified = true; | ||||||
|  |     		} | ||||||
|  |     	for (; i < rhs_vec->size(); ++ i) | ||||||
|  |     		if (! rhs_vec->is_nil(i)) { | ||||||
|  |     			if (this->values.empty()) | ||||||
|  |     				this->values.resize(i + 1); | ||||||
|  |     			else | ||||||
|  |     				this->values.resize(i + 1, this->values.front()); | ||||||
|  |     			this->values[i] = rhs_vec->values[i]; | ||||||
|  |     			modified = true; | ||||||
|  |     		} | ||||||
|  |     	return false; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
| private: | private: | ||||||
| 	friend class cereal::access; | 	friend class cereal::access; | ||||||
| 	template<class Archive> void serialize(Archive & ar) { ar(this->values); } | 	template<class Archive> void serialize(Archive & ar) { ar(this->values); } | ||||||
|  | @ -1595,7 +1664,7 @@ public: | ||||||
| 
 | 
 | ||||||
|     // Allow DynamicConfig to be instantiated on ints own without a definition.
 |     // Allow DynamicConfig to be instantiated on ints own without a definition.
 | ||||||
|     // If the definition is not defined, the method requiring the definition will throw NoDefinitionException.
 |     // If the definition is not defined, the method requiring the definition will throw NoDefinitionException.
 | ||||||
|     const ConfigDef*        def() const override { return nullptr; }; |     const ConfigDef*        def() const override { return nullptr; } | ||||||
|     template<class T> T*    opt(const t_config_option_key &opt_key, bool create = false) |     template<class T> T*    opt(const t_config_option_key &opt_key, bool create = false) | ||||||
|         { return dynamic_cast<T*>(this->option(opt_key, create)); } |         { return dynamic_cast<T*>(this->option(opt_key, create)); } | ||||||
|     template<class T> const T* opt(const t_config_option_key &opt_key) const |     template<class T> const T* opt(const t_config_option_key &opt_key) const | ||||||
|  |  | ||||||
|  | @ -1829,25 +1829,12 @@ void GCode::apply_print_config(const PrintConfig &print_config) | ||||||
|     m_config.apply(print_config); |     m_config.apply(print_config); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void GCode::append_full_config(const Print& print, std::string& str) | void GCode::append_full_config(const Print &print, std::string &str) | ||||||
| { | { | ||||||
|     const StaticPrintConfig *configs[] = { static_cast<const GCodeConfig*>(&print.config()), &print.default_object_config(), &print.default_region_config() }; | 	const DynamicPrintConfig &cfg = print.full_print_config(); | ||||||
|     for (size_t i = 0; i < sizeof(configs) / sizeof(configs[0]); ++i) { |     for (const std::string &key : cfg.keys()) | ||||||
|         const StaticPrintConfig *cfg = configs[i]; |         if (key != "compatible_prints" && key != "compatible_printers" && ! cfg.option(key)->is_nil()) | ||||||
|         for (const std::string &key : cfg->keys()) |             str += "; " + key + " = " + cfg.opt_serialize(key) + "\n"; | ||||||
|             if (key != "compatible_printers") |  | ||||||
|                 str += "; " + key + " = " + cfg->opt_serialize(key) + "\n"; |  | ||||||
|     } |  | ||||||
|     const DynamicConfig &full_config = print.placeholder_parser().config(); |  | ||||||
| 	for (const char *key : { |  | ||||||
| 		"print_settings_id", "filament_settings_id", "sla_print_settings_id", "sla_material_settings_id", "printer_settings_id", |  | ||||||
| 		"printer_model", "printer_variant",  |  | ||||||
| 	    "default_print_profile", "default_filament_profile", "default_sla_print_profile", "default_sla_material_profile", |  | ||||||
| 		"compatible_prints_condition_cummulative", "compatible_printers_condition_cummulative", "inherits_cummulative" }) { |  | ||||||
| 		const ConfigOption *opt = full_config.option(key); |  | ||||||
| 		if (opt != nullptr) |  | ||||||
| 			str += std::string("; ") + key + " = " + opt->serialize() + "\n"; |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void GCode::set_extruders(const std::vector<unsigned int> &extruder_ids) | void GCode::set_extruders(const std::vector<unsigned int> &extruder_ids) | ||||||
|  |  | ||||||
|  | @ -94,14 +94,6 @@ void PlaceholderParser::update_timestamp(DynamicConfig &config) | ||||||
|     config.set_key_value("second", new ConfigOptionInt(timeinfo->tm_sec)); |     config.set_key_value("second", new ConfigOptionInt(timeinfo->tm_sec)); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Ignore this key by the placeholder parser.
 |  | ||||||
| static inline bool placeholder_parser_ignore(const ConfigDef *def, const std::string &opt_key) |  | ||||||
| { |  | ||||||
|     const ConfigOptionDef *opt_def = def->get(opt_key); |  | ||||||
|     assert(opt_def != nullptr); |  | ||||||
|     return (opt_def->multiline && boost::ends_with(opt_key, "_gcode")) || opt_key == "post_process"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static inline bool opts_equal(const DynamicConfig &config_old, const DynamicConfig &config_new, const std::string &opt_key) | static inline bool opts_equal(const DynamicConfig &config_old, const DynamicConfig &config_new, const std::string &opt_key) | ||||||
| { | { | ||||||
| 	const ConfigOption *opt_old = config_old.option(opt_key); | 	const ConfigOption *opt_old = config_old.option(opt_key); | ||||||
|  | @ -119,7 +111,7 @@ std::vector<std::string> PlaceholderParser::config_diff(const DynamicPrintConfig | ||||||
|     const ConfigDef *def = rhs.def(); |     const ConfigDef *def = rhs.def(); | ||||||
|     std::vector<std::string> diff_keys; |     std::vector<std::string> diff_keys; | ||||||
|     for (const t_config_option_key &opt_key : rhs.keys()) |     for (const t_config_option_key &opt_key : rhs.keys()) | ||||||
|         if (! placeholder_parser_ignore(def, opt_key) && ! opts_equal(m_config, rhs, opt_key)) |         if (! opts_equal(m_config, rhs, opt_key)) | ||||||
|             diff_keys.emplace_back(opt_key); |             diff_keys.emplace_back(opt_key); | ||||||
|     return diff_keys; |     return diff_keys; | ||||||
| } | } | ||||||
|  | @ -135,8 +127,6 @@ bool PlaceholderParser::apply_config(const DynamicPrintConfig &rhs) | ||||||
|     const ConfigDef *def = rhs.def(); |     const ConfigDef *def = rhs.def(); | ||||||
|     bool modified = false; |     bool modified = false; | ||||||
|     for (const t_config_option_key &opt_key : rhs.keys()) { |     for (const t_config_option_key &opt_key : rhs.keys()) { | ||||||
|         if (placeholder_parser_ignore(def, opt_key)) |  | ||||||
|             continue; |  | ||||||
|         if (! opts_equal(m_config, rhs, opt_key)) { |         if (! opts_equal(m_config, rhs, opt_key)) { | ||||||
|             // Store a copy of the config option.
 |             // Store a copy of the config option.
 | ||||||
|             // Convert FloatOrPercent values to floats first.
 |             // Convert FloatOrPercent values to floats first.
 | ||||||
|  | @ -155,7 +145,6 @@ bool PlaceholderParser::apply_config(const DynamicPrintConfig &rhs) | ||||||
| void PlaceholderParser::apply_only(const DynamicPrintConfig &rhs, const std::vector<std::string> &keys) | void PlaceholderParser::apply_only(const DynamicPrintConfig &rhs, const std::vector<std::string> &keys) | ||||||
| { | { | ||||||
|     for (const t_config_option_key &opt_key : keys) { |     for (const t_config_option_key &opt_key : keys) { | ||||||
|         assert(! placeholder_parser_ignore(rhs.def(), opt_key)); |  | ||||||
|         // Store a copy of the config option.
 |         // Store a copy of the config option.
 | ||||||
|         // Convert FloatOrPercent values to floats first.
 |         // Convert FloatOrPercent values to floats first.
 | ||||||
|         //FIXME there are some ratio_over chains, which end with empty ratio_with.
 |         //FIXME there are some ratio_over chains, which end with empty ratio_with.
 | ||||||
|  | @ -167,6 +156,11 @@ void PlaceholderParser::apply_only(const DynamicPrintConfig &rhs, const std::vec | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void PlaceholderParser::apply_config(DynamicPrintConfig &&rhs) | ||||||
|  | { | ||||||
|  | 	m_config += std::move(rhs); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void PlaceholderParser::apply_env_variables() | void PlaceholderParser::apply_env_variables() | ||||||
| { | { | ||||||
|     for (char** env = environ; *env; ++ env) { |     for (char** env = environ; *env; ++ env) { | ||||||
|  |  | ||||||
|  | @ -19,6 +19,7 @@ public: | ||||||
|     std::vector<std::string> config_diff(const DynamicPrintConfig &rhs); |     std::vector<std::string> config_diff(const DynamicPrintConfig &rhs); | ||||||
|     // Return true if modified.
 |     // Return true if modified.
 | ||||||
|     bool apply_config(const DynamicPrintConfig &config); |     bool apply_config(const DynamicPrintConfig &config); | ||||||
|  |     void apply_config(DynamicPrintConfig &&config); | ||||||
|     // To be called on the values returned by PlaceholderParser::config_diff().
 |     // To be called on the values returned by PlaceholderParser::config_diff().
 | ||||||
|     // The keys should already be valid.
 |     // The keys should already be valid.
 | ||||||
|     void apply_only(const DynamicPrintConfig &config, const std::vector<std::string> &keys); |     void apply_only(const DynamicPrintConfig &config, const std::vector<std::string> &keys); | ||||||
|  |  | ||||||
|  | @ -485,23 +485,77 @@ bool layer_height_ranges_equal(const t_layer_config_ranges &lr1, const t_layer_c | ||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Print::ApplyStatus Print::apply(const Model &model, const DynamicPrintConfig &config_in) | // Collect diffs of configuration values at various containers,
 | ||||||
|  | // resolve the filament rectract overrides of extruder retract values.
 | ||||||
|  | void Print::config_diffs( | ||||||
|  | 	const DynamicPrintConfig &new_full_config,  | ||||||
|  | 	t_config_option_keys &print_diff, t_config_option_keys &object_diff, t_config_option_keys ®ion_diff,  | ||||||
|  | 	t_config_option_keys &full_config_diff,  | ||||||
|  | 	DynamicPrintConfig &placeholder_parser_overrides, | ||||||
|  | 	DynamicPrintConfig &filament_overrides) const | ||||||
|  | { | ||||||
|  |     // Collect changes to print config, account for overrides of extruder retract values by filament presets.
 | ||||||
|  |     { | ||||||
|  | 	    const std::vector<std::string> &extruder_retract_keys = print_config_def.extruder_retract_keys(); | ||||||
|  | 	    const std::string               filament_prefix       = "filament_"; | ||||||
|  | 	    for (const t_config_option_key &opt_key : m_config.keys()) { | ||||||
|  | 	        const ConfigOption *opt_old = m_config.option(opt_key); | ||||||
|  | 	        assert(opt_old != nullptr); | ||||||
|  | 	        const ConfigOption *opt_new = new_full_config.option(opt_key); | ||||||
|  | 	        assert(opt_new != nullptr); | ||||||
|  | 	        const ConfigOption *opt_new_filament = std::binary_search(extruder_retract_keys.begin(), extruder_retract_keys.end(), opt_key) ? new_full_config.option(filament_prefix + opt_key) : nullptr; | ||||||
|  | 	        if (opt_new_filament != nullptr && ! opt_new_filament->is_nil()) { | ||||||
|  | 	        	// An extruder retract override is available at some of the filament presets.
 | ||||||
|  | 	        	if (*opt_old != *opt_new || opt_new->overriden_by(opt_new_filament)) { | ||||||
|  | 	        		auto opt_copy = opt_new->clone(); | ||||||
|  | 	        		opt_copy->apply_override(opt_new_filament); | ||||||
|  | 	        		if (*opt_old == *opt_copy) | ||||||
|  | 	        			delete opt_copy; | ||||||
|  | 	        		else { | ||||||
|  | 	        			filament_overrides.set_key_value(opt_key, opt_copy); | ||||||
|  | 	        			print_diff.emplace_back(opt_key); | ||||||
|  | 	        		} | ||||||
|  | 	        	} | ||||||
|  | 	        } else if (*opt_new != *opt_old) | ||||||
|  | 	            print_diff.emplace_back(opt_key); | ||||||
|  | 	    } | ||||||
|  | 	} | ||||||
|  | 	// Collect changes to object and region configs.
 | ||||||
|  |     object_diff = m_default_object_config.diff(new_full_config); | ||||||
|  |     region_diff = m_default_region_config.diff(new_full_config); | ||||||
|  |     // Prepare for storing of the full print config into new_full_config to be exported into the G-code and to be used by the PlaceholderParser.
 | ||||||
|  |     // As the PlaceholderParser does not interpret the FloatOrPercent values itself, these values are stored into the PlaceholderParser converted to floats.
 | ||||||
|  |     for (const t_config_option_key &opt_key : new_full_config.keys()) { | ||||||
|  |         const ConfigOption *opt_old = m_full_print_config.option(opt_key); | ||||||
|  |         const ConfigOption *opt_new = new_full_config.option(opt_key); | ||||||
|  |         if (opt_old == nullptr || *opt_new != *opt_old) | ||||||
|  |             full_config_diff.emplace_back(opt_key); | ||||||
|  |         if (opt_new->type() == coFloatOrPercent) { | ||||||
|  |         	// The m_placeholder_parser is never modified by the background processing, GCode.cpp/hpp makes a copy.
 | ||||||
|  | 	        const ConfigOption *opt_old_pp = this->placeholder_parser().config().option(opt_key); | ||||||
|  | 	        double new_value = new_full_config.get_abs_value(opt_key); | ||||||
|  | 	        if (opt_old_pp == nullptr || static_cast<const ConfigOptionFloat*>(opt_old_pp)->value != new_value) | ||||||
|  | 	        	placeholder_parser_overrides.set_key_value(opt_key, new ConfigOptionFloat(new_value)); | ||||||
|  | 		} | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | Print::ApplyStatus Print::apply(const Model &model, DynamicPrintConfig new_full_config) | ||||||
| { | { | ||||||
| #ifdef _DEBUG | #ifdef _DEBUG | ||||||
|     check_model_ids_validity(model); |     check_model_ids_validity(model); | ||||||
| #endif /* _DEBUG */ | #endif /* _DEBUG */ | ||||||
| 
 | 
 | ||||||
|     // Make a copy of the config, normalize it.
 |     // Normalize the config.
 | ||||||
|     DynamicPrintConfig config(config_in); | 	new_full_config.option("print_settings_id",    true); | ||||||
| 	config.option("print_settings_id",    true); | 	new_full_config.option("filament_settings_id", true); | ||||||
| 	config.option("filament_settings_id", true); | 	new_full_config.option("printer_settings_id",  true); | ||||||
| 	config.option("printer_settings_id",  true); |     new_full_config.normalize(); | ||||||
|     config.normalize(); | 
 | ||||||
|     // Collect changes to print config.
 |     // Find modified keys of the various configs. Resolve overrides extruder retract values by filament profiles.
 | ||||||
|     t_config_option_keys print_diff  = m_config.diff(config); | 	t_config_option_keys print_diff, object_diff, region_diff, full_config_diff; | ||||||
|     t_config_option_keys object_diff = m_default_object_config.diff(config); | 	DynamicPrintConfig placeholder_parser_overrides, filament_overrides; | ||||||
|     t_config_option_keys region_diff = m_default_region_config.diff(config); | 	this->config_diffs(new_full_config, print_diff, object_diff, region_diff, full_config_diff, placeholder_parser_overrides, filament_overrides); | ||||||
|     t_config_option_keys placeholder_parser_diff = this->placeholder_parser().config_diff(config); |  | ||||||
| 
 | 
 | ||||||
|     // Do not use the ApplyStatus as we will use the max function when updating apply_status.
 |     // Do not use the ApplyStatus as we will use the max function when updating apply_status.
 | ||||||
|     unsigned int apply_status = APPLY_STATUS_UNCHANGED; |     unsigned int apply_status = APPLY_STATUS_UNCHANGED; | ||||||
|  | @ -516,25 +570,27 @@ Print::ApplyStatus Print::apply(const Model &model, const DynamicPrintConfig &co | ||||||
|     // The following call may stop the background processing.
 |     // The following call may stop the background processing.
 | ||||||
|     if (! print_diff.empty()) |     if (! print_diff.empty()) | ||||||
|         update_apply_status(this->invalidate_state_by_config_options(print_diff)); |         update_apply_status(this->invalidate_state_by_config_options(print_diff)); | ||||||
|  | 
 | ||||||
|     // Apply variables to placeholder parser. The placeholder parser is used by G-code export,
 |     // Apply variables to placeholder parser. The placeholder parser is used by G-code export,
 | ||||||
|     // which should be stopped if print_diff is not empty.
 |     // which should be stopped if print_diff is not empty.
 | ||||||
| 	if (! placeholder_parser_diff.empty()) { |     if (! full_config_diff.empty() || ! placeholder_parser_overrides.empty()) { | ||||||
|         update_apply_status(this->invalidate_step(psGCodeExport)); |         update_apply_status(this->invalidate_step(psGCodeExport)); | ||||||
| 		PlaceholderParser &pp = this->placeholder_parser(); | 		PlaceholderParser &pp = this->placeholder_parser(); | ||||||
| 		pp.apply_only(config, placeholder_parser_diff); | 		pp.apply_config(std::move(placeholder_parser_overrides)); | ||||||
|         // Set the profile aliases for the PrintBase::output_filename()
 |         // Set the profile aliases for the PrintBase::output_filename()
 | ||||||
| 		pp.set("print_preset",    config.option("print_settings_id")->clone()); | 		pp.set("print_preset",    new_full_config.option("print_settings_id")->clone()); | ||||||
| 		pp.set("filament_preset", config.option("filament_settings_id")->clone()); | 		pp.set("filament_preset", new_full_config.option("filament_settings_id")->clone()); | ||||||
| 		pp.set("printer_preset",  config.option("printer_settings_id")->clone()); | 		pp.set("printer_preset",  new_full_config.option("printer_settings_id")->clone()); | ||||||
|  | 	    // It is also safe to change m_config now after this->invalidate_state_by_config_options() call.
 | ||||||
|  | 	    m_config.apply_only(new_full_config, print_diff, true); | ||||||
|  | 	    m_config.apply(filament_overrides); | ||||||
|  | 	    // Handle changes to object config defaults
 | ||||||
|  | 	    m_default_object_config.apply_only(new_full_config, object_diff, true); | ||||||
|  | 	    // Handle changes to regions config defaults
 | ||||||
|  | 	    m_default_region_config.apply_only(new_full_config, region_diff, true); | ||||||
|  |         m_full_print_config = std::move(new_full_config); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     // It is also safe to change m_config now after this->invalidate_state_by_config_options() call.
 |  | ||||||
|     m_config.apply_only(config, print_diff, true); |  | ||||||
|     // Handle changes to object config defaults
 |  | ||||||
|     m_default_object_config.apply_only(config, object_diff, true); |  | ||||||
|     // Handle changes to regions config defaults
 |  | ||||||
|     m_default_region_config.apply_only(config, region_diff, true); |  | ||||||
|      |  | ||||||
|     class LayerRanges |     class LayerRanges | ||||||
|     { |     { | ||||||
|     public: |     public: | ||||||
|  | @ -1698,8 +1754,8 @@ void Print::_make_wipe_tower() | ||||||
| 			(float)m_config.filament_cooling_initial_speed.get_at(i), | 			(float)m_config.filament_cooling_initial_speed.get_at(i), | ||||||
| 			(float)m_config.filament_cooling_final_speed.get_at(i), | 			(float)m_config.filament_cooling_final_speed.get_at(i), | ||||||
|             m_config.filament_ramming_parameters.get_at(i), |             m_config.filament_ramming_parameters.get_at(i), | ||||||
|             m_config.filament_max_volumetric_speed.get_at(i), | 			(float)m_config.filament_max_volumetric_speed.get_at(i), | ||||||
|             m_config.nozzle_diameter.get_at(i)); |             (float)m_config.nozzle_diameter.get_at(i)); | ||||||
| 
 | 
 | ||||||
|     m_wipe_tower_data.priming = Slic3r::make_unique<std::vector<WipeTower::ToolChangeResult>>( |     m_wipe_tower_data.priming = Slic3r::make_unique<std::vector<WipeTower::ToolChangeResult>>( | ||||||
|         wipe_tower.prime((float)this->skirt_first_layer_height(), m_wipe_tower_data.tool_ordering.all_extruders(), false)); |         wipe_tower.prime((float)this->skirt_first_layer_height(), m_wipe_tower_data.tool_ordering.all_extruders(), false)); | ||||||
|  |  | ||||||
|  | @ -296,7 +296,7 @@ public: | ||||||
|     void                clear() override; |     void                clear() override; | ||||||
|     bool                empty() const override { return m_objects.empty(); } |     bool                empty() const override { return m_objects.empty(); } | ||||||
| 
 | 
 | ||||||
|     ApplyStatus         apply(const Model &model, const DynamicPrintConfig &config) override; |     ApplyStatus         apply(const Model &model, DynamicPrintConfig config) override; | ||||||
| 
 | 
 | ||||||
|     void                process() override; |     void                process() override; | ||||||
|     // Exports G-code into a file name based on the path_template, returns the file path of the generated G-code file.
 |     // Exports G-code into a file name based on the path_template, returns the file path of the generated G-code file.
 | ||||||
|  | @ -368,6 +368,13 @@ protected: | ||||||
|     bool                invalidate_step(PrintStep step); |     bool                invalidate_step(PrintStep step); | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|  | 	void 				config_diffs( | ||||||
|  | 		const DynamicPrintConfig &new_full_config,  | ||||||
|  | 		t_config_option_keys &print_diff, t_config_option_keys &object_diff, t_config_option_keys ®ion_diff,  | ||||||
|  | 		t_config_option_keys &full_config_diff,  | ||||||
|  | 		DynamicPrintConfig &placeholder_parser_overrides, | ||||||
|  | 		DynamicPrintConfig &filament_overrides) const; | ||||||
|  | 
 | ||||||
|     bool                invalidate_state_by_config_options(const std::vector<t_config_option_key> &opt_keys); |     bool                invalidate_state_by_config_options(const std::vector<t_config_option_key> &opt_keys); | ||||||
| 
 | 
 | ||||||
|     void                _make_skirt(); |     void                _make_skirt(); | ||||||
|  |  | ||||||
|  | @ -217,7 +217,7 @@ protected: | ||||||
| class PrintBase | class PrintBase | ||||||
| { | { | ||||||
| public: | public: | ||||||
| 	PrintBase() { this->restart(); } | 	PrintBase() : m_placeholder_parser(&m_full_print_config) { this->restart(); } | ||||||
|     inline virtual ~PrintBase() {} |     inline virtual ~PrintBase() {} | ||||||
| 
 | 
 | ||||||
|     virtual PrinterTechnology technology() const noexcept = 0; |     virtual PrinterTechnology technology() const noexcept = 0; | ||||||
|  | @ -240,7 +240,7 @@ public: | ||||||
|         // Some data was changed, which in turn invalidated already calculated steps.
 |         // Some data was changed, which in turn invalidated already calculated steps.
 | ||||||
|         APPLY_STATUS_INVALIDATED, |         APPLY_STATUS_INVALIDATED, | ||||||
|     }; |     }; | ||||||
|     virtual ApplyStatus     apply(const Model &model, const DynamicPrintConfig &config) = 0; |     virtual ApplyStatus     apply(const Model &model, DynamicPrintConfig config) = 0; | ||||||
|     const Model&            model() const { return m_model; } |     const Model&            model() const { return m_model; } | ||||||
| 
 | 
 | ||||||
|     struct TaskParams { |     struct TaskParams { | ||||||
|  | @ -316,7 +316,7 @@ public: | ||||||
|     virtual bool               finished() const = 0; |     virtual bool               finished() const = 0; | ||||||
| 
 | 
 | ||||||
|     const PlaceholderParser&   placeholder_parser() const { return m_placeholder_parser; } |     const PlaceholderParser&   placeholder_parser() const { return m_placeholder_parser; } | ||||||
|     PlaceholderParser&         placeholder_parser() { return m_placeholder_parser; } |     const DynamicPrintConfig&  full_print_config() const { return m_full_print_config; } | ||||||
| 
 | 
 | ||||||
|     virtual std::string        output_filename(const std::string &filename_base = std::string()) const = 0; |     virtual std::string        output_filename(const std::string &filename_base = std::string()) const = 0; | ||||||
|     // If the filename_base is set, it is used as the input for the template processing. In that case the path is expected to be the directory (may be empty).
 |     // If the filename_base is set, it is used as the input for the template processing. In that case the path is expected to be the directory (may be empty).
 | ||||||
|  | @ -327,6 +327,8 @@ protected: | ||||||
| 	friend class PrintObjectBase; | 	friend class PrintObjectBase; | ||||||
|     friend class BackgroundSlicingProcess; |     friend class BackgroundSlicingProcess; | ||||||
| 
 | 
 | ||||||
|  |     PlaceholderParser&     placeholder_parser() { return m_placeholder_parser; } | ||||||
|  | 
 | ||||||
|     tbb::mutex&            state_mutex() const { return m_state_mutex; } |     tbb::mutex&            state_mutex() const { return m_state_mutex; } | ||||||
|     std::function<void()>  cancel_callback() { return m_cancel_callback; } |     std::function<void()>  cancel_callback() { return m_cancel_callback; } | ||||||
| 	void				   call_cancel_callback() { m_cancel_callback(); } | 	void				   call_cancel_callback() { m_cancel_callback(); } | ||||||
|  | @ -341,6 +343,7 @@ protected: | ||||||
|     void                   update_object_placeholders(DynamicConfig &config, const std::string &default_ext) const; |     void                   update_object_placeholders(DynamicConfig &config, const std::string &default_ext) const; | ||||||
| 
 | 
 | ||||||
| 	Model                                   m_model; | 	Model                                   m_model; | ||||||
|  | 	DynamicPrintConfig						m_full_print_config; | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     tbb::atomic<CancelStatus>               m_cancel_status; |     tbb::atomic<CancelStatus>               m_cancel_status; | ||||||
|  |  | ||||||
|  | @ -29,6 +29,7 @@ PrintConfigDef::PrintConfigDef() | ||||||
|     this->init_common_params(); |     this->init_common_params(); | ||||||
|     assign_printer_technology_to_unknown(this->options, ptAny); |     assign_printer_technology_to_unknown(this->options, ptAny); | ||||||
|     this->init_fff_params(); |     this->init_fff_params(); | ||||||
|  |     this->init_extruder_retract_keys(); | ||||||
|     assign_printer_technology_to_unknown(this->options, ptFFF); |     assign_printer_technology_to_unknown(this->options, ptFFF); | ||||||
|     this->init_sla_params(); |     this->init_sla_params(); | ||||||
|     assign_printer_technology_to_unknown(this->options, ptSLA); |     assign_printer_technology_to_unknown(this->options, ptSLA); | ||||||
|  | @ -2254,6 +2255,24 @@ void PrintConfigDef::init_fff_params() | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void PrintConfigDef::init_extruder_retract_keys() | ||||||
|  | { | ||||||
|  | 	m_extruder_retract_keys = { | ||||||
|  | 		"deretract_speed", | ||||||
|  | 		"retract_before_travel", | ||||||
|  | 		"retract_before_wipe", | ||||||
|  | 		"retract_layer_change", | ||||||
|  | 		"retract_length", | ||||||
|  | 		"retract_lift", | ||||||
|  | 		"retract_lift_above", | ||||||
|  | 		"retract_lift_below", | ||||||
|  | 		"retract_restart_extra", | ||||||
|  | 		"retract_speed", | ||||||
|  | 		"wipe" | ||||||
|  | 	}; | ||||||
|  | 	assert(std::is_sorted(m_extruder_retract_keys.begin(), m_extruder_retract_keys.end())); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void PrintConfigDef::init_sla_params() | void PrintConfigDef::init_sla_params() | ||||||
| { | { | ||||||
|     ConfigOptionDef* def; |     ConfigOptionDef* def; | ||||||
|  |  | ||||||
|  | @ -185,10 +185,18 @@ public: | ||||||
| 
 | 
 | ||||||
|     static void handle_legacy(t_config_option_key &opt_key, std::string &value); |     static void handle_legacy(t_config_option_key &opt_key, std::string &value); | ||||||
| 
 | 
 | ||||||
|  |     // Options defining the extruder retract properties. These keys are sorted lexicographically.
 | ||||||
|  |     // The extruder retract keys could be overidden by the same values defined at the Filament level
 | ||||||
|  |     // (then the key is further prefixed with the "filament_" prefix).
 | ||||||
|  |     const std::vector<std::string>& extruder_retract_keys() const { return m_extruder_retract_keys; } | ||||||
|  | 
 | ||||||
| private: | private: | ||||||
|     void init_common_params(); |     void init_common_params(); | ||||||
|     void init_fff_params(); |     void init_fff_params(); | ||||||
|  |     void init_extruder_retract_keys(); | ||||||
|     void init_sla_params(); |     void init_sla_params(); | ||||||
|  | 
 | ||||||
|  |     std::vector<std::string> 	m_extruder_retract_keys; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // The one and only global definition of SLic3r configuration options.
 | // The one and only global definition of SLic3r configuration options.
 | ||||||
|  |  | ||||||
|  | @ -145,14 +145,13 @@ static std::vector<SLAPrintObject::Instance> sla_instances(const ModelObject &mo | ||||||
|     return instances; |     return instances; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| SLAPrint::ApplyStatus SLAPrint::apply(const Model &model, const DynamicPrintConfig &config_in) | SLAPrint::ApplyStatus SLAPrint::apply(const Model &model, DynamicPrintConfig config) | ||||||
| { | { | ||||||
| #ifdef _DEBUG | #ifdef _DEBUG | ||||||
|     check_model_ids_validity(model); |     check_model_ids_validity(model); | ||||||
| #endif /* _DEBUG */ | #endif /* _DEBUG */ | ||||||
| 
 | 
 | ||||||
|     // Make a copy of the config, normalize it.
 |     // Normalize the config.
 | ||||||
|     DynamicPrintConfig config(config_in); |  | ||||||
|     config.option("sla_print_settings_id",    true); |     config.option("sla_print_settings_id",    true); | ||||||
|     config.option("sla_material_settings_id", true); |     config.option("sla_material_settings_id", true); | ||||||
|     config.option("printer_settings_id",      true); |     config.option("printer_settings_id",      true); | ||||||
|  | @ -459,6 +458,7 @@ SLAPrint::ApplyStatus SLAPrint::apply(const Model &model, const DynamicPrintConf | ||||||
|     check_model_ids_equal(m_model, model); |     check_model_ids_equal(m_model, model); | ||||||
| #endif /* _DEBUG */ | #endif /* _DEBUG */ | ||||||
| 
 | 
 | ||||||
|  |     m_full_print_config = std::move(config); | ||||||
|     return static_cast<ApplyStatus>(apply_status); |     return static_cast<ApplyStatus>(apply_status); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -349,7 +349,7 @@ public: | ||||||
| 
 | 
 | ||||||
|     void                clear() override; |     void                clear() override; | ||||||
|     bool                empty() const override { return m_objects.empty(); } |     bool                empty() const override { return m_objects.empty(); } | ||||||
|     ApplyStatus         apply(const Model &model, const DynamicPrintConfig &config) override; |     ApplyStatus         apply(const Model &model, DynamicPrintConfig config) override; | ||||||
|     void                set_task(const TaskParams ¶ms) override; |     void                set_task(const TaskParams ¶ms) override; | ||||||
|     void                process() override; |     void                process() override; | ||||||
|     void                finalize() override; |     void                finalize() override; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv