mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 17:51:10 -06:00 
			
		
		
		
	check if last path is on rem drive
This commit is contained in:
		
							parent
							
								
									b8b4b1dd42
								
							
						
					
					
						commit
						852d8ad5cc
					
				
					 4 changed files with 39 additions and 7 deletions
				
			
		|  | @ -21,7 +21,6 @@ | ||||||
| 
 | 
 | ||||||
| #include <wx/string.h> | #include <wx/string.h> | ||||||
| #include "I18N.hpp" | #include "I18N.hpp" | ||||||
| #include "RemovableDriveManager.hpp" |  | ||||||
| 
 | 
 | ||||||
| namespace Slic3r { | namespace Slic3r { | ||||||
| 
 | 
 | ||||||
|  | @ -358,10 +357,7 @@ void AppConfig::update_skein_dir(const std::string &dir) | ||||||
| 
 | 
 | ||||||
| std::string AppConfig::get_last_output_dir(const std::string &alt) const | std::string AppConfig::get_last_output_dir(const std::string &alt) const | ||||||
| { | { | ||||||
| 	if (GUI::RemovableDriveManager::getInstance().update()) | 	 | ||||||
| 	{ |  | ||||||
| 		return GUI::RemovableDriveManager::getInstance().get_last_drive_path(); |  | ||||||
| 	} |  | ||||||
|     const auto it = m_storage.find(""); |     const auto it = m_storage.find(""); | ||||||
|     if (it != m_storage.end()) { |     if (it != m_storage.end()) { | ||||||
|         const auto it2 = it->second.find("last_output_path"); |         const auto it2 = it->second.find("last_output_path"); | ||||||
|  |  | ||||||
|  | @ -77,6 +77,7 @@ | ||||||
| #include "../Utils/FixModelByWin10.hpp" | #include "../Utils/FixModelByWin10.hpp" | ||||||
| #include "../Utils/UndoRedo.hpp" | #include "../Utils/UndoRedo.hpp" | ||||||
| #include "../Utils/Thread.hpp" | #include "../Utils/Thread.hpp" | ||||||
|  | #include "RemovableDriveManager.hpp" | ||||||
| 
 | 
 | ||||||
| #include <wx/glcanvas.h>    // Needs to be last because reasons :-/
 | #include <wx/glcanvas.h>    // Needs to be last because reasons :-/
 | ||||||
| #include "WipeTowerDialog.hpp" | #include "WipeTowerDialog.hpp" | ||||||
|  | @ -4661,7 +4662,13 @@ void Plater::export_gcode() | ||||||
|     } |     } | ||||||
|     default_output_file = fs::path(Slic3r::fold_utf8_to_ascii(default_output_file.string())); |     default_output_file = fs::path(Slic3r::fold_utf8_to_ascii(default_output_file.string())); | ||||||
|     auto start_dir = wxGetApp().app_config->get_last_output_dir(default_output_file.parent_path().string()); |     auto start_dir = wxGetApp().app_config->get_last_output_dir(default_output_file.parent_path().string()); | ||||||
| 
 | 	if (GUI::RemovableDriveManager::getInstance().update()) | ||||||
|  | 	{ | ||||||
|  | 		if (!RemovableDriveManager::getInstance().is_path_on_removable_drive(start_dir)) | ||||||
|  | 		{ | ||||||
|  | 			start_dir = RemovableDriveManager::getInstance().get_last_drive_path(); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|     wxFileDialog dlg(this, (printer_technology() == ptFFF) ? _(L("Save G-code file as:")) : _(L("Save SL1 file as:")), |     wxFileDialog dlg(this, (printer_technology() == ptFFF) ? _(L("Save G-code file as:")) : _(L("Save SL1 file as:")), | ||||||
|         start_dir, |         start_dir, | ||||||
|         from_path(default_output_file.filename()), |         from_path(default_output_file.filename()), | ||||||
|  |  | ||||||
|  | @ -7,6 +7,7 @@ | ||||||
| #include <windows.h> | #include <windows.h> | ||||||
| #include <tchar.h> | #include <tchar.h> | ||||||
| #include <winioctl.h> | #include <winioctl.h> | ||||||
|  | #include <shlwapi.h> | ||||||
| DEFINE_GUID(GUID_DEVINTERFACE_USB_DEVICE, | DEFINE_GUID(GUID_DEVINTERFACE_USB_DEVICE, | ||||||
| 	0xA5DCBF10L, 0x6530, 0x11D2, 0x90, 0x1F, 0x00, 0xC0, 0x4F, 0xB9, 0x51, 0xED); | 	0xA5DCBF10L, 0x6530, 0x11D2, 0x90, 0x1F, 0x00, 0xC0, 0x4F, 0xB9, 0x51, 0xED); | ||||||
| #else | #else | ||||||
|  | @ -208,7 +209,11 @@ std::string RemovableDriveManager::get_last_drive_path() | ||||||
| { | { | ||||||
| 	if (!m_current_drives.empty()) | 	if (!m_current_drives.empty()) | ||||||
| 	{ | 	{ | ||||||
|  | #if _WIN32 | ||||||
|  | 		return m_current_drives.back().path + "\\"; | ||||||
|  | #else | ||||||
| 		return m_current_drives.back().path; | 		return m_current_drives.back().path; | ||||||
|  | #endif	 | ||||||
| 	} | 	} | ||||||
| 	return ""; | 	return ""; | ||||||
| } | } | ||||||
|  | @ -216,4 +221,27 @@ std::vector<DriveData> RemovableDriveManager::get_all_drives() | ||||||
| { | { | ||||||
| 	return m_current_drives; | 	return m_current_drives; | ||||||
| } | } | ||||||
| }} | #if _WIN32 | ||||||
|  | bool RemovableDriveManager::is_path_on_removable_drive(const std::string& path) | ||||||
|  | { | ||||||
|  | 	if (m_current_drives.empty()) | ||||||
|  | 		return false; | ||||||
|  | 	int letter = PathGetDriveNumberA(path.c_str()); | ||||||
|  | 	for (auto it = m_current_drives.begin(); it != m_current_drives.end(); ++it) | ||||||
|  | 	{ | ||||||
|  | 		char drive = (*it).path[0]; | ||||||
|  | 		if (drive == ('A' + letter)) | ||||||
|  | 			return true; | ||||||
|  | 	} | ||||||
|  | 	return false; | ||||||
|  | } | ||||||
|  | #else | ||||||
|  | bool RemovableDriveManager::is_path_on_removable_drive(const std::string& path, const std::string& drive) | ||||||
|  | { | ||||||
|  | 	if (m_current_drives.empty()) | ||||||
|  | 		return false; | ||||||
|  | 
 | ||||||
|  | 	return false; | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  | }}//namespace Slicer::Gui::
 | ||||||
|  | @ -29,6 +29,7 @@ public: | ||||||
| 	static void eject_drive(const std::string &path); | 	static void eject_drive(const std::string &path); | ||||||
| 	static std::string get_last_drive_path(); | 	static std::string get_last_drive_path(); | ||||||
| 	static std::vector<DriveData> get_all_drives(); | 	static std::vector<DriveData> get_all_drives(); | ||||||
|  | 	static bool is_path_on_removable_drive(const std::string &path); | ||||||
| private: | private: | ||||||
| 	RemovableDriveManager(){} | 	RemovableDriveManager(){} | ||||||
| 	static void search_for_drives(); | 	static void search_for_drives(); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 David Kocik
						David Kocik