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…
Reference in a new issue