nalgebra/src/structs/pnt_macros.rs

143 lines
3.8 KiB
Rust
Raw Normal View History

#![macro_escape]
macro_rules! orig_impl(
($t: ident, $comp0: ident $(,$compN: ident)*) => (
impl<N: Zero> Orig for $t<N> {
#[inline]
fn orig() -> $t<N> {
$t {
$comp0: ::zero()
$(, $compN: ::zero() )*
}
}
#[inline]
fn is_orig(&self) -> bool {
self.$comp0.is_zero() $(&& self.$compN.is_zero() )*
}
}
)
);
macro_rules! pnt_sub_impl(
($t: ident, $tv: ident) => (
impl<N: Copy + Sub<N, N>> Sub<$t<N>, $tv<N>> for $t<N> {
#[inline]
fn sub(self, right: $t<N>) -> $tv<N> {
*self.as_vec() - *right.as_vec()
}
}
)
);
macro_rules! pnt_add_vec_impl(
($t: ident, $tv: ident, $comp0: ident $(,$compN: ident)*) => (
impl<N: Copy + Add<N, N>> Add<$tv<N>, $t<N>> for $t<N> {
#[inline]
fn add(self, right: $tv<N>) -> $t<N> {
$t::new(self.$comp0 + right.$comp0 $(, self.$compN + right.$compN)*)
}
}
)
);
macro_rules! pnt_sub_vec_impl(
($t: ident, $tv: ident, $comp0: ident $(,$compN: ident)*) => (
impl<N: Copy + Sub<N, N>> Sub<$tv<N>, $t<N>> for $t<N> {
#[inline]
fn sub(self, right: $tv<N>) -> $t<N> {
$t::new(self.$comp0 - right.$comp0 $(, self.$compN - right.$compN)*)
}
}
)
);
macro_rules! pnt_as_vec_impl(
2014-10-10 18:19:37 +08:00
($t: ident, $tv: ident, $comp0: ident $(,$compN: ident)*) => (
impl<N> $t<N> {
2014-10-12 16:35:56 +08:00
/// Converts this point to its associated vector.
2014-10-10 18:19:37 +08:00
#[inline]
pub fn to_vec(self) -> $tv<N> {
$tv::new(
self.$comp0
$(, self.$compN)*
)
}
2014-10-12 16:35:56 +08:00
/// Converts a reference to this point to a reference to its associated vector.
#[inline]
pub fn as_vec<'a>(&'a self) -> &'a $tv<N> {
unsafe {
mem::transmute(self)
}
}
2014-10-11 02:56:40 +08:00
#[inline]
fn set_coords(&mut self, v: $tv<N>) {
self.$comp0 = v.$comp0;
$(self.$compN = v.$compN;)*
}
}
impl<N> PntAsVec<$tv<N>> for $t<N> {
2014-10-10 18:19:37 +08:00
#[inline]
fn to_vec(self) -> $tv<N> {
self.to_vec()
}
#[inline]
fn as_vec<'a>(&'a self) -> &'a $tv<N> {
self.as_vec()
}
2014-10-11 02:56:40 +08:00
#[inline]
fn set_coords(&mut self, v: $tv<N>) {
self.set_coords(v)
}
}
)
);
macro_rules! pnt_to_homogeneous_impl(
($t: ident, $t2: ident, $extra: ident, $comp0: ident $(,$compN: ident)*) => (
impl<N: Copy + One + Zero> ToHomogeneous<$t2<N>> for $t<N> {
fn to_homogeneous(&self) -> $t2<N> {
let mut res: $t2<N> = Orig::orig();
res.$comp0 = self.$comp0;
$( res.$compN = self.$compN; )*
res.$extra = ::one();
res
}
}
)
);
macro_rules! pnt_from_homogeneous_impl(
($t: ident, $t2: ident, $extra: ident, $comp0: ident $(,$compN: ident)*) => (
impl<N: Copy + Div<N, N> + One + Zero> FromHomogeneous<$t2<N>> for $t<N> {
fn from(v: &$t2<N>) -> $t<N> {
let mut res: $t<N> = Orig::orig();
res.$comp0 = v.$comp0 / v.$extra;
$( res.$compN = v.$compN / v.$extra; )*
res
}
}
)
);
macro_rules! num_float_pnt_impl(
($t: ident, $tv: ident) => (
impl<N> NumPnt<N, $tv<N>> for $t<N>
where N: BaseNum {
}
impl<N> FloatPnt<N, $tv<N>> for $t<N>
where N: BaseFloat + ApproxEq<N> {
}
)
);