macro_rules! send_sync_read_only {
($name:ident) => {
unsafe impl<'a, A, D> Send for $name<'a, A, D>
where
A: Sync,
D: Send,
{
}
unsafe impl<'a, A, D> Sync for $name<'a, A, D>
where
A: Sync,
D: Sync,
{
}
};
}
macro_rules! send_sync_read_write {
($name:ident) => {
unsafe impl<'a, A, D> Send for $name<'a, A, D>
where
A: Send,
D: Send,
{
}
unsafe impl<'a, A, D> Sync for $name<'a, A, D>
where
A: Sync,
D: Sync,
{
}
};
}
macro_rules! impl_ndproducer {
(
[$($typarm:tt)*]
[Clone => $($cloneparm:tt)*]
$typename:ident {
$base:ident,
$(
$fieldname:ident,
)*
}
$fulltype:ty {
$(
type $atyn:ident = $atyv:ty;
)*
unsafe fn item(&$self_:ident, $ptr:pat) {
$refexpr:expr
}
}) => {
impl<$($typarm)*> NdProducer for $fulltype {
$(
type $atyn = $atyv;
)*
type Ptr = *mut A;
type Stride = isize;
fn raw_dim(&self) -> D {
self.$base.raw_dim()
}
fn layout(&self) -> Layout {
self.$base.layout()
}
fn as_ptr(&self) -> *mut A {
self.$base.as_ptr() as *mut _
}
fn contiguous_stride(&self) -> isize {
self.$base.contiguous_stride()
}
unsafe fn as_ref(&$self_, $ptr: *mut A) -> Self::Item {
$refexpr
}
unsafe fn uget_ptr(&self, i: &Self::Dim) -> *mut A {
self.$base.uget_ptr(i)
}
fn stride_of(&self, axis: Axis) -> isize {
self.$base.stride_of(axis)
}
fn split_at(self, axis: Axis, index: usize) -> (Self, Self) {
let (a, b) = self.$base.split_at(axis, index);
($typename {
$base: a,
$(
$fieldname: self.$fieldname.clone(),
)*
},
$typename {
$base: b,
$(
$fieldname: self.$fieldname,
)*
})
}
private_impl!{}
}
expand_if!(@nonempty [$($cloneparm)*]
impl<$($cloneparm)*> Clone for $fulltype {
fn clone(&self) -> Self {
$typename {
$base: self.base.clone(),
$(
$fieldname: self.$fieldname.clone(),
)*
}
}
}
);
}
}
macro_rules! impl_iterator {
(
[$($typarm:tt)*]
[Clone => $($cloneparm:tt)*]
$typename:ident {
$base:ident,
$(
$fieldname:ident,
)*
}
$fulltype:ty {
type Item = $ity:ty;
fn item(&mut $self_:ident, $elt:pat) {
$refexpr:expr
}
}) => {
expand_if!(@nonempty [$($cloneparm)*]
impl<$($cloneparm)*> Clone for $fulltype {
fn clone(&self) -> Self {
$typename {
$base: self.$base.clone(),
$(
$fieldname: self.$fieldname.clone(),
)*
}
}
}
);
impl<$($typarm)*> Iterator for $fulltype {
type Item = $ity;
fn next(&mut $self_) -> Option<Self::Item> {
$self_.$base.next().map(|$elt| {
$refexpr
})
}
fn size_hint(&self) -> (usize, Option<usize>) {
self.$base.size_hint()
}
}
}
}