#[repr(C)]pub struct FPUIActionExtensionViewController { /* private fields */ }
FPUIActionExtensionViewController
and crate feature objc2-app-kit
and macOS only.Expand description
The custom user interface used to perform a selected action.
Subclass this view controller to provide the user interface for your actions.
No matter how many actions you define, your File Provider UI extension has
only one FPUIActionExtensionViewController
subclass. When the user
selects one of your actions, the system instantiates a copy of your
subclass, calls its
FPUIActionExtensionViewController/prepareForActionWithIdentifier:itemIdentifiers:
method, and presents it to the user.
Your subclass must do the following:
- Override the
FPUIActionExtensionViewController/prepareForActionWithIdentifier:itemIdentifiers:
method to check the action identifiers and present an appropriate user interface for the selected actions. - Provide some sort of feedback, even if the action doesn’t require interaction with the user. For example, present a view that quickly fades out and automatically completes the action.
- Call the
FPUIActionExtensionViewController/extensionContext
object’sFPUIActionExtensionContext/cancelRequestWithError:
orFPUIActionExtensionContext/completeRequest
method when the action is finished to complete the action.
See also Apple’s documentation
Implementations§
Source§impl FPUIActionExtensionViewController
impl FPUIActionExtensionViewController
Sourcepub unsafe fn extensionContext(&self) -> Retained<FPUIActionExtensionContext>
Available on crate feature FPUIActionExtensionContext
only.
pub unsafe fn extensionContext(&self) -> Retained<FPUIActionExtensionContext>
FPUIActionExtensionContext
only.The extension context provided by the host app.
Sourcepub unsafe fn prepareForError(&self, error: &NSError)
pub unsafe fn prepareForError(&self, error: &NSError)
Performs any necessary setup or configuration when an authentication error occurs.
While your file provider is enumerating its content, the system calls this method whenever your file provider returns an <doc ://com.apple.documentation/documentation/fileprovider/nsfileprovidererrordomain> error with a <doc ://com.apple.documentation/documentation/fileprovider/nsfileprovidererrorcode/nsfileprovidererrornotauthenticated> code. Use this method to present an interface to authenticate the user.
- Parameters:
- error: An object representing the authentication error. Your File Provider extension can pass additional information in the error’s <doc ://com.apple.documentation/documentation/foundation/nserror/1411580-userinfo> property.
Sourcepub unsafe fn prepareForActionWithIdentifier_itemIdentifiers(
&self,
action_identifier: &NSString,
item_identifiers: &NSArray<NSFileProviderItemIdentifier>,
)
pub unsafe fn prepareForActionWithIdentifier_itemIdentifiers( &self, action_identifier: &NSString, item_identifiers: &NSArray<NSFileProviderItemIdentifier>, )
Performs any necessary setup or configuration for the specified action.
Use this method to prepare a user interface for handling the action. At a minimum, you should display feedback about the action.
For more information, see
-
Parameters:
-
actionIdentifier: The identifier for the action performed by the user.
-
itemIdentifiers: The identifiers of the items affected by the action.
Source§impl FPUIActionExtensionViewController
Methods declared on superclass NSViewController
.
impl FPUIActionExtensionViewController
Methods declared on superclass NSViewController
.
Source§impl FPUIActionExtensionViewController
Methods declared on superclass NSResponder
.
impl FPUIActionExtensionViewController
Methods declared on superclass NSResponder
.
Source§impl FPUIActionExtensionViewController
Methods declared on superclass NSObject
.
impl FPUIActionExtensionViewController
Methods declared on superclass NSObject
.
pub unsafe fn new(mtm: MainThreadMarker) -> Retained<Self>
Methods from Deref<Target = NSViewController>§
pub unsafe fn nibName(&self) -> Option<Retained<NSString>>
pub unsafe fn nibBundle(&self) -> Option<Retained<NSBundle>>
pub unsafe fn representedObject(&self) -> Option<Retained<AnyObject>>
Sourcepub unsafe fn setRepresentedObject(
&self,
represented_object: Option<&AnyObject>,
)
pub unsafe fn setRepresentedObject( &self, represented_object: Option<&AnyObject>, )
Setter for representedObject
.
pub unsafe fn title(&self) -> Option<Retained<NSString>>
pub unsafe fn loadView(&self)
pub unsafe fn loadViewIfNeeded(&self)
pub unsafe fn commitEditingWithDelegate_didCommitSelector_contextInfo( &self, delegate: Option<&AnyObject>, did_commit_selector: Option<Sel>, context_info: *mut c_void, )
pub unsafe fn commitEditing(&self) -> bool
pub unsafe fn discardEditing(&self)
pub unsafe fn viewDidLoad(&self)
pub unsafe fn isViewLoaded(&self) -> bool
pub unsafe fn viewWillAppear(&self)
pub unsafe fn viewDidAppear(&self)
pub unsafe fn viewWillDisappear(&self)
pub unsafe fn viewDidDisappear(&self)
pub unsafe fn preferredContentSize(&self) -> CGSize
Sourcepub unsafe fn setPreferredContentSize(&self, preferred_content_size: CGSize)
pub unsafe fn setPreferredContentSize(&self, preferred_content_size: CGSize)
Setter for preferredContentSize
.
pub unsafe fn updateViewConstraints(&self)
pub unsafe fn viewWillLayout(&self)
pub unsafe fn viewDidLayout(&self)
pub unsafe fn presentViewController_animator( &self, view_controller: &NSViewController, animator: &ProtocolObject<dyn NSViewControllerPresentationAnimator>, )
pub unsafe fn dismissViewController(&self, view_controller: &NSViewController)
pub unsafe fn dismissController(&self, sender: Option<&AnyObject>)
pub unsafe fn presentedViewControllers( &self, ) -> Option<Retained<NSArray<NSViewController>>>
pub unsafe fn presentingViewController( &self, ) -> Option<Retained<NSViewController>>
pub unsafe fn presentViewControllerAsSheet( &self, view_controller: &NSViewController, )
pub unsafe fn presentViewControllerAsModalWindow( &self, view_controller: &NSViewController, )
pub unsafe fn parentViewController(&self) -> Option<Retained<NSViewController>>
pub unsafe fn childViewControllers(&self) -> Retained<NSArray<NSViewController>>
Sourcepub unsafe fn setChildViewControllers(
&self,
child_view_controllers: &NSArray<NSViewController>,
)
pub unsafe fn setChildViewControllers( &self, child_view_controllers: &NSArray<NSViewController>, )
Setter for childViewControllers
.
pub unsafe fn addChildViewController( &self, child_view_controller: &NSViewController, )
pub unsafe fn removeFromParentViewController(&self)
pub unsafe fn insertChildViewController_atIndex( &self, child_view_controller: &NSViewController, index: isize, )
pub unsafe fn removeChildViewControllerAtIndex(&self, index: isize)
pub unsafe fn preferredContentSizeDidChangeForViewController( &self, view_controller: &NSViewController, )
pub unsafe fn viewWillTransitionToSize(&self, new_size: CGSize)
pub unsafe fn extensionContext(&self) -> Option<Retained<NSExtensionContext>>
pub unsafe fn preferredScreenOrigin(&self) -> CGPoint
Sourcepub unsafe fn setPreferredScreenOrigin(&self, preferred_screen_origin: CGPoint)
pub unsafe fn setPreferredScreenOrigin(&self, preferred_screen_origin: CGPoint)
Setter for preferredScreenOrigin
.
pub unsafe fn preferredMinimumSize(&self) -> CGSize
pub unsafe fn preferredMaximumSize(&self) -> CGSize
Methods from Deref<Target = NSResponder>§
pub unsafe fn nextResponder(&self) -> Option<Retained<NSResponder>>
Sourcepub unsafe fn setNextResponder(&self, next_responder: Option<&NSResponder>)
pub unsafe fn setNextResponder(&self, next_responder: Option<&NSResponder>)
Setter for nextResponder
.
pub unsafe fn tryToPerform_with( &self, action: Sel, object: Option<&AnyObject>, ) -> bool
pub unsafe fn noResponderFor(&self, event_selector: Sel)
pub unsafe fn acceptsFirstResponder(&self) -> bool
pub unsafe fn becomeFirstResponder(&self) -> bool
pub unsafe fn resignFirstResponder(&self) -> bool
pub unsafe fn flushBufferedKeyEvents(&self)
pub unsafe fn showContextHelp(&self, sender: Option<&AnyObject>)
pub unsafe fn supplementalTargetForAction_sender( &self, action: Sel, sender: Option<&AnyObject>, ) -> Option<Retained<AnyObject>>
pub unsafe fn undoManager(&self) -> Option<Retained<NSUndoManager>>
pub unsafe fn presentError(&self, error: &NSError) -> bool
pub unsafe fn willPresentError(&self, error: &NSError) -> Retained<NSError>
pub unsafe fn performTextFinderAction(&self, sender: Option<&AnyObject>)
pub unsafe fn newWindowForTab(&self, sender: Option<&AnyObject>)
pub unsafe fn showWritingTools(&self, sender: Option<&AnyObject>)
pub unsafe fn performMnemonic(&self, string: &NSString) -> bool
Methods from Deref<Target = NSObject>§
Sourcepub fn doesNotRecognizeSelector(&self, sel: Sel) -> !
pub fn doesNotRecognizeSelector(&self, sel: Sel) -> !
Handle messages the object doesn’t recognize.
See Apple’s documentation for details.
Methods from Deref<Target = AnyObject>§
Sourcepub fn class(&self) -> &'static AnyClass
pub fn class(&self) -> &'static AnyClass
Dynamically find the class of this object.
§Panics
May panic if the object is invalid (which may be the case for objects
returned from unavailable init
/new
methods).
§Example
Check that an instance of NSObject
has the precise class NSObject
.
use objc2::ClassType;
use objc2::runtime::NSObject;
let obj = NSObject::new();
assert_eq!(obj.class(), NSObject::class());
Sourcepub unsafe fn get_ivar<T>(&self, name: &str) -> &Twhere
T: Encode,
👎Deprecated: this is difficult to use correctly, use Ivar::load
instead.
pub unsafe fn get_ivar<T>(&self, name: &str) -> &Twhere
T: Encode,
Ivar::load
instead.Use Ivar::load
instead.
§Safety
The object must have an instance variable with the given name, and it
must be of type T
.
See Ivar::load_ptr
for details surrounding this.
Sourcepub fn downcast_ref<T>(&self) -> Option<&T>where
T: DowncastTarget,
pub fn downcast_ref<T>(&self) -> Option<&T>where
T: DowncastTarget,
Attempt to downcast the object to a class of type T
.
This is the reference-variant. Use Retained::downcast
if you want
to convert a retained object to another type.
§Mutable classes
Some classes have immutable and mutable variants, such as NSString
and NSMutableString
.
When some Objective-C API signature says it gives you an immutable class, it generally expects you to not mutate that, even though it may technically be mutable “under the hood”.
So using this method to convert a NSString
to a NSMutableString
,
while not unsound, is generally frowned upon unless you created the
string yourself, or the API explicitly documents the string to be
mutable.
See Apple’s documentation on mutability and on
isKindOfClass:
for more details.
§Generic classes
Objective-C generics are called “lightweight generics”, and that’s because they aren’t exposed in the runtime. This makes it impossible to safely downcast to generic collections, so this is disallowed by this method.
You can, however, safely downcast to generic collections where all the
type-parameters are AnyObject
.
§Panics
This works internally by calling isKindOfClass:
. That means that the
object must have the instance method of that name, and an exception
will be thrown (if CoreFoundation is linked) or the process will abort
if that is not the case. In the vast majority of cases, you don’t need
to worry about this, since both root objects NSObject
and
NSProxy
implement this method.
§Examples
Cast an NSString
back and forth from NSObject
.
use objc2::rc::Retained;
use objc2_foundation::{NSObject, NSString};
let obj: Retained<NSObject> = NSString::new().into_super();
let string = obj.downcast_ref::<NSString>().unwrap();
// Or with `downcast`, if we do not need the object afterwards
let string = obj.downcast::<NSString>().unwrap();
Try (and fail) to cast an NSObject
to an NSString
.
use objc2_foundation::{NSObject, NSString};
let obj = NSObject::new();
assert!(obj.downcast_ref::<NSString>().is_none());
Try to cast to an array of strings.
use objc2_foundation::{NSArray, NSObject, NSString};
let arr = NSArray::from_retained_slice(&[NSObject::new()]);
// This is invalid and doesn't type check.
let arr = arr.downcast_ref::<NSArray<NSString>>();
This fails to compile, since it would require enumerating over the array to ensure that each element is of the desired type, which is a performance pitfall.
Downcast when processing each element instead.
use objc2_foundation::{NSArray, NSObject, NSString};
let arr = NSArray::from_retained_slice(&[NSObject::new()]);
for elem in arr {
if let Some(data) = elem.downcast_ref::<NSString>() {
// handle `data`
}
}
Trait Implementations§
Source§impl AsRef<NSResponder> for FPUIActionExtensionViewController
impl AsRef<NSResponder> for FPUIActionExtensionViewController
Source§fn as_ref(&self) -> &NSResponder
fn as_ref(&self) -> &NSResponder
Source§impl AsRef<NSViewController> for FPUIActionExtensionViewController
impl AsRef<NSViewController> for FPUIActionExtensionViewController
Source§fn as_ref(&self) -> &NSViewController
fn as_ref(&self) -> &NSViewController
Source§impl Borrow<NSResponder> for FPUIActionExtensionViewController
impl Borrow<NSResponder> for FPUIActionExtensionViewController
Source§fn borrow(&self) -> &NSResponder
fn borrow(&self) -> &NSResponder
Source§impl Borrow<NSViewController> for FPUIActionExtensionViewController
impl Borrow<NSViewController> for FPUIActionExtensionViewController
Source§fn borrow(&self) -> &NSViewController
fn borrow(&self) -> &NSViewController
Source§impl ClassType for FPUIActionExtensionViewController
impl ClassType for FPUIActionExtensionViewController
Source§const NAME: &'static str = "FPUIActionExtensionViewController"
const NAME: &'static str = "FPUIActionExtensionViewController"
Source§type Super = NSViewController
type Super = NSViewController
Source§type ThreadKind = <<FPUIActionExtensionViewController as ClassType>::Super as ClassType>::ThreadKind
type ThreadKind = <<FPUIActionExtensionViewController as ClassType>::Super as ClassType>::ThreadKind
Source§impl NSEditor for FPUIActionExtensionViewController
impl NSEditor for FPUIActionExtensionViewController
unsafe fn discardEditing(&self)
unsafe fn commitEditing(&self) -> bool
unsafe fn commitEditingWithDelegate_didCommitSelector_contextInfo( &self, delegate: Option<&AnyObject>, did_commit_selector: Option<Sel>, context_info: *mut c_void, )
unsafe fn commitEditingAndReturnError(&self) -> Result<(), Retained<NSError>>
Source§impl NSObjectProtocol for FPUIActionExtensionViewController
impl NSObjectProtocol for FPUIActionExtensionViewController
Source§fn isEqual(&self, other: Option<&AnyObject>) -> bool
fn isEqual(&self, other: Option<&AnyObject>) -> bool
Source§fn hash(&self) -> usize
fn hash(&self) -> usize
Source§fn isKindOfClass(&self, cls: &AnyClass) -> bool
fn isKindOfClass(&self, cls: &AnyClass) -> bool
Source§fn is_kind_of<T>(&self) -> bool
fn is_kind_of<T>(&self) -> bool
isKindOfClass
directly, or cast your objects with AnyObject::downcast_ref
Source§fn isMemberOfClass(&self, cls: &AnyClass) -> bool
fn isMemberOfClass(&self, cls: &AnyClass) -> bool
Source§fn respondsToSelector(&self, aSelector: Sel) -> bool
fn respondsToSelector(&self, aSelector: Sel) -> bool
Source§fn conformsToProtocol(&self, aProtocol: &AnyProtocol) -> bool
fn conformsToProtocol(&self, aProtocol: &AnyProtocol) -> bool
Source§fn debugDescription(&self) -> Retained<NSObject>
fn debugDescription(&self) -> Retained<NSObject>
Source§impl NSSeguePerforming for FPUIActionExtensionViewController
impl NSSeguePerforming for FPUIActionExtensionViewController
unsafe fn prepareForSegue_sender( &self, segue: &NSStoryboardSegue, sender: Option<&AnyObject>, )
unsafe fn performSegueWithIdentifier_sender( &self, identifier: &NSString, sender: Option<&AnyObject>, )
unsafe fn shouldPerformSegueWithIdentifier_sender( &self, identifier: &NSString, sender: Option<&AnyObject>, ) -> bool
Source§impl RefEncode for FPUIActionExtensionViewController
impl RefEncode for FPUIActionExtensionViewController
Source§const ENCODING_REF: Encoding = <NSViewController as ::objc2::RefEncode>::ENCODING_REF
const ENCODING_REF: Encoding = <NSViewController as ::objc2::RefEncode>::ENCODING_REF
impl DowncastTarget for FPUIActionExtensionViewController
impl Eq for FPUIActionExtensionViewController
Auto Trait Implementations§
impl !Freeze for FPUIActionExtensionViewController
impl !RefUnwindSafe for FPUIActionExtensionViewController
impl !Send for FPUIActionExtensionViewController
impl !Sync for FPUIActionExtensionViewController
impl !Unpin for FPUIActionExtensionViewController
impl !UnwindSafe for FPUIActionExtensionViewController
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<'a, T> MainThreadOnly for T
impl<'a, T> MainThreadOnly for T
Source§fn mtm(&self) -> MainThreadMarker
fn mtm(&self) -> MainThreadMarker
MainThreadMarker
from the main-thread-only object. Read more