pub struct NSManagedObjectContext { /* private fields */ }NSManagedObjectContext only.Expand description
Implementations§
Source§impl NSManagedObjectContext
impl NSManagedObjectContext
pub unsafe fn new() -> Retained<Self>
pub unsafe fn init(this: Allocated<Self>) -> Retained<Self>
pub unsafe fn initWithConcurrencyType( this: Allocated<Self>, ct: NSManagedObjectContextConcurrencyType, ) -> Retained<Self>
Sourcepub unsafe fn performBlock(&self, block: &DynBlock<dyn Fn()>)
Available on crate feature block2 only.
pub unsafe fn performBlock(&self, block: &DynBlock<dyn Fn()>)
block2 only.§Safety
block block must be sendable.
Sourcepub unsafe fn performBlockAndWait(&self, block: &DynBlock<dyn Fn() + '_>)
Available on crate feature block2 only.
pub unsafe fn performBlockAndWait(&self, block: &DynBlock<dyn Fn() + '_>)
block2 only.§Safety
block block must be sendable.
pub unsafe fn persistentStoreCoordinator( &self, ) -> Option<Retained<NSPersistentStoreCoordinator>>
NSPersistentStoreCoordinator only.Sourcepub unsafe fn setPersistentStoreCoordinator(
&self,
persistent_store_coordinator: Option<&NSPersistentStoreCoordinator>,
)
Available on crate feature NSPersistentStoreCoordinator only.
pub unsafe fn setPersistentStoreCoordinator( &self, persistent_store_coordinator: Option<&NSPersistentStoreCoordinator>, )
NSPersistentStoreCoordinator only.Setter for persistentStoreCoordinator.
pub unsafe fn parentContext(&self) -> Option<Retained<NSManagedObjectContext>>
Sourcepub unsafe fn setParentContext(
&self,
parent_context: Option<&NSManagedObjectContext>,
)
pub unsafe fn setParentContext( &self, parent_context: Option<&NSManagedObjectContext>, )
Setter for parentContext.
pub unsafe fn name(&self) -> Option<Retained<NSString>>
Sourcepub unsafe fn undoManager(
&self,
mtm: MainThreadMarker,
) -> Option<Retained<NSUndoManager>>
pub unsafe fn undoManager( &self, mtm: MainThreadMarker, ) -> Option<Retained<NSUndoManager>>
Sourcepub unsafe fn setUndoManager(&self, undo_manager: Option<&NSUndoManager>)
pub unsafe fn setUndoManager(&self, undo_manager: Option<&NSUndoManager>)
Sourcepub unsafe fn hasChanges(&self) -> bool
pub unsafe fn hasChanges(&self) -> bool
Sourcepub unsafe fn userInfo(&self) -> Retained<NSMutableDictionary>
pub unsafe fn userInfo(&self) -> Retained<NSMutableDictionary>
This property is not atomic.
§Safety
- The returned generic should be of the correct type.
- This might not be thread-safe.
pub unsafe fn concurrencyType(&self) -> NSManagedObjectContextConcurrencyType
pub unsafe fn objectRegisteredForID( &self, object_id: &NSManagedObjectID, ) -> Option<Retained<NSManagedObject>>
NSManagedObject and NSManagedObjectID only.pub unsafe fn objectWithID( &self, object_id: &NSManagedObjectID, ) -> Retained<NSManagedObject>
NSManagedObject and NSManagedObjectID only.pub unsafe fn existingObjectWithID_error( &self, object_id: &NSManagedObjectID, ) -> Result<Retained<NSManagedObject>, Retained<NSError>>
NSManagedObject and NSManagedObjectID only.Sourcepub unsafe fn executeFetchRequest_error(
&self,
request: &NSFetchRequest,
) -> Result<Retained<NSArray>, Retained<NSError>>
Available on crate features NSFetchRequest and NSPersistentStoreRequest only.
pub unsafe fn executeFetchRequest_error( &self, request: &NSFetchRequest, ) -> Result<Retained<NSArray>, Retained<NSError>>
NSFetchRequest and NSPersistentStoreRequest only.§Safety
request generic should be bound by NSFetchRequestResult.
pub unsafe fn executeRequest_error( &self, request: &NSPersistentStoreRequest, ) -> Result<Retained<NSPersistentStoreResult>, Retained<NSError>>
NSPersistentStoreRequest and NSPersistentStoreResult only.pub unsafe fn insertObject(&self, object: &NSManagedObject)
NSManagedObject only.pub unsafe fn deleteObject(&self, object: &NSManagedObject)
NSManagedObject only.pub unsafe fn refreshObject_mergeChanges( &self, object: &NSManagedObject, flag: bool, )
NSManagedObject only.pub unsafe fn detectConflictsForObject(&self, object: &NSManagedObject)
NSManagedObject only.Sourcepub unsafe fn observeValueForKeyPath_ofObject_change_context(
&self,
key_path: Option<&NSString>,
object: Option<&AnyObject>,
change: Option<&NSDictionary<NSString, AnyObject>>,
context: *mut c_void,
)
pub unsafe fn observeValueForKeyPath_ofObject_change_context( &self, key_path: Option<&NSString>, object: Option<&AnyObject>, change: Option<&NSDictionary<NSString, AnyObject>>, context: *mut c_void, )
§Safety
objectshould be of the correct type.changegeneric should be of the correct type.contextmust be a valid pointer or null.
pub unsafe fn processPendingChanges(&self)
Sourcepub unsafe fn assignObject_toPersistentStore(
&self,
object: &AnyObject,
store: &NSPersistentStore,
)
Available on crate feature NSPersistentStore only.
pub unsafe fn assignObject_toPersistentStore( &self, object: &AnyObject, store: &NSPersistentStore, )
NSPersistentStore only.§Safety
object should be of the correct type.
Sourcepub unsafe fn insertedObjects(&self) -> Retained<NSSet<NSManagedObject>>
Available on crate feature NSManagedObject only.
pub unsafe fn insertedObjects(&self) -> Retained<NSSet<NSManagedObject>>
NSManagedObject only.Sourcepub unsafe fn updatedObjects(&self) -> Retained<NSSet<NSManagedObject>>
Available on crate feature NSManagedObject only.
pub unsafe fn updatedObjects(&self) -> Retained<NSSet<NSManagedObject>>
NSManagedObject only.Sourcepub unsafe fn deletedObjects(&self) -> Retained<NSSet<NSManagedObject>>
Available on crate feature NSManagedObject only.
pub unsafe fn deletedObjects(&self) -> Retained<NSSet<NSManagedObject>>
NSManagedObject only.Sourcepub unsafe fn registeredObjects(&self) -> Retained<NSSet<NSManagedObject>>
Available on crate feature NSManagedObject only.
pub unsafe fn registeredObjects(&self) -> Retained<NSSet<NSManagedObject>>
NSManagedObject only.pub unsafe fn undo(&self)
pub unsafe fn redo(&self)
pub unsafe fn reset(&self)
pub unsafe fn rollback(&self)
pub unsafe fn save(&self) -> Result<(), Retained<NSError>>
pub unsafe fn refreshAllObjects(&self)
pub unsafe fn lock(&self)
pub unsafe fn unlock(&self)
pub unsafe fn tryLock(&self) -> bool
Sourcepub unsafe fn propagatesDeletesAtEndOfEvent(&self) -> bool
pub unsafe fn propagatesDeletesAtEndOfEvent(&self) -> bool
Sourcepub unsafe fn setPropagatesDeletesAtEndOfEvent(
&self,
propagates_deletes_at_end_of_event: bool,
)
pub unsafe fn setPropagatesDeletesAtEndOfEvent( &self, propagates_deletes_at_end_of_event: bool, )
Sourcepub unsafe fn retainsRegisteredObjects(&self) -> bool
pub unsafe fn retainsRegisteredObjects(&self) -> bool
Sourcepub unsafe fn setRetainsRegisteredObjects(
&self,
retains_registered_objects: bool,
)
pub unsafe fn setRetainsRegisteredObjects( &self, retains_registered_objects: bool, )
pub unsafe fn shouldDeleteInaccessibleFaults(&self) -> bool
Sourcepub unsafe fn setShouldDeleteInaccessibleFaults(
&self,
should_delete_inaccessible_faults: bool,
)
pub unsafe fn setShouldDeleteInaccessibleFaults( &self, should_delete_inaccessible_faults: bool, )
Setter for shouldDeleteInaccessibleFaults.
pub unsafe fn shouldHandleInaccessibleFault_forObjectID_triggeredByProperty( &self, fault: &NSManagedObject, oid: &NSManagedObjectID, property: Option<&NSPropertyDescription>, ) -> bool
NSManagedObject and NSManagedObjectID and NSPropertyDescription only.pub unsafe fn stalenessInterval(&self) -> NSTimeInterval
Sourcepub unsafe fn setStalenessInterval(&self, staleness_interval: NSTimeInterval)
pub unsafe fn setStalenessInterval(&self, staleness_interval: NSTimeInterval)
Setter for stalenessInterval.
pub unsafe fn mergePolicy(&self) -> Retained<AnyObject>
Sourcepub unsafe fn setMergePolicy(&self, merge_policy: &AnyObject)
pub unsafe fn setMergePolicy(&self, merge_policy: &AnyObject)
pub unsafe fn obtainPermanentIDsForObjects_error( &self, objects: &NSArray<NSManagedObject>, ) -> Result<(), Retained<NSError>>
NSManagedObject only.pub unsafe fn mergeChangesFromContextDidSaveNotification( &self, notification: &NSNotification, )
Sourcepub unsafe fn mergeChangesFromRemoteContextSave_intoContexts(
change_notification_data: &NSDictionary,
contexts: &NSArray<NSManagedObjectContext>,
)
pub unsafe fn mergeChangesFromRemoteContextSave_intoContexts( change_notification_data: &NSDictionary, contexts: &NSArray<NSManagedObjectContext>, )
§Safety
change_notification_data generic should be of the correct type.
Sourcepub unsafe fn queryGenerationToken(
&self,
) -> Option<Retained<NSQueryGenerationToken>>
Available on crate feature NSQueryGenerationToken only.
pub unsafe fn queryGenerationToken( &self, ) -> Option<Retained<NSQueryGenerationToken>>
NSQueryGenerationToken only.pub unsafe fn setQueryGenerationFromToken_error( &self, generation: Option<&NSQueryGenerationToken>, ) -> Result<(), Retained<NSError>>
NSQueryGenerationToken only.Sourcepub unsafe fn automaticallyMergesChangesFromParent(&self) -> bool
pub unsafe fn automaticallyMergesChangesFromParent(&self) -> bool
Sourcepub unsafe fn setAutomaticallyMergesChangesFromParent(
&self,
automatically_merges_changes_from_parent: bool,
)
pub unsafe fn setAutomaticallyMergesChangesFromParent( &self, automatically_merges_changes_from_parent: bool, )
pub unsafe fn transactionAuthor(&self) -> Option<Retained<NSString>>
Sourcepub unsafe fn setTransactionAuthor(&self, transaction_author: Option<&NSString>)
pub unsafe fn setTransactionAuthor(&self, transaction_author: Option<&NSString>)
Setter for transactionAuthor.
This is copied when set.
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<AnyObject> for NSManagedObjectContext
impl AsRef<AnyObject> for NSManagedObjectContext
Source§impl AsRef<NSObject> for NSManagedObjectContext
impl AsRef<NSObject> for NSManagedObjectContext
Source§impl Borrow<AnyObject> for NSManagedObjectContext
impl Borrow<AnyObject> for NSManagedObjectContext
Source§impl Borrow<NSObject> for NSManagedObjectContext
impl Borrow<NSObject> for NSManagedObjectContext
Source§impl ClassType for NSManagedObjectContext
impl ClassType for NSManagedObjectContext
Source§const NAME: &'static str = "NSManagedObjectContext"
const NAME: &'static str = "NSManagedObjectContext"
Source§type ThreadKind = <<NSManagedObjectContext as ClassType>::Super as ClassType>::ThreadKind
type ThreadKind = <<NSManagedObjectContext as ClassType>::Super as ClassType>::ThreadKind
Source§impl Debug for NSManagedObjectContext
impl Debug for NSManagedObjectContext
Source§impl Deref for NSManagedObjectContext
impl Deref for NSManagedObjectContext
Source§impl Hash for NSManagedObjectContext
impl Hash for NSManagedObjectContext
Source§impl Message for NSManagedObjectContext
impl Message for NSManagedObjectContext
Source§impl NSCoding for NSManagedObjectContext
impl NSCoding for NSManagedObjectContext
Source§impl NSLocking for NSManagedObjectContext
impl NSLocking for NSManagedObjectContext
Source§impl NSObjectProtocol for NSManagedObjectContext
impl NSObjectProtocol for NSManagedObjectContext
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