mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	The issue is that opening the wxMessageDialog in GUI_App::check_printer_presets fires wxEVT_IDLE event (on Linux at least). At that point it is already bound to our lambda which will in turn call post_init prematurely. The solution is to move the Bind at the very end of the initialization. The post_init that it calls assumes that init has been finished anyway.
This commit is contained in:
		
							parent
							
								
									181642b85b
								
							
						
					
					
						commit
						1f5ac7d2f7
					
				
					 1 changed files with 25 additions and 26 deletions
				
			
		|  | @ -886,6 +886,23 @@ bool GUI_App::on_init_inner() | |||
| 
 | ||||
|     m_printhost_job_queue.reset(new PrintHostJobQueue(mainframe->printhost_queue_dlg())); | ||||
| 
 | ||||
|     if (is_gcode_viewer()) { | ||||
|         mainframe->update_layout(); | ||||
|         if (plater_ != nullptr) | ||||
|             // ensure the selected technology is ptFFF
 | ||||
|             plater_->set_printer_technology(ptFFF); | ||||
|     } | ||||
|     else | ||||
|         load_current_presets(); | ||||
|     mainframe->Show(true); | ||||
| 
 | ||||
|     obj_list()->set_min_height(); | ||||
| 
 | ||||
|     update_mode(); // update view mode after fix of the object_list size
 | ||||
| 
 | ||||
| #ifdef __APPLE__ | ||||
|     other_instance_message_handler()->bring_instance_forward(); | ||||
| #endif //__APPLE__
 | ||||
| 
 | ||||
|     Bind(wxEVT_IDLE, [this](wxIdleEvent& event) | ||||
|     { | ||||
|  | @ -907,12 +924,12 @@ bool GUI_App::on_init_inner() | |||
|             this->post_init(); | ||||
|         } | ||||
| 
 | ||||
| 		// Preset updating & Configwizard are done after the above initializations,
 | ||||
| 	    // and after MainFrame is created & shown.
 | ||||
| 	    // The extra CallAfter() is needed because of Mac, where this is the only way
 | ||||
| 	    // to popup a modal dialog on start without screwing combo boxes.
 | ||||
| 	    // This is ugly but I honestly found no better way to do it.
 | ||||
| 	    // Neither wxShowEvent nor wxWindowCreateEvent work reliably. 
 | ||||
|         // Preset updating & Configwizard are done after the above initializations,
 | ||||
|         // and after MainFrame is created & shown.
 | ||||
|         // The extra CallAfter() is needed because of Mac, where this is the only way
 | ||||
|         // to popup a modal dialog on start without screwing combo boxes.
 | ||||
|         // This is ugly but I honestly found no better way to do it.
 | ||||
|         // Neither wxShowEvent nor wxWindowCreateEvent work reliably.
 | ||||
| 
 | ||||
|         static bool once = true; | ||||
|         if (once) { | ||||
|  | @ -929,30 +946,12 @@ bool GUI_App::on_init_inner() | |||
|             } | ||||
| 
 | ||||
| #ifdef _WIN32 | ||||
| 			//sets window property to mainframe so other instances can indentify it
 | ||||
| 			OtherInstanceMessageHandler::init_windows_properties(mainframe, m_instance_hash_int); | ||||
|             //sets window property to mainframe so other instances can indentify it
 | ||||
|             OtherInstanceMessageHandler::init_windows_properties(mainframe, m_instance_hash_int); | ||||
| #endif //WIN32
 | ||||
|         } | ||||
|     }); | ||||
| 
 | ||||
|     if (is_gcode_viewer()) { | ||||
|         mainframe->update_layout(); | ||||
|         if (plater_ != nullptr) | ||||
|             // ensure the selected technology is ptFFF
 | ||||
|             plater_->set_printer_technology(ptFFF); | ||||
|     } | ||||
|     else | ||||
|         load_current_presets(); | ||||
|     mainframe->Show(true); | ||||
| 
 | ||||
|     obj_list()->set_min_height(); | ||||
| 
 | ||||
|     update_mode(); // update view mode after fix of the object_list size
 | ||||
| 
 | ||||
| #ifdef __APPLE__ | ||||
|     other_instance_message_handler()->bring_instance_forward(); | ||||
| #endif //__APPLE__
 | ||||
| 
 | ||||
|     m_initialized = true; | ||||
|     return true; | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lukas Matena
						Lukas Matena