mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 01:31:14 -06:00 
			
		
		
		
	aditional information to FAIL_COPY_FILE error message and changed bools controlling Export finished notification
This commit is contained in:
		
							parent
							
								
									a623630614
								
							
						
					
					
						commit
						115cbd4650
					
				
					 4 changed files with 33 additions and 16 deletions
				
			
		|  | @ -137,11 +137,12 @@ void BackgroundSlicingProcess::process_fff() | |||
| 	    	//FIXME localize the messages
 | ||||
| 	    	// Perform the final post-processing of the export path by applying the print statistics over the file name.
 | ||||
| 	    	std::string export_path = m_fff_print->print_statistics().finalize_output_path(m_export_path); | ||||
| 			int copy_ret_val = copy_file(m_temp_output_path, export_path, m_export_path_on_removable_media); | ||||
| 			boost::system::error_code error_code; | ||||
| 			int copy_ret_val = copy_file(m_temp_output_path, export_path, error_code, m_export_path_on_removable_media); | ||||
| 			switch (copy_ret_val) { | ||||
| 			case SUCCESS: break; // no error
 | ||||
| 			case FAIL_COPY_FILE: | ||||
| 				throw Slic3r::RuntimeError(_utf8(L("Copying of the temporary G-code to the output G-code failed. Maybe the SD card is write locked?"))); | ||||
| 				throw Slic3r::RuntimeError((boost::format(_utf8(L("Copying of the temporary G-code to the output G-code failed. Maybe the SD card is write locked?\nError message: %1%"))) % error_code.message()).str()); | ||||
| 				break; | ||||
| 			case FAIL_FILES_DIFFERENT:  | ||||
| 				throw Slic3r::RuntimeError((boost::format(_utf8(L("Copying of the temporary G-code to the output G-code failed. There might be problem with target device, please try exporting again or using different device. The corrupted output G-code is at %1%.tmp."))) % export_path).str()); | ||||
|  | @ -156,7 +157,7 @@ void BackgroundSlicingProcess::process_fff() | |||
| 				throw Slic3r::RuntimeError((boost::format(_utf8(L("Copying of the temporary G-code has finished but the exported code couldn't be opened during copy check. The output G-code is at %1%.tmp."))) % export_path).str());  | ||||
| 				break; | ||||
| 			default: | ||||
| 				BOOST_LOG_TRIVIAL(warning) << "Unexpected fail code(" << (int)copy_ret_val << ") durring copy_file() to " << export_path << "."; | ||||
| 				BOOST_LOG_TRIVIAL(error) << "Unexpected fail code(" << (int)copy_ret_val << ") durring copy_file() to " << export_path << "."; | ||||
| 				break; | ||||
| 			} | ||||
| 			 | ||||
|  | @ -521,7 +522,8 @@ void BackgroundSlicingProcess::prepare_upload() | |||
| 
 | ||||
| 	if (m_print == m_fff_print) { | ||||
| 		m_print->set_status(95, _utf8(L("Running post-processing scripts"))); | ||||
| 		if (copy_file(m_temp_output_path, source_path.string()) != SUCCESS) { | ||||
| 		boost::system::error_code error_code; | ||||
| 		if (copy_file(m_temp_output_path, source_path.string(), error_code) != SUCCESS) { | ||||
| 			throw Slic3r::RuntimeError(_utf8(L("Copying of the temporary G-code to the output G-code failed"))); | ||||
| 		} | ||||
| 		run_post_process_scripts(source_path.string(), m_fff_print->config()); | ||||
|  |  | |||
|  | @ -1770,7 +1770,8 @@ struct Plater::priv | |||
|     // Caching last value of show_action_buttons parameter for show_action_buttons(), so that a callback which does not know this state will not override it.
 | ||||
|     mutable bool    			ready_to_slice = { false }; | ||||
|     // Flag indicating that the G-code export targets a removable device, therefore the show_action_buttons() needs to be called at any case when the background processing finishes.
 | ||||
|     bool 						writing_to_removable_device = { false }; | ||||
|     bool 						writing_to_removable_device { false }; | ||||
|     bool 						show_ExportToRemovableFinished_notification { false }; | ||||
|     bool                        inside_snapshot_capture() { return m_prevent_snapshots != 0; } | ||||
| 	bool                        process_completed_with_error { false }; | ||||
| private: | ||||
|  | @ -3506,6 +3507,8 @@ void Plater::priv::on_export_began(wxCommandEvent& evt) | |||
| { | ||||
| 	if (show_warning_dialog) | ||||
| 		warnings_dialog(); | ||||
|     if (this->writing_to_removable_device) | ||||
|         this->show_ExportToRemovableFinished_notification = true; | ||||
| } | ||||
| void Plater::priv::on_slicing_began() | ||||
| { | ||||
|  | @ -3621,11 +3624,12 @@ void Plater::priv::on_process_completed(SlicingProcessCompletedEvent &evt) | |||
|             show_action_buttons(false); | ||||
|         } | ||||
|         // If writing to removable drive was scheduled, show notification with eject button
 | ||||
|         if (this->writing_to_removable_device) { | ||||
|         if (this->writing_to_removable_device && this->show_ExportToRemovableFinished_notification) { | ||||
|             show_action_buttons(false); | ||||
|             notification_manager->push_notification(NotificationType::ExportToRemovableFinished, *q->get_current_canvas3D()); | ||||
|         } | ||||
|     } | ||||
|     this->show_ExportToRemovableFinished_notification = false; | ||||
| 	this->writing_to_removable_device = false; | ||||
| } | ||||
| 
 | ||||
|  | @ -4989,12 +4993,13 @@ void Plater::export_gcode(bool prefer_removable) | |||
| 
 | ||||
|     if (! output_path.empty()) { | ||||
| 		bool path_on_removable_media = removable_drive_manager.set_and_verify_last_save_path(output_path.string()); | ||||
|         p->writing_to_removable_device = path_on_removable_media; | ||||
|         p->export_gcode(output_path, path_on_removable_media, PrintHostJob()); | ||||
|         // Storing a path to AppConfig either as path to removable media or a path to internal media.
 | ||||
|         // is_path_on_removable_drive() is called with the "true" parameter to update its internal database as the user may have shuffled the external drives
 | ||||
|         // while the dialog was open.
 | ||||
|         appconfig.update_last_output_dir(output_path.parent_path().string(), path_on_removable_media); | ||||
| 		p->writing_to_removable_device = path_on_removable_media; | ||||
| 		 | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 David Kocik
						David Kocik