mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 17:51:10 -06:00 
			
		
		
		
	Fix duplicated error message dialog from GUI jobs.
This commit is contained in:
		
							parent
							
								
									9aac1b6fa5
								
							
						
					
					
						commit
						3135e47180
					
				
					 3 changed files with 28 additions and 7 deletions
				
			
		|  | @ -24,7 +24,7 @@ void GUI::Job::run(std::exception_ptr &eptr) | |||
| 
 | ||||
| void GUI::Job::update_status(int st, const wxString &msg) | ||||
| { | ||||
|     auto evt = new wxThreadEvent(); | ||||
|     auto evt = new wxThreadEvent(wxEVT_THREAD, m_thread_evt_id); | ||||
|     evt->SetInt(st); | ||||
|     evt->SetString(msg); | ||||
|     wxQueueEvent(this, evt); | ||||
|  | @ -33,7 +33,11 @@ void GUI::Job::update_status(int st, const wxString &msg) | |||
| GUI::Job::Job(std::shared_ptr<ProgressIndicator> pri) | ||||
|     : m_progress(std::move(pri)) | ||||
| { | ||||
|     Bind(wxEVT_THREAD, [this](const wxThreadEvent &evt) {             | ||||
|     m_thread_evt_id = wxNewId(); | ||||
| 
 | ||||
|     Bind(wxEVT_THREAD, [this](const wxThreadEvent &evt) { | ||||
|         if (m_finalizing)  return; | ||||
| 
 | ||||
|         auto msg = evt.GetString(); | ||||
|         if (!msg.empty() && !m_worker_error) | ||||
|             m_progress->set_status_text(msg.ToUTF8().data()); | ||||
|  | @ -53,13 +57,27 @@ GUI::Job::Job(std::shared_ptr<ProgressIndicator> pri) | |||
|                 m_progress->set_progress(m_range); | ||||
|                 on_exception(m_worker_error); | ||||
|             } | ||||
|             else | ||||
|             else { | ||||
|                 // This is an RAII solution to remember that finalization is
 | ||||
|                 // running. The run method calls update_status(status_range(), "")
 | ||||
|                 // at the end, which queues up a call to this handler in all cases.
 | ||||
|                 // If process also calls update_status with maxed out status arg
 | ||||
|                 // it will call this handler twice. It is not a problem unless
 | ||||
|                 // yield is called inside the finilize() method, which would
 | ||||
|                 // jump out of finalize and call this handler again.
 | ||||
|                 struct Finalizing { | ||||
|                     bool &flag; | ||||
|                     Finalizing (bool &f): flag(f) { flag = true; } | ||||
|                     ~Finalizing() { flag = false; } | ||||
|                 } fin(m_finalizing); | ||||
| 
 | ||||
|                 finalize(); | ||||
|             } | ||||
| 
 | ||||
|             // dont do finalization again for the same process
 | ||||
|             m_finalized = true; | ||||
|         } | ||||
|     }); | ||||
|     }, m_thread_evt_id); | ||||
| } | ||||
| 
 | ||||
| void GUI::Job::start() | ||||
|  | @ -76,7 +94,8 @@ void GUI::Job::start() | |||
|         m_progress->set_cancel_callback( | ||||
|                     [this]() { m_canceled.store(true); }); | ||||
|          | ||||
|         m_finalized = false; | ||||
|         m_finalized  = false; | ||||
|         m_finalizing = false; | ||||
|          | ||||
|         // Changing cursor to busy
 | ||||
|         wxBeginBusyCursor(); | ||||
|  |  | |||
|  | @ -29,9 +29,10 @@ namespace Slic3r { namespace GUI { | |||
| class Job : public wxEvtHandler | ||||
| { | ||||
|     int               m_range = 100; | ||||
|     int               m_thread_evt_id = wxID_ANY; | ||||
|     boost::thread     m_thread; | ||||
|     std::atomic<bool> m_running{false}, m_canceled{false}; | ||||
|     bool              m_finalized = false; | ||||
|     bool              m_finalized = false, m_finalizing = false; | ||||
|     std::shared_ptr<ProgressIndicator> m_progress; | ||||
|     std::exception_ptr                 m_worker_error = nullptr; | ||||
|      | ||||
|  |  | |||
|  | @ -132,7 +132,8 @@ SLAImportJob::~SLAImportJob() = default; | |||
| void SLAImportJob::process() | ||||
| { | ||||
|     auto progr = [this](int s) { | ||||
|         if (s < 100) update_status(int(s), _(L("Importing SLA archive"))); | ||||
|         if (s < 100) | ||||
|             update_status(int(s), _(L("Importing SLA archive"))); | ||||
|         return !was_canceled(); | ||||
|     }; | ||||
|      | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 tamasmeszaros
						tamasmeszaros