#![macro_escape] macro_rules! submat_impl( ($t: ident, $submat: ident) => ( impl $t { #[inline] pub fn submat<'r>(&'r self) -> &'r $submat { &self.submat } } ) ) macro_rules! rotate_impl( ($t: ident, $tv: ident, $tp: ident) => ( impl Rotate<$tv> for $t { #[inline] fn rotate(&self, v: &$tv) -> $tv { *self * *v } #[inline] fn inv_rotate(&self, v: &$tv) -> $tv { *v * *self } } impl Rotate<$tp> for $t { #[inline] fn rotate(&self, p: &$tp) -> $tp { *self * *p } #[inline] fn inv_rotate(&self, p: &$tp) -> $tp { *p * *self } } ) ) macro_rules! transform_impl( ($t: ident, $tv: ident, $tp: ident) => ( impl Transform<$tv> for $t { #[inline] fn transform(&self, v: &$tv) -> $tv { self.rotate(v) } #[inline] fn inv_transform(&self, v: &$tv) -> $tv { self.inv_rotate(v) } } impl Transform<$tp> for $t { #[inline] fn transform(&self, p: &$tp) -> $tp { self.rotate(p) } #[inline] fn inv_transform(&self, p: &$tp) -> $tp { self.inv_rotate(p) } } ) ) macro_rules! dim_impl( ($t: ident, $dim: expr) => ( impl Dim for $t { #[inline] fn dim(_: Option<$t>) -> uint { $dim } } ) ) macro_rules! rotation_matrix_impl( ($t: ident, $tlv: ident, $tav: ident) => ( impl + BaseFloat> RotationMatrix, $tav, $t> for $t { #[inline] fn to_rot_mat(&self) -> $t { self.clone() } } ) ) macro_rules! one_impl( ($t: ident) => ( impl One for $t { #[inline] fn one() -> $t { $t { submat: ::one() } } } ) ) macro_rules! rot_mul_rot_impl( ($t: ident) => ( impl Mul<$t, $t> for $t { #[inline] fn mul(&self, right: &$t) -> $t { $t { submat: self.submat * right.submat } } } ) ) macro_rules! rot_mul_vec_impl( ($t: ident, $tv: ident) => ( impl Mul<$tv, $tv> for $t { #[inline] fn mul(&self, right: &$tv) -> $tv { self.submat * *right } } ) ) macro_rules! rot_mul_pnt_impl( ($t: ident, $tv: ident) => ( rot_mul_vec_impl!($t, $tv) ) ) macro_rules! vec_mul_rot_impl( ($t: ident, $tv: ident) => ( impl Mul<$t, $tv> for $tv { #[inline] fn mul(&self, right: &$t) -> $tv { *self * right.submat } } ) ) macro_rules! pnt_mul_rot_impl( ($t: ident, $tv: ident) => ( vec_mul_rot_impl!($t, $tv) ) ) macro_rules! inv_impl( ($t: ident) => ( impl Inv for $t { #[inline] fn inv(&mut self) -> bool { self.transpose(); // always succeed true } #[inline] fn inv_cpy(m: &$t) -> Option<$t> { // always succeed Some(Transpose::transpose_cpy(m)) } } ) ) macro_rules! transpose_impl( ($t: ident) => ( impl Transpose for $t { #[inline] fn transpose_cpy(m: &$t) -> $t { $t { submat: Transpose::transpose_cpy(&m.submat) } } #[inline] fn transpose(&mut self) { self.submat.transpose() } } ) ) macro_rules! row_impl( ($t: ident, $tv: ident) => ( impl Row<$tv> for $t { #[inline] fn nrows(&self) -> uint { self.submat.nrows() } #[inline] fn row(&self, i: uint) -> $tv { self.submat.row(i) } #[inline] fn set_row(&mut self, i: uint, row: $tv) { self.submat.set_row(i, row); } } ) ) macro_rules! col_impl( ($t: ident, $tv: ident) => ( impl Col<$tv> for $t { #[inline] fn ncols(&self) -> uint { self.submat.ncols() } #[inline] fn col(&self, i: uint) -> $tv { self.submat.col(i) } #[inline] fn set_col(&mut self, i: uint, col: $tv) { self.submat.set_col(i, col); } } ) ) macro_rules! index_impl( ($t: ident) => ( impl Index<(uint, uint), N> for $t { fn index(&self, i: &(uint, uint)) -> &N { &self.submat[*i] } } impl IndexMut<(uint, uint), N> for $t { fn index_mut(&mut self, i: &(uint, uint)) -> &mut N { &mut self.submat[*i] } } ) ) macro_rules! to_homogeneous_impl( ($t: ident, $tm: ident) => ( impl ToHomogeneous<$tm> for $t { #[inline] fn to_homogeneous(&self) -> $tm { self.submat.to_homogeneous() } } ) ) macro_rules! approx_eq_impl( ($t: ident) => ( impl> ApproxEq for $t { #[inline] fn approx_epsilon(_: Option<$t>) -> N { ApproxEq::approx_epsilon(None::) } #[inline] fn approx_eq(a: &$t, b: &$t) -> bool { ApproxEq::approx_eq(&a.submat, &b.submat) } #[inline] fn approx_eq_eps(a: &$t, b: &$t, epsilon: &N) -> bool { ApproxEq::approx_eq_eps(&a.submat, &b.submat, epsilon) } } ) ) macro_rules! absolute_impl( ($t: ident, $tm: ident) => ( impl> Absolute<$tm> for $t { #[inline] fn abs(m: &$t) -> $tm { Absolute::abs(&m.submat) } } ) )