MDItem

Struct MDItem 

Source
pub struct MDItem { /* private fields */ }
Available on crate feature MDItem only.
Expand description

This is the type of a reference to MDItems.

See also Apple’s documentation

Implementations§

Source§

impl MDItem

Source

pub unsafe fn new( allocator: Option<&CFAllocator>, path: Option<&CFString>, ) -> Option<CFRetained<MDItem>>

Available on crate feature Metadata only.

Returns an metadata item for the given path.

Parameter allocator: The CFAllocator which should be used to allocate memory for the query and its sub-storage. This parameter may be NULL in which case the current default CFAllocator is used.

Parameter path: A path to the file for which to create the MDItem. [[Currently, the path must exist. MDItemRefs may or may not be uniqued. Use CFEqual() to compare them.]]

Returns: An MDItemRef, or NULL on failure.

§Safety
  • allocator might not allow None.
  • path might not allow None.
Source

pub unsafe fn with_url( allocator: Option<&CFAllocator>, url: Option<&CFURL>, ) -> Option<CFRetained<MDItem>>

Available on crate feature Metadata only.

Returns an metadata item for the given path.

Parameter allocator: The CFAllocator which should be used to allocate memory for the query and its sub-storage. This parameter may be NULL in which case the current default CFAllocator is used.

Parameter url: A url to the file for which to create the MDItem. [[Currently, the file must exist. MDItemRefs may or may not be uniqued. Use CFEqual() to compare them.]]

Returns: An MDItemRef, or NULL on failure.

§Safety
  • allocator might not allow None.
  • url might not allow None.
Source§

impl MDItem

Source

pub unsafe fn attribute( &self, name: Option<&CFString>, ) -> Option<CFRetained<CFType>>

Available on crate feature Metadata only.

Returns the value of the given attribute for the item.

Parameter item: The item to be interrogated.

Parameter name: The name of the desired attribute.

Returns: A CFTypeRef, or NULL on failure, or if the attribute does not exist, of if the attribute is not readable.

§Safety

name might not allow None.

Source

pub unsafe fn attributes( &self, names: Option<&CFArray>, ) -> Option<CFRetained<CFDictionary>>

Available on crate feature Metadata only.

Returns the values of the given attributes for the item.

Parameter item: The item to be interrogated.

Parameter names: A CFArray of the names of the desired attributes.

Returns: A CFDictionary where the keys are the attribute names, and the values are the attribute values, or NULL on failure. If an attribute does not exist, or is unreadable, there will be no key-value pair for it in the dictionary.

§Safety
  • names generic must be of the correct type.
  • names might not allow None.
Source

pub unsafe fn attribute_names(&self) -> Option<CFRetained<CFArray>>

Available on crate feature Metadata only.

Returns an array of the attribute names existing in the item.

Parameter item: The item to be interrogated.

Returns: A CFArray of CFString attribute names, or NULL on failure.

Source§

impl MDItem

Source

pub unsafe fn cache_file_descriptors( items: Option<&CFArray>, completion_handler: Option<&DynBlock<dyn Fn(*const CFArray)>>, )

Available on crate features Metadata and block2 only.
§Safety
  • items generic must be of the correct type.
  • items might not allow None.
  • completion_handler might not allow None.
Source§

impl MDItem

Source

pub unsafe fn labels(&self) -> Option<CFRetained<CFArray>>

Available on crate features Metadata and MDLabel only.

Returns an array of the labels set on the specified item.

Parameter item: The item to be interrogated.

Returns: A CFArrayRef containing MDLabelRefs for the labels set on the item, or NULL on failure.

Source

pub unsafe fn set_label(&self, label: Option<&MDLabel>) -> bool

Available on crate features Metadata and MDLabel only.

Sets a label on the specified item.

Parameter item: The item to be updated.

Parameter label: The label.

Returns: True if the label was successfully set on the item, false otherwise.

§Safety

label might not allow None.

Source

pub unsafe fn remove_label(&self, label: Option<&MDLabel>) -> bool

