CGImageMetadataTag

Struct CGImageMetadataTag 

Source
#[repr(C)]
pub struct CGImageMetadataTag { /* private fields */ }
Available on crate feature CGImageMetadata only.
Expand description

an individual metadata tag

A CGImageMetadataTag encapsulates an EXIF, IPTC, or XMP property. All tags contain a namespace, prefix, name, type, and value. Please see

 CGImageMetadataTagCreate

for more details.

See also Apple’s documentation

Implementations§

Source§

impl CGImageMetadataTag

Source

pub unsafe fn new( xmlns: &CFString, prefix: Option<&CFString>, name: &CFString, type: CGImageMetadataType, value: &CFType, ) -> Option<CFRetained<CGImageMetadataTag>>

Creates a new CGImageMetadataTag

Parameter xmlns: The namespace for the tag. The value can be a common XMP namespace defined above, such as kCGImageMetadataNamespaceExif, or a CFString with a custom namespace URI. Custom namespaces must be a valid XML namespace. By convention, namespaces should end with either ‘/’ or ‘#’. For example, exif uses the namespace “http://ns.adobe.com/exif/1.0/”.

Parameter prefix: An abbreviation for the XML namespace. The value can be NULL if the namespace is defined as a constant. Custom prefixes must be a valid XML name. For example, the prefix used for “http://ns.adobe.com/exif/1.0/” is “exif”. The XMP serialization of the tag will use the prefix. Prefixes are also important for path-based CGImageMetadata functions, such as

 CGImageMetadataCopyStringValueWithPath

or

 CGImageMetadataSetValueWithPath

.

Parameter name: The name of the tag. It must be a valid XMP name.

Parameter type: The type of the tag’s value. Must be a constant from

  
 CGImageMetadataType

.

Parameter value: The value of the tag. Allowable CFTypes include CFStringRef, CFNumberRef, CFBooleanRef, CFArrayRef, and CFDictionaryRef. The CFType of ‘value’ must correspond to the ‘type’. The elements of a CFArray must be either a CFStringRef or CGImageMetadataTagRef. The keys of a CFDictionary must be CFStringRefs with valid XMP names. The values of a CFDictionary must be either CFStringRefs or CGImageMetadataTagRefs. A shallow copy of the value is stored in the tag. Therefore, modifying a mutable value after the tag is created will not affect the tag’s value.

Returns: Returns a pointer to a new CGImageMetadataTag. Returns NULL if a tag could not be created with the specified parameters.

Source

pub unsafe fn namespace( self: &CGImageMetadataTag, ) -> Option<CFRetained<CFString>>

*!

Returns a copy of the tag’s namespace

Source

pub unsafe fn prefix(self: &CGImageMetadataTag) -> Option<CFRetained<CFString>>

Returns a copy of the tag’s prefix

Source

pub unsafe fn name(self: &CGImageMetadataTag) -> Option<CFRetained<CFString>>

Returns a copy of the tag’s name

Source

pub unsafe fn value(self: &CGImageMetadataTag) -> Option<CFRetained<CFType>>

Returns a shallow copy of the tag’s value

This function should only be used to read the tag’s value. CGImageMetadataCopyTagWithPath returns a copy of the tag (including a copy of the tag’s value). Therefore mutating a tag’s value returned from this function may not actually mutate the value in the CGImageMetadata. It is recommended to create a new tag followed by CGImageMetadataSetTagWithPath, or use CGImageMetadataSetValueWithPath to mutate a metadata value.

Source

pub unsafe fn type(self: &CGImageMetadataTag) -> CGImageMetadataType

Get the type of the CGImageMetadataTag

Returns: Returns a CGImageMetadataType constant for the CGImageMetadataTag. This is primarily used to determine how to interpret the tag’s value.

Source

pub unsafe fn qualifiers( self: &CGImageMetadataTag, ) -> Option<CFRetained<CFArray>>

Return a copy of the tag’s qualifiers

XMP allows properties to contain supplemental properties called qualifiers. Qualifiers are themselves CGImageMetadataTags with their own namespace, prefix, name, and value. A common use is the xml:lang qualifier for elements of an alternate-text array.

Returns: Returns a copy of the array of qualifiers. Elements of the array are CGImageMetadataTags. Returns NULL if the tag does not have any qualifiers. The copy is shallow, the qualifiers are not deep copied.

Methods from Deref<Target = CFType>§

Source

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

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

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 CGImageMetadataTag

Source§

fn as_ref(&self) -> &AnyObject

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

impl AsRef<CFType> for CGImageMetadataTag

Source§

fn as_ref(&self) -> &CFType

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

impl AsRef<CGImageMetadataTag> for CGImageMetadataTag

Source§

fn as_ref(&self) -> &Self

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

impl Borrow<AnyObject> for CGImageMetadataTag

Source§

fn borrow(&self) -> &AnyObject

Immutably borrows from an owned value. Read more
Source§

impl Borrow<CFType> for CGImageMetadataTag

Source§

fn borrow(&self) -> &CFType

Immutably borrows from an owned value. Read more
Source§

impl ConcreteType for CGImageMetadataTag

Source§

fn type_id() -> CFTypeID

*!

Gets the type identifier for the CGImageMetadataTag opaque type

Returns: the type identifier for the CGImageMetadataTagGetTypeID opaque type

Source§

impl Debug for CGImageMetadataTag

Source§

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

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

impl Deref for CGImageMetadataTag

Source§

type Target = CFType

The resulting type after dereferencing.
Source§

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

Dereferences the value.
Source§

impl Hash for CGImageMetadataTag

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 CGImageMetadataTag

Source§

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

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

impl PartialEq for CGImageMetadataTag

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 CGImageMetadataTag

Source§

const ENCODING_REF: Encoding

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

impl Type for CGImageMetadataTag

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 CGImageMetadataTag

Auto Trait Implementations§

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,