mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 10:11:10 -06:00 
			
		
		
		
	Ported test_support_material from upstream Slic3r.
Reworked the FFF testing framework & ConfigBase::set_deserialize() for more compact tests: set_deserialize() now accepts list of key / value pairs. Fixed an incorrect assert in LayerRegion.
This commit is contained in:
		
							parent
							
								
									0ee78543a4
								
							
						
					
					
						commit
						c228a49fe0
					
				
					 13 changed files with 769 additions and 536 deletions
				
			
		|  | @ -438,6 +438,14 @@ bool ConfigBase::set_deserialize(const t_config_option_key &opt_key_src, const s | |||
|     return this->set_deserialize_raw(opt_key, value, append); | ||||
| } | ||||
| 
 | ||||
| bool ConfigBase::set_deserialize(std::initializer_list<SetDeserializeItem> items) | ||||
| { | ||||
| 	bool deserialized = true; | ||||
| 	for (const SetDeserializeItem &item : items) | ||||
| 		deserialized &= this->set_deserialize(item.opt_key, item.opt_value, item.append); | ||||
| 	return deserialized; | ||||
| } | ||||
| 
 | ||||
| bool ConfigBase::set_deserialize_raw(const t_config_option_key &opt_key_src, const std::string &value, bool append) | ||||
| { | ||||
|     t_config_option_key opt_key = opt_key_src; | ||||
|  |  | |||
|  | @ -1554,6 +1554,8 @@ public: | |||
|     // Set a configuration value from a string, it will call an overridable handle_legacy() 
 | ||||
|     // to resolve renamed and removed configuration keys.
 | ||||
|     bool set_deserialize(const t_config_option_key &opt_key, const std::string &str, bool append = false); | ||||
|     struct SetDeserializeItem { std::string opt_key; std::string opt_value; bool append = false; }; | ||||
|     bool set_deserialize(std::initializer_list<SetDeserializeItem> items); | ||||
| 
 | ||||
|     double get_abs_value(const t_config_option_key &opt_key) const; | ||||
|     double get_abs_value(const t_config_option_key &opt_key, double ratio_over) const; | ||||
|  |  | |||
|  | @ -70,7 +70,7 @@ void LayerRegion::make_perimeters(const SurfaceCollection &slices, SurfaceCollec | |||
|         fill_surfaces | ||||
|     ); | ||||
|      | ||||
|     if (this->layer()->lower_layer != NULL) | ||||
|     if (this->layer()->lower_layer != nullptr) | ||||
|         // Cummulative sum of polygons over all the regions.
 | ||||
|         g.lower_slices = &this->layer()->lower_layer->slices; | ||||
|      | ||||
|  | @ -130,7 +130,7 @@ void LayerRegion::process_external_surfaces(const Layer *lower_layer, const Poly | |||
|                     bridges.emplace_back(surface); | ||||
|             } | ||||
|             if (surface.is_internal()) { | ||||
|             	assert(surface.surface_type == stInternal); | ||||
|             	assert(surface.surface_type == stInternal || surface.surface_type == stInternalSolid); | ||||
|             	if (! has_infill && lower_layer != nullptr) | ||||
|             		polygons_append(voids, surface.expolygon); | ||||
|             	internal.emplace_back(std::move(surface)); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv