LSMMap

Struct LSMMap 

Source
pub struct LSMMap { /* private fields */ }
Expand description

An opaque Core Foundation type representing an LSM map (mutable).

See also Apple’s documentation

Implementations§

Source§

impl LSMMap

Source

pub unsafe fn new( alloc: Option<&CFAllocator>, flags: CFOptionFlags, ) -> CFRetained<LSMMap>

Creates a new LSM map. Call CFRelease to dispose.

Source§

impl LSMMap

Source

pub unsafe fn set_properties(&self, properties: &CFDictionary)

Set a dictionary of properties for the map. LSM makes its own copy of the properties, there’s no need to retain them past this call.

§Safety

properties generics must be of the correct type.

Source

pub unsafe fn properties(&self) -> CFRetained<CFDictionary>

Get a dictionary of properties for the map. LSM retains ownership of this dictionary, do not release it.

Source

pub unsafe fn start_training(&self) -> i32

Puts the map into training mode, preparing it for the addition of more categories and/or texts. This function will be somewhat expensive, as it requires substantial data structure reorganization.

Source

pub unsafe fn add_category(&self) -> LSMCategory

Adds another category and returns its category identifier.

Source

pub unsafe fn category_count(&self) -> CFIndex

Returns the number of categories in the map.

Source

pub unsafe fn set_stop_words(&self, textref: &LSMText) -> i32

The specified words will be omitted from all classification efforts. Needs to be called before any other texts are created. The textref is no longer needed after this call.

Source

pub unsafe fn add_text(&self, textref: &LSMText, category: LSMCategory) -> i32

Adds a training text to the given category. The textref is no longer needed after this call.

Source

pub unsafe fn add_text_with_weight( &self, textref: &LSMText, category: LSMCategory, weight: c_float, ) -> i32

Adds a training text to the given category with a weight different from 1. The weight may be negative, but global counts will be pinned to 0. The textref is no longer needed after this call.

Source

pub unsafe fn compile(&self) -> i32

Compiles the map into executable form and puts it into mapping mode, preparing it for the classification of texts. This function is computationally expensive.

Source

pub unsafe fn new_clusters( alloc: Option<&CFAllocator>, mapref: &LSMMap, subset: Option<&CFArray>, num_clusters: CFIndex, flags: CFOptionFlags, ) -> Option<CFRetained<CFArray>>

Compute a set of clusters grouping similar categories or words. If subset is non-NULL, only perform clustering on the categories or words listed.

§Safety

subset generic must be of the correct type.

Source§

impl LSMMap

Source

pub unsafe fn apply_clusters(&self, clusters: &CFArray) -> i32

Group categories or words (tokens) into the specified sets of clusters.

§Safety

clusters generic must be of the correct type.

Source§

impl LSMMap

Source

pub unsafe fn write_to_url(&self, file: &CFURL, flags: CFOptionFlags) -> i32

Compiles the map if necessary and then stores it into the given file.

Source

pub unsafe fn from_url( alloc: Option<&CFAllocator>, file: &CFURL, flags: CFOptionFlags, ) -> Option<CFRetained<LSMMap>>

Loads a map from a given file.

Source§

impl LSMMap

Source

pub unsafe fn write_to_stream( &self, textref: Option<&LSMText>, stream: &CFWriteStream, options: CFOptionFlags, ) -> i32

Writes information about a map and/or text to a stream in text form

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 LSMMap

Source§

fn as_ref(&self) -> &AnyObject

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

impl AsRef<CFType> for LSMMap

Source§

fn as_ref(&self) -> &CFType

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

impl AsRef<LSMMap> for LSMMap

Source§

fn as_ref(&self) -> &Self

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

impl Borrow<AnyObject> for LSMMap

Source§

fn borrow(&self) -> &AnyObject

Immutably borrows from an owned value. Read more
Source§

impl Borrow<CFType> for LSMMap

Source§

fn borrow(&self) -> &CFType

Immutably borrows from an owned value. Read more
Source§

impl ConcreteType for LSMMap

Source§

fn type_id() -> CFTypeID

Returns the Core Foundation type identifier for LSM maps.

Source§

impl Debug for LSMMap

Source§

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

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

impl Deref for LSMMap

Source§

type Target = CFType

The resulting type after dereferencing.
Source§

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

Dereferences the value.
Source§

impl Hash for LSMMap

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 LSMMap

Source§

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

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

impl PartialEq for LSMMap

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 LSMMap

Source§

const ENCODING_REF: Encoding

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

impl Type for LSMMap

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 LSMMap

Auto Trait Implementations§

§

impl !Freeze for LSMMap

§

impl !RefUnwindSafe for LSMMap

§

impl !Send for LSMMap

§

impl !Sync for LSMMap

§

impl !Unpin for LSMMap

§

impl !UnwindSafe for LSMMap

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,