Available on crate features Metadata and MDLabel only.

Removes a label from the specified item.

Parameter item: The item to be updated.

Parameter label: The label.

Returns: True if the label was successfully removed from the item, false otherwise.

§Safety

label might not allow None.

Methods from Deref<Target = CFType>§

Source

pub fn downcast_ref<T>(&self) -> Option<&T>
where T: ConcreteType,

Available on crate features SearchKit and SKDocument only.

Attempt to downcast the type to that of type T.

This is the reference-variant. Use CFRetained::downcast if you want to convert a retained type. See also ConcreteType for more details on which types support being converted to.

Source

pub fn retain_count(&self) -> usize

Available on crate features SearchKit and SKDocument only.

Get the reference count of the object.

This function may be useful for debugging. You normally do not use this function otherwise.

Beware that some things (like CFNumbers, small CFStrings etc.) may not have a normal retain count for optimization purposes, and can return usize::MAX in that case.

Trait Implementations§

Source§

impl AsRef<AnyObject> for MDItem

Available on crate feature Metadata only.
Source§

fn as_ref(&self) -> &AnyObject

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<CFType> for MDItem

Available on crate feature Metadata only.
Source§

fn as_ref(&self) -> &CFType

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<MDItem> for MDItem

Available on crate feature Metadata only.
Source§

fn as_ref(&self) -> &Self

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl Borrow<AnyObject> for MDItem

Available on crate feature Metadata only.
Source§

fn borrow(&self) -> &AnyObject

Immutably borrows from an owned value. Read more
Source§

impl Borrow<CFType> for MDItem

Available on crate feature Metadata only.
Source§

fn borrow(&self) -> &CFType

Immutably borrows from an owned value. Read more
Source§

impl ConcreteType for MDItem

Available on crate feature Metadata only.
Source§

fn type_id() -> CFTypeID

Returns the type identifier of all MDItem instances.

Source§

impl Debug for MDItem

Available on crate feature Metadata only.
Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Deref for MDItem

Available on crate feature Metadata only.
Source§

type Target = CFType

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl Hash for MDItem

Available on crate feature Metadata only.
Source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl Message for MDItem

Available on crate feature Metadata only.
Source§

fn retain(&self) -> Retained<Self>
where Self: Sized,

Increment the reference count of the receiver. Read more
Source§

impl PartialEq for MDItem

Available on crate feature Metadata only.
Source§

fn eq(&self, other: &Self) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl RefEncode for MDItem

Available on crate feature Metadata only.
Source§

const ENCODING_REF: Encoding

The Objective-C type-encoding for a reference of this type. Read more
Source§

impl Type for MDItem

Available on crate feature Metadata only.
Source§

fn retain(&self) -> CFRetained<Self>
where Self: Sized,

Increment the reference count of the receiver. Read more
Source§

fn as_concrete_TypeRef(&self) -> &Self

👎Deprecated: this is redundant
Helper for easier transition from the core-foundation crate.
Source§

unsafe fn wrap_under_get_rule(ptr: *const Self) -> CFRetained<Self>
where Self: Sized,

👎Deprecated: use CFRetained::retain
Helper for easier transition from the core-foundation crate. Read more
Source§

fn as_CFTypeRef(&self) -> &CFType
where Self: AsRef<CFType>,

👎Deprecated: this is redundant (CF types deref to CFType)
Helper for easier transition from the core-foundation crate.
Source§

unsafe fn wrap_under_create_rule(ptr: *const Self) -> CFRetained<Self>
where Self: Sized,

👎Deprecated: use CFRetained::from_raw
Helper for easier transition from the core-foundation crate. Read more
Source§

impl Eq for MDItem

Available on crate feature Metadata only.

Auto Trait Implementations§

§

impl !Freeze for MDItem

§

impl !RefUnwindSafe for MDItem

§

impl !Send for MDItem

§

impl !Sync for MDItem

§

impl !Unpin for MDItem

§

impl !UnwindSafe for MDItem

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> AutoreleaseSafe for T
where T: ?Sized,