1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
use CellArea;
use CellRenderer;
use TreeIter;
use TreeModel;
use ffi;
use glib::object::IsA;
use glib::translate::*;
use std::boxed::Box as Box_;
use std::fmt;
glib_wrapper! {
pub struct CellLayout(Interface<ffi::GtkCellLayout>);
match fn {
get_type => || ffi::gtk_cell_layout_get_type(),
}
}
pub const NONE_CELL_LAYOUT: Option<&CellLayout> = None;
pub trait CellLayoutExt: 'static {
fn add_attribute<P: IsA<CellRenderer>>(&self, cell: &P, attribute: &str, column: i32);
fn clear(&self);
fn clear_attributes<P: IsA<CellRenderer>>(&self, cell: &P);
fn get_area(&self) -> Option<CellArea>;
fn get_cells(&self) -> Vec<CellRenderer>;
fn pack_end<P: IsA<CellRenderer>>(&self, cell: &P, expand: bool);
fn pack_start<P: IsA<CellRenderer>>(&self, cell: &P, expand: bool);
fn reorder<P: IsA<CellRenderer>>(&self, cell: &P, position: i32);
fn set_cell_data_func<P: IsA<CellRenderer>>(&self, cell: &P, func: Option<Box<dyn Fn(&CellLayout, &CellRenderer, &TreeModel, &TreeIter) + 'static>>);
}
impl<O: IsA<CellLayout>> CellLayoutExt for O {
fn add_attribute<P: IsA<CellRenderer>>(&self, cell: &P, attribute: &str, column: i32) {
unsafe {
ffi::gtk_cell_layout_add_attribute(self.as_ref().to_glib_none().0, cell.as_ref().to_glib_none().0, attribute.to_glib_none().0, column);
}
}
fn clear(&self) {
unsafe {
ffi::gtk_cell_layout_clear(self.as_ref().to_glib_none().0);
}
}
fn clear_attributes<P: IsA<CellRenderer>>(&self, cell: &P) {
unsafe {
ffi::gtk_cell_layout_clear_attributes(self.as_ref().to_glib_none().0, cell.as_ref().to_glib_none().0);
}
}
fn get_area(&self) -> Option<CellArea> {
unsafe {
from_glib_none(ffi::gtk_cell_layout_get_area(self.as_ref().to_glib_none().0))
}
}
fn get_cells(&self) -> Vec<CellRenderer> {
unsafe {
FromGlibPtrContainer::from_glib_container(ffi::gtk_cell_layout_get_cells(self.as_ref().to_glib_none().0))
}
}
fn pack_end<P: IsA<CellRenderer>>(&self, cell: &P, expand: bool) {
unsafe {
ffi::gtk_cell_layout_pack_end(self.as_ref().to_glib_none().0, cell.as_ref().to_glib_none().0, expand.to_glib());
}
}
fn pack_start<P: IsA<CellRenderer>>(&self, cell: &P, expand: bool) {
unsafe {
ffi::gtk_cell_layout_pack_start(self.as_ref().to_glib_none().0, cell.as_ref().to_glib_none().0, expand.to_glib());
}
}
fn reorder<P: IsA<CellRenderer>>(&self, cell: &P, position: i32) {
unsafe {
ffi::gtk_cell_layout_reorder(self.as_ref().to_glib_none().0, cell.as_ref().to_glib_none().0, position);
}
}
fn set_cell_data_func<P: IsA<CellRenderer>>(&self, cell: &P, func: Option<Box<dyn Fn(&CellLayout, &CellRenderer, &TreeModel, &TreeIter) + 'static>>) {
let func_data: Box_<Option<Box<dyn Fn(&CellLayout, &CellRenderer, &TreeModel, &TreeIter) + 'static>>> = Box::new(func);
unsafe extern "C" fn func_func<P: IsA<CellRenderer>>(cell_layout: *mut ffi::GtkCellLayout, cell: *mut ffi::GtkCellRenderer, tree_model: *mut ffi::GtkTreeModel, iter: *mut ffi::GtkTreeIter, data: glib_ffi::gpointer) {
let cell_layout = from_glib_borrow(cell_layout);
let cell = from_glib_borrow(cell);
let tree_model = from_glib_borrow(tree_model);
let iter = from_glib_borrow(iter);
let callback: &Option<Box<dyn Fn(&CellLayout, &CellRenderer, &TreeModel, &TreeIter) + 'static>> = &*(data as *mut _);
if let Some(ref callback) = *callback {
callback(&cell_layout, &cell, &tree_model, &iter)
} else {
panic!("cannot get closure...")
};
}
let func = if func_data.is_some() { Some(func_func::<P> as _) } else { None };
unsafe extern "C" fn destroy_func<P: IsA<CellRenderer>>(data: glib_ffi::gpointer) {
let _callback: Box_<Option<Box<dyn Fn(&CellLayout, &CellRenderer, &TreeModel, &TreeIter) + 'static>>> = Box_::from_raw(data as *mut _);
}
let destroy_call4 = Some(destroy_func::<P> as _);
let super_callback0: Box_<Option<Box<dyn Fn(&CellLayout, &CellRenderer, &TreeModel, &TreeIter) + 'static>>> = func_data;
unsafe {
ffi::gtk_cell_layout_set_cell_data_func(self.as_ref().to_glib_none().0, cell.as_ref().to_glib_none().0, func, Box::into_raw(super_callback0) as *mut _, destroy_call4);
}
}
}
impl fmt::Display for CellLayout {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "CellLayout")
}
}