mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Firmware updater: Make the GUI less scary
This commit is contained in:
		
							parent
							
								
									c5f1acfbfb
								
							
						
					
					
						commit
						a54672fb54
					
				
					 5 changed files with 211 additions and 68 deletions
				
			
		|  | @ -8,37 +8,67 @@ extern "C" { | |||
| 
 | ||||
| namespace Slic3r { | ||||
| 
 | ||||
| namespace AvrDude { | ||||
| 
 | ||||
| 
 | ||||
| // Used by our custom code in avrdude to receive messages that avrdude normally outputs on stdout (see avrdude_message())
 | ||||
| static void avrdude_message_handler_closure(const char *msg, unsigned size, void *user_p) | ||||
| { | ||||
| 	auto *message_fn = reinterpret_cast<MessageFn*>(user_p); | ||||
| 	auto *message_fn = reinterpret_cast<AvrDude::MessageFn*>(user_p); | ||||
| 	(*message_fn)(msg, size); | ||||
| } | ||||
| 
 | ||||
| int main(std::vector<std::string> args, std::string sys_config, MessageFn message_fn) | ||||
| // Used by our custom code in avrdude to report progress in the GUI
 | ||||
| static void avrdude_progress_handler_closure(const char *task, unsigned progress, void *user_p) | ||||
| { | ||||
| 	auto *progress_fn = reinterpret_cast<AvrDude::ProgressFn*>(user_p); | ||||
| 	(*progress_fn)(task, progress); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| AvrDude::AvrDude() {} | ||||
| AvrDude::~AvrDude() {} | ||||
| 
 | ||||
| AvrDude& AvrDude::sys_config(std::string sys_config) | ||||
| { | ||||
| 	m_sys_config = std::move(sys_config); | ||||
| 	return *this; | ||||
| } | ||||
| 
 | ||||
| AvrDude& AvrDude::on_message(MessageFn fn) | ||||
| { | ||||
| 	m_message_fn = std::move(fn); | ||||
| 	return *this; | ||||
| } | ||||
| 
 | ||||
| AvrDude& AvrDude::on_progress(MessageFn fn) | ||||
| { | ||||
| 	m_progress_fn = std::move(fn); | ||||
| 	return *this; | ||||
| } | ||||
| 
 | ||||
| int AvrDude::run(std::vector<std::string> args) | ||||
| { | ||||
| 	std::vector<char *> c_args {{ const_cast<char*>(PACKAGE_NAME) }}; | ||||
| 	for (const auto &arg : args) { | ||||
| 		c_args.push_back(const_cast<char*>(arg.data())); | ||||
| 	} | ||||
| 
 | ||||
| 	::avrdude_message_handler_set(avrdude_message_handler_closure, reinterpret_cast<void*>(&message_fn)); | ||||
| 	const auto res = ::avrdude_main(static_cast<int>(c_args.size()), c_args.data(), sys_config.c_str()); | ||||
| 	if (m_message_fn) { | ||||
| 		::avrdude_message_handler_set(avrdude_message_handler_closure, reinterpret_cast<void*>(&m_message_fn)); | ||||
| 	} else { | ||||
| 		::avrdude_message_handler_set(nullptr, nullptr); | ||||
| 	} | ||||
| 	 | ||||
| 	if (m_progress_fn) { | ||||
| 		::avrdude_progress_handler_set(avrdude_progress_handler_closure, reinterpret_cast<void*>(&m_progress_fn)); | ||||
| 	} else { | ||||
| 		::avrdude_progress_handler_set(nullptr, nullptr); | ||||
| 	} | ||||
| 	 | ||||
| 	const auto res = ::avrdude_main(static_cast<int>(c_args.size()), c_args.data(), m_sys_config.c_str()); | ||||
| 	 | ||||
| 	::avrdude_message_handler_set(nullptr, nullptr); | ||||
| 	::avrdude_progress_handler_set(nullptr, nullptr); | ||||
| 	return res; | ||||
| } | ||||
| 
 | ||||
| int main(std::vector<std::string> args, std::string sys_config, std::ostream &os) | ||||
| { | ||||
| 	return main(std::move(args), std::move(sys_config), std::move([&os](const char *msg, unsigned /* size */) { | ||||
| 		os << msg; | ||||
| 	})); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Vojtech Kral
						Vojtech Kral