mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 09:11:23 -06:00 
			
		
		
		
	Slic3r::format(), Slic3r::GUI::format_wxstr():
wrappers around boost::format using C++17 variadic templates,
replacing the ugly and verbose
	(boost::format("template") % arg1 % arg2).str()
syntax.
The wrappers also implictely convert input parameters including the template
from wxString to UTF8.
The new format wrapper has been applied at multiple places as a start,
also some double macros _(L()) with new single macro _L().
			
			
This commit is contained in:
		
							parent
							
								
									daa6dd0a25
								
							
						
					
					
						commit
						b843a094f6
					
				
					 10 changed files with 364 additions and 240 deletions
				
			
		|  | @ -17,6 +17,7 @@ | |||
| #include <wx/msgdlg.h> | ||||
| 
 | ||||
| #include "libslic3r/libslic3r.h" | ||||
| #include "libslic3r/format.hpp" | ||||
| #include "libslic3r/Utils.hpp" | ||||
| #include "slic3r/GUI/GUI.hpp" | ||||
| #include "slic3r/GUI/I18N.hpp" | ||||
|  | @ -54,7 +55,7 @@ void copy_file_fix(const fs::path &source, const fs::path &target) | |||
| { | ||||
| 	static const auto perms = fs::owner_read | fs::owner_write | fs::group_read | fs::others_read;   // aka 644
 | ||||
| 
 | ||||
| 	BOOST_LOG_TRIVIAL(debug) << boost::format("PresetUpdater: Copying %1% -> %2%") % source % target; | ||||
| 	BOOST_LOG_TRIVIAL(debug) << format("PresetUpdater: Copying %1% -> %2%", source, target); | ||||
| 
 | ||||
| 	// Make sure the file has correct permission both before and after we copy over it
 | ||||
| 	if (fs::exists(target)) { | ||||
|  | @ -190,12 +191,12 @@ bool PresetUpdater::priv::get_file(const std::string &url, const fs::path &targe | |||
| { | ||||
| 	bool res = false; | ||||
| 	fs::path tmp_path = target_path; | ||||
| 	tmp_path += (boost::format(".%1%%2%") % get_current_pid() % TMP_EXTENSION).str(); | ||||
| 	tmp_path += format(".%1%%2%", get_current_pid(), TMP_EXTENSION); | ||||
| 
 | ||||
| 	BOOST_LOG_TRIVIAL(info) << boost::format("Get: `%1%`\n\t-> `%2%`\n\tvia tmp path `%3%`") | ||||
| 		% url | ||||
| 		% target_path.string() | ||||
| 		% tmp_path.string(); | ||||
| 	BOOST_LOG_TRIVIAL(info) << format("Get: `%1%`\n\t-> `%2%`\n\tvia tmp path `%3%`", | ||||
| 		url, | ||||
| 		target_path.string(), | ||||
| 		tmp_path.string()); | ||||
| 
 | ||||
| 	Http::get(url) | ||||
| 		.on_progress([this](Http::Progress, bool &cancel) { | ||||
|  | @ -203,10 +204,10 @@ bool PresetUpdater::priv::get_file(const std::string &url, const fs::path &targe | |||
| 		}) | ||||
| 		.on_error([&](std::string body, std::string error, unsigned http_status) { | ||||
| 			(void)body; | ||||
| 			BOOST_LOG_TRIVIAL(error) << boost::format("Error getting: `%1%`: HTTP %2%, %3%") | ||||
| 				% url | ||||
| 				% http_status | ||||
| 				% error; | ||||
| 			BOOST_LOG_TRIVIAL(error) << format("Error getting: `%1%`: HTTP %2%, %3%", | ||||
| 				url, | ||||
| 				http_status, | ||||
| 				error); | ||||
| 		}) | ||||
| 		.on_complete([&](std::string body, unsigned /* http_status */) { | ||||
| 			fs::fstream file(tmp_path, std::ios::out | std::ios::binary | std::ios::trunc); | ||||
|  | @ -235,7 +236,7 @@ void PresetUpdater::priv::sync_version() const | |||
| { | ||||
| 	if (! enabled_version_check) { return; } | ||||
| 
 | ||||
| 	BOOST_LOG_TRIVIAL(info) << boost::format("Downloading %1% online version from: `%2%`") % SLIC3R_APP_NAME % version_check_url; | ||||
| 	BOOST_LOG_TRIVIAL(info) << format("Downloading %1% online version from: `%2%`", SLIC3R_APP_NAME, version_check_url); | ||||
| 
 | ||||
| 	Http::get(version_check_url) | ||||
| 		.size_limit(SLIC3R_VERSION_BODY_MAX) | ||||
|  | @ -244,10 +245,10 @@ void PresetUpdater::priv::sync_version() const | |||
| 		}) | ||||
| 		.on_error([&](std::string body, std::string error, unsigned http_status) { | ||||
| 			(void)body; | ||||
| 			BOOST_LOG_TRIVIAL(error) << boost::format("Error getting: `%1%`: HTTP %2%, %3%") | ||||
| 				% version_check_url | ||||
| 				% http_status | ||||
| 				% error; | ||||
| 			BOOST_LOG_TRIVIAL(error) << format("Error getting: `%1%`: HTTP %2%, %3%", | ||||
| 				version_check_url, | ||||
| 				http_status, | ||||
| 				error); | ||||
| 		}) | ||||
| 		.on_complete([&](std::string body, unsigned /* http_status */) { | ||||
| 			boost::trim(body); | ||||
|  | @ -257,11 +258,11 @@ void PresetUpdater::priv::sync_version() const | |||
| 			} | ||||
| 
 | ||||
| 			if (! Semver::parse(body)) { | ||||
| 				BOOST_LOG_TRIVIAL(warning) << boost::format("Received invalid contents from `%1%`: Not a correct semver: `%2%`") % SLIC3R_APP_NAME % body; | ||||
| 				BOOST_LOG_TRIVIAL(warning) << format("Received invalid contents from `%1%`: Not a correct semver: `%2%`", SLIC3R_APP_NAME, body); | ||||
| 				return; | ||||
| 			} | ||||
| 
 | ||||
| 			BOOST_LOG_TRIVIAL(info) << boost::format("Got %1% online version: `%2%`. Sending to GUI thread...") % SLIC3R_APP_NAME % body; | ||||
| 			BOOST_LOG_TRIVIAL(info) << format("Got %1% online version: `%2%`. Sending to GUI thread...", SLIC3R_APP_NAME, body); | ||||
| 
 | ||||
| 			wxCommandEvent* evt = new wxCommandEvent(EVT_SLIC3R_VERSION_ONLINE); | ||||
| 			evt->SetString(GUI::from_u8(body)); | ||||
|  | @ -315,11 +316,11 @@ void PresetUpdater::priv::sync_config(const VendorMap vendors) | |||
| 			try { | ||||
| 				new_index.load(idx_path_temp); | ||||
| 			} catch (const std::exception & /* err */) { | ||||
| 				BOOST_LOG_TRIVIAL(error) << boost::format("Could not load downloaded index %1% for vendor %2%: invalid index?") % idx_path_temp % vendor.name; | ||||
| 				BOOST_LOG_TRIVIAL(error) << format("Could not load downloaded index %1% for vendor %2%: invalid index?", idx_path_temp, vendor.name); | ||||
| 				continue; | ||||
| 			} | ||||
| 			if (new_index.version() < index.version()) { | ||||
| 				BOOST_LOG_TRIVIAL(warning) << boost::format("The downloaded index %1% for vendor %2% is older than the active one. Ignoring the downloaded index.") % idx_path_temp % vendor.name; | ||||
| 				BOOST_LOG_TRIVIAL(warning) << format("The downloaded index %1% for vendor %2% is older than the active one. Ignoring the downloaded index.", idx_path_temp, vendor.name); | ||||
| 				continue; | ||||
| 			} | ||||
| 			Slic3r::rename_file(idx_path_temp, idx_path); | ||||
|  | @ -331,22 +332,22 @@ void PresetUpdater::priv::sync_config(const VendorMap vendors) | |||
| 		// See if a there's a new version to download
 | ||||
| 		const auto recommended_it = index.recommended(); | ||||
| 		if (recommended_it == index.end()) { | ||||
| 			BOOST_LOG_TRIVIAL(error) << boost::format("No recommended version for vendor: %1%, invalid index?") % vendor.name; | ||||
| 			BOOST_LOG_TRIVIAL(error) << format("No recommended version for vendor: %1%, invalid index?", vendor.name); | ||||
| 			continue; | ||||
| 		} | ||||
| 
 | ||||
| 		const auto recommended = recommended_it->config_version; | ||||
| 
 | ||||
| 		BOOST_LOG_TRIVIAL(debug) << boost::format("Got index for vendor: %1%: current version: %2%, recommended version: %3%") | ||||
| 			% vendor.name | ||||
| 			% vendor.config_version.to_string() | ||||
| 			% recommended.to_string(); | ||||
| 		BOOST_LOG_TRIVIAL(debug) << format("Got index for vendor: %1%: current version: %2%, recommended version: %3%", | ||||
| 			vendor.name, | ||||
| 			vendor.config_version.to_string(), | ||||
| 			recommended.to_string()); | ||||
| 
 | ||||
| 		if (vendor.config_version >= recommended) { continue; } | ||||
| 
 | ||||
| 		// Download a fresh bundle
 | ||||
| 		BOOST_LOG_TRIVIAL(info) << "Downloading new bundle for vendor: " << vendor.name; | ||||
| 		const auto bundle_url = (boost::format("%1%/%2%.ini") % vendor.config_update_url % recommended.to_string()).str(); | ||||
| 		const auto bundle_url = format("%1%/%2%.ini", vendor.config_update_url, recommended.to_string()); | ||||
| 		const auto bundle_path = cache_path / (vendor.id + ".ini"); | ||||
| 		if (! get_file(bundle_url, bundle_path)) { continue; } | ||||
| 		if (cancel) { return; } | ||||
|  | @ -394,7 +395,7 @@ Updates PresetUpdater::priv::get_config_updates(const Semver &old_slic3r_version | |||
| 		auto bundle_path_idx = vendor_path / idx.path().filename(); | ||||
| 
 | ||||
| 		if (! fs::exists(bundle_path)) { | ||||
| 			BOOST_LOG_TRIVIAL(info) << boost::format("Confing bundle not installed for vendor %1%, skipping: ") % idx.vendor(); | ||||
| 			BOOST_LOG_TRIVIAL(info) << format("Confing bundle not installed for vendor %1%, skipping: ", idx.vendor()); | ||||
| 			continue; | ||||
| 		} | ||||
| 
 | ||||
|  | @ -405,7 +406,7 @@ Updates PresetUpdater::priv::get_config_updates(const Semver &old_slic3r_version | |||
| 		// from the internet, or installed / updated from the installation resources.
 | ||||
| 		auto recommended = idx.recommended(); | ||||
| 		if (recommended == idx.end()) { | ||||
| 			BOOST_LOG_TRIVIAL(error) << boost::format("No recommended version for vendor: %1%, invalid index? Giving up.") % idx.vendor(); | ||||
| 			BOOST_LOG_TRIVIAL(error) << format("No recommended version for vendor: %1%, invalid index? Giving up.", idx.vendor()); | ||||
| 			// XXX: what should be done here?
 | ||||
| 			continue; | ||||
| 		} | ||||
|  | @ -413,15 +414,15 @@ Updates PresetUpdater::priv::get_config_updates(const Semver &old_slic3r_version | |||
| 		const auto ver_current = idx.find(vp.config_version); | ||||
| 		const bool ver_current_found = ver_current != idx.end(); | ||||
| 
 | ||||
| 		BOOST_LOG_TRIVIAL(debug) << boost::format("Vendor: %1%, version installed: %2%%3%, version cached: %4%") | ||||
| 			% vp.name | ||||
| 			% vp.config_version.to_string() | ||||
| 			% (ver_current_found ? "" : " (not found in index!)") | ||||
| 			% recommended->config_version.to_string(); | ||||
| 		BOOST_LOG_TRIVIAL(debug) << format("Vendor: %1%, version installed: %2%%3%, version cached: %4%", | ||||
| 			vp.name, | ||||
| 			vp.config_version.to_string(), | ||||
| 			(ver_current_found ? "" : " (not found in index!)"), | ||||
| 			recommended->config_version.to_string()); | ||||
| 
 | ||||
| 		if (! ver_current_found) { | ||||
| 			// Any published config shall be always found in the latest config index.
 | ||||
| 			auto message = (boost::format("Preset bundle `%1%` version not found in index: %2%") % idx.vendor() % vp.config_version.to_string()).str(); | ||||
| 			auto message = format("Preset bundle `%1%` version not found in index: %2%", idx.vendor(), vp.config_version.to_string()); | ||||
| 			BOOST_LOG_TRIVIAL(error) << message; | ||||
| 			GUI::show_error(nullptr, message); | ||||
| 			continue; | ||||
|  | @ -440,7 +441,7 @@ Updates PresetUpdater::priv::get_config_updates(const Semver &old_slic3r_version | |||
| 		} | ||||
| 
 | ||||
| 		if (recommended->config_version < vp.config_version) { | ||||
| 			BOOST_LOG_TRIVIAL(warning) << (boost::format("Recommended config version for the currently running PrusaSlicer is older than the currently installed config for vendor %1%. This should not happen.") % idx.vendor()).str(); | ||||
| 			BOOST_LOG_TRIVIAL(warning) << format("Recommended config version for the currently running PrusaSlicer is older than the currently installed config for vendor %1%. This should not happen.", idx.vendor()); | ||||
| 			continue; | ||||
| 		} | ||||
| 
 | ||||
|  | @ -482,7 +483,7 @@ Updates PresetUpdater::priv::get_config_updates(const Semver &old_slic3r_version | |||
| 					found = true; | ||||
| 				} | ||||
| 			} catch (const std::exception &ex) { | ||||
| 				BOOST_LOG_TRIVIAL(info) << boost::format("Failed to load the config bundle `%1%`: %2%") % path_in_cache.string() % ex.what(); | ||||
| 				BOOST_LOG_TRIVIAL(info) << format("Failed to load the config bundle `%1%`: %2%", path_in_cache.string(), ex.what()); | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
|  | @ -496,13 +497,13 @@ Updates PresetUpdater::priv::get_config_updates(const Semver &old_slic3r_version | |||
| 			try { | ||||
| 				rsrc_vp = VendorProfile::from_ini(path_in_rsrc, false); | ||||
| 			} catch (const std::exception &ex) { | ||||
| 				BOOST_LOG_TRIVIAL(info) << boost::format("Cannot load the config bundle at `%1%`: %2%") % path_in_rsrc.string() % ex.what(); | ||||
| 				BOOST_LOG_TRIVIAL(info) << format("Cannot load the config bundle at `%1%`: %2%", path_in_rsrc.string(), ex.what()); | ||||
| 			} | ||||
| 			if (rsrc_vp.valid()) { | ||||
| 				try { | ||||
| 					rsrc_idx.load(path_idx_in_rsrc); | ||||
| 				} catch (const std::exception &ex) { | ||||
| 					BOOST_LOG_TRIVIAL(info) << boost::format("Cannot load the config index at `%1%`: %2%") % path_idx_in_rsrc.string() % ex.what(); | ||||
| 					BOOST_LOG_TRIVIAL(info) << format("Cannot load the config index at `%1%`: %2%", path_idx_in_rsrc.string(), ex.what()); | ||||
| 				} | ||||
| 				recommended = rsrc_idx.recommended(); | ||||
| 				if (recommended != rsrc_idx.end() && recommended->config_version == rsrc_vp.config_version && recommended->config_version > vp.config_version) { | ||||
|  | @ -510,8 +511,8 @@ Updates PresetUpdater::priv::get_config_updates(const Semver &old_slic3r_version | |||
| 					bundle_path_idx_to_install = path_idx_in_rsrc; | ||||
| 					found = true; | ||||
| 				} else { | ||||
| 					BOOST_LOG_TRIVIAL(warning) << (boost::format("The recommended config version for vendor `%1%` in resources does not match the recommended\n" | ||||
| 					                                             " config version for this version of PrusaSlicer. Corrupted installation?") % idx.vendor()).str(); | ||||
| 					BOOST_LOG_TRIVIAL(warning) << format("The recommended config version for vendor `%1%` in resources does not match the recommended\n" | ||||
| 			                                             " config version for this version of PrusaSlicer. Corrupted installation?", idx.vendor()); | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|  | @ -529,11 +530,11 @@ Updates PresetUpdater::priv::get_config_updates(const Semver &old_slic3r_version | |||
|                     /*const auto existing_recommended = existing_idx.recommended(old_slic3r_version);
 | ||||
|                     if (existing_recommended != existing_idx.end() && recommended->config_version == existing_recommended->config_version) { | ||||
| 						// The user has already seen (and presumably rejected) this update
 | ||||
| 						BOOST_LOG_TRIVIAL(info) << boost::format("Downloaded index for `%1%` is the same as installed one, not offering an update.") % idx.vendor(); | ||||
| 						BOOST_LOG_TRIVIAL(info) << format("Downloaded index for `%1%` is the same as installed one, not offering an update.",idx.vendor()); | ||||
| 						continue; | ||||
| 					}*/ | ||||
| 				} catch (const std::exception &err) { | ||||
| 					BOOST_LOG_TRIVIAL(error) << boost::format("Cannot load the installed index at `%1%`: %2%") % bundle_path_idx % err.what(); | ||||
| 					BOOST_LOG_TRIVIAL(error) << format("Cannot load the installed index at `%1%`: %2%", bundle_path_idx, err.what()); | ||||
| 				} | ||||
| 			} | ||||
| 
 | ||||
|  | @ -542,10 +543,10 @@ Updates PresetUpdater::priv::get_config_updates(const Semver &old_slic3r_version | |||
| 			{ | ||||
| 				const auto recommended_snap = SnapshotDB::singleton().snapshot_with_vendor_preset(vp.name, recommended->config_version); | ||||
| 				if (recommended_snap != SnapshotDB::singleton().end()) { | ||||
| 					BOOST_LOG_TRIVIAL(info) << boost::format("Bundle update %1% %2% already found in snapshot %3%, skipping...") | ||||
| 						% vp.name | ||||
| 						% recommended->config_version.to_string() | ||||
| 						% recommended_snap->id; | ||||
| 					BOOST_LOG_TRIVIAL(info) << format("Bundle update %1% %2% already found in snapshot %3%, skipping...", | ||||
| 						vp.name, | ||||
| 						recommended->config_version.to_string(), | ||||
| 						recommended_snap->id); | ||||
| 					continue; | ||||
| 				} | ||||
| 			} | ||||
|  | @ -555,9 +556,9 @@ Updates PresetUpdater::priv::get_config_updates(const Semver &old_slic3r_version | |||
| 			// offered updates and to not offer the same update again if it was cancelled by the user.
 | ||||
| 			copy_file_fix(bundle_path_idx_to_install, 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") | ||||
| 				% idx.vendor() | ||||
| 				% recommended->config_version.to_string(); | ||||
| 			BOOST_LOG_TRIVIAL(warning) << format("Index for vendor %1% indicates update (%2%) but the new bundle was found neither in cache nor resources", | ||||
| 				idx.vendor(), | ||||
| 				recommended->config_version.to_string()); | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
|  | @ -572,7 +573,7 @@ void PresetUpdater::priv::perform_updates(Updates &&updates, bool snapshot) cons | |||
| 			SnapshotDB::singleton().take_snapshot(*GUI::wxGetApp().app_config, Snapshot::SNAPSHOT_DOWNGRADE); | ||||
| 		} | ||||
| 		 | ||||
| 		BOOST_LOG_TRIVIAL(info) << boost::format("Deleting %1% incompatible bundles") % updates.incompats.size(); | ||||
| 		BOOST_LOG_TRIVIAL(info) << format("Deleting %1% incompatible bundles", updates.incompats.size()); | ||||
| 
 | ||||
| 		for (auto &incompat : updates.incompats) { | ||||
| 			BOOST_LOG_TRIVIAL(info) << '\t' << incompat; | ||||
|  | @ -587,7 +588,7 @@ void PresetUpdater::priv::perform_updates(Updates &&updates, bool snapshot) cons | |||
| 			SnapshotDB::singleton().take_snapshot(*GUI::wxGetApp().app_config, Snapshot::SNAPSHOT_UPGRADE); | ||||
| 		} | ||||
| 
 | ||||
| 		BOOST_LOG_TRIVIAL(info) << boost::format("Performing %1% updates") % updates.updates.size(); | ||||
| 		BOOST_LOG_TRIVIAL(info) << format("Performing %1% updates", updates.updates.size()); | ||||
| 
 | ||||
| 		for (const auto &update : updates.updates) { | ||||
| 			BOOST_LOG_TRIVIAL(info) << '\t' << update; | ||||
|  | @ -597,8 +598,7 @@ void PresetUpdater::priv::perform_updates(Updates &&updates, bool snapshot) cons | |||
| 			PresetBundle bundle; | ||||
| 			bundle.load_configbundle(update.source.string(), PresetBundle::LOAD_CFGBNDLE_SYSTEM); | ||||
| 
 | ||||
| 			BOOST_LOG_TRIVIAL(info) << boost::format("Deleting %1% conflicting presets") | ||||
| 				% (bundle.prints.size() + bundle.filaments.size() + bundle.printers.size()); | ||||
| 			BOOST_LOG_TRIVIAL(info) << format("Deleting %1% conflicting presets", bundle.prints.size() + bundle.filaments.size() + bundle.printers.size()); | ||||
| 
 | ||||
| 			auto preset_remover = [](const Preset &preset) { | ||||
| 				BOOST_LOG_TRIVIAL(info) << '\t' << preset.file; | ||||
|  | @ -611,8 +611,8 @@ void PresetUpdater::priv::perform_updates(Updates &&updates, bool snapshot) cons | |||
| 
 | ||||
| 			// Also apply the `obsolete_presets` property, removing obsolete ini files
 | ||||
| 
 | ||||
| 			BOOST_LOG_TRIVIAL(info) << boost::format("Deleting %1% obsolete presets") | ||||
| 				% (bundle.obsolete_presets.prints.size() + bundle.obsolete_presets.filaments.size() + bundle.obsolete_presets.printers.size()); | ||||
| 			BOOST_LOG_TRIVIAL(info) << format("Deleting %1% obsolete presets", | ||||
| 				bundle.obsolete_presets.prints.size() + bundle.obsolete_presets.filaments.size() + bundle.obsolete_presets.printers.size()); | ||||
| 
 | ||||
| 			auto obsolete_remover = [](const char *subdir, const std::string &preset) { | ||||
| 				auto path = fs::path(Slic3r::data_dir()) / subdir / preset; | ||||
|  | @ -694,7 +694,7 @@ PresetUpdater::UpdateResult PresetUpdater::config_update(const Semver &old_slic3 | |||
| 
 | ||||
| 	auto updates = p->get_config_updates(old_slic3r_version); | ||||
| 	if (updates.incompats.size() > 0) { | ||||
| 		BOOST_LOG_TRIVIAL(info) << boost::format("%1% bundles incompatible. Asking for action...") % updates.incompats.size(); | ||||
| 		BOOST_LOG_TRIVIAL(info) << format("%1% bundles incompatible. Asking for action...", updates.incompats.size()); | ||||
| 
 | ||||
| 		std::unordered_map<std::string, wxString> incompats_map; | ||||
| 		for (const auto &incompat : updates.incompats) { | ||||
|  | @ -702,15 +702,14 @@ PresetUpdater::UpdateResult PresetUpdater::config_update(const Semver &old_slic3 | |||
| 			const auto max_slic3r = incompat.version.max_slic3r_version; | ||||
| 			wxString restrictions; | ||||
| 			if (min_slic3r != Semver::zero() && max_slic3r != Semver::inf()) { | ||||
|                 restrictions = GUI::from_u8((boost::format(_utf8(L("requires min. %s and max. %s"))) | ||||
|                     % min_slic3r.to_string() | ||||
|                     % max_slic3r.to_string()).str() | ||||
| 				); | ||||
|                 restrictions = GUI::format_wxstr(_L("requires min. %s and max. %s"), | ||||
|                     min_slic3r.to_string(), | ||||
|                     max_slic3r.to_string()); | ||||
| 			} else if (min_slic3r != Semver::zero()) { | ||||
|                 restrictions = GUI::from_u8((boost::format(_utf8(L("requires min. %s"))) % min_slic3r.to_string()).str()); | ||||
| 				restrictions = GUI::format_wxstr(_L("requires min. %s"), min_slic3r.to_string()); | ||||
| 				BOOST_LOG_TRIVIAL(debug) << "Bundle is not downgrade, user will now have to do whole wizard. This should not happen."; | ||||
| 			} else { | ||||
|                 restrictions = GUI::from_u8((boost::format(_utf8(L("requires max. %s"))) % max_slic3r.to_string()).str()); | ||||
|                 restrictions = GUI::format_wxstr(_L("requires max. %s"), max_slic3r.to_string()); | ||||
| 			} | ||||
| 
 | ||||
| 			incompats_map.emplace(std::make_pair(incompat.vendor, std::move(restrictions))); | ||||
|  | @ -742,13 +741,13 @@ PresetUpdater::UpdateResult PresetUpdater::config_update(const Semver &old_slic3 | |||
| 		for (const auto& update : updates.updates) { | ||||
| 			incompatible_version = (update.forced_update ? true : incompatible_version); | ||||
| 			//td::cout << update.forced_update << std::endl;
 | ||||
| 			//BOOST_LOG_TRIVIAL(info) << boost::format("Update requires higher version.");
 | ||||
| 			//BOOST_LOG_TRIVIAL(info) << format("Update requires higher version.");
 | ||||
| 		} | ||||
| 
 | ||||
| 		//forced update
 | ||||
| 		if(incompatible_version) | ||||
| 		{ | ||||
| 			BOOST_LOG_TRIVIAL(info) << boost::format("Update of %1% bundles available. At least one requires higher version of Slicer.") % updates.updates.size(); | ||||
| 			BOOST_LOG_TRIVIAL(info) << format("Update of %1% bundles available. At least one requires higher version of Slicer.", updates.updates.size()); | ||||
| 
 | ||||
| 			std::vector<GUI::MsgUpdateForced::Update> updates_msg; | ||||
| 			for (const auto& update : updates.updates) { | ||||
|  | @ -778,7 +777,7 @@ PresetUpdater::UpdateResult PresetUpdater::config_update(const Semver &old_slic3 | |||
| 		} | ||||
| 
 | ||||
| 		// regular update
 | ||||
| 		BOOST_LOG_TRIVIAL(info) << boost::format("Update of %1% bundles available. Asking for confirmation ...") % updates.updates.size(); | ||||
| 		BOOST_LOG_TRIVIAL(info) << format("Update of %1% bundles available. Asking for confirmation ...", updates.updates.size()); | ||||
| 
 | ||||
| 		std::vector<GUI::MsgUpdateConfig::Update> updates_msg; | ||||
| 		for (const auto &update : updates.updates) { | ||||
|  | @ -813,7 +812,7 @@ void PresetUpdater::install_bundles_rsrc(std::vector<std::string> bundles, bool | |||
| { | ||||
| 	Updates updates; | ||||
| 
 | ||||
| 	BOOST_LOG_TRIVIAL(info) << boost::format("Installing %1% bundles from resources ...") % bundles.size(); | ||||
| 	BOOST_LOG_TRIVIAL(info) << format("Installing %1% bundles from resources ...", bundles.size()); | ||||
| 
 | ||||
| 	for (const auto &bundle : bundles) { | ||||
| 		auto path_in_rsrc = (p->rsrc_path / bundle).replace_extension(".ini"); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv