refactor: migrate deprecated platform_util_mac calls (#43161)
		
	refactor: migrate deprecated platform_util_mac calls
This commit is contained in:
		
					parent
					
						
							
								a7c52f1fb2
							
						
					
				
			
			
				commit
				
					
						4801a54d08
					
				
			
		
					 1 changed files with 16 additions and 64 deletions
				
			
		|  | @ -25,67 +25,13 @@ | ||||||
| #include "ui/views/widget/widget.h" | #include "ui/views/widget/widget.h" | ||||||
| #include "url/gurl.h" | #include "url/gurl.h" | ||||||
| 
 | 
 | ||||||
| // platform_util_mac.mm uses a lot of deprecated API. |  | ||||||
| // https://github.com/electron/electron/issues/43126 |  | ||||||
| #pragma clang diagnostic push |  | ||||||
| #pragma clang diagnostic ignored "-Wdeprecated-declarations" |  | ||||||
| 
 |  | ||||||
| namespace { | namespace { | ||||||
| 
 | 
 | ||||||
| // This may be called from a global dispatch queue, the methods used here are |  | ||||||
| // thread safe, including LSGetApplicationForURL (> 10.2) and |  | ||||||
| // NSWorkspace#openURLs. |  | ||||||
| std::string OpenURL(NSURL* ns_url, bool activate) { |  | ||||||
|   CFURLRef cf_url = (__bridge CFURLRef)(ns_url); |  | ||||||
|   CFURLRef ref = |  | ||||||
|       LSCopyDefaultApplicationURLForURL(cf_url, kLSRolesAll, nullptr); |  | ||||||
| 
 |  | ||||||
|   // If no application could be found, nullptr is returned and outError |  | ||||||
|   // (if not nullptr) is populated with kLSApplicationNotFoundErr. |  | ||||||
|   if (ref == nullptr) |  | ||||||
|     return "No application in the Launch Services database matches the input " |  | ||||||
|            "criteria."; |  | ||||||
| 
 |  | ||||||
|   NSUInteger launchOptions = NSWorkspaceLaunchDefault; |  | ||||||
|   if (!activate) |  | ||||||
|     launchOptions |= NSWorkspaceLaunchWithoutActivation; |  | ||||||
| 
 |  | ||||||
|   bool opened = [[NSWorkspace sharedWorkspace] openURLs:@[ ns_url ] |  | ||||||
|                                 withAppBundleIdentifier:nil |  | ||||||
|                                                 options:launchOptions |  | ||||||
|                          additionalEventParamDescriptor:nil |  | ||||||
|                                       launchIdentifiers:nil]; |  | ||||||
|   if (!opened) |  | ||||||
|     return "Failed to open URL"; |  | ||||||
| 
 |  | ||||||
|   return ""; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| NSString* GetLoginHelperBundleIdentifier() { | NSString* GetLoginHelperBundleIdentifier() { | ||||||
|   return [[[NSBundle mainBundle] bundleIdentifier] |   return [[[NSBundle mainBundle] bundleIdentifier] | ||||||
|       stringByAppendingString:@".loginhelper"]; |       stringByAppendingString:@".loginhelper"]; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::string OpenPathOnThread(const base::FilePath& full_path) { |  | ||||||
|   NSString* path_string = base::SysUTF8ToNSString(full_path.value()); |  | ||||||
|   NSURL* url = [NSURL fileURLWithPath:path_string]; |  | ||||||
|   if (!url) |  | ||||||
|     return "Invalid path"; |  | ||||||
| 
 |  | ||||||
|   const NSWorkspaceLaunchOptions launch_options = |  | ||||||
|       NSWorkspaceLaunchAsync | NSWorkspaceLaunchWithErrorPresentation; |  | ||||||
|   BOOL success = [[NSWorkspace sharedWorkspace] openURLs:@[ url ] |  | ||||||
|                                  withAppBundleIdentifier:nil |  | ||||||
|                                                  options:launch_options |  | ||||||
|                           additionalEventParamDescriptor:nil |  | ||||||
|                                        launchIdentifiers:nil]; |  | ||||||
| 
 |  | ||||||
|   return success ? "" : "Failed to open path"; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // -Wdeprecated-declarations |  | ||||||
| #pragma clang diagnostic pop |  | ||||||
| 
 |  | ||||||
| // https://developer.apple.com/documentation/servicemanagement/1561515-service_management_errors?language=objc | // https://developer.apple.com/documentation/servicemanagement/1561515-service_management_errors?language=objc | ||||||
| std::string GetLaunchStringForError(NSError* error) { | std::string GetLaunchStringForError(NSError* error) { | ||||||
|   if (@available(macOS 13, *)) { |   if (@available(macOS 13, *)) { | ||||||
|  | @ -179,7 +125,15 @@ void ShowItemInFolder(const base::FilePath& path) { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void OpenPath(const base::FilePath& full_path, OpenCallback callback) { | void OpenPath(const base::FilePath& full_path, OpenCallback callback) { | ||||||
|   std::move(callback).Run(OpenPathOnThread(full_path)); |   DCHECK([NSThread isMainThread]); | ||||||
|  |   NSURL* ns_url = base::apple::FilePathToNSURL(full_path); | ||||||
|  |   if (!ns_url) { | ||||||
|  |     std::move(callback).Run("Invalid path"); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   bool success = [[NSWorkspace sharedWorkspace] openURL:ns_url]; | ||||||
|  |   std::move(callback).Run(success ? "" : "Failed to open path"); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void OpenExternal(const GURL& url, | void OpenExternal(const GURL& url, | ||||||
|  | @ -192,25 +146,23 @@ void OpenExternal(const GURL& url, | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   base::ThreadPool::PostTaskAndReplyWithResult( |   bool success = [[NSWorkspace sharedWorkspace] openURL:ns_url]; | ||||||
|       FROM_HERE, |   if (success && options.activate) | ||||||
|       {base::MayBlock(), base::WithBaseSyncPrimitives(), |     [NSApp activateIgnoringOtherApps:YES]; | ||||||
|        base::TaskPriority::USER_BLOCKING, | 
 | ||||||
|        base::TaskShutdownBehavior::SKIP_ON_SHUTDOWN}, |   std::move(callback).Run(success ? "" : "Failed to open URL"); | ||||||
|       base::BindOnce(&OpenURL, ns_url, options.activate), std::move(callback)); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool MoveItemToTrashWithError(const base::FilePath& full_path, | bool MoveItemToTrashWithError(const base::FilePath& full_path, | ||||||
|                               bool delete_on_fail, |                               bool delete_on_fail, | ||||||
|                               std::string* error) { |                               std::string* error) { | ||||||
|   NSString* path_string = base::SysUTF8ToNSString(full_path.value()); |   NSURL* url = base::apple::FilePathToNSURL(full_path); | ||||||
|   if (!path_string) { |   if (!url) { | ||||||
|     *error = "Invalid file path: " + full_path.value(); |     *error = "Invalid file path: " + full_path.value(); | ||||||
|     LOG(WARNING) << *error; |     LOG(WARNING) << *error; | ||||||
|     return false; |     return false; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   NSURL* url = [NSURL fileURLWithPath:path_string]; |  | ||||||
|   NSError* err = nil; |   NSError* err = nil; | ||||||
|   BOOL did_trash = [[NSFileManager defaultManager] trashItemAtURL:url |   BOOL did_trash = [[NSFileManager defaultManager] trashItemAtURL:url | ||||||
|                                                  resultingItemURL:nil |                                                  resultingItemURL:nil | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Shelley Vohr
				Shelley Vohr