use std::cell::Cell;
use std::rc::Rc;
#[allow(unused_imports)]
use std::marker::PhantomData;
#[allow(unused_imports)]
use std::os::raw::c_void;
#[allow(unused_imports)]
use std::mem::transmute;
#[allow(unused_imports)]
use std::ffi::{CStr, CString};
use rute_ffi_base::*;
#[allow(unused_imports)]
use auto::*;
#[derive(Clone)]
pub struct Pen<'a> {
#[doc(hidden)]
pub data: Rc<Cell<Option<*const RUBase>>>,
#[doc(hidden)]
pub all_funcs: *const RUPenAllFuncs,
#[doc(hidden)]
pub owned: bool,
#[doc(hidden)]
pub _marker: PhantomData<::std::cell::Cell<&'a ()>>,
}
impl<'a> Pen<'a> {
pub fn new() -> Pen<'a> {
let data = Rc::new(Cell::new(None));
let ffi_data = unsafe {
((*rute_ffi_get()).create_pen)(
::std::ptr::null(),
transmute(rute_object_delete_callback as usize),
Rc::into_raw(data.clone()) as *const c_void,
)
};
data.set(Some(ffi_data.qt_data));
Pen {
data,
all_funcs: ffi_data.all_funcs,
owned: true,
_marker: PhantomData,
}
}
#[allow(dead_code)]
pub(crate) fn new_from_rc(ffi_data: RUPen) -> Pen<'a> {
Pen {
data: unsafe { Rc::from_raw(ffi_data.host_data as *const Cell<Option<*const RUBase>>) },
all_funcs: ffi_data.all_funcs,
owned: false,
_marker: PhantomData,
}
}
#[allow(dead_code)]
pub(crate) fn new_from_owned(ffi_data: RUPen) -> Pen<'a> {
Pen {
data: Rc::new(Cell::new(Some(ffi_data.qt_data as *const RUBase))),
all_funcs: ffi_data.all_funcs,
owned: true,
_marker: PhantomData,
}
}
#[allow(dead_code)]
pub(crate) fn new_from_temporary(ffi_data: RUPen) -> Pen<'a> {
Pen {
data: Rc::new(Cell::new(Some(ffi_data.qt_data as *const RUBase))),
all_funcs: ffi_data.all_funcs,
owned: false,
_marker: PhantomData,
}
}
pub fn swap<P: PenTrait<'a>>(&self, other: &P) -> &Self {
let (obj_other_1, _funcs) = other.get_pen_obj_funcs();
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
((*funcs).swap)(obj_data, obj_other_1);
}
self
}
pub fn style(&self) -> PenStyle {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
let ret_val = ((*funcs).style)(obj_data);
let ret_val = { transmute::<u32, PenStyle>(ret_val) };
ret_val
}
}
pub fn set_style(&self, arg0: PenStyle) -> &Self {
let enum_arg0_1 = arg0 as u32;
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
((*funcs).set_style)(obj_data, enum_arg0_1);
}
self
}
pub fn dash_pattern(&self) -> PrimitiveArray<f32> {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
let ret_val = ((*funcs).dash_pattern)(obj_data);
let ret_val = PrimitiveArray::<f32>::new(ret_val);
ret_val
}
}
pub fn dash_offset(&self) -> f32 {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
let ret_val = ((*funcs).dash_offset)(obj_data);
ret_val
}
}
pub fn set_dash_offset(&self, doffset: f32) -> &Self {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
((*funcs).set_dash_offset)(obj_data, doffset);
}
self
}
pub fn miter_limit(&self) -> f32 {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
let ret_val = ((*funcs).miter_limit)(obj_data);
ret_val
}
}
pub fn set_miter_limit(&self, limit: f32) -> &Self {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
((*funcs).set_miter_limit)(obj_data, limit);
}
self
}
pub fn width_f(&self) -> f32 {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
let ret_val = ((*funcs).width_f)(obj_data);
ret_val
}
}
pub fn set_width_f(&self, width: f32) -> &Self {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
((*funcs).set_width_f)(obj_data, width);
}
self
}
pub fn width(&self) -> i32 {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
let ret_val = ((*funcs).width)(obj_data);
ret_val
}
}
pub fn set_width(&self, width: i32) -> &Self {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
((*funcs).set_width)(obj_data, width);
}
self
}
pub fn color(&self) -> Color {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
let ret_val = ((*funcs).color)(obj_data);
let t = ret_val;
let ret_val;
if t.host_data != ::std::ptr::null() {
ret_val = Color::new_from_rc(t);
} else {
ret_val = Color::new_from_owned(t);
}
ret_val
}
}
pub fn set_color<C: ColorTrait<'a>>(&self, color: &C) -> &Self {
let (obj_color_1, _funcs) = color.get_color_obj_funcs();
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
((*funcs).set_color)(obj_data, obj_color_1);
}
self
}
pub fn brush(&self) -> Brush {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
let ret_val = ((*funcs).brush)(obj_data);
let t = ret_val;
let ret_val;
if t.host_data != ::std::ptr::null() {
ret_val = Brush::new_from_rc(t);
} else {
ret_val = Brush::new_from_owned(t);
}
ret_val
}
}
pub fn set_brush<B: BrushTrait<'a>>(&self, brush: &B) -> &Self {
let (obj_brush_1, _funcs) = brush.get_brush_obj_funcs();
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
((*funcs).set_brush)(obj_data, obj_brush_1);
}
self
}
pub fn is_solid(&self) -> bool {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
let ret_val = ((*funcs).is_solid)(obj_data);
ret_val
}
}
pub fn cap_style(&self) -> PenCapStyle {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
let ret_val = ((*funcs).cap_style)(obj_data);
let ret_val = { transmute::<u32, PenCapStyle>(ret_val) };
ret_val
}
}
pub fn set_cap_style(&self, pcs: PenCapStyle) -> &Self {
let enum_pcs_1 = pcs as u32;
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
((*funcs).set_cap_style)(obj_data, enum_pcs_1);
}
self
}
pub fn join_style(&self) -> PenJoinStyle {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
let ret_val = ((*funcs).join_style)(obj_data);
let ret_val = PenJoinStyle::from_bits_truncate(ret_val);
ret_val
}
}
pub fn set_join_style(&self, pcs: PenJoinStyle) -> &Self {
let enum_pcs_1 = pcs.bits();
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
((*funcs).set_join_style)(obj_data, enum_pcs_1);
}
self
}
pub fn is_cosmetic(&self) -> bool {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
let ret_val = ((*funcs).is_cosmetic)(obj_data);
ret_val
}
}
pub fn set_cosmetic(&self, cosmetic: bool) -> &Self {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
((*funcs).set_cosmetic)(obj_data, cosmetic);
}
self
}
pub fn is_detached(&self) -> bool {
let (obj_data, funcs) = self.get_pen_obj_funcs();
unsafe {
let ret_val = ((*funcs).is_detached)(obj_data);
ret_val
}
}
pub fn build(&self) -> Self {
self.clone()
}
}
pub trait PenTrait<'a> {
#[inline]
#[doc(hidden)]
fn get_pen_obj_funcs(&self) -> (*const RUBase, *const RUPenFuncs);
}
impl<'a> PenTrait<'a> for Pen<'a> {
#[doc(hidden)]
fn get_pen_obj_funcs(&self) -> (*const RUBase, *const RUPenFuncs) {
let obj = self.data.get().unwrap();
unsafe { (obj, (*self.all_funcs).pen_funcs) }
}
}