mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 17:51:10 -06:00 
			
		
		
		
	Fix of Crash on Export config Bundle (Win64) (#2307)
Export of the names of the SLA profiles was performed into the config bundle for SLA profiles, which were nop set. A safe method is now used, which stores an empty string in such a case.
This commit is contained in:
		
							parent
							
								
									37984ece16
								
							
						
					
					
						commit
						f5ef537640
					
				
					 3 changed files with 16 additions and 16 deletions
				
			
		|  | @ -832,7 +832,7 @@ void Sidebar::update_presets(Preset::Type preset_type) | ||||||
| 
 | 
 | ||||||
|         if (filament_cnt == 1) { |         if (filament_cnt == 1) { | ||||||
|             // Single filament printer, synchronize the filament presets.
 |             // Single filament printer, synchronize the filament presets.
 | ||||||
|             const std::string &name = preset_bundle.filaments.get_selected_preset().name; |             const std::string &name = preset_bundle.filaments.get_selected_preset_name(); | ||||||
|             preset_bundle.set_filament_preset(0, name); |             preset_bundle.set_filament_preset(0, name); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -526,9 +526,9 @@ DynamicPrintConfig PresetBundle::full_fff_config() const | ||||||
|         opt->value = boost::algorithm::clamp<int>(opt->value, 0, int(num_extruders)); |         opt->value = boost::algorithm::clamp<int>(opt->value, 0, int(num_extruders)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     out.option<ConfigOptionString >("print_settings_id",    true)->value  = this->prints.get_selected_preset().name; |     out.option<ConfigOptionString >("print_settings_id",    true)->value  = this->prints.get_selected_preset_name(); | ||||||
|     out.option<ConfigOptionStrings>("filament_settings_id", true)->values = this->filament_presets; |     out.option<ConfigOptionStrings>("filament_settings_id", true)->values = this->filament_presets; | ||||||
|     out.option<ConfigOptionString >("printer_settings_id",  true)->value  = this->printers.get_selected_preset().name; |     out.option<ConfigOptionString >("printer_settings_id",  true)->value  = this->printers.get_selected_preset_name(); | ||||||
| 
 | 
 | ||||||
|     // Serialize the collected "compatible_printers_condition" and "inherits" fields.
 |     // Serialize the collected "compatible_printers_condition" and "inherits" fields.
 | ||||||
|     // There will be 1 + num_exturders fields for "inherits" and 2 + num_extruders for "compatible_printers_condition" stored.
 |     // There will be 1 + num_exturders fields for "inherits" and 2 + num_extruders for "compatible_printers_condition" stored.
 | ||||||
|  | @ -577,9 +577,9 @@ DynamicPrintConfig PresetBundle::full_sla_config() const | ||||||
|     out.erase("compatible_printers_condition"); |     out.erase("compatible_printers_condition"); | ||||||
|     out.erase("inherits"); |     out.erase("inherits"); | ||||||
|      |      | ||||||
|     out.option<ConfigOptionString >("sla_print_settings_id",    true)->value  = this->sla_prints.get_selected_preset().name; |     out.option<ConfigOptionString >("sla_print_settings_id",    true)->value  = this->sla_prints.get_selected_preset_name(); | ||||||
|     out.option<ConfigOptionString >("sla_material_settings_id", true)->value  = this->sla_materials.get_selected_preset().name; |     out.option<ConfigOptionString >("sla_material_settings_id", true)->value  = this->sla_materials.get_selected_preset_name(); | ||||||
|     out.option<ConfigOptionString >("printer_settings_id",      true)->value  = this->printers.get_selected_preset().name; |     out.option<ConfigOptionString >("printer_settings_id",      true)->value  = this->printers.get_selected_preset_name(); | ||||||
| 
 | 
 | ||||||
|     // Serialize the collected "compatible_printers_condition" and "inherits" fields.
 |     // Serialize the collected "compatible_printers_condition" and "inherits" fields.
 | ||||||
|     // There will be 1 + num_exturders fields for "inherits" and 2 + num_extruders for "compatible_printers_condition" stored.
 |     // There will be 1 + num_exturders fields for "inherits" and 2 + num_extruders for "compatible_printers_condition" stored.
 | ||||||
|  | @ -854,11 +854,11 @@ void PresetBundle::load_config_file_config_bundle(const std::string &path, const | ||||||
|         collection_dst.load_preset(path, preset_name_dst, std::move(preset_src->config), activate).is_external = true; |         collection_dst.load_preset(path, preset_name_dst, std::move(preset_src->config), activate).is_external = true; | ||||||
|         return preset_name_dst; |         return preset_name_dst; | ||||||
|     }; |     }; | ||||||
|     load_one(this->prints,        tmp_bundle.prints,        tmp_bundle.prints       .get_selected_preset().name, true); |     load_one(this->prints,        tmp_bundle.prints,        tmp_bundle.prints       .get_selected_preset_name(), true); | ||||||
|     load_one(this->sla_prints,    tmp_bundle.sla_prints,    tmp_bundle.sla_prints   .get_selected_preset().name, true); |     load_one(this->sla_prints,    tmp_bundle.sla_prints,    tmp_bundle.sla_prints   .get_selected_preset_name(), true); | ||||||
|     load_one(this->filaments,     tmp_bundle.filaments,     tmp_bundle.filaments    .get_selected_preset().name, true); |     load_one(this->filaments,     tmp_bundle.filaments,     tmp_bundle.filaments    .get_selected_preset_name(), true); | ||||||
|     load_one(this->sla_materials, tmp_bundle.sla_materials, tmp_bundle.sla_materials.get_selected_preset().name, true); |     load_one(this->sla_materials, tmp_bundle.sla_materials, tmp_bundle.sla_materials.get_selected_preset_name(), true); | ||||||
|     load_one(this->printers,      tmp_bundle.printers,      tmp_bundle.printers     .get_selected_preset().name, true); |     load_one(this->printers,      tmp_bundle.printers,      tmp_bundle.printers     .get_selected_preset_name(), true); | ||||||
|     this->update_multi_material_filament_presets(); |     this->update_multi_material_filament_presets(); | ||||||
|     for (size_t i = 1; i < std::min(tmp_bundle.filament_presets.size(), this->filament_presets.size()); ++ i) |     for (size_t i = 1; i < std::min(tmp_bundle.filament_presets.size(), this->filament_presets.size()); ++ i) | ||||||
|         this->filament_presets[i] = load_one(this->filaments, tmp_bundle.filaments, tmp_bundle.filament_presets[i], false); |         this->filament_presets[i] = load_one(this->filaments, tmp_bundle.filaments, tmp_bundle.filament_presets[i], false); | ||||||
|  | @ -1372,10 +1372,10 @@ void PresetBundle::export_configbundle(const std::string &path, bool export_syst | ||||||
| 
 | 
 | ||||||
|     // Export the names of the active presets.
 |     // Export the names of the active presets.
 | ||||||
|     c << std::endl << "[presets]" << std::endl; |     c << std::endl << "[presets]" << std::endl; | ||||||
|     c << "print = " << this->prints.get_selected_preset().name << std::endl; |     c << "print = " << this->prints.get_selected_preset_name() << std::endl; | ||||||
|     c << "sla_print = " << this->sla_prints.get_selected_preset().name << std::endl; |     c << "sla_print = " << this->sla_prints.get_selected_preset_name() << std::endl; | ||||||
|     c << "sla_material = " << this->sla_materials.get_selected_preset().name << std::endl; |     c << "sla_material = " << this->sla_materials.get_selected_preset_name() << std::endl; | ||||||
|     c << "printer = " << this->printers.get_selected_preset().name << std::endl; |     c << "printer = " << this->printers.get_selected_preset_name() << std::endl; | ||||||
|     for (size_t i = 0; i < this->filament_presets.size(); ++ i) { |     for (size_t i = 0; i < this->filament_presets.size(); ++ i) { | ||||||
|         char suffix[64]; |         char suffix[64]; | ||||||
|         if (i > 0) |         if (i > 0) | ||||||
|  |  | ||||||
|  | @ -67,7 +67,7 @@ std::string PresetHints::maximum_volumetric_flow_description(const PresetBundle | ||||||
|     int idx_extruder  = 0; |     int idx_extruder  = 0; | ||||||
| 	int num_extruders = (int)preset_bundle.filament_presets.size(); | 	int num_extruders = (int)preset_bundle.filament_presets.size(); | ||||||
|     for (; idx_extruder < num_extruders; ++ idx_extruder) |     for (; idx_extruder < num_extruders; ++ idx_extruder) | ||||||
|         if (preset_bundle.filament_presets[idx_extruder] == preset_bundle.filaments.get_selected_preset().name) |         if (preset_bundle.filament_presets[idx_extruder] == preset_bundle.filaments.get_selected_preset_name()) | ||||||
|             break; |             break; | ||||||
|     if (idx_extruder == num_extruders) |     if (idx_extruder == num_extruders) | ||||||
|         // The current filament preset is not active for any extruder.
 |         // The current filament preset is not active for any extruder.
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv