mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 17:51:10 -06:00 
			
		
		
		
	macos device detection
This commit is contained in:
		
							parent
							
								
									fad035137f
								
							
						
					
					
						commit
						b8aa12486e
					
				
					 5 changed files with 96 additions and 2 deletions
				
			
		|  | @ -1,6 +1,7 @@ | |||
| #import "RemovableDriveManager.hpp" | ||||
| #import "RemovableDriveManagerMM.h" | ||||
| #import <AppKit/AppKit.h>  | ||||
| #import <DiskArbitration/DiskArbitration.h> | ||||
| 
 | ||||
| @implementation RemovableDriveManagerMM | ||||
| 
 | ||||
|  | @ -27,9 +28,81 @@ | |||
| } | ||||
| -(NSArray*) list_dev | ||||
| { | ||||
|     NSArray* devices = [[NSWorkspace sharedWorkspace] mountedRemovableMedia]; | ||||
| 	return devices; | ||||
|     // DEPRICATED: | ||||
|     //NSArray* devices = [[NSWorkspace sharedWorkspace] mountedRemovableMedia]; | ||||
| 	//return devices; | ||||
|      | ||||
|     NSArray *mountedRemovableMedia = [[NSFileManager defaultManager] mountedVolumeURLsIncludingResourceValuesForKeys:nil options:NSVolumeEnumerationSkipHiddenVolumes]; | ||||
|     NSMutableArray *result = [NSMutableArray array]; | ||||
|     for(NSURL *volURL in mountedRemovableMedia) | ||||
|     { | ||||
|         int                 err = 0; | ||||
|         DADiskRef           disk; | ||||
|         DASessionRef        session; | ||||
|         CFDictionaryRef     descDict; | ||||
|         session = DASessionCreate(NULL); | ||||
|         if (session == NULL) { | ||||
|             err = EINVAL; | ||||
|         } | ||||
|         if (err == 0) { | ||||
|             disk = DADiskCreateFromVolumePath(NULL,session,(CFURLRef)volURL); | ||||
|             if (session == NULL) { | ||||
|                 err = EINVAL; | ||||
|             } | ||||
|         } | ||||
|         if (err == 0) { | ||||
|             descDict = DADiskCopyDescription(disk); | ||||
|             if (descDict == NULL) { | ||||
|                 err = EINVAL; | ||||
|             } | ||||
|         } | ||||
|         if (err == 0) { | ||||
|             CFTypeRef mediaEjectableKey = CFDictionaryGetValue(descDict,kDADiskDescriptionMediaEjectableKey); | ||||
|             BOOL ejectable = [mediaEjectableKey boolValue]; | ||||
|             CFTypeRef deviceProtocolName = CFDictionaryGetValue(descDict,kDADiskDescriptionDeviceProtocolKey); | ||||
|             CFTypeRef deviceModelKey = CFDictionaryGetValue(descDict, kDADiskDescriptionDeviceModelKey); | ||||
|             if (mediaEjectableKey != NULL) | ||||
|             { | ||||
|                 BOOL op = ejectable && (CFEqual(deviceProtocolName, CFSTR("USB")) || CFEqual(deviceModelKey, CFSTR("SD Card Reader"))); | ||||
|                 //!CFEqual(deviceModelKey, CFSTR("Disk Image")); | ||||
|                 // | ||||
|                 if (op) { | ||||
|                     [result addObject:volURL.path]; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if (descDict != NULL) { | ||||
|             CFRelease(descDict); | ||||
|         } | ||||
|          | ||||
|          | ||||
|     } | ||||
|     return result; | ||||
| } | ||||
| -(void)eject_drive:(NSString *)path | ||||
| { | ||||
|     DADiskRef disk; | ||||
|     DASessionRef session; | ||||
|     NSURL *url = [[NSURL alloc] initFileURLWithPath:path]; | ||||
|     int err = 0; | ||||
|     session = DASessionCreate(NULL); | ||||
|     if (session == NULL) { | ||||
|         err = EINVAL; | ||||
|     } | ||||
|     if (err == 0) { | ||||
|         disk = DADiskCreateFromVolumePath(NULL,session,(CFURLRef)url); | ||||
|     } | ||||
|     if( err == 0) | ||||
|     { | ||||
|         DADiskUnmount(disk, kDADiskUnmountOptionDefault, | ||||
|                       NULL, NULL); | ||||
|     } | ||||
|     if (disk != NULL) { | ||||
|         CFRelease(disk); | ||||
|     } | ||||
|     if (session != NULL) { | ||||
|         CFRelease(session); | ||||
|     } | ||||
| } | ||||
| namespace Slic3r { | ||||
| namespace GUI { | ||||
|  | @ -66,6 +139,15 @@ void RDMMMWrapper::log(const std::string &msg) | |||
| { | ||||
|     NSLog(@"%s", msg.c_str()); | ||||
| } | ||||
| void RDMMMWrapper::eject_device(const std::string &path) | ||||
| { | ||||
|     if(m_imp) | ||||
|     { | ||||
|         NSString * pth = [NSString stringWithCString:path.c_str() | ||||
|                                             encoding:[NSString defaultCStringEncoding]]; | ||||
|         [m_imp eject_drive:pth]; | ||||
|     } | ||||
| } | ||||
| }}//namespace Slicer::GUI | ||||
| 
 | ||||
| /* | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Slic3rPE
						Slic3rPE