use super::super::super::*;
use super::*;
use crate::msg::*;
use crate::rcl;
extern "C" {
fn sensor_msgs__msg__LaserEcho__init(msg: *mut LaserEcho) -> bool;
fn sensor_msgs__msg__LaserEcho__fini(msg: *mut LaserEcho);
fn sensor_msgs__msg__LaserEcho__are_equal(lhs: *const LaserEcho, rhs: *const LaserEcho)
-> bool;
fn sensor_msgs__msg__LaserEcho__Sequence__init(msg: *mut LaserEchoSeqRaw, size: usize) -> bool;
fn sensor_msgs__msg__LaserEcho__Sequence__fini(msg: *mut LaserEchoSeqRaw);
fn sensor_msgs__msg__LaserEcho__Sequence__are_equal(
lhs: *const LaserEchoSeqRaw,
rhs: *const LaserEchoSeqRaw,
) -> bool;
fn rosidl_typesupport_c__get_message_type_support_handle__sensor_msgs__msg__LaserEcho(
) -> *const rcl::rosidl_message_type_support_t;
}
#[repr(C)]
#[derive(Debug)]
pub struct LaserEcho {
pub echoes: crate::msg::F32Seq<0>,
}
impl LaserEcho {
pub fn new() -> Option<Self> {
let mut msg: Self = unsafe { std::mem::MaybeUninit::zeroed().assume_init() };
if unsafe { sensor_msgs__msg__LaserEcho__init(&mut msg) } {
Some(msg)
} else {
None
}
}
}
impl Drop for LaserEcho {
fn drop(&mut self) {
unsafe { sensor_msgs__msg__LaserEcho__fini(self) };
}
}
#[repr(C)]
#[derive(Debug)]
struct LaserEchoSeqRaw {
data: *mut LaserEcho,
size: size_t,
capacity: size_t,
}
#[repr(C)]
#[derive(Debug)]
pub struct LaserEchoSeq<const N: usize> {
data: *mut LaserEcho,
size: size_t,
capacity: size_t,
}
impl<const N: usize> LaserEchoSeq<N> {
pub fn new(size: usize) -> Option<Self> {
if N != 0 && size > N {
return None;
}
let mut msg: LaserEchoSeqRaw = unsafe { std::mem::MaybeUninit::zeroed().assume_init() };
if unsafe { sensor_msgs__msg__LaserEcho__Sequence__init(&mut msg, size) } {
Some(Self {
data: msg.data,
size: msg.size,
capacity: msg.capacity,
})
} else {
None
}
}
pub fn null() -> Self {
let msg: LaserEchoSeqRaw = unsafe { std::mem::MaybeUninit::zeroed().assume_init() };
Self {
data: msg.data,
size: msg.size,
capacity: msg.capacity,
}
}
pub fn as_slice(&self) -> &[LaserEcho] {
if self.data.is_null() {
&[]
} else {
let s = unsafe { std::slice::from_raw_parts(self.data, self.size as _) };
s
}
}
pub fn as_slice_mut(&mut self) -> &mut [LaserEcho] {
if self.data.is_null() {
&mut []
} else {
let s = unsafe { std::slice::from_raw_parts_mut(self.data, self.size as _) };
s
}
}
pub fn iter(&self) -> std::slice::Iter<'_, LaserEcho> {
self.as_slice().iter()
}
pub fn iter_mut(&mut self) -> std::slice::IterMut<'_, LaserEcho> {
self.as_slice_mut().iter_mut()
}
pub fn len(&self) -> usize {
self.as_slice().len()
}
pub fn is_empty(&self) -> bool {
self.len() == 0
}
}
impl<const N: usize> Drop for LaserEchoSeq<N> {
fn drop(&mut self) {
let mut msg = LaserEchoSeqRaw {
data: self.data,
size: self.size,
capacity: self.capacity,
};
unsafe { sensor_msgs__msg__LaserEcho__Sequence__fini(&mut msg) };
}
}
unsafe impl<const N: usize> Send for LaserEchoSeq<N> {}
unsafe impl<const N: usize> Sync for LaserEchoSeq<N> {}
impl TypeSupport for LaserEcho {
fn type_support() -> *const rcl::rosidl_message_type_support_t {
unsafe {
rosidl_typesupport_c__get_message_type_support_handle__sensor_msgs__msg__LaserEcho()
}
}
}
impl PartialEq for LaserEcho {
fn eq(&self, other: &Self) -> bool {
unsafe { sensor_msgs__msg__LaserEcho__are_equal(self, other) }
}
}
impl<const N: usize> PartialEq for LaserEchoSeq<N> {
fn eq(&self, other: &Self) -> bool {
unsafe {
let msg1 = LaserEchoSeqRaw {
data: self.data,
size: self.size,
capacity: self.capacity,
};
let msg2 = LaserEchoSeqRaw {
data: other.data,
size: other.size,
capacity: other.capacity,
};
sensor_msgs__msg__LaserEcho__Sequence__are_equal(&msg1, &msg2)
}
}
}