objc2_app_kit/generated/
NSRunningApplication.rs

1//! This file has been automatically generated by `objc2`'s `header-translator`.
2//! DO NOT EDIT
3use core::ffi::*;
4use core::ptr::NonNull;
5use objc2::__framework_prelude::*;
6use objc2_foundation::*;
7
8use crate::*;
9
10/// The following flags are for `-activateWithOptions:` and equivalent.
11///
12/// See also [Apple's documentation](https://developer.apple.com/documentation/appkit/nsapplicationactivationoptions?language=objc)
13// NS_OPTIONS
14#[repr(transparent)]
15#[derive(Clone, Copy, Debug, PartialEq, Eq, Hash, PartialOrd, Ord)]
16pub struct NSApplicationActivationOptions(pub NSUInteger);
17bitflags::bitflags! {
18    impl NSApplicationActivationOptions: NSUInteger {
19/// By default, activation brings only the main and key
20/// windows forward. If you specify `activateAllWindows`,
21/// all of the application's windows are brought forward.
22        #[doc(alias = "NSApplicationActivateAllWindows")]
23        const ActivateAllWindows = 1<<0;
24/// The application is activated regardless of the currently
25/// active app.
26#[deprecated = "ignoringOtherApps is deprecated in macOS 14 and will have no effect."]
27        #[doc(alias = "NSApplicationActivateIgnoringOtherApps")]
28        const ActivateIgnoringOtherApps = 1<<1;
29    }
30}
31
32unsafe impl Encode for NSApplicationActivationOptions {
33    const ENCODING: Encoding = NSUInteger::ENCODING;
34}
35
36unsafe impl RefEncode for NSApplicationActivationOptions {
37    const ENCODING_REF: Encoding = Encoding::Pointer(&Self::ENCODING);
38}
39
40/// The following activation policies control whether and how an application may be activated.
41/// They are determined by the `Info.plist`.
42///
43/// See also [Apple's documentation](https://developer.apple.com/documentation/appkit/nsapplicationactivationpolicy?language=objc)
44// NS_ENUM
45#[repr(transparent)]
46#[derive(Clone, Copy, Debug, PartialEq, Eq, Hash, PartialOrd, Ord)]
47pub struct NSApplicationActivationPolicy(pub NSInteger);
48impl NSApplicationActivationPolicy {
49    #[doc(alias = "NSApplicationActivationPolicyRegular")]
50    pub const Regular: Self = Self(0);
51    #[doc(alias = "NSApplicationActivationPolicyAccessory")]
52    pub const Accessory: Self = Self(1);
53    #[doc(alias = "NSApplicationActivationPolicyProhibited")]
54    pub const Prohibited: Self = Self(2);
55}
56
57unsafe impl Encode for NSApplicationActivationPolicy {
58    const ENCODING: Encoding = NSInteger::ENCODING;
59}
60
61unsafe impl RefEncode for NSApplicationActivationPolicy {
62    const ENCODING_REF: Encoding = Encoding::Pointer(&Self::ENCODING);
63}
64
65extern_class!(
66    /// `NSRunningApplication` is a class to manipulate and provide information for a single instance of an application.  Only user applications are tracked; this does not provide information about every process on the system.
67    ///
68    /// Some properties of an application are fixed, such as the bundle identifier.  Other properties may vary over time, such as whether the app is hidden.  Properties that vary can be observed with KVO, in which case the description comment for the method will mention it.
69    ///
70    /// Properties that vary over time are inherently race-prone.  For example, a hidden app may unhide itself at any time.  To ameliorate this, properties persist until the next turn of the main run loop in a common mode.  For example, if you repeatedly poll an unhidden app for its hidden property without allowing the run loop to run, it will continue to return `NO`, even if the app hides, until the next turn of the run loop.
71    ///
72    /// `NSRunningApplication` is thread safe, in that its properties are returned atomically.  However, it is still subject to the main run loop policy described above.  If you access an instance of `NSRunningApplication` from a background thread, be aware that its time-varying properties may change from under you as the main run loop runs (or not).
73    ///
74    /// An `NSRunningApplication` instance remains valid after the application exits.  However, most properties lose their significance, and some properties may not be available on a terminated application.
75    ///
76    /// To access the list of all running applications, use the `-runningApplications` method on `NSWorkspace`.
77    ///
78    /// See also [Apple's documentation](https://developer.apple.com/documentation/appkit/nsrunningapplication?language=objc)
79    #[unsafe(super(NSObject))]
80    #[derive(Debug, PartialEq, Eq, Hash)]
81    pub struct NSRunningApplication;
82);
83
84unsafe impl Send for NSRunningApplication {}
85
86unsafe impl Sync for NSRunningApplication {}
87
88unsafe impl NSObjectProtocol for NSRunningApplication {}
89
90impl NSRunningApplication {
91    extern_methods!(
92        /// Indicates that the process is an exited application.
93        /// This is observable through KVO.
94        #[unsafe(method(isTerminated))]
95        #[unsafe(method_family = none)]
96        pub unsafe fn isTerminated(&self) -> bool;
97
98        /// Indicates that the process is finished launching, which corresponds to the
99        /// `NSApplicationDidFinishLaunching`internal notification.
100        /// This is observable through KVO.
101        /// Some applications do not post this notification and so are never reported as finished launching.
102        #[unsafe(method(isFinishedLaunching))]
103        #[unsafe(method_family = none)]
104        pub unsafe fn isFinishedLaunching(&self) -> bool;
105
106        /// Indicates whether the application is currently hidden.
107        /// This is observable through KVO.
108        #[unsafe(method(isHidden))]
109        #[unsafe(method_family = none)]
110        pub unsafe fn isHidden(&self) -> bool;
111
112        /// Indicates whether the application is currently frontmost.
113        /// This is observable through KVO.
114        #[unsafe(method(isActive))]
115        #[unsafe(method_family = none)]
116        pub unsafe fn isActive(&self) -> bool;
117
118        /// Indicates whether the application currently owns the menu bar.
119        /// This is observable through KVO.
120        #[unsafe(method(ownsMenuBar))]
121        #[unsafe(method_family = none)]
122        pub unsafe fn ownsMenuBar(&self) -> bool;
123
124        /// Indicates the activation policy of the application.
125        /// This is observable through KVO (the type is usually fixed, but may be changed through a call to `-[NSApplication setActivationPolicy:]`).
126        #[unsafe(method(activationPolicy))]
127        #[unsafe(method_family = none)]
128        pub unsafe fn activationPolicy(&self) -> NSApplicationActivationPolicy;
129
130        /// Indicates the name of the application.
131        /// This is dependent on the current localization of the referenced app, and is suitable for presentation to the user.
132        #[unsafe(method(localizedName))]
133        #[unsafe(method_family = none)]
134        pub unsafe fn localizedName(&self) -> Option<Retained<NSString>>;
135
136        /// Indicates the `CFBundleIdentifier` of the application, or nil if the application does not have an `Info.plist`.
137        #[unsafe(method(bundleIdentifier))]
138        #[unsafe(method_family = none)]
139        pub unsafe fn bundleIdentifier(&self) -> Option<Retained<NSString>>;
140
141        /// Indicates the URL to the application's bundle, or nil if the application does not have a bundle.
142        #[unsafe(method(bundleURL))]
143        #[unsafe(method_family = none)]
144        pub unsafe fn bundleURL(&self) -> Option<Retained<NSURL>>;
145
146        /// Indicates the URL to the application's executable.
147        #[unsafe(method(executableURL))]
148        #[unsafe(method_family = none)]
149        pub unsafe fn executableURL(&self) -> Option<Retained<NSURL>>;
150
151        #[cfg(feature = "libc")]
152        /// Indicates the process identifier (pid) of the application.
153        /// Do not rely on this for comparing processes.  Use `-isEqual:` instead.
154        ///
155        /// Note: Not all applications have a pid.  Applications without a pid return -1 from this method.
156        /// This is observable through KVO (an application's pid may change if it is automatically terminated).
157        #[unsafe(method(processIdentifier))]
158        #[unsafe(method_family = none)]
159        pub unsafe fn processIdentifier(&self) -> libc::pid_t;
160
161        /// Indicates the date when the application was launched.
162        /// This property is not available for all applications.
163        /// Specifically, it is not available for applications that were launched without going through `LaunchServices`.
164        #[unsafe(method(launchDate))]
165        #[unsafe(method_family = none)]
166        pub unsafe fn launchDate(&self) -> Option<Retained<NSDate>>;
167
168        #[cfg(feature = "NSImage")]
169        /// Returns: The icon of the application.
170        #[unsafe(method(icon))]
171        #[unsafe(method_family = none)]
172        pub unsafe fn icon(&self) -> Option<Retained<NSImage>>;
173
174        /// Indicates the executing processor architecture for the application, as an
175        /// `NSBundleExecutableArchitecture`from `NSBundle.h`.
176        #[unsafe(method(executableArchitecture))]
177        #[unsafe(method_family = none)]
178        pub unsafe fn executableArchitecture(&self) -> NSInteger;
179
180        /// Attempts to hide the receiver.
181        ///
182        /// Returns: `YES` if the request to hide or unhide was successfully sent, `NO` if not (for example, if the application has quit, or is of a type that cannot be unhidden).
183        #[unsafe(method(hide))]
184        #[unsafe(method_family = none)]
185        pub unsafe fn hide(&self) -> bool;
186
187        /// Attempts to unhide the receiver.
188        ///
189        /// Returns: `YES` if the request to hide or unhide was successfully sent, `NO` if not (for example, if the application has quit, or is of a type that cannot be unhidden).
190        #[unsafe(method(unhide))]
191        #[unsafe(method_family = none)]
192        pub unsafe fn unhide(&self) -> bool;
193
194        /// Attempts to activate the application using the specified options.
195        ///
196        /// You shouldn’t assume the app will be active immediately
197        /// after sending this message. The framework also does not
198        /// guarantee that the app will be activated at all.
199        ///
200        /// Additionally allows specifying another application to take
201        /// the active status from, which can be used for coordinated
202        /// or cooperative activation. The other application should
203        /// call `-yieldActivationToApplication:` or equivalent prior to this
204        /// request being sent.
205        ///
206        ///
207        /// Returns: `YES` if the request has been allowed by the system,
208        /// otherwise `NO`.
209        #[unsafe(method(activateFromApplication:options:))]
210        #[unsafe(method_family = none)]
211        pub unsafe fn activateFromApplication_options(
212            &self,
213            application: &NSRunningApplication,
214            options: NSApplicationActivationOptions,
215        ) -> bool;
216
217        /// Attempts to activate the receiver.
218        ///
219        /// Returns: `YES` if the request to activate was successfully sent, `NO` if not (for example, if the application has quit, or is of a type that cannot be activated).
220        #[unsafe(method(activateWithOptions:))]
221        #[unsafe(method_family = none)]
222        pub unsafe fn activateWithOptions(&self, options: NSApplicationActivationOptions) -> bool;
223
224        /// Attempts to quit the receiver normally.
225        ///
226        /// Returns: `YES` if the request was successfully sent, `NO` if not (for example, if the application is no longer running).
227        /// This method may return before the receiver exits; you should observe the terminated property or listen for the notification to detect when the app has exited.
228        #[unsafe(method(terminate))]
229        #[unsafe(method_family = none)]
230        pub unsafe fn terminate(&self) -> bool;
231
232        /// Attempts to force the receiver to quit.
233        ///
234        /// Returns: `YES` if the request was successfully sent, `NO` if not (for example, if the application is no longer running).
235        /// This method may return before the receiver exits; you should observe the terminated property or listen for the notification to detect when the app has exited.
236        #[unsafe(method(forceTerminate))]
237        #[unsafe(method_family = none)]
238        pub unsafe fn forceTerminate(&self) -> bool;
239
240        /// Returns: An array of currently running applications with the given bundle identifier, or an empty array if no apps match.
241        #[unsafe(method(runningApplicationsWithBundleIdentifier:))]
242        #[unsafe(method_family = none)]
243        pub unsafe fn runningApplicationsWithBundleIdentifier(
244            bundle_identifier: &NSString,
245        ) -> Retained<NSArray<NSRunningApplication>>;
246
247        #[cfg(feature = "libc")]
248        /// Returns: The running application with the given process identifier, or nil if no application has that pid.
249        /// Applications that do not have PIDs cannot be returned from this method.
250        #[unsafe(method(runningApplicationWithProcessIdentifier:))]
251        #[unsafe(method_family = none)]
252        pub unsafe fn runningApplicationWithProcessIdentifier(
253            pid: libc::pid_t,
254        ) -> Option<Retained<Self>>;
255
256        /// Returns: An
257        /// `NSRunningApplication`representing this application.
258        #[unsafe(method(currentApplication))]
259        #[unsafe(method_family = none)]
260        pub unsafe fn currentApplication() -> Retained<NSRunningApplication>;
261
262        /// Cause any applications that are invisibly still running (see `NSProcessInfo.h` automatic termination methods and docs) to terminate as if triggered by system memory pressure.
263        /// This is intended for installer apps and the like to make sure that nothing is unexpectedly relying on the files they're replacing.
264        #[unsafe(method(terminateAutomaticallyTerminableApplications))]
265        #[unsafe(method_family = none)]
266        pub unsafe fn terminateAutomaticallyTerminableApplications();
267    );
268}
269
270/// Methods declared on superclass `NSObject`.
271impl NSRunningApplication {
272    extern_methods!(
273        #[unsafe(method(init))]
274        #[unsafe(method_family = init)]
275        pub unsafe fn init(this: Allocated<Self>) -> Retained<Self>;
276
277        #[unsafe(method(new))]
278        #[unsafe(method_family = new)]
279        pub unsafe fn new() -> Retained<Self>;
280    );
281}
282
283/// NSWorkspaceRunningApplications.
284#[cfg(feature = "NSWorkspace")]
285impl NSWorkspace {
286    extern_methods!(
287        /// Returns: An array of `NSRunningApplication`s representing currently running applications.
288        /// The order of the array is unspecified, but it is stable, meaning that the relative order of particular applications will not change across multiple calls to `runningApplications`.
289        /// Similar to `NSRunningApplication`'s properties, this property will only change when the main run loop is run in a common mode.  Instead of polling, use key-value observing to be notified of changes to this array property.
290        /// This property is thread safe, in that it may be called from background threads and the result is returned atomically.  This property is observable through KVO.
291        #[unsafe(method(runningApplications))]
292        #[unsafe(method_family = none)]
293        pub unsafe fn runningApplications(&self) -> Retained<NSArray<NSRunningApplication>>;
294    );
295}