i_slint_core::model

Struct ReverseModel

Source
pub struct ReverseModel<M>(/* private fields */)
where
    M: Model + 'static;
Expand description

Provides a reversed view of another Model.

When the other Model is updated, the ReverseModel is updated accordingly.

Generic parameters:

  • M the type of the wrapped Model.

§Example

Here we have a VecModel holding crate::SharedStrings. It is then reversed into a ReverseModel.

let model = VecModel::from(vec![
    SharedString::from("Lorem"),
    SharedString::from("ipsum"),
    SharedString::from("dolor"),
]);

let reverse_model = ReverseModel::new(model);

assert_eq!(reverse_model.row_data(0).unwrap(), SharedString::from("dolor"));
assert_eq!(reverse_model.row_data(1).unwrap(), SharedString::from("ipsum"));
assert_eq!(reverse_model.row_data(2).unwrap(), SharedString::from("Lorem"));

Alternatively you can use the shortcut ModelExt::reverse.

let reverse_model = VecModel::from(vec![
    SharedString::from("Lorem"),
    SharedString::from("ipsum"),
    SharedString::from("dolor"),
]).reverse();
assert_eq!(reverse_model.row_data(0).unwrap(), SharedString::from("dolor"));
assert_eq!(reverse_model.row_data(1).unwrap(), SharedString::from("ipsum"));
assert_eq!(reverse_model.row_data(2).unwrap(), SharedString::from("Lorem"));

If you want to modify the underlying VecModel you can give the ReverseModel a Rc of it:

let model = Rc::new(VecModel::from(vec![
    SharedString::from("Lorem"),
    SharedString::from("ipsum"),
    SharedString::from("dolor"),
]));

let reverse_model = ReverseModel::new(model.clone());

assert_eq!(reverse_model.row_data(0).unwrap(), SharedString::from("dolor"));
assert_eq!(reverse_model.row_data(1).unwrap(), SharedString::from("ipsum"));
assert_eq!(reverse_model.row_data(2).unwrap(), SharedString::from("Lorem"));

model.push(SharedString::from("opsom"));

assert_eq!(reverse_model.row_data(0).unwrap(), SharedString::from("opsom"));
assert_eq!(reverse_model.row_data(1).unwrap(), SharedString::from("dolor"));
assert_eq!(reverse_model.row_data(2).unwrap(), SharedString::from("ipsum"));
assert_eq!(reverse_model.row_data(3).unwrap(), SharedString::from("Lorem"));

Implementations§

Source§

impl<M> ReverseModel<M>
where M: Model + 'static,

Source

pub fn new(wrapped_model: M) -> Self

Creates a new ReverseModel based on the given wrapped_model. Alternatively you can use ModelExt::reverse on your Model.

Source

pub fn source_model(&self) -> &M

Returns a reference to the inner model

Trait Implementations§

Source§

impl<M> Model for ReverseModel<M>
where M: Model + 'static,

Source§

type Data = <M as Model>::Data

The model data: A model is a set of rows and each row has this data
Source§

fn row_count(&self) -> usize

The number of rows in the model
Source§

fn row_data(&self, row: usize) -> Option<Self::Data>

Returns the data for a particular row. Read more
Source§

fn set_row_data(&self, row: usize, data: Self::Data)

Sets the data for a particular row. Read more
Source§

fn model_tracker(&self) -> &dyn ModelTracker

The implementation should return a reference to its ModelNotify field. Read more
Source§

fn as_any(&self) -> &dyn Any

Return something that can be downcast’ed (typically self) Read more
Source§

fn iter(&self) -> ModelIterator<'_, Self::Data>
where Self: Sized,

Returns an iterator visiting all elements of the model.

Auto Trait Implementations§

§

impl<M> Freeze for ReverseModel<M>

§

impl<M> !RefUnwindSafe for ReverseModel<M>

§

impl<M> !Send for ReverseModel<M>

§

impl<M> !Sync for ReverseModel<M>

§

impl<M> Unpin for ReverseModel<M>

§

impl<M> !UnwindSafe for ReverseModel<M>

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<T> ModelExt for T
where T: Model,

Source§

fn row_data_tracked(&self, row: usize) -> Option<Self::Data>

Convenience function that calls ModelTracker::track_row_data_changes before returning Model::row_data. Read more
Source§

fn map<F, U>(self, map_function: F) -> MapModel<Self, F>
where Self: Sized + 'static, F: Fn(Self::Data) -> U + 'static,

Returns a new Model where all elements are mapped by the function map_function. This is a shortcut for MapModel::new().
Source§

fn filter<F>(self, filter_function: F) -> FilterModel<Self, F>
where Self: Sized + 'static, F: Fn(&Self::Data) -> bool + 'static,

Returns a new Model where the elements are filtered by the function filter_function. This is a shortcut for FilterModel::new().
Source§

fn sort(self) -> SortModel<Self, AscendingSortHelper>
where Self: Sized + 'static, Self::Data: Ord,

Returns a new Model where the elements are sorted ascending. This is a shortcut for SortModel::new_ascending().
Source§

fn sort_by<F>(self, sort_function: F) -> SortModel<Self, F>
where Self: Sized + 'static, F: FnMut(&Self::Data, &Self::Data) -> Ordering + 'static,

Returns a new Model where the elements are sorted by the function sort_function. This is a shortcut for SortModel::new().
Source§

fn reverse(self) -> ReverseModel<Self>
where Self: Sized + 'static,

Returns a new Model where the elements are reversed. This is a shortcut for ReverseModel::new().
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.