use crate::Sorter;
use glib::{
prelude::*,
signal::{connect_raw, SignalHandlerId},
translate::*,
};
use std::{boxed::Box as Box_, fmt, mem::transmute};
glib::wrapper! {
#[doc(alias = "GtkSortListModel")]
pub struct SortListModel(Object<ffi::GtkSortListModel, ffi::GtkSortListModelClass>) @implements gio::ListModel;
match fn {
type_ => || ffi::gtk_sort_list_model_get_type(),
}
}
impl SortListModel {
#[doc(alias = "gtk_sort_list_model_new")]
pub fn new(
model: Option<impl IsA<gio::ListModel>>,
sorter: Option<impl IsA<Sorter>>,
) -> SortListModel {
assert_initialized_main_thread!();
unsafe {
from_glib_full(ffi::gtk_sort_list_model_new(
model.map(|p| p.upcast()).into_glib_ptr(),
sorter.map(|p| p.upcast()).into_glib_ptr(),
))
}
}
pub fn builder() -> SortListModelBuilder {
SortListModelBuilder::new()
}
#[doc(alias = "gtk_sort_list_model_get_incremental")]
#[doc(alias = "get_incremental")]
pub fn is_incremental(&self) -> bool {
unsafe {
from_glib(ffi::gtk_sort_list_model_get_incremental(
self.to_glib_none().0,
))
}
}
#[doc(alias = "gtk_sort_list_model_get_model")]
#[doc(alias = "get_model")]
pub fn model(&self) -> Option<gio::ListModel> {
unsafe { from_glib_none(ffi::gtk_sort_list_model_get_model(self.to_glib_none().0)) }
}
#[doc(alias = "gtk_sort_list_model_get_pending")]
#[doc(alias = "get_pending")]
pub fn pending(&self) -> u32 {
unsafe { ffi::gtk_sort_list_model_get_pending(self.to_glib_none().0) }
}
#[doc(alias = "gtk_sort_list_model_get_sorter")]
#[doc(alias = "get_sorter")]
pub fn sorter(&self) -> Option<Sorter> {
unsafe { from_glib_none(ffi::gtk_sort_list_model_get_sorter(self.to_glib_none().0)) }
}
#[doc(alias = "gtk_sort_list_model_set_incremental")]
pub fn set_incremental(&self, incremental: bool) {
unsafe {
ffi::gtk_sort_list_model_set_incremental(
self.to_glib_none().0,
incremental.into_glib(),
);
}
}
#[doc(alias = "gtk_sort_list_model_set_model")]
pub fn set_model(&self, model: Option<&impl IsA<gio::ListModel>>) {
unsafe {
ffi::gtk_sort_list_model_set_model(
self.to_glib_none().0,
model.map(|p| p.as_ref()).to_glib_none().0,
);
}
}
#[doc(alias = "gtk_sort_list_model_set_sorter")]
pub fn set_sorter(&self, sorter: Option<&impl IsA<Sorter>>) {
unsafe {
ffi::gtk_sort_list_model_set_sorter(
self.to_glib_none().0,
sorter.map(|p| p.as_ref()).to_glib_none().0,
);
}
}
#[doc(alias = "incremental")]
pub fn connect_incremental_notify<F: Fn(&Self) + 'static>(&self, f: F) -> SignalHandlerId {
unsafe extern "C" fn notify_incremental_trampoline<F: Fn(&SortListModel) + 'static>(
this: *mut ffi::GtkSortListModel,
_param_spec: glib::ffi::gpointer,
f: glib::ffi::gpointer,
) {
let f: &F = &*(f as *const F);
f(&from_glib_borrow(this))
}
unsafe {
let f: Box_<F> = Box_::new(f);
connect_raw(
self.as_ptr() as *mut _,
b"notify::incremental\0".as_ptr() as *const _,
Some(transmute::<_, unsafe extern "C" fn()>(
notify_incremental_trampoline::<F> as *const (),
)),
Box_::into_raw(f),
)
}
}
#[doc(alias = "model")]
pub fn connect_model_notify<F: Fn(&Self) + 'static>(&self, f: F) -> SignalHandlerId {
unsafe extern "C" fn notify_model_trampoline<F: Fn(&SortListModel) + 'static>(
this: *mut ffi::GtkSortListModel,
_param_spec: glib::ffi::gpointer,
f: glib::ffi::gpointer,
) {
let f: &F = &*(f as *const F);
f(&from_glib_borrow(this))
}
unsafe {
let f: Box_<F> = Box_::new(f);
connect_raw(
self.as_ptr() as *mut _,
b"notify::model\0".as_ptr() as *const _,
Some(transmute::<_, unsafe extern "C" fn()>(
notify_model_trampoline::<F> as *const (),
)),
Box_::into_raw(f),
)
}
}
#[doc(alias = "pending")]
pub fn connect_pending_notify<F: Fn(&Self) + 'static>(&self, f: F) -> SignalHandlerId {
unsafe extern "C" fn notify_pending_trampoline<F: Fn(&SortListModel) + 'static>(
this: *mut ffi::GtkSortListModel,
_param_spec: glib::ffi::gpointer,
f: glib::ffi::gpointer,
) {
let f: &F = &*(f as *const F);
f(&from_glib_borrow(this))
}
unsafe {
let f: Box_<F> = Box_::new(f);
connect_raw(
self.as_ptr() as *mut _,
b"notify::pending\0".as_ptr() as *const _,
Some(transmute::<_, unsafe extern "C" fn()>(
notify_pending_trampoline::<F> as *const (),
)),
Box_::into_raw(f),
)
}
}
#[doc(alias = "sorter")]
pub fn connect_sorter_notify<F: Fn(&Self) + 'static>(&self, f: F) -> SignalHandlerId {
unsafe extern "C" fn notify_sorter_trampoline<F: Fn(&SortListModel) + 'static>(
this: *mut ffi::GtkSortListModel,
_param_spec: glib::ffi::gpointer,
f: glib::ffi::gpointer,
) {
let f: &F = &*(f as *const F);
f(&from_glib_borrow(this))
}
unsafe {
let f: Box_<F> = Box_::new(f);
connect_raw(
self.as_ptr() as *mut _,
b"notify::sorter\0".as_ptr() as *const _,
Some(transmute::<_, unsafe extern "C" fn()>(
notify_sorter_trampoline::<F> as *const (),
)),
Box_::into_raw(f),
)
}
}
}
impl Default for SortListModel {
fn default() -> Self {
glib::object::Object::new::<Self>()
}
}
#[must_use = "The builder must be built to be used"]
pub struct SortListModelBuilder {
builder: glib::object::ObjectBuilder<'static, SortListModel>,
}
impl SortListModelBuilder {
fn new() -> Self {
Self {
builder: glib::object::Object::builder(),
}
}
pub fn incremental(self, incremental: bool) -> Self {
Self {
builder: self.builder.property("incremental", incremental),
}
}
pub fn model(self, model: &impl IsA<gio::ListModel>) -> Self {
Self {
builder: self.builder.property("model", model.clone().upcast()),
}
}
pub fn sorter(self, sorter: &impl IsA<Sorter>) -> Self {
Self {
builder: self.builder.property("sorter", sorter.clone().upcast()),
}
}
#[must_use = "Building the object from the builder is usually expensive and is not expected to have side effects"]
pub fn build(self) -> SortListModel {
self.builder.build()
}
}
impl fmt::Display for SortListModel {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
f.write_str("SortListModel")
}
}