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
use Actionable;
use Bin;
use Buildable;
use CheckMenuItem;
use Container;
use MenuItem;
use Widget;
use ffi;
use glib::object::Cast;
use glib::object::IsA;
use glib::signal::SignalHandlerId;
use glib::signal::connect_raw;
use glib::translate::*;
use glib_ffi;
use std::boxed::Box as Box_;
use std::fmt;
use std::mem::transmute;
glib_wrapper! {
pub struct RadioMenuItem(Object<ffi::GtkRadioMenuItem, ffi::GtkRadioMenuItemClass, RadioMenuItemClass>) @extends CheckMenuItem, MenuItem, Bin, Container, Widget, @implements Buildable, Actionable;
match fn {
get_type => || ffi::gtk_radio_menu_item_get_type(),
}
}
impl RadioMenuItem {
pub fn new_from_widget<P: IsA<RadioMenuItem>>(group: &P) -> RadioMenuItem {
skip_assert_initialized!();
unsafe {
Widget::from_glib_none(ffi::gtk_radio_menu_item_new_from_widget(group.as_ref().to_glib_none().0)).unsafe_cast()
}
}
pub fn new_with_label_from_widget<'a, P: IsA<RadioMenuItem>, Q: Into<Option<&'a str>>>(group: &P, label: Q) -> RadioMenuItem {
skip_assert_initialized!();
let label = label.into();
unsafe {
Widget::from_glib_none(ffi::gtk_radio_menu_item_new_with_label_from_widget(group.as_ref().to_glib_none().0, label.to_glib_none().0)).unsafe_cast()
}
}
pub fn new_with_mnemonic_from_widget<'a, P: IsA<RadioMenuItem>, Q: Into<Option<&'a str>>>(group: &P, label: Q) -> RadioMenuItem {
skip_assert_initialized!();
let label = label.into();
unsafe {
Widget::from_glib_none(ffi::gtk_radio_menu_item_new_with_mnemonic_from_widget(group.as_ref().to_glib_none().0, label.to_glib_none().0)).unsafe_cast()
}
}
}
pub const NONE_RADIO_MENU_ITEM: Option<&RadioMenuItem> = None;
pub trait RadioMenuItemExt: 'static {
fn get_group(&self) -> Vec<RadioMenuItem>;
#[cfg(any(feature = "v3_18", feature = "dox"))]
fn join_group<'a, P: IsA<RadioMenuItem> + 'a, Q: Into<Option<&'a P>>>(&self, group_source: Q);
fn connect_group_changed<F: Fn(&Self) + 'static>(&self, f: F) -> SignalHandlerId;
}
impl<O: IsA<RadioMenuItem>> RadioMenuItemExt for O {
fn get_group(&self) -> Vec<RadioMenuItem> {
unsafe {
FromGlibPtrContainer::from_glib_none(ffi::gtk_radio_menu_item_get_group(self.as_ref().to_glib_none().0))
}
}
#[cfg(any(feature = "v3_18", feature = "dox"))]
fn join_group<'a, P: IsA<RadioMenuItem> + 'a, Q: Into<Option<&'a P>>>(&self, group_source: Q) {
let group_source = group_source.into();
unsafe {
ffi::gtk_radio_menu_item_join_group(self.as_ref().to_glib_none().0, group_source.map(|p| p.as_ref()).to_glib_none().0);
}
}
fn connect_group_changed<F: Fn(&Self) + 'static>(&self, f: F) -> SignalHandlerId {
unsafe {
let f: Box_<F> = Box_::new(f);
connect_raw(self.as_ptr() as *mut _, b"group-changed\0".as_ptr() as *const _,
Some(transmute(group_changed_trampoline::<Self, F> as usize)), Box_::into_raw(f))
}
}
}
unsafe extern "C" fn group_changed_trampoline<P, F: Fn(&P) + 'static>(this: *mut ffi::GtkRadioMenuItem, f: glib_ffi::gpointer)
where P: IsA<RadioMenuItem> {
let f: &F = transmute(f);
f(&RadioMenuItem::from_glib_borrow(this).unsafe_cast())
}
impl fmt::Display for RadioMenuItem {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "RadioMenuItem")
}
}