gecko-dev/widget/cocoa/nsMacWebAppUtils.mm
Mike Hommey 9331b9fb07 Bug 1851529 - Set clang-format ColumnLimit consistently. r=sylvestre,necko-reviewers,kershaw
For some reason, its value in the Google style we use is 80... except
for Objective-C, where it's 100, which led to things like:
https://hg.mozilla.org/mozilla-central/rev/31bf68247e6e
https://hg.mozilla.org/mozilla-central/rev/64ceb33533a4.

There's probably a discussion to have about whether 80 is the right
limit, but since it's what's used for everything except ObjC, let's roll
with it.

# ignore-this-changeset

Differential Revision: https://phabricator.services.mozilla.com/D187409
2023-09-05 11:23:01 +00:00

99 lines
3.2 KiB
Plaintext

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#import <Cocoa/Cocoa.h>
#include "nsMacWebAppUtils.h"
#include "nsCOMPtr.h"
#include "nsCocoaUtils.h"
#include "nsString.h"
// This must be included last:
#include "nsObjCExceptions.h"
// Find the path to the app with the given bundleIdentifier, if any.
// Note that the OS will return the path to the newest binary, if there is more
// than one. The determination of 'newest' is complex and beyond the scope of
// this comment.
NS_IMPL_ISUPPORTS(nsMacWebAppUtils, nsIMacWebAppUtils)
NS_IMETHODIMP nsMacWebAppUtils::PathForAppWithIdentifier(
const nsAString& bundleIdentifier, nsAString& outPath) {
NS_OBJC_BEGIN_TRY_BLOCK_RETURN;
outPath.Truncate();
nsAutoreleasePool localPool;
// note that the result of this expression might be nil, meaning no matching
// app was found.
NSString* temp = [[NSWorkspace sharedWorkspace]
absolutePathForAppBundleWithIdentifier:
[NSString
stringWithCharacters:reinterpret_cast<const unichar*>(
((nsString)bundleIdentifier).get())
length:((nsString)bundleIdentifier).Length()]];
if (temp) {
// Copy out the resultant absolute path into outPath if non-nil.
nsCocoaUtils::GetStringForNSString(temp, outPath);
}
return NS_OK;
NS_OBJC_END_TRY_BLOCK_RETURN(NS_ERROR_FAILURE);
}
NS_IMETHODIMP nsMacWebAppUtils::LaunchAppWithIdentifier(
const nsAString& bundleIdentifier) {
NS_OBJC_BEGIN_TRY_BLOCK_RETURN;
nsAutoreleasePool localPool;
// Note this might return false, meaning the app wasnt launched for some
// reason.
BOOL success = [[NSWorkspace sharedWorkspace]
launchAppWithBundleIdentifier:
[NSString
stringWithCharacters:reinterpret_cast<const unichar*>(
((nsString)bundleIdentifier).get())
length:((nsString)bundleIdentifier).Length()]
options:(NSWorkspaceLaunchOptions)0
additionalEventParamDescriptor:nil
launchIdentifier:NULL];
return success ? NS_OK : NS_ERROR_FAILURE;
NS_OBJC_END_TRY_BLOCK_RETURN(NS_ERROR_FAILURE);
}
NS_IMETHODIMP nsMacWebAppUtils::TrashApp(const nsAString& path,
nsITrashAppCallback* aCallback) {
NS_OBJC_BEGIN_TRY_BLOCK_RETURN;
if (NS_WARN_IF(!aCallback)) {
return NS_ERROR_INVALID_ARG;
}
nsCOMPtr<nsITrashAppCallback> callback = aCallback;
NSString* tempString =
[NSString stringWithCharacters:reinterpret_cast<const unichar*>(
((nsString)path).get())
length:path.Length()];
[[NSWorkspace sharedWorkspace]
recycleURLs:[NSArray
arrayWithObject:[NSURL fileURLWithPath:tempString]]
completionHandler:^(NSDictionary* newURLs, NSError* error) {
nsresult rv = (error == nil) ? NS_OK : NS_ERROR_FAILURE;
callback->TrashAppFinished(rv);
}];
return NS_OK;
NS_OBJC_END_TRY_BLOCK_RETURN(NS_ERROR_FAILURE);
}