mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	PresetUpdater: Fix: Index installed too early
This commit is contained in:
		
							parent
							
								
									61080bcff6
								
							
						
					
					
						commit
						1a529cb778
					
				
					 1 changed files with 14 additions and 8 deletions
				
			
		|  | @ -402,15 +402,8 @@ Updates PresetUpdater::priv::get_config_updates() const | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		copy_file_fix(idx.path(), bundle_path_idx); |  | ||||||
| 
 |  | ||||||
| 		const auto ver_current = idx.find(vp.config_version); | 		const auto ver_current = idx.find(vp.config_version); | ||||||
| 		const bool ver_current_found = ver_current != idx.end(); | 		const bool ver_current_found = ver_current != idx.end(); | ||||||
| 		if (! ver_current_found) { |  | ||||||
| 			auto message = (boost::format("Preset bundle `%1%` version not found in index: %2%") % idx.vendor() % vp.config_version.to_string()).str(); |  | ||||||
| 			BOOST_LOG_TRIVIAL(error) << message; |  | ||||||
| 			GUI::show_error(nullptr, GUI::from_u8(message)); |  | ||||||
| 		} |  | ||||||
| 
 | 
 | ||||||
| 		BOOST_LOG_TRIVIAL(debug) << boost::format("Vendor: %1%, version installed: %2%%3%, version cached: %4%") | 		BOOST_LOG_TRIVIAL(debug) << boost::format("Vendor: %1%, version installed: %2%%3%, version cached: %4%") | ||||||
| 			% vp.name | 			% vp.name | ||||||
|  | @ -418,6 +411,13 @@ Updates PresetUpdater::priv::get_config_updates() const | ||||||
| 			% (ver_current_found ? "" : " (not found in index!)") | 			% (ver_current_found ? "" : " (not found in index!)") | ||||||
| 			% recommended->config_version.to_string(); | 			% recommended->config_version.to_string(); | ||||||
| 
 | 
 | ||||||
|  | 		if (! ver_current_found) { | ||||||
|  | 			auto message = (boost::format("Preset bundle `%1%` version not found in index: %2%") % idx.vendor() % vp.config_version.to_string()).str(); | ||||||
|  | 			BOOST_LOG_TRIVIAL(error) << message; | ||||||
|  | 			GUI::show_error(nullptr, GUI::from_u8(message)); | ||||||
|  | 			continue; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		if (ver_current_found && !ver_current->is_current_slic3r_supported()) { | 		if (ver_current_found && !ver_current->is_current_slic3r_supported()) { | ||||||
| 			BOOST_LOG_TRIVIAL(warning) << "Current Slic3r incompatible with installed bundle: " << bundle_path.string(); | 			BOOST_LOG_TRIVIAL(warning) << "Current Slic3r incompatible with installed bundle: " << bundle_path.string(); | ||||||
| 			updates.incompats.emplace_back(std::move(bundle_path), *ver_current, vp.name); | 			updates.incompats.emplace_back(std::move(bundle_path), *ver_current, vp.name); | ||||||
|  | @ -459,12 +459,18 @@ Updates PresetUpdater::priv::get_config_updates() const | ||||||
| 					found = true; | 					found = true; | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 			if (! found) | 
 | ||||||
|  | 			if (found) { | ||||||
|  | 				// 'Install' the index in the vendor directory. This is used to memoize
 | ||||||
|  | 				// offered updates and to not offer the same update again if it was cancelled by the user.
 | ||||||
|  | 				copy_file_fix(idx.path(), bundle_path_idx); | ||||||
|  | 			} else { | ||||||
| 				BOOST_LOG_TRIVIAL(warning) << boost::format("Index for vendor %1% indicates update (%2%) but the new bundle was found neither in cache nor resources") | 				BOOST_LOG_TRIVIAL(warning) << boost::format("Index for vendor %1% indicates update (%2%) but the new bundle was found neither in cache nor resources") | ||||||
| 					% idx.vendor() | 					% idx.vendor() | ||||||
| 					% recommended->config_version.to_string(); | 					% recommended->config_version.to_string(); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	return updates; | 	return updates; | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Vojtech Kral
						Vojtech Kral