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
use crate::DropTarget;
use glib::signal::connect_raw;
use glib::Type;
use glib::{translate::*, value::FromValue, ObjectType, SignalHandlerId};
use std::boxed::Box as Box_;
use std::mem::transmute;
impl DropTarget {
#[doc(alias = "gtk_drop_target_set_gtypes")]
pub fn set_types(&self, types: &[Type]) {
let types: Vec<glib::ffi::GType> = types.iter().map(|t| t.into_glib()).collect();
unsafe {
ffi::gtk_drop_target_set_gtypes(
self.to_glib_none().0,
mut_override(types.as_ptr()),
types.len(),
)
}
}
#[doc(alias = "gtk_drop_target_get_value")]
#[doc(alias = "get_value")]
pub fn value_as<V: for<'b> FromValue<'b> + 'static>(&self) -> Option<V> {
self.value().map(|v| {
v.get_owned::<V>()
.expect("Failed to get value as this type")
})
}
#[doc(alias = "gtk_drop_target_get_gtypes")]
#[doc(alias = "get_gtypes")]
pub fn types(&self) -> Vec<Type> {
unsafe {
let mut n_types = std::mem::MaybeUninit::uninit();
let types =
ffi::gtk_drop_target_get_gtypes(self.to_glib_none().0, n_types.as_mut_ptr());
FromGlibContainer::from_glib_none_num(types, n_types.assume_init() as usize)
}
}
pub fn connect_drop<F: Fn(&DropTarget, &glib::Value, f64, f64) -> bool + 'static>(
&self,
f: F,
) -> SignalHandlerId {
unsafe extern "C" fn drop_trampoline<
F: Fn(&DropTarget, &glib::Value, f64, f64) -> bool + 'static,
>(
this: *mut ffi::GtkDropTarget,
value: *mut glib::gobject_ffi::GValue,
x: libc::c_double,
y: libc::c_double,
f: glib::ffi::gpointer,
) -> glib::ffi::gboolean {
let f: &F = &*(f as *const F);
f(
&from_glib_borrow(this),
&*(value as *const glib::Value),
x,
y,
)
.into_glib()
}
unsafe {
let f: Box_<F> = Box_::new(f);
connect_raw(
self.as_ptr() as *mut _,
b"drop\0".as_ptr() as *const _,
Some(transmute::<_, unsafe extern "C" fn()>(
drop_trampoline::<F> as *const (),
)),
Box_::into_raw(f),
)
}
}
}